Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.
 
 
 
 
 
 

235 rindas
5.6 KiB

  1. # Copyright (c) 2013, Web Notes Technologies Pvt. Ltd.
  2. # MIT License. See license.txt
  3. from __future__ import unicode_literals
  4. import os
  5. import conf
  6. from startup.webutils import *
  7. import webnotes
  8. import webnotes.utils
  9. def render(page_name):
  10. """render html page"""
  11. try:
  12. if page_name:
  13. html = get_html(page_name)
  14. else:
  15. html = get_html('index')
  16. except Exception:
  17. html = get_html('error')
  18. from webnotes.handler import eprint, print_zip
  19. eprint("Content-Type: text/html; charset: utf-8")
  20. print_zip(html)
  21. def get_html(page_name):
  22. """get page html"""
  23. page_name = scrub_page_name(page_name)
  24. html = ''
  25. # load from cache, if auto cache clear is falsy
  26. if not (hasattr(conf, 'auto_cache_clear') and conf.auto_cache_clear or 0):
  27. if not get_page_settings().get(page_name, {}).get("no_cache"):
  28. html = webnotes.cache().get_value("page:" + page_name)
  29. from_cache = True
  30. if not html:
  31. from webnotes.auth import HTTPRequest
  32. webnotes.http_request = HTTPRequest()
  33. #webnotes.connect()
  34. html = load_into_cache(page_name)
  35. from_cache = False
  36. if not html:
  37. html = get_html("404")
  38. if page_name=="error":
  39. html = html.replace("%(error)s", webnotes.getTraceback())
  40. else:
  41. comments = "\n\npage:"+page_name+\
  42. "\nload status: " + (from_cache and "cache" or "fresh")
  43. html += """\n<!-- %s -->""" % webnotes.utils.cstr(comments)
  44. return html
  45. def scrub_page_name(page_name):
  46. if page_name.endswith('.html'):
  47. page_name = page_name[:-5]
  48. return page_name
  49. def page_name(title):
  50. """make page name from title"""
  51. import re
  52. name = title.lower()
  53. name = re.sub('[~!@#$%^&*()<>,."\']', '', name)
  54. name = re.sub('[:/]', '-', name)
  55. name = '-'.join(name.split())
  56. # replace repeating hyphens
  57. name = re.sub(r"(-)\1+", r"\1", name)
  58. return name
  59. def update_page_name(doc, title):
  60. """set page_name and check if it is unique"""
  61. webnotes.conn.set(doc, "page_name", page_name(title))
  62. if doc.page_name in get_standard_pages():
  63. webnotes.conn.sql("""Page Name cannot be one of %s""" % ', '.join(get_standard_pages()))
  64. res = webnotes.conn.sql("""\
  65. select count(*) from `tab%s`
  66. where page_name=%s and name!=%s""" % (doc.doctype, '%s', '%s'),
  67. (doc.page_name, doc.name))
  68. if res and res[0][0] > 0:
  69. webnotes.msgprint("""A %s with the same title already exists.
  70. Please change the title of %s and save again."""
  71. % (doc.doctype, doc.name), raise_exception=1)
  72. delete_page_cache(doc.page_name)
  73. def load_into_cache(page_name):
  74. args = prepare_args(page_name)
  75. if not args:
  76. return ""
  77. html = build_html(args)
  78. webnotes.cache().set_value("page:" + page_name, html)
  79. return html
  80. def build_html(args):
  81. from jinja2 import Environment, FileSystemLoader
  82. args["len"] = len
  83. jenv = Environment(loader = FileSystemLoader(webnotes.utils.get_base_path()))
  84. template_name = args['template']
  85. if not template_name.endswith(".html"):
  86. template_name = template_name + ".html"
  87. html = jenv.get_template(template_name).render(args)
  88. return html
  89. def get_standard_pages():
  90. return webnotes.get_config()["web"]["pages"].keys()
  91. def prepare_args(page_name):
  92. if page_name == 'index':
  93. page_name = get_home_page()
  94. pages = get_page_settings()
  95. if page_name in pages:
  96. page_info = pages[page_name]
  97. args = webnotes._dict({
  98. 'template': page_info["template"],
  99. 'name': page_name,
  100. })
  101. # additional args
  102. if "args_method" in page_info:
  103. args.update(webnotes.get_method(page_info["args_method"])())
  104. elif "args_doctype" in page_info:
  105. bean = webnotes.bean(page_info["args_doctype"])
  106. bean.run_method("onload")
  107. args.obj = bean.make_controller()
  108. else:
  109. args = get_doc_fields(page_name)
  110. if not args:
  111. return False
  112. update_template_args(page_name, args)
  113. return args
  114. def get_doc_fields(page_name):
  115. doc_type, doc_name = get_source_doc(page_name)
  116. if not doc_type:
  117. return False
  118. obj = webnotes.get_obj(doc_type, doc_name, with_children=True)
  119. if hasattr(obj, 'prepare_template_args'):
  120. obj.prepare_template_args()
  121. args = obj.doc.fields
  122. args['template'] = get_generators()[doc_type]["template"]
  123. args['obj'] = obj
  124. args['int'] = int
  125. return args
  126. def get_source_doc(page_name):
  127. """get source doc for the given page name"""
  128. for doctype in get_generators():
  129. name = webnotes.conn.sql("""select name from `tab%s` where
  130. page_name=%s and ifnull(%s, 0)=1""" % (doctype, "%s",
  131. get_generators()[doctype]["condition_field"]), page_name)
  132. if name:
  133. return doctype, name[0][0]
  134. return None, None
  135. def clear_cache(page_name=None):
  136. if page_name:
  137. delete_page_cache(page_name)
  138. else:
  139. cache = webnotes.cache()
  140. for p in get_all_pages():
  141. cache.delete_value("page:" + p)
  142. def get_all_pages():
  143. all_pages = get_standard_pages()
  144. for doctype in get_generators():
  145. all_pages += [p[0] for p in webnotes.conn.sql("""select distinct page_name
  146. from `tab%s`""" % doctype) if p[0]]
  147. return all_pages
  148. def delete_page_cache(page_name):
  149. if page_name:
  150. webnotes.cache().delete_value("page:" + page_name)
  151. def get_hex_shade(color, percent):
  152. def p(c):
  153. v = int(c, 16) + int(int('ff', 16) * (float(percent)/100))
  154. if v < 0:
  155. v=0
  156. if v > 255:
  157. v=255
  158. h = hex(v)[2:]
  159. if len(h) < 2:
  160. h = "0" + h
  161. return h
  162. r, g, b = color[0:2], color[2:4], color[4:6]
  163. avg = (float(int(r, 16) + int(g, 16) + int(b, 16)) / 3)
  164. # switch dark and light shades
  165. if avg > 128:
  166. percent = -percent
  167. # stronger diff for darker shades
  168. if percent < 25 and avg < 64:
  169. percent = percent * 2
  170. return p(r) + p(g) + p(b)
  171. def get_standard_pages():
  172. return webnotes.get_config()["web"]["pages"].keys()
  173. def get_generators():
  174. return webnotes.get_config()["web"]["generators"]
  175. def get_page_settings():
  176. return webnotes.get_config()["web"]["pages"]