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

# -*- 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