2012-03-16 16:21:44 +05:30
import webnotes
from webnotes . model import rename , delete_doc
from webnotes . model . code import get_obj
from wnf import replace_code
from termcolor import colored
2012-04-02 14:06:46 +05:30
from webnotes . modules import reload_doc
2012-03-16 16:21:44 +05:30
from webnotes . utils import make_esc
import os
2012-04-02 19:13:00 +05:30
def execute1 ( ) :
2012-04-02 19:12:29 +05:30
rendt = get_dt_to_be_renamed ( )
rename_dt_files ( rendt )
#update_local_file_system()
2012-04-02 19:13:00 +05:30
def execute ( ) :
2012-03-16 16:21:44 +05:30
# delete dt, mapper
delete_dt_and_mapper ( )
#---------------------------------------------------
# doctype renaming
rendt = get_dt_to_be_renamed ( )
# Rename dt in db
rename_in_db ( rendt , ' DocType ' , 1 )
# Upadte dt in records
update_dt_in_records ( rendt )
#---------------------------------------------------
# Dt Mapper renaming
ren_mapper = get_mapper_to_be_renamed ( )
# Rename mapper in db
rename_in_db ( ren_mapper , ' DocType Mapper ' , 0 )
#---------------------------------------------------
# GL Mapper renaming
gl_mapper = { ' Receivable Voucher ' : ' Sales Invoice ' , ' Payable Voucher ' : ' Purchase Invoice ' }
rename_in_db ( gl_mapper , ' GL Mapper ' , 0 )
#---------------------------------------------------
# remove dt label
webnotes . conn . sql ( """ delete from `tabDocType Label` where name in ( ' Ticket ' , ' Receivable Voucher ' ,
' QA Inspection Report ' , ' Payable Voucher ' , ' Manage Account ' , ' Indent ' , ' DocLayer ' ) """ )
#---------------------------------------------------
# Reload mapper from file
for d in ren_mapper :
mod = ' _ ' . join ( webnotes . conn . sql ( " select module from `tabDocType Mapper` where name = %s " , ren_mapper [ d ] ) [ 0 ] [ 0 ] . lower ( ) . split ( ) )
reload_doc ( mod , ' DocType Mapper ' , ren_mapper [ d ] )
2012-03-30 18:18:36 +05:30
webnotes . conn . sql ( " DELETE FROM `tabSearch Criteria` WHERE name= ' ' " )
webnotes . conn . sql ( """ UPDATE `tabSearch Criteria` SET standard= ' No '
WHERE name IN ( ' appraisal_custom ' , ' bills-to_be_paid ' ,
' bills-to_be_submitted ' , ' cenvat_credit_-_input_or_capital_goods ' ,
' custom_test ' , ' custom_test1 ' , ' delivery_note-to_be_billed ' ,
' delivery_note-to_be_submitted ' , ' delivery_notes ' ,
' employee_leave_balance_report ' , ' flat_bom_report ' ,
' general_ledger1 ' , ' lead_interested ' ,
' payables_-_as_on_outstanding ' , ' periodical_budget_report ' ,
' projectwise_delivered_qty_and_costs_as_per_purchase_cost ' ,
' projectwise_pending_qty_and_costs_as_per_purchase_cost ' , ' sales ' ,
' sales_order1 ' , ' sales_order_pending_items ' ,
' territory_wise_sales_-_target_vs_actual_ ' , ' test_report ' ) """ )
2012-03-16 16:21:44 +05:30
# reload custom search criteria
2012-03-30 18:18:36 +05:30
for d in webnotes . conn . sql ( """ select name, module from
` tabSearch Criteria ` where ifnull ( standard , ' No ' ) = ' Yes ' and ifnull ( disabled , 0 ) = 0 """ ):
2012-04-02 14:24:35 +05:30
try :
reload_doc ( d [ 1 ] , ' search_criteria ' , d [ 0 ] . replace ( ' - ' , ' _ ' ) )
print d
except Exception , e :
print " did not reload: " + str ( d )
2012-03-30 18:18:36 +05:30
webnotes . conn . sql ( """ DELETE FROM `tabPrint Format`
WHERE name IN ( ' Delivery Note Format ' , ' Purchase Order Format ' ,
' Quotation Format ' , ' Receivable Voucher Format ' , ' Sales Order ' ,
' SalesInvoiceModern_test ' , ' SalesInvoiceStdNew ' ,
' Service Order Format ' , ' Service Quotation Format ' ) """ )
2012-03-16 16:21:44 +05:30
# reload custom print format
2012-03-30 18:18:36 +05:30
for d in webnotes . conn . sql ( """ select name, module from `tabPrint Format`
where ifnull ( standard , ' No ' ) = ' Yes ' """ ):
2012-04-02 14:24:35 +05:30
try :
reload_doc ( d [ 1 ] , ' Print Format ' , d [ 0 ] )
except Exception , e :
print " did not reload: " + str ( d )
2012-03-16 16:21:44 +05:30
# Reload GL Mapper
for d in webnotes . conn . sql ( " select name from `tabGL Mapper` " ) :
reload_doc ( ' accounts ' , ' GL Mapper ' , d [ 0 ] )
#gl entry, stock ledger entry,
# T0-do-list
# gl mapper name
def delete_dt_and_mapper ( ) :
del_mapper = [ ' Production Forecast-Production Planning Tool ' , ' Production Forecast-Production Plan ' , ' Sales Order-Production Plan ' ]
2012-03-14 12:04:16 +05:30
for d in del_mapper :
delete_doc ( ' DocType Mapper ' , d )
2012-03-14 11:07:00 +05:30
2012-03-14 12:04:16 +05:30
del_dt = [ ' Widget Control ' , ' Update Delivery Date Detail ' , ' Update Delivery Date ' , ' Tag Detail ' , ' Supplier rating ' , ' Stylesheet ' , ' Question Tag ' , ' PRO PP Detail ' , ' PRO Detail ' , ' PPW Detail ' , ' PF Detail ' , ' Personalize ' , ' Patch Util ' , ' Page Template ' , ' Module Def Role ' , ' Module Def Item ' , ' File Group ' , ' File Browser Control ' , ' File ' , ' Educational Qualifications ' , ' Earn Deduction Detail ' , ' DocType Property Setter ' , ' Contact Detail ' , ' BOM Report Detail ' , ' BOM Replace Utility Detail ' , ' BOM Replace Utility ' , ' Absent Days Detail ' , ' Activity Dashboard Control ' , ' Raw Materials Supplied ' , ' Setup Wizard Control ' , ' Company Group ' ] # docformat
for d in del_dt :
2012-03-14 11:07:00 +05:30
delete_doc ( ' DocType ' , d )
2012-03-16 16:21:44 +05:30
2012-04-02 19:12:29 +05:30
2012-03-16 16:21:44 +05:30
def rename_in_db ( ren_data , data_type , is_doctype ) :
for d in ren_data :
print colored ( ' Renaming... ' + d + ' --> ' + ren_data [ d ] , ' yellow ' )
#rename
try :
rename ( data_type , d , ren_data [ d ] , is_doctype )
except Exception , e :
print e
pass
def update_dt_in_records ( rendt ) :
for d in rendt :
# Feed, property setter, search criteria, gl mapper, form 16A, naming series options, doclayer - dodtype is not mentioed in options
2012-03-28 16:19:01 +05:30
dt_list = webnotes . conn . sql ( " select t1.parent, t1.fieldname from tabDocField t1, tabDocType t2 where t1.parent = t2.name and t1.fieldname in ( ' dt ' , ' doctype ' , ' doc_type ' , ' dt_type ' ) and ifnull(t1.options, ' ' ) = ' ' and ifnull(t2.issingle, 0) = 0 " )
2012-03-26 11:06:34 +05:30
for dt in dt_list :
2012-03-28 16:19:01 +05:30
webnotes . conn . sql ( " update `tab %s ` set %s = replace( %s , ' %s ' , ' %s ' ) where %s = ' %s ' " % ( dt [ 0 ] , dt [ 1 ] , dt [ 1 ] , d , rendt [ d ] , dt [ 1 ] , d ) )
2012-03-16 16:21:44 +05:30
# gl mapper, gl entry
2012-03-28 16:19:01 +05:30
webnotes . conn . sql ( " update `tabGL Mapper Detail` set against_voucher_type = replace(against_voucher_type, ' %s ' , ' %s ' ) where against_voucher_type like ' %% %s %% ' " % ( d , rendt [ d ] , d ) )
webnotes . conn . sql ( " update `tabGL Entry` set against_voucher_type = replace(against_voucher_type, ' %s ' , ' %s ' ) where against_voucher_type = ' %s ' " % ( d , rendt [ d ] , d ) )
webnotes . conn . sql ( " update `tabGL Entry` set voucher_type = replace(voucher_type, ' %s ' , ' %s ' ) where voucher_type = ' %s ' " % ( d , rendt [ d ] , d ) )
2012-03-16 16:21:44 +05:30
# Stock ledger entry
2012-03-28 16:19:01 +05:30
webnotes . conn . sql ( " update `tabStock ledger Entry` set voucher_type = replace(voucher_type, ' %s ' , ' %s ' ) where voucher_type = ' %s ' " % ( d , rendt [ d ] , d ) )
2012-03-16 16:21:44 +05:30
# Custom fld: options
webnotes . conn . sql ( " update `tabCustom Field` set options = replace(options, %s , %s ) where fieldtype in ( ' Link ' , ' Select ' ) " , ( d , rendt [ d ] ) )
#Property Setter: value (if property=options)
webnotes . conn . sql ( " update `tabProperty Setter` set value = replace(value, %s , %s ) where property = ' Options ' " , ( d , rendt [ d ] ) )
# custom script: script
webnotes . conn . sql ( " update `tabCustom Script` set script = replace(script, %s , %s ) " , ( d , rendt [ d ] ) )
# print format: html
webnotes . conn . sql ( " update `tabPrint Format` set html = replace(html, %s , %s ) where ifnull(standard, ' Yes ' ) = ' No ' " , ( d , rendt [ d ] ) )
# custom report: doc_type, filters, columns, parent_doc_type, add_cond, add_col, add_tab,
# dis_filters, group_by, sort_by, report_script, server_script, custom_query
webnotes . conn . sql ( """
update
` tabSearch Criteria `
set
doc_type = replace ( doc_type , % s , % s ) ,
filters = replace ( filters , % s , % s ) ,
columns = replace ( columns , % s , % s ) ,
parent_doc_type = replace ( parent_doc_type , % s , % s ) ,
add_cond = replace ( add_cond , % s , % s ) ,
add_col = replace ( add_col , % s , % s ) ,
add_tab = replace ( add_tab , % s , % s ) ,
dis_filters = replace ( dis_filters , % s , % s ) ,
group_by = replace ( group_by , % s , % s ) ,
sort_by = replace ( sort_by , % s , % s ) ,
report_script = replace ( report_script , % s , % s ) ,
server_script = replace ( server_script , % s , % s ) ,
custom_query = replace ( custom_query , % s , % s )
where
ifnull ( standard , ' Yes ' ) = ' No '
""" , (d, rendt[d], d, rendt[d], d, rendt[d], d, rendt[d], d, rendt[d], d, rendt[d], d, rendt[d],
d , rendt [ d ] , d , rendt [ d ] , d , rendt [ d ] , d , rendt [ d ] , d , rendt [ d ] , d , rendt [ d ] , ) )
def get_dt_to_be_renamed ( ) :
2012-03-26 11:06:34 +05:30
rendt = {
2012-03-14 11:07:00 +05:30
' Receivable Voucher ' : ' Sales Invoice ' ,
' RV Detail ' : ' Sales Invoice Item ' ,
' RV Tax Detail ' : ' Sales Taxes and Charges ' ,
' Payable Voucher ' : ' Purchase Invoice ' ,
' PV Detail ' : ' Purchase Invoice Item ' ,
' Purchase Tax Detail ' : ' Purchase Taxes and Charges ' ,
' Indent ' : ' Purchase Request ' ,
' Indent Detail ' : ' Purchase Request Item ' ,
' QA Inspection Report ' : ' Quality Inspection ' ,
' Ticket ' : ' Task ' ,
' Manage Account ' : ' Global Defaults ' ,
' ToDo Item ' : ' ToDo ' ,
' Term ' : ' Terms and Conditions ' ,
' Static Parameter Detail ' : ' SMS Parameter ' ,
' SS Earning Detail ' : ' Salary Slip Earning ' ,
' SS Deduction Detail ' : ' Salary Slip Deduction ' ,
' Sales Order Detail ' : ' Sales Order Item ' ,
' Sales BOM Detail ' : ' Sales BOM Item ' ,
' Return Detail ' : ' Sales and Purchase Return Item ' ,
' Ref Rate Detail ' : ' Item Price ' ,
' Receiver Detail ' : ' SMS Receiver ' ,
' Quotation Detail ' : ' Quotation Item ' ,
' QA Specification Detail ' : ' Quality Inspection Reading ' ,
' Purchase Receipt Detail ' : ' Purchase Receipt Item ' ,
' Purchase Other Charges ' : ' Purchase Taxes and Charges Master ' ,
' PR Raw Material Detail ' : ' Purchase Receipt Item Supplied ' ,
' PP SO Detail ' : ' Production Plan Sales Order ' ,
' PP Detail ' : ' Production Plan Item ' ,
' PO Raw Material Detail ' : ' Purchase Order Item Supplied ' ,
' PO Detail ' : ' Purchase Order Item ' ,
' Packing Slip Detail ' : ' Packing Slip Item ' ,
' Other Charges ' : ' Sales Taxes and Charges Master ' ,
' Order Lost Reason ' : ' Quotation Lost Reason ' ,
' Manage Account ' : ' Global Defaults ' ,
' Maintenance Visit Detail ' : ' Maintenance Visit Purpose ' ,
' Ledger Balance Export ' : ' Multi Ledger Report ' ,
' LC PR Detail ' : ' Landed Cost Purchase Receipt ' ,
' Landed Cost Detail ' : ' Landed Cost Item ' ,
' KRA Template ' : ' Appraisal Template ' ,
' KRA Sheet ' : ' Appraisal Template Goal ' ,
' Item Specification Detail ' : ' Item Quality Inspection Parameter ' ,
' Item Maintenance Detail ' : ' Maintenance Schedule Item ' ,
' IR Payment Detail ' : ' Payment to Invoice Matching Tool Detail ' ,
' Internal Reconciliation ' : ' Payment to Invoice Matching Tool ' ,
' Installed Item Details ' : ' Installation Note Item ' ,
' Holiday List Detail ' : ' Holiday ' ,
' Follow up ' : ' Communication Log ' ,
' Flat BOM Detail ' : ' BOM Explosion Item ' ,
' Expense Voucher Detail ' : ' Expense Claim Detail ' ,
' Expense Voucher ' : ' Expense Claim ' ,
' Expense Type ' : ' Expense Claim Type ' ,
' Enquiry Detail ' : ' Opportunity Item ' ,
' Enquiry ' : ' Opportunity ' ,
' Earning Detail ' : ' Salary Structure Earning ' ,
' DocLayerField ' : ' Customize Form Field ' ,
' DocLayer ' : ' Customize Form ' ,
' Delivery Note Detail ' : ' Delivery Note Item ' ,
' Deduction Detail ' : ' Salary Structure Deduction ' ,
' Comment Widget Record ' : ' Comment ' ,
' BOM Material ' : ' BOM Item ' ,
' Bill Of Materials ' : ' BOM ' ,
' Appraisal Detail ' : ' Appraisal Goal ' ,
' Advance Allocation Detail ' : ' Purchase Invoice Advance ' ,
2012-03-14 12:04:16 +05:30
' Advance Adjustment Detail ' : ' Sales Invoice Advance ' ,
2012-03-14 11:07:00 +05:30
' Ledger Detail ' : ' Multi Ledger Report Detail ' ,
' TA Control ' : ' Trend Analyzer Control ' ,
' Sales and Purchase Return Wizard ' : ' Sales and Purchase Return Tool ' ,
' Educational Qualifications Detail ' : ' Employee Education ' ,
' Delivery Note Packing Detail ' : ' Delivery Note Packing Item ' ,
' Experience In Company Detail ' : ' Employee Internal Work History ' ,
' Professional Training Details ' : ' Employee Training ' ,
' Previous Experience Detail ' : ' Employee External Work History ' ,
}
2012-03-16 16:21:44 +05:30
return rendt
2012-03-14 11:07:00 +05:30
2012-03-14 12:04:16 +05:30
2012-03-16 16:21:44 +05:30
def get_mapper_to_be_renamed ( ) :
ren_map = {
' Sales Order-Receivable Voucher ' : ' Sales Order-Sales Invoice ' ,
' Sales Order-Indent ' : ' Sales Order-Purchase Request ' ,
' Receivable Voucher-Delivery Note ' : ' Sales Invoice-Delivery Note ' ,
' Purchase Receipt-Payable Voucher ' : ' Purchase Receipt-Purchase Invoice ' ,
' Purchase Order-Payable Voucher ' : ' Purchase Order-Purchase Invoice ' ,
' Project-Receivable Voucher ' : ' Project-Sales Invoice ' ,
' Lead-Enquiry ' : ' Lead-Opportunity ' ,
' KRA Template-Appraisal ' : ' Appraisal Template-Appraisal ' ,
' Indent-Purchase Order ' : ' Purchase Request-Purchase Order ' ,
' Enquiry-Quotation ' : ' Opportunity-Quotation ' ,
' Delivery Note-Receivable Voucher ' : ' Delivery Note-Sales Invoice '
}
2012-03-30 12:29:06 +05:30
return ren_map
2012-03-14 11:07:00 +05:30
2012-03-14 12:04:16 +05:30
2012-03-16 16:21:44 +05:30
#--------------------------------------------------------------------------------------------------------
2012-03-14 11:07:00 +05:30
2012-03-16 16:21:44 +05:30
def update_local_file_system ( ) :
""" RUN ONLY IN LOCAL """
# doctype renaming
rendt = get_dt_to_be_renamed ( )
2012-03-14 11:07:00 +05:30
2012-03-16 16:21:44 +05:30
# replace dt in js/py file
2012-03-30 18:18:36 +05:30
update_file_content ( rendt )
2012-03-16 16:21:44 +05:30
# git mv
2012-03-30 18:18:36 +05:30
rename_dt_files ( rendt )
2012-03-14 11:07:00 +05:30
2012-03-16 16:21:44 +05:30
# Mapper renaming
ren_mapper = get_mapper_to_be_renamed ( )
2012-03-14 11:07:00 +05:30
2012-03-16 16:21:44 +05:30
rename_mapper_files ( ren_mapper )
2012-03-14 11:07:00 +05:30
2012-03-30 18:18:36 +05:30
os . system ( ' git mv erpnext/accounts/GL \ Mapper/Payable \ Voucher erpnext/accounts/GL \ Mapper/Purchase \ Invoice ' )
os . system ( ' git mv erpnext/accounts/GL \ Mapper/Purchase \ Invoice/Payable \ Voucher.txt erpnext/accounts/GL \ Mapper/Purchase \ Invoice/Purchase \ Invoice.txt ' )
os . system ( ' git mv erpnext/accounts/GL \ Mapper/Receivable \ Voucher erpnext/accounts/GL \ Mapper/Sales \ Invoice ' )
os . system ( ' git mv erpnext/accounts/GL \ Mapper/Sales \ Invoice/Receivable \ Voucher.txt erpnext/accounts/GL \ Mapper/Sales \ Invoice/Sales \ Invoice.txt ' )
2012-03-16 16:21:44 +05:30
# git rm production dt mapper
os . system ( ' git rm -r erpnext/production/DocType \ Mapper/ ' )
def update_file_content ( rendt ) :
for d in rendt :
2012-03-30 12:29:06 +05:30
print colored ( ' Renaming... ' + d + ' --> ' + rendt [ d ] , ' yellow ' )
2012-04-02 19:12:29 +05:30
for extn in [ ' js ' , ' py ' , ' txt ' , ' html ' ] :
res = replace_code ( ' /var/www/erpnext/ ' , d , rendt [ d ] , extn )
if res == ' skip ' :
break
2012-03-16 16:21:44 +05:30
def rename_dt_files ( rendt ) :
for d in rendt :
mod = webnotes . conn . sql ( " select module from tabDocType where name = %s " , rendt [ d ] ) [ 0 ] [ 0 ]
2012-04-02 19:12:29 +05:30
if mod == ' Core ' :
os . chdir ( ' /var/www/erpnext/lib/ ' )
path = ' py/core/doctype/ '
else :
os . chdir ( ' /var/www/erpnext/ ' )
path = ' erpnext/ ' + ' _ ' . join ( mod . lower ( ) . split ( ) ) + ' /doctype/ '
2012-03-16 16:21:44 +05:30
old = ' _ ' . join ( d . lower ( ) . split ( ) )
new = ' _ ' . join ( rendt [ d ] . lower ( ) . split ( ) )
2012-04-02 19:12:29 +05:30
print ' git mv ' + path + old + ' ' + path + new
2012-03-16 16:21:44 +05:30
# rename old dir
os . system ( ' git mv ' + path + old + ' ' + path + new )
# rename all files in that dir
2012-04-02 19:12:29 +05:30
for extn in [ ' js ' , ' py ' , ' txt ' , ' html ' ] :
2012-03-16 16:21:44 +05:30
if os . path . exists ( path + new + ' / ' + old + ' . ' + extn ) :
os . system ( ' git mv ' + path + new + ' / ' + old + ' . ' + extn + ' ' + path + new + ' / ' + new + ' . ' + extn )
print ' git mv ' + path + new + ' / ' + old + ' . ' + extn + ' ' + path + new + ' / ' + new + ' . ' + extn
def rename_mapper_files ( ren_mapper ) :
for d in ren_mapper :
# module
2012-03-30 18:18:36 +05:30
mod = ' _ ' . join ( webnotes . conn . sql ( " select module from `tabDocType Mapper` where name = %s " , ren_mapper [ d ] ) [ 0 ] [ 0 ] . lower ( ) . split ( ) )
2012-03-16 16:21:44 +05:30
path = ' erpnext/ ' + mod + ' /DocType Mapper/ '
# rename old dir
esc = make_esc ( ' $ ' )
os . system ( ' git mv ' + esc ( path + d ) + ' ' + esc ( path + ren_mapper [ d ] ) )
print ' git mv ' + esc ( path + d ) + ' ' + esc ( path + ren_mapper [ d ] )
2012-03-30 12:29:06 +05:30
os . system ( ' git mv ' + esc ( path + ren_mapper [ d ] + ' / ' + d + ' .txt ' )
+ ' ' + esc ( path + ren_mapper [ d ] + ' / ' + ren_mapper [ d ] + ' .txt ' ) )
2012-03-16 16:21:44 +05:30
print ' git mv ' + esc ( path + ren_mapper [ d ] + ' / ' + d + ' .txt ' ) + ' ' + esc ( path + ren_mapper [ d ] + ' / ' + ren_mapper [ d ] + ' .txt ' )