You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

168 lines
6.1 KiB

  1. # Author: Julien Coux
  2. # Copyright 2016 Camptocamp SA
  3. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
  4. from odoo import _, models
  5. class OpenItemsXslx(models.AbstractModel):
  6. _name = "report.a_f_r.report_open_items_xlsx"
  7. _inherit = "report.account_financial_report.abstract_report_xlsx"
  8. def _get_report_name(self, report, data=False):
  9. company_id = data.get("company_id", False)
  10. report_name = _("Open Items")
  11. if company_id:
  12. company = self.env["res.company"].browse(company_id)
  13. suffix = " - {} - {}".format(company.name, company.currency_id.name)
  14. report_name = report_name + suffix
  15. return report_name
  16. def _get_report_columns(self, report):
  17. res = {
  18. 0: {"header": _("Date"), "field": "date", "width": 11},
  19. 1: {"header": _("Entry"), "field": "move_id_name", "width": 18},
  20. 2: {"header": _("Journal"), "field": "journal", "width": 8},
  21. 3: {"header": _("Account"), "field": "account", "width": 9},
  22. 4: {"header": _("Partner"), "field": "partner", "width": 25},
  23. 5: {"header": _("Ref - Label"), "field": "ref", "width": 40},
  24. 6: {"header": _("Due date"), "field": "date_maturity", "width": 11},
  25. 7: {
  26. "header": _("Original"),
  27. "field": "original",
  28. "type": "amount",
  29. "width": 14,
  30. },
  31. 8: {
  32. "header": _("Residual"),
  33. "field": "amount_residual",
  34. "field_final_balance": "residual",
  35. "type": "amount",
  36. "width": 14,
  37. },
  38. }
  39. if report.foreign_currency:
  40. foreign_currency = {
  41. 9: {
  42. "header": _("Cur."),
  43. "field": "currency_name",
  44. "field_currency_balance": "currency_name",
  45. "type": "currency_name",
  46. "width": 7,
  47. },
  48. 10: {
  49. "header": _("Cur. Original"),
  50. "field": "amount_currency",
  51. "field_final_balance": "amount_currency",
  52. "type": "amount_currency",
  53. "width": 14,
  54. },
  55. 11: {
  56. "header": _("Cur. Residual"),
  57. "field": "amount_residual_currency",
  58. "field_final_balance": "amount_currency",
  59. "type": "amount_currency",
  60. "width": 14,
  61. },
  62. }
  63. res = {**res, **foreign_currency}
  64. return res
  65. def _get_report_filters(self, report):
  66. return [
  67. [_("Date at filter"), report.date_at.strftime("%d/%m/%Y")],
  68. [
  69. _("Target moves filter"),
  70. _("All posted entries")
  71. if report.target_move == "posted"
  72. else _("All entries"),
  73. ],
  74. [
  75. _("Account balance at 0 filter"),
  76. _("Hide") if report.hide_account_at_0 else _("Show"),
  77. ],
  78. [
  79. _("Show foreign currency"),
  80. _("Yes") if report.foreign_currency else _("No"),
  81. ],
  82. ]
  83. def _get_col_count_filter_name(self):
  84. return 2
  85. def _get_col_count_filter_value(self):
  86. return 2
  87. def _get_col_count_final_balance_name(self):
  88. return 5
  89. def _get_col_pos_final_balance_label(self):
  90. return 5
  91. def _generate_report_content(self, workbook, report, data):
  92. res_data = self.env[
  93. "report.account_financial_report.open_items"
  94. ]._get_report_values(report, data)
  95. # For each account
  96. Open_items = res_data["Open_Items"]
  97. accounts_data = res_data["accounts_data"]
  98. partners_data = res_data["partners_data"]
  99. total_amount = res_data["total_amount"]
  100. for account_id in Open_items.keys():
  101. # Write account title
  102. self.write_array_title(
  103. accounts_data[account_id]["code"]
  104. + " - "
  105. + accounts_data[account_id]["name"]
  106. )
  107. # For each partner
  108. if Open_items[account_id]:
  109. for partner_id in Open_items[account_id]:
  110. type_object = "partner"
  111. # Write partner title
  112. self.write_array_title(partners_data[partner_id]["name"])
  113. # Display array header for move lines
  114. self.write_array_header()
  115. # Display account move lines
  116. for line in Open_items[account_id][partner_id]:
  117. self.write_line_from_dict(line)
  118. # Display ending balance line for partner
  119. self.write_ending_balance_from_dict(
  120. partners_data[partner_id],
  121. type_object,
  122. total_amount,
  123. account_id,
  124. partner_id,
  125. )
  126. # Line break
  127. self.row_pos += 1
  128. # Display ending balance line for account
  129. type_object = "account"
  130. self.write_ending_balance_from_dict(
  131. accounts_data[account_id], type_object, total_amount, account_id
  132. )
  133. # 2 lines break
  134. self.row_pos += 2
  135. def write_ending_balance_from_dict(
  136. self, my_object, type_object, total_amount, account_id=False, partner_id=False
  137. ):
  138. """Specific function to write ending balance for Open Items"""
  139. if type_object == "partner":
  140. name = my_object["name"]
  141. my_object["residual"] = total_amount[account_id][partner_id]["residual"]
  142. label = _("Partner ending balance")
  143. elif type_object == "account":
  144. name = my_object["code"] + " - " + my_object["name"]
  145. my_object["residual"] = total_amount[account_id]["residual"]
  146. label = _("Ending balance")
  147. super(OpenItemsXslx, self).write_ending_balance_from_dict(
  148. my_object, name, label
  149. )