[MERGE] trunk-methflow-thu: use model methods to interact with the worflow instances of records
bzr revid: rco@openerp.com-20130213105919-gei0qgh0l0kbn61g
This commit is contained in:
commit
c442dc824e
|
@ -23,7 +23,6 @@ import time
|
||||||
from lxml import etree
|
from lxml import etree
|
||||||
import openerp.addons.decimal_precision as dp
|
import openerp.addons.decimal_precision as dp
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
from openerp import pooler
|
from openerp import pooler
|
||||||
from openerp.osv import fields, osv, orm
|
from openerp.osv import fields, osv, orm
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
@ -80,11 +79,10 @@ class account_invoice(osv.osv):
|
||||||
|
|
||||||
def _reconciled(self, cr, uid, ids, name, args, context=None):
|
def _reconciled(self, cr, uid, ids, name, args, context=None):
|
||||||
res = {}
|
res = {}
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for inv in self.browse(cr, uid, ids, context=context):
|
for inv in self.browse(cr, uid, ids, context=context):
|
||||||
res[inv.id] = self.test_paid(cr, uid, [inv.id])
|
res[inv.id] = self.test_paid(cr, uid, [inv.id])
|
||||||
if not res[inv.id] and inv.state == 'paid':
|
if not res[inv.id] and inv.state == 'paid':
|
||||||
wf_service.trg_validate(uid, 'account.invoice', inv.id, 'open_test', cr)
|
self.signal_open_test(cr, uid, [inv.id])
|
||||||
return res
|
return res
|
||||||
|
|
||||||
def _get_reference_type(self, cr, uid, context=None):
|
def _get_reference_type(self, cr, uid, context=None):
|
||||||
|
@ -638,10 +636,8 @@ class account_invoice(osv.osv):
|
||||||
# go from canceled state to draft state
|
# go from canceled state to draft state
|
||||||
def action_cancel_draft(self, cr, uid, ids, *args):
|
def action_cancel_draft(self, cr, uid, ids, *args):
|
||||||
self.write(cr, uid, ids, {'state':'draft'})
|
self.write(cr, uid, ids, {'state':'draft'})
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.delete_workflow(cr, uid, ids)
|
||||||
for inv_id in ids:
|
self.create_workflow(cr, uid, ids)
|
||||||
wf_service.trg_delete(uid, 'account.invoice', inv_id, cr)
|
|
||||||
wf_service.trg_create(uid, 'account.invoice', inv_id, cr)
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
# Workflow stuff
|
# Workflow stuff
|
||||||
|
|
|
@ -23,7 +23,6 @@ import time
|
||||||
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
from openerp import netsvc
|
|
||||||
|
|
||||||
class account_invoice_refund(osv.osv_memory):
|
class account_invoice_refund(osv.osv_memory):
|
||||||
|
|
||||||
|
@ -90,7 +89,6 @@ class account_invoice_refund(osv.osv_memory):
|
||||||
account_m_line_obj = self.pool.get('account.move.line')
|
account_m_line_obj = self.pool.get('account.move.line')
|
||||||
mod_obj = self.pool.get('ir.model.data')
|
mod_obj = self.pool.get('ir.model.data')
|
||||||
act_obj = self.pool.get('ir.actions.act_window')
|
act_obj = self.pool.get('ir.actions.act_window')
|
||||||
wf_service = netsvc.LocalService('workflow')
|
|
||||||
inv_tax_obj = self.pool.get('account.invoice.tax')
|
inv_tax_obj = self.pool.get('account.invoice.tax')
|
||||||
inv_line_obj = self.pool.get('account.invoice.line')
|
inv_line_obj = self.pool.get('account.invoice.line')
|
||||||
res_users_obj = self.pool.get('res.users')
|
res_users_obj = self.pool.get('res.users')
|
||||||
|
@ -161,8 +159,7 @@ class account_invoice_refund(osv.osv_memory):
|
||||||
to_reconcile_ids[line.account_id.id] = [line.id]
|
to_reconcile_ids[line.account_id.id] = [line.id]
|
||||||
if type(line.reconcile_id) != osv.orm.browse_null:
|
if type(line.reconcile_id) != osv.orm.browse_null:
|
||||||
reconcile_obj.unlink(cr, uid, line.reconcile_id.id)
|
reconcile_obj.unlink(cr, uid, line.reconcile_id.id)
|
||||||
wf_service.trg_validate(uid, 'account.invoice', \
|
inv_obj.signal_invoice_open(cr, uid, [refund.id])
|
||||||
refund.id, 'invoice_open', cr)
|
|
||||||
refund = inv_obj.browse(cr, uid, refund_id[0], context=context)
|
refund = inv_obj.browse(cr, uid, refund_id[0], context=context)
|
||||||
for tmpline in refund.move_id.line_id:
|
for tmpline in refund.move_id.line_id:
|
||||||
if tmpline.account_id.id == inv.account_id.id:
|
if tmpline.account_id.id == inv.account_id.id:
|
||||||
|
|
|
@ -21,7 +21,6 @@
|
||||||
|
|
||||||
from openerp.osv import osv
|
from openerp.osv import osv
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
from openerp import netsvc
|
|
||||||
from openerp import pooler
|
from openerp import pooler
|
||||||
|
|
||||||
class account_invoice_confirm(osv.osv_memory):
|
class account_invoice_confirm(osv.osv_memory):
|
||||||
|
@ -33,16 +32,16 @@ class account_invoice_confirm(osv.osv_memory):
|
||||||
_description = "Confirm the selected invoices"
|
_description = "Confirm the selected invoices"
|
||||||
|
|
||||||
def invoice_confirm(self, cr, uid, ids, context=None):
|
def invoice_confirm(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService('workflow')
|
|
||||||
if context is None:
|
if context is None:
|
||||||
context = {}
|
context = {}
|
||||||
pool_obj = pooler.get_pool(cr.dbname)
|
pool_obj = pooler.get_pool(cr.dbname)
|
||||||
data_inv = pool_obj.get('account.invoice').read(cr, uid, context['active_ids'], ['state'], context=context)
|
account_invoice_obj = pool_obj.get('account.invoice')
|
||||||
|
data_inv = account_invoice_obj.read(cr, uid, context['active_ids'], ['state'], context=context)
|
||||||
for record in data_inv:
|
for record in data_inv:
|
||||||
if record['state'] not in ('draft','proforma','proforma2'):
|
if record['state'] not in ('draft','proforma','proforma2'):
|
||||||
raise osv.except_osv(_('Warning!'), _("Selected invoice(s) cannot be confirmed as they are not in 'Draft' or 'Pro-Forma' state."))
|
raise osv.except_osv(_('Warning!'), _("Selected invoice(s) cannot be confirmed as they are not in 'Draft' or 'Pro-Forma' state."))
|
||||||
wf_service.trg_validate(uid, 'account.invoice', record['id'], 'invoice_open', cr)
|
account_invoice_obj.signal_invoice_open(cr, uid, [ record['id'] ])
|
||||||
|
|
||||||
return {'type': 'ir.actions.act_window_close'}
|
return {'type': 'ir.actions.act_window_close'}
|
||||||
|
|
||||||
account_invoice_confirm()
|
account_invoice_confirm()
|
||||||
|
@ -59,14 +58,13 @@ class account_invoice_cancel(osv.osv_memory):
|
||||||
def invoice_cancel(self, cr, uid, ids, context=None):
|
def invoice_cancel(self, cr, uid, ids, context=None):
|
||||||
if context is None:
|
if context is None:
|
||||||
context = {}
|
context = {}
|
||||||
wf_service = netsvc.LocalService('workflow')
|
|
||||||
pool_obj = pooler.get_pool(cr.dbname)
|
pool_obj = pooler.get_pool(cr.dbname)
|
||||||
data_inv = pool_obj.get('account.invoice').read(cr, uid, context['active_ids'], ['state'], context=context)
|
account_invoice_obj = pool_obj.get('account.invoice')
|
||||||
|
data_inv = account_invoice_obj.read(cr, uid, context['active_ids'], ['state'], context=context)
|
||||||
for record in data_inv:
|
for record in data_inv:
|
||||||
if record['state'] in ('cancel','paid'):
|
if record['state'] in ('cancel','paid'):
|
||||||
raise osv.except_osv(_('Warning!'), _("Selected invoice(s) cannot be cancelled as they are already in 'Cancelled' or 'Done' state."))
|
raise osv.except_osv(_('Warning!'), _("Selected invoice(s) cannot be cancelled as they are already in 'Cancelled' or 'Done' state."))
|
||||||
wf_service.trg_validate(uid, 'account.invoice', record['id'], 'invoice_cancel', cr)
|
account_invoice_obj.signal_invoice_cancel(cr , uid, [record['id']])
|
||||||
return {'type': 'ir.actions.act_window_close'}
|
return {'type': 'ir.actions.act_window_close'}
|
||||||
|
|
||||||
account_invoice_cancel()
|
account_invoice_cancel()
|
||||||
|
|
|
@ -35,8 +35,7 @@ class account_state_open(osv.osv_memory):
|
||||||
data_inv = obj_invoice.browse(cr, uid, context['active_ids'][0], context=context)
|
data_inv = obj_invoice.browse(cr, uid, context['active_ids'][0], context=context)
|
||||||
if data_inv.reconciled:
|
if data_inv.reconciled:
|
||||||
raise osv.except_osv(_('Warning!'), _('Invoice is already reconciled.'))
|
raise osv.except_osv(_('Warning!'), _('Invoice is already reconciled.'))
|
||||||
wf_service = netsvc.LocalService("workflow")
|
obj_invoice.signal_open_test(cr, uid, context['active_ids'][0])
|
||||||
wf_service.trg_validate(uid, 'account.invoice', context['active_ids'][0], 'open_test', cr)
|
|
||||||
return {'type': 'ir.actions.act_window_close'}
|
return {'type': 'ir.actions.act_window_close'}
|
||||||
|
|
||||||
account_state_open()
|
account_state_open()
|
||||||
|
|
|
@ -44,8 +44,7 @@ class TestAccountFollowup(TransactionCase):
|
||||||
'quantity': 5,
|
'quantity': 5,
|
||||||
'price_unit':200
|
'price_unit':200
|
||||||
})]})
|
})]})
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.registry('account.invoice').signal_invoice_open(cr, uid, [self.invoice_id])
|
||||||
wf_service.trg_validate(uid, 'account.invoice', self.invoice_id, 'invoice_open', cr)
|
|
||||||
|
|
||||||
self.voucher = self.registry("account.voucher")
|
self.voucher = self.registry("account.voucher")
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,6 @@ import logging
|
||||||
import time
|
import time
|
||||||
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp import netsvc
|
|
||||||
|
|
||||||
_logger = logging.getLogger(__name__)
|
_logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
@ -120,9 +119,7 @@ class payment_order(osv.osv):
|
||||||
|
|
||||||
def set_to_draft(self, cr, uid, ids, *args):
|
def set_to_draft(self, cr, uid, ids, *args):
|
||||||
self.write(cr, uid, ids, {'state': 'draft'})
|
self.write(cr, uid, ids, {'state': 'draft'})
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.create_workflow(cr, uid, ids)
|
||||||
for id in ids:
|
|
||||||
wf_service.trg_create(uid, 'payment.order', id, cr)
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def action_open(self, cr, uid, ids, *args):
|
def action_open(self, cr, uid, ids, *args):
|
||||||
|
@ -135,9 +132,8 @@ class payment_order(osv.osv):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def set_done(self, cr, uid, ids, *args):
|
def set_done(self, cr, uid, ids, *args):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
self.write(cr, uid, ids, {'date_done': time.strftime('%Y-%m-%d')})
|
self.write(cr, uid, ids, {'date_done': time.strftime('%Y-%m-%d')})
|
||||||
wf_service.trg_validate(uid, 'payment.order', ids[0], 'done', cr)
|
self.signal_done(cr, uid, [ids[0]])
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def copy(self, cr, uid, id, default=None, context=None):
|
def copy(self, cr, uid, id, default=None, context=None):
|
||||||
|
|
|
@ -22,7 +22,6 @@
|
||||||
import time
|
import time
|
||||||
from lxml import etree
|
from lxml import etree
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
import openerp.addons.decimal_precision as dp
|
import openerp.addons.decimal_precision as dp
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
@ -820,10 +819,7 @@ class account_voucher(osv.osv):
|
||||||
return vals
|
return vals
|
||||||
|
|
||||||
def button_proforma_voucher(self, cr, uid, ids, context=None):
|
def button_proforma_voucher(self, cr, uid, ids, context=None):
|
||||||
context = context or {}
|
self.signal_proforma_voucher(cr, uid, ids)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for vid in ids:
|
|
||||||
wf_service.trg_validate(uid, 'account.voucher', vid, 'proforma_voucher', cr)
|
|
||||||
return {'type': 'ir.actions.act_window_close'}
|
return {'type': 'ir.actions.act_window_close'}
|
||||||
|
|
||||||
def proforma_voucher(self, cr, uid, ids, context=None):
|
def proforma_voucher(self, cr, uid, ids, context=None):
|
||||||
|
@ -831,9 +827,7 @@ class account_voucher(osv.osv):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def action_cancel_draft(self, cr, uid, ids, context=None):
|
def action_cancel_draft(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.create_workflow(cr, uid, ids)
|
||||||
for voucher_id in ids:
|
|
||||||
wf_service.trg_create(uid, 'account.voucher', voucher_id, cr)
|
|
||||||
self.write(cr, uid, ids, {'state':'draft'})
|
self.write(cr, uid, ids, {'state':'draft'})
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
@ -1508,7 +1502,6 @@ class account_bank_statement(osv.osv):
|
||||||
|
|
||||||
def create_move_from_st_line(self, cr, uid, st_line_id, company_currency_id, next_number, context=None):
|
def create_move_from_st_line(self, cr, uid, st_line_id, company_currency_id, next_number, context=None):
|
||||||
voucher_obj = self.pool.get('account.voucher')
|
voucher_obj = self.pool.get('account.voucher')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
move_line_obj = self.pool.get('account.move.line')
|
move_line_obj = self.pool.get('account.move.line')
|
||||||
bank_st_line_obj = self.pool.get('account.bank.statement.line')
|
bank_st_line_obj = self.pool.get('account.bank.statement.line')
|
||||||
st_line = bank_st_line_obj.browse(cr, uid, st_line_id, context=context)
|
st_line = bank_st_line_obj.browse(cr, uid, st_line_id, context=context)
|
||||||
|
@ -1516,7 +1509,7 @@ class account_bank_statement(osv.osv):
|
||||||
voucher_obj.write(cr, uid, [st_line.voucher_id.id], {'number': next_number}, context=context)
|
voucher_obj.write(cr, uid, [st_line.voucher_id.id], {'number': next_number}, context=context)
|
||||||
if st_line.voucher_id.state == 'cancel':
|
if st_line.voucher_id.state == 'cancel':
|
||||||
voucher_obj.action_cancel_draft(cr, uid, [st_line.voucher_id.id], context=context)
|
voucher_obj.action_cancel_draft(cr, uid, [st_line.voucher_id.id], context=context)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', st_line.voucher_id.id, 'proforma_voucher', cr)
|
voucher_obj.signal_proforma_voucher(cr, uid, [st_line.voucher_id.id])
|
||||||
|
|
||||||
v = voucher_obj.browse(cr, uid, st_line.voucher_id.id, context=context)
|
v = voucher_obj.browse(cr, uid, st_line.voucher_id.id, context=context)
|
||||||
bank_st_line_obj.write(cr, uid, [st_line_id], {
|
bank_st_line_obj.write(cr, uid, [st_line_id], {
|
||||||
|
|
|
@ -159,8 +159,6 @@
|
||||||
I fill amounts 180 for the invoice of 200$ and 70 for the invoice of 100$>
|
I fill amounts 180 for the invoice of 200$ and 70 for the invoice of 100$>
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
import time
|
|
||||||
from openerp import netsvc
|
|
||||||
vals = {}
|
vals = {}
|
||||||
voucher_id = self.browse(cr, uid, ref('account_voucher_1_case1'))
|
voucher_id = self.browse(cr, uid, ref('account_voucher_1_case1'))
|
||||||
data = []
|
data = []
|
||||||
|
@ -183,10 +181,8 @@
|
||||||
I confirm the voucher
|
I confirm the voucher
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 1 USD/USD'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 1 USD/USD'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that the move of my first voucher is valid
|
I check that the move of my first voucher is valid
|
||||||
-
|
-
|
||||||
|
@ -257,8 +253,6 @@
|
||||||
I fill amounts 20 for the invoice of 200$ and 30 for the invoice of 100$
|
I fill amounts 20 for the invoice of 200$ and 30 for the invoice of 100$
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
import time
|
|
||||||
from openerp import netsvc
|
|
||||||
vals = {}
|
vals = {}
|
||||||
voucher_id = self.browse(cr, uid, ref('account_voucher_2_case1'))
|
voucher_id = self.browse(cr, uid, ref('account_voucher_2_case1'))
|
||||||
data = []
|
data = []
|
||||||
|
@ -281,10 +275,8 @@
|
||||||
I confirm the voucher
|
I confirm the voucher
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 1'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 1'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that the move of my second voucher is valid
|
I check that the move of my second voucher is valid
|
||||||
-
|
-
|
||||||
|
|
|
@ -131,8 +131,6 @@
|
||||||
I fill amounts 180 for the invoice of 200$ and 70 for the invoice of 100$
|
I fill amounts 180 for the invoice of 200$ and 70 for the invoice of 100$
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
import time
|
|
||||||
from openerp import netsvc
|
|
||||||
vals = {}
|
vals = {}
|
||||||
voucher_id = self.browse(cr, uid, ref('account_voucher_1_case2_suppl'))
|
voucher_id = self.browse(cr, uid, ref('account_voucher_1_case2_suppl'))
|
||||||
data = []
|
data = []
|
||||||
|
@ -162,10 +160,8 @@
|
||||||
I confirm the voucher
|
I confirm the voucher
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 2 SUPPL USD/EUR'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 2 SUPPL USD/EUR'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that the move of my voucher is valid
|
I check that the move of my voucher is valid
|
||||||
-
|
-
|
||||||
|
@ -237,8 +233,6 @@
|
||||||
I fill amounts 20 for the invoice of 200$ and 30 for the invoice of 100$>
|
I fill amounts 20 for the invoice of 200$ and 30 for the invoice of 100$>
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
import time
|
|
||||||
from openerp import netsvc
|
|
||||||
vals = {}
|
vals = {}
|
||||||
voucher_id = self.browse(cr, uid, ref('account_voucher_2_case2_suppl'))
|
voucher_id = self.browse(cr, uid, ref('account_voucher_2_case2_suppl'))
|
||||||
data = []
|
data = []
|
||||||
|
@ -268,10 +262,8 @@
|
||||||
I confirm the voucher
|
I confirm the voucher
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 2 SUPPL USD/EUR'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 2 SUPPL USD/EUR'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that my voucher state is posted
|
I check that my voucher state is posted
|
||||||
-
|
-
|
||||||
|
|
|
@ -182,8 +182,7 @@
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
from openerp import netsvc
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 2 USD/EUR DR EUR'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 2 USD/EUR DR EUR'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that the move of my voucher is valid
|
I check that the move of my voucher is valid
|
||||||
-
|
-
|
||||||
|
@ -258,8 +257,7 @@
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
from openerp import netsvc
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 2 SUPPL USD/EUR DR EUR'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 2 SUPPL USD/EUR DR EUR'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that my voucher state is posted
|
I check that my voucher state is posted
|
||||||
-
|
-
|
||||||
|
|
|
@ -163,8 +163,6 @@
|
||||||
I fill amounts 130 for the invoice of 200$ and 70 for the invoice of 100$>
|
I fill amounts 130 for the invoice of 200$ and 70 for the invoice of 100$>
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
import time
|
|
||||||
from openerp import netsvc
|
|
||||||
vals = {}
|
vals = {}
|
||||||
voucher_id = self.browse(cr, uid, ref('account_voucher_1_case2b'))
|
voucher_id = self.browse(cr, uid, ref('account_voucher_1_case2b'))
|
||||||
data = []
|
data = []
|
||||||
|
@ -180,10 +178,8 @@
|
||||||
I confirm the voucher
|
I confirm the voucher
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 2 USD/EUR DR USD'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 2 USD/EUR DR USD'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that the move of my voucher is valid
|
I check that the move of my voucher is valid
|
||||||
-
|
-
|
||||||
|
@ -247,8 +243,6 @@
|
||||||
and I fully reconcil the 2 previous invoices
|
and I fully reconcil the 2 previous invoices
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
import time
|
|
||||||
from openerp import netsvc
|
|
||||||
vals = {}
|
vals = {}
|
||||||
voucher_id = self.browse(cr, uid, ref('account_voucher_2_case2b'))
|
voucher_id = self.browse(cr, uid, ref('account_voucher_2_case2b'))
|
||||||
data = []
|
data = []
|
||||||
|
@ -271,10 +265,8 @@
|
||||||
I confirm the voucher
|
I confirm the voucher
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 2 SUPPL USD/EUR DR USD'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 2 SUPPL USD/EUR DR USD'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that my voucher state is posted
|
I check that my voucher state is posted
|
||||||
-
|
-
|
||||||
|
|
|
@ -118,8 +118,6 @@
|
||||||
I fill amounts 100 for the invoice of 150€ and 20 for the invoice of 80€
|
I fill amounts 100 for the invoice of 150€ and 20 for the invoice of 80€
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
import time
|
|
||||||
from openerp import netsvc
|
|
||||||
vals = {}
|
vals = {}
|
||||||
voucher_id = self.browse(cr, uid, ref('account_voucher_1_case3'))
|
voucher_id = self.browse(cr, uid, ref('account_voucher_1_case3'))
|
||||||
data = []
|
data = []
|
||||||
|
@ -142,10 +140,8 @@
|
||||||
I confirm the voucher
|
I confirm the voucher
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 3'),('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 3'),('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that the move of my first voucher is valid
|
I check that the move of my first voucher is valid
|
||||||
-
|
-
|
||||||
|
@ -209,8 +205,6 @@
|
||||||
I fill amounts 50 for the invoice of 150€ and 70 for the invoice of 80€
|
I fill amounts 50 for the invoice of 150€ and 70 for the invoice of 80€
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
import time
|
|
||||||
from openerp import netsvc
|
|
||||||
vals = {}
|
vals = {}
|
||||||
voucher_id = self.browse(cr, uid, ref('account_voucher_2_case3'))
|
voucher_id = self.browse(cr, uid, ref('account_voucher_2_case3'))
|
||||||
data = []
|
data = []
|
||||||
|
@ -233,10 +227,8 @@
|
||||||
I confirm the voucher
|
I confirm the voucher
|
||||||
-
|
-
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 3'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'Second payment: Case 3'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that the move of my second voucher is valid
|
I check that the move of my second voucher is valid
|
||||||
-
|
-
|
||||||
|
|
|
@ -144,8 +144,7 @@
|
||||||
!python {model: account.voucher}: |
|
!python {model: account.voucher}: |
|
||||||
from openerp import netsvc
|
from openerp import netsvc
|
||||||
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 4'), ('partner_id', '=', ref('base.res_partner_19'))])
|
voucher = self.search(cr, uid, [('name', '=', 'First payment: Case 4'), ('partner_id', '=', ref('base.res_partner_19'))])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, voucher)
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher[0], 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that the move of my voucher is valid
|
I check that the move of my voucher is valid
|
||||||
-
|
-
|
||||||
|
|
|
@ -61,8 +61,7 @@
|
||||||
id = self.create(cr, uid, vals)
|
id = self.create(cr, uid, vals)
|
||||||
voucher_id = self.browse(cr, uid, id)
|
voucher_id = self.browse(cr, uid, id)
|
||||||
assert (voucher_id.state=='draft'), "Voucher is not in draft state"
|
assert (voucher_id.state=='draft'), "Voucher is not in draft state"
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, [voucher_id.id])
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher_id.id, 'proforma_voucher', cr)
|
|
||||||
|
|
||||||
-
|
-
|
||||||
Finally i will Confirm the state of the invoice is paid
|
Finally i will Confirm the state of the invoice is paid
|
||||||
|
|
|
@ -65,8 +65,7 @@
|
||||||
id = self.create(cr, uid, vals)
|
id = self.create(cr, uid, vals)
|
||||||
voucher_id = self.browse(cr, uid, id)
|
voucher_id = self.browse(cr, uid, id)
|
||||||
assert (voucher_id.state=='draft'), "Voucher is not in draft state"
|
assert (voucher_id.state=='draft'), "Voucher is not in draft state"
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_proforma_voucher(cr, uid, [voucher_id.id])
|
||||||
wf_service.trg_validate(uid, 'account.voucher', voucher_id.id, 'proforma_voucher', cr)
|
|
||||||
-
|
-
|
||||||
I check that move lines are reconciled meaning voucher is paid
|
I check that move lines are reconciled meaning voucher is paid
|
||||||
-
|
-
|
||||||
|
|
|
@ -21,7 +21,6 @@
|
||||||
|
|
||||||
import time
|
import time
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
|
||||||
|
@ -152,7 +151,6 @@ class hr_expense_expense(osv.osv):
|
||||||
account_journal = self.pool.get('account.journal')
|
account_journal = self.pool.get('account.journal')
|
||||||
voucher_obj = self.pool.get('account.voucher')
|
voucher_obj = self.pool.get('account.voucher')
|
||||||
currency_obj = self.pool.get('res.currency')
|
currency_obj = self.pool.get('res.currency')
|
||||||
wkf_service = netsvc.LocalService("workflow")
|
|
||||||
if context is None:
|
if context is None:
|
||||||
context = {}
|
context = {}
|
||||||
for exp in self.browse(cr, uid, ids, context=context):
|
for exp in self.browse(cr, uid, ids, context=context):
|
||||||
|
|
|
@ -24,10 +24,9 @@
|
||||||
import datetime
|
import datetime
|
||||||
import time
|
import time
|
||||||
from itertools import groupby
|
from itertools import groupby
|
||||||
from operator import itemgetter
|
from operator import attrgetter, itemgetter
|
||||||
|
|
||||||
import math
|
import math
|
||||||
from openerp import netsvc
|
|
||||||
from openerp import tools
|
from openerp import tools
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
@ -304,10 +303,8 @@ class hr_holidays(osv.osv):
|
||||||
'manager_id': False,
|
'manager_id': False,
|
||||||
'manager_id2': False,
|
'manager_id2': False,
|
||||||
})
|
})
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.delete_workflow(cr, uid, ids)
|
||||||
for id in ids:
|
self.create_workflow(cr, uid, ids)
|
||||||
wf_service.trg_delete(uid, 'hr.holidays', id, cr)
|
|
||||||
wf_service.trg_create(uid, 'hr.holidays', id, cr)
|
|
||||||
to_unlink = []
|
to_unlink = []
|
||||||
for record in self.browse(cr, uid, ids, context=context):
|
for record in self.browse(cr, uid, ids, context=context):
|
||||||
for record2 in record.linked_request_ids:
|
for record2 in record.linked_request_ids:
|
||||||
|
@ -370,11 +367,11 @@ class hr_holidays(osv.osv):
|
||||||
'employee_id': emp.id
|
'employee_id': emp.id
|
||||||
}
|
}
|
||||||
leave_ids.append(self.create(cr, uid, vals, context=None))
|
leave_ids.append(self.create(cr, uid, vals, context=None))
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for leave_id in leave_ids:
|
for leave_id in leave_ids:
|
||||||
wf_service.trg_validate(uid, 'hr.holidays', leave_id, 'confirm', cr)
|
# TODO is it necessary to interleave the calls?
|
||||||
wf_service.trg_validate(uid, 'hr.holidays', leave_id, 'validate', cr)
|
self.signal_confirm(cr, uid, [leave_id])
|
||||||
wf_service.trg_validate(uid, 'hr.holidays', leave_id, 'second_validate', cr)
|
self.signal_validate(cr, uid, [leave_id])
|
||||||
|
self.signal_second_validate(cr, uid, [leave_id])
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def holidays_confirm(self, cr, uid, ids, context=None):
|
def holidays_confirm(self, cr, uid, ids, context=None):
|
||||||
|
@ -404,9 +401,7 @@ class hr_holidays(osv.osv):
|
||||||
meeting_obj.unlink(cr, uid, [record.meeting_id.id])
|
meeting_obj.unlink(cr, uid, [record.meeting_id.id])
|
||||||
|
|
||||||
# If a category that created several holidays, cancel all related
|
# If a category that created several holidays, cancel all related
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_refuse(cr, uid, map(attrgetter('id'), record.linked_request_ids or []))
|
||||||
for request in record.linked_request_ids or []:
|
|
||||||
wf_service.trg_validate(uid, 'hr.holidays', request.id, 'refuse', cr)
|
|
||||||
|
|
||||||
self._remove_resource_leave(cr, uid, ids, context=context)
|
self._remove_resource_leave(cr, uid, ids, context=context)
|
||||||
return True
|
return True
|
||||||
|
@ -478,10 +473,9 @@ class hr_employee(osv.osv):
|
||||||
leave_id = holiday_obj.create(cr, uid, {'name': _('Leave Request for %s') % employee.name, 'employee_id': employee.id, 'holiday_status_id': status_id, 'type': 'remove', 'holiday_type': 'employee', 'number_of_days_temp': abs(diff)}, context=context)
|
leave_id = holiday_obj.create(cr, uid, {'name': _('Leave Request for %s') % employee.name, 'employee_id': employee.id, 'holiday_status_id': status_id, 'type': 'remove', 'holiday_type': 'employee', 'number_of_days_temp': abs(diff)}, context=context)
|
||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
wf_service = netsvc.LocalService("workflow")
|
holidays_obj.signal_confirm(cr, uid, [leave_id])
|
||||||
wf_service.trg_validate(uid, 'hr.holidays', leave_id, 'confirm', cr)
|
holidays_obj.signal_validate(cr, uid, [leave_id])
|
||||||
wf_service.trg_validate(uid, 'hr.holidays', leave_id, 'validate', cr)
|
holidays_obj.signal_second_validate(cr, uid, [leave_id])
|
||||||
wf_service.trg_validate(uid, 'hr.holidays', leave_id, 'second_validate', cr)
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _get_remaining_days(self, cr, uid, ids, name, args, context=None):
|
def _get_remaining_days(self, cr, uid, ids, name, args, context=None):
|
||||||
|
|
|
@ -18,10 +18,8 @@
|
||||||
I again set to draft and then confirm.
|
I again set to draft and then confirm.
|
||||||
-
|
-
|
||||||
!python {model: hr.holidays}: |
|
!python {model: hr.holidays}: |
|
||||||
from openerp import netsvc
|
self.set_to_draft(cr, uid, [ref('hr_holidays_employee1_cl')])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_confirm(cr, uid, [ref('hr_holidays_employee1_cl')])
|
||||||
self.set_to_draft(cr, uid, [ref('hr_holidays_employee1_cl')])
|
|
||||||
wf_service.trg_validate(uid, 'hr.holidays', ref('hr_holidays_employee1_cl'), 'confirm', cr)
|
|
||||||
-
|
-
|
||||||
I validate the holiday request by clicking on "To Approve" button.
|
I validate the holiday request by clicking on "To Approve" button.
|
||||||
-
|
-
|
||||||
|
|
|
@ -26,7 +26,6 @@ from datetime import datetime
|
||||||
from datetime import timedelta
|
from datetime import timedelta
|
||||||
from dateutil import relativedelta
|
from dateutil import relativedelta
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp import tools
|
from openerp import tools
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
@ -331,12 +330,11 @@ class hr_payslip(osv.osv):
|
||||||
|
|
||||||
def refund_sheet(self, cr, uid, ids, context=None):
|
def refund_sheet(self, cr, uid, ids, context=None):
|
||||||
mod_obj = self.pool.get('ir.model.data')
|
mod_obj = self.pool.get('ir.model.data')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for payslip in self.browse(cr, uid, ids, context=context):
|
for payslip in self.browse(cr, uid, ids, context=context):
|
||||||
id_copy = self.copy(cr, uid, payslip.id, {'credit_note': True, 'name': _('Refund: ')+payslip.name}, context=context)
|
id_copy = self.copy(cr, uid, payslip.id, {'credit_note': True, 'name': _('Refund: ')+payslip.name}, context=context)
|
||||||
self.compute_sheet(cr, uid, [id_copy], context=context)
|
self.compute_sheet(cr, uid, [id_copy], context=context)
|
||||||
wf_service.trg_validate(uid, 'hr.payslip', id_copy, 'hr_verify_sheet', cr)
|
self.signal_hr_verify_sheet(cr, uid, [id_copy])
|
||||||
wf_service.trg_validate(uid, 'hr.payslip', id_copy, 'process_sheet', cr)
|
self.signal_process_sheet(cr, uid, [id_copy])
|
||||||
|
|
||||||
form_id = mod_obj.get_object_reference(cr, uid, 'hr_payroll', 'view_hr_payslip_form')
|
form_id = mod_obj.get_object_reference(cr, uid, 'hr_payroll', 'view_hr_payslip_form')
|
||||||
form_res = form_id and form_id[1] or False
|
form_res = form_id and form_id[1] or False
|
||||||
|
|
|
@ -104,10 +104,8 @@
|
||||||
I want to check cancel button. So I first cancel the sheet then make it set to draft.
|
I want to check cancel button. So I first cancel the sheet then make it set to draft.
|
||||||
-
|
-
|
||||||
!python {model: hr.payslip}: |
|
!python {model: hr.payslip}: |
|
||||||
from openerp import netsvc
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
self.cancel_sheet(cr, uid, [ref("hr_payslip_0")], None)
|
self.cancel_sheet(cr, uid, [ref("hr_payslip_0")], None)
|
||||||
wf_service.trg_validate(uid, 'hr.payslip', ref("hr_payslip_0"), 'draft', cr)
|
self.signal_draft(cr, uid, [ref("hr_payslip_0")])
|
||||||
-
|
-
|
||||||
Then I click on the "Confirm" button.
|
Then I click on the "Confirm" button.
|
||||||
-
|
-
|
||||||
|
|
|
@ -115,6 +115,4 @@
|
||||||
I click on "Create Invoice" button to create Invoice and validate the invoice.
|
I click on "Create Invoice" button to create Invoice and validate the invoice.
|
||||||
-
|
-
|
||||||
!python {model: hr.timesheet.invoice.create.final}: |
|
!python {model: hr.timesheet.invoice.create.final}: |
|
||||||
from openerp import netsvc
|
|
||||||
wkf_service = netsvc.LocalService("workflow")
|
|
||||||
res = self.do_create(cr, uid, [ref("hr_timesheet_invoice_create_final_0")], {"active_ids": [ref("account.analytic_agrolait")]})
|
res = self.do_create(cr, uid, [ref("hr_timesheet_invoice_create_final_0")], {"active_ids": [ref("account.analytic_agrolait")]})
|
||||||
|
|
|
@ -114,6 +114,4 @@
|
||||||
I click on "Create Invoice" button to create Invoice and validate the invoice.
|
I click on "Create Invoice" button to create Invoice and validate the invoice.
|
||||||
-
|
-
|
||||||
!python {model: hr.timesheet.invoice.create.final}: |
|
!python {model: hr.timesheet.invoice.create.final}: |
|
||||||
from openerp import netsvc
|
|
||||||
wkf_service = netsvc.LocalService("workflow")
|
|
||||||
res = self.do_create(cr, uid, [ref("hr_timesheet_invoice_create_final_0")], {"active_ids": [ref("account.analytic_agrolait")]})
|
res = self.do_create(cr, uid, [ref("hr_timesheet_invoice_create_final_0")], {"active_ids": [ref("account.analytic_agrolait")]})
|
||||||
|
|
|
@ -25,7 +25,6 @@ from dateutil.relativedelta import relativedelta
|
||||||
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
from openerp import netsvc
|
|
||||||
|
|
||||||
class hr_timesheet_sheet(osv.osv):
|
class hr_timesheet_sheet(osv.osv):
|
||||||
_name = "hr_timesheet_sheet.sheet"
|
_name = "hr_timesheet_sheet.sheet"
|
||||||
|
@ -93,8 +92,7 @@ class hr_timesheet_sheet(osv.osv):
|
||||||
self.check_employee_attendance_state(cr, uid, sheet.id, context=context)
|
self.check_employee_attendance_state(cr, uid, sheet.id, context=context)
|
||||||
di = sheet.user_id.company_id.timesheet_max_difference
|
di = sheet.user_id.company_id.timesheet_max_difference
|
||||||
if (abs(sheet.total_difference) < di) or not di:
|
if (abs(sheet.total_difference) < di) or not di:
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_confirm(cr, uid, [sheet.id])
|
||||||
wf_service.trg_validate(uid, 'hr_timesheet_sheet.sheet', sheet.id, 'confirm', cr)
|
|
||||||
else:
|
else:
|
||||||
raise osv.except_osv(_('Warning!'), _('Please verify that the total difference of the sheet is lower than %.2f.') %(di,))
|
raise osv.except_osv(_('Warning!'), _('Please verify that the total difference of the sheet is lower than %.2f.') %(di,))
|
||||||
return True
|
return True
|
||||||
|
@ -192,9 +190,7 @@ class hr_timesheet_sheet(osv.osv):
|
||||||
|
|
||||||
def action_set_to_draft(self, cr, uid, ids, *args):
|
def action_set_to_draft(self, cr, uid, ids, *args):
|
||||||
self.write(cr, uid, ids, {'state': 'draft'})
|
self.write(cr, uid, ids, {'state': 'draft'})
|
||||||
wf_service = netsvc.LocalService('workflow')
|
self.create_workflow(cr, uid, ids)
|
||||||
for id in ids:
|
|
||||||
wf_service.trg_create(uid, self._name, id, cr)
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def name_get(self, cr, uid, ids, context=None):
|
def name_get(self, cr, uid, ids, context=None):
|
||||||
|
|
|
@ -26,7 +26,6 @@ from calendar import isleap
|
||||||
|
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp import netsvc
|
|
||||||
import openerp.addons.decimal_precision as dp
|
import openerp.addons.decimal_precision as dp
|
||||||
|
|
||||||
DATETIME_FORMAT = "%Y-%m-%d"
|
DATETIME_FORMAT = "%Y-%m-%d"
|
||||||
|
@ -179,7 +178,6 @@ class hr_payslip_run(osv.osv):
|
||||||
return res
|
return res
|
||||||
|
|
||||||
def create_advice(self, cr, uid, ids, context=None):
|
def create_advice(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
payslip_pool = self.pool.get('hr.payslip')
|
payslip_pool = self.pool.get('hr.payslip')
|
||||||
payslip_line_pool = self.pool.get('hr.payslip.line')
|
payslip_line_pool = self.pool.get('hr.payslip.line')
|
||||||
advice_pool = self.pool.get('hr.payroll.advice')
|
advice_pool = self.pool.get('hr.payroll.advice')
|
||||||
|
@ -198,8 +196,9 @@ class hr_payslip_run(osv.osv):
|
||||||
advice_id = advice_pool.create(cr, uid, advice_data, context=context)
|
advice_id = advice_pool.create(cr, uid, advice_data, context=context)
|
||||||
slip_ids = []
|
slip_ids = []
|
||||||
for slip_id in run.slip_ids:
|
for slip_id in run.slip_ids:
|
||||||
wf_service.trg_validate(uid, 'hr.payslip', slip_id.id, 'hr_verify_sheet', cr)
|
# TODO is it necessary to interleave the calls ?
|
||||||
wf_service.trg_validate(uid, 'hr.payslip', slip_id.id, 'process_sheet', cr)
|
payslip_pool.signal_hr_verify_sheet(cr, uid, [slip_id.id])
|
||||||
|
payslip_pool.signal_process_sheet(cr, uid, [slip_id.id])
|
||||||
slip_ids.append(slip_id.id)
|
slip_ids.append(slip_id.id)
|
||||||
|
|
||||||
for slip in payslip_pool.browse(cr, uid, slip_ids, context=context):
|
for slip in payslip_pool.browse(cr, uid, slip_ids, context=context):
|
||||||
|
|
|
@ -159,7 +159,7 @@ class lunch_order(osv.Model):
|
||||||
def specific_function(cr, uid, ids, context=None):
|
def specific_function(cr, uid, ids, context=None):
|
||||||
return self.add_preference(cr, uid, ids, pref_id, context=context)
|
return self.add_preference(cr, uid, ids, pref_id, context=context)
|
||||||
return specific_function
|
return specific_function
|
||||||
return super(lunch_order,self).__getattr__(self,attr)
|
return super(lunch_order, self).__getattr__(attr)
|
||||||
|
|
||||||
def fields_view_get(self, cr, uid, view_id=None, view_type=False, context=None, toolbar=False, submenu=False):
|
def fields_view_get(self, cr, uid, view_id=None, view_type=False, context=None, toolbar=False, submenu=False):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -31,19 +31,18 @@
|
||||||
I'm Opening that Invoice which is created for "Seagate".
|
I'm Opening that Invoice which is created for "Seagate".
|
||||||
-
|
-
|
||||||
!python {model: res.partner}: |
|
!python {model: res.partner}: |
|
||||||
from openerp import netsvc
|
from openerp.tools.translate import _
|
||||||
from openerp.tools.translate import _
|
invoice_pool = self.pool.get('account.invoice')
|
||||||
invoice_pool = self.pool.get('account.invoice')
|
partner_pool = self.pool.get('res.partner')
|
||||||
partner_pool = self.pool.get('res.partner')
|
membership_line_pool = self.pool.get('membership.membership_line')
|
||||||
membership_line_pool = self.pool.get('membership.membership_line')
|
membership_pool = self.pool.get('product.product')
|
||||||
membership_pool = self.pool.get('product.product')
|
|
||||||
|
membership_line_ids = membership_line_pool.search(cr, uid, [('membership_id','=',ref('product_product_membershipproduct0')),('partner','=',ref('base.res_partner_19'))])
|
||||||
|
membership_lines = membership_line_pool.browse(cr, uid, membership_line_ids)
|
||||||
|
assert membership_lines, _('Membership is not registrated.')
|
||||||
|
membership_line = membership_lines[0]
|
||||||
|
invoice_pool.signal_invoice_open(cr, uid, [membership_line.account_invoice_id.id])
|
||||||
|
|
||||||
membership_line_ids = membership_line_pool.search(cr, uid, [('membership_id','=',ref('product_product_membershipproduct0')),('partner','=',ref('base.res_partner_19'))])
|
|
||||||
membership_lines = membership_line_pool.browse(cr, uid, membership_line_ids)
|
|
||||||
assert membership_lines, _('Membership is not registrated.')
|
|
||||||
membership_line = membership_lines[0]
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
wf_service.trg_validate(uid, 'account.invoice', membership_line.account_invoice_id.id, 'invoice_open', cr)
|
|
||||||
- |
|
- |
|
||||||
I'm checking "Current membership state" of "Seagate". It is an "Invoiced Member" or not.
|
I'm checking "Current membership state" of "Seagate". It is an "Invoiced Member" or not.
|
||||||
-
|
-
|
||||||
|
|
|
@ -27,7 +27,6 @@ from openerp.osv import fields, osv
|
||||||
from openerp.tools import DEFAULT_SERVER_DATETIME_FORMAT, DATETIME_FORMATS_MAP
|
from openerp.tools import DEFAULT_SERVER_DATETIME_FORMAT, DATETIME_FORMATS_MAP
|
||||||
from openerp.tools import float_compare
|
from openerp.tools import float_compare
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
from openerp import netsvc
|
|
||||||
from openerp import tools
|
from openerp import tools
|
||||||
|
|
||||||
#----------------------------------------------------------
|
#----------------------------------------------------------
|
||||||
|
@ -775,8 +774,7 @@ class mrp_production(osv.osv):
|
||||||
for new_parent_id in new_parent_ids:
|
for new_parent_id in new_parent_ids:
|
||||||
stock_mov_obj.write(cr, uid, [raw_product.id], {'move_history_ids': [(4,new_parent_id)]})
|
stock_mov_obj.write(cr, uid, [raw_product.id], {'move_history_ids': [(4,new_parent_id)]})
|
||||||
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_button_produce_done(cr, uid, [production_id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production', production_id, 'button_produce_done', cr)
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _costs_generate(self, cr, uid, production):
|
def _costs_generate(self, cr, uid, production):
|
||||||
|
@ -844,7 +842,6 @@ class mrp_production(osv.osv):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _make_production_line_procurement(self, cr, uid, production_line, shipment_move_id, context=None):
|
def _make_production_line_procurement(self, cr, uid, production_line, shipment_move_id, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
procurement_order = self.pool.get('procurement.order')
|
procurement_order = self.pool.get('procurement.order')
|
||||||
production = production_line.production_id
|
production = production_line.production_id
|
||||||
location_id = production.location_src_id.id
|
location_id = production.location_src_id.id
|
||||||
|
@ -864,7 +861,7 @@ class mrp_production(osv.osv):
|
||||||
'move_id': shipment_move_id,
|
'move_id': shipment_move_id,
|
||||||
'company_id': production.company_id.id,
|
'company_id': production.company_id.id,
|
||||||
})
|
})
|
||||||
wf_service.trg_validate(uid, procurement_order._name, procurement_id, 'button_confirm', cr)
|
self.signal_button_confirm(cr, uid, [procurement_id])
|
||||||
return procurement_id
|
return procurement_id
|
||||||
|
|
||||||
def _make_production_internal_shipment_line(self, cr, uid, production_line, shipment_id, parent_move_id, destination_location_id=False, context=None):
|
def _make_production_internal_shipment_line(self, cr, uid, production_line, shipment_id, parent_move_id, destination_location_id=False, context=None):
|
||||||
|
@ -977,7 +974,6 @@ class mrp_production(osv.osv):
|
||||||
@return: Newly generated Shipment Id.
|
@return: Newly generated Shipment Id.
|
||||||
"""
|
"""
|
||||||
shipment_id = False
|
shipment_id = False
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
uncompute_ids = filter(lambda x:x, [not x.product_lines and x.id or False for x in self.browse(cr, uid, ids, context=context)])
|
uncompute_ids = filter(lambda x:x, [not x.product_lines and x.id or False for x in self.browse(cr, uid, ids, context=context)])
|
||||||
self.action_compute(cr, uid, uncompute_ids, context=context)
|
self.action_compute(cr, uid, uncompute_ids, context=context)
|
||||||
for production in self.browse(cr, uid, ids, context=context):
|
for production in self.browse(cr, uid, ids, context=context):
|
||||||
|
@ -995,7 +991,7 @@ class mrp_production(osv.osv):
|
||||||
destination_location_id=source_location_id, context=context)
|
destination_location_id=source_location_id, context=context)
|
||||||
self._make_production_line_procurement(cr, uid, line, shipment_move_id, context=context)
|
self._make_production_line_procurement(cr, uid, line, shipment_move_id, context=context)
|
||||||
|
|
||||||
wf_service.trg_validate(uid, 'stock.picking', shipment_id, 'button_confirm', cr)
|
self.pool.get('stock.picking').signal_button_confirm(cr, uid, [shipment_id])
|
||||||
production.write({'state':'confirmed'}, context=context)
|
production.write({'state':'confirmed'}, context=context)
|
||||||
return shipment_id
|
return shipment_id
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,6 @@ from dateutil.relativedelta import relativedelta
|
||||||
from openerp.osv import fields
|
from openerp.osv import fields
|
||||||
from openerp.osv import osv
|
from openerp.osv import osv
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
from openerp import netsvc
|
|
||||||
|
|
||||||
class procurement_order(osv.osv):
|
class procurement_order(osv.osv):
|
||||||
_inherit = 'procurement.order'
|
_inherit = 'procurement.order'
|
||||||
|
@ -87,7 +86,6 @@ class procurement_order(osv.osv):
|
||||||
company = self.pool.get('res.users').browse(cr, uid, uid, context).company_id
|
company = self.pool.get('res.users').browse(cr, uid, uid, context).company_id
|
||||||
production_obj = self.pool.get('mrp.production')
|
production_obj = self.pool.get('mrp.production')
|
||||||
move_obj = self.pool.get('stock.move')
|
move_obj = self.pool.get('stock.move')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
procurement_obj = self.pool.get('procurement.order')
|
procurement_obj = self.pool.get('procurement.order')
|
||||||
for procurement in procurement_obj.browse(cr, uid, ids, context=context):
|
for procurement in procurement_obj.browse(cr, uid, ids, context=context):
|
||||||
res_id = procurement.move_id.id
|
res_id = procurement.move_id.id
|
||||||
|
@ -112,7 +110,7 @@ class procurement_order(osv.osv):
|
||||||
self.write(cr, uid, [procurement.id], {'state': 'running', 'production_id': produce_id})
|
self.write(cr, uid, [procurement.id], {'state': 'running', 'production_id': produce_id})
|
||||||
bom_result = production_obj.action_compute(cr, uid,
|
bom_result = production_obj.action_compute(cr, uid,
|
||||||
[produce_id], properties=[x.id for x in procurement.property_ids])
|
[produce_id], properties=[x.id for x in procurement.property_ids])
|
||||||
wf_service.trg_validate(uid, 'mrp.production', produce_id, 'button_confirm', cr)
|
production_obj.signal_button_confirm(cr, uid, [produce_id])
|
||||||
if res_id:
|
if res_id:
|
||||||
move_obj.write(cr, uid, [res_id],
|
move_obj.write(cr, uid, [res_id],
|
||||||
{'location_id': procurement.location_id.id})
|
{'location_id': procurement.location_id.id})
|
||||||
|
|
|
@ -21,7 +21,6 @@
|
||||||
|
|
||||||
from openerp.osv import fields
|
from openerp.osv import fields
|
||||||
from openerp.osv import osv
|
from openerp.osv import osv
|
||||||
from openerp import netsvc
|
|
||||||
|
|
||||||
|
|
||||||
class StockMove(osv.osv):
|
class StockMove(osv.osv):
|
||||||
|
@ -45,7 +44,6 @@ class StockMove(osv.osv):
|
||||||
move_obj = self.pool.get('stock.move')
|
move_obj = self.pool.get('stock.move')
|
||||||
procurement_obj = self.pool.get('procurement.order')
|
procurement_obj = self.pool.get('procurement.order')
|
||||||
product_obj = self.pool.get('product.product')
|
product_obj = self.pool.get('product.product')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
processed_ids = [move.id]
|
processed_ids = [move.id]
|
||||||
if move.product_id.supply_method == 'produce' and move.product_id.procure_method == 'make_to_order':
|
if move.product_id.supply_method == 'produce' and move.product_id.procure_method == 'make_to_order':
|
||||||
bis = bom_obj.search(cr, uid, [
|
bis = bom_obj.search(cr, uid, [
|
||||||
|
@ -90,16 +88,17 @@ class StockMove(osv.osv):
|
||||||
'procure_method': prodobj.procure_method,
|
'procure_method': prodobj.procure_method,
|
||||||
'move_id': mid,
|
'move_id': mid,
|
||||||
})
|
})
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc_id, 'button_confirm', cr)
|
procurement_obj.signal_button_confirm(cr, uid, [proc_id])
|
||||||
|
|
||||||
move_obj.write(cr, uid, [move.id], {
|
move_obj.write(cr, uid, [move.id], {
|
||||||
'location_dest_id': move.location_id.id, # dummy move for the kit
|
'location_dest_id': move.location_id.id, # dummy move for the kit
|
||||||
'auto_validate': True,
|
'auto_validate': True,
|
||||||
'picking_id': False,
|
'picking_id': False,
|
||||||
'state': 'confirmed'
|
'state': 'confirmed'
|
||||||
})
|
})
|
||||||
for m in procurement_obj.search(cr, uid, [('move_id','=',move.id)], context):
|
procurement_ids = procurement_obj.search(cr, uid, [('move_id','=',move.id)], context)
|
||||||
wf_service.trg_validate(uid, 'procurement.order', m, 'button_confirm', cr)
|
procurement_obj.signal_button_confirm(cr, uid, procurement_ids)
|
||||||
wf_service.trg_validate(uid, 'procurement.order', m, 'button_wait_done', cr)
|
procurement_obj.signal_button_wait_done(cr, uid, procurement_ids)
|
||||||
return processed_ids
|
return processed_ids
|
||||||
|
|
||||||
def action_consume(self, cr, uid, ids, product_qty, location_id=False, context=None):
|
def action_consume(self, cr, uid, ids, product_qty, location_id=False, context=None):
|
||||||
|
@ -110,7 +109,6 @@ class StockMove(osv.osv):
|
||||||
"""
|
"""
|
||||||
res = []
|
res = []
|
||||||
production_obj = self.pool.get('mrp.production')
|
production_obj = self.pool.get('mrp.production')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for move in self.browse(cr, uid, ids):
|
for move in self.browse(cr, uid, ids):
|
||||||
move.action_confirm(context)
|
move.action_confirm(context)
|
||||||
new_moves = super(StockMove, self).action_consume(cr, uid, [move.id], product_qty, location_id, context=context)
|
new_moves = super(StockMove, self).action_consume(cr, uid, [move.id], product_qty, location_id, context=context)
|
||||||
|
@ -118,7 +116,7 @@ class StockMove(osv.osv):
|
||||||
for prod in production_obj.browse(cr, uid, production_ids, context=context):
|
for prod in production_obj.browse(cr, uid, production_ids, context=context):
|
||||||
if prod.state == 'confirmed':
|
if prod.state == 'confirmed':
|
||||||
production_obj.force_production(cr, uid, [prod.id])
|
production_obj.force_production(cr, uid, [prod.id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production', prod.id, 'button_produce', cr)
|
production_obj.signal_button_produce(cr, uid, production_ids)
|
||||||
for new_move in new_moves:
|
for new_move in new_moves:
|
||||||
if new_move == move.id:
|
if new_move == move.id:
|
||||||
#This move is already there in move lines of production order
|
#This move is already there in move lines of production order
|
||||||
|
@ -135,14 +133,13 @@ class StockMove(osv.osv):
|
||||||
"""
|
"""
|
||||||
res = []
|
res = []
|
||||||
production_obj = self.pool.get('mrp.production')
|
production_obj = self.pool.get('mrp.production')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for move in self.browse(cr, uid, ids, context=context):
|
for move in self.browse(cr, uid, ids, context=context):
|
||||||
new_moves = super(StockMove, self).action_scrap(cr, uid, [move.id], product_qty, location_id, context=context)
|
new_moves = super(StockMove, self).action_scrap(cr, uid, [move.id], product_qty, location_id, context=context)
|
||||||
#If we are not scrapping our whole move, tracking and lot references must not be removed
|
#If we are not scrapping our whole move, tracking and lot references must not be removed
|
||||||
#self.write(cr, uid, [move.id], {'prodlot_id': False, 'tracking_id': False})
|
#self.write(cr, uid, [move.id], {'prodlot_id': False, 'tracking_id': False})
|
||||||
production_ids = production_obj.search(cr, uid, [('move_lines', 'in', [move.id])])
|
production_ids = production_obj.search(cr, uid, [('move_lines', 'in', [move.id])])
|
||||||
for prod_id in production_ids:
|
for prod_id in production_ids:
|
||||||
wf_service.trg_validate(uid, 'mrp.production', prod_id, 'button_produce', cr)
|
production_obj.signal_button_produce(cr, uid, [prod_id])
|
||||||
for new_move in new_moves:
|
for new_move in new_moves:
|
||||||
production_obj.write(cr, uid, production_ids, {'move_lines': [(4, new_move)]})
|
production_obj.write(cr, uid, production_ids, {'move_lines': [(4, new_move)]})
|
||||||
res.append(new_move)
|
res.append(new_move)
|
||||||
|
|
|
@ -118,16 +118,15 @@ class mrp_production_workcenter_line(osv.osv):
|
||||||
@param action: Action to perform.
|
@param action: Action to perform.
|
||||||
@return: Nothing
|
@return: Nothing
|
||||||
"""
|
"""
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
prod_obj_pool = self.pool.get('mrp.production')
|
prod_obj_pool = self.pool.get('mrp.production')
|
||||||
oper_obj = self.browse(cr, uid, ids)[0]
|
oper_obj = self.browse(cr, uid, ids)[0]
|
||||||
prod_obj = oper_obj.production_id
|
prod_obj = oper_obj.production_id
|
||||||
if action == 'start':
|
if action == 'start':
|
||||||
if prod_obj.state =='confirmed':
|
if prod_obj.state =='confirmed':
|
||||||
prod_obj_pool.force_production(cr, uid, [prod_obj.id])
|
prod_obj_pool.force_production(cr, uid, [prod_obj.id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production', prod_obj.id, 'button_produce', cr)
|
prod_obj_pool.signal_button_produce(cr, uid, [prod_obj.id])
|
||||||
elif prod_obj.state =='ready':
|
elif prod_obj.state =='ready':
|
||||||
wf_service.trg_validate(uid, 'mrp.production', prod_obj.id, 'button_produce', cr)
|
prod_obj_pool.signal_button_produce(cr, uid, [prod_obj.id])
|
||||||
elif prod_obj.state =='in_production':
|
elif prod_obj.state =='in_production':
|
||||||
return
|
return
|
||||||
else:
|
else:
|
||||||
|
@ -143,7 +142,7 @@ class mrp_production_workcenter_line(osv.osv):
|
||||||
for production in prod_obj_pool.browse(cr, uid, [prod_obj.id], context= None):
|
for production in prod_obj_pool.browse(cr, uid, [prod_obj.id], context= None):
|
||||||
if production.move_lines or production.move_created_ids:
|
if production.move_lines or production.move_created_ids:
|
||||||
prod_obj_pool.action_produce(cr,uid, production.id, production.product_qty, 'consume_produce', context = None)
|
prod_obj_pool.action_produce(cr,uid, production.id, production.product_qty, 'consume_produce', context = None)
|
||||||
wf_service.trg_validate(uid, 'mrp.production', oper_obj.production_id.id, 'button_produce_done', cr)
|
prod_obj_pool.signal_button_produce_done(cr, uid, [oper_obj.production_id.id])
|
||||||
return
|
return
|
||||||
|
|
||||||
def write(self, cr, uid, ids, vals, context=None, update=True):
|
def write(self, cr, uid, ids, vals, context=None, update=True):
|
||||||
|
@ -228,23 +227,21 @@ class mrp_production(osv.osv):
|
||||||
@return: Super method
|
@return: Super method
|
||||||
"""
|
"""
|
||||||
obj = self.browse(cr, uid, ids)[0]
|
obj = self.browse(cr, uid, ids)[0]
|
||||||
wf_service = netsvc.LocalService("workflow")
|
workcenter_pool = self.pool.get('mrp.production.workcenter.line')
|
||||||
for workcenter_line in obj.workcenter_lines:
|
for workcenter_line in obj.workcenter_lines:
|
||||||
if workcenter_line.state == 'draft':
|
if workcenter_line.state == 'draft':
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', workcenter_line.id, 'button_start_working', cr)
|
workcenter_pool.signal_button_start_working(cr, uid, [workcenter_line.id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', workcenter_line.id, 'button_done', cr)
|
workcenter_pool.signal_button_done(cr, uid, [workcenter_line.id])
|
||||||
return super(mrp_production,self).action_production_end(cr, uid, ids)
|
return super(mrp_production,self).action_production_end(cr, uid, ids)
|
||||||
|
|
||||||
def action_in_production(self, cr, uid, ids):
|
def action_in_production(self, cr, uid, ids):
|
||||||
""" Changes state to In Production and writes starting date.
|
""" Changes state to In Production and writes starting date.
|
||||||
@return: True
|
@return: True
|
||||||
"""
|
"""
|
||||||
obj = self.browse(cr, uid, ids)[0]
|
|
||||||
workcenter_pool = self.pool.get('mrp.production.workcenter.line')
|
workcenter_pool = self.pool.get('mrp.production.workcenter.line')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for prod in self.browse(cr, uid, ids):
|
for prod in self.browse(cr, uid, ids):
|
||||||
if prod.workcenter_lines:
|
if prod.workcenter_lines:
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', prod.workcenter_lines[0].id, 'button_start_working', cr)
|
workcenter_pool.signal_button_start_working(cr, uid, [prod.workcenter_lines[0].id])
|
||||||
return super(mrp_production,self).action_in_production(cr, uid, ids)
|
return super(mrp_production,self).action_in_production(cr, uid, ids)
|
||||||
|
|
||||||
def action_cancel(self, cr, uid, ids, context=None):
|
def action_cancel(self, cr, uid, ids, context=None):
|
||||||
|
@ -252,9 +249,8 @@ class mrp_production(osv.osv):
|
||||||
@return: Super method
|
@return: Super method
|
||||||
"""
|
"""
|
||||||
obj = self.browse(cr, uid, ids,context=context)[0]
|
obj = self.browse(cr, uid, ids,context=context)[0]
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for workcenter_line in obj.workcenter_lines:
|
for workcenter_line in obj.workcenter_lines:
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', workcenter_line.id, 'button_cancel', cr)
|
workcenter_pool.signal_button_cancel(cr, uid, [workcenter_line.id])
|
||||||
return super(mrp_production,self).action_cancel(cr,uid,ids,context=context)
|
return super(mrp_production,self).action_cancel(cr,uid,ids,context=context)
|
||||||
|
|
||||||
def _compute_planned_workcenter(self, cr, uid, ids, context=None, mini=False):
|
def _compute_planned_workcenter(self, cr, uid, ids, context=None, mini=False):
|
||||||
|
@ -503,35 +499,34 @@ class mrp_operations_operation(osv.osv):
|
||||||
return super(mrp_operations_operation, self).write(cr, uid, ids, vals, context=context)
|
return super(mrp_operations_operation, self).write(cr, uid, ids, vals, context=context)
|
||||||
|
|
||||||
def create(self, cr, uid, vals, context=None):
|
def create(self, cr, uid, vals, context=None):
|
||||||
wf_service = netsvc.LocalService('workflow')
|
workcenter_pool = self.pool.get('mrp.production.workcenter.line')
|
||||||
code_ids=self.pool.get('mrp_operations.operation.code').search(cr,uid,[('id','=',vals['code_id'])])
|
code_ids=self.pool.get('mrp_operations.operation.code').search(cr,uid,[('id','=',vals['code_id'])])
|
||||||
code=self.pool.get('mrp_operations.operation.code').browse(cr, uid, code_ids, context=context)[0]
|
code=self.pool.get('mrp_operations.operation.code').browse(cr, uid, code_ids, context=context)[0]
|
||||||
wc_op_id=self.pool.get('mrp.production.workcenter.line').search(cr,uid,[('workcenter_id','=',vals['workcenter_id']),('production_id','=',vals['production_id'])])
|
wc_op_id=workcenter_pool.search(cr,uid,[('workcenter_id','=',vals['workcenter_id']),('production_id','=',vals['production_id'])])
|
||||||
if code.start_stop in ('start','done','pause','cancel','resume'):
|
if code.start_stop in ('start','done','pause','cancel','resume'):
|
||||||
if not wc_op_id:
|
if not wc_op_id:
|
||||||
production_obj=self.pool.get('mrp.production').browse(cr, uid, vals['production_id'], context=context)
|
production_obj=self.pool.get('mrp.production').browse(cr, uid, vals['production_id'], context=context)
|
||||||
wc_op_id.append(self.pool.get('mrp.production.workcenter.line').create(cr,uid,{'production_id':vals['production_id'],'name':production_obj.product_id.name,'workcenter_id':vals['workcenter_id']}))
|
wc_op_id.append(workcenter_pool.create(cr,uid,{'production_id':vals['production_id'],'name':production_obj.product_id.name,'workcenter_id':vals['workcenter_id']}))
|
||||||
if code.start_stop=='start':
|
if code.start_stop=='start':
|
||||||
self.pool.get('mrp.production.workcenter.line').action_start_working(cr,uid,wc_op_id)
|
workcenter_pool.action_start_working(cr,uid,wc_op_id)
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', wc_op_id[0], 'button_start_working', cr)
|
workcenter_pool.signal_button_start_working(cr, uid, [wc_op_id[0]])
|
||||||
|
|
||||||
|
|
||||||
if code.start_stop=='done':
|
if code.start_stop=='done':
|
||||||
self.pool.get('mrp.production.workcenter.line').action_done(cr,uid,wc_op_id)
|
workcenter_pool.action_done(cr,uid,wc_op_id)
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', wc_op_id[0], 'button_done', cr)
|
workcenter_pool.signal_button_done(cr, uid, [wc_op_id[0]])
|
||||||
self.pool.get('mrp.production').write(cr,uid,vals['production_id'],{'date_finished':datetime.now().strftime('%Y-%m-%d %H:%M:%S')})
|
self.pool.get('mrp.production').write(cr,uid,vals['production_id'],{'date_finished':datetime.now().strftime('%Y-%m-%d %H:%M:%S')})
|
||||||
|
|
||||||
if code.start_stop=='pause':
|
if code.start_stop=='pause':
|
||||||
self.pool.get('mrp.production.workcenter.line').action_pause(cr,uid,wc_op_id)
|
workcenter_pool.action_pause(cr,uid,wc_op_id)
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', wc_op_id[0], 'button_pause', cr)
|
workcenter_pool.signal_button_pause(cr, uid, [wc_op_id[0]])
|
||||||
|
|
||||||
if code.start_stop=='resume':
|
if code.start_stop=='resume':
|
||||||
self.pool.get('mrp.production.workcenter.line').action_resume(cr,uid,wc_op_id)
|
workcenter_pool.action_resume(cr,uid,wc_op_id)
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', wc_op_id[0], 'button_resume', cr)
|
workcenter_pool.signal_button_resume(cr, uid, [wc_op_id[0]])
|
||||||
|
|
||||||
if code.start_stop=='cancel':
|
if code.start_stop=='cancel':
|
||||||
self.pool.get('mrp.production.workcenter.line').action_cancel(cr,uid,wc_op_id)
|
workcenter_pool.action_cancel(cr,uid,wc_op_id)
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', wc_op_id[0], 'button_cancel', cr)
|
workcenter_pool.signal_button_cancel(cr, uid, [wc_op_id[0]])
|
||||||
|
|
||||||
if not self.check_operation(cr, uid, vals):
|
if not self.check_operation(cr, uid, vals):
|
||||||
return
|
return
|
||||||
|
@ -549,10 +544,9 @@ class mrp_operations_operation(osv.osv):
|
||||||
return super(mrp_operations_operation, self).create(cr, uid, vals, context=context)
|
return super(mrp_operations_operation, self).create(cr, uid, vals, context=context)
|
||||||
|
|
||||||
def initialize_workflow_instance(self, cr, uid, context=None):
|
def initialize_workflow_instance(self, cr, uid, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
mrp_production_workcenter_line = self.pool.get('mrp.production.workcenter.line')
|
||||||
line_ids = self.pool.get('mrp.production.workcenter.line').search(cr, uid, [], context=context)
|
line_ids = mrp_production_workcenter_line.search(cr, uid, [], context=context)
|
||||||
for line_id in line_ids:
|
mrp_production_workcenter_line.create_workflow(cr, uid, line_ids)
|
||||||
wf_service.trg_create(uid, 'mrp.production.workcenter.line', line_id, cr)
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
_columns={
|
_columns={
|
||||||
|
|
|
@ -39,62 +39,48 @@
|
||||||
Production start on first work center, so I start work operation on first work center.
|
Production start on first work center, so I start work operation on first work center.
|
||||||
-
|
-
|
||||||
!python {model: mrp.production}: |
|
!python {model: mrp.production}: |
|
||||||
from openerp import netsvc
|
|
||||||
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('mrp.production.workcenter.line').signal_button_start_working(cr, uid, [order.workcenter_lines[0].id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', order.workcenter_lines[0].id, 'button_start_working', cr)
|
|
||||||
-
|
-
|
||||||
Now I pause first work operation due to technical fault of work center.
|
Now I pause first work operation due to technical fault of work center.
|
||||||
-
|
-
|
||||||
!python {model: mrp.production}: |
|
!python {model: mrp.production}: |
|
||||||
from openerp import netsvc
|
|
||||||
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('mrp.production.workcenter.line').signal_button_pause(cr, uid, [order.workcenter_lines[0].id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', order.workcenter_lines[0].id, 'button_pause', cr)
|
|
||||||
-
|
-
|
||||||
I resume first work operation.
|
I resume first work operation.
|
||||||
-
|
-
|
||||||
!python {model: mrp.production}: |
|
!python {model: mrp.production}: |
|
||||||
from openerp import netsvc
|
|
||||||
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('mrp.production.workcenter.line').signal_button_resume(cr, uid, [order.workcenter_lines[0].id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', order.workcenter_lines[0].id, 'button_resume', cr)
|
|
||||||
|
|
||||||
-
|
-
|
||||||
I cancel first work operation.
|
I cancel first work operation.
|
||||||
-
|
-
|
||||||
!python {model: mrp.production}: |
|
!python {model: mrp.production}: |
|
||||||
from openerp import netsvc
|
|
||||||
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('mrp.production.workcenter.line').signal_button_cancel(cr, uid, [order.workcenter_lines[0].id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', order.workcenter_lines[0].id, 'button_cancel', cr)
|
|
||||||
-
|
-
|
||||||
I reset first work operation and start after resolving techninal fault of work center.
|
I reset first work operation and start after resolving techninal fault of work center.
|
||||||
-
|
-
|
||||||
!python {model: mrp.production}: |
|
!python {model: mrp.production}: |
|
||||||
from openerp import netsvc
|
|
||||||
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('mrp.production.workcenter.line').signal_button_draft(cr, uid, [order.workcenter_lines[0].id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', order.workcenter_lines[0].id, 'button_draft', cr)
|
self.pool.get('mrp.production.workcenter.line').signal_button_start_working(cr, uid, [order.workcenter_lines[0].id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', order.workcenter_lines[0].id, 'button_start_working', cr)
|
|
||||||
-
|
-
|
||||||
I close first work operation as this work center completed its process.
|
I close first work operation as this work center completed its process.
|
||||||
-
|
-
|
||||||
!python {model: mrp.production}: |
|
!python {model: mrp.production}: |
|
||||||
from openerp import netsvc
|
|
||||||
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('mrp.production.workcenter.line').signal_button_done(cr, uid, [order.workcenter_lines[0].id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', order.workcenter_lines[0].id, 'button_done', cr)
|
|
||||||
-
|
-
|
||||||
Now I close other operations one by one which are in start state.
|
Now I close other operations one by one which are in start state.
|
||||||
-
|
-
|
||||||
!python {model: mrp.production}: |
|
!python {model: mrp.production}: |
|
||||||
from openerp import netsvc
|
|
||||||
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
order = self.browse(cr, uid, ref("mrp.mrp_production_1"), context=context)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for work_line in order.workcenter_lines[1:]:
|
for work_line in order.workcenter_lines[1:]:
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', work_line.id, 'button_start_working', cr)
|
self.pool.get('mrp.production.workcenter.line').signal_button_start_working(cr, uid, [work_line.id])
|
||||||
wf_service.trg_validate(uid, 'mrp.production.workcenter.line', work_line.id, 'button_done', cr)
|
self.pool.get('mrp.production.workcenter.line').signal_button_done(cr, uid, [work_line.id])
|
||||||
|
|
||||||
-
|
-
|
||||||
I check that the production order is now done.
|
I check that the production order is now done.
|
||||||
|
@ -106,8 +92,7 @@
|
||||||
I print a Barcode Report of Operation line.
|
I print a Barcode Report of Operation line.
|
||||||
-
|
-
|
||||||
!python {model: mrp_operations.operation.code}: |
|
!python {model: mrp_operations.operation.code}: |
|
||||||
import os
|
import netsvc, tools, os
|
||||||
from openerp import netsvc, tools
|
|
||||||
(data, format) = netsvc.LocalService('report.mrp.code.barcode').create(cr, uid, [ref('mrp_operations.mrp_op_1'),ref('mrp_operations.mrp_op_2'),ref('mrp_operations.mrp_op_3'),ref('mrp_operations.mrp_op_4'),ref('mrp_operations.mrp_op_5')], {}, {})
|
(data, format) = netsvc.LocalService('report.mrp.code.barcode').create(cr, uid, [ref('mrp_operations.mrp_op_1'),ref('mrp_operations.mrp_op_2'),ref('mrp_operations.mrp_op_3'),ref('mrp_operations.mrp_op_4'),ref('mrp_operations.mrp_op_5')], {}, {})
|
||||||
if tools.config['test_report_directory']:
|
if tools.config['test_report_directory']:
|
||||||
file(os.path.join(tools.config['test_report_directory'], 'mrp_operations-barcode_report.'+format), 'wb+').write(data)
|
file(os.path.join(tools.config['test_report_directory'], 'mrp_operations-barcode_report.'+format), 'wb+').write(data)
|
||||||
|
@ -116,8 +101,7 @@
|
||||||
I print Workcenter's Barcode Report.
|
I print Workcenter's Barcode Report.
|
||||||
-
|
-
|
||||||
!python {model: mrp.workcenter}: |
|
!python {model: mrp.workcenter}: |
|
||||||
import os
|
import netsvc, tools, os
|
||||||
from openerp import netsvc, tools
|
|
||||||
(data, format) = netsvc.LocalService('report.mrp.wc.barcode').create(cr, uid, [ref('mrp.mrp_workcenter_0'),ref('mrp.mrp_workcenter_1')], {}, {})
|
(data, format) = netsvc.LocalService('report.mrp.wc.barcode').create(cr, uid, [ref('mrp.mrp_workcenter_0'),ref('mrp.mrp_workcenter_1')], {}, {})
|
||||||
if tools.config['test_report_directory']:
|
if tools.config['test_report_directory']:
|
||||||
file(os.path.join(tools.config['test_report_directory'], 'mrp_operations-workcenter_barcode_report.'+format), 'wb+').write(data)
|
file(os.path.join(tools.config['test_report_directory'], 'mrp_operations-workcenter_barcode_report.'+format), 'wb+').write(data)
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
from openerp.osv import fields,osv
|
from openerp.osv import fields,osv
|
||||||
from openerp import netsvc
|
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from dateutil.relativedelta import relativedelta
|
from dateutil.relativedelta import relativedelta
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
@ -314,9 +313,7 @@ class mrp_repair(osv.osv):
|
||||||
for repair in self.browse(cr, uid, ids):
|
for repair in self.browse(cr, uid, ids):
|
||||||
mrp_line_obj.write(cr, uid, [l.id for l in repair.operations], {'state': 'draft'})
|
mrp_line_obj.write(cr, uid, [l.id for l in repair.operations], {'state': 'draft'})
|
||||||
self.write(cr, uid, ids, {'state':'draft'})
|
self.write(cr, uid, ids, {'state':'draft'})
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.create_workflow(cr, uid, ids)
|
||||||
for id in ids:
|
|
||||||
wf_service.trg_create(uid, 'mrp.repair', id, cr)
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def action_confirm(self, cr, uid, ids, *args):
|
def action_confirm(self, cr, uid, ids, *args):
|
||||||
|
@ -505,7 +502,6 @@ class mrp_repair(osv.osv):
|
||||||
"""
|
"""
|
||||||
res = {}
|
res = {}
|
||||||
move_obj = self.pool.get('stock.move')
|
move_obj = self.pool.get('stock.move')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
repair_line_obj = self.pool.get('mrp.repair.line')
|
repair_line_obj = self.pool.get('mrp.repair.line')
|
||||||
seq_obj = self.pool.get('ir.sequence')
|
seq_obj = self.pool.get('ir.sequence')
|
||||||
pick_obj = self.pool.get('stock.picking')
|
pick_obj = self.pool.get('stock.picking')
|
||||||
|
@ -548,7 +544,7 @@ class mrp_repair(osv.osv):
|
||||||
'tracking_id': False,
|
'tracking_id': False,
|
||||||
'state': 'assigned',
|
'state': 'assigned',
|
||||||
})
|
})
|
||||||
wf_service.trg_validate(uid, 'stock.picking', picking, 'button_confirm', cr)
|
pick_obj.signal_button_confirm(cr, uid, [picking])
|
||||||
self.write(cr, uid, [repair.id], {'state': 'done', 'picking_id': picking})
|
self.write(cr, uid, [repair.id], {'state': 'done', 'picking_id': picking})
|
||||||
res[repair.id] = picking
|
res[repair.id] = picking
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
#
|
#
|
||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
|
|
||||||
class make_invoice(osv.osv_memory):
|
class make_invoice(osv.osv_memory):
|
||||||
|
@ -50,9 +49,7 @@ class make_invoice(osv.osv_memory):
|
||||||
# We have to trigger the workflow of the given repairs, otherwise they remain 'to be invoiced'.
|
# We have to trigger the workflow of the given repairs, otherwise they remain 'to be invoiced'.
|
||||||
# Note that the signal 'action_invoice_create' will trigger another call to the method 'action_invoice_create',
|
# Note that the signal 'action_invoice_create' will trigger another call to the method 'action_invoice_create',
|
||||||
# but that second call will not do anything, since the repairs are already invoiced.
|
# but that second call will not do anything, since the repairs are already invoiced.
|
||||||
wf_service = netsvc.LocalService("workflow")
|
order_obj.signal_action_invoice_create(cr, uid, context['active_ids'])
|
||||||
for repair_id in context['active_ids']:
|
|
||||||
wf_service.trg_validate(uid, 'mrp.repair', repair_id, 'action_invoice_create', cr)
|
|
||||||
|
|
||||||
form_res = mod_obj.get_object_reference(cr, uid, 'account', 'invoice_form')
|
form_res = mod_obj.get_object_reference(cr, uid, 'account', 'invoice_form')
|
||||||
form_id = form_res and form_res[1] or False
|
form_id = form_res and form_res[1] or False
|
||||||
|
|
|
@ -27,7 +27,7 @@ import pdb
|
||||||
import time
|
import time
|
||||||
|
|
||||||
import openerp
|
import openerp
|
||||||
from openerp import netsvc, tools
|
from openerp import tools
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
|
||||||
|
@ -442,14 +442,14 @@ class pos_session(osv.osv):
|
||||||
}
|
}
|
||||||
|
|
||||||
def _confirm_orders(self, cr, uid, ids, context=None):
|
def _confirm_orders(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
account_move_obj = self.pool.get('account.move')
|
||||||
|
pos_order_obj = self.pool.get('pos.order')
|
||||||
for session in self.browse(cr, uid, ids, context=context):
|
for session in self.browse(cr, uid, ids, context=context):
|
||||||
order_ids = [order.id for order in session.order_ids if order.state == 'paid']
|
order_ids = [order.id for order in session.order_ids if order.state == 'paid']
|
||||||
|
|
||||||
move_id = self.pool.get('account.move').create(cr, uid, {'ref' : session.name, 'journal_id' : session.config_id.journal_id.id, }, context=context)
|
move_id = account_move_obj.create(cr, uid, {'ref' : session.name, 'journal_id' : session.config_id.journal_id.id, }, context=context)
|
||||||
|
|
||||||
self.pool.get('pos.order')._create_account_move_line(cr, uid, order_ids, session, move_id, context=context)
|
pos_order_obj._create_account_move_line(cr, uid, order_ids, session, move_id, context=context)
|
||||||
|
|
||||||
for order in session.order_ids:
|
for order in session.order_ids:
|
||||||
if order.state not in ('paid', 'invoiced'):
|
if order.state not in ('paid', 'invoiced'):
|
||||||
|
@ -457,7 +457,7 @@ class pos_session(osv.osv):
|
||||||
_('Error!'),
|
_('Error!'),
|
||||||
_("You cannot confirm all orders of this session, because they have not the 'paid' status"))
|
_("You cannot confirm all orders of this session, because they have not the 'paid' status"))
|
||||||
else:
|
else:
|
||||||
wf_service.trg_validate(uid, 'pos.order', order.id, 'done', cr)
|
pos_order_obj.signal_done(cr, uid, [order.id])
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
@ -519,8 +519,7 @@ class pos_order(osv.osv):
|
||||||
'journal': cash_journal.id,
|
'journal': cash_journal.id,
|
||||||
}, context=context)
|
}, context=context)
|
||||||
order_ids.append(order_id)
|
order_ids.append(order_id)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_paid(cr, uid, [order_id])
|
||||||
wf_service.trg_validate(uid, 'pos.order', order_id, 'paid', cr)
|
|
||||||
return order_ids
|
return order_ids
|
||||||
|
|
||||||
def unlink(self, cr, uid, ids, context=None):
|
def unlink(self, cr, uid, ids, context=None):
|
||||||
|
@ -696,8 +695,7 @@ class pos_order(osv.osv):
|
||||||
if line.qty < 0:
|
if line.qty < 0:
|
||||||
location_id, output_id = output_id, location_id
|
location_id, output_id = output_id, location_id
|
||||||
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
picking_obj.signal_button_confirm(cr, uid, [picking_id])
|
||||||
wf_service.trg_validate(uid, 'stock.picking', picking_id, 'button_confirm', cr)
|
|
||||||
picking_obj.force_assign(cr, uid, [picking_id], context)
|
picking_obj.force_assign(cr, uid, [picking_id], context)
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
@ -707,7 +705,7 @@ class pos_order(osv.osv):
|
||||||
"""
|
"""
|
||||||
stock_picking_obj = self.pool.get('stock.picking')
|
stock_picking_obj = self.pool.get('stock.picking')
|
||||||
for order in self.browse(cr, uid, ids, context=context):
|
for order in self.browse(cr, uid, ids, context=context):
|
||||||
wf_service.trg_validate(uid, 'stock.picking', order.picking_id.id, 'button_cancel', cr)
|
stock_picking_obj.signal_button_cancel(cr, uid, [order.picking_id.id])
|
||||||
if stock_picking_obj.browse(cr, uid, order.picking_id.id, context=context).state <> 'cancel':
|
if stock_picking_obj.browse(cr, uid, order.picking_id.id, context=context).state <> 'cancel':
|
||||||
raise osv.except_osv(_('Error!'), _('Unable to cancel the picking.'))
|
raise osv.except_osv(_('Error!'), _('Unable to cancel the picking.'))
|
||||||
self.write(cr, uid, ids, {'state': 'cancel'}, context=context)
|
self.write(cr, uid, ids, {'state': 'cancel'}, context=context)
|
||||||
|
@ -803,7 +801,6 @@ class pos_order(osv.osv):
|
||||||
return self.write(cr, uid, ids, {'state':'invoiced'}, context=context)
|
return self.write(cr, uid, ids, {'state':'invoiced'}, context=context)
|
||||||
|
|
||||||
def action_invoice(self, cr, uid, ids, context=None):
|
def action_invoice(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
inv_ref = self.pool.get('account.invoice')
|
inv_ref = self.pool.get('account.invoice')
|
||||||
inv_line_ref = self.pool.get('account.invoice.line')
|
inv_line_ref = self.pool.get('account.invoice.line')
|
||||||
product_obj = self.pool.get('product.product')
|
product_obj = self.pool.get('product.product')
|
||||||
|
@ -856,7 +853,7 @@ class pos_order(osv.osv):
|
||||||
inv_line['invoice_line_tax_id'] = [(6, 0, [x.id for x in line.product_id.taxes_id] )]
|
inv_line['invoice_line_tax_id'] = [(6, 0, [x.id for x in line.product_id.taxes_id] )]
|
||||||
inv_line_ref.create(cr, uid, inv_line, context=context)
|
inv_line_ref.create(cr, uid, inv_line, context=context)
|
||||||
inv_ref.button_reset_taxes(cr, uid, [inv_id], context=context)
|
inv_ref.button_reset_taxes(cr, uid, [inv_id], context=context)
|
||||||
wf_service.trg_validate(uid, 'pos.order', order.id, 'invoice', cr)
|
self.signal_invoice(cr, uid, [order.id])
|
||||||
|
|
||||||
if not inv_ids: return {}
|
if not inv_ids: return {}
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
#
|
#
|
||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
from openerp.osv import osv
|
from openerp.osv import osv
|
||||||
|
|
||||||
|
|
||||||
|
@ -28,7 +27,6 @@ class pos_confirm(osv.osv_memory):
|
||||||
_description = 'Post POS Journal Entries'
|
_description = 'Post POS Journal Entries'
|
||||||
|
|
||||||
def action_confirm(self, cr, uid, ids, context=None):
|
def action_confirm(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
order_obj = self.pool.get('pos.order')
|
order_obj = self.pool.get('pos.order')
|
||||||
ids = order_obj.search(cr, uid, [('state','=','paid')], context=context)
|
ids = order_obj.search(cr, uid, [('state','=','paid')], context=context)
|
||||||
for order in order_obj.browse(cr, uid, ids, context=context):
|
for order in order_obj.browse(cr, uid, ids, context=context):
|
||||||
|
@ -38,7 +36,7 @@ class pos_confirm(osv.osv_memory):
|
||||||
todo = False
|
todo = False
|
||||||
break
|
break
|
||||||
if todo:
|
if todo:
|
||||||
wf_service.trg_validate(uid, 'pos.order', order.id, 'done', cr)
|
order_obj.signal_done(cr, uid, [order.id])
|
||||||
|
|
||||||
# Check if there is orders to reconcile their invoices
|
# Check if there is orders to reconcile their invoices
|
||||||
ids = order_obj.search(cr, uid, [('state','=','invoiced'),('invoice_id.state','=','open')], context=context)
|
ids = order_obj.search(cr, uid, [('state','=','invoiced'),('invoice_id.state','=','open')], context=context)
|
||||||
|
|
|
@ -23,7 +23,6 @@ import time
|
||||||
|
|
||||||
import pos_box_entries
|
import pos_box_entries
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
from openerp.osv import osv, fields
|
from openerp.osv import osv, fields
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
|
||||||
|
@ -67,8 +66,7 @@ class pos_make_payment(osv.osv_memory):
|
||||||
order_obj.add_payment(cr, uid, active_id, data, context=context)
|
order_obj.add_payment(cr, uid, active_id, data, context=context)
|
||||||
|
|
||||||
if order_obj.test_paid(cr, uid, [active_id]):
|
if order_obj.test_paid(cr, uid, [active_id]):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
order_obj.signal_paid(cr, uid, [active_id])
|
||||||
wf_service.trg_validate(uid, 'pos.order', active_id, 'paid', cr)
|
|
||||||
return {'type' : 'ir.actions.act_window_close' }
|
return {'type' : 'ir.actions.act_window_close' }
|
||||||
##self.print_report(cr, uid, ids, context=context)
|
##self.print_report(cr, uid, ids, context=context)
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
#
|
#
|
||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
from openerp.osv import osv,fields
|
from openerp.osv import osv,fields
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
import time
|
import time
|
||||||
|
@ -104,7 +103,6 @@ class pos_return(osv.osv_memory):
|
||||||
property_obj= self.pool.get("ir.property")
|
property_obj= self.pool.get("ir.property")
|
||||||
uom_obj =self. pool.get('product.uom')
|
uom_obj =self. pool.get('product.uom')
|
||||||
statementl_obj = self.pool.get('account.bank.statement.line')
|
statementl_obj = self.pool.get('account.bank.statement.line')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
#Todo :Need to clean the code
|
#Todo :Need to clean the code
|
||||||
if active_id:
|
if active_id:
|
||||||
data = self.browse(cr, uid, ids, context=context)[0]
|
data = self.browse(cr, uid, ids, context=context)[0]
|
||||||
|
@ -157,7 +155,7 @@ class pos_return(osv.osv_memory):
|
||||||
'amount': -amount,
|
'amount': -amount,
|
||||||
})
|
})
|
||||||
order_obj.write(cr,uid, [active_id,new_order], {'state': 'done'})
|
order_obj.write(cr,uid, [active_id,new_order], {'state': 'done'})
|
||||||
wf_service.trg_validate(uid, 'stock.picking', new_picking, 'button_confirm', cr)
|
picking_obj.signal_button_confirm(cr, uid, [new_picking])
|
||||||
picking_obj.force_assign(cr, uid, [new_picking], context)
|
picking_obj.force_assign(cr, uid, [new_picking], context)
|
||||||
act = {
|
act = {
|
||||||
'domain': "[('id', 'in', ["+str(new_order)+"])]",
|
'domain': "[('id', 'in', ["+str(new_order)+"])]",
|
||||||
|
@ -200,7 +198,6 @@ class add_product(osv.osv_memory):
|
||||||
date_cur=time.strftime('%Y-%m-%d')
|
date_cur=time.strftime('%Y-%m-%d')
|
||||||
uom_obj = self.pool.get('product.uom')
|
uom_obj = self.pool.get('product.uom')
|
||||||
prod_obj=self.pool.get('product.product')
|
prod_obj=self.pool.get('product.product')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
order_obj.add_product(cr, uid, active_id, data['product_id'], data['quantity'], context=context)
|
order_obj.add_product(cr, uid, active_id, data['product_id'], data['quantity'], context=context)
|
||||||
|
|
||||||
for order_id in order_obj.browse(cr, uid, [active_id], context=context):
|
for order_id in order_obj.browse(cr, uid, [active_id], context=context):
|
||||||
|
@ -232,7 +229,7 @@ class add_product(osv.osv_memory):
|
||||||
'date':date_cur
|
'date':date_cur
|
||||||
})
|
})
|
||||||
|
|
||||||
wf_service.trg_validate(uid, 'stock.picking', new_picking, 'button_confirm', cr)
|
picking_obj.signal_button_confirm(cr, uid, [new_picking])
|
||||||
picking_obj.force_assign(cr, uid, [new_picking], context)
|
picking_obj.force_assign(cr, uid, [new_picking], context)
|
||||||
order_obj.write(cr,uid,active_id,{'picking_id':new_picking})
|
order_obj.write(cr,uid,active_id,{'picking_id':new_picking})
|
||||||
|
|
||||||
|
@ -265,7 +262,6 @@ class add_product(osv.osv_memory):
|
||||||
if return_id:
|
if return_id:
|
||||||
data = return_boj.read(cr,uid,return_id,[])[0]
|
data = return_boj.read(cr,uid,return_id,[])[0]
|
||||||
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
self_data = self.browse(cr, uid, ids, context=context)[0]
|
self_data = self.browse(cr, uid, ids, context=context)[0]
|
||||||
order_obj.add_product(cr, uid, active_ids[0], self_data.product_id.id, self_data.quantity, context=context)
|
order_obj.add_product(cr, uid, active_ids[0], self_data.product_id.id, self_data.quantity, context=context)
|
||||||
|
|
||||||
|
@ -306,7 +302,7 @@ class add_product(osv.osv_memory):
|
||||||
'name':'%s (return)' % order_id.name,
|
'name':'%s (return)' % order_id.name,
|
||||||
'date':date_cur,
|
'date':date_cur,
|
||||||
})
|
})
|
||||||
wf_service.trg_validate(uid, 'stock.picking',new_picking,'button_confirm', cr)
|
picking_obj.signal_button_confirm(cr, uid, [new_picking])
|
||||||
picking_obj.force_assign(cr, uid, [new_picking], context)
|
picking_obj.force_assign(cr, uid, [new_picking], context)
|
||||||
obj=order_obj.browse(cr,uid, active_ids[0])
|
obj=order_obj.browse(cr,uid, active_ids[0])
|
||||||
context.update({'return':'return'})
|
context.update({'return':'return'})
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
from openerp.osv import osv, fields
|
from openerp.osv import osv, fields
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
|
||||||
|
@ -37,9 +36,8 @@ class pos_session_opening(osv.osv_memory):
|
||||||
}
|
}
|
||||||
|
|
||||||
def open_existing_session_cb_close(self, cr, uid, ids, context=None):
|
def open_existing_session_cb_close(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
wizard = self.browse(cr, uid, ids[0], context=context)
|
wizard = self.browse(cr, uid, ids[0], context=context)
|
||||||
wf_service.trg_validate(uid, 'pos.session', wizard.pos_session_id.id, 'cashbox_control', cr)
|
self.pool.get('pos.session').signal_cashbox_control(cr, uid, [wizard.pos_session_id.id])
|
||||||
return self.open_session_cb(cr, uid, ids, context)
|
return self.open_session_cb(cr, uid, ids, context)
|
||||||
|
|
||||||
def open_session_cb(self, cr, uid, ids, context=None):
|
def open_session_cb(self, cr, uid, ids, context=None):
|
||||||
|
|
|
@ -19,10 +19,12 @@
|
||||||
#
|
#
|
||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
|
from operator import attrgetter
|
||||||
|
import time
|
||||||
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
from openerp import netsvc
|
from openerp import netsvc
|
||||||
import time
|
|
||||||
import openerp.addons.decimal_precision as dp
|
import openerp.addons.decimal_precision as dp
|
||||||
|
|
||||||
# Procurement
|
# Procurement
|
||||||
|
@ -42,7 +44,6 @@ class mrp_property_group(osv.osv):
|
||||||
'name': fields.char('Property Group', size=64, required=True),
|
'name': fields.char('Property Group', size=64, required=True),
|
||||||
'description': fields.text('Description'),
|
'description': fields.text('Description'),
|
||||||
}
|
}
|
||||||
mrp_property_group()
|
|
||||||
|
|
||||||
class mrp_property(osv.osv):
|
class mrp_property(osv.osv):
|
||||||
"""
|
"""
|
||||||
|
@ -59,7 +60,6 @@ class mrp_property(osv.osv):
|
||||||
_defaults = {
|
_defaults = {
|
||||||
'composition': lambda *a: 'min',
|
'composition': lambda *a: 'min',
|
||||||
}
|
}
|
||||||
mrp_property()
|
|
||||||
|
|
||||||
class StockMove(osv.osv):
|
class StockMove(osv.osv):
|
||||||
_inherit = 'stock.move'
|
_inherit = 'stock.move'
|
||||||
|
@ -72,7 +72,6 @@ class StockMove(osv.osv):
|
||||||
default['procurements'] = []
|
default['procurements'] = []
|
||||||
return super(StockMove, self).copy(cr, uid, id, default, context=context)
|
return super(StockMove, self).copy(cr, uid, id, default, context=context)
|
||||||
|
|
||||||
StockMove()
|
|
||||||
|
|
||||||
class procurement_order(osv.osv):
|
class procurement_order(osv.osv):
|
||||||
"""
|
"""
|
||||||
|
@ -468,15 +467,12 @@ class procurement_order(osv.osv):
|
||||||
|
|
||||||
class StockPicking(osv.osv):
|
class StockPicking(osv.osv):
|
||||||
_inherit = 'stock.picking'
|
_inherit = 'stock.picking'
|
||||||
def test_finished(self, cursor, user, ids):
|
def test_finished(self, cr, uid, ids):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
res = super(StockPicking, self).test_finished(cr, uid, ids)
|
||||||
res = super(StockPicking, self).test_finished(cursor, user, ids)
|
for picking in self.browse(cr, uid, ids):
|
||||||
for picking in self.browse(cursor, user, ids):
|
|
||||||
for move in picking.move_lines:
|
for move in picking.move_lines:
|
||||||
if move.state == 'done' and move.procurements:
|
if move.state == 'done' and move.procurements:
|
||||||
for procurement in move.procurements:
|
self.pool.get('procurement.order').signal_button_check(cr, uid, map(attrgetter('id'), move.procurements))
|
||||||
wf_service.trg_validate(user, 'procurement.order',
|
|
||||||
procurement.id, 'button_check', cursor)
|
|
||||||
return res
|
return res
|
||||||
|
|
||||||
class stock_warehouse_orderpoint(osv.osv):
|
class stock_warehouse_orderpoint(osv.osv):
|
||||||
|
|
|
@ -57,13 +57,11 @@ class procurement_order(osv.osv):
|
||||||
try:
|
try:
|
||||||
if use_new_cursor:
|
if use_new_cursor:
|
||||||
cr = pooler.get_db(use_new_cursor).cursor()
|
cr = pooler.get_db(use_new_cursor).cursor()
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
|
|
||||||
procurement_obj = self.pool.get('procurement.order')
|
procurement_obj = self.pool.get('procurement.order')
|
||||||
if not ids:
|
if not ids:
|
||||||
ids = procurement_obj.search(cr, uid, [('state', '=', 'exception')], order="date_planned")
|
ids = procurement_obj.search(cr, uid, [('state', '=', 'exception')], order="date_planned")
|
||||||
for id in ids:
|
self.signal_button_restart(cr, uid, ids)
|
||||||
wf_service.trg_validate(uid, 'procurement.order', id, 'button_restart', cr)
|
|
||||||
if use_new_cursor:
|
if use_new_cursor:
|
||||||
cr.commit()
|
cr.commit()
|
||||||
company = self.pool.get('res.users').browse(cr, uid, uid, context=context).company_id
|
company = self.pool.get('res.users').browse(cr, uid, uid, context=context).company_id
|
||||||
|
@ -78,7 +76,7 @@ class procurement_order(osv.osv):
|
||||||
ids = procurement_obj.search(cr, uid, [('state', '=', 'confirmed'), ('procure_method', '=', 'make_to_order')], offset=offset, limit=500, order='priority, date_planned', context=context)
|
ids = procurement_obj.search(cr, uid, [('state', '=', 'confirmed'), ('procure_method', '=', 'make_to_order')], offset=offset, limit=500, order='priority, date_planned', context=context)
|
||||||
for proc in procurement_obj.browse(cr, uid, ids, context=context):
|
for proc in procurement_obj.browse(cr, uid, ids, context=context):
|
||||||
if maxdate >= proc.date_planned:
|
if maxdate >= proc.date_planned:
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc.id, 'button_check', cr)
|
self.signal_button_check(cr, uid, [proc.id])
|
||||||
else:
|
else:
|
||||||
offset += 1
|
offset += 1
|
||||||
report_later += 1
|
report_later += 1
|
||||||
|
@ -100,7 +98,7 @@ class procurement_order(osv.osv):
|
||||||
ids = procurement_obj.search(cr, uid, [('state', '=', 'confirmed'), ('procure_method', '=', 'make_to_stock')], offset=offset)
|
ids = procurement_obj.search(cr, uid, [('state', '=', 'confirmed'), ('procure_method', '=', 'make_to_stock')], offset=offset)
|
||||||
for proc in procurement_obj.browse(cr, uid, ids):
|
for proc in procurement_obj.browse(cr, uid, ids):
|
||||||
if maxdate >= proc.date_planned:
|
if maxdate >= proc.date_planned:
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc.id, 'button_check', cr)
|
self.signal_button_check(cr, uid, [proc.id])
|
||||||
report_ids.append(proc.id)
|
report_ids.append(proc.id)
|
||||||
else:
|
else:
|
||||||
report_later += 1
|
report_later += 1
|
||||||
|
@ -155,7 +153,6 @@ class procurement_order(osv.osv):
|
||||||
product_obj = self.pool.get('product.product')
|
product_obj = self.pool.get('product.product')
|
||||||
proc_obj = self.pool.get('procurement.order')
|
proc_obj = self.pool.get('procurement.order')
|
||||||
warehouse_obj = self.pool.get('stock.warehouse')
|
warehouse_obj = self.pool.get('stock.warehouse')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
|
|
||||||
warehouse_ids = warehouse_obj.search(cr, uid, [], context=context)
|
warehouse_ids = warehouse_obj.search(cr, uid, [], context=context)
|
||||||
products_ids = product_obj.search(cr, uid, [('purchase_ok', '=', True)], order='id', context=context)
|
products_ids = product_obj.search(cr, uid, [('purchase_ok', '=', True)], order='id', context=context)
|
||||||
|
@ -178,8 +175,8 @@ class procurement_order(osv.osv):
|
||||||
proc_id = proc_obj.create(cr, uid,
|
proc_id = proc_obj.create(cr, uid,
|
||||||
self._prepare_automatic_op_procurement(cr, uid, product, warehouse, location_id, context=context),
|
self._prepare_automatic_op_procurement(cr, uid, product, warehouse, location_id, context=context),
|
||||||
context=context)
|
context=context)
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc_id, 'button_confirm', cr)
|
self.signal_button_confirm(cr, uid, [proc_id])
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc_id, 'button_check', cr)
|
self.signal_button_check(cr, uid, [proc_id])
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _get_orderpoint_date_planned(self, cr, uid, orderpoint, start_date, context=None):
|
def _get_orderpoint_date_planned(self, cr, uid, orderpoint, start_date, context=None):
|
||||||
|
@ -225,7 +222,6 @@ class procurement_order(osv.osv):
|
||||||
orderpoint_obj = self.pool.get('stock.warehouse.orderpoint')
|
orderpoint_obj = self.pool.get('stock.warehouse.orderpoint')
|
||||||
|
|
||||||
procurement_obj = self.pool.get('procurement.order')
|
procurement_obj = self.pool.get('procurement.order')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
offset = 0
|
offset = 0
|
||||||
ids = [1]
|
ids = [1]
|
||||||
if automatic:
|
if automatic:
|
||||||
|
@ -254,7 +250,7 @@ class procurement_order(osv.osv):
|
||||||
to_generate = qty
|
to_generate = qty
|
||||||
for proc_data in procure_datas:
|
for proc_data in procure_datas:
|
||||||
if to_generate >= proc_data['product_qty']:
|
if to_generate >= proc_data['product_qty']:
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc_data['id'], 'button_confirm', cr)
|
self.signal_button_confirm(cr, uid, [proc_data['id']])
|
||||||
procurement_obj.write(cr, uid, [proc_data['id']], {'origin': op.name}, context=context)
|
procurement_obj.write(cr, uid, [proc_data['id']], {'origin': op.name}, context=context)
|
||||||
to_generate -= proc_data['product_qty']
|
to_generate -= proc_data['product_qty']
|
||||||
if not to_generate:
|
if not to_generate:
|
||||||
|
@ -265,10 +261,8 @@ class procurement_order(osv.osv):
|
||||||
proc_id = procurement_obj.create(cr, uid,
|
proc_id = procurement_obj.create(cr, uid,
|
||||||
self._prepare_orderpoint_procurement(cr, uid, op, qty, context=context),
|
self._prepare_orderpoint_procurement(cr, uid, op, qty, context=context),
|
||||||
context=context)
|
context=context)
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc_id,
|
self.signal_button_confirm(cr, uid, [proc_id])
|
||||||
'button_confirm', cr)
|
self.signal_button_check(cr, uid, [proc_id])
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc_id,
|
|
||||||
'button_check', cr)
|
|
||||||
orderpoint_obj.write(cr, uid, [op.id],
|
orderpoint_obj.write(cr, uid, [op.id],
|
||||||
{'procurement_id': proc_id}, context=context)
|
{'procurement_id': proc_id}, context=context)
|
||||||
offset += len(ids)
|
offset += len(ids)
|
||||||
|
@ -279,6 +273,4 @@ class procurement_order(osv.osv):
|
||||||
cr.close()
|
cr.close()
|
||||||
return {}
|
return {}
|
||||||
|
|
||||||
procurement_order()
|
|
||||||
|
|
||||||
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
#
|
#
|
||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
from openerp import netsvc
|
|
||||||
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
|
|
||||||
|
@ -64,7 +63,6 @@ class make_procurement(osv.osv_memory):
|
||||||
user = self.pool.get('res.users').browse(cr, uid, uid, context=context).login
|
user = self.pool.get('res.users').browse(cr, uid, uid, context=context).login
|
||||||
wh_obj = self.pool.get('stock.warehouse')
|
wh_obj = self.pool.get('stock.warehouse')
|
||||||
procurement_obj = self.pool.get('procurement.order')
|
procurement_obj = self.pool.get('procurement.order')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
data_obj = self.pool.get('ir.model.data')
|
data_obj = self.pool.get('ir.model.data')
|
||||||
|
|
||||||
for proc in self.browse(cr, uid, ids, context=context):
|
for proc in self.browse(cr, uid, ids, context=context):
|
||||||
|
@ -78,9 +76,7 @@ class make_procurement(osv.osv_memory):
|
||||||
'location_id': wh.lot_stock_id.id,
|
'location_id': wh.lot_stock_id.id,
|
||||||
'procure_method':'make_to_order',
|
'procure_method':'make_to_order',
|
||||||
})
|
})
|
||||||
|
procurement_obj.signal_button_confirm(cr, uid, [procure_id])
|
||||||
wf_service.trg_validate(uid, 'procurement.order', procure_id, 'button_confirm', cr)
|
|
||||||
|
|
||||||
|
|
||||||
id2 = data_obj._get_id(cr, uid, 'procurement', 'procurement_tree_view')
|
id2 = data_obj._get_id(cr, uid, 'procurement', 'procurement_tree_view')
|
||||||
id3 = data_obj._get_id(cr, uid, 'procurement', 'procurement_form_view')
|
id3 = data_obj._get_id(cr, uid, 'procurement', 'procurement_form_view')
|
||||||
|
|
|
@ -22,9 +22,9 @@
|
||||||
import time
|
import time
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from dateutil.relativedelta import relativedelta
|
from dateutil.relativedelta import relativedelta
|
||||||
|
from operator import attrgetter
|
||||||
|
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp import netsvc
|
|
||||||
from openerp import pooler
|
from openerp import pooler
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
import openerp.addons.decimal_precision as dp
|
import openerp.addons.decimal_precision as dp
|
||||||
|
@ -260,9 +260,7 @@ class purchase_order(osv.osv):
|
||||||
raise osv.except_osv(_('Invalid Action!'), _('In order to delete a purchase order, you must cancel it first.'))
|
raise osv.except_osv(_('Invalid Action!'), _('In order to delete a purchase order, you must cancel it first.'))
|
||||||
|
|
||||||
# automatically sending subflow.delete upon deletion
|
# automatically sending subflow.delete upon deletion
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_purchase_cancel(cr, uid, unlink_ids)
|
||||||
for id in unlink_ids:
|
|
||||||
wf_service.trg_validate(uid, 'purchase.order', id, 'purchase_cancel', cr)
|
|
||||||
|
|
||||||
return super(purchase_order, self).unlink(cr, uid, unlink_ids, context=context)
|
return super(purchase_order, self).unlink(cr, uid, unlink_ids, context=context)
|
||||||
|
|
||||||
|
@ -439,8 +437,7 @@ class purchase_order(osv.osv):
|
||||||
This function prints the request for quotation and mark it as sent, so that we can see more easily the next step of the workflow
|
This function prints the request for quotation and mark it as sent, so that we can see more easily the next step of the workflow
|
||||||
'''
|
'''
|
||||||
assert len(ids) == 1, 'This option should only be used for a single id at a time'
|
assert len(ids) == 1, 'This option should only be used for a single id at a time'
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_send_rfq(cr, uid, ids)
|
||||||
wf_service.trg_validate(uid, 'purchase.order', ids[0], 'send_rfq', cr)
|
|
||||||
datas = {
|
datas = {
|
||||||
'model': 'purchase.order',
|
'model': 'purchase.order',
|
||||||
'ids': ids,
|
'ids': ids,
|
||||||
|
@ -486,11 +483,10 @@ class purchase_order(osv.osv):
|
||||||
if not len(ids):
|
if not len(ids):
|
||||||
return False
|
return False
|
||||||
self.write(cr, uid, ids, {'state':'draft','shipped':0})
|
self.write(cr, uid, ids, {'state':'draft','shipped':0})
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for p_id in ids:
|
for p_id in ids:
|
||||||
# Deleting the existing instance of workflow for PO
|
# Deleting the existing instance of workflow for PO
|
||||||
wf_service.trg_delete(uid, 'purchase.order', p_id, cr)
|
self.delete_workflow(cr, uid, [p_id]) # TODO is it necessary to interleave the calls?
|
||||||
wf_service.trg_create(uid, 'purchase.order', p_id, cr)
|
self.create_workflow(cr, uid, [p_id])
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def action_invoice_create(self, cr, uid, ids, context=None):
|
def action_invoice_create(self, cr, uid, ids, context=None):
|
||||||
|
@ -571,26 +567,24 @@ class purchase_order(osv.osv):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def action_cancel(self, cr, uid, ids, context=None):
|
def action_cancel(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for purchase in self.browse(cr, uid, ids, context=context):
|
for purchase in self.browse(cr, uid, ids, context=context):
|
||||||
for pick in purchase.picking_ids:
|
for pick in purchase.picking_ids:
|
||||||
if pick.state not in ('draft','cancel'):
|
if pick.state not in ('draft','cancel'):
|
||||||
raise osv.except_osv(
|
raise osv.except_osv(
|
||||||
_('Unable to cancel this purchase order.'),
|
_('Unable to cancel this purchase order.'),
|
||||||
_('First cancel all receptions related to this purchase order.'))
|
_('First cancel all receptions related to this purchase order.'))
|
||||||
for pick in purchase.picking_ids:
|
self.pool.get('stock.picking') \
|
||||||
wf_service.trg_validate(uid, 'stock.picking', pick.id, 'button_cancel', cr)
|
.signal_button_cancel(cr, uid, map(attrgetter('id'), purchase.picking_ids))
|
||||||
for inv in purchase.invoice_ids:
|
for inv in purchase.invoice_ids:
|
||||||
if inv and inv.state not in ('cancel','draft'):
|
if inv and inv.state not in ('cancel','draft'):
|
||||||
raise osv.except_osv(
|
raise osv.except_osv(
|
||||||
_('Unable to cancel this purchase order.'),
|
_('Unable to cancel this purchase order.'),
|
||||||
_('You must first cancel all receptions related to this purchase order.'))
|
_('You must first cancel all receptions related to this purchase order.'))
|
||||||
if inv:
|
self.pool.get('account.invoice') \
|
||||||
wf_service.trg_validate(uid, 'account.invoice', inv.id, 'invoice_cancel', cr)
|
.signal_invoice_cancel(cr, uid, map(attrgetter('id'), purchase.invoice_ids))
|
||||||
self.write(cr,uid,ids,{'state':'cancel'})
|
self.write(cr,uid,ids,{'state':'cancel'})
|
||||||
|
|
||||||
for (id, name) in self.name_get(cr, uid, ids):
|
self.signal_purchase_cancel(cr, uid, ids)
|
||||||
wf_service.trg_validate(uid, 'purchase.order', id, 'purchase_cancel', cr)
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _prepare_order_picking(self, cr, uid, order, context=None):
|
def _prepare_order_picking(self, cr, uid, order, context=None):
|
||||||
|
@ -648,11 +642,11 @@ class purchase_order(osv.osv):
|
||||||
will be added. A new picking will be created if omitted.
|
will be added. A new picking will be created if omitted.
|
||||||
:return: list of IDs of pickings used/created for the given order lines (usually just one)
|
:return: list of IDs of pickings used/created for the given order lines (usually just one)
|
||||||
"""
|
"""
|
||||||
|
stock_picking = self.pool.get('stock.picking')
|
||||||
if not picking_id:
|
if not picking_id:
|
||||||
picking_id = self.pool.get('stock.picking').create(cr, uid, self._prepare_order_picking(cr, uid, order, context=context))
|
picking_id = stock_picking.create(cr, uid, self._prepare_order_picking(cr, uid, order, context=context))
|
||||||
todo_moves = []
|
todo_moves = []
|
||||||
stock_move = self.pool.get('stock.move')
|
stock_move = self.pool.get('stock.move')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for order_line in order_lines:
|
for order_line in order_lines:
|
||||||
if not order_line.product_id:
|
if not order_line.product_id:
|
||||||
continue
|
continue
|
||||||
|
@ -663,7 +657,7 @@ class purchase_order(osv.osv):
|
||||||
todo_moves.append(move)
|
todo_moves.append(move)
|
||||||
stock_move.action_confirm(cr, uid, todo_moves)
|
stock_move.action_confirm(cr, uid, todo_moves)
|
||||||
stock_move.force_assign(cr, uid, todo_moves)
|
stock_move.force_assign(cr, uid, todo_moves)
|
||||||
wf_service.trg_validate(uid, 'stock.picking', picking_id, 'button_confirm', cr)
|
stock_picking.signal_button_confirm(cr, uid, [picking_id])
|
||||||
return [picking_id]
|
return [picking_id]
|
||||||
|
|
||||||
def action_picking_create(self, cr, uid, ids, context=None):
|
def action_picking_create(self, cr, uid, ids, context=None):
|
||||||
|
@ -714,7 +708,6 @@ class purchase_order(osv.osv):
|
||||||
|
|
||||||
"""
|
"""
|
||||||
#TOFIX: merged order line should be unlink
|
#TOFIX: merged order line should be unlink
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
def make_key(br, fields):
|
def make_key(br, fields):
|
||||||
list_key = []
|
list_key = []
|
||||||
for field in fields:
|
for field in fields:
|
||||||
|
@ -801,8 +794,8 @@ class purchase_order(osv.osv):
|
||||||
|
|
||||||
# make triggers pointing to the old orders point to the new order
|
# make triggers pointing to the old orders point to the new order
|
||||||
for old_id in old_ids:
|
for old_id in old_ids:
|
||||||
wf_service.trg_redirect(uid, 'purchase.order', old_id, neworder_id, cr)
|
self.redirect_workflow(cr, uid, [(old_id, neworder_id)])
|
||||||
wf_service.trg_validate(uid, 'purchase.order', old_id, 'purchase_cancel', cr)
|
self.signal_purchase_cancel(cr, uid, [old_id]) # TODO Is it necessary to interleave the calls?
|
||||||
return orders_info
|
return orders_info
|
||||||
|
|
||||||
|
|
||||||
|
@ -1169,8 +1162,7 @@ class mail_mail(osv.Model):
|
||||||
|
|
||||||
def _postprocess_sent_message(self, cr, uid, mail, context=None):
|
def _postprocess_sent_message(self, cr, uid, mail, context=None):
|
||||||
if mail.model == 'purchase.order':
|
if mail.model == 'purchase.order':
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('purchase.order').signal_send_rfq(cr, uid, [mail.res_id])
|
||||||
wf_service.trg_validate(uid, 'purchase.order', mail.res_id, 'send_rfq', cr)
|
|
||||||
return super(mail_mail, self)._postprocess_sent_message(cr, uid, mail=mail, context=context)
|
return super(mail_mail, self)._postprocess_sent_message(cr, uid, mail=mail, context=context)
|
||||||
|
|
||||||
|
|
||||||
|
@ -1192,8 +1184,7 @@ class mail_compose_message(osv.Model):
|
||||||
context = context or {}
|
context = context or {}
|
||||||
if context.get('default_model') == 'purchase.order' and context.get('default_res_id'):
|
if context.get('default_model') == 'purchase.order' and context.get('default_res_id'):
|
||||||
context = dict(context, mail_post_autofollow=True)
|
context = dict(context, mail_post_autofollow=True)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('purchase.order').signal_send_rfq(cr, uid, [context['default_res_id']])
|
||||||
wf_service.trg_validate(uid, 'purchase.order', context['default_res_id'], 'send_rfq', cr)
|
|
||||||
return super(mail_compose_message, self).send_mail(cr, uid, ids, context=context)
|
return super(mail_compose_message, self).send_mail(cr, uid, ids, context=context)
|
||||||
|
|
||||||
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
||||||
|
|
|
@ -59,11 +59,8 @@
|
||||||
I Validate Invoice of Purchase Order.
|
I Validate Invoice of Purchase Order.
|
||||||
-
|
-
|
||||||
!python {model: purchase.order}: |
|
!python {model: purchase.order}: |
|
||||||
from openerp import netsvc
|
|
||||||
invoice_ids = [x.id for x in self.browse(cr, uid, ref("purchase_order_1")).invoice_ids]
|
invoice_ids = [x.id for x in self.browse(cr, uid, ref("purchase_order_1")).invoice_ids]
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('account.invoice').signal_invoice_open(cr, uid, invoice_ids)
|
||||||
for invoice in invoice_ids:
|
|
||||||
wf_service.trg_validate(uid, 'account.invoice', invoice, 'invoice_open', cr)
|
|
||||||
-
|
-
|
||||||
I check that purchase order is invoiced.
|
I check that purchase order is invoiced.
|
||||||
-
|
-
|
||||||
|
|
|
@ -22,7 +22,6 @@
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from dateutil.relativedelta import relativedelta
|
from dateutil.relativedelta import relativedelta
|
||||||
import time
|
import time
|
||||||
from openerp import netsvc
|
|
||||||
|
|
||||||
from openerp.osv import fields,osv
|
from openerp.osv import fields,osv
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
@ -211,8 +210,7 @@ class purchase_order(osv.osv):
|
||||||
proc_ids = proc_obj.search(cr, uid, [('purchase_id', '=', order.id)])
|
proc_ids = proc_obj.search(cr, uid, [('purchase_id', '=', order.id)])
|
||||||
if proc_ids and po.state=='confirmed':
|
if proc_ids and po.state=='confirmed':
|
||||||
proc_obj.write(cr, uid, proc_ids, {'purchase_id': po.id})
|
proc_obj.write(cr, uid, proc_ids, {'purchase_id': po.id})
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_purchase_cancel(cr, uid, [order.id])
|
||||||
wf_service.trg_validate(uid, 'purchase.order', order.id, 'purchase_cancel', cr)
|
|
||||||
po.requisition_id.tender_done(context=context)
|
po.requisition_id.tender_done(context=context)
|
||||||
return res
|
return res
|
||||||
|
|
||||||
|
|
|
@ -69,10 +69,8 @@
|
||||||
I confirmed RFQ which has best price.
|
I confirmed RFQ which has best price.
|
||||||
-
|
-
|
||||||
!python {model: purchase.order}: |
|
!python {model: purchase.order}: |
|
||||||
from openerp import netsvc
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
purchase = self.browse(cr, uid, ref('rfq2'), context=context)
|
purchase = self.browse(cr, uid, ref('rfq2'), context=context)
|
||||||
wf_service.trg_validate(uid, 'purchase.order', purchase.id, 'purchase_confirm', cr)
|
self.signal_purchase_confirm(cr, uid, [purchase.id])
|
||||||
|
|
||||||
-
|
-
|
||||||
I check status of requisition after confirmed best RFQ.
|
I check status of requisition after confirmed best RFQ.
|
||||||
|
|
|
@ -418,8 +418,7 @@ class sale_order(osv.osv):
|
||||||
This function prints the sales order and mark it as sent, so that we can see more easily the next step of the workflow
|
This function prints the sales order and mark it as sent, so that we can see more easily the next step of the workflow
|
||||||
'''
|
'''
|
||||||
assert len(ids) == 1, 'This option should only be used for a single id at a time'
|
assert len(ids) == 1, 'This option should only be used for a single id at a time'
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.signal_quotation_sent(cr, uid, ids)
|
||||||
wf_service.trg_validate(uid, 'sale.order', ids[0], 'quotation_sent', cr)
|
|
||||||
datas = {
|
datas = {
|
||||||
'model': 'sale.order',
|
'model': 'sale.order',
|
||||||
'ids': ids,
|
'ids': ids,
|
||||||
|
@ -432,12 +431,10 @@ class sale_order(osv.osv):
|
||||||
view of one of the newly created invoices
|
view of one of the newly created invoices
|
||||||
"""
|
"""
|
||||||
mod_obj = self.pool.get('ir.model.data')
|
mod_obj = self.pool.get('ir.model.data')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
|
|
||||||
# create invoices through the sales orders' workflow
|
# create invoices through the sales orders' workflow
|
||||||
inv_ids0 = set(inv.id for sale in self.browse(cr, uid, ids, context) for inv in sale.invoice_ids)
|
inv_ids0 = set(inv.id for sale in self.browse(cr, uid, ids, context) for inv in sale.invoice_ids)
|
||||||
for id in ids:
|
self.signal_manual_invoice(cr, uid, ids)
|
||||||
wf_service.trg_validate(uid, 'sale.order', id, 'manual_invoice', cr)
|
|
||||||
inv_ids1 = set(inv.id for sale in self.browse(cr, uid, ids, context) for inv in sale.invoice_ids)
|
inv_ids1 = set(inv.id for sale in self.browse(cr, uid, ids, context) for inv in sale.invoice_ids)
|
||||||
# determine newly created invoices
|
# determine newly created invoices
|
||||||
new_inv_ids = list(inv_ids1 - inv_ids0)
|
new_inv_ids = list(inv_ids1 - inv_ids0)
|
||||||
|
@ -555,10 +552,10 @@ class sale_order(osv.osv):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def action_cancel(self, cr, uid, ids, context=None):
|
def action_cancel(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
if context is None:
|
if context is None:
|
||||||
context = {}
|
context = {}
|
||||||
sale_order_line_obj = self.pool.get('sale.order.line')
|
sale_order_line_obj = self.pool.get('sale.order.line')
|
||||||
|
account_invoice_obj = self.pool.get('account.invoice')
|
||||||
for sale in self.browse(cr, uid, ids, context=context):
|
for sale in self.browse(cr, uid, ids, context=context):
|
||||||
for inv in sale.invoice_ids:
|
for inv in sale.invoice_ids:
|
||||||
if inv.state not in ('draft', 'cancel'):
|
if inv.state not in ('draft', 'cancel'):
|
||||||
|
@ -566,8 +563,7 @@ class sale_order(osv.osv):
|
||||||
_('Cannot cancel this sales order!'),
|
_('Cannot cancel this sales order!'),
|
||||||
_('First cancel all invoices attached to this sales order.'))
|
_('First cancel all invoices attached to this sales order.'))
|
||||||
for r in self.read(cr, uid, ids, ['invoice_ids']):
|
for r in self.read(cr, uid, ids, ['invoice_ids']):
|
||||||
for inv in r['invoice_ids']:
|
account_invoice_obj.signal_invoice_cancel(cr, uid, r['invoice_ids'])
|
||||||
wf_service.trg_validate(uid, 'account.invoice', inv, 'invoice_cancel', cr)
|
|
||||||
sale_order_line_obj.write(cr, uid, [l.id for l in sale.order_line],
|
sale_order_line_obj.write(cr, uid, [l.id for l in sale.order_line],
|
||||||
{'state': 'cancel'})
|
{'state': 'cancel'})
|
||||||
self.write(cr, uid, ids, {'state': 'cancel'})
|
self.write(cr, uid, ids, {'state': 'cancel'})
|
||||||
|
@ -575,8 +571,7 @@ class sale_order(osv.osv):
|
||||||
|
|
||||||
def action_button_confirm(self, cr, uid, ids, context=None):
|
def action_button_confirm(self, cr, uid, ids, context=None):
|
||||||
assert len(ids) == 1, 'This option should only be used for a single id at a time.'
|
assert len(ids) == 1, 'This option should only be used for a single id at a time.'
|
||||||
wf_service = netsvc.LocalService('workflow')
|
self.signal_order_confirm(cr, uid, ids)
|
||||||
wf_service.trg_validate(uid, 'sale.order', ids[0], 'order_confirm', cr)
|
|
||||||
|
|
||||||
# redisplay the record as a sales order
|
# redisplay the record as a sales order
|
||||||
view_ref = self.pool.get('ir.model.data').get_object_reference(cr, uid, 'sale', 'view_order_form')
|
view_ref = self.pool.get('ir.model.data').get_object_reference(cr, uid, 'sale', 'view_order_form')
|
||||||
|
@ -991,8 +986,7 @@ class mail_compose_message(osv.Model):
|
||||||
context = context or {}
|
context = context or {}
|
||||||
if context.get('default_model') == 'sale.order' and context.get('default_res_id') and context.get('mark_so_as_sent'):
|
if context.get('default_model') == 'sale.order' and context.get('default_res_id') and context.get('mark_so_as_sent'):
|
||||||
context = dict(context, mail_post_autofollow=True)
|
context = dict(context, mail_post_autofollow=True)
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('sale.order').signal_quotation_sent(cr, uid, [context['default_res_id']])
|
||||||
wf_service.trg_validate(uid, 'sale.order', context['default_res_id'], 'quotation_sent', cr)
|
|
||||||
return super(mail_compose_message, self).send_mail(cr, uid, ids, context=context)
|
return super(mail_compose_message, self).send_mail(cr, uid, ids, context=context)
|
||||||
|
|
||||||
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
||||||
|
|
|
@ -51,11 +51,10 @@
|
||||||
I cancel all the invoices.
|
I cancel all the invoices.
|
||||||
-
|
-
|
||||||
!python {model: sale.order}: |
|
!python {model: sale.order}: |
|
||||||
from openerp import netsvc
|
|
||||||
invoice_ids = self.browse(cr, uid, ref("sale_order_8")).invoice_ids
|
invoice_ids = self.browse(cr, uid, ref("sale_order_8")).invoice_ids
|
||||||
wf_service = netsvc.LocalService("workflow")
|
account_invoice_obj = self.pool.get('account.invoice')
|
||||||
for invoice in invoice_ids:
|
for invoice in invoice_ids:
|
||||||
wf_service.trg_validate(uid, 'account.invoice', invoice.id, 'invoice_cancel', cr)
|
account_invoice_obj.signal_invoice_cancel(cr, uid, [invoice.id])
|
||||||
-
|
-
|
||||||
I check order status in "Invoice Exception" and related invoice is in cancel state.
|
I check order status in "Invoice Exception" and related invoice is in cancel state.
|
||||||
-
|
-
|
||||||
|
|
|
@ -41,11 +41,10 @@
|
||||||
I open the Invoice.
|
I open the Invoice.
|
||||||
-
|
-
|
||||||
!python {model: sale.order}: |
|
!python {model: sale.order}: |
|
||||||
from openerp import netsvc
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
so = self.browse(cr, uid, ref("sale_order_2"))
|
so = self.browse(cr, uid, ref("sale_order_2"))
|
||||||
|
account_invoice_obj = self.pool.get('account.invoice')
|
||||||
for invoice in so.invoice_ids:
|
for invoice in so.invoice_ids:
|
||||||
wf_service.trg_validate(uid, 'account.invoice', invoice.id, 'invoice_open', cr)
|
account_invoice_obj.signal_invoice_open(cr, uid, [invoice.id])
|
||||||
-
|
-
|
||||||
I pay the invoice.
|
I pay the invoice.
|
||||||
-
|
-
|
||||||
|
|
|
@ -80,7 +80,6 @@ class sale_order_line_make_invoice(osv.osv_memory):
|
||||||
|
|
||||||
sales_order_line_obj = self.pool.get('sale.order.line')
|
sales_order_line_obj = self.pool.get('sale.order.line')
|
||||||
sales_order_obj = self.pool.get('sale.order')
|
sales_order_obj = self.pool.get('sale.order')
|
||||||
wf_service = netsvc.LocalService('workflow')
|
|
||||||
for line in sales_order_line_obj.browse(cr, uid, context.get('active_ids', []), context=context):
|
for line in sales_order_line_obj.browse(cr, uid, context.get('active_ids', []), context=context):
|
||||||
if (not line.invoiced) and (line.state not in ('draft', 'cancel')):
|
if (not line.invoiced) and (line.state not in ('draft', 'cancel')):
|
||||||
if not line.order_id.id in invoices:
|
if not line.order_id.id in invoices:
|
||||||
|
@ -103,7 +102,7 @@ class sale_order_line_make_invoice(osv.osv_memory):
|
||||||
flag = False
|
flag = False
|
||||||
break
|
break
|
||||||
if flag:
|
if flag:
|
||||||
wf_service.trg_validate(uid, 'sale.order', line.order_id.id, 'manual_invoice', cr)
|
sales_order_obj.signal_manual_invoice(cr, uid, [line.order_id.id])
|
||||||
sales_order_obj.write(cr, uid, [line.order_id.id], {'state': 'progress'})
|
sales_order_obj.write(cr, uid, [line.order_id.id], {'state': 'progress'})
|
||||||
|
|
||||||
if not invoices:
|
if not invoices:
|
||||||
|
|
|
@ -52,9 +52,7 @@ class sale_make_invoice(osv.osv_memory):
|
||||||
context = {}
|
context = {}
|
||||||
data = self.read(cr, uid, ids)[0]
|
data = self.read(cr, uid, ids)[0]
|
||||||
order_obj.action_invoice_create(cr, uid, context.get(('active_ids'), []), data['grouped'], date_inv = data['invoice_date'])
|
order_obj.action_invoice_create(cr, uid, context.get(('active_ids'), []), data['grouped'], date_inv = data['invoice_date'])
|
||||||
wf_service = netsvc.LocalService("workflow")
|
order_obj.signal_manual_invoice(cr, uid, context.get(('active_ids'), []))
|
||||||
for id in context.get(('active_ids'), []):
|
|
||||||
wf_service.trg_validate(uid, 'sale.order', id, 'manual_invoice', cr)
|
|
||||||
|
|
||||||
for o in order_obj.browse(cr, uid, context.get(('active_ids'), []), context=context):
|
for o in order_obj.browse(cr, uid, context.get(('active_ids'), []), context=context):
|
||||||
for i in o.invoice_ids:
|
for i in o.invoice_ids:
|
||||||
|
|
|
@ -103,11 +103,8 @@
|
||||||
!python {model: procurement.order}: |
|
!python {model: procurement.order}: |
|
||||||
sale_order_obj = self.pool.get('sale.order')
|
sale_order_obj = self.pool.get('sale.order')
|
||||||
so = sale_order_obj.browse(cr, uid, ref("sale_order_so0"))
|
so = sale_order_obj.browse(cr, uid, ref("sale_order_so0"))
|
||||||
from openerp import netsvc
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
proc_ids = self.search(cr, uid, [('origin','=',so.name)])
|
proc_ids = self.search(cr, uid, [('origin','=',so.name)])
|
||||||
for proc in proc_ids:
|
self.signal_button_check(cr, uid, proc_ids)
|
||||||
wf_service.trg_validate(uid, 'procurement.order',proc,'button_check', cr)
|
|
||||||
-
|
-
|
||||||
I verify that a procurement state is "running"
|
I verify that a procurement state is "running"
|
||||||
-
|
-
|
||||||
|
|
|
@ -23,7 +23,6 @@ from datetime import datetime, timedelta
|
||||||
from openerp.tools import DEFAULT_SERVER_DATE_FORMAT, DEFAULT_SERVER_DATETIME_FORMAT, DATETIME_FORMATS_MAP, float_compare
|
from openerp.tools import DEFAULT_SERVER_DATE_FORMAT, DEFAULT_SERVER_DATETIME_FORMAT, DATETIME_FORMATS_MAP, float_compare
|
||||||
from dateutil.relativedelta import relativedelta
|
from dateutil.relativedelta import relativedelta
|
||||||
from openerp.osv import fields, osv
|
from openerp.osv import fields, osv
|
||||||
from openerp import netsvc
|
|
||||||
from openerp.tools.translate import _
|
from openerp.tools.translate import _
|
||||||
|
|
||||||
class sale_shop(osv.osv):
|
class sale_shop(osv.osv):
|
||||||
|
@ -194,11 +193,11 @@ class sale_order(osv.osv):
|
||||||
return res
|
return res
|
||||||
|
|
||||||
def action_cancel(self, cr, uid, ids, context=None):
|
def action_cancel(self, cr, uid, ids, context=None):
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
if context is None:
|
if context is None:
|
||||||
context = {}
|
context = {}
|
||||||
sale_order_line_obj = self.pool.get('sale.order.line')
|
sale_order_line_obj = self.pool.get('sale.order.line')
|
||||||
proc_obj = self.pool.get('procurement.order')
|
proc_obj = self.pool.get('procurement.order')
|
||||||
|
stock_obj = self.pool.get('stock.picking')
|
||||||
for sale in self.browse(cr, uid, ids, context=context):
|
for sale in self.browse(cr, uid, ids, context=context):
|
||||||
for pick in sale.picking_ids:
|
for pick in sale.picking_ids:
|
||||||
if pick.state not in ('draft', 'cancel'):
|
if pick.state not in ('draft', 'cancel'):
|
||||||
|
@ -209,11 +208,9 @@ class sale_order(osv.osv):
|
||||||
for mov in pick.move_lines:
|
for mov in pick.move_lines:
|
||||||
proc_ids = proc_obj.search(cr, uid, [('move_id', '=', mov.id)])
|
proc_ids = proc_obj.search(cr, uid, [('move_id', '=', mov.id)])
|
||||||
if proc_ids:
|
if proc_ids:
|
||||||
for proc in proc_ids:
|
proc_obj.signal_button_check(cr, uid, proc_ids)
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc, 'button_check', cr)
|
|
||||||
for r in self.read(cr, uid, ids, ['picking_ids']):
|
for r in self.read(cr, uid, ids, ['picking_ids']):
|
||||||
for pick in r['picking_ids']:
|
stock_obj.signal_button_cancel(cr, uid, r['picking_ids'])
|
||||||
wf_service.trg_validate(uid, 'stock.picking', pick, 'button_cancel', cr)
|
|
||||||
return super(sale_order, self).action_cancel(cr, uid, ids, context=context)
|
return super(sale_order, self).action_cancel(cr, uid, ids, context=context)
|
||||||
|
|
||||||
def action_wait(self, cr, uid, ids, context=None):
|
def action_wait(self, cr, uid, ids, context=None):
|
||||||
|
@ -396,11 +393,9 @@ class sale_order(osv.osv):
|
||||||
line.write({'procurement_id': proc_id})
|
line.write({'procurement_id': proc_id})
|
||||||
self.ship_recreate(cr, uid, order, line, move_id, proc_id)
|
self.ship_recreate(cr, uid, order, line, move_id, proc_id)
|
||||||
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
if picking_id:
|
if picking_id:
|
||||||
wf_service.trg_validate(uid, 'stock.picking', picking_id, 'button_confirm', cr)
|
picking_obj.signal_button_confirm(cr, uid, [picking_id])
|
||||||
for proc_id in proc_ids:
|
procurement_obj.signal_button_confirm(cr, uid, proc_ids)
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc_id, 'button_confirm', cr)
|
|
||||||
|
|
||||||
val = {}
|
val = {}
|
||||||
if order.state == 'shipping_except':
|
if order.state == 'shipping_except':
|
||||||
|
|
|
@ -17,11 +17,9 @@
|
||||||
Now I cancel latest shipment.
|
Now I cancel latest shipment.
|
||||||
-
|
-
|
||||||
!python {model: stock.picking}: |
|
!python {model: stock.picking}: |
|
||||||
from openerp import netsvc
|
|
||||||
delivery_orders = self.search(cr, uid, [('sale_id','=',ref("sale.sale_order_8"))])
|
delivery_orders = self.search(cr, uid, [('sale_id','=',ref("sale.sale_order_8"))])
|
||||||
last_delivery_order_id = delivery_orders[0]
|
last_delivery_order_id = delivery_orders[0]
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('stock.picking').signal_button_cancel(cr, uid, [last_delivery_order_id])
|
||||||
wf_service.trg_validate(uid, 'stock.picking', last_delivery_order_id, 'button_cancel', cr)
|
|
||||||
-
|
-
|
||||||
I run the scheduler.
|
I run the scheduler.
|
||||||
-
|
-
|
||||||
|
@ -50,11 +48,9 @@
|
||||||
To cancel the sale order from Invoice Exception, I have to cancel the invoice of sale order.
|
To cancel the sale order from Invoice Exception, I have to cancel the invoice of sale order.
|
||||||
-
|
-
|
||||||
!python {model: sale.order}: |
|
!python {model: sale.order}: |
|
||||||
from openerp import netsvc
|
|
||||||
invoice_ids = self.browse(cr, uid, ref("sale.sale_order_8")).invoice_ids
|
invoice_ids = self.browse(cr, uid, ref("sale.sale_order_8")).invoice_ids
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
first_invoice_id = invoice_ids[0]
|
first_invoice_id = invoice_ids[0]
|
||||||
wf_service.trg_validate(uid, 'account.invoice', first_invoice_id.id, 'invoice_cancel', cr)
|
self.pool.get('account.invoice').signal_invoice_cancel(cr, uid, [first_invoice_id.id])
|
||||||
-
|
-
|
||||||
I check order status in "Invoice Exception" and related invoice is in cancel state.
|
I check order status in "Invoice Exception" and related invoice is in cancel state.
|
||||||
-
|
-
|
||||||
|
|
|
@ -132,11 +132,10 @@
|
||||||
I open the Invoice.
|
I open the Invoice.
|
||||||
-
|
-
|
||||||
!python {model: sale.order}: |
|
!python {model: sale.order}: |
|
||||||
from openerp import netsvc
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
so = self.browse(cr, uid, ref("sale.sale_order_6"))
|
so = self.browse(cr, uid, ref("sale.sale_order_6"))
|
||||||
|
account_invoice_obj = self.pool.get('account.invoice')
|
||||||
for invoice in so.invoice_ids:
|
for invoice in so.invoice_ids:
|
||||||
wf_service.trg_validate(uid, 'account.invoice', invoice.id, 'invoice_open', cr)
|
account_invoice_obj.signal_invoice_open(cr, uid, [invoice.id])
|
||||||
-
|
-
|
||||||
I pay the invoice
|
I pay the invoice
|
||||||
-
|
-
|
||||||
|
|
|
@ -759,10 +759,9 @@ class stock_picking(osv.osv):
|
||||||
""" Changes state of picking to available if all moves are confirmed.
|
""" Changes state of picking to available if all moves are confirmed.
|
||||||
@return: True
|
@return: True
|
||||||
"""
|
"""
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for pick in self.browse(cr, uid, ids):
|
for pick in self.browse(cr, uid, ids):
|
||||||
if pick.state == 'draft':
|
if pick.state == 'draft':
|
||||||
wf_service.trg_validate(uid, 'stock.picking', pick.id, 'button_confirm', cr)
|
self.signal_button_confirm(cr, uid, [pick.id])
|
||||||
move_ids = [x.id for x in pick.move_lines if x.state == 'confirmed']
|
move_ids = [x.id for x in pick.move_lines if x.state == 'confirmed']
|
||||||
if not move_ids:
|
if not move_ids:
|
||||||
raise osv.except_osv(_('Warning!'),_('Not enough stock, unable to reserve the products.'))
|
raise osv.except_osv(_('Warning!'),_('Not enough stock, unable to reserve the products.'))
|
||||||
|
@ -784,12 +783,10 @@ class stock_picking(osv.osv):
|
||||||
""" Confirms picking directly from draft state.
|
""" Confirms picking directly from draft state.
|
||||||
@return: True
|
@return: True
|
||||||
"""
|
"""
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for pick in self.browse(cr, uid, ids):
|
for pick in self.browse(cr, uid, ids):
|
||||||
if not pick.move_lines:
|
if not pick.move_lines:
|
||||||
raise osv.except_osv(_('Error!'),_('You cannot process picking without stock moves.'))
|
raise osv.except_osv(_('Error!'),_('You cannot process picking without stock moves.'))
|
||||||
wf_service.trg_validate(uid, 'stock.picking', pick.id,
|
self.signal_button_confirm(cr, uid, [pick.id])
|
||||||
'button_confirm', cr)
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def draft_validate(self, cr, uid, ids, context=None):
|
def draft_validate(self, cr, uid, ids, context=None):
|
||||||
|
@ -1345,18 +1342,18 @@ class stock_picking(osv.osv):
|
||||||
|
|
||||||
# At first we confirm the new picking (if necessary)
|
# At first we confirm the new picking (if necessary)
|
||||||
if new_picking:
|
if new_picking:
|
||||||
wf_service.trg_validate(uid, 'stock.picking', new_picking, 'button_confirm', cr)
|
self.signal_button_confirm(cr, uid, [new_picking])
|
||||||
# Then we finish the good picking
|
# Then we finish the good picking
|
||||||
self.write(cr, uid, [pick.id], {'backorder_id': new_picking})
|
self.write(cr, uid, [pick.id], {'backorder_id': new_picking})
|
||||||
self.action_move(cr, uid, [new_picking], context=context)
|
self.action_move(cr, uid, [new_picking], context=context)
|
||||||
wf_service.trg_validate(uid, 'stock.picking', new_picking, 'button_done', cr)
|
self.signal_button_done(cr, uid, [new_picking])
|
||||||
wf_service.trg_write(uid, 'stock.picking', pick.id, cr)
|
wf_service.trg_write(uid, 'stock.picking', pick.id, cr)
|
||||||
delivered_pack_id = new_picking
|
delivered_pack_id = new_picking
|
||||||
back_order_name = self.browse(cr, uid, delivered_pack_id, context=context).name
|
back_order_name = self.browse(cr, uid, delivered_pack_id, context=context).name
|
||||||
self.message_post(cr, uid, ids, body=_("Back order <em>%s</em> has been <b>created</b>.") % (back_order_name), context=context)
|
self.message_post(cr, uid, ids, body=_("Back order <em>%s</em> has been <b>created</b>.") % (back_order_name), context=context)
|
||||||
else:
|
else:
|
||||||
self.action_move(cr, uid, [pick.id], context=context)
|
self.action_move(cr, uid, [pick.id], context=context)
|
||||||
wf_service.trg_validate(uid, 'stock.picking', pick.id, 'button_done', cr)
|
self.signal_button_done(cr, uid, [pick.id])
|
||||||
delivered_pack_id = pick.id
|
delivered_pack_id = pick.id
|
||||||
|
|
||||||
delivered_pack = self.browse(cr, uid, delivered_pack_id, context=context)
|
delivered_pack = self.browse(cr, uid, delivered_pack_id, context=context)
|
||||||
|
@ -2037,7 +2034,6 @@ class stock_move(osv.osv):
|
||||||
res_obj = self.pool.get('res.company')
|
res_obj = self.pool.get('res.company')
|
||||||
location_obj = self.pool.get('stock.location')
|
location_obj = self.pool.get('stock.location')
|
||||||
move_obj = self.pool.get('stock.move')
|
move_obj = self.pool.get('stock.move')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
new_moves = []
|
new_moves = []
|
||||||
if context is None:
|
if context is None:
|
||||||
context = {}
|
context = {}
|
||||||
|
@ -2073,7 +2069,7 @@ class stock_move(osv.osv):
|
||||||
})
|
})
|
||||||
new_moves.append(self.browse(cr, uid, [new_id])[0])
|
new_moves.append(self.browse(cr, uid, [new_id])[0])
|
||||||
if pickid:
|
if pickid:
|
||||||
wf_service.trg_validate(uid, 'stock.picking', pickid, 'button_confirm', cr)
|
self.signal_button_confirm(cr, uid, [pickid])
|
||||||
if new_moves:
|
if new_moves:
|
||||||
new_moves += self.create_chained_picking(cr, uid, new_moves, context)
|
new_moves += self.create_chained_picking(cr, uid, new_moves, context)
|
||||||
return new_moves
|
return new_moves
|
||||||
|
@ -2195,6 +2191,7 @@ class stock_move(osv.osv):
|
||||||
return True
|
return True
|
||||||
if context is None:
|
if context is None:
|
||||||
context = {}
|
context = {}
|
||||||
|
wf_service = netsvc.LocalService("workflow")
|
||||||
pickings = set()
|
pickings = set()
|
||||||
for move in self.browse(cr, uid, ids, context=context):
|
for move in self.browse(cr, uid, ids, context=context):
|
||||||
if move.state in ('confirmed', 'waiting', 'assigned', 'draft'):
|
if move.state in ('confirmed', 'waiting', 'assigned', 'draft'):
|
||||||
|
@ -2203,7 +2200,6 @@ class stock_move(osv.osv):
|
||||||
if move.move_dest_id and move.move_dest_id.state == 'waiting':
|
if move.move_dest_id and move.move_dest_id.state == 'waiting':
|
||||||
self.write(cr, uid, [move.move_dest_id.id], {'state': 'assigned'})
|
self.write(cr, uid, [move.move_dest_id.id], {'state': 'assigned'})
|
||||||
if context.get('call_unlink',False) and move.move_dest_id.picking_id:
|
if context.get('call_unlink',False) and move.move_dest_id.picking_id:
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
wf_service.trg_write(uid, 'stock.picking', move.move_dest_id.picking_id.id, cr)
|
wf_service.trg_write(uid, 'stock.picking', move.move_dest_id.picking_id.id, cr)
|
||||||
self.write(cr, uid, ids, {'state': 'cancel', 'move_dest_id': False})
|
self.write(cr, uid, ids, {'state': 'cancel', 'move_dest_id': False})
|
||||||
if not context.get('call_unlink',False):
|
if not context.get('call_unlink',False):
|
||||||
|
@ -2211,7 +2207,6 @@ class stock_move(osv.osv):
|
||||||
if all(move.state == 'cancel' for move in pick.move_lines):
|
if all(move.state == 'cancel' for move in pick.move_lines):
|
||||||
self.pool.get('stock.picking').write(cr, uid, [pick.id], {'state': 'cancel'})
|
self.pool.get('stock.picking').write(cr, uid, [pick.id], {'state': 'cancel'})
|
||||||
|
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for id in ids:
|
for id in ids:
|
||||||
wf_service.trg_trigger(uid, 'stock.move', id, cr)
|
wf_service.trg_trigger(uid, 'stock.move', id, cr)
|
||||||
return True
|
return True
|
||||||
|
@ -2633,7 +2628,6 @@ class stock_move(osv.osv):
|
||||||
product_obj = self.pool.get('product.product')
|
product_obj = self.pool.get('product.product')
|
||||||
currency_obj = self.pool.get('res.currency')
|
currency_obj = self.pool.get('res.currency')
|
||||||
uom_obj = self.pool.get('product.uom')
|
uom_obj = self.pool.get('product.uom')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
|
|
||||||
if context is None:
|
if context is None:
|
||||||
context = {}
|
context = {}
|
||||||
|
@ -2734,7 +2728,7 @@ class stock_move(osv.osv):
|
||||||
res = cr.fetchall()
|
res = cr.fetchall()
|
||||||
if len(res) == len(move.picking_id.move_lines):
|
if len(res) == len(move.picking_id.move_lines):
|
||||||
picking_obj.action_move(cr, uid, [move.picking_id.id])
|
picking_obj.action_move(cr, uid, [move.picking_id.id])
|
||||||
wf_service.trg_validate(uid, 'stock.picking', move.picking_id.id, 'button_done', cr)
|
picking_obj.signal_button_done(cr, uid, [move.picking_id.id])
|
||||||
|
|
||||||
return [move.id for move in complete]
|
return [move.id for move in complete]
|
||||||
|
|
||||||
|
|
|
@ -151,7 +151,6 @@ class stock_return_picking(osv.osv_memory):
|
||||||
data_obj = self.pool.get('stock.return.picking.memory')
|
data_obj = self.pool.get('stock.return.picking.memory')
|
||||||
act_obj = self.pool.get('ir.actions.act_window')
|
act_obj = self.pool.get('ir.actions.act_window')
|
||||||
model_obj = self.pool.get('ir.model.data')
|
model_obj = self.pool.get('ir.model.data')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
pick = pick_obj.browse(cr, uid, record_id, context=context)
|
pick = pick_obj.browse(cr, uid, record_id, context=context)
|
||||||
data = self.read(cr, uid, ids[0], context=context)
|
data = self.read(cr, uid, ids[0], context=context)
|
||||||
date_cur = time.strftime('%Y-%m-%d %H:%M:%S')
|
date_cur = time.strftime('%Y-%m-%d %H:%M:%S')
|
||||||
|
@ -206,7 +205,7 @@ class stock_return_picking(osv.osv_memory):
|
||||||
|
|
||||||
if set_invoice_state_to_none:
|
if set_invoice_state_to_none:
|
||||||
pick_obj.write(cr, uid, [pick.id], {'invoice_state':'none'}, context=context)
|
pick_obj.write(cr, uid, [pick.id], {'invoice_state':'none'}, context=context)
|
||||||
wf_service.trg_validate(uid, 'stock.picking', new_picking, 'button_confirm', cr)
|
pick_obj.signal_button_confirm(cr, uid, [new_picking])
|
||||||
pick_obj.force_assign(cr, uid, [new_picking], context)
|
pick_obj.force_assign(cr, uid, [new_picking], context)
|
||||||
# Update view id in context, lp:702939
|
# Update view id in context, lp:702939
|
||||||
model_list = {
|
model_list = {
|
||||||
|
|
|
@ -49,7 +49,6 @@ class procurement_order(osv.osv):
|
||||||
proc_obj = self.pool.get('procurement.order')
|
proc_obj = self.pool.get('procurement.order')
|
||||||
move_obj = self.pool.get('stock.move')
|
move_obj = self.pool.get('stock.move')
|
||||||
picking_obj=self.pool.get('stock.picking')
|
picking_obj=self.pool.get('stock.picking')
|
||||||
wf_service = netsvc.LocalService("workflow")
|
|
||||||
for proc in proc_obj.browse(cr, uid, ids, context=context):
|
for proc in proc_obj.browse(cr, uid, ids, context=context):
|
||||||
line = None
|
line = None
|
||||||
for line in proc.product_id.flow_pull_ids:
|
for line in proc.product_id.flow_pull_ids:
|
||||||
|
@ -109,9 +108,8 @@ class procurement_order(osv.osv):
|
||||||
'procure_method': line.procure_method,
|
'procure_method': line.procure_method,
|
||||||
'move_id': move_id,
|
'move_id': move_id,
|
||||||
})
|
})
|
||||||
wf_service = netsvc.LocalService("workflow")
|
self.pool.get('stock.picking').signal_button_confirm(cr, uid, [picking_id])
|
||||||
wf_service.trg_validate(uid, 'stock.picking', picking_id, 'button_confirm', cr)
|
self.signal_button_confirm(cr, uid, [proc_id])
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc_id, 'button_confirm', cr)
|
|
||||||
if proc.move_id:
|
if proc.move_id:
|
||||||
move_obj.write(cr, uid, [proc.move_id.id],
|
move_obj.write(cr, uid, [proc.move_id.id],
|
||||||
{'location_id':proc.location_id.id})
|
{'location_id':proc.location_id.id})
|
||||||
|
@ -119,9 +117,8 @@ class procurement_order(osv.osv):
|
||||||
self.write(cr, uid, [proc.id], {'state':'running', 'message': msg})
|
self.write(cr, uid, [proc.id], {'state':'running', 'message': msg})
|
||||||
self.message_post(cr, uid, [proc.id], body=msg, context=context)
|
self.message_post(cr, uid, [proc.id], body=msg, context=context)
|
||||||
# trigger direct processing (the new procurement shares the same planned date as the original one, which is already being processed)
|
# trigger direct processing (the new procurement shares the same planned date as the original one, which is already being processed)
|
||||||
wf_service.trg_validate(uid, 'procurement.order', proc_id, 'button_check', cr)
|
self.signal_button_check(cr, uid, [proc_id]) # TODO is it necessary to interleave the calls?
|
||||||
return False
|
return False
|
||||||
|
|
||||||
procurement_order()
|
|
||||||
|
|
||||||
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
||||||
|
|
Loading…
Reference in New Issue