diff options
| author | IT Fixcomart <it@fixcomart.co.id> | 2022-11-15 17:35:23 +0700 |
|---|---|---|
| committer | IT Fixcomart <it@fixcomart.co.id> | 2022-11-15 17:35:23 +0700 |
| commit | f6671dd4595af3c1075b27925f10c457854cecf8 (patch) | |
| tree | fadac999707657fc3ce1b0e359e5acc69d497308 | |
| parent | 2861ba3cd7844079ce85ad31aa1470e95de7f71d (diff) | |
Fitur crud cart dan wishlist
Update struktur response product
| -rw-r--r-- | indoteknik_api/controllers/api_v1/__init__.py | 4 | ||||
| -rw-r--r-- | indoteknik_api/controllers/api_v1/cart.py | 71 | ||||
| -rw-r--r-- | indoteknik_api/controllers/api_v1/wishlist.py | 53 | ||||
| -rw-r--r-- | indoteknik_api/models/__init__.py | 1 | ||||
| -rw-r--r-- | indoteknik_api/models/product_product.py | 19 | ||||
| -rw-r--r-- | indoteknik_api/models/product_template.py | 14 | ||||
| -rwxr-xr-x | indoteknik_custom/__manifest__.py | 2 | ||||
| -rwxr-xr-x | indoteknik_custom/models/__init__.py | 1 | ||||
| -rw-r--r-- | indoteknik_custom/models/website_user_cart.py | 9 | ||||
| -rw-r--r-- | indoteknik_custom/models/website_user_wishlist.py | 9 | ||||
| -rwxr-xr-x | indoteknik_custom/security/ir.model.access.csv | 4 | ||||
| -rwxr-xr-x | indoteknik_custom/views/website_user_cart.xml | 47 | ||||
| -rwxr-xr-x | indoteknik_custom/views/website_user_wishlist.xml | 45 |
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 |
