2018-08-28 08:14:48 +00:00
|
|
|
# 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.-.#####',
|
2020-07-23 13:21:26 +00:00
|
|
|
'POS Closing Entry': 'POS-CLO-.YYYY.-.#####',
|
2018-08-28 08:14:48 +00:00
|
|
|
'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
|