summaryrefslogtreecommitdiff
path: root/addons/l10n_in/report/account_invoice_report.py
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/l10n_in/report/account_invoice_report.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/l10n_in/report/account_invoice_report.py')
-rw-r--r--addons/l10n_in/report/account_invoice_report.py325
1 files changed, 325 insertions, 0 deletions
diff --git a/addons/l10n_in/report/account_invoice_report.py b/addons/l10n_in/report/account_invoice_report.py
new file mode 100644
index 00000000..59a86695
--- /dev/null
+++ b/addons/l10n_in/report/account_invoice_report.py
@@ -0,0 +1,325 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo import api, fields, models, tools
+
+
+class L10nInAccountInvoiceReport(models.Model):
+ _name = "l10n_in.account.invoice.report"
+ _description = "Account Invoice Statistics"
+ _auto = False
+ _order = 'date desc'
+
+ account_move_id = fields.Many2one('account.move', string="Account Move")
+ company_id = fields.Many2one('res.company', string="Company")
+ date = fields.Date(string="Accounting Date")
+ name = fields.Char(string="Invoice Number")
+ partner_id = fields.Many2one('res.partner', string="Customer")
+ is_reverse_charge = fields.Char("Reverse Charge")
+ l10n_in_gst_treatment = fields.Selection([
+ ('regular', 'Registered Business - Regular'),
+ ('composition', 'Registered Business - Composition'),
+ ('unregistered', 'Unregistered Business'),
+ ('consumer', 'Consumer'),
+ ('overseas', 'Overseas'),
+ ('special_economic_zone', 'Special Economic Zone'),
+ ('deemed_export', 'Deemed Export'),
+ ], string="GST Treatment")
+ journal_id = fields.Many2one('account.journal', string="Journal")
+ state = fields.Selection([('draft', 'Unposted'), ('posted', 'Posted')], string='Status')
+ igst_amount = fields.Float(string="IGST Amount")
+ cgst_amount = fields.Float(string="CGST Amount")
+ sgst_amount = fields.Float(string="SGST Amount")
+ cess_amount = fields.Float(string="Cess Amount")
+ price_total = fields.Float(string='Total Without Tax')
+ total = fields.Float(string="Invoice Total")
+ reversed_entry_id = fields.Many2one('account.move', string="Refund Invoice", help="From where this Refund is created")
+ shipping_bill_number = fields.Char(string="Shipping Bill Number")
+ shipping_bill_date = fields.Date(string="Shipping Bill Date")
+ shipping_port_code_id = fields.Many2one('l10n_in.port.code', string='Shipping port code')
+ ecommerce_partner_id = fields.Many2one('res.partner', string="E-commerce")
+ move_type = fields.Selection(selection=[
+ ('entry', 'Journal Entry'),
+ ('out_invoice', 'Customer Invoice'),
+ ('out_refund', 'Customer Credit Note'),
+ ('in_invoice', 'Vendor Bill'),
+ ('in_refund', 'Vendor Credit Note'),
+ ('out_receipt', 'Sales Receipt'),
+ ('in_receipt', 'Purchase Receipt')])
+ partner_vat = fields.Char(string="Customer GSTIN")
+ ecommerce_vat = fields.Char(string="E-commerce GSTIN")
+ tax_rate = fields.Float(string="Rate")
+ place_of_supply = fields.Char(string="Place of Supply")
+ is_pre_gst = fields.Char(string="Is Pre GST")
+ is_ecommerce = fields.Char(string="Is E-commerce")
+ b2cl_is_ecommerce = fields.Char(string="B2CL Is E-commerce")
+ b2cs_is_ecommerce = fields.Char(string="B2CS Is E-commerce")
+ supply_type = fields.Char(string="Supply Type")
+ export_type = fields.Char(string="Export Type") # String from GSTR column.
+ refund_export_type = fields.Char(string="UR Type") # String from GSTR column.
+ b2b_type = fields.Char(string="B2B Invoice Type")
+ refund_invoice_type = fields.Char(string="Document Type")
+ gst_format_date = fields.Char(string="Formated Date")
+ gst_format_refund_date = fields.Char(string="Formated Refund Date")
+ gst_format_shipping_bill_date = fields.Char(string="Formated Shipping Bill Date")
+ tax_id = fields.Many2one('account.tax', string="Tax")
+
+ def _select(self):
+ select_str = """
+ SELECT min(sub.id) as id,
+ sub.move_id,
+ sub.account_move_id,
+ sub.name,
+ sub.state,
+ sub.partner_id,
+ sub.date,
+ sub.l10n_in_gst_treatment,
+ sub.ecommerce_partner_id,
+ sub.shipping_bill_number,
+ sub.shipping_bill_date,
+ sub.shipping_port_code_id,
+ sub.total * sub.b2cs_refund_sign as total,
+ sub.journal_id,
+ sub.company_id,
+ sub.move_type,
+ sub.reversed_entry_id,
+ sub.partner_vat,
+ sub.ecommerce_vat,
+ sub.tax_rate as tax_rate,
+ (CASE WHEN count(sub.is_reverse_charge) > 0
+ THEN 'Y'
+ ELSE 'N'
+ END) AS is_reverse_charge,
+ sub.place_of_supply,
+ sub.is_pre_gst,
+ sub.is_ecommerce,
+ sub.b2cl_is_ecommerce,
+ sub.b2cs_is_ecommerce,
+ sub.supply_type,
+ sub.export_type,
+ sub.refund_export_type,
+ sub.b2b_type,
+ sub.refund_invoice_type,
+ sub.gst_format_date,
+ sub.gst_format_refund_date,
+ sub.gst_format_shipping_bill_date,
+ sum(sub.igst_amount) * sub.amount_sign * sub.b2cs_refund_sign AS igst_amount,
+ sum(sub.cgst_amount) * sub.amount_sign * sub.b2cs_refund_sign AS cgst_amount,
+ sum(sub.sgst_amount) * sub.amount_sign * sub.b2cs_refund_sign AS sgst_amount,
+ avg(sub.cess_amount) * sub.amount_sign * sub.b2cs_refund_sign AS cess_amount,
+ sum(sub.price_total) * sub.amount_sign * sub.b2cs_refund_sign AS price_total,
+ sub.tax_id
+ """
+ return select_str
+
+ def _sub_select(self):
+ sub_select_str = """
+ SELECT aml.id AS id,
+ aml.move_id,
+ aml.partner_id,
+ am.id AS account_move_id,
+ am.name,
+ am.state,
+ am.date,
+ am.l10n_in_gst_treatment AS l10n_in_gst_treatment,
+ am.l10n_in_reseller_partner_id AS ecommerce_partner_id,
+ am.l10n_in_shipping_bill_number AS shipping_bill_number,
+ am.l10n_in_shipping_bill_date AS shipping_bill_date,
+ am.l10n_in_shipping_port_code_id AS shipping_port_code_id,
+ ABS(am.amount_total_signed) AS total,
+ am.journal_id,
+ aj.company_id,
+ am.move_type AS move_type,
+ am.reversed_entry_id AS reversed_entry_id,
+ am.l10n_in_gstin AS partner_vat,
+ CASE WHEN rp.vat IS NULL THEN '' ELSE rp.vat END AS ecommerce_vat,
+ (CASE WHEN at.l10n_in_reverse_charge = True
+ THEN True
+ ELSE NULL
+ END) AS is_reverse_charge,
+ (CASE WHEN ps.l10n_in_tin IS NOT NULL
+ THEN concat(ps.l10n_in_tin,'-',ps.name)
+ WHEN ps.id IS NULL and cps.l10n_in_tin IS NOT NULL
+ THEN concat(cps.l10n_in_tin,'-',cps.name)
+ ELSE ''
+ END) AS place_of_supply,
+ (CASE WHEN am.move_type in ('out_refund', 'in_refund') and refund_am.date <= to_date('2017-07-01', 'YYYY-MM-DD')
+ THEN 'Y'
+ ELSE 'N'
+ END) as is_pre_gst,
+
+ (CASE WHEN am.l10n_in_reseller_partner_id IS NOT NULL
+ THEN 'Y'
+ ELSE 'N'
+ END) as is_ecommerce,
+ (CASE WHEN am.l10n_in_reseller_partner_id IS NOT NULL
+ THEN 'Y'
+ ELSE 'N'
+ END) as b2cl_is_ecommerce,
+ (CASE WHEN am.l10n_in_reseller_partner_id IS NOT NULL
+ THEN 'E'
+ ELSE 'OE'
+ END) as b2cs_is_ecommerce,
+ (CASE WHEN am.l10n_in_state_id = cp.state_id or p.id IS NULL
+ THEN 'Intra State'
+ WHEN am.l10n_in_state_id != cp.state_id and p.id IS NOT NULL
+ THEN 'Inter State'
+ END) AS supply_type,
+ (CASE WHEN am.l10n_in_gst_treatment in ('deemed_export', 'overseas') and am.amount_tax > 0.00
+ THEN 'EXPWP'
+ WHEN am.l10n_in_gst_treatment in ('deemed_export', 'overseas') and am.amount_tax <= 0.00
+ THEN 'EXPWOP'
+ ELSE ''
+ END) AS export_type,
+ (CASE WHEN am.l10n_in_gst_treatment in ('deemed_export', 'overseas') and am.amount_tax > 0.00
+ THEN 'EXPWP'
+ WHEN am.l10n_in_gst_treatment in ('deemed_export', 'overseas') and am.amount_tax <= 0.00
+ THEN 'EXPWOP'
+ ELSE 'B2CL'
+ END) AS refund_export_type,
+ (CASE WHEN am.l10n_in_gst_treatment = 'regular'
+ THEN 'Regular'
+ WHEN am.l10n_in_gst_treatment = 'deemed_export'
+ THEN 'Deemed'
+ WHEN am.l10n_in_gst_treatment = 'overseas' and am.amount_tax > 0.00
+ THEN 'Export with IGST'
+ WHEN am.l10n_in_gst_treatment = 'special_economic_zone' and am.amount_tax > 0.00
+ THEN 'SEZ with IGST payment'
+ WHEN am.l10n_in_gst_treatment = 'special_economic_zone' and am.amount_tax <= 0.00
+ THEN 'SEZ without IGST payment'
+ END) AS b2b_type,
+ (CASE WHEN am.move_type = 'out_refund'
+ THEN 'C'
+ WHEN am.move_type = 'in_refund'
+ THEN 'D'
+ ELSE ''
+ END) as refund_invoice_type,
+ (CASE WHEN am.date IS NOT NULL
+ THEN TO_CHAR(am.date, 'DD-MON-YYYY')
+ ELSE ''
+ END) as gst_format_date,
+ (CASE WHEN refund_am.date IS NOT NULL
+ THEN TO_CHAR(refund_am.date, 'DD-MON-YYYY')
+ ELSE ''
+ END) as gst_format_refund_date,
+ (CASE WHEN am.l10n_in_shipping_bill_date IS NOT NULL
+ THEN TO_CHAR(am.l10n_in_shipping_bill_date, 'DD-MON-YYYY')
+ ELSE ''
+ END) as gst_format_shipping_bill_date,
+ CASE WHEN tag_rep_ln.account_tax_report_line_id IN
+ (SELECT res_id FROM ir_model_data WHERE module='l10n_in' AND name in ('tax_report_line_igst', 'tax_report_line_igst_rc'))
+ THEN aml.balance
+ ELSE 0
+ END AS igst_amount,
+ CASE WHEN tag_rep_ln.account_tax_report_line_id IN
+ (SELECT res_id FROM ir_model_data WHERE module='l10n_in' AND name in ('tax_report_line_cgst', 'tax_report_line_cgst_rc'))
+ THEN aml.balance
+ ELSE 0
+ END AS cgst_amount,
+ CASE WHEN tag_rep_ln.account_tax_report_line_id IN
+ (SELECT res_id FROM ir_model_data WHERE module='l10n_in' AND name in ('tax_report_line_sgst', 'tax_report_line_sgst_rc'))
+ THEN aml.balance
+ ELSE 0
+ END AS sgst_amount,
+ (SELECT sum(temp_aml.balance) from account_move_line temp_aml
+ JOIN account_account_tag_account_move_line_rel aat_aml_rel_temp ON aat_aml_rel_temp.account_move_line_id = temp_aml.id
+ JOIN account_account_tag aat_temp ON aat_temp.id = aat_aml_rel_temp.account_account_tag_id
+ JOIN account_tax_report_line_tags_rel tag_rep_ln_temp ON aat_temp.id = tag_rep_ln_temp.account_account_tag_id
+ where temp_aml.move_id = aml.move_id and temp_aml.product_id = aml.product_id
+ and tag_rep_ln_temp.account_tax_report_line_id IN (SELECT res_id FROM ir_model_data WHERE module='l10n_in' AND name in ('tax_report_line_cess', 'tax_report_line_cess_rc'))
+ ) AS cess_amount,
+ CASE WHEN tag_rep_ln.account_tax_report_line_id IN
+ (SELECT res_id FROM ir_model_data WHERE module='l10n_in' AND name in ('tax_report_line_sgst', 'tax_report_line_sgst_rc'))
+ THEN NULL
+ ELSE (CASE WHEN aml.tax_base_amount <> 0 THEN aml.tax_base_amount * (CASE WHEN aml.balance < 0 THEN -1 ELSE 1 END) ELSE NULL END)
+ END AS price_total,
+ (CASE WHEN (aj.type = 'sale' AND am.move_type != 'out_refund') or (aj.type = 'purchase' AND at.l10n_in_reverse_charge AND am.move_type != 'in_refund') THEN -1 ELSE 1 END) AS amount_sign,
+ (CASE WHEN am.move_type in ('in_refund','out_refund')
+ AND p.vat IS NULL
+ AND am.l10n_in_gst_treatment != 'overseas'
+ AND (ABS(am.amount_total_signed) <= 250000 OR
+ (ps.id = cp.state_id OR p.id IS NULL))
+ THEN -1
+ ELSE 1 END) AS b2cs_refund_sign,
+ (CASE WHEN atr.parent_tax IS NOT NULL THEN atr.parent_tax
+ ELSE at.id END) AS tax_id,
+ (CASE WHEN atr.parent_tax IS NOT NULL THEN parent_at.amount
+ ELSE at.amount END) AS tax_rate
+ """
+ return sub_select_str
+
+ def _from(self):
+ from_str = """
+ FROM account_move_line aml
+ JOIN account_move am ON am.id = aml.move_id
+ JOIN account_journal aj ON aj.id = am.journal_id
+ JOIN res_company c ON c.id = aj.company_id
+ LEFT JOIN account_tax at ON at.id = aml.tax_line_id
+ JOIN account_account_tag_account_move_line_rel aat_aml_rel ON aat_aml_rel.account_move_line_id = aml.id
+ JOIN account_account_tag aat ON aat.id = aat_aml_rel.account_account_tag_id
+ JOIN account_tax_report_line_tags_rel tag_rep_ln ON aat.id = tag_rep_ln.account_account_tag_id
+ LEFT JOIN res_partner cp ON cp.id = COALESCE(aj.l10n_in_gstin_partner_id, c.partner_id)
+ LEFT JOIN res_country_state cps ON cps.id = cp.state_id
+ LEFT JOIN account_move refund_am ON refund_am.id = am.reversed_entry_id
+ LEFT JOIN res_partner p ON p.id = aml.partner_id
+ LEFT JOIN res_country_state ps ON ps.id = am.l10n_in_state_id
+ LEFT JOIN res_partner rp ON rp.id = am.l10n_in_reseller_partner_id
+ LEFT JOIN account_tax_filiation_rel atr ON atr.child_tax = at.id
+ LEFT JOIN account_tax parent_at ON parent_at.id = atr.parent_tax
+ """
+ return from_str
+
+ def _where(self):
+ return """
+ WHERE am.state = 'posted'
+ AND tag_rep_ln.account_tax_report_line_id in (SELECT res_id FROM ir_model_data WHERE module='l10n_in' AND name in ('tax_report_line_igst', 'tax_report_line_cgst', 'tax_report_line_sgst', 'tax_report_line_zero_rated', 'tax_report_line_igst_rc', 'tax_report_line_cgst_rc', 'tax_report_line_sgst_rc'))
+ """
+
+ def _group_by(self):
+ group_by_str = """
+ GROUP BY sub.move_id,
+ sub.account_move_id,
+ sub.name,
+ sub.state,
+ sub.partner_id,
+ sub.date,
+ sub.l10n_in_gst_treatment,
+ sub.ecommerce_partner_id,
+ sub.shipping_bill_number,
+ sub.shipping_bill_date,
+ sub.shipping_port_code_id,
+ sub.total,
+ sub.journal_id,
+ sub.company_id,
+ sub.move_type,
+ sub.reversed_entry_id,
+ sub.partner_vat,
+ sub.ecommerce_vat,
+ sub.place_of_supply,
+ sub.is_pre_gst,
+ sub.is_ecommerce,
+ sub.b2cl_is_ecommerce,
+ sub.b2cs_is_ecommerce,
+ sub.supply_type,
+ sub.export_type,
+ sub.refund_export_type,
+ sub.b2b_type,
+ sub.refund_invoice_type,
+ sub.gst_format_date,
+ sub.gst_format_refund_date,
+ sub.gst_format_shipping_bill_date,
+ sub.amount_sign,
+ sub.tax_id,
+ sub.tax_rate,
+ sub.b2cs_refund_sign
+ """
+ return group_by_str
+
+ def init(self):
+ tools.drop_view_if_exists(self.env.cr, self._table)
+ self.env.cr.execute("""CREATE or REPLACE VIEW %s AS (
+ %s
+ FROM (
+ %s %s %s
+ ) AS sub %s)""" % (self._table, self._select(), self._sub_select(),
+ self._from(), self._where(), self._group_by()))