Merge pull request #34812 from frappe/version-13-hotfix

chore: release v13
This commit is contained in:
Deepesh Garg
2023-04-11 17:09:06 +05:30
committed by GitHub
6 changed files with 60 additions and 30 deletions

View File

@@ -33,7 +33,7 @@ frappe.listview_settings['Asset'] = {
} }
}, },
onload: function(me) { onload: function(me) {
me.page.add_action_item('Make Asset Movement', function() { me.page.add_action_item(__("Make Asset Movement"), function() {
const assets = me.get_checked_items(); const assets = me.get_checked_items();
frappe.call({ frappe.call({
method: "erpnext.assets.doctype.asset.asset.make_asset_movement", method: "erpnext.assets.doctype.asset.asset.make_asset_movement",

View File

@@ -24,7 +24,7 @@ frappe.query_reports["Fixed Asset Register"] = {
"label": __("Period Based On"), "label": __("Period Based On"),
"fieldtype": "Select", "fieldtype": "Select",
"options": ["Fiscal Year", "Date Range"], "options": ["Fiscal Year", "Date Range"],
"default": ["Fiscal Year"], "default": "Fiscal Year",
"reqd": 1 "reqd": 1
}, },
{ {
@@ -75,12 +75,6 @@ frappe.query_reports["Fixed Asset Register"] = {
fieldtype: "Link", fieldtype: "Link",
options: "Asset Category" options: "Asset Category"
}, },
{
fieldname:"finance_book",
label: __("Finance Book"),
fieldtype: "Link",
options: "Finance Book"
},
{ {
fieldname:"cost_center", fieldname:"cost_center",
label: __("Cost Center"), label: __("Cost Center"),
@@ -96,8 +90,20 @@ frappe.query_reports["Fixed Asset Register"] = {
reqd: 1 reqd: 1
}, },
{ {
fieldname:"is_existing_asset", fieldname:"finance_book",
label: __("Is Existing Asset"), label: __("Finance Book"),
fieldtype: "Link",
options: "Finance Book",
depends_on: "eval: doc.only_depreciable_assets == 1",
},
{
fieldname:"only_depreciable_assets",
label: __("Only depreciable assets"),
fieldtype: "Check"
},
{
fieldname:"only_existing_assets",
label: __("Only existing assets"),
fieldtype: "Check" fieldtype: "Check"
}, },
] ]

View File

@@ -45,8 +45,10 @@ def get_conditions(filters):
filters.year_end_date = getdate(fiscal_year.year_end_date) filters.year_end_date = getdate(fiscal_year.year_end_date)
conditions[date_field] = ["between", [filters.year_start_date, filters.year_end_date]] conditions[date_field] = ["between", [filters.year_start_date, filters.year_end_date]]
if filters.get("is_existing_asset"): if filters.get("only_depreciable_assets"):
conditions["is_existing_asset"] = filters.get("is_existing_asset") conditions["calculate_depreciation"] = filters.get("only_depreciable_assets")
if filters.get("only_existing_assets"):
conditions["is_existing_asset"] = filters.get("only_existing_assets")
if filters.get("asset_category"): if filters.get("asset_category"):
conditions["asset_category"] = filters.get("asset_category") conditions["asset_category"] = filters.get("asset_category")
if filters.get("cost_center"): if filters.get("cost_center"):
@@ -102,19 +104,18 @@ def get_data(filters):
] ]
assets_record = frappe.db.get_all("Asset", filters=conditions, fields=fields) assets_record = frappe.db.get_all("Asset", filters=conditions, fields=fields)
assets_linked_to_fb = frappe.db.get_all( assets_linked_to_fb = None
doctype="Asset Finance Book",
filters={"finance_book": filters.finance_book or ("is", "not set")}, if filters.only_depreciable_assets:
pluck="parent", assets_linked_to_fb = frappe.db.get_all(
) doctype="Asset Finance Book",
filters={"finance_book": filters.finance_book or ("is", "not set")},
pluck="parent",
)
for asset in assets_record: for asset in assets_record:
if filters.finance_book: if assets_linked_to_fb and asset.asset_id not in assets_linked_to_fb:
if asset.asset_id not in assets_linked_to_fb: continue
continue
else:
if asset.calculate_depreciation and asset.asset_id not in assets_linked_to_fb:
continue
asset_value = get_asset_value_after_depreciation(asset.asset_id, filters.finance_book) asset_value = get_asset_value_after_depreciation(asset.asset_id, filters.finance_book)
row = { row = {
@@ -172,11 +173,11 @@ def prepare_chart_data(data, filters):
"datasets": [ "datasets": [
{ {
"name": _("Asset Value"), "name": _("Asset Value"),
"values": [d.get("asset_value") for d in labels_values_map.values()], "values": [flt(d.get("asset_value"), 2) for d in labels_values_map.values()],
}, },
{ {
"name": _("Depreciatied Amount"), "name": _("Depreciatied Amount"),
"values": [d.get("depreciated_amount") for d in labels_values_map.values()], "values": [flt(d.get("depreciated_amount"), 2) for d in labels_values_map.values()],
}, },
], ],
}, },
@@ -310,7 +311,7 @@ def get_columns(filters):
return [ return [
{ {
"label": _("Asset Id"), "label": _("Asset ID"),
"fieldtype": "Link", "fieldtype": "Link",
"fieldname": "asset_id", "fieldname": "asset_id",
"options": "Asset", "options": "Asset",

View File

@@ -37,8 +37,24 @@ class ItemGroup(NestedSet, WebsiteGenerator):
self.make_route() self.make_route()
self.validate_item_group_defaults() self.validate_item_group_defaults()
self.check_item_tax()
ECommerceSettings.validate_field_filters(self.filter_fields, enable_field_filters=True) ECommerceSettings.validate_field_filters(self.filter_fields, enable_field_filters=True)
def check_item_tax(self):
"""Check whether Tax Rate is not entered twice for same Tax Type"""
check_list = []
for d in self.get("taxes"):
if d.item_tax_template:
if (d.item_tax_template, d.tax_category) in check_list:
frappe.throw(
_("{0} entered twice {1} in Item Taxes").format(
frappe.bold(d.item_tax_template),
"for tax category {0}".format(frappe.bold(d.tax_category)) if d.tax_category else "",
)
)
else:
check_list.append((d.item_tax_template, d.tax_category))
def on_update(self): def on_update(self):
NestedSet.on_update(self) NestedSet.on_update(self)
invalidate_cache_for(self) invalidate_cache_for(self)

View File

@@ -354,10 +354,15 @@ class Item(Document):
check_list = [] check_list = []
for d in self.get("taxes"): for d in self.get("taxes"):
if d.item_tax_template: if d.item_tax_template:
if d.item_tax_template in check_list: if (d.item_tax_template, d.tax_category) in check_list:
frappe.throw(_("{0} entered twice in Item Tax").format(d.item_tax_template)) frappe.throw(
_("{0} entered twice {1} in Item Taxes").format(
frappe.bold(d.item_tax_template),
"for tax category {0}".format(frappe.bold(d.tax_category)) if d.tax_category else "",
)
)
else: else:
check_list.append(d.item_tax_template) check_list.append((d.item_tax_template, d.tax_category))
def validate_barcode(self): def validate_barcode(self):
from stdnum import ean from stdnum import ean

View File

@@ -606,7 +606,9 @@ def _get_item_tax_template(args, taxes, out=None, for_validate=False):
taxes_with_no_validity.append(tax) taxes_with_no_validity.append(tax)
if taxes_with_validity: if taxes_with_validity:
taxes = sorted(taxes_with_validity, key=lambda i: i.valid_from, reverse=True) taxes = sorted(
taxes_with_validity, key=lambda i: i.valid_from or tax.maximum_net_rate, reverse=True
)
else: else:
taxes = taxes_with_no_validity taxes = taxes_with_no_validity