175 lines
4.8 KiB
Python
Raw Normal View History

# ERPNext - web based ERP (http://erpnext.com)
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
2012-07-12 18:41:12 +05:30
# html generation functions
from __future__ import unicode_literals
2012-12-06 16:15:38 +05:30
import os
import conf
import webnotes
import website.utils
2012-12-06 16:52:17 +05:30
from webnotes.utils import cstr
2012-12-06 16:15:38 +05:30
2012-07-12 18:41:12 +05:30
template_map = {
'Web Page': 'html/web_page.html',
'Blog': 'html/blog_page.html',
'Item': 'html/product_page.html',
}
2012-12-06 16:15:38 +05:30
def get_page_html(page_name, comments=''):
2012-07-12 18:41:12 +05:30
html = ''
2012-07-12 18:41:12 +05:30
# load from cache, if auto cache clear is falsy
if not (hasattr(conf, 'auto_cache_clear') and conf.auto_cache_clear or 0):
2012-12-06 16:15:38 +05:30
html = webnotes.cache().get_value("page:" + page_name)
comments += "\n\npage load status: fresh"
2012-07-12 18:41:12 +05:30
if not html:
html = load_into_cache(page_name)
comments += "\n\npage load status: cache"
2012-07-12 18:41:12 +05:30
# insert comments
html += """\n<!-- %s -->""" % webnotes.utils.cstr(comments)
2012-06-27 12:06:45 +05:30
return html
2012-12-06 16:15:38 +05:30
def load_into_cache(page_name):
args = prepare_args(page_name)
html = build_html(args)
webnotes.cache().set_value("page:" + page_name, html)
return html
def build_html(args):
2012-12-06 16:15:38 +05:30
templates_path = os.path.join(os.path.dirname(conf.__file__),
'app', 'website', 'templates')
from jinja2 import Environment, FileSystemLoader
jenv = Environment(loader = FileSystemLoader(templates_path))
html = jenv.get_template(args['template']).render(args)
return html
def prepare_args(page_name):
if page_name == 'index':
page_name = get_home_page()
if page_name in get_predefined_pages():
args = {
'template': 'pages/%s.html' % page_name,
'name': page_name,
}
else:
args = get_doc_fields(page_name)
2012-07-12 18:41:12 +05:30
2012-12-06 16:15:38 +05:30
args.update(get_outer_env())
return args
def load_from_cache(page_name):
2012-07-12 18:41:12 +05:30
result = search_cache(page_name)
if not result:
if page_name in get_predefined_pages():
# if a predefined page doesn't exist, load it into cache
return None
else:
# if page doesn't exist, raise exception
raise Exception, "Page %s not found" % page_name
2012-07-12 18:41:12 +05:30
return result[0][0]
2012-12-06 16:15:38 +05:30
def get_predefined_pages():
pages_path = os.path.join(os.path.dirname(conf.__file__), 'app',
'website', 'templates', 'pages')
2012-07-12 18:41:12 +05:30
page_list = []
for page in os.listdir(pages_path):
page_list.append(website.utils.scrub_page_name(page))
return page_list
def get_home_page():
doc_name = webnotes.conn.get_value('Website Settings', None, 'home_page')
if doc_name:
page_name = webnotes.conn.get_value('Web Page', doc_name, 'page_name')
else:
page_name = 'login'
2012-07-12 18:41:12 +05:30
return page_name
def get_doc_fields(page_name):
2012-12-06 16:15:38 +05:30
doc_type, doc_name = get_source_doc(page_name)
2012-07-12 18:41:12 +05:30
2012-12-06 16:15:38 +05:30
obj = webnotes.get_obj(doc_type, doc_name)
2012-07-12 18:41:12 +05:30
if hasattr(obj, 'prepare_template_args'):
obj.prepare_template_args()
args = obj.doc.fields
args['template'] = template_map[doc_type]
return args
2012-12-06 16:15:38 +05:30
def get_source_doc(page_name):
"""get source doc for the given page name"""
for doctype in [('Web Page', 'published'), ('Blog', 'published'),
('Item', 'show_in_website')]:
name = webnotes.conn.sql("""select name from `tab%s` where
page_name=%s and ifnull(`%s`, 0)=1""" % (doctype[0], "%s", doctype[1]),
page_name)
if name:
return doctype[0], name[0][0]
return None, None
2012-09-05 12:32:19 +05:30
2012-12-06 16:15:38 +05:30
def get_outer_env():
2012-09-05 12:32:19 +05:30
all_top_items = webnotes.conn.sql("""\
select * from `tabTop Bar Item`
where parent='Website Settings' and parentfield='top_bar_items'
order by idx asc""", as_dict=1)
top_items = [d for d in all_top_items if not d['parent_label']]
# attach child items to top bar
for d in all_top_items:
if d['parent_label']:
for t in top_items:
if t['label']==d['parent_label']:
if not 'child_items' in t:
t['child_items'] = []
t['child_items'].append(d)
break
return {
2012-09-05 12:32:19 +05:30
'top_bar_items': top_items,
2012-07-12 18:41:12 +05:30
'footer_items': webnotes.conn.sql("""\
select * from `tabTop Bar Item`
where parent='Website Settings' and parentfield='footer_items'
order by idx asc""", as_dict=1),
'brand': webnotes.conn.get_value('Website Settings', None, 'brand_html') or 'ERPNext',
'copyright': webnotes.conn.get_value('Website Settings', None, 'copyright'),
'favicon': webnotes.conn.get_value('Website Settings', None, 'favicon')
}
2012-12-06 18:26:09 +05:30
def clear_cache(page_name):
2012-12-06 16:15:38 +05:30
if page_name:
delete_page_cache(page_name)
else:
2012-12-06 16:15:38 +05:30
webnotes.cache().flush_keys("page:")
2012-12-06 16:15:38 +05:30
def delete_page_cache(page_name):
webnotes.cache().delete_value("page:" + page_name)