Browse Source

Ajout d'un wizard pour créer un nouvel enfant directement chez le travailleur. Correction de qq mots qui étaient encore en français

pull/13/head
EliseDup 9 years ago
parent
commit
5387e0cd96
  1. 1
      beesdoo_base/__openerp__.py
  2. 13
      beesdoo_base/models/partner.py
  3. 31
      beesdoo_base/views/partner.xml
  4. 2
      beesdoo_base/wizard/__init__.py
  5. 2
      beesdoo_base/wizard/member_card.py
  6. 22
      beesdoo_base/wizard/partner.py
  7. 6
      beesdoo_base/wizard/views/member_card.xml
  8. 22
      beesdoo_base/wizard/views/partner.xml

1
beesdoo_base/__openerp__.py

@ -22,5 +22,6 @@
'security/ir.model.access.csv', 'security/ir.model.access.csv',
'views/partner.xml', 'views/partner.xml',
'wizard/views/member_card.xml', 'wizard/views/member_card.xml',
'wizard/views/partner.xml'
], ],
} }

13
beesdoo_base/models/partner.py

@ -44,7 +44,7 @@ class Partner(models.Model):
def write(self, values): def write(self, values):
if values.get('parent_eater_id') and self.parent_eater_id: if values.get('parent_eater_id') and self.parent_eater_id:
raise ValidationError(_('You try to assign a eater to a worker but this easer is alread assign to %s please remove it before') % self.parent_eater_id.name) raise ValidationError(_('You try to assign a eater to a worker but this easer is alread assign to %s please remove it before') % self.parent_eater_id.name)
#replace many2many command when writing on child_eater_ids to just remove the link
# replace many2many command when writing on child_eater_ids to just remove the link
if 'child_eater_ids' in values: if 'child_eater_ids' in values:
for command in values['child_eater_ids']: for command in values['child_eater_ids']:
if command[0] == 2: if command[0] == 2:
@ -74,4 +74,15 @@ class Partner(models.Model):
cr.execute("UPDATE res_partner set last_name = name where last_name IS NULL") cr.execute("UPDATE res_partner set last_name = name where last_name IS NULL")
return res return res
@api.multi
def _new_eater(self, name, surname, email):
partner_data = {
'name' : name,
'surname' : surname,
'is_customer' : True,
'eater' : 'eater',
'parent_eater_id' : self.id,
'email' : email
}
self.env['res.partner'].create(partner_data)

31
beesdoo_base/views/partner.xml

@ -7,6 +7,13 @@
<field name="target">new</field> <field name="target">new</field>
</record> </record>
<record model="ir.actions.act_window" id="action_eater_wizard">
<field name="name">New Eater</field>
<field name="res_model">eater.new.wizard</field>
<field name="view_mode">form</field>
<field name="target">new</field>
</record>
<record model="ir.ui.view" id="beesdoo_partner_form_view"> <record model="ir.ui.view" id="beesdoo_partner_form_view">
<field name="name">beesdoo.partner.form.view</field> <field name="name">beesdoo.partner.form.view</field>
<field name="model">res.partner</field> <field name="model">res.partner</field>
@ -20,22 +27,25 @@
default_focus="1" /> default_focus="1" />
</field> </field>
<field name="website" position="after"> <field name="website" position="after">
<field name="eater"
attrs="{'invisible': [('customer', '=', False)]}" />
<field name="eater" attrs="{'invisible': [('customer', '=', False)]}" />
<field name="parent_eater_id" attrs="{'invisible' : [('eater', '!=', 'eater')]}" /> <field name="parent_eater_id" attrs="{'invisible' : [('eater', '!=', 'eater')]}" />
</field> </field>
<xpath expr="//notebook" position="inside"> <xpath expr="//notebook" position="inside">
<page string="Carte de Membre"
<page string="Member Card"
attrs="{'invisible': ['|', ('customer', '=', False), ('eater', '!=', 'worker_eater')]}"> attrs="{'invisible': ['|', ('customer', '=', False), ('eater', '!=', 'worker_eater')]}">
<separator string="Printing" /> <separator string="Printing" />
<group> <group>
<field name="member_card_to_be_printed" /> <field name="member_card_to_be_printed" />
<field name="last_printed" /> <field name="last_printed" />
</group> </group>
<separator string="Mangeurs" />
<separator string="Eaters" />
<field name="child_eater_ids" widget="many2many_tags" /> <field name="child_eater_ids" widget="many2many_tags" />
<separator string="Cartes" />
<field string="Cartes" name="member_card_ids">
<group>
<button string="New Eater" name="%(action_eater_wizard)d"
type="action" />
</group>
<separator string="Cards" />
<field string="Cards" name="member_card_ids">
<tree editable="bottom"> <tree editable="bottom">
<field name="barcode" /> <field name="barcode" />
<field name="create_date" /> <field name="create_date" />
@ -46,13 +56,15 @@
</tree> </tree>
</field> </field>
<group> <group>
<button string="Nouvelle Carte" name="%(action_membercard_wizard)d"
<button string="New Card" name="%(action_membercard_wizard)d"
type="action" /> type="action" />
</group> </group>
</page> </page>
</xpath> </xpath>
<field name="barcode" position="attributes"> <field name="barcode" position="attributes">
<attribute name="attrs">{'invisible' : [('eater', '!=', 'worker_eater')]}</attribute>
<attribute name="attrs">{'invisible' : [('eater', '!=',
'worker_eater')]}
</attribute>
</field> </field>
<field name="barcode" position="after"> <field name="barcode" position="after">
<field name="parent_barcode" attrs="{'invisible' : [('eater', '!=', 'eater')]}" /> <field name="parent_barcode" attrs="{'invisible' : [('eater', '!=', 'eater')]}" />
@ -63,7 +75,8 @@
<!-- S022 : By default a supplier should be a company --> <!-- S022 : By default a supplier should be a company -->
<record id="base.action_partner_supplier_form" model="ir.actions.act_window"> <record id="base.action_partner_supplier_form" model="ir.actions.act_window">
<field name="context">{ 'search_default_supplier': 1, <field name="context">{ 'search_default_supplier': 1,
'default_customer': 0,
'default_customer':
0,
'default_supplier': 1, 'default_supplier': 1,
'default_is_company' : True, 'default_is_company' : True,
'default_company_type' : 'company', } 'default_company_type' : 'company', }

2
beesdoo_base/wizard/__init__.py

@ -1,2 +1,2 @@
import member_card
import member_card, partner

2
beesdoo_base/wizard/member_card.py

@ -12,7 +12,7 @@ class NewMemberCardWizard(models.TransientModel):
def _get_default_partner(self): def _get_default_partner(self):
return self.env.context['active_id'] return self.env.context['active_id']
new_comment = fields.Text('Reason', required=True)
new_comment = fields.Char('Reason', required=True)
partner_id = fields.Many2one('res.partner', default=_get_default_partner) partner_id = fields.Many2one('res.partner', default=_get_default_partner)
force_barcode = fields.Char('Force Barcode', groups="beesdoo_base.group_force_barcode") force_barcode = fields.Char('Force Barcode', groups="beesdoo_base.group_force_barcode")

22
beesdoo_base/wizard/partner.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
from openerp import models, fields, api
class NewEaterWizard(models.TransientModel):
"""
A transient model for the creation of a eater related to a worker.
"""
_name = 'eater.new.wizard'
def _get_default_partner(self):
return self.env.context['active_id']
first_name = fields.Char('First Name', required=True)
last_name = fields.Char('Last Name', required=True)
email = fields.Char('Email')
partner_id = fields.Many2one('res.partner', default=_get_default_partner)
@api.one
def create_new_eater(self):
client = self.partner_id.sudo()
client._new_eater(self.first_name, self.last_name, self.email)

6
beesdoo_base/wizard/views/member_card.xml

@ -10,12 +10,12 @@
<field name="force_barcode" /> <field name="force_barcode" />
</group> </group>
<separator string="Reason" /> <separator string="Reason" />
<field name="new_comment" string="Raison" editable="True" />
<field name="new_comment" string="Reason" editable="True" />
<field name="partner_id" invisible="1" /> <field name="partner_id" invisible="1" />
<footer> <footer>
<button type="object" name="create_new_card" string="Créer"
<button type="object" name="create_new_card" string="Create"
class="oe_highlight" /> class="oe_highlight" />
<button special="cancel" string="Annuler" />
<button special="cancel" string="Cancel" />
</footer> </footer>
</form> </form>
</field> </field>

22
beesdoo_base/wizard/views/partner.xml

@ -0,0 +1,22 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- New eater generation wizard -->
<record id="Eater Wizard" model="ir.ui.view">
<field name="name">New Eater Wizard</field>
<field name="model">eater.new.wizard</field>
<field name="arch" type="xml">
<form string="Create a new eater">
<group>
<field name="first_name" />
<field name="last_name" />
<field name="email" />
</group>
<footer>
<button type="object" name="create_new_eater" string="Create"
class="oe_highlight" />
<button special="cancel" string="Cancel" />
</footer>
</form>
</field>
</record>
</odoo>
Loading…
Cancel
Save