Rushabh Mehta | ad45e31 | 2013-11-20 12:59:58 +0530 | [diff] [blame] | 1 | # Copyright (c) 2013, Web Notes Technologies Pvt. Ltd. and Contributors |
Rushabh Mehta | e67d1fb | 2013-08-05 14:59:54 +0530 | [diff] [blame] | 2 | # License: GNU General Public License v3. See license.txt |
| 3 | |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 4 | from __future__ import unicode_literals |
| 5 | |
Rushabh Mehta | 793ba6b | 2014-02-14 15:47:51 +0530 | [diff] [blame] | 6 | import frappe |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 7 | |
Rushabh Mehta | 1f84799 | 2013-12-12 19:12:19 +0530 | [diff] [blame] | 8 | def after_install(): |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 9 | import_defaults() |
| 10 | import_country_and_currency() |
Nabin Hait | 813a93d | 2014-03-06 18:21:56 +0530 | [diff] [blame] | 11 | from erpnext.accounts.doctype.chart_of_accounts.import_charts import import_charts |
| 12 | import_charts() |
Anand Doshi | e9baaa6 | 2014-02-26 12:35:33 +0530 | [diff] [blame] | 13 | frappe.db.set_value('Control Panel', None, 'home_page', 'setup-wizard') |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 14 | feature_setup() |
Rushabh Mehta | 1f84799 | 2013-12-12 19:12:19 +0530 | [diff] [blame] | 15 | from erpnext.setup.page.setup_wizard.setup_wizard import add_all_roles_to |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 16 | add_all_roles_to("Administrator") |
Pratik Vyas | 28da752 | 2014-02-19 20:53:45 +0530 | [diff] [blame] | 17 | set_single_defaults() |
Anand Doshi | e9baaa6 | 2014-02-26 12:35:33 +0530 | [diff] [blame] | 18 | frappe.db.commit() |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 19 | |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 20 | def import_country_and_currency(): |
Rushabh Mehta | 793ba6b | 2014-02-14 15:47:51 +0530 | [diff] [blame] | 21 | from frappe.country_info import get_all |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 22 | data = get_all() |
Anand Doshi | 44077d2 | 2013-01-27 17:02:49 +0530 | [diff] [blame] | 23 | |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 24 | for name in data: |
Rushabh Mehta | 793ba6b | 2014-02-14 15:47:51 +0530 | [diff] [blame] | 25 | country = frappe._dict(data[name]) |
Anand Doshi | 7fbdba0 | 2014-03-25 13:50:52 +0530 | [diff] [blame] | 26 | if not frappe.db.exists("Country", name): |
Rushabh Mehta | b385ecf | 2014-03-28 16:44:37 +0530 | [diff] [blame] | 27 | frappe.get_doc({ |
Anand Doshi | 7fbdba0 | 2014-03-25 13:50:52 +0530 | [diff] [blame] | 28 | "doctype": "Country", |
| 29 | "country_name": name, |
| 30 | "code": country.code, |
| 31 | "date_format": country.date_format or "dd-mm-yyyy", |
| 32 | "time_zones": "\n".join(country.timezones or []) |
| 33 | }).insert() |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 34 | |
Anand Doshi | e9baaa6 | 2014-02-26 12:35:33 +0530 | [diff] [blame] | 35 | if country.currency and not frappe.db.exists("Currency", country.currency): |
Rushabh Mehta | b385ecf | 2014-03-28 16:44:37 +0530 | [diff] [blame] | 36 | frappe.get_doc({ |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 37 | "doctype": "Currency", |
| 38 | "currency_name": country.currency, |
| 39 | "fraction": country.currency_fraction, |
| 40 | "symbol": country.currency_symbol, |
Rushabh Mehta | f5b04cf | 2013-01-21 10:14:10 +0530 | [diff] [blame] | 41 | "fraction_units": country.currency_fraction_units, |
| 42 | "number_format": country.number_format |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 43 | }).insert() |
| 44 | |
| 45 | def import_defaults(): |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 46 | records = [ |
| 47 | # item group |
Rushabh Mehta | ad71473 | 2013-07-10 18:59:55 +0530 | [diff] [blame] | 48 | {'doctype': 'Item Group', 'item_group_name': 'All Item Groups', 'is_group': 'Yes', 'parent_item_group': ''}, |
| 49 | {'doctype': 'Item Group', 'item_group_name': 'Products', 'is_group': 'No', 'parent_item_group': 'All Item Groups'}, |
| 50 | {'doctype': 'Item Group', 'item_group_name': 'Raw Material', 'is_group': 'No', 'parent_item_group': 'All Item Groups'}, |
| 51 | {'doctype': 'Item Group', 'item_group_name': 'Services', 'is_group': 'No', 'parent_item_group': 'All Item Groups'}, |
Rushabh Mehta | 7cfefbc | 2013-08-07 17:46:35 +0530 | [diff] [blame] | 52 | {'doctype': 'Item Group', 'item_group_name': 'Sub Assemblies', 'is_group': 'No', 'parent_item_group': 'All Item Groups'}, |
Rushabh Mehta | ddca90e | 2013-10-09 16:08:54 +0530 | [diff] [blame] | 53 | {'doctype': 'Item Group', 'item_group_name': 'Consumable', 'is_group': 'No', 'parent_item_group': 'All Item Groups'}, |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 54 | |
| 55 | # deduction type |
| 56 | {'doctype': 'Deduction Type', 'name': 'Income Tax', 'description': 'Income Tax', 'deduction_name': 'Income Tax'}, |
| 57 | {'doctype': 'Deduction Type', 'name': 'Professional Tax', 'description': 'Professional Tax', 'deduction_name': 'Professional Tax'}, |
| 58 | {'doctype': 'Deduction Type', 'name': 'Provident Fund', 'description': 'Provident fund', 'deduction_name': 'Provident Fund'}, |
| 59 | |
| 60 | # earning type |
| 61 | {'doctype': 'Earning Type', 'name': 'Basic', 'description': 'Basic', 'earning_name': 'Basic', 'taxable': 'Yes'}, |
| 62 | {'doctype': 'Earning Type', 'name': 'House Rent Allowance', 'description': 'House Rent Allowance', 'earning_name': 'House Rent Allowance', 'taxable': 'No'}, |
| 63 | |
| 64 | # expense claim type |
| 65 | {'doctype': 'Expense Claim Type', 'name': 'Calls', 'expense_type': 'Calls'}, |
| 66 | {'doctype': 'Expense Claim Type', 'name': 'Food', 'expense_type': 'Food'}, |
| 67 | {'doctype': 'Expense Claim Type', 'name': 'Medical', 'expense_type': 'Medical'}, |
| 68 | {'doctype': 'Expense Claim Type', 'name': 'Others', 'expense_type': 'Others'}, |
| 69 | {'doctype': 'Expense Claim Type', 'name': 'Travel', 'expense_type': 'Travel'}, |
| 70 | |
| 71 | # leave type |
| 72 | {'doctype': 'Leave Type', 'leave_type_name': 'Casual Leave', 'name': 'Casual Leave', 'is_encash': 1, 'is_carry_forward': 1, 'max_days_allowed': '3', }, |
| 73 | {'doctype': 'Leave Type', 'leave_type_name': 'Compensatory Off', 'name': 'Compensatory Off', 'is_encash': 0, 'is_carry_forward': 0, }, |
| 74 | {'doctype': 'Leave Type', 'leave_type_name': 'Sick Leave', 'name': 'Sick Leave', 'is_encash': 0, 'is_carry_forward': 0, }, |
| 75 | {'doctype': 'Leave Type', 'leave_type_name': 'Privilege Leave', 'name': 'Privilege Leave', 'is_encash': 0, 'is_carry_forward': 0, }, |
| 76 | {'doctype': 'Leave Type', 'leave_type_name': 'Leave Without Pay', 'name': 'Leave Without Pay', 'is_encash': 0, 'is_carry_forward': 0, 'is_lwp':1}, |
| 77 | |
| 78 | # territory |
| 79 | {'doctype': 'Territory', 'territory_name': 'All Territories', 'is_group': 'Yes', 'name': 'All Territories', 'parent_territory': ''}, |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 80 | |
| 81 | # customer group |
| 82 | {'doctype': 'Customer Group', 'customer_group_name': 'All Customer Groups', 'is_group': 'Yes', 'name': 'All Customer Groups', 'parent_customer_group': ''}, |
Rushabh Mehta | ad71473 | 2013-07-10 18:59:55 +0530 | [diff] [blame] | 83 | {'doctype': 'Customer Group', 'customer_group_name': 'Individual', 'is_group': 'No', 'parent_customer_group': 'All Customer Groups'}, |
| 84 | {'doctype': 'Customer Group', 'customer_group_name': 'Commercial', 'is_group': 'No', 'parent_customer_group': 'All Customer Groups'}, |
| 85 | {'doctype': 'Customer Group', 'customer_group_name': 'Non Profit', 'is_group': 'No', 'parent_customer_group': 'All Customer Groups'}, |
| 86 | {'doctype': 'Customer Group', 'customer_group_name': 'Government', 'is_group': 'No', 'parent_customer_group': 'All Customer Groups'}, |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 87 | |
| 88 | # supplier type |
Rushabh Mehta | ad71473 | 2013-07-10 18:59:55 +0530 | [diff] [blame] | 89 | {'doctype': 'Supplier Type', 'supplier_type': 'Services'}, |
| 90 | {'doctype': 'Supplier Type', 'supplier_type': 'Local'}, |
| 91 | {'doctype': 'Supplier Type', 'supplier_type': 'Raw Material'}, |
| 92 | {'doctype': 'Supplier Type', 'supplier_type': 'Electrical'}, |
| 93 | {'doctype': 'Supplier Type', 'supplier_type': 'Hardware'}, |
| 94 | {'doctype': 'Supplier Type', 'supplier_type': 'Pharmaceutical'}, |
| 95 | {'doctype': 'Supplier Type', 'supplier_type': 'Distributor'}, |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 96 | |
| 97 | # Sales Person |
Rushabh Mehta | ad71473 | 2013-07-10 18:59:55 +0530 | [diff] [blame] | 98 | {'doctype': 'Sales Person', 'sales_person_name': 'Sales Team', 'is_group': "Yes", "parent_sales_person": ""}, |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 99 | |
| 100 | # UOM |
Rushabh Mehta | 4dca401 | 2013-07-25 17:45:59 +0530 | [diff] [blame] | 101 | {'uom_name': 'Unit', 'doctype': 'UOM', 'name': 'Unit', "must_be_whole_number": 1}, |
| 102 | {'uom_name': 'Box', 'doctype': 'UOM', 'name': 'Box', "must_be_whole_number": 1}, |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 103 | {'uom_name': 'Kg', 'doctype': 'UOM', 'name': 'Kg'}, |
Rushabh Mehta | 4dca401 | 2013-07-25 17:45:59 +0530 | [diff] [blame] | 104 | {'uom_name': 'Nos', 'doctype': 'UOM', 'name': 'Nos', "must_be_whole_number": 1}, |
| 105 | {'uom_name': 'Pair', 'doctype': 'UOM', 'name': 'Pair', "must_be_whole_number": 1}, |
| 106 | {'uom_name': 'Set', 'doctype': 'UOM', 'name': 'Set', "must_be_whole_number": 1}, |
| 107 | {'uom_name': 'Hour', 'doctype': 'UOM', 'name': 'Hour'}, |
Rushabh Mehta | db7139a | 2013-01-17 18:22:22 +0530 | [diff] [blame] | 108 | {'uom_name': 'Minute', 'doctype': 'UOM', 'name': 'Minute'}, |
Rushabh Mehta | d8de921 | 2014-03-06 15:40:22 +0530 | [diff] [blame] | 109 | |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 110 | ] |
| 111 | |
Rushabh Mehta | 793ba6b | 2014-02-14 15:47:51 +0530 | [diff] [blame] | 112 | from frappe.modules import scrub |
Rushabh Mehta | 6f9915c | 2013-01-16 17:48:17 +0530 | [diff] [blame] | 113 | for r in records: |
Rushabh Mehta | b385ecf | 2014-03-28 16:44:37 +0530 | [diff] [blame] | 114 | bean = frappe.get_doc(r) |
Rushabh Mehta | e41bceb | 2013-07-10 20:42:44 +0530 | [diff] [blame] | 115 | |
| 116 | # ignore mandatory for root |
Anand Doshi | f78d1ae | 2014-03-28 13:55:00 +0530 | [diff] [blame] | 117 | parent_link_field = ("parent_" + scrub(bean.doctype)) |
| 118 | if parent_link_field in bean.fields and not bean.get(parent_link_field): |
Rushabh Mehta | e41bceb | 2013-07-10 20:42:44 +0530 | [diff] [blame] | 119 | bean.ignore_mandatory = True |
| 120 | |
Rushabh Mehta | 1f84799 | 2013-12-12 19:12:19 +0530 | [diff] [blame] | 121 | bean.insert() |
| 122 | |
| 123 | def feature_setup(): |
| 124 | """save global defaults and features setup""" |
Rushabh Mehta | b385ecf | 2014-03-28 16:44:37 +0530 | [diff] [blame] | 125 | bean = frappe.get_doc("Features Setup", "Features Setup") |
Rushabh Mehta | 1f84799 | 2013-12-12 19:12:19 +0530 | [diff] [blame] | 126 | bean.ignore_permissions = True |
| 127 | |
| 128 | # store value as 1 for all these fields |
| 129 | flds = ['fs_item_serial_nos', 'fs_item_batch_nos', 'fs_brands', 'fs_item_barcode', |
| 130 | 'fs_item_advanced', 'fs_packing_details', 'fs_item_group_in_details', |
| 131 | 'fs_exports', 'fs_imports', 'fs_discounts', 'fs_purchase_discounts', |
| 132 | 'fs_after_sales_installations', 'fs_projects', 'fs_sales_extras', |
| 133 | 'fs_recurring_invoice', 'fs_pos', 'fs_manufacturing', 'fs_quality', |
| 134 | 'fs_page_break', 'fs_more_info', 'fs_pos_view' |
| 135 | ] |
Anand Doshi | f78d1ae | 2014-03-28 13:55:00 +0530 | [diff] [blame] | 136 | bean.update(dict(zip(flds, [1]*len(flds)))) |
Pratik Vyas | 28da752 | 2014-02-19 20:53:45 +0530 | [diff] [blame] | 137 | bean.save() |
| 138 | |
| 139 | def set_single_defaults(): |
Anand Doshi | eb7fea6 | 2014-03-19 17:10:01 +0530 | [diff] [blame] | 140 | for dt in frappe.db.sql_list("""select name from `tabDocType` where issingle=1"""): |
| 141 | default_values = frappe.db.sql("""select fieldname, `default` from `tabDocField` |
| 142 | where parent=%s""", dt, as_dict=True) |
| 143 | if default_values: |
| 144 | try: |
Rushabh Mehta | b385ecf | 2014-03-28 16:44:37 +0530 | [diff] [blame] | 145 | b = frappe.get_doc(dt, dt) |
Anand Doshi | eb7fea6 | 2014-03-19 17:10:01 +0530 | [diff] [blame] | 146 | for fieldname, value in default_values: |
Anand Doshi | f78d1ae | 2014-03-28 13:55:00 +0530 | [diff] [blame] | 147 | b.set(fieldname, value) |
Anand Doshi | eb7fea6 | 2014-03-19 17:10:01 +0530 | [diff] [blame] | 148 | b.save() |
| 149 | except frappe.MandatoryError: |
| 150 | pass |
| 151 | |
Anand Doshi | e9baaa6 | 2014-02-26 12:35:33 +0530 | [diff] [blame] | 152 | frappe.db.set_default("date_format", "dd-mm-yyyy") |