brotherton-erpnext/erpnext/patches/v11_0/refactor_autoname_naming.py
Shreya Shah a5add289bb Refactor Naming Series (#15070)
* Patch to create Property Setter for existing naming series

* Update existing naming series options with new

* Add patch link to patches.txt

* Update patch

* Fix codacy

* Fix as per suggestions

* Remove old patch for property setter

* Improve as per suggested

- Modified the naming
- Also refactored naming for doctypes having autoname with series
- Added a patch to make property setter for autoname

* Fix Travis

* Rebase with develop
2018-08-28 13:44:48 +05:30

120 lines
4.5 KiB
Python

# Copyright (c) 2018, Frappe Technologies Pvt. Ltd. and Contributors
# License: GNU General Public License v3. See license.txt
from __future__ import print_function, unicode_literals
import frappe
from frappe.custom.doctype.property_setter.property_setter import make_property_setter
doctype_series_map = {
'Activity Cost': 'PROJ-ACC-.#####',
'Agriculture Task': 'AG-TASK-.#####',
'Assessment Plan': 'EDU-ASP-.YYYY.-.#####',
'Assessment Result': 'EDU-RES-.YYYY.-.#####',
'Asset Movement': 'ACC-ASM-.YYYY.-.#####',
'Attendance Request': 'HR-ARQ-.YY.-.MM.-.#####',
'Authorization Rule': 'HR-ARU-.#####',
'Bank Guarantee': 'ACC-BG-.YYYY.-.#####',
'Bin': 'MAT-BIN-.YYYY.-.#####',
'Certification Application': 'NPO-CAPP-.YYYY.-.#####',
'Certified Consultant': 'NPO-CONS-.YYYY.-.#####',
'Chat Room': 'CHAT-ROOM-.#####',
'Compensatory Leave Request': 'HR-CMP-.YY.-.MM.-.#####',
'Custom Script': 'SYS-SCR-.#####',
'Employee Benefit Application': 'HR-BEN-APP-.YY.-.MM.-.#####',
'Employee Benefit Application Detail': '',
'Employee Benefit Claim': 'HR-BEN-CLM-.YY.-.MM.-.#####',
'Employee Incentive': 'HR-EINV-.YY.-.MM.-.#####',
'Employee Onboarding': 'HR-EMP-ONB-.YYYY.-.#####',
'Employee Onboarding Template': 'HR-EMP-ONT-.#####',
'Employee Promotion': 'HR-EMP-PRO-.YYYY.-.#####',
'Employee Separation': 'HR-EMP-SEP-.YYYY.-.#####',
'Employee Separation Template': 'HR-EMP-STP-.#####',
'Employee Tax Exemption Declaration': 'HR-TAX-DEC-.YYYY.-.#####',
'Employee Tax Exemption Proof Submission': 'HR-TAX-PRF-.YYYY.-.#####',
'Employee Transfer': 'HR-EMP-TRN-.YYYY.-.#####',
'Event': 'EVENT-.YYYY.-.#####',
'Exchange Rate Revaluation': 'ACC-ERR-.YYYY.-.#####',
'GL Entry': 'ACC-GLE-.YYYY.-.#####',
'Guardian': 'EDU-GRD-.YYYY.-.#####',
'Hotel Room Reservation': 'HTL-RES-.YYYY.-.#####',
'Item Price': '',
'Job Applicant': 'HR-APP-.YYYY.-.#####',
'Job Offer': 'HR-OFF-.YYYY.-.#####',
'Leave Encashment': 'HR-ENC-.YYYY.-.#####',
'Leave Period': 'HR-LPR-.YYYY.-.#####',
'Leave Policy': 'HR-LPOL-.YYYY.-.#####',
'Loan': 'ACC-LOAN-.YYYY.-.#####',
'Loan Application': 'ACC-LOAP-.YYYY.-.#####',
'Loyalty Point Entry': '',
'Membership': 'NPO-MSH-.YYYY.-.#####',
'Packing Slip': 'MAT-PAC-.YYYY.-.#####',
'Patient Appointment': 'HLC-APP-.YYYY.-.#####',
'Payment Terms Template Detail': '',
'Payroll Entry': 'HR-PRUN-.YYYY.-.#####',
'Period Closing Voucher': 'ACC-PCV-.YYYY.-.#####',
'Plant Analysis': 'AG-PLA-.YYYY.-.#####',
'POS Closing Voucher': 'POS-CLO-.YYYY.-.#####',
'Prepared Report': 'SYS-PREP-.YYYY.-.#####',
'Program Enrollment': 'EDU-ENR-.YYYY.-.#####',
'Quotation Item': '',
'Restaurant Reservation': 'RES-RES-.YYYY.-.#####',
'Retention Bonus': 'HR-RTB-.YYYY.-.#####',
'Room': 'HTL-ROOM-.YYYY.-.#####',
'Salary Structure Assignment': 'HR-SSA-.YY.-.MM.-.#####',
'Sales Taxes and Charges': '',
'Share Transfer': 'ACC-SHT-.YYYY.-.#####',
'Shift Assignment': 'HR-SHA-.YY.-.MM.-.#####',
'Shift Request': 'HR-SHR-.YY.-.MM.-.#####',
'SMS Log': 'SYS-SMS-.#####',
'Soil Analysis': 'AG-ANA-.YY.-.MM.-.#####',
'Soil Texture': 'AG-TEX-.YYYY.-.#####',
'Stock Ledger Entry': 'MAT-SLE-.YYYY.-.#####',
'Student Leave Application': 'EDU-SLA-.YYYY.-.#####',
'Student Log': 'EDU-SLOG-.YYYY.-.#####',
'Subscription': 'ACC-SUB-.YYYY.-.#####',
'Task': 'TASK-.YYYY.-.#####',
'Tax Rule': 'ACC-TAX-RULE-.YYYY.-.#####',
'Training Feedback': 'HR-TRF-.YYYY.-.#####',
'Training Result': 'HR-TRR-.YYYY.-.#####',
'Travel Request': 'HR-TRQ-.YYYY.-.#####',
'UOM Conversion Factor': 'MAT-UOM-CNV-.#####',
'Water Analysis': 'HR-WAT-.YYYY.-.#####',
'Workflow Action': 'SYS-WACT-.#####',
}
def execute():
series_to_set = get_series()
for doctype, opts in series_to_set.items():
set_series(doctype, opts['value'])
def set_series(doctype, value):
doc = frappe.db.exists('Property Setter', {'doc_type': doctype, 'property': 'autoname'})
if doc:
frappe.db.set_value('Property Setter', doc, 'value', value)
else:
make_property_setter(doctype, '', 'autoname', value, '', for_doctype = True)
def get_series():
series_to_set = {}
for doctype in doctype_series_map:
if not frappe.db.exists('DocType', doctype):
continue
if not frappe.db.a_row_exists(doctype):
continue
series_to_preserve = get_series_to_preserve(doctype)
if not series_to_preserve:
continue
# set autoname property setter
if series_to_preserve:
series_to_set[doctype] = {'value': series_to_preserve}
return series_to_set
def get_series_to_preserve(doctype):
series_to_preserve = frappe.db.get_value('DocType', doctype, 'autoname')
return series_to_preserve