Propogate root type and report type into children based on parent
This commit is contained in:
parent
ba9dbb1b09
commit
94f15fcec6
@ -23,6 +23,7 @@ class Account(Document):
|
|||||||
def validate(self):
|
def validate(self):
|
||||||
self.validate_parent()
|
self.validate_parent()
|
||||||
self.validate_root_details()
|
self.validate_root_details()
|
||||||
|
self.set_root_and_report_type()
|
||||||
self.validate_mandatory()
|
self.validate_mandatory()
|
||||||
self.validate_warehouse_account()
|
self.validate_warehouse_account()
|
||||||
self.validate_frozen_accounts_modifier()
|
self.validate_frozen_accounts_modifier()
|
||||||
@ -32,7 +33,7 @@ class Account(Document):
|
|||||||
"""Fetch Parent Details and validate parent account"""
|
"""Fetch Parent Details and validate parent account"""
|
||||||
if self.parent_account:
|
if self.parent_account:
|
||||||
par = frappe.db.get_value("Account", self.parent_account,
|
par = frappe.db.get_value("Account", self.parent_account,
|
||||||
["name", "is_group", "report_type", "root_type", "company"], as_dict=1)
|
["name", "is_group", "company"], as_dict=1)
|
||||||
if not par:
|
if not par:
|
||||||
throw(_("Account {0}: Parent account {1} does not exist").format(self.name, self.parent_account))
|
throw(_("Account {0}: Parent account {1} does not exist").format(self.name, self.parent_account))
|
||||||
elif par.name == self.name:
|
elif par.name == self.name:
|
||||||
@ -43,11 +44,25 @@ class Account(Document):
|
|||||||
throw(_("Account {0}: Parent account {1} does not belong to company: {2}")
|
throw(_("Account {0}: Parent account {1} does not belong to company: {2}")
|
||||||
.format(self.name, self.parent_account, self.company))
|
.format(self.name, self.parent_account, self.company))
|
||||||
|
|
||||||
|
def set_root_and_report_type(self):
|
||||||
|
if self.parent_account:
|
||||||
|
par = frappe.db.get_value("Account", self.parent_account, ["report_type", "root_type"], as_dict=1)
|
||||||
|
|
||||||
if par.report_type:
|
if par.report_type:
|
||||||
self.report_type = par.report_type
|
self.report_type = par.report_type
|
||||||
if par.root_type:
|
if par.root_type:
|
||||||
self.root_type = par.root_type
|
self.root_type = par.root_type
|
||||||
|
|
||||||
|
if self.is_group:
|
||||||
|
db_value = frappe.db.get_value("Account", self.name, ["report_type", "root_type"], as_dict=1)
|
||||||
|
if db_value:
|
||||||
|
if self.report_type != db_value.report_type:
|
||||||
|
frappe.db.sql("update `tabAccount` set report_type=%s where lft > %s and rgt < %s",
|
||||||
|
(self.report_type, self.lft, self.rgt))
|
||||||
|
if self.root_type != db_value.root_type:
|
||||||
|
frappe.db.sql("update `tabAccount` set root_type=%s where lft > %s and rgt < %s",
|
||||||
|
(self.root_type, self.lft, self.rgt))
|
||||||
|
|
||||||
def validate_root_details(self):
|
def validate_root_details(self):
|
||||||
# does not exists parent
|
# does not exists parent
|
||||||
if frappe.db.exists("Account", self.name):
|
if frappe.db.exists("Account", self.name):
|
||||||
|
@ -184,3 +184,4 @@ execute:frappe.delete_doc("Module Def", "Contacts")
|
|||||||
erpnext.patches.v5_4.fix_reserved_qty_and_sle_for_packed_items # 30-07-2015
|
erpnext.patches.v5_4.fix_reserved_qty_and_sle_for_packed_items # 30-07-2015
|
||||||
execute:frappe.reload_doctype("Leave Type")
|
execute:frappe.reload_doctype("Leave Type")
|
||||||
execute:frappe.db.sql("update `tabLeave Type` set include_holiday=0")
|
execute:frappe.db.sql("update `tabLeave Type` set include_holiday=0")
|
||||||
|
erpnext.patches.v5_4.set_root_and_report_type
|
12
erpnext/patches/v5_4/set_root_and_report_type.py
Normal file
12
erpnext/patches/v5_4/set_root_and_report_type.py
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
# Copyright (c) 2013, Web Notes Technologies Pvt. Ltd. and Contributors
|
||||||
|
# License: GNU General Public License v3. See license.txt
|
||||||
|
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
import frappe
|
||||||
|
|
||||||
|
def execute():
|
||||||
|
roots = frappe.db.sql("""select lft, rgt, report_type, root_type
|
||||||
|
from `tabAccount` where ifnull(parent_account, '')=''""", as_dict=1)
|
||||||
|
for d in roots:
|
||||||
|
frappe.db.sql("update `tabAccount` set report_type=%s, root_type=%s where lft > %s and rgt < %s",
|
||||||
|
(d.report_type, d.root_type, d.lft, d.rgt))
|
Loading…
Reference in New Issue
Block a user