2023-02-23 11:16:37 +00:00
|
|
|
# Copyright (c) 2023, Frappe Technologies Pvt. Ltd. and Contributors
|
|
|
|
# License: MIT. See LICENSE
|
|
|
|
|
|
|
|
|
2023-02-26 10:36:04 +00:00
|
|
|
import frappe
|
|
|
|
|
2023-03-13 15:21:35 +00:00
|
|
|
from erpnext.accounts.doctype.account_closing_balance.account_closing_balance import (
|
|
|
|
make_closing_entries,
|
|
|
|
)
|
2023-02-26 10:36:04 +00:00
|
|
|
from erpnext.accounts.utils import get_fiscal_year
|
2023-02-23 11:16:37 +00:00
|
|
|
|
|
|
|
|
|
|
|
def execute():
|
2023-05-05 12:24:34 +00:00
|
|
|
frappe.db.truncate("Account Closing Balance")
|
|
|
|
|
2023-07-14 04:58:36 +00:00
|
|
|
for company in frappe.get_all("Company", pluck="name"):
|
|
|
|
i = 0
|
|
|
|
company_wise_order = {}
|
|
|
|
for pcv in frappe.db.get_all(
|
|
|
|
"Period Closing Voucher",
|
|
|
|
fields=["company", "posting_date", "name"],
|
|
|
|
filters={"docstatus": 1, "company": company},
|
|
|
|
order_by="posting_date",
|
|
|
|
):
|
2023-02-26 10:36:04 +00:00
|
|
|
|
2023-07-14 04:58:36 +00:00
|
|
|
company_wise_order.setdefault(pcv.company, [])
|
|
|
|
if pcv.posting_date not in company_wise_order[pcv.company]:
|
|
|
|
pcv_doc = frappe.get_doc("Period Closing Voucher", pcv.name)
|
|
|
|
pcv_doc.year_start_date = get_fiscal_year(
|
|
|
|
pcv.posting_date, pcv.fiscal_year, company=pcv.company
|
|
|
|
)[1]
|
2023-05-01 05:26:46 +00:00
|
|
|
|
2023-07-14 04:58:36 +00:00
|
|
|
# get gl entries against pcv
|
|
|
|
gl_entries = frappe.db.get_all(
|
|
|
|
"GL Entry", filters={"voucher_no": pcv.name, "is_cancelled": 0}, fields=["*"]
|
|
|
|
)
|
|
|
|
for entry in gl_entries:
|
|
|
|
entry["is_period_closing_voucher_entry"] = 1
|
|
|
|
entry["closing_date"] = pcv_doc.posting_date
|
|
|
|
entry["period_closing_voucher"] = pcv_doc.name
|
2023-05-01 05:26:46 +00:00
|
|
|
|
2023-07-14 04:58:36 +00:00
|
|
|
closing_entries = []
|
2023-05-05 12:24:34 +00:00
|
|
|
|
2023-07-14 04:58:36 +00:00
|
|
|
if pcv.posting_date not in company_wise_order[pcv.company]:
|
|
|
|
# get all gl entries for the year
|
|
|
|
closing_entries = frappe.db.get_all(
|
|
|
|
"GL Entry",
|
|
|
|
filters={
|
|
|
|
"is_cancelled": 0,
|
|
|
|
"voucher_no": ["!=", pcv.name],
|
|
|
|
"posting_date": ["between", [pcv_doc.year_start_date, pcv.posting_date]],
|
|
|
|
"is_opening": "No",
|
2023-07-14 10:26:59 +00:00
|
|
|
"company": company,
|
2023-07-14 04:58:36 +00:00
|
|
|
},
|
|
|
|
fields=["*"],
|
|
|
|
)
|
2023-05-17 16:35:46 +00:00
|
|
|
|
2023-07-14 04:58:36 +00:00
|
|
|
if i == 0:
|
|
|
|
# add opening entries only for the first pcv
|
|
|
|
closing_entries += frappe.db.get_all(
|
|
|
|
"GL Entry",
|
2023-07-14 10:26:59 +00:00
|
|
|
filters={"is_cancelled": 0, "is_opening": "Yes", "company": company},
|
2023-07-14 04:58:36 +00:00
|
|
|
fields=["*"],
|
|
|
|
)
|
2023-05-05 12:24:34 +00:00
|
|
|
|
2023-07-14 04:58:36 +00:00
|
|
|
for entry in closing_entries:
|
|
|
|
entry["closing_date"] = pcv_doc.posting_date
|
|
|
|
entry["period_closing_voucher"] = pcv_doc.name
|
2023-07-13 10:40:05 +00:00
|
|
|
|
2023-07-14 04:58:36 +00:00
|
|
|
entries = gl_entries + closing_entries
|
2023-05-17 16:35:46 +00:00
|
|
|
|
2023-07-18 09:46:52 +00:00
|
|
|
make_closing_entries(entries, pcv.name, pcv.company, pcv.posting_date)
|
|
|
|
company_wise_order[pcv.company].append(pcv.posting_date)
|
|
|
|
i += 1
|