1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- # -*- encoding: utf-8 -*-
- from openerp import models, api, fields
- from pytz import timezone
- from openerp.tools import DEFAULT_SERVER_DATETIME_FORMAT, DEFAULT_SERVER_DATE_FORMAT
- from datetime import datetime,timedelta
- DATE_FORMAT = '%Y-%m-%d'
- class SaleOrder(models.Model):
- _inherit = 'sale.order'
- _name = 'sale.order'
- invoice_number = fields.Char('Numero de Factura')
- ''' Timezone '''
- def get_timezone(self):
- return timezone(self._context.get('tz') or self.env.user.tz)
- def _convert_str_to_datetime(self, date):
- return datetime.strptime(date,DEFAULT_SERVER_DATETIME_FORMAT)
- @api.multi
- def order_process_now(self):
- """
- Confirms order and creates and validates invoice, confirms pickings.
- """
- for sale in self:
- sale.action_button_confirm()
- inv_id = sale.action_invoice_create()
- if inv_id:
- inv = self.env['account.invoice'].browse(inv_id)
- date = self._convert_str_to_datetime(sale.date_order)
- date = date.strftime(DATE_FORMAT)
- inv.write({
- 'date_invoice':date,
- 'supplier_invoice_number':self.invoice_number
- })
- self.update_state()
- inv.signal_workflow('invoice_open')
- for picking in sale.picking_ids:
- picking.force_assign()
- picking.action_done()
- @api.multi
- def update_state(self):
- for order in self:
- order.write({'state': 'done'})
- return True
- class SaleOrderLine(models.Model):
- _inherit = 'sale.order.line'
- _name = 'sale.order.line'
- amount_total = fields.Float(compute='_calculate_total_sale_line',string='Total',default=0.0)
- @api.depends('price_unit','product_uom_qty')
- def _calculate_total_sale_line(self):
- for line in self:
- line.amount_total = line.product_uom_qty * line.price_unit
|