* feat: crm settings * feat: CRM Settings * feat: lead and opprtunity section * feat: added CRM Settings in ERPNext Settings workspace * fix: review chnages * added patch * fix: linter issues * fix: linter issues * fix: linter issues * fix: removed crm settings from selling module * fix: raw query to frappe.qb * fix: removed hardcoded value * fix: linter issue * fix: simplify CRM Settings migration patch Co-authored-by: Anupam Kumar <anupam@Anupams-MacBook-Air.local> Co-authored-by: Rucha Mahabal <ruchamahabal2@gmail.com>
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
 | |
| # License: GNU General Public License v3. See license.txt"
 | |
| 
 | |
| 
 | |
| 
 | |
| import frappe
 | |
| from frappe.utils import cint
 | |
| 
 | |
| 
 | |
| def boot_session(bootinfo):
 | |
| 	"""boot session - send website info if guest"""
 | |
| 
 | |
| 	bootinfo.custom_css = frappe.db.get_value('Style Settings', None, 'custom_css') or ''
 | |
| 
 | |
| 	if frappe.session['user']!='Guest':
 | |
| 		update_page_info(bootinfo)
 | |
| 
 | |
| 		load_country_and_currency(bootinfo)
 | |
| 		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.quotation_valid_till = cint(frappe.db.get_single_value('CRM Settings',
 | |
| 			'default_valid_till'))
 | |
| 
 | |
| 		# if no company, show a dialog box to create a new company
 | |
| 		bootinfo.customer_count = frappe.db.sql("""SELECT count(*) FROM `tabCustomer`""")[0][0]
 | |
| 
 | |
| 		if not bootinfo.customer_count:
 | |
| 			bootinfo.setup_complete = frappe.db.sql("""SELECT `name`
 | |
| 				FROM `tabCompany`
 | |
| 				LIMIT 1""") and 'Yes' or 'No'
 | |
| 
 | |
| 		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`""",
 | |
| 			as_dict=1, update={"doctype":":Company"})
 | |
| 
 | |
| 		party_account_types = frappe.db.sql(""" select name, ifnull(account_type, '') from `tabParty Type`""")
 | |
| 		bootinfo.party_account_types = frappe._dict(party_account_types)
 | |
| 
 | |
| def load_country_and_currency(bootinfo):
 | |
| 	country = frappe.db.get_default("country")
 | |
| 	if country and frappe.db.exists("Country", country):
 | |
| 		bootinfo.docs += [frappe.get_doc("Country", country)]
 | |
| 
 | |
| 	bootinfo.docs += frappe.db.sql("""select name, fraction, fraction_units,
 | |
| 		number_format, smallest_currency_fraction_value, symbol from tabCurrency
 | |
| 		where enabled=1""", as_dict=1, update={"doctype":":Currency"})
 | |
| 
 | |
| def update_page_info(bootinfo):
 | |
| 	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"
 | |
| 		}
 | |
| 	})
 |