~openerp-commiter/openobject-addons/extra-6.0

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
# -*- coding: utf-8 -*-
#
#  File: stock.py
#  Module: eagle_contracts
#
#  Created by cyp@open-net.ch
#
#  Copyright (c) 2010 Open-Net Ltd. All rights reserved.
##############################################################################
#	
#	OpenERP, Open Source Management Solution
#	Copyright (C) 2004-2010 Tiny SPRL (<http://tiny.be>).
#
#	This program is free software: you can redistribute it and/or modify
#	it under the terms of the GNU Affero General Public License as
#	published by the Free Software Foundation, either version 3 of the
#	License, or (at your option) any later version.
#
#	This program is distributed in the hope that it will be useful,
#	but WITHOUT ANY WARRANTY; without even the implied warranty of
#	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#	GNU Affero General Public License for more details.
#
#	You should have received a copy of the GNU Affero General Public License
#	along with this program.  If not, see <http://www.gnu.org/licenses/>.	 
#
##############################################################################

import netsvc
from osv import fields, osv

class stock_move( osv.osv ):
	_inherit = 'stock.move'
	
	_columns = {
		'contract_id': fields.many2one( 'eagle.contract', 'Contract' ),
	}
	
	def create( self, cr, uid, vals, context=None ):
		if 'sale_line_id' in vals:
			sl_id = vals['sale_line_id']
			if sl_id:
				sol = self.pool.get( 'sale.order.line' ).browse( cr, uid, sl_id, context=context )
				if sol and sol.order_id and sol.order_id.contract_id:
					vals['contract_id'] = sol.order_id.contract_id.id
		return super( stock_move, self ).create( cr, uid, vals, context=context )

stock_move()

class stock_picking( osv.osv ):
	_inherit = 'stock.picking'

	_columns = {
		'contract_id': fields.many2one( 'eagle.contract', 'Contract' ),
	}

	def create( self, cr, uid, vals, context=None ):
		sales = self.pool.get( 'sale.order' )
		if 'sale_id' in vals and vals['sale_id']:
			sale = sales.browse( cr, uid, vals['sale_id'], context=context )
			if sale and sale.contract_id:
				vals['contract_id'] = sale.contract_id.id
		return super( stock_picking, self ).create( cr, uid, vals, context=context )

stock_picking()