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.

51 lines
1.8 KiB

  1. # -*- coding: utf-8 -*-
  2. from openerp import api, fields, models
  3. class PartnerUpdateInfo(models.TransientModel):
  4. _name = "partner.update.info"
  5. _description = "Update Partner Info"
  6. @api.model
  7. def _get_partner(self):
  8. active_id = self.env.context.get('active_id')
  9. return self.env['res.partner'].browse(active_id)
  10. @api.model
  11. def _get_register_number(self):
  12. partner = self._get_partner()
  13. if partner.is_company:
  14. return partner.company_register_number
  15. register_number = fields.Char(string="Register Number",
  16. default=_get_register_number)
  17. cooperator = fields.Many2one('res.partner',
  18. string="Cooperator",
  19. default=_get_partner)
  20. all = fields.Boolean(string="Update from subscription request")
  21. birthdate = fields.Boolean(string="set missing birth date")
  22. @api.multi
  23. def update(self):
  24. partner_obj = self.env['res.partner']
  25. cooperator = self.cooperator
  26. coop_vals = {}
  27. if self.all:
  28. if self.birthdate:
  29. coops = partner_obj.search([('cooperator', '=', True),
  30. ('birthdate_date', '=', False),
  31. ('is_company', '=', False)])
  32. for coop in coops:
  33. if coop.subscription_request_ids:
  34. sub_req = coop.subscription_request_ids[0]
  35. coop.birthdate_date = sub_req.birthdate
  36. else:
  37. if cooperator:
  38. if cooperator.is_company:
  39. coop_vals['company_register_number'] = self.register_number
  40. if coop_vals:
  41. cooperator.write(coop_vals)
  42. return True