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.

93 lines
3.7 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. from datetime import datetime
  22. from openerp import pooler
  23. from openerp.report import report_sxw
  24. from openerp.tools.translate import _
  25. from .common_balance_reports import CommonBalanceReportHeaderWebkit
  26. from .webkit_parser_header_fix import HeaderFooterTextWebKitParser
  27. def sign(number):
  28. return cmp(number, 0)
  29. class TrialBalanceWebkit(report_sxw.rml_parse,
  30. CommonBalanceReportHeaderWebkit):
  31. def __init__(self, cursor, uid, name, context):
  32. super(TrialBalanceWebkit, self).__init__(cursor, uid, name,
  33. context=context)
  34. self.pool = pooler.get_pool(self.cr.dbname)
  35. self.cursor = self.cr
  36. company = self.pool.get('res.users').browse(self.cr, uid, uid,
  37. context=context).company_id
  38. header_report_name = ' - '.join((_('TRIAL BALANCE'), company.name,
  39. company.currency_id.name))
  40. footer_date_time = self.formatLang(str(datetime.today()),
  41. date_time=True)
  42. self.localcontext.update({
  43. 'cr': cursor,
  44. 'uid': uid,
  45. 'report_name': _('Trial Balance'),
  46. 'display_account': self._get_display_account,
  47. 'display_account_raw': self._get_display_account_raw,
  48. 'filter_form': self._get_filter,
  49. 'target_move': self._get_target_move,
  50. 'display_target_move': self._get_display_target_move,
  51. 'accounts': self._get_accounts_br,
  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'),
  61. '[topage]'))),
  62. ('--footer-line',),
  63. ],
  64. })
  65. def set_context(self, objects, data, ids, report_type=None):
  66. """Populate a ledger_lines attribute on each browse record that will
  67. be used by mako template"""
  68. objects, new_ids, context_report_values = self.\
  69. compute_balance_data(data)
  70. self.localcontext.update(context_report_values)
  71. return super(TrialBalanceWebkit, self).set_context(
  72. objects, data, new_ids, report_type=report_type)
  73. HeaderFooterTextWebKitParser(
  74. 'report.account.account_report_trial_balance_webkit',
  75. 'account.account',
  76. 'addons/account_financial_report_webkit/report/templates/\
  77. account_report_trial_balance.mako',
  78. parser=TrialBalanceWebkit)