2018-08-28 13:44:48 +05:30
|
|
|
# Copyright (c) 2018, Frappe Technologies Pvt. Ltd. and Contributors
|
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
|
|
|
|
|
|
|
import frappe
|
2018-08-28 16:08:22 +05:30
|
|
|
from frappe.custom.doctype.property_setter.property_setter import make_property_setter
|
2018-08-28 13:44:48 +05:30
|
|
|
|
|
|
|
doctype_series_map = {
|
|
|
|
"Additional Salary": "HR-ADS-.YY.-.MM.-",
|
|
|
|
"Appraisal": "HR-APR-.YY.-.MM.",
|
|
|
|
"Asset": "ACC-ASS-.YYYY.-",
|
|
|
|
"Attendance": "HR-ATT-.YYYY.-",
|
|
|
|
"Auto Repeat": "SYS-ARP-.YYYY.-",
|
|
|
|
"Blanket Order": "MFG-BLR-.YYYY.-",
|
|
|
|
"C-Form": "ACC-CF-.YYYY.-",
|
|
|
|
"Campaign": "SAL-CAM-.YYYY.-",
|
|
|
|
"Course Schedule": "EDU-CSH-.YYYY.-",
|
|
|
|
"Customer": "CUST-.YYYY.-",
|
|
|
|
"Delivery Note": "MAT-DN-.YYYY.-",
|
|
|
|
"Delivery Trip": "MAT-DT-.YYYY.-",
|
|
|
|
"Driver": "HR-DRI-.YYYY.-",
|
|
|
|
"Employee": "HR-EMP-",
|
|
|
|
"Employee Advance": "HR-EAD-.YYYY.-",
|
|
|
|
"Expense Claim": "HR-EXP-.YYYY.-",
|
|
|
|
"Fee Schedule": "EDU-FSH-.YYYY.-",
|
|
|
|
"Fee Structure": "EDU-FST-.YYYY.-",
|
|
|
|
"Fees": "EDU-FEE-.YYYY.-",
|
|
|
|
"Installation Note": "MAT-INS-.YYYY.-",
|
|
|
|
"Instructor": "EDU-INS-.YYYY.-",
|
|
|
|
"Issue": "ISS-.YYYY.-",
|
|
|
|
"Journal Entry": "ACC-JV-.YYYY.-",
|
|
|
|
"Landed Cost Voucher": "MAT-LCV-.YYYY.-",
|
|
|
|
"Lead": "CRM-LEAD-.YYYY.-",
|
|
|
|
"Leave Allocation": "HR-LAL-.YYYY.-",
|
|
|
|
"Leave Application": "HR-LAP-.YYYY.-",
|
|
|
|
"Maintenance Schedule": "MAT-MSH-.YYYY.-",
|
|
|
|
"Maintenance Visit": "MAT-MVS-.YYYY.-",
|
|
|
|
"Material Request": "MAT-MR-.YYYY.-",
|
|
|
|
"Member": "NPO-MEM-.YYYY.-",
|
|
|
|
"Opportunity": "CRM-OPP-.YYYY.-",
|
|
|
|
"Packing Slip": "MAT-PAC-.YYYY.-",
|
|
|
|
"Payment Entry": "ACC-PAY-.YYYY.-",
|
|
|
|
"Payment Request": "ACC-PRQ-.YYYY.-",
|
|
|
|
"Production Plan": "MFG-PP-.YYYY.-",
|
|
|
|
"Project Update": "PROJ-UPD-.YYYY.-",
|
|
|
|
"Purchase Invoice": "ACC-PINV-.YYYY.-",
|
|
|
|
"Purchase Order": "PUR-ORD-.YYYY.-",
|
|
|
|
"Purchase Receipt": "MAT-PRE-.YYYY.-",
|
|
|
|
"Quality Inspection": "MAT-QA-.YYYY.-",
|
|
|
|
"Quotation": "SAL-QTN-.YYYY.-",
|
|
|
|
"Request for Quotation": "PUR-RFQ-.YYYY.-",
|
|
|
|
"Sales Invoice": "ACC-SINV-.YYYY.-",
|
|
|
|
"Sales Order": "SAL-ORD-.YYYY.-",
|
|
|
|
"Sample Collection": "HLC-SC-.YYYY.-",
|
|
|
|
"Shareholder": "ACC-SH-.YYYY.-",
|
|
|
|
"Stock Entry": "MAT-STE-.YYYY.-",
|
|
|
|
"Stock Reconciliation": "MAT-RECO-.YYYY.-",
|
|
|
|
"Supplier": "SUP-.YYYY.-",
|
|
|
|
"Supplier Quotation": "PUR-SQTN-.YYYY.-",
|
|
|
|
"Supplier Scorecard Period": "PU-SSP-.YYYY.-",
|
|
|
|
"Timesheet": "TS-.YYYY.-",
|
|
|
|
"Vehicle Log": "HR-VLOG-.YYYY.-",
|
|
|
|
"Warranty Claim": "SER-WRN-.YYYY.-",
|
|
|
|
"Work Order": "MFG-WO-.YYYY.-",
|
|
|
|
}
|
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2018-08-28 13:44:48 +05:30
|
|
|
def execute():
|
2018-08-28 16:08:22 +05:30
|
|
|
frappe.db.sql(
|
|
|
|
"""
|
|
|
|
update `tabProperty Setter`
|
|
|
|
set name=concat(doc_type, '-', field_name, '-', property)
|
|
|
|
where property='fetch_from'
|
|
|
|
"""
|
|
|
|
)
|
2018-08-28 13:44:48 +05:30
|
|
|
series_to_set = get_series()
|
|
|
|
for doctype, opts in series_to_set.items():
|
|
|
|
set_series(doctype, opts["options"], opts["default"])
|
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2018-08-28 13:44:48 +05:30
|
|
|
def set_series(doctype, options, default):
|
2018-08-28 16:08:22 +05:30
|
|
|
def _make_property_setter(property_name, value):
|
|
|
|
property_setter = frappe.db.exists(
|
|
|
|
"Property Setter",
|
|
|
|
{"doc_type": doctype, "field_name": "naming_series", "property": property_name},
|
|
|
|
)
|
|
|
|
if property_setter:
|
|
|
|
frappe.db.set_value("Property Setter", property_setter, "value", value)
|
|
|
|
else:
|
|
|
|
make_property_setter(doctype, "naming_series", "options", value, "Text")
|
|
|
|
|
|
|
|
_make_property_setter("options", options)
|
2018-08-28 15:18:48 +05:30
|
|
|
if default:
|
2018-08-28 16:08:22 +05:30
|
|
|
_make_property_setter("default", default)
|
2018-08-28 13:44:48 +05:30
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2018-08-28 13:44:48 +05:30
|
|
|
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
|
|
|
|
if not frappe.db.has_column(doctype, "naming_series"):
|
|
|
|
continue
|
2018-10-11 16:28:59 +05:30
|
|
|
if not frappe.get_meta(doctype).has_field("naming_series"):
|
|
|
|
continue
|
2018-08-28 14:39:47 +05:30
|
|
|
series_to_preserve = list(filter(None, get_series_to_preserve(doctype)))
|
2018-08-28 13:44:48 +05:30
|
|
|
default_series = get_default_series(doctype)
|
|
|
|
|
|
|
|
if not series_to_preserve:
|
|
|
|
continue
|
|
|
|
existing_series = (frappe.get_meta(doctype).get_field("naming_series").options or "").split("\n")
|
2018-08-28 14:39:47 +05:30
|
|
|
existing_series = list(filter(None, [d.strip() for d in existing_series]))
|
2018-08-28 13:44:48 +05:30
|
|
|
|
|
|
|
# set naming series property setter
|
|
|
|
series_to_preserve = list(set(series_to_preserve + existing_series))
|
|
|
|
|
|
|
|
if series_to_preserve:
|
|
|
|
series_to_set[doctype] = {"options": "\n".join(series_to_preserve), "default": default_series}
|
|
|
|
|
|
|
|
return series_to_set
|
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2018-08-28 13:44:48 +05:30
|
|
|
def get_series_to_preserve(doctype):
|
2018-08-28 15:02:59 +05:30
|
|
|
series_to_preserve = frappe.db.sql_list(
|
|
|
|
"""select distinct naming_series from `tab{doctype}` where ifnull(naming_series, '') != ''""".format(
|
|
|
|
doctype=doctype
|
|
|
|
)
|
2022-03-28 18:52:46 +05:30
|
|
|
)
|
2018-08-28 13:44:48 +05:30
|
|
|
series_to_preserve.sort()
|
|
|
|
return series_to_preserve
|
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2018-08-28 13:44:48 +05:30
|
|
|
def get_default_series(doctype):
|
2018-10-11 16:27:05 +05:30
|
|
|
field = frappe.get_meta(doctype).get_field("naming_series")
|
|
|
|
default_series = field.get("default", "") if field else ""
|
2018-08-28 16:08:22 +05:30
|
|
|
return default_series
|