2013-08-05 14:59:54 +05:30
|
|
|
# Copyright (c) 2013, Web Notes Technologies Pvt. Ltd.
|
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
2013-01-16 17:48:17 +05:30
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
import webnotes
|
|
|
|
|
|
|
|
def pre_import():
|
2013-01-17 18:22:22 +05:30
|
|
|
webnotes.conn.begin()
|
2013-01-16 17:48:17 +05:30
|
|
|
make_modules()
|
|
|
|
make_roles()
|
2013-01-17 18:22:22 +05:30
|
|
|
webnotes.conn.commit()
|
2013-01-16 17:48:17 +05:30
|
|
|
|
|
|
|
def make_modules():
|
|
|
|
modules = [
|
2013-07-10 18:39:06 +05:30
|
|
|
"Home", "System", "Utilities", "Website", "Setup",
|
|
|
|
"Selling", "Buying", "Projects", "Accounts", "Stock",
|
|
|
|
"Support", "HR", "Manufacturing"]
|
2013-01-16 17:48:17 +05:30
|
|
|
|
|
|
|
for m in modules:
|
|
|
|
doc = webnotes.doc(fielddata = {
|
|
|
|
"doctype": "Module Def",
|
|
|
|
"module_name": m,
|
|
|
|
})
|
|
|
|
doc.insert()
|
|
|
|
|
|
|
|
def make_roles():
|
|
|
|
roles = [
|
2013-01-17 18:22:22 +05:30
|
|
|
"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",
|
2013-02-26 16:36:41 +05:30
|
|
|
"Partner", "Projects User", "Projects Manager", "Purchase Manager", "Purchase Master Manager",
|
2013-01-17 18:22:22 +05:30
|
|
|
"Purchase User", "Quality Manager", "Sales Manager",
|
|
|
|
"Sales Master Manager", "Sales User", "Supplier", "Support Manager",
|
2013-02-12 13:03:25 +05:30
|
|
|
"Support Team", "Website Manager"]
|
2013-01-17 18:22:22 +05:30
|
|
|
|
2013-01-16 17:48:17 +05:30
|
|
|
for r in roles:
|
|
|
|
doc = webnotes.doc(fielddata = {
|
|
|
|
"doctype":"Role",
|
|
|
|
"role_name": r
|
|
|
|
})
|
|
|
|
doc.insert()
|
2013-01-17 18:22:22 +05:30
|
|
|
|
2013-01-16 17:48:17 +05:30
|
|
|
def post_import():
|
2013-01-17 18:22:22 +05:30
|
|
|
webnotes.conn.begin()
|
2013-06-25 12:36:13 +05:30
|
|
|
|
2013-01-17 18:22:22 +05:30
|
|
|
# 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',
|
2013-08-23 13:16:22 +05:30
|
|
|
'fs_page_break', 'fs_more_info', 'fs_pos_view'
|
2013-01-17 18:22:22 +05:30
|
|
|
]
|
|
|
|
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()
|
2013-01-27 17:02:49 +05:30
|
|
|
|
2013-01-17 18:22:22 +05:30
|
|
|
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()
|
|
|
|
|
2013-01-27 17:02:49 +05:30
|
|
|
if country.currency and not webnotes.conn.exists("Currency", country.currency):
|
2013-01-17 18:22:22 +05:30
|
|
|
webnotes.doc({
|
|
|
|
"doctype": "Currency",
|
|
|
|
"currency_name": country.currency,
|
|
|
|
"fraction": country.currency_fraction,
|
|
|
|
"symbol": country.currency_symbol,
|
2013-01-21 10:14:10 +05:30
|
|
|
"fraction_units": country.currency_fraction_units,
|
|
|
|
"number_format": country.number_format
|
2013-01-17 18:22:22 +05:30
|
|
|
}).insert()
|
|
|
|
|
|
|
|
def import_defaults():
|
2013-01-16 17:48:17 +05:30
|
|
|
records = [
|
|
|
|
# item group
|
2013-07-10 18:59:55 +05:30
|
|
|
{'doctype': 'Item Group', 'item_group_name': 'All Item Groups', 'is_group': 'Yes', 'parent_item_group': ''},
|
|
|
|
{'doctype': 'Item Group', 'item_group_name': 'Products', 'is_group': 'No', 'parent_item_group': 'All Item Groups'},
|
|
|
|
{'doctype': 'Item Group', 'item_group_name': 'Raw Material', 'is_group': 'No', 'parent_item_group': 'All Item Groups'},
|
|
|
|
{'doctype': 'Item Group', 'item_group_name': 'Services', 'is_group': 'No', 'parent_item_group': 'All Item Groups'},
|
2013-08-07 17:46:35 +05:30
|
|
|
{'doctype': 'Item Group', 'item_group_name': 'Sub Assemblies', 'is_group': 'No', 'parent_item_group': 'All Item Groups'},
|
2013-01-16 17:48:17 +05:30
|
|
|
|
|
|
|
# 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': ''},
|
|
|
|
|
|
|
|
# customer group
|
|
|
|
{'doctype': 'Customer Group', 'customer_group_name': 'All Customer Groups', 'is_group': 'Yes', 'name': 'All Customer Groups', 'parent_customer_group': ''},
|
2013-07-10 18:59:55 +05:30
|
|
|
{'doctype': 'Customer Group', 'customer_group_name': 'Individual', 'is_group': 'No', 'parent_customer_group': 'All Customer Groups'},
|
|
|
|
{'doctype': 'Customer Group', 'customer_group_name': 'Commercial', 'is_group': 'No', 'parent_customer_group': 'All Customer Groups'},
|
|
|
|
{'doctype': 'Customer Group', 'customer_group_name': 'Non Profit', 'is_group': 'No', 'parent_customer_group': 'All Customer Groups'},
|
|
|
|
{'doctype': 'Customer Group', 'customer_group_name': 'Government', 'is_group': 'No', 'parent_customer_group': 'All Customer Groups'},
|
2013-01-16 17:48:17 +05:30
|
|
|
|
|
|
|
# supplier type
|
2013-07-10 18:59:55 +05:30
|
|
|
{'doctype': 'Supplier Type', 'supplier_type': 'Services'},
|
|
|
|
{'doctype': 'Supplier Type', 'supplier_type': 'Local'},
|
|
|
|
{'doctype': 'Supplier Type', 'supplier_type': 'Raw Material'},
|
|
|
|
{'doctype': 'Supplier Type', 'supplier_type': 'Electrical'},
|
|
|
|
{'doctype': 'Supplier Type', 'supplier_type': 'Hardware'},
|
|
|
|
{'doctype': 'Supplier Type', 'supplier_type': 'Pharmaceutical'},
|
|
|
|
{'doctype': 'Supplier Type', 'supplier_type': 'Distributor'},
|
2013-01-16 17:48:17 +05:30
|
|
|
|
|
|
|
# Sales Person
|
2013-07-10 18:59:55 +05:30
|
|
|
{'doctype': 'Sales Person', 'sales_person_name': 'Sales Team', 'is_group': "Yes", "parent_sales_person": ""},
|
2013-01-16 17:48:17 +05:30
|
|
|
|
|
|
|
# UOM
|
2013-07-25 17:45:59 +05:30
|
|
|
{'uom_name': 'Unit', 'doctype': 'UOM', 'name': 'Unit', "must_be_whole_number": 1},
|
|
|
|
{'uom_name': 'Box', 'doctype': 'UOM', 'name': 'Box', "must_be_whole_number": 1},
|
2013-01-16 17:48:17 +05:30
|
|
|
{'uom_name': 'Kg', 'doctype': 'UOM', 'name': 'Kg'},
|
2013-07-25 17:45:59 +05:30
|
|
|
{'uom_name': 'Nos', 'doctype': 'UOM', 'name': 'Nos', "must_be_whole_number": 1},
|
|
|
|
{'uom_name': 'Pair', 'doctype': 'UOM', 'name': 'Pair', "must_be_whole_number": 1},
|
|
|
|
{'uom_name': 'Set', 'doctype': 'UOM', 'name': 'Set', "must_be_whole_number": 1},
|
|
|
|
{'uom_name': 'Hour', 'doctype': 'UOM', 'name': 'Hour'},
|
2013-01-17 18:22:22 +05:30
|
|
|
{'uom_name': 'Minute', 'doctype': 'UOM', 'name': 'Minute'},
|
2013-01-16 17:48:17 +05:30
|
|
|
]
|
|
|
|
|
2013-07-08 18:50:45 +05:30
|
|
|
from webnotes.modules import scrub
|
2013-01-16 17:48:17 +05:30
|
|
|
for r in records:
|
2013-07-10 20:42:44 +05:30
|
|
|
bean = webnotes.bean(r)
|
|
|
|
|
|
|
|
# ignore mandatory for root
|
|
|
|
parent_link_field = ("parent_" + scrub(bean.doc.doctype))
|
|
|
|
if parent_link_field in bean.doc.fields and not bean.doc.fields.get(parent_link_field):
|
|
|
|
bean.ignore_mandatory = True
|
|
|
|
|
|
|
|
bean.insert()
|