rename Production --> Manufacturing and delete old patches
This commit is contained in:
parent
29c187118f
commit
89e2dd8dbb
@ -4,7 +4,7 @@
|
|||||||
"docstatus": 0,
|
"docstatus": 0,
|
||||||
"creation": "2012-08-06 11:15:46",
|
"creation": "2012-08-06 11:15:46",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"modified": "2012-08-02 18:04:35"
|
"modified": "2012-12-10 18:30:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"is_submittable": 1,
|
"is_submittable": 1,
|
||||||
@ -698,7 +698,7 @@
|
|||||||
"doctype": "DocPerm",
|
"doctype": "DocPerm",
|
||||||
"submit": 1,
|
"submit": 1,
|
||||||
"write": 1,
|
"write": 1,
|
||||||
"role": "Production Manager",
|
"role": "Manufacturing Manager",
|
||||||
"cancel": 1,
|
"cancel": 1,
|
||||||
"permlevel": 0
|
"permlevel": 0
|
||||||
},
|
},
|
||||||
|
@ -265,7 +265,7 @@ class DocType:
|
|||||||
# module settings
|
# module settings
|
||||||
# -------------------------------------------------------------------------------------------------------
|
# -------------------------------------------------------------------------------------------------------
|
||||||
def get_module_order(self):
|
def get_module_order(self):
|
||||||
show_list = ['Home','Setup','Accounts','Selling','Buying','Support','Stock','HR','Projects','Analysis','Production']
|
show_list = ['Home','Setup','Accounts','Selling','Buying','Support','Stock','HR','Projects','Analysis','Manufacturing']
|
||||||
ml = filter(lambda x: x[0] in show_list, \
|
ml = filter(lambda x: x[0] in show_list, \
|
||||||
sql("select name, module_label, module_seq, is_hidden from `tabModule Def` where docstatus<2 order by module_seq asc, module_label asc"))
|
sql("select name, module_label, module_seq, is_hidden from `tabModule Def` where docstatus<2 order by module_seq asc, module_label asc"))
|
||||||
return webnotes.conn.convert_to_lists(ml)
|
return webnotes.conn.convert_to_lists(ml)
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
.sprite-hr{ background-position: 0 -439px; width: 40px; height: 32px; }
|
.sprite-hr{ background-position: 0 -439px; width: 40px; height: 32px; }
|
||||||
.sprite-kb{ background-position: 0 -521px; width: 24px; height: 39px; }
|
.sprite-kb{ background-position: 0 -521px; width: 24px; height: 39px; }
|
||||||
.sprite-messages{ background-position: 0 -610px; width: 40px; height: 26px; }
|
.sprite-messages{ background-position: 0 -610px; width: 40px; height: 26px; }
|
||||||
.sprite-production{ background-position: 0 -686px; width: 40px; height: 33px; }
|
.sprite-manufacturing{ background-position: 0 -686px; width: 40px; height: 33px; }
|
||||||
.sprite-project{ background-position: 0 -769px; width: 40px; height: 22px; }
|
.sprite-project{ background-position: 0 -769px; width: 40px; height: 22px; }
|
||||||
.sprite-report{ background-position: 0 -841px; width: 29px; height: 40px; }
|
.sprite-report{ background-position: 0 -841px; width: 29px; height: 40px; }
|
||||||
.sprite-selling{ background-position: 0 -931px; width: 34px; height: 40px; }
|
.sprite-selling{ background-position: 0 -931px; width: 34px; height: 40px; }
|
||||||
@ -26,7 +26,7 @@
|
|||||||
.sprite-support{ margin-top: 8px; margin-left: 8px; }
|
.sprite-support{ margin-top: 8px; margin-left: 8px; }
|
||||||
.sprite-hr{ margin-top: 12px; margin-left: 8px; }
|
.sprite-hr{ margin-top: 12px; margin-left: 8px; }
|
||||||
.sprite-project{ margin-top: 16px; margin-left: 8px; }
|
.sprite-project{ margin-top: 16px; margin-left: 8px; }
|
||||||
.sprite-production{ margin-top: 10px; margin-left: 8px; }
|
.sprite-manufacturing{ margin-top: 10px; margin-left: 8px; }
|
||||||
.sprite-website{ margin-top: 8px; margin-left: 8px; }
|
.sprite-website{ margin-top: 8px; margin-left: 8px; }
|
||||||
.sprite-setting{ margin-top: 8px; margin-left: 8px; }
|
.sprite-setting{ margin-top: 8px; margin-left: 8px; }
|
||||||
.sprite-report{ margin-top: 8px; margin-left: 14px; }
|
.sprite-report{ margin-top: 8px; margin-left: 14px; }
|
||||||
|
@ -33,7 +33,7 @@ erpnext.desktop.render = function() {
|
|||||||
'Support': { sprite: 'support', label: 'Support'},
|
'Support': { sprite: 'support', label: 'Support'},
|
||||||
'HR': { sprite: 'hr', label: 'Human<br />Resources'},
|
'HR': { sprite: 'hr', label: 'Human<br />Resources'},
|
||||||
'Projects': { sprite: 'project', label: 'Projects'},
|
'Projects': { sprite: 'project', label: 'Projects'},
|
||||||
'Production': { sprite: 'production', label: 'Production'},
|
'Manufacturing': { sprite: 'manufacturing', label: 'Manufacturing'},
|
||||||
'Website': { sprite: 'website', label: 'Website'},
|
'Website': { sprite: 'website', label: 'Website'},
|
||||||
'Activity': { sprite: 'feed', label: 'Activity'},
|
'Activity': { sprite: 'feed', label: 'Activity'},
|
||||||
'Setup': { sprite: 'setting', label: 'Setup'},
|
'Setup': { sprite: 'setting', label: 'Setup'},
|
||||||
|
@ -1,31 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
reload_doc('accounts', 'doctype', 'pv_detail')
|
|
||||||
reload_doc('buying', 'doctype', 'po_detail')
|
|
||||||
reload_doc('stock', 'doctype', 'purchase_receipt_detail')
|
|
||||||
if webnotes.conn.sql("select name from `tabDocField` where parent = 'Purchase Order Item' and fieldname = 'discount'"):
|
|
||||||
webnotes.conn.sql("update `tabPurchase Order Item` set discount_rate=discount")
|
|
||||||
|
|
||||||
# Features setup
|
|
||||||
reload_doc('setup', 'doctype', 'features_setup')
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
get_obj('Features Setup').validate()
|
|
@ -1 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
@ -1,23 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('setup', 'doctype', 'company')
|
|
||||||
reload_doc('setup', 'doctype', 'manage_account')
|
|
||||||
|
|
@ -1,25 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('setup', 'doctype', 'manage_account')
|
|
||||||
reload_doc('stock', 'doctype', 'item')
|
|
||||||
webnotes.conn.sql("delete from `tabDocField` where fieldname='minimum_inventory_level' and parent='item'")
|
|
||||||
webnotes.conn.sql("update `tabItem` set re_order_level = minimum_inventory_level where ifnull(re_order_level,0) = 0 ")
|
|
||||||
|
|
@ -1,29 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
reload_doc('accounts', 'doctype', 'receivable_voucher')
|
|
||||||
reload_doc('accounts', 'doctype', 'c_form')
|
|
||||||
reload_doc('accounts', 'doctype', 'c_form_invoice_detail')
|
|
||||||
reload_doc('accounts', 'Module Def', 'Accounts')
|
|
||||||
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
sql("update `tabSales Invoice` set c_form_applicable = 'Yes' where c_form_applicable = 'Y'")
|
|
||||||
sql("update `tabSales Invoice` set c_form_applicable = 'No' where c_form_applicable = 'N'")
|
|
@ -1,72 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
|
|
||||||
test=1
|
|
||||||
|
|
||||||
# Update SO and DN Detail
|
|
||||||
#--------------------------
|
|
||||||
def update_delivered_billed_qty():
|
|
||||||
# update billed amt in item table in so and dn
|
|
||||||
sql(""" update `tabSales Order Item` so
|
|
||||||
set billed_amt = (select sum(amount) from `tabSales Invoice Item` where `so_detail`= so.name and docstatus=1 and parent not like 'old%%'),
|
|
||||||
delivered_qty = (select sum(qty) from `tabDelivery Note Item` where `prevdoc_detail_docname`= so.name and docstatus=1 and parent not like 'old%%'),
|
|
||||||
modified = now()
|
|
||||||
where docstatus = 1
|
|
||||||
""")
|
|
||||||
|
|
||||||
sql(""" update `tabDelivery Note Item` dn
|
|
||||||
set billed_amt = (select sum(amount) from `tabSales Invoice Item` where `dn_detail`= dn.name and docstatus=1 and parent not like 'old%%'),
|
|
||||||
modified = now()
|
|
||||||
where docstatus = 1
|
|
||||||
""")
|
|
||||||
|
|
||||||
# update SO
|
|
||||||
#---------------
|
|
||||||
def update_percent():
|
|
||||||
# calculate % billed based on item table
|
|
||||||
sql(""" update `tabSales Order` so
|
|
||||||
set per_delivered = (select sum(if(qty > ifnull(delivered_qty, 0), delivered_qty, qty))/sum(qty)*100 from `tabSales Order Item` where parent=so.name),
|
|
||||||
per_billed = (select sum(if(amount > ifnull(billed_amt, 0), billed_amt, amount))/sum(amount)*100 from `tabSales Order Item` where parent = so.name),
|
|
||||||
modified = now()
|
|
||||||
where docstatus = 1
|
|
||||||
""")
|
|
||||||
|
|
||||||
# update DN
|
|
||||||
# ---------
|
|
||||||
sql(""" update `tabDelivery Note` dn
|
|
||||||
set per_billed = (select sum(if(amount > ifnull(billed_amt, 0), billed_amt, amount))/sum(amount)*100 from `tabDelivery Note Item` where parent = dn.name),
|
|
||||||
modified = now()
|
|
||||||
where docstatus=1
|
|
||||||
""")
|
|
||||||
|
|
||||||
# update delivery/billing status
|
|
||||||
#-------------------------------
|
|
||||||
def update_status():
|
|
||||||
sql("""update `tabSales Order` set delivery_status = if(ifnull(per_delivered,0) < 0.001, 'Not Delivered',
|
|
||||||
if(per_delivered >= 99.99, 'Fully Delivered', 'Partly Delivered'))""")
|
|
||||||
sql("""update `tabSales Order` set billing_status = if(ifnull(per_billed,0) < 0.001, 'Not Billed',
|
|
||||||
if(per_billed >= 99.99, 'Fully Billed', 'Partly Billed'))""")
|
|
||||||
sql("""update `tabDelivery Note` set billing_status = if(ifnull(per_billed,0) < 0.001, 'Not Billed',
|
|
||||||
if(per_billed >= 99.99, 'Fully Billed', 'Partly Billed'))""")
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
update_delivered_billed_qty()
|
|
||||||
update_percent()
|
|
||||||
update_status()
|
|
@ -1,113 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Reload email_digest doctype
|
|
||||||
* Create default email digest
|
|
||||||
"""
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
# Minor fix in print_format doctype
|
|
||||||
#reload_doc('core', 'doctype', 'print_format')
|
|
||||||
|
|
||||||
#reload_doc('setup', 'doctype', 'email_digest')
|
|
||||||
|
|
||||||
#global create_default_email_digest
|
|
||||||
#create_default_email_digest()
|
|
||||||
|
|
||||||
global enabled_default_email_digest
|
|
||||||
enabled_default_email_digest()
|
|
||||||
|
|
||||||
|
|
||||||
def enabled_default_email_digest():
|
|
||||||
"""
|
|
||||||
Enables the created email digest
|
|
||||||
"""
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
companies_list = webnotes.conn.sql("SELECT company_name FROM `tabCompany`", as_list=1)
|
|
||||||
for company in companies_list:
|
|
||||||
if company and company[0]:
|
|
||||||
edigest = Document('Email Digest', 'Default Weekly Digest - ' + company[0])
|
|
||||||
if edigest:
|
|
||||||
edigest.enabled = 1
|
|
||||||
edigest.save()
|
|
||||||
ed_obj = get_obj(doc=edigest)
|
|
||||||
ed_obj.on_update()
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def create_default_email_digest():
|
|
||||||
"""
|
|
||||||
* Weekly Digest
|
|
||||||
* For all companies
|
|
||||||
* Recipients: System Managers
|
|
||||||
* Full content
|
|
||||||
* Disabled by default
|
|
||||||
"""
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
companies_list = webnotes.conn.sql("SELECT company_name FROM `tabCompany`", as_list=1)
|
|
||||||
global get_system_managers
|
|
||||||
system_managers = get_system_managers()
|
|
||||||
for company in companies_list:
|
|
||||||
if company and company[0]:
|
|
||||||
edigest = Document('Email Digest')
|
|
||||||
edigest.name = "Default Weekly Digest - " + company[0]
|
|
||||||
edigest.company = company[0]
|
|
||||||
edigest.frequency = 'Weekly'
|
|
||||||
edigest.recipient_list = system_managers
|
|
||||||
edigest.new_leads = 1
|
|
||||||
edigest.new_enquiries = 1
|
|
||||||
edigest.new_quotations = 1
|
|
||||||
edigest.new_sales_orders = 1
|
|
||||||
edigest.new_purchase_orders = 1
|
|
||||||
edigest.new_transactions = 1
|
|
||||||
edigest.payables = 1
|
|
||||||
edigest.payments = 1
|
|
||||||
edigest.expenses_booked = 1
|
|
||||||
edigest.invoiced_amount = 1
|
|
||||||
edigest.collections = 1
|
|
||||||
edigest.income = 1
|
|
||||||
edigest.bank_balance = 1
|
|
||||||
exists = webnotes.conn.sql("""\
|
|
||||||
SELECT name FROM `tabEmail Digest`
|
|
||||||
WHERE name = %s""", edigest.name)
|
|
||||||
if (exists and exists[0]) and exists[0][0]:
|
|
||||||
continue
|
|
||||||
else:
|
|
||||||
edigest.save(1)
|
|
||||||
|
|
||||||
|
|
||||||
def get_system_managers():
|
|
||||||
"""
|
|
||||||
Returns a string of system managers' email addresses separated by \n
|
|
||||||
"""
|
|
||||||
system_managers_list = webnotes.conn.sql("""\
|
|
||||||
SELECT DISTINCT p.name
|
|
||||||
FROM tabUserRole ur, tabProfile p
|
|
||||||
WHERE
|
|
||||||
ur.parent = p.name AND
|
|
||||||
ur.role='System Manager' AND
|
|
||||||
p.docstatus<2 AND
|
|
||||||
p.enabled=1 AND
|
|
||||||
p.name not in ('Administrator', 'Guest')""", as_list=1)
|
|
||||||
|
|
||||||
return "\n".join([sysman[0] for sysman in system_managers_list])
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
companies_list = webnotes.conn.sql("SELECT company_name FROM `tabCompany`", as_list=1)
|
|
||||||
for company in companies_list:
|
|
||||||
if company and company[0]:
|
|
||||||
edigest = Document('Email Digest', "Default Weekly Digest - " + company[0])
|
|
||||||
if edigest:
|
|
||||||
edigest.income_year_to_date = 1
|
|
||||||
edigest.save()
|
|
@ -1,217 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
#Cleanup all unwanted documents and restructure of moduloes
|
|
||||||
#----------------------------------------------------------
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
from webnotes.model import delete_doc
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
from webnotes.modules.export_file import export_to_files
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
|
|
||||||
|
|
||||||
#----------------------------
|
|
||||||
|
|
||||||
def delete_unwanted_doctypes():
|
|
||||||
"deletes doctypes which are not used anymore"
|
|
||||||
|
|
||||||
try:
|
|
||||||
sql("delete from `tabMenu Item`")
|
|
||||||
sql("delete from tabDocField where fieldname = 'site_map_details' and parent ='Control Panel'")
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
lst = ['Zone', 'WN Account Control', 'Wiki Page', 'Wiki History', 'Wiki Control', 'While You Were Out', 'Web Visitor', 'Tweet', 'Transfer Utility', 'Transfer Module', 'Transfer Control', 'Transfer Account', 'Tips Common', 'TestTabDT', 'TestDT', 'Test Type', 'Test Run', 'Test Record Detail', 'Test Record', 'Test Case', 'Supplier TDS Category Detail', 'Shopping Cart Control', 'Service Series', 'Series Detail', 'Rule Engine', 'RFQ', 'Report Filter Detail', 'Report Field Detail','Report Control', 'Rating Widget Record', 'Rating Widget Control', 'Rating Template Detail', 'Rating Template', 'PV Ded Tax Detail', 'PV Add Tax Detail', 'Product Variant', 'Product Variance', 'Product Group', 'Product Feature', 'Payroll Tips Common', 'Payroll Rule', 'Password Control', 'Page Visit', 'Patch', 'Multiple Transfer', 'Module Tip Control', 'Module Setter', 'Module Manager', 'Module Import', 'Module Detail', 'Message Control', 'Message', 'Mail Participant Details', 'Mail', 'Leave Type Detail', 'Leave Detail', 'Leave Applicable Detail', 'Lead Item Detail', 'Lead Attachment Detail', 'Item Attachments Detail', 'Instant Message', 'Impact Analysis', 'Forum Topic', 'Forum Control', 'Form Settings', 'Follower', 'ERP Setup', 'Enquiry Attachment Detail', 'Documentation', 'Condition Detail', 'Complaint Note', 'Code History', 'Code Editor', 'Code Backup Control', 'Code Backup', 'City', 'Change Log', 'Business Letter Type', 'Business Letter Template', 'Business Letter', 'Badge Settings Detail', 'Application Type', 'Application', 'Action Detail', 'Accounts Setup', 'Stock Common', 'Job Application', 'Service Schedule', 'Comment Control', 'Bank', 'Tag Widget Control', 'Feature Update', 'RFQ Detail', 'Supplier Quotation Detail', 'Supplier Quotation', 'Year Closing Voucher', 'Approval Structure', 'Site Map Detail', 'Menu Control', 'Menu Item', 'Menu Item Role'] # bank
|
|
||||||
for d in lst:
|
|
||||||
try:
|
|
||||||
sql("delete from `tabProperty Setter` where select_doctype = '%s'" % d)
|
|
||||||
sql("delete from `tabCustom Script` where dt = '%s'" % d)
|
|
||||||
sql("delete from `tabCustom Field` where dt = '%s'" % d)
|
|
||||||
delete_doc('DocType', d)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
sql("commit")
|
|
||||||
delete_tables(lst)
|
|
||||||
|
|
||||||
def delete_tables(lst):
|
|
||||||
for d in lst:
|
|
||||||
for t in ['tab', 'arc']:
|
|
||||||
try:
|
|
||||||
sql("drop table `%s%s`" % (t, d))
|
|
||||||
except:
|
|
||||||
continue
|
|
||||||
|
|
||||||
def delete_unwanted_pages():
|
|
||||||
"deletes pages which are not used anymore"
|
|
||||||
lst = ['Transaction Authorization', 'Prduct Display', 'Data Import', 'Partner Home', 'Product Display', 'Module Settings', 'About Us', 'Custom Reports', 'MIS', 'MIS - Comparison Report', 'Monthly MIS', 'MyReports', 'Navigation Page', 'Point Race', 'Tag Widget', 'Widget Test', 'Yearly MIS']
|
|
||||||
for d in lst:
|
|
||||||
try:
|
|
||||||
delete_doc('Page', d)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
def delete_unwanted_search_criteria():
|
|
||||||
"deletes search criteria which are not used anymore"
|
|
||||||
|
|
||||||
sql("update `tabSearch Criteria` set module = 'HR' where name = 'salary_structure_details'")
|
|
||||||
|
|
||||||
lst = ['_SRCH00002', '_SRCH00001', 'warranty-amc_summary1', 'test_so4', 'test_so3', 'test_so2', 'test_so1', 'test_so', 'test5', 'target_variance_report1', 'STDSRCH/00006', 'STDSRCH/00005', 'STDSRCH/00004', 'STDSRCH/00003', 'STDSRCH/00002', 'STDSRCH/00001', 'so_pending_items_6', 'so_pending_items_5', 'so_pending_items_3', 'so_pending_items_34', 'scrap', 'sales_report_test', 'salary_structure_details1', 'salary_structure_details2', 'salary_structure_details3', 'salary_slips1', 'projectwise_pending_qty_and_costs2', 'projectwise_pending_qty_and_costs1', 'projectwise_delivered_qty_and_costs1', 'projectwise_delivered_qty_and_costs2', 'New Search Criteria 1', 'monthly_salary_register2', 'monthly_salary_register1', 'installed_items','follow_up_history', 'follow_up_report', 'employee_in_company_experience2', 'employee_in_company_experience1', 'employee_in_company_experience', 'employee_details', 'employee_details1', 'employee_details2', 'employees_birthday1', 'draft_so_pending_items', 'draft_sales_orders', 'delivery_notewise_pending_qty_to_install', 'datewise_leave_report2', 'datewise_leave_report1', 'datewise_leave_report', 'customer_issues1', 'cancelled_so_pending_items1', 'cancelled_so_pending_items', 'budget_variance_report3', 'budget_variance_report1', 'account_-_inputs_rg_23_a_-_part_ii_wrong_one', 'territory_item_group_wise_gp', 'sales_orderwise_pending_packing_item_summary', 'itemwise_trend', 'monthly_attendance_details_old', 'projectwise_contribution_report', 'projectwise_delivery_and_material_cost', 'projectwise_delivery_and_mat_cost_report', 'territorywise_trend', 'test_dn', 'rfq', 'rfq1']
|
|
||||||
|
|
||||||
for d in lst:
|
|
||||||
if sql("select name from `tabSearch Criteria` where ifnull(standard, 'Yes') = 'Yes' and name = '%s'" % d):
|
|
||||||
try:
|
|
||||||
delete_doc('Search Criteria', d)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
def delete_unwanted_mappers():
|
|
||||||
"deletes unwanted mappers"
|
|
||||||
|
|
||||||
lst = ['Customer Issue-Maintenance Report', 'Enquiry-Service Quotation', 'Sales Order-Maintenance Report', 'Service Quotation-Service Order', 'Supplier Quotation-Purchase Order', 'Visit Schedule-Maintenance Report', 'RFQ-Supplier Quotation', 'Purchase Request-RFQ']
|
|
||||||
for d in lst:
|
|
||||||
try:
|
|
||||||
delete_doc('DocType Mapper', d)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def delete_unwanted_modules():
|
|
||||||
"deletes unwanted modules"
|
|
||||||
lst = ['Development', 'Recycle Bin', 'Testing', 'Testing System', 'Test', 'Partner Updates', 'My Company', 'Event Updates', 'E-Commerce']
|
|
||||||
for d in lst:
|
|
||||||
try:
|
|
||||||
delete_doc('Module Def', d)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
#---------------------------------------------
|
|
||||||
|
|
||||||
def rename_merge_modules():
|
|
||||||
"Rename module as per users view and merge for removing confusion"
|
|
||||||
|
|
||||||
rename_lst = [['CRM', 'Selling'], ['SRM','Buying'], ['Material Management', 'Stock'], ['Payroll','HR'], ['Maintenance', 'Support']]
|
|
||||||
for d in rename_lst:
|
|
||||||
# create new module manually and export to file???????
|
|
||||||
reload_doc(d[1].lower(), 'Module Def', d[1])
|
|
||||||
|
|
||||||
merge_lst = [['Tools', 'Utilities'], ['Application Internal', 'Utilities'], ['Settings', 'Setup']]
|
|
||||||
# settings hardcoded in my_company
|
|
||||||
# module hardcoded in home_control
|
|
||||||
# material_management hardcoded in installation note
|
|
||||||
# maintenance hardcoded in support_email_settings
|
|
||||||
|
|
||||||
lst = rename_lst + merge_lst
|
|
||||||
for d in lst:
|
|
||||||
update_module(d[0], d[1])
|
|
||||||
try:
|
|
||||||
delete_doc('Module Def', d[0])
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
reload_doc('Utilities', 'Module Def', 'Utilities')
|
|
||||||
|
|
||||||
def update_module(from_mod, to_mod):
|
|
||||||
for t in ['DocType', 'Page', 'Search Criteria', 'DocType Mapper', 'Print Format', 'Role']:
|
|
||||||
sql("update `tab%s` set module='%s' where module = '%s'"% (t, to_mod, from_mod))
|
|
||||||
|
|
||||||
#------------------------------------
|
|
||||||
def sync_roles():
|
|
||||||
"Put Roles into corresponding module and delete Roles module"
|
|
||||||
|
|
||||||
# roles
|
|
||||||
roles = {
|
|
||||||
'Accounts' : "'Accounts Manager', 'Accounts User', 'Auditor'",
|
|
||||||
'Selling' : "'Customer', 'Sales User', 'Sales Manager', 'Sales Master Manager', 'Partner'",
|
|
||||||
'Buying' : "'Supplier', 'Purchase User', 'Purchase Manager', 'Purchase Master Manager'",
|
|
||||||
'Stock' : "'Material User', 'Material Master Manager', 'Material Manager', 'Quality Manager'",
|
|
||||||
'Support' : "'Support Team', 'Support Manager', 'Maintenance User', 'Maintenance Manager'",
|
|
||||||
'Production': "'Production User', 'Production Manager', 'Production Master Manager'",
|
|
||||||
'Setup' : "'System Manager'",
|
|
||||||
'Projects' : "'Projects User'",
|
|
||||||
'HR' : "'HR User', 'HR Manager', 'Employee'",
|
|
||||||
'Core' : "'Administrator', 'All', 'Guest'"
|
|
||||||
}
|
|
||||||
for mod in roles.keys():
|
|
||||||
sql("update `tabRole` set module = '%s' where name in (%s)" % (mod, roles[mod]))
|
|
||||||
|
|
||||||
sql("update `tabDocType` set module = 'Setup' where name = 'Role'")
|
|
||||||
try:
|
|
||||||
|
|
||||||
delete_doc('Module Def', 'Roles')
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
#------------------------------------
|
|
||||||
def sync_mapper():
|
|
||||||
"Put mappers into corresponding module"
|
|
||||||
|
|
||||||
mappers = {
|
|
||||||
'Accounts': ('Delivery Note-Sales Invoice', 'Project-Sales Invoice', 'Purchase Order-Purchase Invoice', 'Purchase Receipt-Purchase Invoice', 'Sales Order-Sales Invoice'),
|
|
||||||
'Selling': ('Delivery Note-Installation Note', 'Opportunity-Quotation', 'Lead-Opportunity', 'Lead-Customer', 'Project-Sales Order', 'Quotation-Sales Order', ),
|
|
||||||
'Buying': ('Purchase Request-Purchase Order', 'Sales Order-Purchase Request'),
|
|
||||||
'Stock': ('Purchase Order-Purchase Receipt', 'Project-Delivery Note', 'Sales Invoice-Delivery Note', 'Sales Order-Delivery Note'),
|
|
||||||
'Support': ('Customer Issue-Maintenance Visit', 'Sales Order-Maintenance Schedule', 'Sales Order-Maintenance Visit'),
|
|
||||||
'Production': ('Production Forecast-Production Plan', 'Production Forecast-Production Planning Tool', 'Sales Order-Production Plan'),
|
|
||||||
'HR': ('Appraisal Template-Appraisal', 'Salary Structure-Salary Slip')
|
|
||||||
}
|
|
||||||
|
|
||||||
for mod in mappers.keys():
|
|
||||||
sql("update `tabDocType Mapper` set module = '%s' where name in %s" % (mod, mappers[mod]))
|
|
||||||
try:
|
|
||||||
delete_doc('Module Def', 'Mapper')
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
# --------------------------------------
|
|
||||||
# function below will be run only in localhost
|
|
||||||
'''def export_docs():
|
|
||||||
"""
|
|
||||||
Export all documents where module has been changed
|
|
||||||
"""
|
|
||||||
for dtype in ['DocType', 'Page', 'Search Criteria', 'DocType Mapper', 'Print Format', 'Role']:
|
|
||||||
lst = sql("select name, module from `tab%s`" % dtype)
|
|
||||||
for rec in lst:
|
|
||||||
webnotes.msgprint(rec)
|
|
||||||
if rec and rec[0] and rec[1]:
|
|
||||||
export_to_files(record_list = [[dtype, rec[0]]], record_module = rec[1])
|
|
||||||
|
|
||||||
#grep test company
|
|
||||||
'''
|
|
||||||
|
|
||||||
#---------------------------------------
|
|
||||||
def run_patches():
|
|
||||||
# update module
|
|
||||||
dt_module = {'Landed Cost Purchase Receipt':'Stock', 'Landed Cost Item':'Stock', 'Comment': 'Core', 'Tag':'Core', 'Tag Detail': 'Core', 'POS Settings': 'Accounts', 'Menu Item': 'Setup', 'Menu Item Role': 'Setup'}
|
|
||||||
for d in dt_module.keys():
|
|
||||||
sql("update `tabDocType` set module = '%s' where name = '%s'" % (dt_module[d], d))
|
|
||||||
delete_unwanted_mappers()
|
|
||||||
delete_unwanted_doctypes()
|
|
||||||
sql("start transaction")
|
|
||||||
delete_unwanted_pages()
|
|
||||||
|
|
||||||
delete_unwanted_search_criteria()
|
|
||||||
|
|
||||||
|
|
||||||
rename_merge_modules()
|
|
||||||
sync_roles()
|
|
||||||
sync_mapper()
|
|
||||||
delete_unwanted_modules()
|
|
||||||
# landed cost wizard link in stock
|
|
||||||
reload_doc('stock', 'Module Def', 'Stock')
|
|
||||||
|
|
||||||
sql("commit")
|
|
@ -1,311 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
"""
|
|
||||||
This patch removes wrong indexs and add proper indexes in tables
|
|
||||||
"""
|
|
||||||
|
|
||||||
import webnotes
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
from webnotes.utils import cstr
|
|
||||||
|
|
||||||
def create_proper_index():
|
|
||||||
from webnotes.modules.export_file import export_to_files
|
|
||||||
|
|
||||||
dt_index_fields={
|
|
||||||
'Purchase Receipt Item': ['prevdoc_docname', 'item_code', 'warehouse', 'prevdoc_detail_docname'],
|
|
||||||
'Period Closing Voucher': ['closing_account_head', 'fiscal_year'],
|
|
||||||
'Lead': ['lead_name', 'status', 'transaction_date'],
|
|
||||||
'Time Sheet Detail': ['app_name'],
|
|
||||||
'Item Quality Inspection Parameter': [],
|
|
||||||
'Budget Detail': ['fiscal_year', 'account'],
|
|
||||||
'Grade': [],
|
|
||||||
'Sales Taxes and Charges': ['parenttype', 'account_head'],
|
|
||||||
'TDS Category Account': ['account_head'],
|
|
||||||
'Role': [],
|
|
||||||
'Leave Allocation': ['leave_type', 'employee', 'fiscal_year'],
|
|
||||||
'Branch': [],
|
|
||||||
'Department': [],
|
|
||||||
'Contact Detail': [],
|
|
||||||
'Territory': ['lft', 'rgt', 'parent_territory'],
|
|
||||||
'Item Tax': ['tax_type'],
|
|
||||||
'Bin': ['warehouse', 'item_code'],
|
|
||||||
'PPW Detail': ['warehouse'],
|
|
||||||
'Sales Partner': ['partner_name'],
|
|
||||||
'Default Home Page': ['home_page', 'role'],
|
|
||||||
'Custom Field': ['dt'],
|
|
||||||
'DocFormat': ['format'],
|
|
||||||
'DocType Mapper': ['from_doctype', 'to_doctype'],
|
|
||||||
'Brand': [],
|
|
||||||
'Quotation Lost Reason': [],
|
|
||||||
'Journal Voucher': ['posting_date', 'voucher_type'],
|
|
||||||
'TDS Return Acknowledgement': ['date_of_receipt', 'acknowledgement'],
|
|
||||||
'BOM Report Detail': ['item_code'],
|
|
||||||
'Quotation Item': ['item_code'],
|
|
||||||
'Update Delivery Date Detail': ['sales_order_no'],
|
|
||||||
'Sales Invoice Advance': ['journal_voucher'],
|
|
||||||
'Authorization Rule': ['approving_user', 'system_user', 'system_role', 'approving_role'],
|
|
||||||
'DocPerm': ['permlevel', 'role'],
|
|
||||||
'Stock Entry Detail': ['item_code', 't_warehouse', 's_warehouse'],
|
|
||||||
'Stock Entry': ['posting_date', 'delivery_note_no', 'purchase_receipt_no', 'production_order'],
|
|
||||||
'Price List': [],
|
|
||||||
'Appraisal Template Goal': [],
|
|
||||||
'Production Order': ['status', 'project_name', 'production_item'],
|
|
||||||
'Account': ['lft', 'rgt', 'parent_account'],
|
|
||||||
'Earn Deduction Detail': [],
|
|
||||||
'Purchase Request': ['status', 'transaction_date'],
|
|
||||||
'Tag Detail': [],
|
|
||||||
'Salary Slip Deduction': ['d_type'],
|
|
||||||
'Batch': ['item'],
|
|
||||||
'Deduction Type': [],
|
|
||||||
'Project': ['project_name', 'customer'],
|
|
||||||
'UserRole': ['role'],
|
|
||||||
'DocField': ['label', 'fieldtype', 'fieldname'],
|
|
||||||
'Property Setter': ['doc_type', 'doc_name', 'property'],
|
|
||||||
'Appraisal': ['status', 'employee'],
|
|
||||||
'Letter Head': [],
|
|
||||||
'Communication Log': ['follow_up_by'],
|
|
||||||
'Project Cost Breakup': [],
|
|
||||||
'Table Mapper Detail': [],
|
|
||||||
'Campaign': [],
|
|
||||||
'SMS Parameter': [],
|
|
||||||
'Leave Type': [],
|
|
||||||
'Absent Days Detail': [],
|
|
||||||
'Tag': [],
|
|
||||||
'Raw Materials Supplied': ['raw_material'],
|
|
||||||
'Project Activity Update': [],
|
|
||||||
'Purchase Receipt Item Supplied': [],
|
|
||||||
'Bank Reconciliation Detail': ['voucher_id'],
|
|
||||||
'Sales Order': ['quotation_no', 'project_name', 'customer', 'posting_date'],
|
|
||||||
'Chapter VI A Detail': [],
|
|
||||||
'Employee Internal Work History': [],
|
|
||||||
'Order Reconciliation Detail': ['sales_order_no'],
|
|
||||||
'Attendance': ['employee', 'att_date'],
|
|
||||||
'Employee External Work History': [],
|
|
||||||
'Salary Structure Earning': ['e_type'],
|
|
||||||
'Sales Order Item': ['item_code', 'prevdoc_docname', 'reserved_warehouse'],
|
|
||||||
'Appraisal Template': [],
|
|
||||||
'Budget Distribution': ['fiscal_year'],
|
|
||||||
'Workstation': ['warehouse'],
|
|
||||||
'Training Session Details': [],
|
|
||||||
'Sales Taxes and Charges Master': [],
|
|
||||||
'State': [],
|
|
||||||
'Bulk Rename Tool': [],
|
|
||||||
'Landed Cost Master Detail': [],
|
|
||||||
'Employee': ['employee_name', 'designation', 'department'],
|
|
||||||
'Terms And Conditions': [],
|
|
||||||
'TC Detail': [],
|
|
||||||
'UOM': [],
|
|
||||||
'Supplier Type': [],
|
|
||||||
'Project Milestone': [],
|
|
||||||
'Landed Cost Master': [],
|
|
||||||
'Budget Distribution Detail': [],
|
|
||||||
'Form 16A Ack Detail': [],
|
|
||||||
'Campaign Expense': [],
|
|
||||||
'Time Sheet': ['employee_name', 'time_sheet_date'],
|
|
||||||
'File Group': ['parent_group'],
|
|
||||||
'Maintenance Visit Purpose': ['item_code', 'service_person'],
|
|
||||||
'Support Ticket Response': [],
|
|
||||||
'Purchase Invoice Item': ['item_code', 'purchase_order', 'po_detail', 'purchase_receipt', 'pr_detail', 'expense_head', 'cost_center'],
|
|
||||||
'Timesheet Detail': ['project_name', 'task_id', 'customer_name'],
|
|
||||||
'Holiday': [],
|
|
||||||
'Workflow Rule Detail': [],
|
|
||||||
'Module Def': ['module_seq', 'module_page'],
|
|
||||||
'Terms and Conditions': [],
|
|
||||||
'PF Detail': ['item_code'],
|
|
||||||
'POS Setting': ['user', 'territory'],
|
|
||||||
'Quality Inspection Reading': [],
|
|
||||||
'Support Ticket': ['customer', 'allocated_to', 'status'],
|
|
||||||
'Project Activity': ['project'],
|
|
||||||
'Customer Group': ['lft', 'rgt', 'parent_customer_group'],
|
|
||||||
'Sales and Purchase Return Item': ['item_code'],
|
|
||||||
'Series Detail': [],
|
|
||||||
'Event Role': ['role'],
|
|
||||||
'Contact': ['employee_id'],
|
|
||||||
'BOM Item': ['item_code', 'bom_no'],
|
|
||||||
'Invest 80 Declaration Detail': [],
|
|
||||||
'Purchase Order Item Supplied': [],
|
|
||||||
'Industry Type': [],
|
|
||||||
'Declaration Detail': [],
|
|
||||||
'Holiday List': ['fiscal_year'],
|
|
||||||
'Sales Person': ['lft', 'rgt', 'parent_sales_person'],
|
|
||||||
'Sales Invoice Item': ['item_code', 'sales_order', 'so_detail', 'delivery_note', 'dn_detail', 'cost_center', 'income_account'],
|
|
||||||
'Module Def Item': [],
|
|
||||||
'TDS Category': [],
|
|
||||||
'DocTrigger': [],
|
|
||||||
'Print Format': ['standard'],
|
|
||||||
'Installation Note Item': ['prevdoc_docname', 'item_code'],
|
|
||||||
'Form 16A Tax Detail': [],
|
|
||||||
'Event': ['event_date', 'event_type'],
|
|
||||||
'Currency': [],
|
|
||||||
'Warehouse Type': ['warehouse_type'],
|
|
||||||
'Sales BOM': ['item_group'],
|
|
||||||
'IT Checklist': ['employee'],
|
|
||||||
'Purchase Taxes and Charges Master': [],
|
|
||||||
'Company': [],
|
|
||||||
'Call Log': [],
|
|
||||||
'Employee Training': [],
|
|
||||||
'Warehouse': ['warehouse_type'],
|
|
||||||
'Competitor': [],
|
|
||||||
'Mode of Payment': [],
|
|
||||||
'Training Session': ['customer'],
|
|
||||||
'Cost Center': ['lft', 'rgt', 'parent_cost_center'],
|
|
||||||
'Timesheet': ['status', 'timesheet_date'],
|
|
||||||
'Form 16A': ['party_no'],
|
|
||||||
'Sales BOM Item': ['item_code'],
|
|
||||||
'Answer': ['question'],
|
|
||||||
'Supplier': [],
|
|
||||||
'Installation Note': ['delivery_note_no', 'customer', 'inst_date'],
|
|
||||||
'Expense Claim': ['approval_status', 'employee'],
|
|
||||||
'Target Detail': ['from_date', 'to_date', 'fiscal_year'],
|
|
||||||
'Page Role': ['role'],
|
|
||||||
'Partner Target Detail': ['fiscal_year', 'item_group'],
|
|
||||||
'Shipping Address': ['customer'],
|
|
||||||
'Purchase Request Item': ['item_code', 'warehouse'],
|
|
||||||
'TDS Payment Detail': [],
|
|
||||||
'Market Segment': [],
|
|
||||||
'Comment': [],
|
|
||||||
'Service Order Detail': ['item_code', 'prevdoc_docname'],
|
|
||||||
'TDS Payment': ['from_date', 'to_date', 'tds_category'],
|
|
||||||
'Lead Email CC Detail': [],
|
|
||||||
'User Setting-Role User': [],
|
|
||||||
'Salary Slip': ['month', 'year', 'employee'],
|
|
||||||
'Maintenance Schedule Detail': ['item_code', 'scheduled_date'],
|
|
||||||
'Employment Type': [],
|
|
||||||
'Purchase Invoice Advance': ['journal_voucher'],
|
|
||||||
'Quotation': ['customer', 'transaction_date'],
|
|
||||||
'Salary Structure Deduction': ['d_type'],
|
|
||||||
'BOM': ['item', 'project_name'],
|
|
||||||
'Earning Type': [],
|
|
||||||
'Designation': [],
|
|
||||||
'BOM Replace Utility Detail': ['parent_bom'],
|
|
||||||
'Question': [],
|
|
||||||
'Stock Ledger Entry': ['item_code', 'warehouse', 'posting_date', 'posting_time'],
|
|
||||||
'Employee Education': [],
|
|
||||||
'BOM Operation': [],
|
|
||||||
'Item Group': ['lft', 'rgt', 'parent_item_group'],
|
|
||||||
'Workflow Action Detail': [],
|
|
||||||
'User Setting-Profile': [],
|
|
||||||
'Customer Issue': ['item_code', 'customer', 'complaint_date'],
|
|
||||||
'Feed': [],
|
|
||||||
'Purchase Taxes and Charges': ['account_head'],
|
|
||||||
'GL Mapper Detail': [],
|
|
||||||
'TDS Detail': [],
|
|
||||||
'PRO Detail': ['item_code', 'source_warehouse'],
|
|
||||||
'DocType Label': [],
|
|
||||||
'Sales Invoice': ['posting_date', 'debit_to', 'project_name'],
|
|
||||||
'GL Entry': ['posting_date', 'account', 'voucher_no'],
|
|
||||||
'Serial No': ['status', 'warehouse'],
|
|
||||||
'Delivery Note': ['posting_date', 'project_name', 'customer'],
|
|
||||||
'UOM Conversion Detail': ['uom'],
|
|
||||||
'Search Criteria': ['criteria_name'],
|
|
||||||
'Salary Structure': [],
|
|
||||||
'Educational Qualifications': ['qualification'],
|
|
||||||
'TDS Rate Chart': ['applicable_from', 'applicable_to'],
|
|
||||||
'GL Mapper': [],
|
|
||||||
'Announcement': [],
|
|
||||||
'Call Log Details': [],
|
|
||||||
'Opportunity': ['lead', 'customer', 'transaction_date'],
|
|
||||||
'BOM Explosion Item': ['item_code'],
|
|
||||||
'Landed Cost Item': ['account_head'],
|
|
||||||
'Field Mapper Detail': ['from_field', 'to_field'],
|
|
||||||
'File Data': [],
|
|
||||||
'Question Tag': [],
|
|
||||||
'Quality Inspection': ['item_code', 'purchase_receipt_no', 'report_date'],
|
|
||||||
'Appraisal Goal': [],
|
|
||||||
'POS Settings': ['territory'],
|
|
||||||
'Delivery Note Item': ['item_code', 'prevdoc_docname', 'warehouse', 'prevdoc_detail_docname'],
|
|
||||||
'Profile': [],
|
|
||||||
'Other Income Detail': [],
|
|
||||||
'Product': ['item_code', 'stock_warehouse'],
|
|
||||||
'Purchase Order Item': ['prevdoc_docname', 'item_code', 'prevdoc_detail_docname', 'warehouse'],
|
|
||||||
'Module Def Role': ['role'],
|
|
||||||
'Sales Team': ['sales_person'],
|
|
||||||
'Opportunity Item': ['item_code'],
|
|
||||||
'DocType': [],
|
|
||||||
'Compaint Note': ['nature_of_complaint', 'compliance_date'],
|
|
||||||
'Maintenance Schedule': ['customer', 'sales_order_no'],
|
|
||||||
'Event User': ['person'],
|
|
||||||
'Stock Reconciliation': ['reconciliation_date'],
|
|
||||||
'Purchase Receipt': ['posting_date', 'supplier', 'project_name'],
|
|
||||||
'Complaint Detail': ['item_name'],
|
|
||||||
'Address': ['customer', 'supplier'],
|
|
||||||
'Task': ['request_date', 'allocated_to', 'category', 'customer', 'project'],
|
|
||||||
'Territory Target Detail': ['month', 'fiscal_year'],
|
|
||||||
'Landed Cost Purchase Receipt': ['purchase_receipt_no'],
|
|
||||||
'Customer': ['customer_name', 'customer_group'],
|
|
||||||
'Production Plan Sales Order': [],
|
|
||||||
'Production Plan Item': ['document_date', 'item_code', 'parent_item'],
|
|
||||||
'User Setting-Role Permission': [],
|
|
||||||
'Custom Script': ['dt'],
|
|
||||||
'Country': [],
|
|
||||||
'DefaultValue': [],
|
|
||||||
'Multi Ledger Report Detail': [],
|
|
||||||
'Salary Slip Earning': ['e_type'],
|
|
||||||
'SMS Log': [],
|
|
||||||
'Expense Claim Type': [],
|
|
||||||
'Item': ['item_group'],
|
|
||||||
'Fiscal Year': [],
|
|
||||||
'ToDo': ['role'],
|
|
||||||
'Purchase Invoice': ['posting_date', 'credit_to', 'project_name', 'supplier'],
|
|
||||||
'Journal Voucher Detail': ['account', 'against_voucher', 'against_invoice', 'against_jv'],
|
|
||||||
'Online Contact': [],
|
|
||||||
'Page': ['module'],
|
|
||||||
'Leave Application': ['employee', 'leave_type', 'from_date', 'to_date'],
|
|
||||||
'Expense Claim Detail': ['expense_type'],
|
|
||||||
'Maintenance Visit': ['customer', 'sales_order_no', 'customer_issue_no'],
|
|
||||||
'Item Price': ['price_list_name', 'ref_currency'],
|
|
||||||
'SMS Receiver': [],
|
|
||||||
'Naming Series Options': ['doc_type'],
|
|
||||||
'Activity Type': [],
|
|
||||||
'Delivery Note Packing Item': ['item_code', 'parent_item', 'warehouse'],
|
|
||||||
'Workflow Rule': ['select_form'],
|
|
||||||
'File': ['file_group'],
|
|
||||||
'Maintenance Schedule Item': ['item_code', 'start_date', 'end_date', 'prevdoc_docname'],
|
|
||||||
'Purchase Order': ['supplier', 'project_name', 'posting_date'],
|
|
||||||
'Print Heading': [],
|
|
||||||
'TDS Rate Detail': ['category']
|
|
||||||
}
|
|
||||||
#sql("commit") # only required if run from login
|
|
||||||
exist_dt = [cstr(d[0]) for d in sql("select name from `tabDocType`")]
|
|
||||||
|
|
||||||
for dt in [d for d in dt_index_fields.keys() if d in exist_dt]:
|
|
||||||
try:
|
|
||||||
current_index = sql("show indexes from `tab%s`" % dt)
|
|
||||||
|
|
||||||
proper_index = dt_index_fields[dt]
|
|
||||||
|
|
||||||
for d in current_index:
|
|
||||||
if d[4] not in ['name', 'parent', 'parenttype']:
|
|
||||||
if d[4] not in proper_index:
|
|
||||||
sql("ALTER TABLE `tab%s` DROP INDEX %s" % (dt, d[4]))
|
|
||||||
sql("start transaction")
|
|
||||||
sql("UPDATE `tabDocField` SET search_index = 0 WHERE fieldname = '%s' AND parent = '%s'" % (d[4], dt))
|
|
||||||
sql("commit")
|
|
||||||
else:
|
|
||||||
proper_index.remove(d[4])
|
|
||||||
|
|
||||||
for d in proper_index:
|
|
||||||
sql("ALTER TABLE `tab%s` ADD INDEX ( `%s` ) " % (dt, d))
|
|
||||||
sql("start transaction")
|
|
||||||
sql("UPDATE `tabDocField` SET search_index = 1 WHERE fieldname = '%s' AND parent = '%s'" % (d, dt))
|
|
||||||
sql("commit")
|
|
||||||
except:
|
|
||||||
continue
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
create_proper_index()
|
|
@ -1,125 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import os, sys
|
|
||||||
import webnotes
|
|
||||||
|
|
||||||
path_to_file = os.sep.join(os.path.abspath(__file__).split(os.sep)[:-1] + ['print_formats'])
|
|
||||||
|
|
||||||
def prepare_pf_dict(args_list):
|
|
||||||
"""
|
|
||||||
|
|
||||||
"""
|
|
||||||
pf_list = []
|
|
||||||
for a in args_list:
|
|
||||||
for pf_type in ['Classic', 'Modern', 'Spartan']:
|
|
||||||
pf = {}
|
|
||||||
pf['name'] = " ".join([a['name'], pf_type])
|
|
||||||
pf['file'] = os.sep.join([path_to_file, "".join(pf['name'].split(" ")) + ".html"])
|
|
||||||
pf['module'] = a['module']
|
|
||||||
pf['doc_type'] = a['doc_type']
|
|
||||||
pf['standard'] = 'Yes'
|
|
||||||
pf_list += [pf]
|
|
||||||
return pf_list
|
|
||||||
|
|
||||||
|
|
||||||
pf_to_install = prepare_pf_dict([
|
|
||||||
{
|
|
||||||
'name' : 'Sales Invoice',
|
|
||||||
'doc_type' : 'Sales Invoice',
|
|
||||||
'module' : 'Accounts'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
'name' : 'Sales Order',
|
|
||||||
'doc_type' : 'Sales Order',
|
|
||||||
'module' : 'Selling'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
'name' : 'Quotation',
|
|
||||||
'doc_type' : 'Quotation',
|
|
||||||
'module' : 'Selling'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
'name' : 'Delivery Note',
|
|
||||||
'doc_type' : 'Delivery Note',
|
|
||||||
'module' : 'Stock'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
'name' : 'Purchase Order',
|
|
||||||
'doc_type' : 'Purchase Order',
|
|
||||||
'module' : 'Buying'
|
|
||||||
}
|
|
||||||
])
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
Install print formats
|
|
||||||
"""
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('core', 'doctype', 'print_format')
|
|
||||||
|
|
||||||
#copy_doctype_to_pfs()
|
|
||||||
global pf_to_install
|
|
||||||
for pf in pf_to_install:
|
|
||||||
# install_print_format(pf)
|
|
||||||
# print "Installed PF: " + pf['name']
|
|
||||||
reload_doc(pf['module'], 'Print Format', pf['name'])
|
|
||||||
|
|
||||||
|
|
||||||
def copy_doctype_to_pfs():
|
|
||||||
"""
|
|
||||||
Copy doctype to existing print formats
|
|
||||||
"""
|
|
||||||
pf_dt_list = webnotes.conn.sql("""
|
|
||||||
SELECT format, parent
|
|
||||||
FROM `tabDocFormat`""", as_list=1)
|
|
||||||
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
|
|
||||||
for pf, dt in pf_dt_list:
|
|
||||||
try:
|
|
||||||
d = Document('Print Format', pf)
|
|
||||||
d.doc_type = dt
|
|
||||||
d.save()
|
|
||||||
except Exception, e:
|
|
||||||
print e.args
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
def install_print_format(args):
|
|
||||||
"""
|
|
||||||
Installs print format
|
|
||||||
args is a dict consisting of following keys:
|
|
||||||
* name
|
|
||||||
* module
|
|
||||||
* doctype
|
|
||||||
* standard = "Yes"/"No"
|
|
||||||
* file
|
|
||||||
"""
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
d = Document('Print Format')
|
|
||||||
d.name = args['name']
|
|
||||||
f = open(args['file'])
|
|
||||||
d.html = f.read()
|
|
||||||
f.close()
|
|
||||||
d.module = args['module']
|
|
||||||
d.doc_type = args['doc_type']
|
|
||||||
d.standard = args['standard']
|
|
||||||
d.save(1)
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
obj = get_obj('Print Format', args['name'])
|
|
||||||
obj.on_update()
|
|
@ -1,26 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
|
|
||||||
reload_doc('stock', 'doctype', 'landed_cost_wizard')
|
|
||||||
reload_doc('stock', 'doctype', 'lc_pr_detail')
|
|
||||||
|
|
||||||
webnotes.conn.sql("delete from `tabDocField` where parent ='Landed Cost Purchase Receipt' and fieldname in ('purchase_receipt_no', 'include_in_landed_cost')")
|
|
@ -1,21 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
if not webnotes.conn.sql("select name from tabDocFormat where parent = 'Sales Invoice' and format != 'POS Invoice'"):
|
|
||||||
webnotes.conn.sql("update tabDocType set default_print_format = 'Standard' where name = 'Sales Invoice'")
|
|
@ -1,25 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('stock', 'doctype', 'delivery_note_detail')
|
|
||||||
reload_doc('stock', 'Print Format', 'Delivery Note Packing List Wise')
|
|
||||||
|
|
||||||
webnotes.conn.sql("delete from `tabDocField` where fieldname in ('packed_by', 'packing_checked_by', 'pack_size') and parent = 'Delivery Note'")
|
|
||||||
|
|
@ -1,30 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
reload_doc('accounts', 'doctype', 'receivable_voucher')
|
|
||||||
reload_doc('stock', 'doctype', 'delivery_note')
|
|
||||||
reload_doc('selling', 'doctype', 'sales_order')
|
|
||||||
reload_doc('selling', 'doctype', 'quotation')
|
|
||||||
reload_doc('setup', 'doctype', 'manage_account')
|
|
||||||
|
|
||||||
|
|
||||||
for d in ['Sales Invoice', 'Delivery Note', 'Sales Order', 'Quotation']:
|
|
||||||
webnotes.conn.sql("update `tab%s` set price_list_currency = currency, plc_conversion_rate = conversion_rate" % d)
|
|
@ -1,20 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("update `tabDocField` set print_hide = 1 where fieldname in ('price_list_currency', 'plc_conversion_rate')")
|
|
@ -1,27 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
Mark DocType Profile as 'not_in_create'
|
|
||||||
"""
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
UPDATE `tabDocType`
|
|
||||||
SET in_create=1
|
|
||||||
WHERE name='Profile'
|
|
||||||
""")
|
|
@ -1,35 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
|
|
||||||
# Reload item table
|
|
||||||
reload_doc('accounts', 'doctype', 'pv_detail')
|
|
||||||
reload_doc('buying', 'doctype', 'po_detail')
|
|
||||||
reload_doc('stock', 'doctype', 'purchase_receipt_detail')
|
|
||||||
|
|
||||||
# copy project value from parent to child
|
|
||||||
sql("update `tabPurchase Order Item` t1, `tabPurchase Order` t2 set t1.project_name = t2.project_name where t1.parent = t2.name and ifnull(t1.project_name, '') = ''")
|
|
||||||
sql("update `tabPurchase Invoice Item` t1, `tabPurchase Invoice` t2 set t1.project_name = t2.project_name where t1.parent = t2.name and ifnull(t1.project_name, '') = ''")
|
|
||||||
sql("update `tabPurchase Receipt Item` t1, `tabPurchase Receipt` t2 set t1.project_name = t2.project_name where t1.parent = t2.name and ifnull(t1.project_name, '') = ''")
|
|
||||||
|
|
||||||
# delete project from parent
|
|
||||||
sql("delete from `tabDocField` where fieldname = 'project_name' and parent in ('Purchase Order', 'Purchase Receipt', 'Purchase Invoice')")
|
|
||||||
|
|
@ -1,22 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
reload_doc('utilities', 'doctype', 'address')
|
|
@ -1,22 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
reload_doc('production', 'doctype', 'bill_of_materials')
|
|
@ -1,33 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
"""
|
|
||||||
Reload Customize Form, Customize Form Field and Print Format doctypes
|
|
||||||
"""
|
|
||||||
def execute():
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('core', 'doctype', 'print_format')
|
|
||||||
reload_doc('core', 'doctype', 'doclayer')
|
|
||||||
reload_doc('core', 'doctype', 'doclayerfield')
|
|
||||||
reload_doc('accounts', 'doctype', 'gl_entry')
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
d = Document('DocType Label')
|
|
||||||
d.dt = "Customize Form"
|
|
||||||
d.dt_label = "Customize Form View"
|
|
||||||
d.save(1)
|
|
||||||
from webnotes.sessions import clear
|
|
||||||
clear()
|
|
@ -1,20 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('Setup', 'DocType', 'Email Digest')
|
|
@ -1,21 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('hr', 'search_criteria', 'employeewise_balance_leave_report')
|
|
@ -1,23 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
from webnotes.modules import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
reload_doc('production', 'doctype', 'flat_bom_detail')
|
|
||||||
reload_doc('production', 'doctype', 'bom_material')
|
|
@ -1,23 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
# reload jv gl mapper
|
|
||||||
reload_doc('accounts', 'GL Mapper', 'Journal Voucher')
|
|
@ -1,26 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
from webnotes.model import delete_doc
|
|
||||||
|
|
||||||
delete_doc('DocType', 'Landed Cost Wizard')
|
|
||||||
delete_doc('DocType', 'Landed Cost Purchase Receipt')
|
|
||||||
reload_doc('stock', 'doctype', 'landed_cost_wizard')
|
|
||||||
reload_doc('stock', 'doctype', 'lc_pr_detail')
|
|
@ -1,34 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
from webnotes.model.doc import addchild
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
reload_doc('stock', 'Print Format', 'Delivery Note Packing List Wise')
|
|
||||||
reload_doc('stock', 'Print Format', 'Purchase Receipt Format')
|
|
||||||
reload_doc('accounts', 'Print Format', 'Payment Receipt Voucher')
|
|
||||||
reload_doc('accounts', 'Print Format', 'POS Invoice')
|
|
||||||
reload_doc('accounts', 'Print Format', 'Form 16A Print Format')
|
|
||||||
reload_doc('accounts', 'Print Format', 'Cheque Printing Format')
|
|
||||||
|
|
||||||
if not webnotes.conn.sql("select format from `tabDocFormat` where name = 'POS Invoice' and parent = 'Sales Invoice'"):
|
|
||||||
dt_obj = get_obj('DocType', 'Sales Invoice', with_children = 1)
|
|
||||||
ch = addchild(dt_obj.doc, 'formats', 'DocFormat', 1)
|
|
||||||
ch.format = 'POS Invoice'
|
|
||||||
ch.save(1)
|
|
@ -1,24 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
"""
|
|
||||||
Reload Task Doctype of Project Module
|
|
||||||
"""
|
|
||||||
def execute():
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('Projects', 'DocType', 'Task')
|
|
||||||
|
|
@ -1,23 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
reload_doc('stock', 'doctype', 'stock_reconciliation')
|
|
||||||
webnotes.conn.sql("delete from `tabDocField` where (label in ('Validate Data', 'Attachment HTML', 'Attachment') or fieldname in ('next_step', 'company', 'fiscal_year', 'amendment_date')) and parent = 'Stock Reconciliation'")
|
|
@ -1,26 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
|
|
||||||
reload_doc('accounts', 'doctype', 'receivable_voucher')
|
|
||||||
|
|
||||||
reload_doc('setup', 'doctype', 'features_setup')
|
|
||||||
get_obj('Features setup').validate()
|
|
@ -1,23 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('Support', 'DocType', 'Support Ticket')
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
get_obj('DocType', 'Support Ticket').validate()
|
|
@ -1,39 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
"""
|
|
||||||
Removes duplicate entries created in
|
|
||||||
"""
|
|
||||||
import webnotes
|
|
||||||
def execute():
|
|
||||||
res = webnotes.conn.sql("""\
|
|
||||||
SELECT a.name
|
|
||||||
FROM
|
|
||||||
`tabTable Mapper Detail` a,
|
|
||||||
`tabTable Mapper Detail` b
|
|
||||||
WHERE
|
|
||||||
a.parent = b.parent AND
|
|
||||||
a.from_table = b.from_table AND
|
|
||||||
a.to_table = b.to_table AND
|
|
||||||
a.from_field = b.from_field AND
|
|
||||||
a.to_field = b.to_field AND
|
|
||||||
a.name < b.name""")
|
|
||||||
if res and len(res)>0:
|
|
||||||
name_string = ", ".join(["'" + str(r[0]) + "'" for r in res])
|
|
||||||
res = webnotes.conn.sql("""\
|
|
||||||
DELETE FROM `tabTable Mapper Detail`
|
|
||||||
WHERE name IN (%s)""" % name_string)
|
|
@ -1,25 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
DELETE FROM tabDocField
|
|
||||||
WHERE parent = 'Email Digest'
|
|
||||||
AND label = 'Add Recipients'
|
|
||||||
AND fieldtype = 'Button'""")
|
|
||||||
|
|
@ -1,32 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
remove control panel email settings if automail.webnotestech.com
|
|
||||||
"""
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
cp = Document('Control Panel', 'Control Panel')
|
|
||||||
if cp:
|
|
||||||
if cp.outgoing_mail_server == 'mail.webnotestech.com':
|
|
||||||
cp.outgoing_mail_server = None;
|
|
||||||
cp.mail_login = None;
|
|
||||||
cp.mail_password = None;
|
|
||||||
cp.mail_port = None;
|
|
||||||
cp.auto_email_id = 'automail@erpnext.com'
|
|
||||||
cp.save()
|
|
||||||
|
|
@ -1,20 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""delete from `tabDefaultValue` where defkey in ('page_break', 'projects', 'packing_details', 'discounts', 'brands', 'item_batch_nos', 'after_sales_installations', 'item_searial_nos', 'item_group_in_details', 'exports', 'imports', 'item_advanced', 'sales_extras', 'more_info', 'quality', 'manufacturing', 'pos', 'item_serial_nos', 'purchase_discounts', 'recurring_invoice') and parent = 'Control Panel'""")
|
|
@ -1,23 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
def execute():
|
|
||||||
webnotes.conn.sql("""\
|
|
||||||
DELETE FROM `tabProperty Setter`
|
|
||||||
WHERE property='previous_field'
|
|
||||||
""")
|
|
@ -1,36 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
|
|
||||||
# repost
|
|
||||||
comp = sql("select name from tabCompany where docstatus!=2")
|
|
||||||
fy = sql("select name from `tabFiscal Year` order by year_start_date asc")
|
|
||||||
for c in comp:
|
|
||||||
prev_fy = ''
|
|
||||||
for f in fy:
|
|
||||||
fy_obj = get_obj('Fiscal Year', f[0])
|
|
||||||
fy_obj.doc.past_year = prev_fy
|
|
||||||
fy_obj.doc.company = c[0]
|
|
||||||
fy_obj.repost()
|
|
||||||
prev_fy = f[0]
|
|
||||||
webnotes.conn.commit()
|
|
||||||
webnotes.conn.begin()
|
|
@ -1,40 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
from webnotes.utils import flt
|
|
||||||
|
|
||||||
# update incoming rate in serial nos
|
|
||||||
sr = sql("""select name, item_code, purchase_document_no from `tabSerial No`
|
|
||||||
where docstatus = 1 and purchase_document_type = 'Purchase Receipt'""")
|
|
||||||
for d in sr:
|
|
||||||
val_rate = sql("""select valuation_rate from `tabPurchase Receipt Item`
|
|
||||||
where item_code = %s and parent = %s""", (d[1], d[2]))
|
|
||||||
sql("""update `tabSerial No` set purchase_rate = %s where name = %s""",
|
|
||||||
(val_rate and flt(val_rate[0][0]) or 0, d[0]))
|
|
||||||
|
|
||||||
|
|
||||||
# repost for all serialized item
|
|
||||||
bin = sql("""select t1.name from `tabBin` t1, tabItem t2 where t1.item_code = t2.name and ifnull(has_serial_no, 'No') = 'Yes'""")
|
|
||||||
for d in bin:
|
|
||||||
get_obj('Bin', d[0]).update_entries_after(posting_date = '2000-01-01', posting_time = '12:00')
|
|
||||||
sql("commit")
|
|
||||||
sql("start transaction")
|
|
||||||
|
|
@ -1,25 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
|
|
||||||
reload_doc('hr', 'doctype', 'salary_manager')
|
|
||||||
sql("delete from `tabDocField` where parent = 'Salary Manager' and fieldname = 'employment_type'")
|
|
@ -1,21 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('projects', 'doctype', 'ticket')
|
|
@ -1,26 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
def execute():
|
|
||||||
doc_type_list = webnotes.conn.sql("""SELECT DISTINCT parent FROM `tabDocField` where idx=0""")
|
|
||||||
for doc_type in doc_type_list:
|
|
||||||
if doc_type and doc_type[0]:
|
|
||||||
webnotes.conn.sql("""\
|
|
||||||
UPDATE `tabDocField` SET idx=idx+1
|
|
||||||
WHERE parent=%s
|
|
||||||
""", doc_type[0])
|
|
@ -1,32 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
|
|
||||||
# select jv where against_jv exists
|
|
||||||
jv = webnotes.conn.sql("select distinct parent from `tabJournal Voucher Detail` where docstatus = 1 and ifnull(against_jv, '') != ''")
|
|
||||||
|
|
||||||
for d in jv:
|
|
||||||
jv_obj = get_obj('Journal Voucher', d[0], with_children=1)
|
|
||||||
|
|
||||||
# cancel
|
|
||||||
get_obj(dt='GL Control').make_gl_entries(jv_obj.doc, jv_obj.doclist, cancel =1, adv_adj = 1)
|
|
||||||
|
|
||||||
#re-submit
|
|
||||||
get_obj(dt='GL Control').make_gl_entries(jv_obj.doc, jv_obj.doclist, cancel =0, adv_adj = 1)
|
|
@ -1 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
@ -1,26 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""update `tabAccount`
|
|
||||||
set account_type = 'Chargeable'
|
|
||||||
where account_name in ('CENVAT Capital Goods', 'CENVAT Service Tax', 'CENVAT Service Tax Cess 1', 'CENVAT Service Tax Cess 2',
|
|
||||||
'P L A', 'P L A - Cess Portion', 'VAT', 'TDS (Advertisement)', 'TDS (Commission)', 'TDS (Contractor)', 'TDS (Interest)',
|
|
||||||
'TDS (Rent)', 'TDS (Salary)')
|
|
||||||
""")
|
|
||||||
|
|
@ -1,11 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
Adds various roles to Administrator. This patch is for making master db
|
|
||||||
ready for on premise installation
|
|
||||||
"""
|
|
||||||
import webnotes
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
sc = get_obj('Setup Control', 'Setup Control')
|
|
||||||
sc.add_roles(Document('Profile', 'Administrator'))
|
|
@ -1,37 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
Changes allocated_to option to Profile in
|
|
||||||
DocType Customer Issue
|
|
||||||
"""
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
UPDATE `tabDocField`
|
|
||||||
SET options='Profile'
|
|
||||||
WHERE fieldname='allocated_to'
|
|
||||||
""")
|
|
||||||
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
DELETE from `tabDocField`
|
|
||||||
WHERE parent='Customer Issue'
|
|
||||||
AND label='Make Maintenance Visit'
|
|
||||||
""")
|
|
||||||
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('support', 'doctype', 'customer_issue')
|
|
@ -1 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
@ -1,23 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Reload ToDo
|
|
||||||
"""
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('utilities', 'doctype', 'todo_item')
|
|
@ -1,25 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
Set docstatus = 2 where status = 'Purchase Returned' for serial no
|
|
||||||
"""
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""\
|
|
||||||
UPDATE `tabSerial No` SET docstatus=2
|
|
||||||
WHERE status='Purchase Returned'""")
|
|
@ -1,20 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.clear_cache()
|
|
@ -1,28 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
|
|
||||||
sql("commit")
|
|
||||||
sql("set foreign_key_checks=0")
|
|
||||||
for tab in sql("show tables"):
|
|
||||||
sql("ALTER TABLE `%s` CONVERT TO CHARACTER SET utf8" % tab[0])
|
|
||||||
|
|
||||||
sql("set foreign_key_checks=1")
|
|
@ -1,75 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Reload Search Criteria "Customer Address Contact"
|
|
||||||
* SET is_primary_contact=1, is_primary_address=1 WHERE not specified
|
|
||||||
"""
|
|
||||||
reload_sc()
|
|
||||||
patch_primary_contact()
|
|
||||||
patch_primary_address()
|
|
||||||
|
|
||||||
def reload_sc():
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('selling', 'search_criteria', 'customer_address_contact')
|
|
||||||
reload_doc('selling', 'Module Def', 'Selling')
|
|
||||||
|
|
||||||
def patch_primary_contact():
|
|
||||||
res = webnotes.conn.sql("""
|
|
||||||
SELECT name FROM `tabContact`
|
|
||||||
WHERE customer IN (
|
|
||||||
SELECT customer FROM `tabContact`
|
|
||||||
WHERE IFNULL(customer, '')!=''
|
|
||||||
GROUP BY customer HAVING SUM(IFNULL(is_primary_contact, 0))=0
|
|
||||||
) OR supplier IN (
|
|
||||||
SELECT supplier FROM `tabContact`
|
|
||||||
WHERE IFNULL(supplier, '')!=''
|
|
||||||
GROUP BY supplier HAVING SUM(IFNULL(is_primary_contact, 0))=0
|
|
||||||
) OR sales_partner IN (
|
|
||||||
SELECT sales_partner FROM `tabContact`
|
|
||||||
WHERE IFNULL(sales_partner, '')!=''
|
|
||||||
GROUP BY sales_partner HAVING SUM(IFNULL(is_primary_contact, 0))=0
|
|
||||||
)
|
|
||||||
""", as_list=1)
|
|
||||||
names = ", ".join(['"' + unicode(r[0]) + '"' for r in res if r])
|
|
||||||
if names: webnotes.conn.sql("UPDATE `tabContact` SET is_primary_contact=1 WHERE name IN (%s)" % names)
|
|
||||||
|
|
||||||
def patch_primary_address():
|
|
||||||
res = webnotes.conn.sql("""
|
|
||||||
SELECT name FROM `tabAddress`
|
|
||||||
WHERE customer IN (
|
|
||||||
SELECT customer FROM `tabAddress`
|
|
||||||
WHERE IFNULL(customer, '')!=''
|
|
||||||
GROUP BY customer HAVING SUM(IFNULL(is_primary_address, 0))=0
|
|
||||||
AND SUM(IFNULL(is_shipping_address, 0))=0
|
|
||||||
) OR supplier IN (
|
|
||||||
SELECT supplier FROM `tabAddress`
|
|
||||||
WHERE IFNULL(supplier, '')!=''
|
|
||||||
GROUP BY supplier HAVING SUM(IFNULL(is_primary_address, 0))=0
|
|
||||||
AND SUM(IFNULL(is_shipping_address, 0))=0
|
|
||||||
) OR sales_partner IN (
|
|
||||||
SELECT sales_partner FROM `tabAddress`
|
|
||||||
WHERE IFNULL(sales_partner, '')!=''
|
|
||||||
GROUP BY sales_partner HAVING SUM(IFNULL(is_primary_address, 0))=0
|
|
||||||
AND SUM(IFNULL(is_shipping_address, 0))=0
|
|
||||||
)
|
|
||||||
""", as_list=1)
|
|
||||||
names = ", ".join(['"' + unicode(r[0]) + '"' for r in res if r])
|
|
||||||
if names: webnotes.conn.sql("UPDATE `tabAddress` SET is_primary_address=1 WHERE name IN (%s)" % names)
|
|
@ -1,21 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.model import delete_doc
|
|
||||||
delete_doc('DocType', 'Purpose of Service')
|
|
@ -1,65 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
delete_fields_dn_detail()
|
|
||||||
deploy_packing_slip()
|
|
||||||
del_packing_slip_pf()
|
|
||||||
|
|
||||||
|
|
||||||
def delete_fields_dn_detail():
|
|
||||||
"""
|
|
||||||
Delete old fields related to packing slip
|
|
||||||
"""
|
|
||||||
from webnotes.model import delete_fields
|
|
||||||
delete_fields({
|
|
||||||
'Delivery Note': [
|
|
||||||
'print_packing_slip', 'shipping_mark', 'packed_by',
|
|
||||||
'packing_checked_by', 'Text', 'pack_size'
|
|
||||||
],
|
|
||||||
'Delivery Note Item': [
|
|
||||||
'pack_no', 'pack_gross_wt', 'weight_uom',
|
|
||||||
'pack_nett_wt', 'no_of_packs', 'pack_unit', 'pack_size',
|
|
||||||
'packed_by', 'packing_checked_by'
|
|
||||||
]
|
|
||||||
}, delete=1)
|
|
||||||
delete_fields({'Item': ['nett_weight', 'gross_weight']}, delete=1)
|
|
||||||
reload_doc('stock', 'doctype', 'delivery_note')
|
|
||||||
reload_doc('stock', 'doctype', 'delivery_note_detail')
|
|
||||||
reload_doc('stock', 'doctype', 'item')
|
|
||||||
|
|
||||||
|
|
||||||
def deploy_packing_slip():
|
|
||||||
reload_doc('stock', 'doctype', 'packing_slip')
|
|
||||||
reload_doc('stock', 'doctype', 'packing_slip_detail')
|
|
||||||
reload_doc('stock', 'Module Def', 'Stock')
|
|
||||||
reload_doc('stock', 'DocType Mapper', 'Delivery Note-Packing Slip')
|
|
||||||
|
|
||||||
|
|
||||||
def del_packing_slip_pf():
|
|
||||||
"""
|
|
||||||
Delete Print Format: 'Delivery Note Packing List Wise'
|
|
||||||
"""
|
|
||||||
webnotes.conn.sql("""\
|
|
||||||
DELETE FROM `tabDocFormat`
|
|
||||||
WHERE parent='Delivery Note'
|
|
||||||
AND format='Delivery Note Packing List Wise'""")
|
|
||||||
from webnotes.model import delete_doc
|
|
||||||
delete_doc('Print Format', 'Delivery Note Packing List Wise')
|
|
@ -1,29 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Change option of doclayer's doc_type field
|
|
||||||
* Reload doclayer
|
|
||||||
"""
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
UPDATE `tabDocField` SET options=NULL
|
|
||||||
WHERE parent='Customize Form' AND fieldname='doc_type'
|
|
||||||
""")
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('core', 'doctype', 'doclayer')
|
|
@ -1,8 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
webnotes.conn.sql("delete from `tabField Mapper Detail` where from_field = 'transaction_date' and parent in ('Sales Order-Delivery Note', 'Purchase Order-Purchase Receipt')")
|
|
||||||
|
|
||||||
reload_doc('stock', 'DocType Mapper', 'Sales Order-Delivery Note')
|
|
||||||
reload_doc('stock', 'DocType Mapper', 'Purchase Order-Purchase Receipt')
|
|
@ -1,30 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Change type of mail_port field to int
|
|
||||||
* reload email settings
|
|
||||||
"""
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
UPDATE `tabDocField` SET fieldtype='Int'
|
|
||||||
WHERE parent = 'Email Settings' AND fieldname = 'mail_port'
|
|
||||||
""")
|
|
||||||
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('setup', 'doctype', 'email_settings')
|
|
@ -1,37 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Change DN to PS mapper
|
|
||||||
+ Set Ref doc should be submitted to 0
|
|
||||||
+ Set validation logic of DN PS Table mapper record to docstatus=0
|
|
||||||
"""
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""\
|
|
||||||
UPDATE `tabDocType Mapper`
|
|
||||||
SET ref_doc_submitted=0
|
|
||||||
WHERE name='Delivery Note-Packing Slip'""")
|
|
||||||
|
|
||||||
webnotes.conn.sql("""\
|
|
||||||
UPDATE `tabTable Mapper Detail`
|
|
||||||
SET validation_logic='docstatus=0'
|
|
||||||
WHERE parent='Delivery Note-Packing Slip'
|
|
||||||
AND docstatus=0
|
|
||||||
AND from_table='Delivery Note'
|
|
||||||
AND to_table='Packing Slip'""")
|
|
||||||
|
|
@ -1,44 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
Patch includes:
|
|
||||||
* Reload of Stock Entry Detail
|
|
||||||
"""
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
reload_doc('stock', 'doctype', 'stock_entry_detail')
|
|
||||||
reload_doc('stock', 'doctype', 'item_supplier')
|
|
||||||
reload_doc('stock', 'doctype', 'item')
|
|
||||||
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
UPDATE tabDocField SET fieldtype='Float'
|
|
||||||
WHERE parent='BOM'
|
|
||||||
AND fieldname IN ('operating_cost', 'raw_material_cost', 'total_cost')
|
|
||||||
""")
|
|
||||||
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
UPDATE tabDocField SET fieldtype='Float'
|
|
||||||
WHERE parent='BOM Item'
|
|
||||||
AND fieldname IN ('qty', 'rate', 'amount', 'qty_consumed_per_unit')
|
|
||||||
""")
|
|
||||||
|
|
||||||
reload_doc('stock', 'doctype', 'stock_entry')
|
|
||||||
reload_doc('production', 'doctype', 'bill_of_materials')
|
|
||||||
reload_doc('production', 'doctype', 'bom_material')
|
|
@ -1,38 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.model import delete_doc
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
|
|
||||||
webnotes.conn.sql("""delete from `tabDocField`
|
|
||||||
where label in ('Note1', 'OT Notes', 'Note', 'Note HTML', 'Rates HTML')
|
|
||||||
and parent in ('Quotation', 'Sales Order', 'Delivery Note', 'Sales Invoice', 'Purchase Order')""")
|
|
||||||
|
|
||||||
|
|
||||||
del_flds = {
|
|
||||||
'Sales Order Item': "'delivery_date', 'confirmation_date'",
|
|
||||||
'Delivery Note': "'supplier', 'supplier_address', 'purchase_receipt_no', 'purchase_order_no', 'transaction_date'",
|
|
||||||
'Sales Invoice': "'voucher_date'",
|
|
||||||
'Purchase Invoice': "'voucher_date'",
|
|
||||||
'Purchase Receipt': "'transaction_date'"
|
|
||||||
}
|
|
||||||
|
|
||||||
del_labels = {
|
|
||||||
'Delivery Note': "'Supplier Details'",
|
|
||||||
'Purchase Receipt': "'Get Currrent Stock'"
|
|
||||||
}
|
|
||||||
|
|
||||||
for d in del_flds:
|
|
||||||
webnotes.conn.sql("delete from `tabDocField` where fieldname in (%s) and parent = '%s'"% (del_flds[d], d))
|
|
||||||
|
|
||||||
for d in del_labels:
|
|
||||||
webnotes.conn.sql("delete from `tabDocField` where label in (%s) and parent = '%s'"% (del_labels[d], d))
|
|
||||||
|
|
||||||
delete_doc('DocType', 'Update Delivery Date Detail')
|
|
||||||
|
|
||||||
# Reload print formats
|
|
||||||
reload_doc('accounts', 'Print Format', 'Sales Invoice Classic')
|
|
||||||
reload_doc('accounts', 'Print Format', 'Sales Invoice Modern')
|
|
||||||
reload_doc('accounts', 'Print Format', 'Sales Invoice Spartan')
|
|
||||||
|
|
@ -1,68 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
from webnotes.model.doc import addchild
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Maps conversion rate in doctype mapper PO-PR
|
|
||||||
* Maps conversion rate in doctype mapper PO-PV
|
|
||||||
"""
|
|
||||||
args = [
|
|
||||||
{
|
|
||||||
'parent': 'Purchase Order-Purchase Receipt',
|
|
||||||
'map': [{
|
|
||||||
'from_table': 'Purchase Order',
|
|
||||||
'to_table': 'Purchase Receipt',
|
|
||||||
'fields': [['conversion_rate', 'conversion_rate', 'Yes']]
|
|
||||||
}]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
'parent': 'Purchase Order-Purchase Invoice',
|
|
||||||
'map': [{
|
|
||||||
'from_table': 'Purchase Order',
|
|
||||||
'to_table': 'Purchase Invoice',
|
|
||||||
'fields': [['conversion_rate', 'conversion_rate', 'Yes']]
|
|
||||||
}]
|
|
||||||
},
|
|
||||||
]
|
|
||||||
|
|
||||||
for a in args:
|
|
||||||
for m in a['map']:
|
|
||||||
match_id = webnotes.conn.sql("""\
|
|
||||||
SELECT match_id FROM `tabTable Mapper Detail`
|
|
||||||
WHERE parent=%s AND from_table=%s AND to_table=%s\
|
|
||||||
""", (a['parent'], m['from_table'], m['to_table']))[0][0]
|
|
||||||
for f in m['fields']:
|
|
||||||
res = webnotes.conn.sql("""\
|
|
||||||
SELECT name FROM `tabField Mapper Detail`
|
|
||||||
WHERE parent=%s AND from_field=%s AND to_field=%s
|
|
||||||
AND match_id=%s""", (a['parent'], f[0], f[1], match_id))
|
|
||||||
if not res:
|
|
||||||
max_idx = webnotes.conn.sql("""\
|
|
||||||
SELECT IFNULL(MAX(idx), 0) FROM `tabField Mapper Detail`
|
|
||||||
WHERE parent=%s""", a['parent'])[0][0]
|
|
||||||
obj = get_obj('DocType Mapper', a['parent'])
|
|
||||||
c = addchild(obj.doc, 'field_mapper_details', 'Field Mapper Detail', obj.doclist)
|
|
||||||
c.from_field = f[0]
|
|
||||||
c.to_field = f[1]
|
|
||||||
c.fields['map'] = f[2]
|
|
||||||
c.match_id = match_id
|
|
||||||
c.idx = max_idx + 1
|
|
||||||
c.save()
|
|
@ -1,4 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("delete from `tabTable Mapper Detail` where to_table = 'Sales Invoice Item' and parent = 'Delivery Note-Sales Invoice' and validation_logic = 'amount > ifnull(billed_amt, 0) and docstatus = 1'")
|
|
@ -1,60 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
import _mysql_exceptions
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('accounts', 'page', 'accounts_home')
|
|
||||||
reload_doc('selling', 'page', 'selling_home')
|
|
||||||
reload_doc('buying', 'page', 'buying_home')
|
|
||||||
reload_doc('stock', 'page', 'stock_home')
|
|
||||||
reload_doc('hr', 'page', 'hr_home')
|
|
||||||
reload_doc('support', 'page', 'support_home')
|
|
||||||
reload_doc('production', 'page', 'production_home')
|
|
||||||
reload_doc('projects', 'page', 'projects_home')
|
|
||||||
reload_doc('website', 'page', 'website_home')
|
|
||||||
reload_doc('home', 'page', 'desktop')
|
|
||||||
reload_doc('utilities', 'page', 'todo')
|
|
||||||
reload_doc('utilities', 'page', 'calendar')
|
|
||||||
reload_doc('utilities', 'page', 'messages')
|
|
||||||
reload_doc('setup', 'page', 'modules_setup')
|
|
||||||
reload_doc('utilities', 'page', 'users')
|
|
||||||
reload_doc('home', 'page', 'activity')
|
|
||||||
reload_doc('home', 'page', 'attributions')
|
|
||||||
reload_doc('core', 'doctype', 'profile')
|
|
||||||
|
|
||||||
# update user_image in profile
|
|
||||||
for p in webnotes.conn.sql("""select name, file_list from tabProfile
|
|
||||||
where ifnull(file_list,'')!=''"""):
|
|
||||||
fid = p[1].split('\n')[0].split(',')[1]
|
|
||||||
webnotes.conn.set_value('Profile', p[0], 'user_image', fid)
|
|
||||||
|
|
||||||
webnotes.conn.set_value('Control Panel', 'Control Panel', 'home_page',
|
|
||||||
'desktop')
|
|
||||||
|
|
||||||
webnotes.conn.commit()
|
|
||||||
|
|
||||||
try:
|
|
||||||
webnotes.conn.sql("""create table __SchedulerLog (
|
|
||||||
`timestamp` timestamp,
|
|
||||||
method varchar(200),
|
|
||||||
error text
|
|
||||||
) engine=MyISAM""")
|
|
||||||
except _mysql_exceptions.OperationalError, e:
|
|
||||||
pass
|
|
@ -1,20 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("update `tabDocField` set no_copy = 1 where fieldname = 'insert_after' and parent = 'Custom Field'")
|
|
@ -1,67 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.model.code import get_obj
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
|
|
||||||
reload_doc('hr', 'doctype', 'appraisal')
|
|
||||||
|
|
||||||
sql("update `tabDocField` set `hidden` = 0 where fieldname = 'group_or_ledger' and parent = 'Cost Center'")
|
|
||||||
sql("update tabDocPerm set amend = 0 where parent = 'Salary Structure'")
|
|
||||||
sql("update tabDocPerm set cancel = 1 where parent = 'Company' and role = 'System Manager'")
|
|
||||||
|
|
||||||
if sql("select count(name) from `tabDocField` where label = 'View Ledger Entry' and parent = 'Journal Voucher' and fieldtype = 'Button'")[0][0] > 1:
|
|
||||||
sql("delete from `tabDocField` where label = 'View Ledger Entry' and parent = 'Journal Voucher' and fieldtype = 'Button' limit 1")
|
|
||||||
if sql("select count(name) from `tabDocField` where label = 'Get Balance' and parent = 'Journal Voucher' and fieldtype = 'Button'")[0][0] > 1:
|
|
||||||
sql("delete from `tabDocField` where label = 'Get Balance' and parent = 'Journal Voucher' and fieldtype = 'Button' limit 1")
|
|
||||||
|
|
||||||
|
|
||||||
if sql("select count(name) from `tabDocField` where label = 'Get Specification Details' and parent = 'Quality Inspection' and fieldtype = 'Button'")[0][0] > 1:
|
|
||||||
sql("delete from `tabDocField` where label = 'Get Specification Details' and parent = 'Quality Inspection' and fieldtype = 'Button' limit 1")
|
|
||||||
|
|
||||||
reload_doc('stock', 'DocType Mapper', 'Purchase Order-Purchase Receipt')
|
|
||||||
|
|
||||||
reload_doc('accounts', 'doctype', 'cost_center')
|
|
||||||
sql("update `tabDocType` set subject = 'Item Code: %(item_code)s, Warehouse: %(warehouse)s' where name = 'Serial No'")
|
|
||||||
|
|
||||||
# Patch for adding packing related columns (packed by, checked by, shipping mark etc)
|
|
||||||
reload_doc('stock','doctype','delivery_note')
|
|
||||||
sql("update `tabDocField` set allow_on_submit = 1 where fieldname = 'page_break'")
|
|
||||||
sql("update `tabDocField` set allow_on_submit = 1 where fieldname in ('indent_details', 'po_details', 'purchase_receipt_details', 'entries', 'sales_order_details', 'delivery_note_details', 'quotation_details') and fieldtype = 'Table'")
|
|
||||||
|
|
||||||
from webnotes.sessions import clear_cache
|
|
||||||
clear_cache(webnotes.session['user'])
|
|
||||||
|
|
||||||
# FEATURES SETUP
|
|
||||||
#----------------
|
|
||||||
reload_doc('setup', 'doctype','features_setup')
|
|
||||||
flds = ['page_break', 'projects', 'packing_details', 'discounts', 'brands', 'item_batch_nos', 'after_sales_installations', 'item_searial_nos', 'item_group_in_details', 'exports', 'imports', 'item_advanced', 'sales_extras', 'more_info', 'quality', 'manufacturing', 'pos', 'item_serial_nos']
|
|
||||||
st = "'"+"', '".join(flds)+"'"
|
|
||||||
sql("delete from `tabSingles` where field in (%s) and doctype = 'Features Setup'" % st)
|
|
||||||
sql("delete from `tabDocField` where fieldname in (%s) and parent = 'Features Setup'" % st)
|
|
||||||
sql("delete from `tabDefaultValue` where defkey in (%s) and parent = 'Control Panel'" % st)
|
|
||||||
|
|
||||||
if not sql("select * from `tabDefaultValue` where defkey like 'fs_%' and parent = 'Control Panel'"):
|
|
||||||
rs = sql("select fieldname from tabDocField where parent='Features Setup' and fieldname is not null")
|
|
||||||
fs = get_obj('Features Setup', 'Features Setup')
|
|
||||||
for d in rs:
|
|
||||||
fs.doc.fields[d[0]] = 1
|
|
||||||
fs.doc.save()
|
|
||||||
fs.validate()
|
|
@ -1,23 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("update `tabDocField` set `default` = 1 where fieldname = 'conversion_rate' and parent = 'POS Setting'")
|
|
||||||
|
|
||||||
from webnotes.model import delete_doc
|
|
||||||
delete_doc('DocType', 'POS Settings')
|
|
@ -1,37 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
To Hide Net Total, Grand Total Export and Rounded Total Export on checking print hide
|
|
||||||
|
|
||||||
Uncheck print_hide for fields:
|
|
||||||
net_total, grand_total_export and rounded_total_export
|
|
||||||
For DocType(s):
|
|
||||||
* Sales Invoice
|
|
||||||
* Sales Order
|
|
||||||
* Delivery Note
|
|
||||||
* Quotation
|
|
||||||
"""
|
|
||||||
webnotes.conn.sql("""\
|
|
||||||
UPDATE tabDocField
|
|
||||||
SET print_hide = 0
|
|
||||||
WHERE fieldname IN ('net_total', 'grand_total_export', 'rounded_total_export')
|
|
||||||
AND parent IN ('Sales Invoice', 'Sales Order', 'Delivery Note', 'Quotation')
|
|
||||||
""")
|
|
@ -1,86 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
from webnotes.model import delete_doc
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
|
|
||||||
# Production Planning Tool
|
|
||||||
#---------------------------------------------------------------
|
|
||||||
#delete_doc('DocType', 'Production Plan Item')
|
|
||||||
#delete_doc('DocType', 'Production Plan Sales Order')
|
|
||||||
#delete_doc('DocType', 'Production Planning Tool')
|
|
||||||
sql("delete from `tabDocField` where parent in ('Production Planning Tool', 'Production Plan Item', 'Production Plan Sales Order')")
|
|
||||||
|
|
||||||
reload_doc('production', 'doctype', 'production_planning_tool')
|
|
||||||
reload_doc('production', 'doctype', 'pp_detail')
|
|
||||||
reload_doc('production', 'doctype', 'pp_so_detail')
|
|
||||||
|
|
||||||
# Production Order
|
|
||||||
#---------------------------------------------------------------
|
|
||||||
|
|
||||||
reload_doc('production', 'doctype', 'production_order')
|
|
||||||
|
|
||||||
sql("""delete from `tabDocField` where parent = 'Production Order'
|
|
||||||
and (label in ('Material Transfer', 'Backflush', 'Stop Production Order', 'Unstop Production Order')
|
|
||||||
or fieldname = 'transaction_date')
|
|
||||||
""")
|
|
||||||
|
|
||||||
|
|
||||||
# BOM
|
|
||||||
#---------------------------------------------------------------
|
|
||||||
reload_doc('production', 'doctype', 'bill_of_materials')
|
|
||||||
reload_doc('production', 'doctype', 'bom_material')
|
|
||||||
reload_doc('production', 'doctype', 'bom_operation')
|
|
||||||
reload_doc('production', 'doctype', 'flat_bom_detail')
|
|
||||||
|
|
||||||
#copy values
|
|
||||||
sql("""update `tabBOM` set rm_cost_as_per = 'Valuation Rate',
|
|
||||||
raw_material_cost = dir_mat_as_per_mar, total_cost = cost_as_per_mar, costing_date = cost_as_on""")
|
|
||||||
|
|
||||||
sql("update `tabBOM Item` set rate = moving_avg_rate, amount = amount_as_per_mar")
|
|
||||||
|
|
||||||
sql("update `tabBOM Explosion Item` set rate = moving_avg_rate, amount = amount_as_per_mar")
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# delete depricated flds from bom
|
|
||||||
sql(""" delete from `tabDocField` where parent = 'BOM'
|
|
||||||
and (
|
|
||||||
label in ('TreeView1', 'Set as Default BOM', 'Activate BOM', 'Inactivate BOM')
|
|
||||||
or fieldname in ('cost_as_per_mar', 'cost_as_per_lpr', 'cost_as_per_sr', 'cost_as_on',
|
|
||||||
'dir_mat_as_per_mar', 'dir_mat_as_per_lpr', 'dir_mat_as_per_sr')
|
|
||||||
)
|
|
||||||
""")
|
|
||||||
|
|
||||||
# delete depricated flds from bom operation
|
|
||||||
sql("delete from `tabDocField` where parent = 'BOM Operation' and fieldname in ('details', 'workstation_capacity')")
|
|
||||||
|
|
||||||
# delete depricated flds from bom material
|
|
||||||
sql("""delete from `tabDocField` where parent = 'BOM Item'
|
|
||||||
and fieldname in ('dir_mat_as_per_mar', 'dir_mat_as_per_sr', 'dir_mat_as_per_lpr', 'operating_cost', 'value_as_per_mar',
|
|
||||||
'value_as_per_sr', 'value_as_per_lpr', 'moving_avg_rate', 'standard_rate', 'last_purchase_rate', 'amount_as_per_sr',
|
|
||||||
'amount_as_per_lpr', 'amount_as_per_mar')
|
|
||||||
""")
|
|
||||||
|
|
||||||
# delete depricated flds from flat bom
|
|
||||||
sql("""delete from tabDocField where parent = 'BOM Explosion Item'
|
|
||||||
and fieldname in ('moving_avg_rate', 'standard_rate', 'last_purchase_rate', 'amount_as_per_mar',
|
|
||||||
'amount_as_per_sr', 'amount_as_per_lpr', 'flat_bom_no', 'bom_mat_no', 'is_pro_applicable')
|
|
||||||
""")
|
|
@ -1,21 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('core', 'doctype', 'doctype')
|
|
@ -1,23 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('stock', 'doctype', 'item')
|
|
||||||
|
|
||||||
webnotes.conn.sql("update `tabItem` set re_order_qty = min_order_qty")
|
|
@ -1,10 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
reload_doc('stock', 'DocType Mapper', 'Sales Order-Delivery Note')
|
|
||||||
reload_doc('accounts', 'DocType Mapper', 'Sales Order-Sales Invoice')
|
|
||||||
reload_doc('accounts', 'DocType Mapper', 'Delivery Note-Sales Invoice')
|
|
||||||
|
|
||||||
webnotes.conn.sql("delete from `tabField Mapper Detail` where parent = 'Sales Order-Delivery Note' and from_field = 'basic_rate' and to_field = 'basic_rate'")
|
|
@ -1,21 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('stock', 'DocType Mapper', 'Purchase Order-Purchase Receipt')
|
|
@ -1,5 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('selling', 'doctype', 'quotation')
|
|
@ -1,4 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
pass
|
|
||||||
|
|
@ -1,41 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# TODO take backup before running this patch
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Restore archived data from arc tables
|
|
||||||
* Drop arc tables
|
|
||||||
"""
|
|
||||||
import webnotes
|
|
||||||
from webnotes.utils import archive
|
|
||||||
arc_tables = webnotes.conn.sql('show tables like "arc%"')
|
|
||||||
try:
|
|
||||||
webnotes.conn.auto_commit_on_many_writes = 1
|
|
||||||
for tab in arc_tables:
|
|
||||||
tab = tab[0]
|
|
||||||
dt = tab[3:]
|
|
||||||
res = webnotes.conn.sql("SELECT name FROM `%s`" % tab)
|
|
||||||
for dn in res:
|
|
||||||
archive.archive_doc(dt, dn[0], restore=1)
|
|
||||||
except Exception, e:
|
|
||||||
raise e
|
|
||||||
else:
|
|
||||||
webnotes.conn.commit()
|
|
||||||
for tab in arc_tables:
|
|
||||||
webnotes.conn.sql("DROP TABLE `%s`" % tab[0])
|
|
||||||
webnotes.conn.begin()
|
|
@ -1,31 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
Remove One Get TDS button, which is appearing twice in JV
|
|
||||||
"""
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
DELETE from `tabDocField`
|
|
||||||
WHERE parent='Journal Voucher'
|
|
||||||
AND label='Get TDS'
|
|
||||||
AND fieldtype='Button'
|
|
||||||
""")
|
|
||||||
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('accounts', 'doctype', 'journal_voucher')
|
|
@ -1,4 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("update `tabDocField` set `default`='' where parent = 'Sales Invoice' and fieldname = 'naming_series' and `default` = 'INV'")
|
|
@ -1,436 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
import conf
|
|
||||||
import webnotes.model
|
|
||||||
from wnf import replace_code
|
|
||||||
from termcolor import colored
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
from webnotes.utils import make_esc
|
|
||||||
import os
|
|
||||||
|
|
||||||
def execute1():
|
|
||||||
#rendt = get_dt_to_be_renamed()
|
|
||||||
#rename_dt_files(rendt)
|
|
||||||
#update_local_file_system()
|
|
||||||
replace_labels_with_fieldnames()
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
|
|
||||||
#---------------------------------------------------
|
|
||||||
# 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])
|
|
||||||
|
|
||||||
delete_search_criteria()
|
|
||||||
change_report_module()
|
|
||||||
|
|
||||||
# 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(conf.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)
|
|
||||||
|
|
||||||
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])
|
|
||||||
reload_doc('accounts', 'GL Mapper', 'Purchase Invoice with write off')
|
|
||||||
|
|
||||||
webnotes.conn.sql("update `tabDocType` set module = 'Utilities' where module = 'Knowledge Base'")
|
|
||||||
webnotes.conn.sql("update `tabPage` set module = 'Utilities' where module = 'Knowledge Base'")
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def delete_search_criteria():
|
|
||||||
webnotes.conn.sql("""DELETE FROM `tabSearch Criteria`
|
|
||||||
WHERE name IN ('', 'bills-to_be_paid',
|
|
||||||
'bills-to_be_submitted', 'cenvat_credit_-_input_or_capital_goods',
|
|
||||||
'appraisal_custom', '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',
|
|
||||||
'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',
|
|
||||||
'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',
|
|
||||||
'sales_order1', 'sales_agentwise_commission', 'test_report',
|
|
||||||
'territory_wise_sales_-_target_vs_actual_',
|
|
||||||
'pending_po_items_to_bill1', 'pending_po_items_to_receive1',
|
|
||||||
'expense_vouchers', 'pending_expense_vouchers', 'shortage_to_indent')""")
|
|
||||||
|
|
||||||
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',
|
|
||||||
'serial_no-warranty_expiring_this_month')
|
|
||||||
AND IFNULL(standard, 'No') = 'Yes'
|
|
||||||
""")
|
|
||||||
|
|
||||||
def change_report_module():
|
|
||||||
reports = {'itemwise_receipt_details': 'Stock'}
|
|
||||||
for k in reports:
|
|
||||||
webnotes.conn.sql("update `tabSearch Criteria` set module = %s where name = %s", (reports[k], k))
|
|
||||||
|
|
||||||
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:
|
|
||||||
webnotes.model.rename(data_type, d, ren_data[d], is_doctype)
|
|
||||||
except Exception, e:
|
|
||||||
if e.args[0]!=1050:
|
|
||||||
raise e
|
|
||||||
else:
|
|
||||||
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
|
|
||||||
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', 'Property Setter')""")
|
|
||||||
for dt in dt_list:
|
|
||||||
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))
|
|
||||||
|
|
||||||
# gl mapper, gl entry
|
|
||||||
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))
|
|
||||||
|
|
||||||
# Stock ledger entry
|
|
||||||
webnotes.conn.sql("update `tabStock Ledger Entry` set voucher_type = replace(voucher_type, '%s', '%s') where voucher_type = '%s'" % (d, rendt[d], d))
|
|
||||||
|
|
||||||
# Custom fld: options
|
|
||||||
webnotes.conn.sql("update `tabCustom Field` set options = replace(options, %s, %s) where fieldtype in ('Link', 'Select', 'Table')", (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():
|
|
||||||
rendt = {
|
|
||||||
'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',
|
|
||||||
'Advance Adjustment Detail' : 'Sales Invoice Advance',
|
|
||||||
'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',
|
|
||||||
}
|
|
||||||
return rendt
|
|
||||||
|
|
||||||
|
|
||||||
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'
|
|
||||||
}
|
|
||||||
return ren_map
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
|
|
||||||
def update_local_file_system():
|
|
||||||
""" RUN ONLY IN LOCAL"""
|
|
||||||
|
|
||||||
# doctype renaming
|
|
||||||
rendt = get_dt_to_be_renamed()
|
|
||||||
|
|
||||||
# replace dt in js/py file
|
|
||||||
update_file_content(rendt)
|
|
||||||
# git mv
|
|
||||||
rename_dt_files(rendt)
|
|
||||||
|
|
||||||
|
|
||||||
# Mapper renaming
|
|
||||||
ren_mapper = get_mapper_to_be_renamed()
|
|
||||||
|
|
||||||
rename_mapper_files(ren_mapper)
|
|
||||||
|
|
||||||
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')
|
|
||||||
|
|
||||||
# git rm production dt mapper
|
|
||||||
os.system('git rm -r erpnext/production/DocType\ Mapper/')
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def update_file_content(rendt):
|
|
||||||
for d in rendt:
|
|
||||||
print colored('Renaming... ' + d + ' --> '+ rendt[d], 'yellow')
|
|
||||||
for extn in ['js', 'py', 'txt', 'html']:
|
|
||||||
res = replace_code('/var/www/erpnext/', d, rendt[d], extn)
|
|
||||||
if res == 'skip':
|
|
||||||
break
|
|
||||||
|
|
||||||
|
|
||||||
def rename_dt_files(rendt):
|
|
||||||
for d in rendt:
|
|
||||||
mod = webnotes.conn.sql("select module from tabDocType where name = %s", rendt[d])[0][0]
|
|
||||||
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/'
|
|
||||||
old = '_'.join(d.lower().split())
|
|
||||||
new = '_'.join(rendt[d].lower().split())
|
|
||||||
|
|
||||||
print 'git mv ' + path + old + ' ' + path + new
|
|
||||||
# rename old dir
|
|
||||||
os.system('git mv ' + path + old + ' ' + path + new)
|
|
||||||
|
|
||||||
# rename all files in that dir
|
|
||||||
for extn in ['js', 'py', 'txt', 'html']:
|
|
||||||
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
|
|
||||||
mod = '_'.join(webnotes.conn.sql("select module from `tabDocType Mapper` where name = %s", ren_mapper[d])[0][0].lower().split())
|
|
||||||
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])
|
|
||||||
os.system('git mv ' + esc(path + ren_mapper[d] + '/'+ d + '.txt')
|
|
||||||
+ ' ' + esc(path + ren_mapper[d] + '/' + ren_mapper[d] + '.txt'))
|
|
||||||
print 'git mv ' + esc(path + ren_mapper[d] + '/'+ d + '.txt') + ' ' + esc(path + ren_mapper[d] + '/' + ren_mapper[d] + '.txt')
|
|
||||||
|
|
||||||
|
|
||||||
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, conf.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
|
|
@ -1,35 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
opts = webnotes.conn.sql("""\
|
|
||||||
SELECT options FROM `tabDocField`
|
|
||||||
WHERE parent='Serial No' AND fieldname='status' AND
|
|
||||||
fieldtype='Select'""")
|
|
||||||
if opts and opts[0][0]:
|
|
||||||
opt_list = opts[0][0].split("\n")
|
|
||||||
if not "Purchase Returned" in opt_list:
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
UPDATE `tabDocField` SET options=%s
|
|
||||||
WHERE parent='Serial No' AND fieldname='status' AND
|
|
||||||
fieldtype='Select'""", "\n".join(opt_list + ["Purchase Returned"]))
|
|
||||||
webnotes.conn.commit()
|
|
||||||
webnotes.conn.begin()
|
|
||||||
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('stock', 'doctype', 'serial_no')
|
|
@ -1,55 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Reload Sales Taxes and Charges
|
|
||||||
* Reload Support Ticket
|
|
||||||
* Run Install Print Format Patch
|
|
||||||
* Reload Customize Form
|
|
||||||
"""
|
|
||||||
reload_doc('accounts', 'doctype', 'rv_tax_detail')
|
|
||||||
reload_doc('support', 'doctype', 'support_ticket')
|
|
||||||
reload_print_formats()
|
|
||||||
reload_doc('core', 'doctype', 'doclayer')
|
|
||||||
|
|
||||||
def reload_print_formats():
|
|
||||||
"""
|
|
||||||
Reloads the following print formats:
|
|
||||||
* Sales Invoice Classic/Modern/Spartan
|
|
||||||
* Sales Order Classic/Modern/Spartan
|
|
||||||
* Delivery Note Classic/Modern/Spartan
|
|
||||||
* Quotation Classic/Modern/Spartan
|
|
||||||
"""
|
|
||||||
reload_doc('accounts', 'Print Format', 'Sales Invoice Classic')
|
|
||||||
reload_doc('accounts', 'Print Format', 'Sales Invoice Modern')
|
|
||||||
reload_doc('accounts', 'Print Format', 'Sales Invoice Spartan')
|
|
||||||
|
|
||||||
reload_doc('selling', 'Print Format', 'Sales Order Classic')
|
|
||||||
reload_doc('selling', 'Print Format', 'Sales Order Modern')
|
|
||||||
reload_doc('selling', 'Print Format', 'Sales Order Spartan')
|
|
||||||
|
|
||||||
reload_doc('selling', 'Print Format', 'Quotation Classic')
|
|
||||||
reload_doc('selling', 'Print Format', 'Quotation Modern')
|
|
||||||
reload_doc('selling', 'Print Format', 'Quotation Spartan')
|
|
||||||
|
|
||||||
reload_doc('stock', 'Print Format', 'Delivery Note Classic')
|
|
||||||
reload_doc('stock', 'Print Format', 'Delivery Note Modern')
|
|
||||||
reload_doc('stock', 'Print Format', 'Delivery Note Spartan')
|
|
@ -1,7 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('stock', 'doctype', 'stock_entry')
|
|
||||||
|
|
||||||
webnotes.conn.sql("update `tabDocField` set options = concat(options, '\nOthers') where fieldname = 'purpose' and parent = 'Stock Entry'")
|
|
@ -1,24 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""
|
|
||||||
update `tabDocField` set `default` = 'No'
|
|
||||||
where parent in ('Purchase Order', 'Purchase Receipt')
|
|
||||||
and fieldname = 'is_subcontracted'
|
|
||||||
""")
|
|
@ -1,54 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
sql = webnotes.conn.sql
|
|
||||||
from webnotes.model import delete_doc
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
del_rec = {
|
|
||||||
'DocType' : ['Update Series', 'File', 'File Browser Control', 'File Group',
|
|
||||||
'Tag Detail', 'DocType Property Setter', 'Company Group', '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', 'Lease Agreement', 'Lease Installment',
|
|
||||||
'Terms and Conditions', 'Time Sheet', 'Time Sheet Detail', 'Naming Series Options',
|
|
||||||
'Invest 80 Declaration Detail', 'IT Checklist', 'Chapter VI A Detail', 'Declaration Detail',
|
|
||||||
'Personalize', 'Salary Slip Control Panel', 'Question Control'
|
|
||||||
],
|
|
||||||
'Page' : ['File Browser', 'Bill of Materials', 'question-view'],
|
|
||||||
'DocType Mapper': ['Production Forecast-Production Planning Tool', 'Production Forecast-Production Plan', 'Sales Order-Production Plan'],
|
|
||||||
}
|
|
||||||
|
|
||||||
for d in del_rec:
|
|
||||||
for r in del_rec[d]:
|
|
||||||
print 'Deleted', d, ' - ', r
|
|
||||||
if d=='DocType':
|
|
||||||
sql("delete from tabFeed where doc_type=%s", r)
|
|
||||||
delete_doc(d, r)
|
|
||||||
|
|
||||||
sql("delete from tabDocField where label='Repair Purchase Request' and parent = 'Purchase Request'")
|
|
||||||
|
|
||||||
drop_tables()
|
|
||||||
|
|
||||||
|
|
||||||
def drop_tables():
|
|
||||||
webnotes.conn.commit()
|
|
||||||
from webnotes.model.db_schema import remove_all_foreign_keys
|
|
||||||
remove_all_foreign_keys()
|
|
||||||
count = 0
|
|
||||||
tab_list = sql("SHOW TABLES")
|
|
||||||
for tab in tab_list:
|
|
||||||
if tab[0].startswith('_') or tab[0] in ('tabSingles', 'tabSessions', 'tabSeries'): continue
|
|
||||||
res = sql("SELECT COUNT(*) FROM `tabDocType` WHERE name = %s", tab[0][3:])
|
|
||||||
if not res[0][0]:
|
|
||||||
count += 1
|
|
||||||
print tab[0]
|
|
||||||
sql("DROP TABLE `%s`" % tab[0])
|
|
||||||
print count
|
|
||||||
webnotes.conn.begin()
|
|
@ -1,4 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("update `tabDocField` set options = replace(options, 'Others', 'Other') where fieldname = 'purpose' and parent = 'Stock Entry'")
|
|
@ -1,7 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("update `tabDocField` set options = 'BOM' where fieldname = 'bom_no' and parent = 'Stock Entry'")
|
|
||||||
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('stock', 'doctype', 'stock_entry')
|
|
@ -1,4 +0,0 @@
|
|||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("update `tabDocPerm` set cancel = 1 where parent = 'Stock Reconciliation' and ifnull(submit, 0) = 1")
|
|
@ -1,3 +0,0 @@
|
|||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
|
|
@ -1,36 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import patches.jan_mar_2012.website.login
|
|
||||||
import patches.jan_mar_2012.website.feed
|
|
||||||
import patches.jan_mar_2012.website.website
|
|
||||||
import patches.jan_mar_2012.website.cleanups
|
|
||||||
import patches.jan_mar_2012.website.domain_list
|
|
||||||
import patches.jan_mar_2012.website.file_data_rename
|
|
||||||
import patches.jan_mar_2012.website.analytics
|
|
||||||
import patches.jan_mar_2012.website.allow_product_delete
|
|
||||||
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
patches.jan_mar_2012.website.login.execute()
|
|
||||||
patches.jan_mar_2012.website.feed.execute()
|
|
||||||
patches.jan_mar_2012.website.website.execute()
|
|
||||||
patches.jan_mar_2012.website.cleanups.execute()
|
|
||||||
patches.jan_mar_2012.website.domain_list.execute()
|
|
||||||
patches.jan_mar_2012.website.file_data_rename.execute()
|
|
||||||
patches.jan_mar_2012.website.analytics.execute()
|
|
||||||
patches.jan_mar_2012.website.allow_product_delete.execute()
|
|
@ -1,25 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
Allow deletion of products
|
|
||||||
"""
|
|
||||||
import webnotes
|
|
||||||
webnotes.conn.sql("""UPDATE `tabDocPerm` SET cancel=1
|
|
||||||
WHERE parent='Product' AND role='Website Manager'
|
|
||||||
AND permlevel=0""")
|
|
@ -1,22 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('website', 'doctype', 'website_settings')
|
|
||||||
reload_doc('website', 'doctype', 'product_settings')
|
|
||||||
|
|
@ -1,48 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
from webnotes.model import delete_doc
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
delete_doc("DocType", "SSO Control")
|
|
||||||
delete_doc("DocType", "WN ERP Client Control")
|
|
||||||
delete_doc("DocType", "Production Tips Common")
|
|
||||||
delete_doc("DocType", "DocTrigger")
|
|
||||||
delete_doc("Page", "Setup Wizard")
|
|
||||||
|
|
||||||
# cleanup control panel
|
|
||||||
delete_doc("DocType", "Control Panel")
|
|
||||||
reload_doc("core", "doctype", "control_panel")
|
|
||||||
|
|
||||||
webnotes.conn.sql("""delete from tabSingles
|
|
||||||
where field like 'startup_%' and doctype='Control Panel'""")
|
|
||||||
webnotes.conn.sql("""delete from __SessionCache""")
|
|
||||||
|
|
||||||
webnotes.conn.commit()
|
|
||||||
|
|
||||||
# DDLs
|
|
||||||
# -------------------
|
|
||||||
|
|
||||||
webnotes.conn.sql("drop table if exists tabDocTrigger")
|
|
||||||
|
|
||||||
try: webnotes.conn.sql("""alter table `tabFile Data` drop column blob_content""")
|
|
||||||
except: pass
|
|
||||||
|
|
||||||
webnotes.conn.sql("""alter table __PatchLog engine=InnoDB""")
|
|
||||||
|
|
@ -1,39 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
def execute():
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
reload_doc('website', 'doctype', 'website_settings')
|
|
||||||
|
|
||||||
res = webnotes.conn.sql("""\
|
|
||||||
SELECT name FROM `tabDocPerm`
|
|
||||||
WHERE parent='Website Settings' AND role='All' AND permlevel=1""")
|
|
||||||
if not res:
|
|
||||||
idx = webnotes.conn.sql("""\
|
|
||||||
SELECT MAX(idx) FROM `tabDocPerm`
|
|
||||||
WHERE parent='Website Settings'
|
|
||||||
""")[0][0]
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
d = Document('DocType', 'Website Settings')
|
|
||||||
perm = d.addchild('permissions', 'DocPerm')
|
|
||||||
perm.read = 1
|
|
||||||
perm.role = 'All'
|
|
||||||
perm.permlevel = 1
|
|
||||||
perm.idx = idx + 1
|
|
||||||
perm.save()
|
|
||||||
|
|
@ -1,22 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
reload_doc('home', 'doctype', 'feed')
|
|
@ -1,81 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
"""
|
|
||||||
* Replace / in names with - in tabFile Data
|
|
||||||
* Change autoname in DocType File Data to FileData-.#####
|
|
||||||
* Change FileData/ to FileData- in tabSeries
|
|
||||||
* In each table containing file_list column, replace / with - in the data of that column
|
|
||||||
"""
|
|
||||||
replace_name_in_file_data()
|
|
||||||
change_autoname_in_tabfile_data()
|
|
||||||
change_file_data_in_tabseries()
|
|
||||||
replace_file_list_column_entries()
|
|
||||||
|
|
||||||
def replace_name_in_file_data():
|
|
||||||
"""
|
|
||||||
Change / to - in tabFile Data name column entries
|
|
||||||
"""
|
|
||||||
files = webnotes.conn.sql("SELECT name FROM `tabFile Data`")
|
|
||||||
for f in files:
|
|
||||||
if "/" in f[0]:
|
|
||||||
webnotes.conn.sql("UPDATE `tabFile Data` SET name=%s WHERE name=%s", (f[0].replace('/', '-'), f[0]))
|
|
||||||
|
|
||||||
|
|
||||||
def change_autoname_in_tabfile_data():
|
|
||||||
"""
|
|
||||||
Change autoname in DocType File Data to FileData-.#####
|
|
||||||
"""
|
|
||||||
webnotes.conn.sql("UPDATE `tabDocType` SET autoname='FileData-.#####' WHERE name='File Data'")
|
|
||||||
|
|
||||||
|
|
||||||
def change_file_data_in_tabseries():
|
|
||||||
"""
|
|
||||||
Change FileData/ to FileData- in tabSeries
|
|
||||||
"""
|
|
||||||
webnotes.conn.sql("UPDATE `tabSeries` SET name='FileData-' WHERE name='FileData/'")
|
|
||||||
|
|
||||||
|
|
||||||
def replace_file_list_column_entries():
|
|
||||||
"""
|
|
||||||
In each table containing file_list column, replace / with - in the data of that column
|
|
||||||
"""
|
|
||||||
tables = webnotes.conn.sql("SHOW TABLES")
|
|
||||||
tab_list = []
|
|
||||||
for tab in tables:
|
|
||||||
columns = webnotes.conn.sql("DESC `%s`" % tab[0])
|
|
||||||
if 'file_list' in [c[0] for c in columns]:
|
|
||||||
tab_list.append(tab[0])
|
|
||||||
|
|
||||||
for tab in tab_list:
|
|
||||||
data = webnotes.conn.sql("SELECT name, file_list FROM `%s`" % tab)
|
|
||||||
for name, file_list in data:
|
|
||||||
if file_list and "/" in file_list:
|
|
||||||
webnotes.conn.sql("UPDATE `%s` SET file_list='%s' WHERE name='%s'" \
|
|
||||||
% (tab, file_list.replace('/', '-'), name))
|
|
||||||
|
|
||||||
singles = webnotes.conn.sql("""SELECT doctype, value FROM `tabSingles`
|
|
||||||
WHERE field='file_list'""")
|
|
||||||
for doctype, file_list in singles:
|
|
||||||
if file_list and "/" in file_list:
|
|
||||||
webnotes.conn.sql("""UPDATE `tabSingles` SET value='%s'
|
|
||||||
WHERE doctype='%s' AND field='file_list'"""
|
|
||||||
% (file_list.replace('/', '-'), doctype))
|
|
||||||
|
|
@ -1,67 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
"""rename from getfle"""
|
|
||||||
l = [
|
|
||||||
('Quotation Item', 'description'),
|
|
||||||
('Sales Order Item', 'description'),
|
|
||||||
('Delivery Note Item', 'description'),
|
|
||||||
('Sales Invoice Item', 'description'),
|
|
||||||
('Item', 'description_html'),
|
|
||||||
('Letter Head', 'content')
|
|
||||||
]
|
|
||||||
|
|
||||||
import re
|
|
||||||
|
|
||||||
for table in l:
|
|
||||||
for item in webnotes.conn.sql("""select name, %s from `tab%s`
|
|
||||||
where %s like '%s'""" % (table[1], table[0], table[1], '%cgi-bin/getfile.cgi%')):
|
|
||||||
txt = re.sub('\&acx=[^"\']*', '', item[1])\
|
|
||||||
.replace('cgi-bin/getfile.cgi?name=', 'files/')\
|
|
||||||
.replace('FileData/', 'FileData-')
|
|
||||||
|
|
||||||
txt = get_file_id(txt)
|
|
||||||
|
|
||||||
webnotes.conn.sql("""update `tab%s` set %s=%s where name=%s""" % \
|
|
||||||
(table[0], table[1], '%s', '%s'), (txt, item[0]))
|
|
||||||
|
|
||||||
# control panel, client name
|
|
||||||
txt = webnotes.conn.get_value('Control Panel',None,'client_name')
|
|
||||||
if txt:
|
|
||||||
txt = get_file_id(txt)
|
|
||||||
webnotes.conn.set_value('Control Panel', None, 'client_name', txt.replace('index.cgi?cmd=get_file&fname=', 'files/'))
|
|
||||||
|
|
||||||
def get_file_id(txt):
|
|
||||||
"""old file links may be from fileid or filename"""
|
|
||||||
import re
|
|
||||||
match = re.search('files/([^"\']*)', txt)
|
|
||||||
|
|
||||||
if not match:
|
|
||||||
print txt
|
|
||||||
return txt
|
|
||||||
|
|
||||||
fname = match.groups()[0]
|
|
||||||
if not fname.startswith('FileData'):
|
|
||||||
fid = webnotes.conn.sql("""select name from `tabFile Data`
|
|
||||||
where file_name=%s""", fname)
|
|
||||||
if fid:
|
|
||||||
fid = fid[0][0].replace('/', '-')
|
|
||||||
txt = txt.replace(fname, fid)
|
|
||||||
return txt
|
|
@ -1,36 +0,0 @@
|
|||||||
# ERPNext - web based ERP (http://erpnext.com)
|
|
||||||
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import webnotes
|
|
||||||
from webnotes.model.doc import Document
|
|
||||||
from webnotes.modules import reload_doc
|
|
||||||
|
|
||||||
def execute():
|
|
||||||
add_default_home_page()
|
|
||||||
reload_doc('setup','doctype','manage_account')
|
|
||||||
|
|
||||||
|
|
||||||
def add_default_home_page():
|
|
||||||
if not webnotes.conn.sql("""select name from `tabDefault Home Page`
|
|
||||||
where role='Guest' and home_page='Login Page'"""):
|
|
||||||
d = Document('Default Home Page')
|
|
||||||
d.parent = 'Control Panel'
|
|
||||||
d.parenttype = 'Control Panel'
|
|
||||||
d.parentfield = 'default_home_pages'
|
|
||||||
d.role = 'Guest'
|
|
||||||
d.home_page = 'Login Page'
|
|
||||||
d.save(1)
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user