Merge pull request #45351 from frappe/mergify/bp/version-14-hotfix/pr-44808

feat: Added difference_posting_date field in Sales Invoice Advance and Purchase Invoice Advance (backport #44808)
This commit is contained in:
ruthra kumar
2025-01-21 14:48:27 +05:30
committed by GitHub
4 changed files with 45 additions and 26 deletions

View File

@@ -14,7 +14,8 @@
"advance_amount", "advance_amount",
"allocated_amount", "allocated_amount",
"exchange_gain_loss", "exchange_gain_loss",
"ref_exchange_rate" "ref_exchange_rate",
"difference_posting_date"
], ],
"fields": [ "fields": [
{ {
@@ -30,7 +31,7 @@
"width": "180px" "width": "180px"
}, },
{ {
"columns": 3, "columns": 2,
"fieldname": "reference_name", "fieldname": "reference_name",
"fieldtype": "Dynamic Link", "fieldtype": "Dynamic Link",
"in_list_view": 1, "in_list_view": 1,
@@ -40,7 +41,7 @@
"read_only": 1 "read_only": 1
}, },
{ {
"columns": 3, "columns": 2,
"fieldname": "remarks", "fieldname": "remarks",
"fieldtype": "Text", "fieldtype": "Text",
"in_list_view": 1, "in_list_view": 1,
@@ -111,13 +112,20 @@
"label": "Reference Exchange Rate", "label": "Reference Exchange Rate",
"non_negative": 1, "non_negative": 1,
"read_only": 1 "read_only": 1
},
{
"columns": 2,
"fieldname": "difference_posting_date",
"fieldtype": "Date",
"in_list_view": 1,
"label": "Difference Posting Date"
} }
], ],
"idx": 1, "idx": 1,
"index_web_pages_for_search": 1, "index_web_pages_for_search": 1,
"istable": 1, "istable": 1,
"links": [], "links": [],
"modified": "2021-09-26 15:47:28.167371", "modified": "2024-12-20 12:04:46.729972",
"modified_by": "Administrator", "modified_by": "Administrator",
"module": "Accounts", "module": "Accounts",
"name": "Purchase Invoice Advance", "name": "Purchase Invoice Advance",

View File

@@ -14,7 +14,8 @@
"advance_amount", "advance_amount",
"allocated_amount", "allocated_amount",
"exchange_gain_loss", "exchange_gain_loss",
"ref_exchange_rate" "ref_exchange_rate",
"difference_posting_date"
], ],
"fields": [ "fields": [
{ {
@@ -30,7 +31,7 @@
"width": "250px" "width": "250px"
}, },
{ {
"columns": 3, "columns": 2,
"fieldname": "reference_name", "fieldname": "reference_name",
"fieldtype": "Dynamic Link", "fieldtype": "Dynamic Link",
"in_list_view": 1, "in_list_view": 1,
@@ -41,7 +42,7 @@
"read_only": 1 "read_only": 1
}, },
{ {
"columns": 3, "columns": 2,
"fieldname": "remarks", "fieldname": "remarks",
"fieldtype": "Text", "fieldtype": "Text",
"in_list_view": 1, "in_list_view": 1,
@@ -112,13 +113,20 @@
"label": "Reference Exchange Rate", "label": "Reference Exchange Rate",
"non_negative": 1, "non_negative": 1,
"read_only": 1 "read_only": 1
},
{
"columns": 2,
"fieldname": "difference_posting_date",
"fieldtype": "Date",
"in_list_view": 1,
"label": "Difference Posting Date"
} }
], ],
"idx": 1, "idx": 1,
"index_web_pages_for_search": 1, "index_web_pages_for_search": 1,
"istable": 1, "istable": 1,
"links": [], "links": [],
"modified": "2021-09-26 15:47:46.911595", "modified": "2024-12-20 11:58:28.962370",
"modified_by": "Administrator", "modified_by": "Administrator",
"module": "Accounts", "module": "Accounts",
"name": "Sales Invoice Advance", "name": "Sales Invoice Advance",

View File

@@ -346,13 +346,14 @@ class AccountsController(TransactionBase):
== 1 == 1
) )
).run() ).run()
frappe.db.sql( gle = frappe.qb.DocType("GL Entry")
"delete from `tabGL Entry` where voucher_type=%s and voucher_no=%s", (self.doctype, self.name) frappe.qb.from_(gle).delete().where(
) (gle.voucher_type == self.doctype) & (gle.voucher_no == self.name)
frappe.db.sql( ).run()
"delete from `tabStock Ledger Entry` where voucher_type=%s and voucher_no=%s", sle = frappe.qb.DocType("Stock Ledger Entry")
(self.doctype, self.name), frappe.qb.from_(sle).delete().where(
) (sle.voucher_type == self.doctype) & (sle.voucher_no == self.name)
).run()
def validate_return_against_account(self): def validate_return_against_account(self):
if self.doctype in ["Sales Invoice", "Purchase Invoice"] and self.is_return and self.return_against: if self.doctype in ["Sales Invoice", "Purchase Invoice"] and self.is_return and self.return_against:
@@ -1027,11 +1028,12 @@ class AccountsController(TransactionBase):
def clear_unallocated_advances(self, childtype, parentfield): def clear_unallocated_advances(self, childtype, parentfield):
self.set(parentfield, self.get(parentfield, {"allocated_amount": ["not in", [0, None, ""]]})) self.set(parentfield, self.get(parentfield, {"allocated_amount": ["not in", [0, None, ""]]}))
frappe.db.sql( doctype = frappe.qb.DocType(childtype)
"""delete from `tab{}` where parentfield={} and parent = {} frappe.qb.from_(doctype).delete().where(
and allocated_amount = 0""".format(childtype, "%s", "%s"), (doctype.parentfield == parentfield)
(parentfield, self.name), & (doctype.parent == self.name)
) & (doctype.allocated_amount == 0)
).run()
@frappe.whitelist() @frappe.whitelist()
def apply_shipping_rule(self): def apply_shipping_rule(self):
@@ -1082,6 +1084,7 @@ class AccountsController(TransactionBase):
"advance_amount": flt(d.amount), "advance_amount": flt(d.amount),
"allocated_amount": allocated_amount, "allocated_amount": allocated_amount,
"ref_exchange_rate": flt(d.exchange_rate), # exchange_rate of advance entry "ref_exchange_rate": flt(d.exchange_rate), # exchange_rate of advance entry
"difference_posting_date": self.posting_date,
} }
self.append("advances", advance_row) self.append("advances", advance_row)
@@ -1332,7 +1335,6 @@ class AccountsController(TransactionBase):
gain_loss_account = frappe.get_cached_value( gain_loss_account = frappe.get_cached_value(
"Company", self.company, "exchange_gain_loss_account" "Company", self.company, "exchange_gain_loss_account"
) )
je = create_gain_loss_journal( je = create_gain_loss_journal(
self.company, self.company,
args.get("difference_posting_date") if args else self.posting_date, args.get("difference_posting_date") if args else self.posting_date,
@@ -1445,6 +1447,7 @@ class AccountsController(TransactionBase):
"Company", self.company, "exchange_gain_loss_account" "Company", self.company, "exchange_gain_loss_account"
), ),
"exchange_gain_loss": flt(d.get("exchange_gain_loss")), "exchange_gain_loss": flt(d.get("exchange_gain_loss")),
"difference_posting_date": d.get("difference_posting_date"),
} }
) )
lst.append(args) lst.append(args)
@@ -1971,11 +1974,9 @@ class AccountsController(TransactionBase):
for adv in self.advances: for adv in self.advances:
consider_for_total_advance = True consider_for_total_advance = True
if adv.reference_name == linked_doc_name: if adv.reference_name == linked_doc_name:
frappe.db.sql( doctype = frappe.qb.DocType(self.doctype + " Advance")
f"""delete from `tab{self.doctype} Advance` frappe.qb.from_(doctype).delete().where(doctype.name == adv.name).run()
where name = %s""",
adv.name,
)
consider_for_total_advance = False consider_for_total_advance = False
if consider_for_total_advance: if consider_for_total_advance:

View File

@@ -2,6 +2,8 @@
# For license information, please see license.txt # For license information, please see license.txt
from datetime import datetime
import frappe import frappe
from frappe import qb from frappe import qb
from frappe.query_builder.functions import Sum from frappe.query_builder.functions import Sum