brotherton-erpnext/patches/december_2012/production_cleanup.py

51 lines
1.8 KiB
Python
Raw Normal View History

2012-12-10 19:28:38 +05:30
import webnotes
def execute():
2012-12-10 19:02:38 +05:30
delete_doctypes()
rename_module()
2012-12-14 14:25:51 +05:30
cleanup_bom()
2012-12-18 18:42:02 +05:30
rebuild_exploded_bom()
2012-12-10 19:02:38 +05:30
def delete_doctypes():
from webnotes.model import delete_doc
delete_doc("DocType", "Production Control")
2012-12-10 19:02:38 +05:30
delete_doc("DocType", "BOM Control")
2012-12-14 14:25:51 +05:30
2012-12-10 19:02:38 +05:30
def rename_module():
2012-12-10 19:37:49 +05:30
webnotes.reload_doc("core", "doctype", "role")
webnotes.reload_doc("core", "doctype", "page")
webnotes.reload_doc("core", "doctype", "module_def")
2012-12-11 15:18:51 +05:30
if webnotes.conn.exists("Role", "Production User"):
webnotes.rename_doc("Role", "Production User", "Manufacturing User")
if webnotes.conn.exists("Role", "Production Manager"):
webnotes.rename_doc("Role", "Production Manager", "Manufacturing Manager")
2012-12-10 19:37:49 +05:30
if webnotes.conn.exists("Page", "manufacturing-home"):
webnotes.delete_doc("Page", "production-home")
else:
webnotes.rename_doc("Page", "production-home", "manufacturing-home")
2012-12-11 15:18:51 +05:30
if webnotes.conn.exists("Module Def", "Production"):
webnotes.rename_doc("Module Def", "Production", "Manufacturing")
2012-12-10 19:28:38 +05:30
2012-12-20 16:53:33 +05:30
modules_list = webnotes.conn.get_global('modules_list')
if modules_list:
webnotes.conn.set_global("modules_list", modules_list.replace("Production",
"Manufacturing"))
2012-12-11 18:38:58 +05:30
# set end of life to null if "0000-00-00"
webnotes.conn.sql("""update `tabItem` set end_of_life=null where end_of_life='0000-00-00'""")
2012-12-10 19:02:38 +05:30
2012-12-18 18:42:02 +05:30
def rebuild_exploded_bom():
2012-12-11 15:14:30 +05:30
from webnotes.model.code import get_obj
for bom in webnotes.conn.sql("""select name from `tabBOM` where docstatus < 2"""):
get_obj("BOM", bom[0], with_children=1).on_update()
2012-12-14 14:25:51 +05:30
def cleanup_bom():
2012-12-18 18:42:02 +05:30
webnotes.conn.sql("""UPDATE `tabBOM` SET is_active = 1 where ifnull(is_active, 'No') = 'Yes'""")
webnotes.conn.sql("""UPDATE `tabBOM` SET is_active = 0 where ifnull(is_active, 'No') = 'No'""")
webnotes.reload_doc("manufacturing", "doctype", "bom")
webnotes.conn.sql("""update `tabBOM` set with_operations = 1""")
2012-12-14 14:25:51 +05:30