naming series changes now saved as property setter
This commit is contained in:
parent
71841df9ab
commit
a9ccc7d6bd
12
erpnext/patches/april_2012/naming_series_patch.py
Normal file
12
erpnext/patches/april_2012/naming_series_patch.py
Normal file
@ -0,0 +1,12 @@
|
||||
def execute():
|
||||
import webnotes
|
||||
from webnotes.model.code import get_obj
|
||||
ns_list = webnotes.conn.sql("""\
|
||||
SELECT `tabDocField`.`parent`, `tabDocField`.`options`
|
||||
FROM `tabDocField`, `tabDocType`
|
||||
WHERE `tabDocField`.`fieldname` = 'naming_series'
|
||||
AND `tabDocType`.name=`tabDocField`.parent""")
|
||||
ns_obj = get_obj('Naming Series')
|
||||
for ns in ns_list:
|
||||
if ns[0] and isinstance(ns[1], basestring):
|
||||
ns_obj.set_series_for(ns[0], ns[1].split("\n"))
|
@ -8,10 +8,11 @@ def execute():
|
||||
* Remove 'no_column' from DocField
|
||||
* Drop table DocFormat
|
||||
"""
|
||||
change_property_setter_fieldnames()
|
||||
|
||||
import webnotes.model.sync
|
||||
webnotes.model.sync.sync_all(force=1)
|
||||
|
||||
change_property_setter_fieldnames()
|
||||
handle_custom_fields()
|
||||
create_file_list()
|
||||
|
||||
@ -19,6 +20,8 @@ def execute():
|
||||
change_to_decimal()
|
||||
|
||||
def change_property_setter_fieldnames():
|
||||
import webnotes.model.sync
|
||||
webnotes.model.sync.sync('core', 'property_setter')
|
||||
docfield_list = webnotes.conn.sql("""\
|
||||
SELECT name, fieldname FROM `tabDocField`""", as_list=1)
|
||||
custom_field_list = webnotes.conn.sql("""\
|
||||
@ -94,12 +97,13 @@ def create_prev_field_prop_setter(cf):
|
||||
WHERE name = %s""", (similar_idx_label[0], f.get('name')))
|
||||
|
||||
prev_field = field_list[label_index]
|
||||
webnotes.conn.sql("""\
|
||||
DELETE FROM `tabProperty Setter`
|
||||
res = webnotes.conn.sql("""\
|
||||
SELECT name FROM `tabProperty Setter`
|
||||
WHERE doc_type = %s
|
||||
AND field_name = %s
|
||||
AND property = 'previous_field'""", (f.get('dt'), f.get('fieldname')))
|
||||
|
||||
if not res:
|
||||
ps = Document('Property Setter', fielddata = {
|
||||
'doctype_or_field': 'DocField',
|
||||
'doc_type': f.get('dt'),
|
||||
|
@ -262,4 +262,9 @@ patch_list = [
|
||||
'patch_file': 'reload_c_form',
|
||||
'description': 'Added attchemnt option and total field'
|
||||
},
|
||||
{
|
||||
'patch_module': 'patches.april_2012',
|
||||
'patch_file': 'naming_series_patch',
|
||||
'description': 'Move naming series options into property setter'
|
||||
},
|
||||
]
|
||||
|
@ -34,14 +34,6 @@ class DocType:
|
||||
def get_transactions(self):
|
||||
return "\n".join([''] + [i[0] for i in sql("SELECT `tabDocField`.`parent` FROM `tabDocField`, `tabDocType` WHERE `tabDocField`.`fieldname` = 'naming_series' and `tabDocType`.name=`tabDocField`.parent order by `tabDocField`.parent")])
|
||||
|
||||
#-----------------------------------------------------------------------------------------------------------------------------------
|
||||
def get_options_for(self, doctype):
|
||||
sr = webnotes.model.doctype.get_property(doctype, 'naming_series')
|
||||
if sr:
|
||||
return sr.split("\n")
|
||||
else:
|
||||
return []
|
||||
|
||||
def scrub_options_list(self, ol):
|
||||
options = filter(lambda x: x, [cstr(n.upper()).strip() for n in ol])
|
||||
return options
|
||||
@ -60,6 +52,7 @@ class DocType:
|
||||
default = options[0]
|
||||
|
||||
# update in property setter
|
||||
from webnotes.model.doc import Document
|
||||
prop_dict = {'options': "\n".join(options), 'default': default}
|
||||
for prop in prop_dict:
|
||||
ps_exists = webnotes.conn.sql("""SELECT name FROM `tabProperty Setter`
|
||||
@ -83,6 +76,9 @@ class DocType:
|
||||
|
||||
self.doc.set_options = "\n".join(options)
|
||||
|
||||
from webnotes.utils.cache import CacheItem
|
||||
CacheItem(doctype).clear()
|
||||
|
||||
#-----------------------------------------------------------------------------------------------------------------------------------
|
||||
def update_series(self):
|
||||
self.check_duplicate()
|
||||
@ -95,7 +91,7 @@ class DocType:
|
||||
dt = DocType()
|
||||
|
||||
parent = sql("select parent from `tabDocField` where fieldname='naming_series' and parent != %s", self.doc.select_doc_for_series)
|
||||
sr = ([p[0], webnotes.model.doctype.get_property(p[0], 'naming_series')] for p in parent)
|
||||
sr = ([webnotes.model.doctype.get_property(p[0], 'options', 'naming_series'), p[0]] for p in parent)
|
||||
options = self.scrub_options_list(self.doc.set_options.split("\n"))
|
||||
for series in options:
|
||||
dt.validate_series(series, self.doc.select_doc_for_series)
|
||||
@ -113,9 +109,8 @@ class DocType:
|
||||
|
||||
#-----------------------------------------------------------------------------------------------------------------------------------
|
||||
def get_options(self, arg=''):
|
||||
so = sql("select options from `tabDocField` where parent=%s and fieldname='naming_series'", self.doc.select_doc_for_series)
|
||||
if so:
|
||||
return so[0][0] or ''
|
||||
sr = webnotes.model.doctype.get_property(self.doc.select_doc_for_series, 'options', 'naming_series')
|
||||
return sr
|
||||
|
||||
|
||||
#-----------------------------------------------------------------------------------------------------------------------------------
|
||||
|
Loading…
x
Reference in New Issue
Block a user