182 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			182 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from __future__ import unicode_literals
 | |
| 
 | |
| import webnotes
 | |
| 
 | |
| def pre_import():
 | |
| 	webnotes.conn.begin()
 | |
| 	make_modules()
 | |
| 	make_roles()
 | |
| 	webnotes.conn.commit()
 | |
| 	webnotes.reload_doc("utilities", "doctype", "gl_mapper")
 | |
| 	webnotes.reload_doc("utilities", "doctype", "gl_mapper_detail")
 | |
| 	
 | |
| def make_modules():
 | |
| 	modules = [
 | |
| 		" Home", " System", " Utilities", " Website", " Setup",
 | |
| 		" Selling", " Buying", " Projects", " Accounts", " Stock",
 | |
| 		" Support", " HR", " Manufacturing"]
 | |
| 	
 | |
| 	for m in modules:
 | |
| 		doc = webnotes.doc(fielddata = {
 | |
| 			"doctype": "Module Def",
 | |
| 			"module_name": m,
 | |
| 		})
 | |
| 		doc.insert()
 | |
| 	
 | |
| def make_roles():
 | |
| 	roles = [
 | |
| 		"Accounts Manager", "Accounts User", "Analytics", "Auditor",
 | |
| 		"Blogger", "Customer", "Employee", "Expense Approver",
 | |
| 		"HR Manager", "HR User", "Leave Approver", "Maintenance Manager",
 | |
| 		"Maintenance User", "Manufacturing Manager", "Manufacturing User",
 | |
| 		"Material Manager", "Material Master Manager", "Material User",
 | |
| 		"Partner", "Projects User", "Projects Manager", "Purchase Manager", "Purchase Master Manager",
 | |
| 		"Purchase User", "Quality Manager", "Sales Manager",
 | |
| 		"Sales Master Manager", "Sales User", "Supplier", "Support Manager",
 | |
| 		"Support Team", "Website Manager"]
 | |
| 		
 | |
| 	for r in roles:
 | |
| 		doc = webnotes.doc(fielddata = {
 | |
| 			"doctype":"Role",
 | |
| 			"role_name": r
 | |
| 		})
 | |
| 		doc.insert()
 | |
| 
 | |
| def post_import():
 | |
| 	webnotes.conn.begin()
 | |
| 	# feature setup
 | |
| 	import_defaults()
 | |
| 	import_country_and_currency()
 | |
| 	
 | |
| 	# home page
 | |
| 	webnotes.conn.set_value('Control Panel', None, 'home_page', 'desktop')
 | |
| 
 | |
| 	# features
 | |
| 	feature_setup()
 | |
| 	
 | |
| 	# all roles to Administrator
 | |
| 	from setup.doctype.setup_control.setup_control import add_all_roles_to
 | |
| 	add_all_roles_to("Administrator")
 | |
| 	
 | |
| 	webnotes.conn.commit()
 | |
| 
 | |
| def feature_setup():
 | |
| 	"""save global defaults and features setup"""
 | |
| 	doc = webnotes.doc("Features Setup", "Features Setup")
 | |
| 
 | |
| 	# store value as 1 for all these fields
 | |
| 	flds = ['fs_item_serial_nos', 'fs_item_batch_nos', 'fs_brands', 'fs_item_barcode',
 | |
| 		'fs_item_advanced', 'fs_packing_details', 'fs_item_group_in_details',
 | |
| 		'fs_exports', 'fs_imports', 'fs_discounts', 'fs_purchase_discounts',
 | |
| 		'fs_after_sales_installations', 'fs_projects', 'fs_sales_extras',
 | |
| 		'fs_recurring_invoice', 'fs_pos', 'fs_manufacturing', 'fs_quality',
 | |
| 		'fs_page_break', 'fs_more_info'
 | |
| 	]
 | |
| 	doc.fields.update(dict(zip(flds, [1]*len(flds))))
 | |
| 	doc.save()
 | |
| 
 | |
| def import_country_and_currency():
 | |
| 	from webnotes.country_info import get_all
 | |
| 	data = get_all()
 | |
| 	
 | |
| 	for name in data:
 | |
| 		country = webnotes._dict(data[name])
 | |
| 		webnotes.doc({
 | |
| 			"doctype": "Country",
 | |
| 			"country_name": name,
 | |
| 			"date_format": country.date_format or "dd-mm-yyyy",
 | |
| 			"time_zones": "\n".join(country.timezones or [])
 | |
| 		}).insert()
 | |
| 		
 | |
| 		if country.currency and not webnotes.conn.exists("Currency", country.currency):
 | |
| 			webnotes.doc({
 | |
| 				"doctype": "Currency",
 | |
| 				"currency_name": country.currency,
 | |
| 				"fraction": country.currency_fraction,
 | |
| 				"symbol": country.currency_symbol,
 | |
| 				"fraction_units": country.currency_fraction_units,
 | |
| 				"number_format": country.number_format
 | |
| 			}).insert()
 | |
| 
 | |
| def import_defaults():
 | |
| 	records = [
 | |
| 		# item group
 | |
| 		{'doctype': 'Item Group', 'item_group_name': 'All Item Groups', 'is_group': 'Yes', 'name': 'All Item Groups', 'parent_item_group': ''},
 | |
| 		{'doctype': 'Item Group', 'item_group_name': 'Default', 'is_group': 'No', 'name': 'Default', 'parent_item_group': 'All Item Groups'},
 | |
| 		
 | |
| 		# deduction type
 | |
| 		{'doctype': 'Deduction Type', 'name': 'Income Tax', 'description': 'Income Tax', 'deduction_name': 'Income Tax'},
 | |
| 		{'doctype': 'Deduction Type', 'name': 'Professional Tax', 'description': 'Professional Tax', 'deduction_name': 'Professional Tax'},
 | |
| 		{'doctype': 'Deduction Type', 'name': 'Provident Fund', 'description': 'Provident fund', 'deduction_name': 'Provident Fund'},
 | |
| 		
 | |
| 		# earning type
 | |
| 		{'doctype': 'Earning Type', 'name': 'Basic', 'description': 'Basic', 'earning_name': 'Basic', 'taxable': 'Yes'},
 | |
| 		{'doctype': 'Earning Type', 'name': 'House Rent Allowance', 'description': 'House Rent Allowance', 'earning_name': 'House Rent Allowance', 'taxable': 'No'},
 | |
| 		
 | |
| 		# expense claim type
 | |
| 		{'doctype': 'Expense Claim Type', 'name': 'Calls', 'expense_type': 'Calls'},
 | |
| 		{'doctype': 'Expense Claim Type', 'name': 'Food', 'expense_type': 'Food'},
 | |
| 		{'doctype': 'Expense Claim Type', 'name': 'Medical', 'expense_type': 'Medical'},
 | |
| 		{'doctype': 'Expense Claim Type', 'name': 'Others', 'expense_type': 'Others'},
 | |
| 		{'doctype': 'Expense Claim Type', 'name': 'Travel', 'expense_type': 'Travel'},
 | |
| 		
 | |
| 		# leave type
 | |
| 		{'doctype': 'Leave Type', 'leave_type_name': 'Casual Leave', 'name': 'Casual Leave', 'is_encash': 1, 'is_carry_forward': 1, 'max_days_allowed': '3', },
 | |
| 		{'doctype': 'Leave Type', 'leave_type_name': 'Compensatory Off', 'name': 'Compensatory Off', 'is_encash': 0, 'is_carry_forward': 0, },
 | |
| 		{'doctype': 'Leave Type', 'leave_type_name': 'Sick Leave', 'name': 'Sick Leave', 'is_encash': 0, 'is_carry_forward': 0, },
 | |
| 		{'doctype': 'Leave Type', 'leave_type_name': 'Privilege Leave', 'name': 'Privilege Leave', 'is_encash': 0, 'is_carry_forward': 0, },
 | |
| 		{'doctype': 'Leave Type', 'leave_type_name': 'Leave Without Pay', 'name': 'Leave Without Pay', 'is_encash': 0, 'is_carry_forward': 0, 'is_lwp':1},
 | |
| 		
 | |
| 		# territory
 | |
| 		{'doctype': 'Territory', 'territory_name': 'All Territories', 'is_group': 'Yes', 'name': 'All Territories', 'parent_territory': ''},
 | |
| 		{'doctype': 'Territory', 'territory_name': 'Default', 'is_group': 'No', 'name': 'Default', 'parent_territory': 'All Territories'},
 | |
| 			
 | |
| 		# customer group
 | |
| 		{'doctype': 'Customer Group', 'customer_group_name': 'All Customer Groups', 'is_group': 'Yes', 	'name': 'All Customer Groups', 'parent_customer_group': ''},
 | |
| 		{'doctype': 'Customer Group', 'customer_group_name': 'Default Customer Group', 'is_group': 'No', 'name': 'Default Customer Group', 'parent_customer_group': 'All Customer Groups'},
 | |
| 			
 | |
| 		# supplier type
 | |
| 		{'doctype': 'Supplier Type', 'name': 'Default Supplier Type', 'supplier_type': 'Default Supplier Type'},
 | |
| 		
 | |
| 		# Price List
 | |
| 		{'doctype': 'Price List', 'name': 'Default Price List', 'price_list_name': 'Default Price List'},
 | |
| 		{'doctype': 'Price List', 'name': 'Standard', 'price_list_name': 'Standard'},
 | |
| 				
 | |
| 		# warehouse type
 | |
| 		{'doctype': 'Warehouse Type', 'name': 'Default Warehouse Type', 'warehouse_type': 'Default Warehouse Type'},
 | |
| 		{'doctype': 'Warehouse Type', 'name': 'Fixed Asset', 'warehouse_type': 'Fixed Asset'},
 | |
| 		{'doctype': 'Warehouse Type', 'name': 'Reserved', 'warehouse_type': 'Reserved'},
 | |
| 		{'doctype': 'Warehouse Type', 'name': 'Rejected', 'warehouse_type': 'Rejected'},
 | |
| 		{'doctype': 'Warehouse Type', 'name': 'Sample', 'warehouse_type': 'Sample'},
 | |
| 		{'doctype': 'Warehouse Type', 'name': 'Stores', 'warehouse_type': 'Stores'},
 | |
| 		{'doctype': 'Warehouse Type', 'name': 'WIP Warehouse', 'warehouse_type': 'WIP Warehouse'},
 | |
| 		
 | |
| 		# warehouse 
 | |
| 		{'doctype': 'Warehouse', 'warehouse_name': 'Default Warehouse', 'name': 'Default Warehouse', 'warehouse_type': 'Default Warehouse Type'},
 | |
| 			
 | |
| 		# Workstation
 | |
| 		{'doctype': 'Workstation', 'name': 'Default Workstation', 'workstation_name': 'Default Workstation', 'warehouse': 'Default Warehouse'},
 | |
| 		
 | |
| 		# Sales Person
 | |
| 		{'doctype': 'Sales Person', 'name': 'All Sales Persons', 'sales_person_name': 'All Sales Persons', 'is_group': "Yes", "parent_sales_person": ""},
 | |
| 		
 | |
| 		# UOM
 | |
| 		{'uom_name': 'Unit', 'doctype': 'UOM', 'name': 'Unit'}, 
 | |
| 		{'uom_name': 'Unit', 'doctype': 'UOM', 'name': 'Hour'}, 
 | |
| 		{'uom_name': 'Box', 'doctype': 'UOM', 'name': 'Box'}, 
 | |
| 		{'uom_name': 'Ft', 'doctype': 'UOM', 'name': 'Ft'}, 
 | |
| 		{'uom_name': 'Kg', 'doctype': 'UOM', 'name': 'Kg'}, 
 | |
| 		{'uom_name': 'Ltr', 'doctype': 'UOM', 'name': 'Ltr'}, 
 | |
| 		{'uom_name': 'Meter', 'doctype': 'UOM', 'name': 'Meter'}, 
 | |
| 		{'uom_name': 'Mtr', 'doctype': 'UOM', 'name': 'Mtr'}, 
 | |
| 		{'uom_name': 'Nos', 'doctype': 'UOM', 'name': 'Nos'}, 
 | |
| 		{'uom_name': 'Pair', 'doctype': 'UOM', 'name': 'Pair'}, 
 | |
| 		{'uom_name': 'Set', 'doctype': 'UOM', 'name': 'Set'}, 
 | |
| 		{'uom_name': 'Hour', 'doctype': 'UOM', 'name': 'Hour'}, 
 | |
| 		{'uom_name': 'Minute', 'doctype': 'UOM', 'name': 'Minute'}, 
 | |
| 	]
 | |
| 	
 | |
| 	for r in records:
 | |
| 		doc = webnotes.doc(r)
 | |
| 		doc.insert()
 | |
| 	 |