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.

53 lines
2.4 KiB

  1. # -*- coding: utf-8 -*-
  2. ##############################################################################
  3. #
  4. # Author: Vincent Renaville, ported by Joel Grand-Guillaume
  5. # Copyright 2010-2013 Camptocamp SA
  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 time
  22. from openerp.report import report_sxw
  23. from openerp.tools import DEFAULT_SERVER_DATE_FORMAT
  24. class account_hours_block(report_sxw.rml_parse):
  25. def __init__(self, cr, uid, name, context=None):
  26. super(account_hours_block, self).__init__(cr, uid, name, context=context)
  27. self.localcontext.update({'time': time,
  28. 'date_format': DEFAULT_SERVER_DATE_FORMAT,
  29. 'analytic_lines': self._get_analytic_lines,
  30. })
  31. self.context = context
  32. def _get_analytic_lines(self, hours_block):
  33. al_pool = self.pool.get('account.analytic.line')
  34. aj_pool = self.pool.get('account.analytic.journal')
  35. tcj_ids = aj_pool.search(self.cr, self.uid,
  36. [('type', '=', 'general')])
  37. al_ids = al_pool.search(self.cr,
  38. self.uid,
  39. [('invoice_id', '=', hours_block.invoice_id.id),
  40. ('journal_id', 'in', tcj_ids),
  41. ],
  42. order='date desc',
  43. context=self.context)
  44. return al_pool.browse(self.cr, self.uid, al_ids, context=self.context)
  45. report_sxw.report_sxw('report.account.hours.block',
  46. 'account.hours.block',
  47. 'addons/analytic_hours_block/report/hours_block.rml',
  48. parser=account_hours_block)