summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIT Fixcomart <it@fixcomart.co.id>2022-11-15 17:35:23 +0700
committerIT Fixcomart <it@fixcomart.co.id>2022-11-15 17:35:23 +0700
commitf6671dd4595af3c1075b27925f10c457854cecf8 (patch)
treefadac999707657fc3ce1b0e359e5acc69d497308
parent2861ba3cd7844079ce85ad31aa1470e95de7f71d (diff)
Fitur crud cart dan wishlist
Update struktur response product
-rw-r--r--indoteknik_api/controllers/api_v1/__init__.py4
-rw-r--r--indoteknik_api/controllers/api_v1/cart.py71
-rw-r--r--indoteknik_api/controllers/api_v1/wishlist.py53
-rw-r--r--indoteknik_api/models/__init__.py1
-rw-r--r--indoteknik_api/models/product_product.py19
-rw-r--r--indoteknik_api/models/product_template.py14
-rwxr-xr-xindoteknik_custom/__manifest__.py2
-rwxr-xr-xindoteknik_custom/models/__init__.py1
-rw-r--r--indoteknik_custom/models/website_user_cart.py9
-rw-r--r--indoteknik_custom/models/website_user_wishlist.py9
-rwxr-xr-xindoteknik_custom/security/ir.model.access.csv4
-rwxr-xr-xindoteknik_custom/views/website_user_cart.xml47
-rwxr-xr-xindoteknik_custom/views/website_user_wishlist.xml45
13 files changed, 258 insertions, 21 deletions
diff --git a/indoteknik_api/controllers/api_v1/__init__.py b/indoteknik_api/controllers/api_v1/__init__.py
index c43a8bd0..d7efb524 100644
--- a/indoteknik_api/controllers/api_v1/__init__.py
+++ b/indoteknik_api/controllers/api_v1/__init__.py
@@ -1,8 +1,10 @@
from . import banner
from . import blog
+from . import cart
from . import category
from . import flash_sale
from . import manufacture
from . import product
from . import promotion
-from . import sale_order \ No newline at end of file
+from . import sale_order
+from . import wishlist \ No newline at end of file
diff --git a/indoteknik_api/controllers/api_v1/cart.py b/indoteknik_api/controllers/api_v1/cart.py
new file mode 100644
index 00000000..29020d8b
--- /dev/null
+++ b/indoteknik_api/controllers/api_v1/cart.py
@@ -0,0 +1,71 @@
+from .. import controller
+from odoo import http
+from odoo.http import request
+
+
+class Cart(controller.Controller):
+ prefix = '/api/v1/'
+
+ @http.route(prefix + 'cart/<user_id>', auth='public', methods=['GET'])
+ def get_cart_by_user_id(self, **kw):
+ if not self.authenticate():
+ return self.response(code=401, description='Unauthorized')
+
+ user_id = int(kw.get('user_id'))
+ limit = int(kw.get('limit', 0))
+ offset = int(kw.get('offset', 0))
+ query = [
+ ('user_id', '=', user_id)
+ ]
+ carts = request.env['website.user.cart'].search(query, limit=limit, offset=offset, order='create_date desc')
+ data = {
+ 'product_total': request.env['website.user.cart'].search_count(query),
+ 'products': []
+ }
+ for cart in carts:
+ product = request.env['product.product'].api_single_response(cart.product_id)
+ product['template_id'] = cart.product_id.product_tmpl_id.id
+ product['quantity'] = cart.qty
+ data['products'].append(product)
+ return self.response(data)
+
+ @http.route(prefix + 'cart/<user_id>/create-or-update', auth='public', methods=['POST'], csrf=False)
+ def create_or_update_cart(self, **kw):
+ if not self.authenticate():
+ return self.response(code=401, description='Unauthorized')
+
+ user_id = int(kw.get('user_id'))
+ product_id = int(kw.get('product_id', 0))
+ qty = int(kw.get('qty', 0))
+
+ if not product_id or not qty:
+ return self.response(code=400, description='product_id and qty is required')
+ query = [('user_id', '=', user_id), ('product_id', '=', product_id)]
+ cart = request.env['website.user.cart'].search(query, limit=1)
+ result = {}
+ if cart:
+ cart.write({'qty': qty})
+ result['id'] = cart.id
+ else:
+ create = request.env['website.user.cart'].create({
+ 'user_id': user_id,
+ 'product_id': product_id,
+ 'qty': qty
+ })
+ result['id'] = create.id
+
+ return self.response(result)
+
+ @http.route(prefix + 'cart/<user_id>', auth='public', methods=['DELETE'], csrf=False)
+ def delete_cart_by_user_id(self, **kw):
+ if not self.authenticate():
+ return self.response(code=401, description='Unauthorized')
+
+ user_id = int(kw.get('user_id'))
+ query = [('user_id', '=', user_id)]
+ product_ids = kw.get('product_ids')
+ if product_ids:
+ query += [('product_id', 'in', [int(x) for x in product_ids.split(',')])]
+ cart = request.env['website.user.cart'].search(query).unlink()
+ return self.response(cart)
+ \ No newline at end of file
diff --git a/indoteknik_api/controllers/api_v1/wishlist.py b/indoteknik_api/controllers/api_v1/wishlist.py
new file mode 100644
index 00000000..c84d58b1
--- /dev/null
+++ b/indoteknik_api/controllers/api_v1/wishlist.py
@@ -0,0 +1,53 @@
+from .. import controller
+from odoo import http
+from odoo.http import request
+
+
+class Wishlist(controller.Controller):
+ prefix = '/api/v1/'
+
+ @http.route(prefix + 'wishlist/<user_id>', auth='public', methods=['GET'])
+ def get_wishlist_by_user_id(self, **kw):
+ if not self.authenticate():
+ return self.response(code=401, description='Unauthorized')
+
+ user_id = int(kw.get('user_id', 0))
+ product_id = kw.get('product_id', 0)
+ limit = int(kw.get('limit', 0))
+ offset = int(kw.get('offset', 0))
+ query = [('user_id', '=', user_id)]
+ if product_id:
+ query += [('product_id', '=', int(product_id))]
+ wishlists = request.env['website.user.wishlist'].search(query, limit=limit, offset=offset, order='create_date desc')
+ data = {
+ 'product_total': request.env['website.user.wishlist'].search_count(query),
+ 'products': [request.env['product.template'].api_single_response(wishlist.product_id) for wishlist in wishlists]
+ }
+ return self.response(data)
+
+ @http.route(prefix + 'wishlist/<user_id>/toggle', auth='public', methods=['POST'], csrf=False)
+ def toggle_wishlist(self, **kw):
+ if not self.authenticate():
+ return self.response(code=401, description='Unauthorized')
+
+ user_id = int(kw.get('user_id', 0))
+ product_id = kw.get('product_id', 0)
+ if not product_id:
+ return self.response(code=400, description='product_id is required')
+
+ query = [
+ ('user_id', '=', user_id),
+ ('product_id', '=', int(product_id))
+ ]
+ wishlist = request.env['website.user.wishlist'].search(query, limit=1)
+ result = {}
+ if wishlist:
+ wishlist.unlink()
+ result['id'] = wishlist.id
+ else:
+ create = request.env['website.user.wishlist'].create({
+ 'user_id': user_id,
+ 'product_id': product_id
+ })
+ result['id'] = create.id
+ return self.response(result)
diff --git a/indoteknik_api/models/__init__.py b/indoteknik_api/models/__init__.py
index bca7d9fe..25f6997f 100644
--- a/indoteknik_api/models/__init__.py
+++ b/indoteknik_api/models/__init__.py
@@ -1,4 +1,5 @@
from . import blog_post
from . import product_pricelist
+from . import product_product
from . import product_template
from . import x_manufactures \ No newline at end of file
diff --git a/indoteknik_api/models/product_product.py b/indoteknik_api/models/product_product.py
new file mode 100644
index 00000000..a1f22068
--- /dev/null
+++ b/indoteknik_api/models/product_product.py
@@ -0,0 +1,19 @@
+from odoo import models
+
+
+class ProductTemplate(models.Model):
+ _inherit = 'product.product'
+
+ def api_single_response(self, product_product):
+ product_pricelist_default_discount_id = self.env['ir.config_parameter'].get_param('product.pricelist.default_discount_id')
+ product_pricelist_default_discount_id = int(product_pricelist_default_discount_id)
+ data = {
+ 'id': product_product.id,
+ 'code': product_product.default_code or '',
+ 'name': product_product.display_name,
+ 'price': self.env['product.pricelist'].compute_price(product_pricelist_default_discount_id, product_product.id),
+ 'stock': product_product.qty_stock_vendor,
+ 'weight': product_product.weight,
+ 'attributes': [x.name for x in product_product.product_template_attribute_value_ids],
+ }
+ return data \ No newline at end of file
diff --git a/indoteknik_api/models/product_template.py b/indoteknik_api/models/product_template.py
index 8ced0374..b616a773 100644
--- a/indoteknik_api/models/product_template.py
+++ b/indoteknik_api/models/product_template.py
@@ -24,23 +24,11 @@ class ProductTemplate(models.Model):
data_with_detail = {
'image': base_url + 'api/image/product.template/image_512/' + str(product_template.id) if product_template.image_512 else '',
'display_name': product_template.display_name,
- 'variants': [],
+ 'variants': [self.env['product.product'].api_single_response(variant) for variant in product_template.product_variant_ids],
'description': product_template.website_description or '',
'solr_flag': product_template.solr_flag,
'product_rating': product_template.product_rating,
}
- for variant in product_template.product_variant_ids:
- data_with_detail['variants'].append({
- 'id': variant.id,
- 'code': variant.default_code or '',
- 'name': variant.display_name,
- 'price': self.env['product.pricelist'].compute_price(product_pricelist_default_discount_id, variant.id),
- 'stock': variant.qty_stock_vendor,
- 'weight': variant.weight,
- 'attributes': [x.name for x in variant.product_template_attribute_value_ids],
- 'solr_flag': product_template.solr_flag,
- 'product_rating': product_template.product_rating,
- })
data.update(data_with_detail)
return data
diff --git a/indoteknik_custom/__manifest__.py b/indoteknik_custom/__manifest__.py
index a703bcef..e0369306 100755
--- a/indoteknik_custom/__manifest__.py
+++ b/indoteknik_custom/__manifest__.py
@@ -26,6 +26,8 @@
'views/vit_kelurahan.xml',
'views/vit_kecamatan.xml',
'views/vit_kota.xml',
+ 'views/website_user_cart.xml',
+ 'views/website_user_wishlist.xml',
'views/x_banner_banner.xml',
'views/x_banner_category.xml',
'views/x_biaya_kirim.xml',
diff --git a/indoteknik_custom/models/__init__.py b/indoteknik_custom/models/__init__.py
index 21549684..c4f1a443 100755
--- a/indoteknik_custom/models/__init__.py
+++ b/indoteknik_custom/models/__init__.py
@@ -30,3 +30,4 @@ from . import ir_attachment
from . import delivery_carrier
from . import dunning_run
from . import website_user_cart
+from . import website_user_wishlist
diff --git a/indoteknik_custom/models/website_user_cart.py b/indoteknik_custom/models/website_user_cart.py
index 165170a9..8046469f 100644
--- a/indoteknik_custom/models/website_user_cart.py
+++ b/indoteknik_custom/models/website_user_cart.py
@@ -1,13 +1,10 @@
-from odoo import fields, models, api, _
-from odoo.exceptions import AccessError, UserError, ValidationError
+from odoo import fields, models
class WebsiteUserCart(models.Model):
_name = 'website.user.cart'
+ _rec_name = 'user_id'
+
user_id = fields.Many2one('res.users', string='User', help="User ID yang terdaftar di table res.users")
- cart_type = fields.Selection([
- ('cart', 'Cart'),
- ('wishlist', 'Wishlist'),
- ], string='Cart Type', help="Type apakah Cart atau Wishlist")
product_id = fields.Many2one('product.product', string='Product', help="Product yang terdaftar di table product.product")
qty = fields.Float(string='Quantity', digits='Product Unit of Measure')
diff --git a/indoteknik_custom/models/website_user_wishlist.py b/indoteknik_custom/models/website_user_wishlist.py
new file mode 100644
index 00000000..a6ee35d4
--- /dev/null
+++ b/indoteknik_custom/models/website_user_wishlist.py
@@ -0,0 +1,9 @@
+from odoo import fields, models
+
+
+class WebsiteUserWishlist(models.Model):
+ _name = 'website.user.wishlist'
+ _rec_name = 'user_id'
+
+ user_id = fields.Many2one('res.users', string='User', help="User ID yang terdaftar di table res.users")
+ product_id = fields.Many2one('product.template', string='Product', help="Product yang terdaftar di table product.template")
diff --git a/indoteknik_custom/security/ir.model.access.csv b/indoteknik_custom/security/ir.model.access.csv
index 9d2137f6..d0cc631d 100755
--- a/indoteknik_custom/security/ir.model.access.csv
+++ b/indoteknik_custom/security/ir.model.access.csv
@@ -13,4 +13,6 @@ access_sale_monitoring_detail,access.sale.monitoring.detail,model_sale_monitorin
access_delivery_order,access.delivery.order,model_delivery_order,,1,1,1,1
access_delivery_order_line,access.delivery.order.line,model_delivery_order_line,,1,1,1,1
access_dunning_run,access.dunning.run,model_dunning_run,,1,1,1,1
-access_dunning_run_line,access.dunning.run.line,model_dunning_run_line,,1,1,1,1 \ No newline at end of file
+access_dunning_run_line,access.dunning.run.line,model_dunning_run_line,,1,1,1,1
+access_website_user_cart,access.website.user.cart,model_website_user_cart,,1,1,1,1
+access_website_user_wishlist,access.website.user.wishlist,model_website_user_wishlist,,1,1,1,1 \ No newline at end of file
diff --git a/indoteknik_custom/views/website_user_cart.xml b/indoteknik_custom/views/website_user_cart.xml
new file mode 100755
index 00000000..890d801c
--- /dev/null
+++ b/indoteknik_custom/views/website_user_cart.xml
@@ -0,0 +1,47 @@
+<odoo>
+ <data>
+ <record id="website_user_cart_action" model="ir.actions.act_window">
+ <field name="name">User Cart</field>
+ <field name="res_model">website.user.cart</field>
+ <field name="view_mode">tree,form</field>
+ </record>
+
+ <record id="website_user_cart_tree" model="ir.ui.view">
+ <field name="name">User Cart</field>
+ <field name="model">website.user.cart</field>
+ <field name="arch" type="xml">
+ <tree>
+ <field name="user_id"/>
+ <field name="product_id"/>
+ <field name="qty"/>
+ </tree>
+ </field>
+ </record>
+
+ <record id="website_user_cart_form" model="ir.ui.view">
+ <field name="name">User Cart</field>
+ <field name="model">website.user.cart</field>
+ <field name="arch" type="xml">
+ <form>
+ <sheet>
+ <group>
+ <group>
+ <field name="user_id"/>
+ <field name="product_id"/>
+ <field name="qty"/>
+ </group>
+ <group></group>
+ </group>
+ </sheet>
+ </form>
+ </field>
+ </record>
+
+ <menuitem id="website_user_cart"
+ name="User Cart"
+ parent="website_sale.menu_orders"
+ sequence="1"
+ action="website_user_cart_action"
+ />
+ </data>
+</odoo> \ No newline at end of file
diff --git a/indoteknik_custom/views/website_user_wishlist.xml b/indoteknik_custom/views/website_user_wishlist.xml
new file mode 100755
index 00000000..998877b2
--- /dev/null
+++ b/indoteknik_custom/views/website_user_wishlist.xml
@@ -0,0 +1,45 @@
+<odoo>
+ <data>
+ <record id="website_user_wishlist_action" model="ir.actions.act_window">
+ <field name="name">User Wishlist</field>
+ <field name="res_model">website.user.wishlist</field>
+ <field name="view_mode">tree,form</field>
+ </record>
+
+ <record id="website_user_wishlist_tree" model="ir.ui.view">
+ <field name="name">User Wishlist</field>
+ <field name="model">website.user.wishlist</field>
+ <field name="arch" type="xml">
+ <tree>
+ <field name="user_id"/>
+ <field name="product_id"/>
+ </tree>
+ </field>
+ </record>
+
+ <record id="website_user_wishlist_form" model="ir.ui.view">
+ <field name="name">User Wishlist</field>
+ <field name="model">website.user.wishlist</field>
+ <field name="arch" type="xml">
+ <form>
+ <sheet>
+ <group>
+ <group>
+ <field name="user_id"/>
+ <field name="product_id"/>
+ </group>
+ <group></group>
+ </group>
+ </sheet>
+ </form>
+ </field>
+ </record>
+
+ <menuitem id="website_user_wishlist"
+ name="User Wishlist"
+ parent="website_sale.menu_orders"
+ sequence="1"
+ action="website_user_wishlist_action"
+ />
+ </data>
+</odoo> \ No newline at end of file