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-02-26 10:36:04 +00:00
|
|
|
company_wise_order = {}
|
2023-03-05 12:48:33 +00:00
|
|
|
get_opening_entries = True
|
2023-02-26 10:36:04 +00:00
|
|
|
for pcv in frappe.db.get_all(
|
|
|
|
"Period Closing Voucher",
|
|
|
|
fields=["company", "posting_date", "name"],
|
|
|
|
filters={"docstatus": 1},
|
|
|
|
order_by="posting_date",
|
|
|
|
):
|
|
|
|
|
|
|
|
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-03-01 09:15:22 +00:00
|
|
|
gl_entries = pcv_doc.get_gl_entries()
|
2023-03-05 12:48:33 +00:00
|
|
|
closing_entries = pcv_doc.get_grouped_gl_entries(get_opening_entries=get_opening_entries)
|
|
|
|
make_closing_entries(gl_entries + closing_entries, voucher_name=pcv.name)
|
2023-02-26 10:36:04 +00:00
|
|
|
company_wise_order[pcv.company].append(pcv.posting_date)
|
2023-03-05 12:48:33 +00:00
|
|
|
get_opening_entries = False
|