blob: 079ad21e0284031b0c95e219422fca463d345ede [file] [log] [blame]
Rushabh Mehta3966f1d2012-02-23 12:35:32 +05301# ERPNext - web based ERP (http://erpnext.com)
2# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
3#
4# This program is free software: you can redistribute it and/or modify
5# it under the terms of the GNU General Public License as published by
6# the Free Software Foundation, either version 3 of the License, or
7# (at your option) any later version.
8#
9# This program is distributed in the hope that it will be useful,
10# but WITHOUT ANY WARRANTY; without even the implied warranty of
11# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12# GNU General Public License for more details.
13#
14# You should have received a copy of the GNU General Public License
15# along with this program. If not, see <http://www.gnu.org/licenses/>.
16
Anand Doshi486f9df2012-07-19 13:40:31 +053017from __future__ import unicode_literals
Rushabh Mehta571377a2012-12-07 11:00:26 +053018
19import os
20import conf
Rushabh Mehtaab1148c2012-01-31 18:01:16 +053021import webnotes
Rushabh Mehta571377a2012-12-07 11:00:26 +053022from webnotes.utils import cstr
23
Rushabh Mehtaa494b882012-12-07 12:44:45 +053024page_map = {
25 'Web Page': webnotes._dict({
26 "template": 'html/web_page.html',
27 "condition_field": "published"
28 }),
29 'Blog': webnotes._dict({
30 "template": 'html/blog_page.html',
31 "condition_field": "published",
32 }),
33 'Item': webnotes._dict({
34 "template": 'html/product_page.html',
35 "condition_field": "show_in_website",
Rushabh Mehta173a0fd2012-12-14 16:39:27 +053036 }),
37 'Item Group': webnotes._dict({
38 "template": "html/product_group.html",
39 "condition_field": "show_in_website"
Rushabh Mehtaa494b882012-12-07 12:44:45 +053040 })
Rushabh Mehta571377a2012-12-07 11:00:26 +053041}
Rushabh Mehtaab1148c2012-01-31 18:01:16 +053042
Rushabh Mehta89c7b412012-12-06 14:58:44 +053043def render(page_name):
44 """render html page"""
Rushabh Mehta89c7b412012-12-06 14:58:44 +053045 try:
46 if page_name:
47 html = get_html(page_name)
48 else:
49 html = get_html('index')
50 except Exception, e:
Rushabh Mehtae109fa42012-12-19 10:14:59 +053051 html = get_html('error')
Rushabh Mehta89c7b412012-12-06 14:58:44 +053052
53 from webnotes.handler import eprint, print_zip
54 eprint("Content-Type: text/html")
55 print_zip(html)
56
57def get_html(page_name):
58 """get page html"""
59 page_name = scrub_page_name(page_name)
Rushabh Mehta89c7b412012-12-06 14:58:44 +053060
Rushabh Mehta571377a2012-12-07 11:00:26 +053061 html = ''
62
63 # load from cache, if auto cache clear is falsy
64 if not (hasattr(conf, 'auto_cache_clear') and conf.auto_cache_clear or 0):
65 html = webnotes.cache().get_value("page:" + page_name)
Rushabh Mehtae109fa42012-12-19 10:14:59 +053066 from_cache = True
Rushabh Mehta571377a2012-12-07 11:00:26 +053067
Rushabh Mehtae109fa42012-12-19 10:14:59 +053068 if not html:
Rushabh Mehta571377a2012-12-07 11:00:26 +053069 html = load_into_cache(page_name)
Rushabh Mehtae109fa42012-12-19 10:14:59 +053070 from_cache = False
Rushabh Mehta571377a2012-12-07 11:00:26 +053071
Rushabh Mehtae109fa42012-12-19 10:14:59 +053072 if not html:
73 html = get_html("404")
74
75 if page_name=="error":
76 html = html % {"error": webnotes.getTraceback()}
77 else:
78 comments = "\n\npage:"+page_name+\
79 "\nload status: " + (from_cache and "cache" or "fresh")
80 html += """\n<!-- %s -->""" % webnotes.utils.cstr(comments)
Rushabh Mehta571377a2012-12-07 11:00:26 +053081
Rushabh Mehta89c7b412012-12-06 14:58:44 +053082 return html
Rushabh Mehta89c7b412012-12-06 14:58:44 +053083
Anand Doshi51146c02012-07-12 18:41:12 +053084def scrub_page_name(page_name):
85 if page_name.endswith('.html'):
86 page_name = page_name[:-5]
87
88 return page_name
89
Rushabh Mehtaab1148c2012-01-31 18:01:16 +053090def page_name(title):
Anand Doshi72c945b2012-06-22 20:01:07 +053091 """make page name from title"""
92 import re
93 name = title.lower()
94 name = re.sub('[~!@#$%^&*()<>,."\']', '', name)
95 return '-'.join(name.split()[:4])
Rushabh Mehtadf0b00a2012-12-06 16:15:38 +053096
97def update_page_name(doc, title):
98 """set page_name and check if it is unique"""
Rushabh Mehtaa2e4cb02012-12-06 17:09:38 +053099 webnotes.conn.set(doc, "page_name", page_name(title))
Rushabh Mehtadf0b00a2012-12-06 16:15:38 +0530100
101 res = webnotes.conn.sql("""\
102 select count(*) from `tab%s`
103 where page_name=%s and name!=%s""" % (doc.doctype, '%s', '%s'),
104 (doc.page_name, doc.name))
105 if res and res[0][0] > 0:
106 webnotes.msgprint("""A %s with the same title already exists.
107 Please change the title of %s and save again."""
108 % (doc.doctype, doc.name), raise_exception=1)
Rushabh Mehta571377a2012-12-07 11:00:26 +0530109
110 delete_page_cache(doc.page_name)
111
112def load_into_cache(page_name):
113 args = prepare_args(page_name)
Rushabh Mehtae109fa42012-12-19 10:14:59 +0530114 if not args:
115 return ""
Rushabh Mehta571377a2012-12-07 11:00:26 +0530116 html = build_html(args)
117 webnotes.cache().set_value("page:" + page_name, html)
118 return html
119
120def build_html(args):
121 from jinja2 import Environment, FileSystemLoader
122
123 templates_path = os.path.join(os.path.dirname(conf.__file__),
124 'app', 'website', 'templates')
125
126 jenv = Environment(loader = FileSystemLoader(templates_path))
127 html = jenv.get_template(args['template']).render(args)
128
129 return html
130
131def prepare_args(page_name):
132 if page_name == 'index':
133 page_name = get_home_page()
134
135 if page_name in get_template_pages():
136 args = {
137 'template': 'pages/%s.html' % page_name,
138 'name': page_name,
139 }
140 else:
141 args = get_doc_fields(page_name)
142
Rushabh Mehtae109fa42012-12-19 10:14:59 +0530143 if not args:
144 return False
145
Rushabh Mehta571377a2012-12-07 11:00:26 +0530146 args.update(get_outer_env())
147
148 return args
149
Rushabh Mehtaa494b882012-12-07 12:44:45 +0530150def get_template_pages():
Rushabh Mehta571377a2012-12-07 11:00:26 +0530151 pages_path = os.path.join(os.path.dirname(conf.__file__), 'app',
152 'website', 'templates', 'pages')
153 page_list = []
154 for page in os.listdir(pages_path):
155 page_list.append(scrub_page_name(page))
156
157 return page_list
158
159def get_doc_fields(page_name):
160 doc_type, doc_name = get_source_doc(page_name)
Rushabh Mehtae109fa42012-12-19 10:14:59 +0530161 if not doc_type:
162 return False
163
Rushabh Mehta0e9e8482012-12-17 16:00:34 +0530164 obj = webnotes.get_obj(doc_type, doc_name, with_children=True)
Rushabh Mehtaa494b882012-12-07 12:44:45 +0530165
Rushabh Mehta571377a2012-12-07 11:00:26 +0530166 if hasattr(obj, 'prepare_template_args'):
167 obj.prepare_template_args()
Rushabh Mehtaa494b882012-12-07 12:44:45 +0530168
Rushabh Mehta571377a2012-12-07 11:00:26 +0530169 args = obj.doc.fields
Rushabh Mehtaa494b882012-12-07 12:44:45 +0530170 args['template'] = page_map[doc_type].template
Rushabh Mehta0e9e8482012-12-17 16:00:34 +0530171 args['obj'] = obj
Rushabh Mehtafc19f252012-12-20 17:11:51 +0530172 args['int'] = int
Rushabh Mehta571377a2012-12-07 11:00:26 +0530173
174 return args
175
176def get_source_doc(page_name):
177 """get source doc for the given page name"""
Rushabh Mehtaa494b882012-12-07 12:44:45 +0530178 for doctype in page_map:
Rushabh Mehta571377a2012-12-07 11:00:26 +0530179 name = webnotes.conn.sql("""select name from `tab%s` where
Rushabh Mehtaa494b882012-12-07 12:44:45 +0530180 page_name=%s and ifnull(%s, 0)=1""" % (doctype, "%s",
181 page_map[doctype].condition_field), page_name)
Rushabh Mehta571377a2012-12-07 11:00:26 +0530182 if name:
Rushabh Mehtaa494b882012-12-07 12:44:45 +0530183 return doctype, name[0][0]
184
Rushabh Mehta571377a2012-12-07 11:00:26 +0530185 return None, None
186
187def get_outer_env():
188 all_top_items = webnotes.conn.sql("""\
189 select * from `tabTop Bar Item`
190 where parent='Website Settings' and parentfield='top_bar_items'
191 order by idx asc""", as_dict=1)
Rushabh Mehta60cc0cc2012-12-21 10:52:26 +0530192
Rushabh Mehta571377a2012-12-07 11:00:26 +0530193 top_items = [d for d in all_top_items if not d['parent_label']]
194
195 # attach child items to top bar
196 for d in all_top_items:
197 if d['parent_label']:
198 for t in top_items:
199 if t['label']==d['parent_label']:
200 if not 'child_items' in t:
201 t['child_items'] = []
202 t['child_items'].append(d)
203 break
204
Nabin Haitab573ce2012-12-21 11:01:31 +0530205 if top_items and ("products" in [d.url.split(".")[0] for d in top_items if d.url]):
Rushabh Mehtafc19f252012-12-20 17:11:51 +0530206 # product categories
207 products = webnotes.conn.sql("""select t1.item_group as label,
208 concat(t2.page_name, ".html") as url,
209 ifnull(t1.indent,0) as indent
210 from `tabWebsite Product Category` t1, `tabItem Group` t2
211 where t1.item_group = t2.name
212 and ifnull(t2.show_in_website,0)=1 order by t1.idx""", as_dict=1)
213 products_item = filter(lambda d: d.url.split(".")[0]=="products", top_items)[0]
214 products_item.child_items = products
215
Rushabh Mehta571377a2012-12-07 11:00:26 +0530216 return {
217 'top_bar_items': top_items,
Rushabh Mehta571377a2012-12-07 11:00:26 +0530218 'footer_items': webnotes.conn.sql("""\
219 select * from `tabTop Bar Item`
220 where parent='Website Settings' and parentfield='footer_items'
221 order by idx asc""", as_dict=1),
222
223 'brand': webnotes.conn.get_value('Website Settings', None, 'brand_html') or 'ERPNext',
224 'copyright': webnotes.conn.get_value('Website Settings', None, 'copyright'),
Rushabh Mehtafc19f252012-12-20 17:11:51 +0530225 'favicon': webnotes.conn.get_value('Website Settings', None, 'favicon'),
226 'int':int
Rushabh Mehta571377a2012-12-07 11:00:26 +0530227 }
228
229def get_home_page():
230 doc_name = webnotes.conn.get_value('Website Settings', None, 'home_page')
231 if doc_name:
232 page_name = webnotes.conn.get_value('Web Page', doc_name, 'page_name')
233 else:
234 page_name = 'login'
235
236 return page_name
237
Rushabh Mehta98b99bd2012-12-07 12:55:06 +0530238def clear_cache(page_name=None):
Rushabh Mehta571377a2012-12-07 11:00:26 +0530239 if page_name:
240 delete_page_cache(page_name)
241 else:
242 webnotes.cache().delete_keys("page:")
243
244def delete_page_cache(page_name):
245 webnotes.cache().delete_value("page:" + page_name)