diff --git a/stock_delivery_planner/models/stock.py b/stock_delivery_planner/models/stock.py index 3f7fd6ea..25c6e611 100644 --- a/stock_delivery_planner/models/stock.py +++ b/stock_delivery_planner/models/stock.py @@ -48,3 +48,11 @@ class StockPicking(models.Model): domain.extend(tools.safe_eval(irconfig_parameter.get_param('sale.order.planner.carrier_domain'))) return Carrier.search(domain) + + +class Warehouse(models.Model): + _inherit = 'stock.warehouse' + + delivery_planner_carrier_ids = fields.Many2many('delivery.carrier', + string='Delivery Planner Base Carriers', + help='Overrides the global carriers.') diff --git a/stock_delivery_planner/views/res_config_settings_views.xml b/stock_delivery_planner/views/res_config_settings_views.xml index bc8f2557..c6645fc7 100644 --- a/stock_delivery_planner/views/res_config_settings_views.xml +++ b/stock_delivery_planner/views/res_config_settings_views.xml @@ -18,7 +18,7 @@ For example, you should add 1 FedEx carrier here and let us build up the rates for your other FedEx shipping methods. - + diff --git a/stock_delivery_planner/views/stock_views.xml b/stock_delivery_planner/views/stock_views.xml index a65334dd..137477e2 100644 --- a/stock_delivery_planner/views/stock_views.xml +++ b/stock_delivery_planner/views/stock_views.xml @@ -1,5 +1,6 @@ + stock.picking.form.inherit.delivery.planner stock.picking @@ -10,4 +11,16 @@ + + + stock.warehouse.delivery.carriers + stock.warehouse + + + + + + + + diff --git a/stock_delivery_planner/wizard/stock_delivery_planner.py b/stock_delivery_planner/wizard/stock_delivery_planner.py index 799f6ed4..0de30215 100644 --- a/stock_delivery_planner/wizard/stock_delivery_planner.py +++ b/stock_delivery_planner/wizard/stock_delivery_planner.py @@ -26,14 +26,15 @@ class StockDeliveryPlanner(models.TransientModel): def create(self, values): planner = super(StockDeliveryPlanner, self).create(values) - base_carriers = self.env['delivery.carrier'] - carrier_ids = self.env['ir.config_parameter'].sudo().get_param('stock.delivery.planner.carrier_ids.%s' % (self.env.user.company_id.id, )) - if carrier_ids: - try: - carrier_ids = [int(c) for c in carrier_ids.split(',')] - base_carriers = base_carriers.browse(carrier_ids) - except: - pass + base_carriers = planner.picking_id.picking_type_id.warehouse_id.delivery_planner_carrier_ids + if not base_carriers: + carrier_ids = self.env['ir.config_parameter'].sudo().get_param('stock.delivery.planner.carrier_ids.%s' % (self.env.user.company_id.id, )) + if carrier_ids: + try: + carrier_ids = [int(c) for c in carrier_ids.split(',')] + base_carriers = base_carriers.browse(carrier_ids) + except: + pass for carrier in base_carriers: rates = carrier.rate_shipment_multi(picking=planner.picking_id) diff --git a/stock_delivery_planner/wizard/stock_delivery_planner_views.xml b/stock_delivery_planner/wizard/stock_delivery_planner_views.xml index ac373043..06e9ac5c 100644 --- a/stock_delivery_planner/wizard/stock_delivery_planner_views.xml +++ b/stock_delivery_planner/wizard/stock_delivery_planner_views.xml @@ -11,6 +11,7 @@