-
Notifications
You must be signed in to change notification settings - Fork 0
/
stock_move_extension.py
67 lines (51 loc) · 2.44 KB
/
stock_move_extension.py
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
from osv import fields, osv
from datetime import datetime
import pytz
class stock_move_extension(osv.osv):
_name = 'stock.move'
_inherit = 'stock.move'
_columns = {
'product_quality_text': fields.related('product_id','quality_check_text',type='text', relation="product.product", string="Quality"),
'product_quality_lower_limit': fields.related('product_id','quality_lower_limit',type='float', relation="product.product", string="Lower Limit"),
'product_quality_upper_limit': fields.related('product_id','quality_upper_limit',type='float', relation="product.product", string="Upper Limit"),
'product_quality_weight': fields.float('Weight', required=False),
'inspection_notes': fields.char('Inspect notes', size=64, required=False, translate=True),
'inspected_by': fields.char('Inspector', size=64, required=False, translate=True),
'localized_date': fields.datetime('Localized Date'),
'prodlot_id': fields.many2one('stock.production.lot', 'Serial Number', select=True, readonly=True),
'lot_serial': fields.char('Serial', size=64)
}
def onPrintLabelClicked(self, cr, uid, ids, context=None):
print 'onPrintLabelClicked'
datas = {'ids':ids}
# Change localized date accordingly
#print str(localDate)
print str(ids)
dateString = self.browse(cr, uid, ids, context=None)[0].date
print 'creation date: ' + dateString
utcDate = datetime.strptime(dateString, "%Y-%m-%d %H:%M:%S")
utcDate = utcDate.replace(tzinfo=pytz.utc)
local = datetime.astimezone(utcDate, pytz.timezone("EET"))
self.write(cr, uid, ids, {'localized_date':local}, context)
# save current data from the form
#create serial number for the lot
move = self.browse(cr, uid, ids, context=None)[0]
print 'creating lot_serial: ' + str(move.lot_serial)
print 'existing prodlot_id: ' + str(move.prodlot_id)
if move.lot_serial:
prodlot_obj = self.pool.get('stock.production.lot')
prodlot_id = prodlot_obj.create(cr, uid, {'product_id': move.product_id.id, 'name': move.lot_serial }, context=context)
print 'created prodlot: ' + str(prodlot_id)
self.write(cr, uid, ids, {'prodlot_id': prodlot_id}, context)
if context is None:
print 'no context'
context = {}
datas = {}
if not self.browse(cr, uid, ids, context=None)[0].inspected_by:
raise osv.except_osv('Error', 'Aseta tarkastaja')
return {
'type' : 'ir.actions.report.xml',
'report_name' : 'stock.move.extended.label',
'datas' : datas,
}
stock_move_extension()