# -*- coding: utf-8 -*- ############################################################################## # # Copyright (C) 2011 Agile Business Group sagl () # Copyright (C) 2011 Domsense srl () # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published # by the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see . # ############################################################################## from openerp.osv import fields, orm from openerp.tools.translate import _ import re class account_document_template(orm.Model): _computed_lines = {} _current_template_id = 0 _cr = None _uid = None _name = 'account.document.template' _columns = { 'name': fields.char('Name', size=64, required=True), } def _input_lines(self, cr, uid, template): count = 0 for line in template.template_line_ids: if line.type == 'input': count += 1 return count def _get_template_line(self, cr, uid, template_id, line_number): for line in self.browse(cr, uid, template_id).template_line_ids: if line.sequence == line_number: return line return False def _generate_empty_lines(self, cr, uid, template_id): lines = {} for template_line in self.browse(cr, uid, template_id).template_line_ids: lines[template_line.sequence] = None return lines def lines(self, line_number): if self._computed_lines[line_number] is not None: return self._computed_lines[line_number] line = self._get_template_line(self._cr, self._uid, self._current_template_id, line_number) if re.match('L\( *'+str(line_number)+' *\)',line.python_code): raise orm.except_orm(_('Error'), _('Line %s can\'t refer to itself') % str(line_number)) try: self._computed_lines[line_number] = eval(line.python_code.replace('L', 'self.lines')) except KeyError: raise orm.except_orm(_('Error'), _('Code "%s" refers to non existing line') % line.python_code) return self._computed_lines[line_number] def compute_lines(self, cr, uid, template_id, input_lines): # input_lines: dictionary in the form {line_number: line_amount} # returns all the lines (included input lines) in the form {line_number: line_amount} template = self.browse(cr, uid, template_id) if len(input_lines) != self._input_lines(cr, uid, template): raise orm.except_orm(_('Error'), _('Inconsistency between input lines and filled lines for template %s') % template.name) self._current_template_id = template.id self._cr = cr self._uid = uid self._computed_lines = self._generate_empty_lines(cr, uid, template_id) self._computed_lines.update(input_lines) for line_number in self._computed_lines: self.lines(line_number) return self._computed_lines def check_zero_lines(self, cr, uid, wizard): if not wizard.line_ids: return True for template_line in wizard.line_ids: if template_line.amount: return True return False class account_document_template_line(orm.Model): _name = 'account.document.template.line' _columns = { 'name': fields.char('Name', size=64, required=True), 'sequence': fields.integer('Sequence', required=True), 'type': fields.selection([('computed', 'Computed'),('input', 'User input')], 'Type', required=True), 'python_code':fields.text('Python Code'), }