summaryrefslogtreecommitdiff
path: root/indoteknik_api/controllers/api_v1
diff options
context:
space:
mode:
authorRafi Zadanly <zadanlyr@gmail.com>2023-07-18 14:00:34 +0700
committerRafi Zadanly <zadanlyr@gmail.com>2023-07-18 14:00:34 +0700
commite0102841e6e21c7b583f096914aa4ba1a28e1587 (patch)
tree3a22b0cb30fbc9e374149929b5294a9043fe5944 /indoteknik_api/controllers/api_v1
parent45fd501a53c6997bf74d5927d7c0eecf387caa51 (diff)
Merge sale order voucher with promotion program
Diffstat (limited to 'indoteknik_api/controllers/api_v1')
-rw-r--r--indoteknik_api/controllers/api_v1/sale_order.py96
1 files changed, 44 insertions, 52 deletions
diff --git a/indoteknik_api/controllers/api_v1/sale_order.py b/indoteknik_api/controllers/api_v1/sale_order.py
index 7c38d47d..a2e28cda 100644
--- a/indoteknik_api/controllers/api_v1/sale_order.py
+++ b/indoteknik_api/controllers/api_v1/sale_order.py
@@ -262,16 +262,10 @@ class SaleOrder(controller.Controller):
@controller.Controller.must_authorized(private=True, private_key='partner_id')
def create_partner_sale_order(self, **kw):
config = request.env['ir.config_parameter']
- product_pricelist_default_discount_id = int(
- config.get_param('product.pricelist.default_discount_id'))
- product_pricelist_tier1 = int(
- config.get_param('product.pricelist.tier1'))
- product_pricelist_tier2 = int(
- config.get_param('product.pricelist.tier2'))
- product_pricelist_tier3 = int(
- config.get_param('product.pricelist.tier3'))
+ product_pricelist_default_discount_id = int(config.get_param('product.pricelist.default_discount_id'))
params = self.get_request_params(kw, {
+ 'user_id': ['number'],
'partner_id': ['number'],
'partner_shipping_id': ['required', 'number'],
'partner_invoice_id': ['required', 'number'],
@@ -281,10 +275,9 @@ class SaleOrder(controller.Controller):
'type': [],
'delivery_amount': ['number', 'default:0'],
'carrier_id': [],
- 'delivery_service_type': [],
- 'voucher': []
+ 'delivery_service_type': []
})
-
+
if not params['valid']:
return self.response(code=400, description=params)
@@ -316,51 +309,50 @@ class SaleOrder(controller.Controller):
if params['value']['type'] == 'sale_order':
parameters['approval_status'] = 'pengajuan1'
sale_order = request.env['sale.order'].create([parameters])
- order_line = json.loads(params['value']['order_line'])
parameters = []
- partner = request.env['res.partner'].browse(
- params['value']['partner_id'])
- partner_pricelist = partner.property_product_pricelist
- for line in order_line:
- product = request.env['product.product'].search(
- [('id', '=', line['product_id'])], limit=1)
- discount = product._get_website_disc(0)
-
- price_tier = False
- pricelist = {
- 'tier1': product._get_pricelist_tier1,
- 'tier2': product._get_pricelist_tier2,
- 'tier3': product._get_pricelist_tier3,
- }
- partner_pricelist_id = partner_pricelist.id if partner_pricelist else False
- if partner_pricelist_id == product_pricelist_tier1:
- price_tier = 'tier1'
- if partner_pricelist_id == product_pricelist_tier2:
- price_tier = 'tier2'
- if partner_pricelist_id == product_pricelist_tier3:
- price_tier = 'tier3'
-
- if price_tier:
- price = pricelist[price_tier]()
- discount_key = 'discount_%s' % price_tier
- if price[discount_key] > 0:
- discount = price[discount_key]
-
- flashsale = product._get_flashsale_price()
- flashsale_discount = flashsale['flashsale_discount']
- if flashsale_discount > 0 and flashsale_discount > discount:
- discount = flashsale_discount
-
- parameters.append({
+ user_id = params['value']['user_id']
+ user_cart = request.env['website.user.cart']
+ products = user_cart.get_product_by_user(user_id=user_id, selected=True)
+ for product in products:
+ total_qty = product['quantity']
+ price_unit = product['price']['price']
+ price_discount =product['price']['discount_percentage']
+ if product['program'] and product['program']['type']['value'] != 'special_price':
+ total_qty += sum(x['quantity'] for x in product['program']['items'])
+ price_unit = product['subtotal'] / total_qty
+ price_discount = 0
+
+ param = {
'company_id': 1,
'order_id': sale_order.id,
- 'product_id': line['product_id'],
- 'product_uom_qty': line['quantity'],
- 'price_unit': product._get_website_price_exclude_tax(),
- 'discount': discount
- })
+ 'price_unit': price_unit,
+ 'discount': price_discount
+ }
+ primary_product = {
+ **param,
+ 'product_id': product['id'],
+ 'product_uom_qty': product['quantity']
+ }
+ if product['program']:
+ primary_product.update({
+ 'program_line_id': product['program']['id']
+ })
+ parameters.append(primary_product)
+
+ if not product['program']:
+ continue
+
+ for item in product['program']['items']:
+ parameters.append({
+ **param,
+ 'product_id': item['id'],
+ 'product_uom_qty': item['quantity'],
+ })
+
+ cart_ids = [x['cart_id'] for x in products]
+ user_cart.browse(cart_ids).unlink()
request.env['sale.order.line'].create(parameters)
amount_untaxed = sale_order.amount_untaxed
@@ -380,7 +372,7 @@ class SaleOrder(controller.Controller):
price = line.price_unit - voucher_discount_line
line.price_unit = price
line.amount_voucher_disc = voucher_discount_item * line.product_uom_qty
-
+
return self.response({
'id': sale_order.id,
'name': sale_order.name