2015-03-03 09:25:30 +00:00
|
|
|
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
2013-08-05 09:29:54 +00:00
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
2017-08-28 12:47:36 +00:00
|
|
|
from __future__ import print_function, unicode_literals
|
2013-01-16 12:18:17 +00:00
|
|
|
|
2014-02-14 10:17:51 +00:00
|
|
|
import frappe
|
2016-05-11 11:17:14 +00:00
|
|
|
from frappe import _
|
2017-09-14 09:47:38 +00:00
|
|
|
from frappe.custom.doctype.custom_field.custom_field import create_custom_field
|
2019-09-17 10:24:41 +00:00
|
|
|
from frappe.desk.page.setup_wizard.setup_wizard import add_all_roles_to
|
|
|
|
from frappe.installer import update_site_config
|
|
|
|
from frappe.utils import cint
|
2021-01-18 09:36:35 +00:00
|
|
|
from six import iteritems
|
2013-01-16 12:18:17 +00:00
|
|
|
|
2018-02-22 05:38:36 +00:00
|
|
|
from erpnext.accounts.doctype.cash_flow_mapper.default_cash_flow_mapper import DEFAULT_MAPPERS
|
2019-09-17 10:24:41 +00:00
|
|
|
from erpnext.setup.default_energy_point_rules import get_default_energy_point_rules
|
2021-09-02 11:14:59 +00:00
|
|
|
|
2018-05-03 13:36:32 +00:00
|
|
|
from .default_success_action import get_default_success_action
|
2021-09-02 11:14:59 +00:00
|
|
|
|
2014-06-26 07:17:45 +00:00
|
|
|
default_mail_footer = """<div style="padding: 7px; text-align: right; color: #888"><small>Sent via
|
2014-06-26 06:32:55 +00:00
|
|
|
<a style="color: #888" href="http://erpnext.org">ERPNext</a></div>"""
|
|
|
|
|
2018-02-22 05:38:36 +00:00
|
|
|
|
2013-12-12 13:42:19 +00:00
|
|
|
def after_install():
|
2014-04-21 08:13:11 +00:00
|
|
|
frappe.get_doc({'doctype': "Role", "role_name": "Analytics"}).insert()
|
2014-04-30 05:46:02 +00:00
|
|
|
set_single_defaults()
|
2016-05-11 11:17:14 +00:00
|
|
|
create_compact_item_print_custom_field()
|
2020-09-02 19:42:52 +00:00
|
|
|
create_print_uom_after_qty_custom_field()
|
2017-09-14 09:47:38 +00:00
|
|
|
create_print_zero_amount_taxes_custom_field()
|
2013-01-17 12:52:22 +00:00
|
|
|
add_all_roles_to("Administrator")
|
2018-02-22 05:38:36 +00:00
|
|
|
create_default_cash_flow_mapper_templates()
|
2018-05-03 13:36:32 +00:00
|
|
|
create_default_success_action()
|
2019-09-17 10:24:41 +00:00
|
|
|
create_default_energy_point_rules()
|
2019-07-24 08:07:54 +00:00
|
|
|
add_company_to_session_defaults()
|
2020-08-06 15:22:02 +00:00
|
|
|
add_standard_navbar_items()
|
2020-09-30 11:03:14 +00:00
|
|
|
add_app_name()
|
2021-01-18 09:36:35 +00:00
|
|
|
add_non_standard_user_types()
|
2014-02-26 07:05:33 +00:00
|
|
|
frappe.db.commit()
|
2013-01-17 12:52:22 +00:00
|
|
|
|
2018-02-22 05:38:36 +00:00
|
|
|
|
2015-12-31 05:42:48 +00:00
|
|
|
def check_setup_wizard_not_completed():
|
2020-08-10 14:06:45 +00:00
|
|
|
if cint(frappe.db.get_single_value('System Settings', 'setup_complete') or 0):
|
2020-08-06 15:22:02 +00:00
|
|
|
message = """ERPNext can only be installed on a fresh site where the setup wizard is not completed.
|
2020-07-08 05:15:55 +00:00
|
|
|
You can reinstall this site (after saving your data) using: bench --site [sitename] reinstall"""
|
2021-05-25 14:24:40 +00:00
|
|
|
frappe.throw(message) # nosemgrep
|
2015-12-31 05:42:48 +00:00
|
|
|
|
2018-02-22 05:38:36 +00:00
|
|
|
|
2014-02-19 15:23:45 +00:00
|
|
|
def set_single_defaults():
|
2016-10-13 05:30:00 +00:00
|
|
|
for dt in ('Accounts Settings', 'Print Settings', 'HR Settings', 'Buying Settings',
|
2018-02-21 09:45:43 +00:00
|
|
|
'Selling Settings', 'Stock Settings'):
|
2014-03-19 11:40:01 +00:00
|
|
|
default_values = frappe.db.sql("""select fieldname, `default` from `tabDocField`
|
2014-04-03 09:00:42 +00:00
|
|
|
where parent=%s""", dt)
|
2014-03-19 11:40:01 +00:00
|
|
|
if default_values:
|
|
|
|
try:
|
2014-03-28 11:14:37 +00:00
|
|
|
b = frappe.get_doc(dt, dt)
|
2014-03-19 11:40:01 +00:00
|
|
|
for fieldname, value in default_values:
|
2014-03-28 08:25:00 +00:00
|
|
|
b.set(fieldname, value)
|
2014-03-19 11:40:01 +00:00
|
|
|
b.save()
|
|
|
|
except frappe.MandatoryError:
|
|
|
|
pass
|
2016-10-13 05:30:00 +00:00
|
|
|
except frappe.ValidationError:
|
|
|
|
pass
|
2016-05-11 11:17:14 +00:00
|
|
|
|
2021-09-04 08:34:56 +00:00
|
|
|
frappe.db.set_default("date_format", "dd-mm-yyyy")
|
|
|
|
ces = frappe.get_single('Currency Exchange Settings')
|
|
|
|
try:
|
|
|
|
ces.api_endpoint = "https://api.exchangerate.host/convert"
|
|
|
|
ces.append('result_key', {'key': 'result'})
|
|
|
|
ces.append('req_params', {'key': 'date', 'value': '{transaction_date}'})
|
|
|
|
ces.append('req_params', {'key': 'from', 'value': '{from_currency}'})
|
|
|
|
ces.append('req_params', {'key': 'to', 'value': '{to_currency}'})
|
|
|
|
ces.save()
|
|
|
|
except frappe.ValidationError:
|
|
|
|
pass
|
2018-02-22 05:38:36 +00:00
|
|
|
|
2016-05-11 11:17:14 +00:00
|
|
|
def create_compact_item_print_custom_field():
|
|
|
|
create_custom_field('Print Settings', {
|
|
|
|
'label': _('Compact Item Print'),
|
|
|
|
'fieldname': 'compact_item_print',
|
|
|
|
'fieldtype': 'Check',
|
|
|
|
'default': 1,
|
|
|
|
'insert_after': 'with_letterhead'
|
2017-09-14 09:47:38 +00:00
|
|
|
})
|
|
|
|
|
2018-02-22 05:38:36 +00:00
|
|
|
|
2020-09-02 19:42:52 +00:00
|
|
|
def create_print_uom_after_qty_custom_field():
|
|
|
|
create_custom_field('Print Settings', {
|
|
|
|
'label': _('Print UOM after Quantity'),
|
|
|
|
'fieldname': 'print_uom_after_quantity',
|
|
|
|
'fieldtype': 'Check',
|
|
|
|
'default': 0,
|
|
|
|
'insert_after': 'compact_item_print'
|
|
|
|
})
|
|
|
|
|
|
|
|
|
2017-09-14 09:47:38 +00:00
|
|
|
def create_print_zero_amount_taxes_custom_field():
|
|
|
|
create_custom_field('Print Settings', {
|
|
|
|
'label': _('Print taxes with zero amount'),
|
|
|
|
'fieldname': 'print_taxes_with_zero_amount',
|
|
|
|
'fieldtype': 'Check',
|
|
|
|
'default': 0,
|
|
|
|
'insert_after': 'allow_print_for_cancelled'
|
2018-02-22 05:38:36 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
def create_default_cash_flow_mapper_templates():
|
2018-05-03 13:36:32 +00:00
|
|
|
for mapper in DEFAULT_MAPPERS:
|
2018-02-22 05:38:36 +00:00
|
|
|
if not frappe.db.exists('Cash Flow Mapper', mapper['section_name']):
|
|
|
|
doc = frappe.get_doc(mapper)
|
|
|
|
doc.insert(ignore_permissions=True)
|
2018-05-03 13:36:32 +00:00
|
|
|
|
|
|
|
def create_default_success_action():
|
|
|
|
for success_action in get_default_success_action():
|
|
|
|
if not frappe.db.exists('Success Action', success_action.get("ref_doctype")):
|
|
|
|
doc = frappe.get_doc(success_action)
|
|
|
|
doc.insert(ignore_permissions=True)
|
2019-07-24 08:07:54 +00:00
|
|
|
|
2019-09-17 10:24:41 +00:00
|
|
|
def create_default_energy_point_rules():
|
|
|
|
|
|
|
|
for rule in get_default_energy_point_rules():
|
|
|
|
# check if any rule for ref. doctype exists
|
|
|
|
rule_exists = frappe.db.exists('Energy Point Rule', {
|
|
|
|
'reference_doctype': rule.get('reference_doctype')
|
|
|
|
})
|
|
|
|
if rule_exists: continue
|
|
|
|
doc = frappe.get_doc(rule)
|
|
|
|
doc.insert(ignore_permissions=True)
|
|
|
|
|
2019-07-24 08:07:54 +00:00
|
|
|
def add_company_to_session_defaults():
|
|
|
|
settings = frappe.get_single("Session Default Settings")
|
|
|
|
settings.append("session_defaults", {
|
|
|
|
"ref_doctype": "Company"
|
|
|
|
})
|
|
|
|
settings.save()
|
2020-08-06 15:22:02 +00:00
|
|
|
|
|
|
|
def add_standard_navbar_items():
|
|
|
|
navbar_settings = frappe.get_single("Navbar Settings")
|
|
|
|
|
|
|
|
erpnext_navbar_items = [
|
|
|
|
{
|
|
|
|
'item_label': 'Documentation',
|
|
|
|
'item_type': 'Route',
|
|
|
|
'route': 'https://erpnext.com/docs/user/manual',
|
|
|
|
'is_standard': 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'item_label': 'User Forum',
|
|
|
|
'item_type': 'Route',
|
|
|
|
'route': 'https://discuss.erpnext.com',
|
|
|
|
'is_standard': 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'item_label': 'Report an Issue',
|
|
|
|
'item_type': 'Route',
|
|
|
|
'route': 'https://github.com/frappe/erpnext/issues',
|
|
|
|
'is_standard': 1
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
2021-03-24 11:15:32 +00:00
|
|
|
current_navbar_items = navbar_settings.help_dropdown
|
2020-08-06 15:22:02 +00:00
|
|
|
navbar_settings.set('help_dropdown', [])
|
|
|
|
|
|
|
|
for item in erpnext_navbar_items:
|
2021-03-24 11:15:32 +00:00
|
|
|
current_labels = [item.get('item_label') for item in current_navbar_items]
|
|
|
|
if not item.get('item_label') in current_labels:
|
|
|
|
navbar_settings.append('help_dropdown', item)
|
2020-08-06 15:22:02 +00:00
|
|
|
|
2021-03-24 11:15:32 +00:00
|
|
|
for item in current_navbar_items:
|
2020-08-06 15:22:02 +00:00
|
|
|
navbar_settings.append('help_dropdown', {
|
|
|
|
'item_label': item.item_label,
|
|
|
|
'item_type': item.item_type,
|
|
|
|
'route': item.route,
|
|
|
|
'action': item.action,
|
|
|
|
'is_standard': item.is_standard,
|
|
|
|
'hidden': item.hidden
|
|
|
|
})
|
|
|
|
|
|
|
|
navbar_settings.save()
|
2020-09-30 11:03:14 +00:00
|
|
|
|
|
|
|
def add_app_name():
|
2021-03-16 06:52:31 +00:00
|
|
|
frappe.db.set_value('System Settings', None, 'app_name', 'ERPNext')
|
2021-01-18 09:36:35 +00:00
|
|
|
|
|
|
|
def add_non_standard_user_types():
|
|
|
|
user_types = get_user_types_data()
|
|
|
|
|
|
|
|
user_type_limit = {}
|
|
|
|
for user_type, data in iteritems(user_types):
|
|
|
|
user_type_limit.setdefault(frappe.scrub(user_type), 10)
|
|
|
|
|
|
|
|
update_site_config('user_type_doctype_limit', user_type_limit)
|
|
|
|
|
|
|
|
for user_type, data in iteritems(user_types):
|
|
|
|
create_custom_role(data)
|
|
|
|
create_user_type(user_type, data)
|
|
|
|
|
|
|
|
def get_user_types_data():
|
|
|
|
return {
|
2021-03-15 19:09:10 +00:00
|
|
|
'Employee Self Service': {
|
|
|
|
'role': 'Employee Self Service',
|
2021-01-18 09:36:35 +00:00
|
|
|
'apply_user_permission_on': 'Employee',
|
|
|
|
'user_id_field': 'user_id',
|
|
|
|
'doctypes': {
|
|
|
|
'Salary Slip': ['read'],
|
|
|
|
'Employee': ['read', 'write'],
|
2021-03-15 19:09:10 +00:00
|
|
|
'Expense Claim': ['read', 'write', 'create', 'delete'],
|
|
|
|
'Leave Application': ['read', 'write', 'create', 'delete'],
|
|
|
|
'Attendance Request': ['read', 'write', 'create', 'delete'],
|
|
|
|
'Compensatory Leave Request': ['read', 'write', 'create', 'delete'],
|
|
|
|
'Employee Tax Exemption Declaration': ['read', 'write', 'create', 'delete'],
|
|
|
|
'Employee Tax Exemption Proof Submission': ['read', 'write', 'create', 'delete'],
|
|
|
|
'Timesheet': ['read', 'write', 'create', 'delete', 'submit', 'cancel', 'amend']
|
2021-01-18 09:36:35 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
def create_custom_role(data):
|
|
|
|
if data.get('role') and not frappe.db.exists('Role', data.get('role')):
|
|
|
|
frappe.get_doc({
|
|
|
|
'doctype': 'Role',
|
|
|
|
'role_name': data.get('role'),
|
|
|
|
'desk_access': 1,
|
|
|
|
'is_custom': 1
|
|
|
|
}).insert(ignore_permissions=True)
|
|
|
|
|
|
|
|
def create_user_type(user_type, data):
|
|
|
|
if frappe.db.exists('User Type', user_type):
|
|
|
|
doc = frappe.get_cached_doc('User Type', user_type)
|
|
|
|
doc.user_doctypes = []
|
|
|
|
else:
|
|
|
|
doc = frappe.new_doc('User Type')
|
|
|
|
doc.update({
|
|
|
|
'name': user_type,
|
|
|
|
'role': data.get('role'),
|
|
|
|
'user_id_field': data.get('user_id_field'),
|
|
|
|
'apply_user_permission_on': data.get('apply_user_permission_on')
|
|
|
|
})
|
|
|
|
|
|
|
|
create_role_permissions_for_doctype(doc, data)
|
|
|
|
doc.save(ignore_permissions=True)
|
|
|
|
|
|
|
|
def create_role_permissions_for_doctype(doc, data):
|
|
|
|
for doctype, perms in iteritems(data.get('doctypes')):
|
|
|
|
args = {'document_type': doctype}
|
|
|
|
for perm in perms:
|
|
|
|
args[perm] = 1
|
|
|
|
|
|
|
|
doc.append('user_doctypes', args)
|
2021-04-13 13:13:57 +00:00
|
|
|
|
|
|
|
def update_select_perm_after_install():
|
|
|
|
if not frappe.flags.update_select_perm_after_migrate:
|
|
|
|
return
|
|
|
|
|
|
|
|
frappe.flags.ignore_select_perm = False
|
|
|
|
for row in frappe.get_all('User Type', filters= {'is_standard': 0}):
|
|
|
|
print('Updating user type :- ', row.name)
|
|
|
|
doc = frappe.get_doc('User Type', row.name)
|
|
|
|
doc.save()
|
|
|
|
|
|
|
|
frappe.flags.update_select_perm_after_migrate = False
|