[MERGE] branch with fixes of picking wave
bzr revid: qdp-launchpad@openerp.com-20140203072833-tda8bncaanf0b36j
This commit is contained in:
commit
3d392cab4e
|
@ -87,6 +87,7 @@ This installs the module product_expiry."""),
|
||||||
'module_stock_dropshipping': fields.boolean("Manage dropshipping",
|
'module_stock_dropshipping': fields.boolean("Manage dropshipping",
|
||||||
help='\nCreates the dropship route and add more complex tests'
|
help='\nCreates the dropship route and add more complex tests'
|
||||||
'-This installs the module stock_dropshipping.'),
|
'-This installs the module stock_dropshipping.'),
|
||||||
|
'module_stock_picking_wave': fields.boolean('Manage picking wave', help='Install the picking wave module which will help you grouping your pickings and processing them in batch'),
|
||||||
}
|
}
|
||||||
|
|
||||||
def _default_company(self, cr, uid, context=None):
|
def _default_company(self, cr, uid, context=None):
|
||||||
|
|
|
@ -82,6 +82,10 @@
|
||||||
<field name="module_stock_dropshipping" class="oe_inline"/>
|
<field name="module_stock_dropshipping" class="oe_inline"/>
|
||||||
<label for="module_stock_dropshipping"/>
|
<label for="module_stock_dropshipping"/>
|
||||||
</div>
|
</div>
|
||||||
|
<div>
|
||||||
|
<field name="module_stock_picking_wave" class="oe_inline"/>
|
||||||
|
<label for="module_stock_picking_wave"/>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</group>
|
</group>
|
||||||
<group>
|
<group>
|
||||||
|
|
|
@ -1,3 +1,2 @@
|
||||||
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
||||||
access_stock_picking_wave,stock.picking.wave stock users,model_stock_picking_wave,stock.group_stock_user,1,1,1,1
|
access_stock_picking_wave,stock.picking.wave stock users,model_stock_picking_wave,stock.group_stock_user,1,1,1,1
|
||||||
access_stock_picking_wave_type,stock.picking.wave.type stock users,model_stock_picking_wave_type,stock.group_stock_user,1,1,1,1
|
|
||||||
|
|
|
|
@ -7,23 +7,23 @@ class stock_picking_wave(osv.osv):
|
||||||
_order = "name desc"
|
_order = "name desc"
|
||||||
_columns = {
|
_columns = {
|
||||||
'name': fields.char('name', required=True, help='Name of the picking wave'),
|
'name': fields.char('name', required=True, help='Name of the picking wave'),
|
||||||
'partner_id': fields.many2one('res.partner', 'Responsible', help='Person responsible for this wave'),
|
'user_id': fields.many2one('res.users', 'Responsible', help='Person responsible for this wave'),
|
||||||
'time': fields.float('Time', help='Time it will take to perform the wave'),
|
'time': fields.float('Time', help='Time it will take to perform the wave'),
|
||||||
'picking_ids': fields.one2many('stock.picking', 'wave_id', 'Pickings', help='List of picking associated to this wave'),
|
'picking_ids': fields.one2many('stock.picking', 'wave_id', 'Pickings', help='List of picking associated to this wave'),
|
||||||
'capacity': fields.float('Capacity', help='The capacity of the transport used to get the goods'),
|
'capacity': fields.float('Capacity', help='The capacity of the transport used to get the goods'),
|
||||||
'capacity_uom': fields.many2one('product.uom', 'Unit of Measure', help='The Unity Of Measure of the transport capacity'),
|
'capacity_uom': fields.many2one('product.uom', 'Unit of Measure', help='The Unity Of Measure of the transport capacity'),
|
||||||
'wave_type_id': fields.many2one('stock.picking.wave.type', 'Picking Wave Type'),
|
'state': fields.selection([('draft', 'Draft'), ('in_progress', 'Running'), ('done', 'Done'), ('cancel', 'Cancelled')], required=True),
|
||||||
'state': fields.selection([('in_progress', 'Running'), ('done', 'Done'), ('cancel', 'Cancelled')], required=True),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
_defaults = {
|
_defaults = {
|
||||||
'name': '/',
|
'name': '/',
|
||||||
'state': 'in_progress',
|
'state': 'draft',
|
||||||
}
|
}
|
||||||
|
|
||||||
def confirm_picking(self, cr, uid, ids, context=None):
|
def confirm_picking(self, cr, uid, ids, context=None):
|
||||||
picking_todo = self.pool.get('stock.picking').search(cr, uid, [('wave_id', 'in', ids)], context=context)
|
picking_todo = self.pool.get('stock.picking').search(cr, uid, [('wave_id', 'in', ids)], context=context)
|
||||||
return self.pool.get('stock.picking').action_done(cr, uid, picking_todo, context=context)
|
self.write(cr, uid, ids, {'state': 'in_progress'}, context=context)
|
||||||
|
return self.pool.get('stock.picking').action_assign(cr, uid, picking_todo, context=context)
|
||||||
|
|
||||||
def cancel_picking(self, cr, uid, ids, context=None):
|
def cancel_picking(self, cr, uid, ids, context=None):
|
||||||
picking_todo = self.pool.get('stock.picking').search(cr, uid, [('wave_id', 'in', ids)], context=context)
|
picking_todo = self.pool.get('stock.picking').search(cr, uid, [('wave_id', 'in', ids)], context=context)
|
||||||
|
@ -66,6 +66,16 @@ class stock_picking_wave(osv.osv):
|
||||||
return super(stock_picking_wave, self).copy(cr, uid, id, default=default, context=context)
|
return super(stock_picking_wave, self).copy(cr, uid, id, default=default, context=context)
|
||||||
|
|
||||||
def done(self, cr, uid, ids, context=None):
|
def done(self, cr, uid, ids, context=None):
|
||||||
|
picking_todo = set()
|
||||||
|
for wave in self.browse(cr, uid, ids, context=context):
|
||||||
|
for picking in wave.picking_ids:
|
||||||
|
if picking.state in ('cancel', 'done'):
|
||||||
|
continue
|
||||||
|
if picking.state != 'assigned':
|
||||||
|
raise osv.except_osv(_('Warning'), _('Some pickings are still waiting for goods. Please check or force their availability before setting this wave to done.'))
|
||||||
|
picking_todo.add(picking.id)
|
||||||
|
if picking_todo:
|
||||||
|
self.pool.get('stock.picking').action_done(cr, uid, list(picking_todo), context=context)
|
||||||
return self.write(cr, uid, ids, {'state': 'done'}, context=context)
|
return self.write(cr, uid, ids, {'state': 'done'}, context=context)
|
||||||
|
|
||||||
|
|
||||||
|
@ -73,17 +83,4 @@ class stock_picking(osv.osv):
|
||||||
_inherit = "stock.picking"
|
_inherit = "stock.picking"
|
||||||
_columns = {
|
_columns = {
|
||||||
'wave_id': fields.many2one('stock.picking.wave', 'Picking Wave', help='Picking wave associated to this picking'),
|
'wave_id': fields.many2one('stock.picking.wave', 'Picking Wave', help='Picking wave associated to this picking'),
|
||||||
'wave_type_ids': fields.related('partner_id', 'wave_type_ids', type="many2many", relation='stock.picking.wave.type', string='Picking Wave Type'),
|
|
||||||
}
|
|
||||||
|
|
||||||
class res_partner(osv.osv):
|
|
||||||
_inherit = 'res.partner'
|
|
||||||
_columns = {
|
|
||||||
'wave_type_ids': fields.many2many('stock.picking.wave.type', 'stock_picking_wave_type_rel', 'wave_type_id', 'partner_id', 'Picking Wave Type'),
|
|
||||||
}
|
|
||||||
|
|
||||||
class stock_picking_wave_type(osv.osv):
|
|
||||||
_name = 'stock.picking.wave.type'
|
|
||||||
_columns = {
|
|
||||||
'name': fields.char('Type', required=True),
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,18 +1,6 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<openerp>
|
<openerp>
|
||||||
<data>
|
<data>
|
||||||
|
|
||||||
<!--
|
|
||||||
Add picking wave type
|
|
||||||
-->
|
|
||||||
<record id="wave_type_freeze" model="stock.picking.wave.type">
|
|
||||||
<field name="name">Type Freeze</field>
|
|
||||||
</record>
|
|
||||||
|
|
||||||
<record id="wave_type_dry" model="stock.picking.wave.type">
|
|
||||||
<field name="name">Type Dry</field>
|
|
||||||
</record>
|
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
Add picking wave
|
Add picking wave
|
||||||
-->
|
-->
|
||||||
|
@ -21,8 +9,6 @@
|
||||||
<field name="capacity">15</field>
|
<field name="capacity">15</field>
|
||||||
<field name="capacity_uom" ref="product.product_uom_ton" />
|
<field name="capacity_uom" ref="product.product_uom_ton" />
|
||||||
<field name="state">in_progress</field>
|
<field name="state">in_progress</field>
|
||||||
<field name="wave_type_id" ref="wave_type_dry" />
|
|
||||||
|
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<record id="stock_picking_wave_freeze_1" model="stock.picking.wave">
|
<record id="stock_picking_wave_freeze_1" model="stock.picking.wave">
|
||||||
|
@ -30,7 +16,6 @@
|
||||||
<field name="capacity">600</field>
|
<field name="capacity">600</field>
|
||||||
<field name="capacity_uom" ref="product.product_uom_kgm" />
|
<field name="capacity_uom" ref="product.product_uom_kgm" />
|
||||||
<field name="state">in_progress</field>
|
<field name="state">in_progress</field>
|
||||||
<field name="wave_type_id" ref="wave_type_freeze" />
|
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
|
|
|
@ -6,15 +6,14 @@
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<form string="Stock Picking Waves" version="7.0">
|
<form string="Stock Picking Waves" version="7.0">
|
||||||
<header>
|
<header>
|
||||||
|
<button name="confirm_picking" states="draft" string="Confirm" type="object" class="oe_highlight"/>
|
||||||
<button name="done" states="in_progress" string="Done" type="object" class="oe_highlight"/>
|
<button name="done" states="in_progress" string="Done" type="object" class="oe_highlight"/>
|
||||||
<button name="cancel_picking" string="Cancel" type="object" states="in_progress"/>
|
<button name="cancel_picking" string="Cancel" type="object" states="in_progress"/>
|
||||||
<field name="state" widget="statusbar" statusbar_visible="in_progress,done"/>
|
<field name="state" widget="statusbar" statusbar_visible="in_progress,done"/>
|
||||||
</header>
|
</header>
|
||||||
<sheet>
|
<sheet>
|
||||||
<div class="oe_right oe_button_box">
|
<div class="oe_right oe_button_box">
|
||||||
<button name="print_picking" string="Print all internal pickings" type="object" context="{'report':'stock.picking.list.internal'}"/>
|
<button name="print_picking" string="Print all pickings" type="object" context="{'report':'stock.picking.list.internal'}"/>
|
||||||
<button name="print_picking" string="Print all in/out pickings" type="object" context="{'report':'stock.picking.list'}"/>
|
|
||||||
<button name="confirm_picking" string="Confirm all pickings" type="object"/>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="oe_title">
|
<div class="oe_title">
|
||||||
<h1>
|
<h1>
|
||||||
|
@ -23,8 +22,7 @@
|
||||||
</div>
|
</div>
|
||||||
<group>
|
<group>
|
||||||
<group>
|
<group>
|
||||||
<field name="partner_id"/>
|
<field name="user_id"/>
|
||||||
<field name="wave_type_id"/>
|
|
||||||
</group>
|
</group>
|
||||||
<group>
|
<group>
|
||||||
<label for="capacity"/>
|
<label for="capacity"/>
|
||||||
|
@ -36,7 +34,7 @@
|
||||||
</group>
|
</group>
|
||||||
</group>
|
</group>
|
||||||
<separator string="Pickings"/>
|
<separator string="Pickings"/>
|
||||||
<field name="picking_ids" widget="many2many">
|
<field name="picking_ids" widget="many2many" domain="[('state', 'not in', ('done', 'cancel'))]">
|
||||||
<tree>
|
<tree>
|
||||||
<field name="name"/>
|
<field name="name"/>
|
||||||
<field name="backorder_id"/>
|
<field name="backorder_id"/>
|
||||||
|
@ -44,7 +42,8 @@
|
||||||
<field name="date"/>
|
<field name="date"/>
|
||||||
<field name="min_date"/>
|
<field name="min_date"/>
|
||||||
<field name="state"/>
|
<field name="state"/>
|
||||||
<button name="action_done" string="Confirm picking" type="object" icon="gtk-apply" attrs="{'invisible': [('state', 'in', ('done', 'cancel'))]}"/>
|
<button name="action_assign" string="Confirm picking" type="object" icon="gtk-apply" attrs="{'invisible': [('state', 'in', ('done', 'cancel', 'confirmed', 'assigned'))]}"/>
|
||||||
|
<button name="force_assign" string="Force availability" type="object" icon="gtk-go-forward" attrs="{'invisible': [('state', 'in', ('done', 'cancel', 'draft', 'assigned'))]}"/>
|
||||||
<button name="action_cancel" string="Cancel picking" type="object" icon="gtk-cancel" attrs="{'invisible': [('state', 'in', ('done', 'cancel'))]}"/>
|
<button name="action_cancel" string="Cancel picking" type="object" icon="gtk-cancel" attrs="{'invisible': [('state', 'in', ('done', 'cancel'))]}"/>
|
||||||
</tree>
|
</tree>
|
||||||
</field>
|
</field>
|
||||||
|
@ -60,10 +59,9 @@
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<tree string="Stock Picking Waves" colors="black:state in ('in_progress','done');grey: state=='cancel'">
|
<tree string="Stock Picking Waves" colors="black:state in ('in_progress','done');grey: state=='cancel'">
|
||||||
<field name="name"/>
|
<field name="name"/>
|
||||||
<field name="partner_id"/>
|
<field name="user_id"/>
|
||||||
<field name="capacity"/>
|
<field name="capacity"/>
|
||||||
<field name="capacity_uom"/>
|
<field name="capacity_uom"/>
|
||||||
<field name="wave_type_id"/>
|
|
||||||
<field name="time" widget="float_time"/>
|
<field name="time" widget="float_time"/>
|
||||||
<field name="state"/>
|
<field name="state"/>
|
||||||
</tree>
|
</tree>
|
||||||
|
@ -77,9 +75,9 @@
|
||||||
<search string="Search Picking Waves">
|
<search string="Search Picking Waves">
|
||||||
<field name="name" string="Picking Wave"/>
|
<field name="name" string="Picking Wave"/>
|
||||||
<filter name="in_progress" string="In Progress" domain="[('state','=', 'in_progress')]" help="Picking Waves not finished"/>
|
<filter name="in_progress" string="In Progress" domain="[('state','=', 'in_progress')]" help="Picking Waves not finished"/>
|
||||||
<field name="partner_id"/>
|
<field name="user_id"/>
|
||||||
<group expand="0" string="Group By...">
|
<group expand="0" string="Group By...">
|
||||||
<filter string="Partner" domain="[]" context="{'group_by':'partner_id'}"/>
|
<filter string="User" domain="[]" context="{'group_by':'user_id'}"/>
|
||||||
<filter string="State" domain="[]" context="{'group_by':'state'}"/>
|
<filter string="State" domain="[]" context="{'group_by':'state'}"/>
|
||||||
</group>
|
</group>
|
||||||
</search>
|
</search>
|
||||||
|
@ -113,10 +111,7 @@
|
||||||
<field name="inherit_id" ref="stock.view_picking_form"/>
|
<field name="inherit_id" ref="stock.view_picking_form"/>
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<xpath expr="//field[@name='picking_type_id']" position="after">
|
<xpath expr="//field[@name='picking_type_id']" position="after">
|
||||||
<field name="wave_id"/>
|
<field name="wave_id" domain="[('state', 'not in', ('done', 'cancel'))]"/>
|
||||||
</xpath>
|
|
||||||
<xpath expr="//field[@name='move_type']" position="after">
|
|
||||||
<field name="wave_type_ids" widget="many2many_tags"/>
|
|
||||||
</xpath>
|
</xpath>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
@ -126,7 +121,6 @@
|
||||||
<field name="inherit_id" ref="stock.vpicktree"/>
|
<field name="inherit_id" ref="stock.vpicktree"/>
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<xpath expr="//field[@name='picking_type_id']" position="after">
|
<xpath expr="//field[@name='picking_type_id']" position="after">
|
||||||
<field name="wave_type_ids" invisible="1"/>
|
|
||||||
<field name="wave_id"/>
|
<field name="wave_id"/>
|
||||||
</xpath>
|
</xpath>
|
||||||
</field>
|
</field>
|
||||||
|
@ -139,22 +133,8 @@
|
||||||
<xpath expr="//filter[@string='Picking Type']" position="after">
|
<xpath expr="//filter[@string='Picking Type']" position="after">
|
||||||
<filter string="Wave" domain="[]" context="{'group_by':'wave_id'}"/>
|
<filter string="Wave" domain="[]" context="{'group_by':'wave_id'}"/>
|
||||||
</xpath>
|
</xpath>
|
||||||
<xpath expr="//field[@name='picking_type_id']" position="after">
|
|
||||||
<field name="wave_type_ids"/>
|
|
||||||
</xpath>
|
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<record model="ir.ui.view" id="partner_wave_type">
|
|
||||||
<field name="name">partner.wave.type.view</field>
|
|
||||||
<field name="model">res.partner</field>
|
|
||||||
<field name="inherit_id" ref="base.view_partner_form" />
|
|
||||||
<field name="arch" type="xml">
|
|
||||||
<xpath expr="//field[@name='active']" position="after">
|
|
||||||
<field name="wave_type_ids" widget="many2many_tags"/>
|
|
||||||
</xpath>
|
|
||||||
</field>
|
|
||||||
</record>
|
|
||||||
|
|
||||||
</data>
|
</data>
|
||||||
</openerp>
|
</openerp>
|
||||||
|
|
Loading…
Reference in New Issue