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.

115 lines
4.9 KiB

  1. # -*- encoding: utf-8 -*-
  2. ##############################################################################
  3. #
  4. # Author: Guewen Baconnier
  5. # Copyright Camptocamp SA 2011
  6. #
  7. # This program is free software: you can redistribute it and/or modify
  8. # it under the terms of the GNU Affero General Public License as
  9. # published by the Free Software Foundation, either version 3 of the
  10. # License, or (at your option) any later version.
  11. #
  12. # This program is distributed in the hope that it will be useful,
  13. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. # GNU Affero General Public License for more details.
  16. #
  17. # You should have received a copy of the GNU Affero General Public License
  18. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  19. #
  20. ##############################################################################
  21. import pooler
  22. from report import report_sxw
  23. from tools.translate import _
  24. from datetime import datetime
  25. from common_balance_reports import CommonBalanceReportHeaderWebkit
  26. from webkit_parser_header_fix import HeaderFooterTextWebKitParser
  27. class ProfitLossWebkit(report_sxw.rml_parse, CommonBalanceReportHeaderWebkit):
  28. def __init__(self, cursor, uid, name, context):
  29. super(ProfitLossWebkit, self).__init__(cursor, uid, name, context=context)
  30. self.pool = pooler.get_pool(self.cr.dbname)
  31. self.cursor = self.cr
  32. company = self.pool.get('res.users').browse(self.cr, uid, uid, context=context).company_id
  33. header_report_name = ' - '.join((_('PROFIT AND LOSS'), company.name, company.currency_id.name))
  34. footer_date_time = self.formatLang(str(datetime.today()), date_time=True)
  35. self.localcontext.update({
  36. 'cr': cursor,
  37. 'uid': uid,
  38. 'report_name': _('Profit and Loss'),
  39. 'display_account': self._get_display_account,
  40. 'display_account_raw': self._get_display_account_raw,
  41. 'filter_form': self._get_filter,
  42. 'target_move': self._get_target_move,
  43. 'display_target_move': self._get_display_target_move,
  44. 'accounts': self._get_accounts_br,
  45. 'numbers_display': self._get_numbers_display,
  46. 'level_print': self._get_level_print,
  47. 'level_bold': self._get_level_bold,
  48. 'level_italic': self._get_level_italic,
  49. 'level_size': self._get_level_size,
  50. 'level_underline': self._get_level_underline,
  51. 'level_uppercase': self._get_level_uppercase,
  52. 'additional_args': [
  53. ('--header-font-name', 'Helvetica'),
  54. ('--footer-font-name', 'Helvetica'),
  55. ('--header-font-size', '10'),
  56. ('--footer-font-size', '6'),
  57. ('--header-left', header_report_name),
  58. ('--header-spacing', '2'),
  59. ('--footer-left', footer_date_time),
  60. ('--footer-right', ' '.join((_('Page'), '[page]', _('of'), '[topage]'))),
  61. ('--footer-line',),
  62. ],
  63. })
  64. def _get_level_print(self, data, level):
  65. return self._get_form_param("level%s_print" % (level,), data)
  66. def _get_level_bold(self, data, level):
  67. return self._get_form_param("level%s_bold" % (level,), data)
  68. def _get_level_italic(self, data, level):
  69. return self._get_form_param("level%s_italic" % (level,), data)
  70. def _get_level_size(self, data, level):
  71. return self._get_form_param("level%s_size" % (level,), data)
  72. def _get_level_underline(self, data, level):
  73. return self._get_form_param("level%s_underline" % (level,), data)
  74. def _get_level_uppercase(self, data, level):
  75. return self._get_form_param("level%s_uppercase" % (level,), data)
  76. def _update_levels(self, objects):
  77. # start leveling from 0
  78. levels = [account['current']['level'] for account in objects]
  79. min_level = min(levels)
  80. for account in objects:
  81. account['current']['level'] -= min_level
  82. return objects
  83. def set_context(self, objects, data, ids, report_type=None):
  84. """Populate a ledger_lines attribute on each browse record that will be used
  85. by mako template"""
  86. objects, new_ids, context_report_values = self.compute_balance_data(data, filter_report_type=['expense', 'income'])
  87. objects = self._update_levels(objects)
  88. self.localcontext.update(context_report_values)
  89. return super(ProfitLossWebkit, self).set_context(objects, data, new_ids,
  90. report_type=report_type)
  91. HeaderFooterTextWebKitParser('report.account.account_report_profit_loss_webkit',
  92. 'account.account',
  93. 'addons/account_financial_report_webkit/report/templates/account_report_profit_loss.mako',
  94. parser=ProfitLossWebkit)