+
+class res_users(orm.Model):
+ _inherit = 'res.users'
+
+ def onchange_partner_id(self, cr, uid, ids, partner_id, login):
+ """Define user email address from partner email address"""
+ v = {}
+ partners = self.pool.get('res.partner')
+ partner = partners.browse(cr, uid, partner_id)
+ if partner.email:
+ v['email'] = partner.email
+ else:
+ v = {}
+ return {'value': v}
+
+
+class event_event(orm.Model):
+ _inherit = 'event.event'
+
+ _columns = {
+ 'duration': fields.float(
+ 'Duration',
+ digits_compute=dp.get_precision('Product Unit of Measure'),
+ help='Duration in hours'
+ ),
+ }
+
+
+class event_registration(orm.Model):
+ _inherit = 'event.registration'
+
+ _columns = {
+ 'gender': fields.selection([
+ ('female', 'Female'),
+ ('male', 'Male'),
+ ('other', 'Other')],
+ 'Gender'),
+ 'position': fields.selection([
+ ('employee', 'Employee'),
+ ('individual', 'Invividual'),
+ ('volunteer', 'Volunteer')],
+ 'Position'),
+ 'funding_main': fields.selection([
+ ('individual', 'Individual'),
+ ('opco', 'OPCO'),
+ ('company', 'Company'),
+ ('pole_emploi', 'Pole Emploi')],
+ 'Main funding', help='Main funding origin'),
+ 'fundings_others': fields.char('Others fundings origins', size=128),
+ 'sale_order_ids': fields.many2many(
+ 'sale.order',
+ 'event_registration_sale_order_rel',
+ 'event_registration_id',
+ 'sale_order_id',
+ 'Related sale order(s)'
+ ),
+ 'invoice_ids': fields.many2many(
+ 'account.invoice',
+ 'event_registration_invoice_id_rel',
+ 'event_registration_id',
+ 'invoice_id',
+ 'Related invoice(s)'
+ ),
+ }
+
+ def onchange_contact_id(self, cr, uid, ids, contact, partner, context=None):
+ """Contcat phone with mobile phone if exist. If mobile exist and not
+ phone, add mobile number"""
+ vals = super(event_registration, self).onchange_contact_id(cr, uid, ids, contact, partner, context)
+ addr_obj = self.pool.get('res.partner')
+ contact_id = addr_obj.browse(cr, uid, contact, context=context)
+ phone = vals['value']['phone']
+ mobile = contact_id.mobile
+ if mobile:
+ if phone:
+ vals['value']['phone'] = '%s - %s' % (phone, mobile)
+ else:
+ vals['value']['phone'] = mobile
+ return vals
+
+
+class crossovered_budget_lines(orm.Model):
+ _inherit = 'crossovered.budget.lines'
+
+ def _prac_amt(self, cr, uid, ids, context=None):
+ """Calculate pratical amount even if there is no analytic account"""
+ res = {}
+ result = 0.0
+ if context is None:
+ context = {}
+ account_obj = self.pool.get('account.account')
+
+ for line in self.browse(cr, uid, ids, context=context):
+ acc_ids = [x.id for x in line.general_budget_id.account_ids]
+ if not acc_ids:
+ raise osv.except_osv(_('Error!'),_("The Budget '%s' has no accounts!") % ustr(line.general_budget_id.name))
+ acc_ids = account_obj._get_children_and_consol(cr, uid, acc_ids, context=context)
+ date_to = line.date_to
+ date_from = line.date_from
+
+ if line.analytic_account_id.id:
+ res = super(crossovered_budget_lines, self)._prac_amt(cr, uid, ids, context)
+ else:
+ cr.execute("SELECT SUM(credit) - SUM(debit) FROM account_move_line WHERE (date "
+ "between to_date(%s,'yyyy-mm-dd') AND to_date(%s,'yyyy-mm-dd')) AND "
+ "account_id=ANY(%s)", (date_from, date_to,acc_ids,))
+ result = cr.fetchone()[0]
+ if result is None:
+ result = 0.00
+ res[line.id] = result
+
+ return res
+
+