You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							162 lines
						
					
					
						
							7.3 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							162 lines
						
					
					
						
							7.3 KiB
						
					
					
				
								# -*- coding: utf-8 -*-
							 | 
						|
								################################################################################
							 | 
						|
								#
							 | 
						|
								#    Cybrosys Technologies Pvt. Ltd.
							 | 
						|
								#
							 | 
						|
								#    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
							 | 
						|
								#    Author: Subina P (odoo@cybrosys.com)
							 | 
						|
								#
							 | 
						|
								#    You can modify it under the terms of the GNU AFFERO
							 | 
						|
								#    GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
							 | 
						|
								#
							 | 
						|
								#    This program is distributed in the hope that it will be useful,
							 | 
						|
								#    but WITHOUT ANY WARRANTY; without even the implied warranty of
							 | 
						|
								#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
							 | 
						|
								#    GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
							 | 
						|
								#
							 | 
						|
								#    You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
							 | 
						|
								#    (AGPL v3) along with this program.
							 | 
						|
								#    If not, see <http://www.gnu.org/licenses/>.
							 | 
						|
								#
							 | 
						|
								################################################################################
							 | 
						|
								import json
							 | 
						|
								import requests
							 | 
						|
								from odoo import api, fields, models
							 | 
						|
								from odoo.exceptions import ValidationError
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								class ProductTemplate(models.Model):
							 | 
						|
								    """Inherits product template for including Pipedrive fields ab=nd
							 | 
						|
								    functions"""
							 | 
						|
								    _inherit = 'product.template'
							 | 
						|
								
							 | 
						|
								    pipedrive_reference = fields.Char(string='Pipedrive Reference',
							 | 
						|
								                                      help="Pipedrive Id of the Product")
							 | 
						|
								    update_from_pipedrive = fields.Boolean(string='Update from Pipedrive',
							 | 
						|
								                                           help="True if the update is from pipedrive")
							 | 
						|
								
							 | 
						|
								    def write(self, vals):
							 | 
						|
								        """Inherited to update the Pipedrive product."""
							 | 
						|
								        data = {}
							 | 
						|
								        if 'name' in vals.keys():
							 | 
						|
								            data['name'] = vals['name']
							 | 
						|
								        if 'uom_id' in vals.keys():
							 | 
						|
								            data['unit'] = self.env['uom.uom'].browse(vals['uom_id']).name
							 | 
						|
								        if 'taxes_id' in vals.keys():
							 | 
						|
								            if vals['taxes_id'] and type(vals['taxes_id'][0]) == list:
							 | 
						|
								                total_tax = 0.0
							 | 
						|
								                for tax in self.env['account.tax'].sudo().search(
							 | 
						|
								                        [('id', 'in', vals['taxes_id'][0][2])]):
							 | 
						|
								                    total_tax += self.calculate_total_tax_percentage(tax)
							 | 
						|
								                data['tax'] = total_tax
							 | 
						|
								        if 'list_price' in vals.keys():
							 | 
						|
								            data['prices'] = [{'price': vals['list_price'],
							 | 
						|
								                               'currency': self.env.company.currency_id.name}
							 | 
						|
								                              ]
							 | 
						|
								        pipedrive_product = self.env['pipedrive.record'].sudo().search(
							 | 
						|
								            [('record_type', '=', 'product'), ('odoo_ref', '=', self.id)])
							 | 
						|
								        if pipedrive_product and data:
							 | 
						|
								            headers = {
							 | 
						|
								                'Content-Type': 'application/json',
							 | 
						|
								                'Accept': 'application/json'
							 | 
						|
								            }
							 | 
						|
								            response = requests.put(
							 | 
						|
								                url=f'https://api.pipedrive.com/v1/products/'
							 | 
						|
								                    f'{pipedrive_product.pipedrive_reference}',
							 | 
						|
								                params={
							 | 
						|
								                    'api_token': self.env.user.company_id.api_key,
							 | 
						|
								                }, timeout=10, headers=headers, data=json.dumps(data))
							 | 
						|
								            if 'error' in response.json().keys():
							 | 
						|
								                raise ValidationError(
							 | 
						|
								                    response.json()['error'])
							 | 
						|
								        return super().write(vals)
							 | 
						|
								
							 | 
						|
								    def calculate_total_tax_percentage(self, tax):
							 | 
						|
								        """Method for calculating total tax"""
							 | 
						|
								        total_percentage_tax = 0.0
							 | 
						|
								        # Percentage Taxes
							 | 
						|
								        if tax.amount_type == 'percent':
							 | 
						|
								            total_percentage_tax = tax.amount
							 | 
						|
								        # Group Taxes
							 | 
						|
								        elif tax.amount_type == 'group':
							 | 
						|
								            for child_tax in tax.children_tax_ids.filtered(
							 | 
						|
								                    lambda t: t.amount_type == 'percent'):
							 | 
						|
								                total_percentage_tax += child_tax.amount
							 | 
						|
								        # Fixed Taxes
							 | 
						|
								        elif tax.amount_type == 'fixed':
							 | 
						|
								            total_percentage_tax = (tax.amount / tax.list_price) * 100
							 | 
						|
								        # Division Taxes
							 | 
						|
								        else:
							 | 
						|
								            total_percentage_tax = (tax.list_price / tax.factor) * 100
							 | 
						|
								        return total_percentage_tax
							 | 
						|
								
							 | 
						|
								    def unlink(self):
							 | 
						|
								        """Method for deleting a product from Pipedrive"""
							 | 
						|
								        pipedrive_product = self.env['pipedrive.record'].sudo().search(
							 | 
						|
								            [('record_type', '=', 'product'), ('odoo_ref', '=', self.id)])
							 | 
						|
								        if pipedrive_product:
							 | 
						|
								            headers = {
							 | 
						|
								                'Content-Type': 'application/json',
							 | 
						|
								                'Accept': 'application/json'
							 | 
						|
								            }
							 | 
						|
								            response = requests.delete(
							 | 
						|
								                url=f'https://api.pipedrive.com/v1/products/'
							 | 
						|
								                    f'{pipedrive_product.pipedrive_reference}',
							 | 
						|
								                params={
							 | 
						|
								                    'api_token': self.env.user.company_id.api_key,
							 | 
						|
								                }, timeout=10, headers=headers)
							 | 
						|
								            if 'error' in response.json().keys():
							 | 
						|
								                raise ValidationError(
							 | 
						|
								                    response.json()['error'])
							 | 
						|
								        return super().unlink()
							 | 
						|
								
							 | 
						|
								    @api.model_create_multi
							 | 
						|
								    def create(self, vals_list):
							 | 
						|
								        """Inherited to add the product to pipedrive"""
							 | 
						|
								        res = super().create(vals_list)
							 | 
						|
								        if self.env.company.product_synced and not res.pipedrive_reference:
							 | 
						|
								            if not self.env['pipedrive.record'].search(
							 | 
						|
								                    [('record_type', '=', 'product',), ('odoo_ref', '=', res.id)]):
							 | 
						|
								                for product in vals_list:
							 | 
						|
								                    tax_ids = product.get('taxes_id', [])
							 | 
						|
								                    total_percentage_tax = 0.0
							 | 
						|
								                    if tax_ids:
							 | 
						|
								                        for tax_id in tax_ids:
							 | 
						|
								                            tax = self.env['account.tax'].sudo().browse(tax_id[1])
							 | 
						|
								                            if tax.amount_type == 'percent':
							 | 
						|
								                                total_percentage_tax += tax.amount
							 | 
						|
								
							 | 
						|
								                            elif tax.amount_type == 'group':
							 | 
						|
								                                for child_tax in tax.children_tax_ids:
							 | 
						|
								                                    if child_tax.amount_type == 'percent':
							 | 
						|
								                                        total_percentage_tax += child_tax.amount
							 | 
						|
								                            elif tax.amount_type == 'fixed':
							 | 
						|
								                                total_percentage_tax += (tax.amount / product[
							 | 
						|
								                                    'list_price']) * 100
							 | 
						|
								                    data = {
							 | 
						|
								                        'name': product['name'],
							 | 
						|
								                        'tax': total_percentage_tax,
							 | 
						|
								                        'prices': [{
							 | 
						|
								                            'price': product['list_price'],
							 | 
						|
								                            'currency': self.env.company.currency_id.name,
							 | 
						|
								                            'cost': product['standard_price']
							 | 
						|
								                        }]
							 | 
						|
								                    }
							 | 
						|
								                    if 'uom_id' in product.keys():
							 | 
						|
								                        data['unit'] = self.env['uom.uom'].sudo().browse(
							 | 
						|
								                            product['uom_id']).name
							 | 
						|
								                    response = requests.post(
							 | 
						|
								                        url='https://api.pipedrive.com/v1/products',
							 | 
						|
								                        params={
							 | 
						|
								                            'api_token': self.env.company.api_key,
							 | 
						|
								                        }, json=data, timeout=10)
							 | 
						|
								                    if not response.json()['success']:
							 | 
						|
								                        raise ValidationError(
							 | 
						|
								                            response.json()['error'] + '. ' + response.json()[
							 | 
						|
								                                'error_info'])
							 | 
						|
								                    self.env['pipedrive.record'].sudo().create({
							 | 
						|
								                        'pipedrive_reference': response.json()['data']['id'],
							 | 
						|
								                        'record_type': 'product',
							 | 
						|
								                        'odoo_ref': res.id
							 | 
						|
								                    })
							 | 
						|
								        return res
							 | 
						|
								
							 |