Browse Source

[IMP] manage legal representative in the wizard

pull/1/head
houssine 7 years ago
parent
commit
f19a4d77ca
  1. 54
      easy_my_coop/wizard/create_subscription_from_partner.py
  2. 2
      easy_my_coop/wizard/create_subscription_from_partner.xml

54
easy_my_coop/wizard/create_subscription_from_partner.py

@ -28,6 +28,27 @@ class PartnerCreateSubscription(models.TransientModel):
return self.env['product.product'].search(domain)[0] return self.env['product.product'].search(domain)[0]
def _get_representative(self):
partner = self._get_partner()
if partner.is_company:
return self.env['res.partner'].search([('parent_id','=',partner.id),
('representative','=',True)])
return False
@api.model
def _get_representative_number(self):
representative = self._get_representative()
if representative:
return representative.national_register_number
return False
@api.model
def _get_representative_name(self):
representative = self._get_representative()
if representative:
return representative.name
return False
@api.model @api.model
def _get_partner(self): def _get_partner(self):
active_id = self.env.context.get('active_id') active_id = self.env.context.get('active_id')
@ -84,10 +105,20 @@ class PartnerCreateSubscription(models.TransientModel):
share_qty = fields.Integer(string="Share Quantity", required=True) share_qty = fields.Integer(string="Share Quantity", required=True)
share_unit_price = fields.Float(related='share_product.list_price', string='Share price', readonly=True) share_unit_price = fields.Float(related='share_product.list_price', string='Share price', readonly=True)
subscription_amount = fields.Float(compute='_compute_subscription_amount', string='Subscription amount', digits=dp.get_precision('Account'), readonly=True) subscription_amount = fields.Float(compute='_compute_subscription_amount', string='Subscription amount', digits=dp.get_precision('Account'), readonly=True)
representative_name = fields.Char(string='Representative name', default=_get_representative_name)
representative_number = fields.Char(string='Representative national register number', default=_get_representative_number)
def check_belgian_ident_id(self, register_number):
if self.env['subscription.request'].check_belgian_identification_id(register_number):
return True
else:
raise UserError(_("The national register number is not valid."))
@api.multi @api.multi
def create_subscription(self): def create_subscription(self):
sub_req = self.env['subscription.request'] sub_req = self.env['subscription.request']
partner_obj = self.env['res.partner']
cooperator = self.cooperator cooperator = self.cooperator
vals = {'partner_id': cooperator.id, vals = {'partner_id': cooperator.id,
'share_product_id': self.share_product.id, 'share_product_id': self.share_product.id,
@ -113,10 +144,24 @@ class PartnerCreateSubscription(models.TransientModel):
if self.is_company: if self.is_company:
coop_vals['company_register_number'] = self.register_number coop_vals['company_register_number'] = self.register_number
else: else:
if sub_req.check_belgian_identification_id(self.register_number):
if self.check_belgian_ident_id(self.register_number):
coop_vals['national_register_number'] = self.register_number coop_vals['national_register_number'] = self.register_number
else:
raise UserError(_("The national register number is not valid."))
if not self._get_representative():
representative_number = self.representative_number
representative = partner_obj.search([('national_register_number','=',representative_number)])
if representative:
if len(representative) > 1:
raise UserError(_('There is two different persons with the same national register number. Please proceed to a merge before to continue'))
if representative.parent_id:
raise UserError(_("A person can't be representative of two differents companies."))
representative.parent_id = cooperator.id
else:
if self.check_belgian_ident_id(representative_number):
represent_vals = {'name':self.representative_name,'national_register_number':representative_number,
'parent_id':cooperator.id,'representative':True}
partner_obj.create(represent_vals)
if not self._get_bank_account(): if not self._get_bank_account():
partner_bank = self.env['res.partner.bank'] partner_bank = self.env['res.partner.bank']
@ -126,8 +171,9 @@ class PartnerCreateSubscription(models.TransientModel):
if coop_vals: if coop_vals:
cooperator.write(coop_vals) cooperator.write(coop_vals)
#self.env.cr.commit()
new_sub_req = sub_req.create(vals) new_sub_req = sub_req.create(vals)
return { return {
'type': 'ir.actions.act_window', 'type': 'ir.actions.act_window',
'view_type': 'form, tree', 'view_type': 'form, tree',

2
easy_my_coop/wizard/create_subscription_from_partner.xml

@ -12,6 +12,8 @@
<group> <group>
<field name="is_company" invisible="True"/> <field name="is_company" invisible="True"/>
<field name="cooperator" invisible="True"/> <field name="cooperator" invisible="True"/>
<field name="representative_name" attrs="{'invisible':[('is_company','=',False)],'required':[('is_company','=',True)]}"/>
<field name="representative_number" attrs="{'invisible':[('is_company','=',False)],'required':[('is_company','=',True)]}"/>
<field name="email"/> <field name="email"/>
<field name="register_number"/> <field name="register_number"/>
<field name="bank_account"/> <field name="bank_account"/>

Loading…
Cancel
Save