summaryrefslogtreecommitdiff
path: root/indoteknik_custom/models/sale_order.py
diff options
context:
space:
mode:
authorRafi Zadanly <zadanlyr@gmail.com>2023-11-10 13:40:58 +0700
committerRafi Zadanly <zadanlyr@gmail.com>2023-11-10 13:40:58 +0700
commit2aee5a44abbe36961dfe23cc3d656aa48e11e0f9 (patch)
tree8ec2b6552aaef4e14539aa52ed796552e24180d6 /indoteknik_custom/models/sale_order.py
parent6a87e59e7220bdfa78e98b23003ccc4ef41bd0ce (diff)
parentb4e74170aeaf00937f78e5af9047218ddb17516c (diff)
Merge branch 'production' into change/feature/promotion-program
Diffstat (limited to 'indoteknik_custom/models/sale_order.py')
-rwxr-xr-xindoteknik_custom/models/sale_order.py50
1 files changed, 46 insertions, 4 deletions
diff --git a/indoteknik_custom/models/sale_order.py b/indoteknik_custom/models/sale_order.py
index 9324930e..f9229bca 100755
--- a/indoteknik_custom/models/sale_order.py
+++ b/indoteknik_custom/models/sale_order.py
@@ -1,5 +1,6 @@
from odoo import fields, models, api, _
from odoo.exceptions import UserError
+from datetime import datetime
import logging, random, string, requests, math, json, re
_logger = logging.getLogger(__name__)
@@ -69,18 +70,28 @@ class SaleOrder(models.Model):
customer_type = fields.Selection([
('pkp', 'PKP'),
('nonpkp', 'Non PKP')
- ])
- sppkp = fields.Char(string="SPPKP")
- npwp = fields.Char(string="NPWP")
+ ], required=True)
+ sppkp = fields.Char(string="SPPKP", required=True)
+ npwp = fields.Char(string="NPWP", required=True)
purchase_total = fields.Monetary(string='Purchase Total', compute='_compute_purchase_total')
voucher_id = fields.Many2one(comodel_name='voucher', string='Voucher', copy=False)
applied_voucher_id = fields.Many2one(comodel_name='voucher', string='Applied Voucher', copy=False)
amount_voucher_disc = fields.Float(string='Voucher Discount')
- source_id = fields.Many2one('utm.source', 'Source', domain="[('id', 'in', [32, 59, 60, 61])]")
+ source_id = fields.Many2one('utm.source', 'Source', domain="[('id', 'in', [32, 59, 60, 61])]", required=True)
estimated_arrival_days = fields.Integer('Estimated Arrival Days', default=0)
email = fields.Char(string='Email')
picking_iu_id = fields.Many2one('stock.picking', 'Picking IU')
helper_by_id = fields.Many2one('res.users', 'Helper By')
+ # picking_ids = fields.Many2many('stock.picking', string='Pickings', compute='_get_pickings', readonly=True, copy=False, search="_search_picking_ids")
+
+ # def _get_pickings(self):
+ # state = ['assigned']
+ # for order in self:
+ # pickings = self.env['stock.picking'].search([
+ # ('sale_id.id', '=', order.id),
+ # ('state', 'in', state)
+ # ])
+ # order.picking_ids = pickings
@api.model
def action_multi_update_state(self):
@@ -193,8 +204,39 @@ class SaleOrder(models.Model):
sale.so_status = 'sebagian'
else:
sale.so_status = 'menunggu'
+
+ for picking in sale.picking_ids:
+ sum_qty_pick = sum(move_line.product_uom_qty for move_line in picking.move_ids_without_package)
+ sum_qty_reserved = sum(move_line.product_uom_qty for move_line in picking.move_line_ids_without_package)
+ if picking.state == 'done':
+ continue
+ elif sum_qty_pick == sum_qty_reserved and not picking.date_reserved:# baru ke reserved
+ current_time = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
+ picking.date_reserved = current_time
+ elif sum_qty_pick == sum_qty_reserved:# sudah ada data reserved
+ picking.date_reserved = picking.date_reserved
+ else:
+ picking.date_reserved = ''
+
_logger.info('Calculate SO Status %s' % sale.id)
+ # def _search_picking_ids(self, operator, value):
+ # if operator == 'in' and value:
+ # self.env.cr.execute("""
+ # SELECT array_agg(so.sale_id)
+ # FROM stock_picking so
+ # WHERE
+ # so.sale_id is not null and so.id = ANY(%s)
+ # """, (list(value),))
+ # so_ids = self.env.cr.fetchone()[0] or []
+ # return [('id', 'in', so_ids)]
+ # elif operator == '=' and not value:
+ # order_ids = self._search([
+ # ('order_line.invoice_lines.move_id.move_type', 'in', ('out_invoice', 'out_refund'))
+ # ])
+ # return [('id', 'not in', order_ids)]
+ # return ['&', ('order_line.invoice_lines.move_id.move_type', 'in', ('out_invoice', 'out_refund')), ('order_line.invoice_lines.move_id', operator, value)]
+
@api.onchange('partner_shipping_id')
def onchange_partner_shipping(self):
self.real_shipping_id = self.partner_shipping_id