2012-03-16 10:51:44 +00:00
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 08:36:46 +00:00
from webnotes . modules import reload_doc
2012-03-16 10:51:44 +00:00
from webnotes . utils import make_esc
import os
2012-04-05 12:57:56 +00:00
def execute1 ( ) :
2012-04-05 07:33:35 +00:00
#rendt = get_dt_to_be_renamed()
#rename_dt_files(rendt)
2012-04-02 13:42:29 +00:00
#update_local_file_system()
2012-04-05 07:33:35 +00:00
replace_labels_with_fieldnames ( )
2012-04-02 13:42:29 +00:00
2012-04-05 12:57:56 +00:00
def execute ( ) :
2012-04-06 12:24:17 +00:00
2012-03-16 10:51:44 +00:00
#---------------------------------------------------
# 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 :
2012-04-06 12:24:17 +00:00
mod = ' _ ' . join ( webnotes . conn . sql ( " select module from `tabDocType Mapper` where name = %s " ,
ren_mapper [ d ] ) [ 0 ] [ 0 ] . lower ( ) . split ( ) )
2012-03-16 10:51:44 +00:00
reload_doc ( mod , ' DocType Mapper ' , ren_mapper [ d ] )
2012-04-06 12:24:17 +00:00
delete_search_criteria ( )
# reload custom search criteria
#for d in webnotes.conn.sql("""select name, module from
# `tabSearch Criteria` where ifnull(standard, 'No') = 'Yes' and ifnull(disabled, 0) = 0"""):
#
for path , folders , files in os . walk ( webnotes . defs . modules_path ) :
if not path . endswith ( ' search_criteria ' ) : continue
module = path . split ( os . sep ) [ - 2 ]
for sc in folders :
try :
reload_doc ( module , ' search_criteria ' , sc )
print module , sc
except Exception , e :
print " did not reload: " + str ( d )
2012-03-30 12:48:36 +00:00
2012-04-06 12:24:17 +00:00
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 ' ) """ )
# reload custom print format
for d in webnotes . conn . sql ( """ select name, module from `tabPrint Format`
where ifnull ( standard , ' No ' ) = ' Yes ' """ ):
try :
reload_doc ( d [ 1 ] , ' Print Format ' , d [ 0 ] )
except Exception , e :
print " did not reload: " + str ( d )
# 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_search_criteria ( ) :
2012-04-05 07:33:35 +00:00
webnotes . conn . sql ( """ DELETE FROM `tabSearch Criteria`
WHERE name IN ( ' ' , ' bills-to_be_paid ' ,
2012-03-30 12:48:36 +00:00
' bills-to_be_submitted ' , ' cenvat_credit_-_input_or_capital_goods ' ,
2012-04-05 07:33:35 +00:00
' appraisal_custom ' , ' custom_test ' , ' custom_test1 ' , ' delivery_note-to_be_billed ' ,
2012-03-30 12:48:36 +00:00
' 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 ' ,
2012-04-05 07:33:35 +00:00
' territory_wise_sales_-_target_vs_actual_ ' , ' test_report ' ,
' lease_agreement_list ' , ' lease_monthly_future_installment_inflows ' ,
' lease_over_due_list ' , ' lease_overdue_age_wise ' ,
' lease_receipt_summary_month_wise ' , ' lease_receipts_client_wise ' ,
' lease_yearly_future_installment_inflows ' ,
' monthly_ledger_summary_report ' , ' payables_-_as_on_outstanding ' ,
2012-04-05 12:57:56 +00:00
' payment_report ' , ' progressive_total_excise_duty ' ,
' service_tax_credit_account_-_inputs ' ,
' total_amout_collection_for_a_period_-_customerwise ' ,
' invoices-to_be_submitted ' , ' invoices-to_receive_payment ' ,
' opportunity-quotations_to_be_sent ' , ' purchase_order-to_be_billed ' ,
' purchase_order-to_be_submitted ' ,
' purchase_order-to_receive_items ' ,
' purchase_request-purchase_order_to_be_made ' ,
' purchase_request-to_be_submitted ' ,
' sales-order_to_be_submitted ' , ' sales_order-overdue ' ,
' sales_order-to_be_billed ' , ' sales_order-to_be_delivered ' ,
' sales_order-to_be_submitted ' , ' task-open ' , ' appraisal_custom ' ,
' employee_details ' , ' employee_in_company_experience ' ,
' employee_leave_balance_report ' , ' employeewise_leave_transaction_details ' ,
' pending_appraisals ' , ' pending_expense_claims ' , ' delivery_plan ' , ' flat_bom_report ' ,
' dispatch_report ' , ' projectwise_delivered_qty_and_costs_as_per_purchase_cost ' ,
' projectwise_pending_qty_and_costs_as_per_purchase_cost ' , ' custom_test ' , ' custom_test1 ' ,
' delivery_notes ' , ' delivery_note_disabled ' , ' lead ' , ' lead_interested ' , ' lead_report ' ,
' periodic_sales_summary ' , ' monthly_despatched_trend ' , ' sales ' , ' sales_order ' ,
2012-04-06 12:24:17 +00:00
' sales_order1 ' , ' sales_agentwise_commission ' , ' test_report ' ,
' territory_wise_sales_-_target_vs_actual_ ' ) """ )
2012-04-05 12:57:56 +00:00
webnotes . conn . sql ( """
DELETE FROM ` tabSearch Criteria `
WHERE name IN ( ' monthly_transaction_summary ' , ' trend_analyzer ' ,
' yearly_transaction_summary ' , ' invoices-overdue ' , ' lead-to_follow_up ' ,
' opportunity-to_follow_up ' , ' serial_no-amc_expiring_this_month ' ,
2012-04-06 12:24:17 +00:00
' serial_no-warranty_expiring_this_month ' )
2012-04-05 12:57:56 +00:00
AND IFNULL ( standard , ' No ' ) = ' Yes '
""" )
2012-03-16 10:51:44 +00:00
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-04-06 12:24:17 +00:00
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 and t1.parent in ( ' Custom Field ' , ' Custom Script ' ) " )
2012-03-26 05:36:34 +00:00
for dt in dt_list :
2012-03-28 10:49:01 +00:00
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 10:51:44 +00:00
# gl mapper, gl entry
2012-03-28 10:49:01 +00:00
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 10:51:44 +00:00
# Stock ledger entry
2012-04-09 06:32:15 +00:00
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 10:51:44 +00:00
# Custom fld: options
2012-04-10 13:44:37 +00:00
webnotes . conn . sql ( " update `tabCustom Field` set options = replace(options, %s , %s ) where fieldtype in ( ' Link ' , ' Select ' , ' Table ' ) " , ( d , rendt [ d ] ) )
2012-03-16 10:51:44 +00:00
#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 05:36:34 +00:00
rendt = {
2012-03-14 05:37:00 +00:00
' 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 06:34:16 +00:00
' Advance Adjustment Detail ' : ' Sales Invoice Advance ' ,
2012-03-14 05:37:00 +00:00
' 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 10:51:44 +00:00
return rendt
2012-03-14 05:37:00 +00:00
2012-03-14 06:34:16 +00:00
2012-03-16 10:51:44 +00:00
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 06:59:06 +00:00
return ren_map
2012-03-14 05:37:00 +00:00
2012-03-14 06:34:16 +00:00
2012-03-16 10:51:44 +00:00
#--------------------------------------------------------------------------------------------------------
2012-03-14 05:37:00 +00:00
2012-03-16 10:51:44 +00:00
def update_local_file_system ( ) :
""" RUN ONLY IN LOCAL """
# doctype renaming
rendt = get_dt_to_be_renamed ( )
2012-03-14 05:37:00 +00:00
2012-03-16 10:51:44 +00:00
# replace dt in js/py file
2012-03-30 12:48:36 +00:00
update_file_content ( rendt )
2012-03-16 10:51:44 +00:00
# git mv
2012-03-30 12:48:36 +00:00
rename_dt_files ( rendt )
2012-03-14 05:37:00 +00:00
2012-03-16 10:51:44 +00:00
# Mapper renaming
ren_mapper = get_mapper_to_be_renamed ( )
2012-03-14 05:37:00 +00:00
2012-03-16 10:51:44 +00:00
rename_mapper_files ( ren_mapper )
2012-03-14 05:37:00 +00:00
2012-03-30 12:48:36 +00:00
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 10:51:44 +00:00
# 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 06:59:06 +00:00
print colored ( ' Renaming... ' + d + ' --> ' + rendt [ d ] , ' yellow ' )
2012-04-02 13:42:29 +00:00
for extn in [ ' js ' , ' py ' , ' txt ' , ' html ' ] :
res = replace_code ( ' /var/www/erpnext/ ' , d , rendt [ d ] , extn )
if res == ' skip ' :
break
2012-03-16 10:51:44 +00:00
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 13:42:29 +00:00
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 10:51:44 +00:00
old = ' _ ' . join ( d . lower ( ) . split ( ) )
new = ' _ ' . join ( rendt [ d ] . lower ( ) . split ( ) )
2012-04-02 13:42:29 +00:00
print ' git mv ' + path + old + ' ' + path + new
2012-03-16 10:51:44 +00:00
# rename old dir
os . system ( ' git mv ' + path + old + ' ' + path + new )
# rename all files in that dir
2012-04-02 13:42:29 +00:00
for extn in [ ' js ' , ' py ' , ' txt ' , ' html ' ] :
2012-03-16 10:51:44 +00:00
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 12:48:36 +00:00
mod = ' _ ' . join ( webnotes . conn . sql ( " select module from `tabDocType Mapper` where name = %s " , ren_mapper [ d ] ) [ 0 ] [ 0 ] . lower ( ) . split ( ) )
2012-03-16 10:51:44 +00:00
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 06:59:06 +00:00
os . system ( ' git mv ' + esc ( path + ren_mapper [ d ] + ' / ' + d + ' .txt ' )
+ ' ' + esc ( path + ren_mapper [ d ] + ' / ' + ren_mapper [ d ] + ' .txt ' ) )
2012-03-16 10:51:44 +00:00
print ' git mv ' + esc ( path + ren_mapper [ d ] + ' / ' + d + ' .txt ' ) + ' ' + esc ( path + ren_mapper [ d ] + ' / ' + ren_mapper [ d ] + ' .txt ' )
2012-04-05 07:33:35 +00:00
def replace_labels_with_fieldnames ( ) :
"""
This is used for replacing instances like cur_frm . cscript [ ' LABEL ' ] with
cur_frm . cscript . FIELDNAME in js files
"""
doctype = { }
doctype . update ( prepare_dict_of_label_fieldname ( ' /var/www/erpnext/erpnext/ ' ) )
doctype . update ( prepare_dict_of_label_fieldname ( ' /var/www/erpnext/lib/py ' ) )
#print doctype
for doc in doctype :
label_fieldname = doctype [ doc ]
for d in label_fieldname :
#label = "cur_frm.cscript['%s']" % d
#fieldname = "cur_frm.cscript.%s" % label_fieldname[d]
label = d
fieldname = label_fieldname [ d ]
print colored ( ' Changing... ' + doc + ' : ' + label + ' --> ' + fieldname , ' yellow ' )
#res = replace_code('/var/www/erpnext/', label, fieldname, 'js')
res = replace_code ( ' /var/www/erpnext/ ' , label , fieldname , ' js ' ,
' hide_field \ (.* %s ' % label )
if res == ' skip ' :
break
def prepare_dict_of_label_fieldname ( module_path ) :
from webnotes . model . utils import peval_doclist
from webnotes . model . sync import get_file_path
doctype = { }
for path , folders , files in os . walk ( module_path ) :
if path == module_path :
modules_list = folders
for f in files :
if f . endswith ( " .txt " ) :
rel_path = os . path . relpath ( path , webnotes . defs . modules_path )
path_tuple = rel_path . split ( os . sep )
if ( len ( path_tuple ) == 3 and path_tuple [ 0 ] in modules_list and
path_tuple [ 1 ] == ' doctype ' ) :
file_name = f [ : - 4 ]
with open ( get_file_path ( path_tuple [ 0 ] , file_name ) , ' r ' ) as fn :
doclist = peval_doclist ( fn . read ( ) )
doctype [ file_name ] = dict ( ( [ d . get ( ' label ' ) , d . get ( ' fieldname ' ) ] \
for d in doclist if d . get ( ' doctype ' ) == ' DocField ' ) )
return doctype