summaryrefslogtreecommitdiff
path: root/indoteknik_custom/controllers/api
diff options
context:
space:
mode:
authorIT Fixcomart <it@fixcomart.co.id>2022-10-05 15:19:27 +0700
committerIT Fixcomart <it@fixcomart.co.id>2022-10-05 15:19:27 +0700
commit14cb30c3f2fb8b15baaf32ab9fca7bb9bda73845 (patch)
treee4039e13e934db6ee148f766882bb82af8db1d7a /indoteknik_custom/controllers/api
parentd1bc570eae2818bc4b535840f2eb3061b99ca98b (diff)
Update struktur API and fitur API flash sale
Diffstat (limited to 'indoteknik_custom/controllers/api')
-rw-r--r--indoteknik_custom/controllers/api/__init__.py2
-rw-r--r--indoteknik_custom/controllers/api/product.py95
-rw-r--r--indoteknik_custom/controllers/api/sale_order.py110
3 files changed, 0 insertions, 207 deletions
diff --git a/indoteknik_custom/controllers/api/__init__.py b/indoteknik_custom/controllers/api/__init__.py
deleted file mode 100644
index bd901bd4..00000000
--- a/indoteknik_custom/controllers/api/__init__.py
+++ /dev/null
@@ -1,2 +0,0 @@
-from . import sale_order
-from . import product
diff --git a/indoteknik_custom/controllers/api/product.py b/indoteknik_custom/controllers/api/product.py
deleted file mode 100644
index 3b1c4ce8..00000000
--- a/indoteknik_custom/controllers/api/product.py
+++ /dev/null
@@ -1,95 +0,0 @@
-import base64
-
-from .. import api_controller
-from odoo import http
-from odoo.http import request
-
-
-class ProductApi(api_controller.ApiController):
- @http.route('/api/product/search', auth='public', methods=['GET'])
- def search_product(self, **kw):
- self.authenticate(kw)
- query = kw.get('query')
- if not query:
- return self.response(code=400, description='Field query is required')
-
- query = '%' + query.replace(' ', '%') + '%'
- domain = [
- ('sale_ok', '=', True),
- '|',
- ('default_code', 'ilike', query),
- ('name', 'ilike', query)
- ]
-
- manufactures = kw.get('manufactures')
- if manufactures:
- manufactures = [int(x) for x in manufactures.split(',')]
- domain.append(('x_manufacture', 'in', manufactures))
-
- categories = kw.get('categories')
- if categories:
- categories = [int(x) for x in categories.split(',')]
- domain.append(('public_categ_ids', 'child_of', categories))
-
- product_variants = request.env['product.product'].search(domain)
- product_variant_ids = [v['id'] for v in product_variants]
-
- base_url = request.env['ir.config_parameter'].sudo().get_param('web.base.url')
- domain = [
- ('product_variant_ids', 'in', product_variant_ids)
- ]
- product_templates = self.search_with_api_params('product.template', kw, domain)
- data = {
- 'total_records': len(request.env['product.template'].search(domain)),
- 'products': []
- }
- for product_template in product_templates:
- stock = 0
- for product_variant in product_template.product_variant_ids:
- stock += product_variant.qty_stock_vendor
-
- discount_price = 0
- price = product_template.web_price
- if price > 0:
- if product_template.taxes_id:
- if not product_template.taxes_id.price_include:
- price += (price * product_template.taxes_id.amount / 100)
- else:
- price += (price * 11 / 100)
-
- promotion = {}
- manufacture = {}
- if product_template.x_manufacture:
- manufacture.update({
- 'id': product_template.x_manufacture.id,
- 'name': product_template.x_manufacture.x_name,
- })
- domain = [
- ('rule_products_domain', 'ilike', product_template.x_manufacture.x_name),
- ('active', '=', True)
- ]
- coupon_program = request.env['coupon.program'].search(domain, limit=1)
- if coupon_program:
- discount_price = price - (price * coupon_program.discount_percentage / 100)
- icon_1 = (base_url + 'api/image/coupon.program/x_studio_field_Ifopn/' + str(coupon_program.id)) if coupon_program.x_studio_field_Ifopn else ''
- icon_2 = (base_url + 'api/image/coupon.program/x_studio_field_2Ul77/' + str(coupon_program.id)) if coupon_program.x_studio_field_2Ul77 else ''
- promotion.update({
- 'name': coupon_program.name,
- 'discount_percentage': coupon_program.discount_percentage,
- 'icon_1': icon_1,
- 'icon_2': icon_2
- })
-
- data['products'].append({
- 'id': product_template.id,
- 'image': base_url + 'api/image/product.template/image_128/' + str(product_template.id) if product_template.image_128 else '',
- 'name': product_template.name,
- 'price': price,
- 'discount_price': discount_price,
- 'total_variant': len(product_template.product_variant_ids),
- 'stock': stock,
- 'manufacture': manufacture,
- 'promotion': promotion,
- })
-
- return self.response(data)
diff --git a/indoteknik_custom/controllers/api/sale_order.py b/indoteknik_custom/controllers/api/sale_order.py
deleted file mode 100644
index c00a94d3..00000000
--- a/indoteknik_custom/controllers/api/sale_order.py
+++ /dev/null
@@ -1,110 +0,0 @@
-from .. import api_controller
-from odoo import http
-from odoo.http import request
-
-
-class SaleOrderApi(api_controller.ApiController):
- @http.route('/api/sale_order/invoiced', auth='public', methods=['GET'])
- def get_sale_order_invoiced_by_partner_id(self, **kw):
- self.authenticate(kw)
- partner_id = kw.get('partner_id')
- if not partner_id:
- return self.response(code=400, description='Field partner_id is required')
-
- partner_id = int(partner_id)
- # Get company member by partner_id
- parent_partner_id = request.env['res.partner'].search([('id', '=', partner_id)], limit=1).parent_id.id
- partner_childs = request.env['res.partner'].search([('parent_id', '=', int(parent_partner_id))])
- partner_child_ids = [v['id'] for v in partner_childs] + [partner_id]
-
- # Get sale order by company member and invoiced
- data = []
- default_domain = [
- ('partner_id', 'in', partner_child_ids),
- '|',
- ('invoice_status', '=', 'invoiced'),
- ('invoice_status', '=', 'to_invoice')
- ]
- sale_orders = self.search_with_api_params('sale.order', kw, default_domain)
- for sale_order in sale_orders:
- pickings = []
- for picking in sale_order.picking_ids:
- if picking.state in ['confirmed', 'assigned', 'done']:
- pickings.append({
- 'id': picking.id,
- 'name': picking.name,
- 'delivery_address': picking.partner_id.street,
- 'delivery_tracking_no': picking.delivery_tracking_no,
- 'delivery_status': picking.delivery_status
- })
-
- data.append({
- 'id': sale_order.id,
- 'name': sale_order.name,
- 'amount_total': sale_order.amount_total,
- 'salesperson': sale_order.user_id.name,
- 'date_order': self.time_to_str(sale_order.date_order, '%d/%m/%Y'),
- 'pickings': pickings,
- 'access_token': sale_order.access_token
- })
- return self.response(data)
-
- @http.route('/api/sale_order/invoiced/detail', auth='public', methods=['GET'])
- def get_sale_order_invoiced_detail_by_partner(self, **kw):
- self.authenticate(kw)
-
- id = kw.get('id')
- partner_id = kw.get('partner_id')
- if not id:
- return self.response(code=400, description='Field id is required')
- if not partner_id:
- return self.response(code=400, description='Field partner_id is required')
-
- default_domain = [
- ('id', '=', id),
- '|',
- ('invoice_status', '=', 'invoiced'),
- ('invoice_status', '=', 'to_invoice')
- ]
- parent_partner_id = request.env['res.partner'].search([('id', '=', int(partner_id))], limit=1).parent_id.id
- partner_childs = request.env['res.partner'].search([('parent_id', '=', int(parent_partner_id))])
- partner_child_ids = [v['id'] for v in partner_childs] + [int(partner_id)]
- default_domain.append(('partner_id', 'in', partner_child_ids))
-
- sale_order = self.search_with_api_params('sale.order', kw, default_domain)
- orders = []
- for order in sale_order.order_line:
- orders.append({
- 'name': order.name,
- 'product_qty': order.product_qty,
- 'price_unit': order.price_unit,
- 'price_tax': order.price_tax,
- 'price_total': order.price_total,
- 'price_subtotal': order.price_subtotal,
- 'tax': order.tax_id.name,
- 'discount': order.discount,
- })
-
- data = {
- 'id': sale_order.id,
- 'name': sale_order.name,
- 'carrier': sale_order.carrier_id.name,
- 'partner': {
- 'id': sale_order.partner_id.id,
- 'name': sale_order.partner_id.name,
- 'mobile': sale_order.partner_id.mobile,
- 'email': sale_order.partner_id.email
- },
- 'delivery_address': sale_order.partner_shipping_id.street,
- 'delivery_method': sale_order.carrier_id.name,
- 'payment_term': sale_order.payment_term_id.name,
- 'salesperson': sale_order.user_id.name,
- 'date_order': self.time_to_str(sale_order.date_order, '%d/%m/%Y %H:%M:%S'),
- 'note': sale_order.note,
- 'amount_untaxed': sale_order.amount_untaxed,
- 'amount_tax': sale_order.amount_tax,
- 'amount_total': sale_order.amount_total,
- 'orders': orders
- }
-
- return self.response(data)