feat: new hook fields_for_group_similar_items to group additional fields for print formats (#40831)
(cherry picked from commit f7c9e1538b)
# Conflicts:
# erpnext/hooks.py
This commit is contained in:
@@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
|
|
||||||
import json
|
import json
|
||||||
|
from collections import defaultdict
|
||||||
|
|
||||||
import frappe
|
import frappe
|
||||||
from frappe import _, bold, qb, throw
|
from frappe import _, bold, qb, throw
|
||||||
@@ -1947,21 +1948,26 @@ class AccountsController(TransactionBase):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def group_similar_items(self):
|
def group_similar_items(self):
|
||||||
group_item_qty = {}
|
grouped_items = {}
|
||||||
group_item_amount = {}
|
|
||||||
# to update serial number in print
|
# to update serial number in print
|
||||||
count = 0
|
count = 0
|
||||||
|
|
||||||
|
fields_to_group = frappe.get_hooks("fields_for_group_similar_items")
|
||||||
|
fields_to_group = set(fields_to_group)
|
||||||
|
|
||||||
for item in self.items:
|
for item in self.items:
|
||||||
group_item_qty[item.item_code] = group_item_qty.get(item.item_code, 0) + item.qty
|
item_values = grouped_items.setdefault(item.item_code, defaultdict(int))
|
||||||
group_item_amount[item.item_code] = group_item_amount.get(item.item_code, 0) + item.amount
|
|
||||||
|
for field in fields_to_group:
|
||||||
|
item_values[field] += item.get(field, 0)
|
||||||
|
|
||||||
duplicate_list = []
|
duplicate_list = []
|
||||||
for item in self.items:
|
for item in self.items:
|
||||||
if item.item_code in group_item_qty:
|
if item.item_code in grouped_items:
|
||||||
count += 1
|
count += 1
|
||||||
item.qty = group_item_qty[item.item_code]
|
|
||||||
item.amount = group_item_amount[item.item_code]
|
for field in fields_to_group:
|
||||||
|
item.set(field, grouped_items[item.item_code][field])
|
||||||
|
|
||||||
if item.qty:
|
if item.qty:
|
||||||
item.rate = flt(flt(item.amount) / flt(item.qty), item.precision("rate"))
|
item.rate = flt(flt(item.amount) / flt(item.qty), item.precision("rate"))
|
||||||
@@ -1969,7 +1975,7 @@ class AccountsController(TransactionBase):
|
|||||||
item.rate = 0
|
item.rate = 0
|
||||||
|
|
||||||
item.idx = count
|
item.idx = count
|
||||||
del group_item_qty[item.item_code]
|
del grouped_items[item.item_code]
|
||||||
else:
|
else:
|
||||||
duplicate_list.append(item)
|
duplicate_list.append(item)
|
||||||
for item in duplicate_list:
|
for item in duplicate_list:
|
||||||
|
|||||||
@@ -643,3 +643,15 @@ extend_bootinfo = [
|
|||||||
"erpnext.support.doctype.service_level_agreement.service_level_agreement.add_sla_doctypes",
|
"erpnext.support.doctype.service_level_agreement.service_level_agreement.add_sla_doctypes",
|
||||||
"erpnext.startup.boot.bootinfo",
|
"erpnext.startup.boot.bootinfo",
|
||||||
]
|
]
|
||||||
|
<<<<<<< HEAD
|
||||||
|
=======
|
||||||
|
|
||||||
|
|
||||||
|
default_log_clearing_doctypes = {
|
||||||
|
"Repost Item Valuation": 60,
|
||||||
|
}
|
||||||
|
|
||||||
|
export_python_type_annotations = True
|
||||||
|
|
||||||
|
fields_for_group_similar_items = ["qty", "amount"]
|
||||||
|
>>>>>>> f7c9e1538b (feat: new hook `fields_for_group_similar_items` to group additional fields for print formats (#40831))
|
||||||
|
|||||||
Reference in New Issue
Block a user