I added a new custom column in the balance sheet (e.g custom_balance and I want that column to show the value of cutom_balance in the account.move.line module)
Things that I already done are
1)Custom_balance column in the account.move.line (it's computed and stored field)
2)custom_balance column in balance sheet add and all the balance sheet lines in Assets and Liability for the custom_balance label with the same formula like balance but changed the custom_balance part.
like this:
balance | Aggregate Other Formulas | CA.balance + FA.balance + PNCA.balance |
custom_balance | Aggregate Other Formulas | CA.custom_balance + FA.custom_balance + PNCA.custom_balance |
Now the problem is the custom_balance is getting the same value as balance I have definited the definition of custom_ balance for balance sheet but I m missing something over there .
here is my xml code
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<record id="model_account_balance_sheet_report_handler" model="ir.model">
<field name="name">account.balance.sheet.report.handler</field>
<field name="model">account.balance.sheet.report.handler</field>
</record>
<record id="account_reports.balance_sheet" model="account.report">
<field name="custom_handler_model_id" ref="custom_account_move.model_account_balance_sheet_report_handler"/>
</record>
<!-- Custom Column -->
<record id="balance_sheet_custom_balance" model="account.report.column">
<field name="report_id" ref="account_reports.balance_sheet"/>
<field name="name">Exchange Balance</field>
<field name="expression_label">custom_balance</field>
<field name="figure_type">monetary</field>
</record>
<!-- Attach a custom expression to an existing line -->
<record id="custom_balance_assets_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_total_assets0"/>
<field name="label">custom_balance</field>
<field name="engine">aggregation</field>
<field name="formula">CA.custom_balance + FA.custom_balance + PNCA.custom_balance</field>
</record>
<record id="custom_balance_current_assets_expression_view0" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_current_assets_view0"/>
<field name="label">custom_balance</field>
<field name="engine">aggregation</field>
<field name="formula">BA.custom_balance + REC.custom_balance + CAS.custom_balance + PRE.custom_balance</field>
</record>
<record id="custom_balance_bank_cash_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_bank_view0"/>
<field name="label">custom_balance</field>
<field name="engine">domain</field>
<field name="formula">[('account_id.account_type', '=', 'asset_cash')]</field>
<field name="subformula">sum</field>
</record>
<record id="custom_balance_receivables_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_receivable0"/>
<field name="label">custom_balance</field>
<field name="engine">domain</field>
<field name="formula">[('account_id.account_type', '=', 'asset_receivable'), ('account_id.non_trade', '=', False)]</field>
<field name="subformula">sum</field>
</record>
<record id="custom_balance_current_assets_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_current_assets0"/>
<field name="label">custom_balance</field>
<field name="engine">domain</field>
<field name="formula">['|', ('account_id.account_type', '=', 'asset_current'), '&', ('account_id.account_type', '=', 'asset_receivable'), ('account_id.non_trade', '=', True)]</field>
<field name="subformula">sum</field>
</record>
<record id="custom_balance_prepayments_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_prepayements0"/>
<field name="label">custom_balance</field>
<field name="engine">domain</field>
<field name="formula">[('account_id.account_type', '=', 'asset_prepayments')]</field>
<field name="subformula">sum</field>
</record>
<record id="custom_balance_fixed_assets_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_fixed_assets_view0"/>
<field name="label">custom_balance</field>
<field name="engine">domain</field>
<field name="formula">[('account_id.account_type', '=', 'asset_fixed')]</field>
<field name="subformula">sum</field>
</record>
<record id="custom_balance_non_current_assets_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_non_current_assets_view0"/>
<field name="label">custom_balance</field>
<field name="engine">domain</field>
<field name="formula">[('account_id.account_type', '=', 'asset_non_current')]</field>
<field name="subformula">sum</field>
</record>
<record id="custom_balance_liabilities_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_liabilities_view0"/>
<field name="label">custom_balance</field>
<field name="engine">aggregation</field>
<field name="formula">CL.custom_balance + NL.custom_balance</field>
</record>
<record id="custom_balance_current_liabilities_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_current_liabilities0"/>
<field name="label">custom_balance</field>
<field name="engine">aggregation</field>
<field name="formula">CL1.custom_balance + CL2.custom_balance</field>
</record>
<record id="custom_balance_current_liabilities1_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_current_liabilities1"/>
<field name="label">custom_balance</field>
<field name="engine">domain</field>
<field name="formula" eval="['|', ('account_id.account_type', 'in', ('liability_current', 'liability_credit_card')), '&', ('account_id.account_type', '=', 'liability_payable'), ('account_id.non_trade', '=', True)]"/>
<field name="subformula">-sum</field>
</record>
<record id="custom_balance_current_liabilities_payable_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_current_liabilities_payable"/>
<field name="label">custom_balance</field>
<field name="engine">domain</field>
<field name="formula" eval="[('account_id.account_type', '=', 'liability_payable'), ('account_id.non_trade', '=', False)]"/>
<field name="subformula">-sum</field>
</record>
<record id="custom_balance_non_current_liabilities_expression" model="account.report.expression">
<field name="report_line_id" ref="account_reports.account_financial_report_non_current_liabilities0"/>
<field name="label">custom_balance</field>
<field name="engine">domain</field>
<field name="formula" eval="[('account_id.account_type', '=', 'liability_non_current')]"/>
<field name="subformula">-sum</field>
</record>
</odoo>
here is my pyton code:
from odoo import models
from odoo.tools import SQL
class BalanceSheetCustomHandler(models.AbstractModel):
_name = 'account.balance.sheet.report.handler'
_inherit = 'account.report.custom.handler'
_description = 'Balance Sheet Custom Handler'
def _get_expression_alias_mapping(self, report, options):
alias_map = super()._get_expression_alias_mapping(report, options)
alias_map['custom_balance'] = 'custom_balance'
return alias_map
def _get_custom_expression_field(self, report, expression_label):
if expression_label == 'custom_balance':
return 'custom_balance'
return super()._get_custom_expression_field(report, expression_label)
def _get_query_sums(self, report, options):
options_by_column_group = report._split_options_per_column_group(options)
queries = []
for column_group_key, options_group in options_by_column_group.items():
query = report._get_report_query(options_group, domain=[])
queries.append(SQL("""
SELECT
aml.account_id AS groupby,
'custom_balance' AS key,
%(column_group_key)s AS column_group_key,
SUM(aml.custom_debit - aml.custom_credit) AS value
FROM %(table_references)s
WHERE %(search_condition)s
GROUP BY aml.account_id
""",
column_group_key=column_group_key,
table_references=query.from_clause,
search_condition=query.where_clause))
return SQL(" UNION ALL ").join(queries)