Update for sale_report_py3o

Code cleanup
This commit is contained in:
Alexis de Lattre
2019-03-05 17:17:36 +01:00
parent 9f1cf7af1e
commit 528438586c
2 changed files with 26 additions and 34 deletions

View File

@@ -25,7 +25,7 @@ class SaleOrder(models.Model):
has_discount = fields.Boolean(
compute='_compute_has_discount', readonly=True)
@api.multi
@api.depends('order_line.discount')
def _compute_has_discount(self):
prec = self.env['decimal.precision'].precision_get('Discount')
for order in self:
@@ -37,38 +37,30 @@ class SaleOrder(models.Model):
order.has_discount = has_discount
# for report
@api.multi
def py3o_lines_layout(self):
self.ensure_one()
res1 = OrderedDict()
# {categ(6): {'lines': [l1, l2], 'subtotal': 23.32}}
res = []
has_sections = False
subtotal = 0.0
for line in self.order_line:
categ = line.layout_category_id
if categ in res1:
res1[categ]['lines'].append(line)
res1[categ]['subtotal'] += line.price_subtotal
if line.display_type == 'line_section':
# insert line
if has_sections:
res.append({'subtotal': subtotal})
subtotal = 0.0 # reset counter
has_sections = True
else:
res1[categ] = {
'lines': [line],
'subtotal': line.price_subtotal}
res2 = []
if len(res1) == 1 and not res1.keys()[0]:
# No category at all
for line in res1.values()[0]['lines']:
res2.append({'line': line})
else:
for categ, ldict in res1.iteritems():
res2.append({'categ': categ})
for line in ldict['lines']:
res2.append({'line': line})
if categ.subtotal:
res2.append({'subtotal': ldict['subtotal']})
# res2:
if not line.display_type:
subtotal += line.price_subtotal
res.append({'line': line})
if has_sections: # insert last subtotal line
res.append({'subtotal': subtotal})
# res:
# [
# {'categ': categ(1)},
# {'line': sale_order_line(2)},
# {'line': sale_order_line(3)},
# {'line': sale_order_line(1) with display_type=='line_section'},
# {'line': sale_order_line(2) without display_type},
# {'line': sale_order_line(3) without display_type},
# {'line': sale_order_line(4) with display_type=='line_note'},
# {'subtotal': 8932.23},
# ]
return res2
return res

View File

@@ -76,15 +76,15 @@ class StockMove(models.Model):
in it'''
res = []
for line in self:
name = line.location_id.name + ' > ' + line.location_dest_id.name
name = '%s > %s' % (line.location_id.name, line.location_dest_id.name)
if line.product_id.code:
name = line.product_id.code + ': ' + name
name = '%s: %s' % (line.product_id.code, name)
if line.picking_id.origin:
name = line.picking_id.origin + ' ' + name
name = '%s %s' % (line.picking_id.origin, name)
if line.partner_id:
name = line.partner_id.name + ' ' + name
name = '%s %s' % (line.partner_id.name, name)
if line.date_expected:
name = name + ' ' + line.date_expected
name = '%s %s' % (name, line.date_expected)
res.append((line.id, name))
return res