brotherton-erpnext/erpnext/startup/boot.py

76 lines
2.5 KiB
Python
Raw Normal View History

# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
# License: GNU General Public License v3. See license.txt"
2014-02-14 10:17:51 +00:00
import frappe
from frappe.utils import cint
def boot_session(bootinfo):
"""boot session - send website info if guest"""
2014-05-31 05:06:04 +00:00
2022-03-28 13:22:46 +00:00
bootinfo.custom_css = frappe.db.get_value("Style Settings", None, "custom_css") or ""
2022-03-28 13:22:46 +00:00
if frappe.session["user"] != "Guest":
2014-05-31 05:06:04 +00:00
update_page_info(bootinfo)
2022-03-28 13:22:46 +00:00
bootinfo.sysdefaults.territory = frappe.db.get_single_value("Selling Settings", "territory")
bootinfo.sysdefaults.customer_group = frappe.db.get_single_value(
"Selling Settings", "customer_group"
)
bootinfo.sysdefaults.allow_stale = cint(
frappe.db.get_single_value("Accounts Settings", "allow_stale")
)
bootinfo.sysdefaults.over_billing_allowance = frappe.db.get_single_value(
"Accounts Settings", "over_billing_allowance"
)
2022-03-28 13:22:46 +00:00
bootinfo.sysdefaults.quotation_valid_till = cint(
frappe.db.get_single_value("CRM Settings", "default_valid_till")
)
2014-05-31 05:06:04 +00:00
bootinfo.sysdefaults.allow_sales_order_creation_for_expired_quotation = cint(
frappe.db.get_single_value(
"Selling Settings", "allow_sales_order_creation_for_expired_quotation"
)
)
# if no company, show a dialog box to create a new company
bootinfo.customer_count = frappe.db.sql("""SELECT count(*) FROM `tabCustomer`""")[0][0]
2013-06-26 11:50:12 +00:00
2014-05-31 05:06:04 +00:00
if not bootinfo.customer_count:
2022-03-28 13:22:46 +00:00
bootinfo.setup_complete = (
frappe.db.sql(
"""SELECT `name`
FROM `tabCompany`
2022-03-28 13:22:46 +00:00
LIMIT 1"""
)
and "Yes"
or "No"
)
2014-05-31 05:06:04 +00:00
2022-03-28 13:22:46 +00:00
bootinfo.docs += frappe.db.sql(
"""select name, default_currency, cost_center, default_selling_terms, default_buying_terms,
default_letter_head, default_bank_account, enable_perpetual_inventory, country from `tabCompany`""",
2022-03-28 13:22:46 +00:00
as_dict=1,
update={"doctype": ":Company"},
)
2022-03-28 13:22:46 +00:00
party_account_types = frappe.db.sql(
""" select name, ifnull(account_type, '') from `tabParty Type`"""
)
2018-05-16 05:32:26 +00:00
bootinfo.party_account_types = frappe._dict(party_account_types)
2022-03-28 13:22:46 +00:00
2014-05-31 05:06:04 +00:00
def update_page_info(bootinfo):
2022-03-28 13:22:46 +00:00
bootinfo.page_info.update(
{
"Chart of Accounts": {"title": "Chart of Accounts", "route": "Tree/Account"},
"Chart of Cost Centers": {"title": "Chart of Cost Centers", "route": "Tree/Cost Center"},
"Item Group Tree": {"title": "Item Group Tree", "route": "Tree/Item Group"},
"Customer Group Tree": {"title": "Customer Group Tree", "route": "Tree/Customer Group"},
"Territory Tree": {"title": "Territory Tree", "route": "Tree/Territory"},
"Sales Person Tree": {"title": "Sales Person Tree", "route": "Tree/Sales Person"},
2014-05-31 05:06:04 +00:00
}
2022-03-28 13:22:46 +00:00
)