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.
 
 
 
 
 

377 lines
19 KiB

# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2020-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Sayooj A O(<https://www.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/>.
#
#############################################################################
from odoo import fields, models, _
from odoo.exceptions import UserError
class StockPicking(models.Model):
"""Inheriting model stock.picking"""
_inherit = 'stock.picking'
invoice_count = fields.Integer(string='Invoices',
compute='_compute_invoice_count')
operation_code = fields.Selection(related='picking_type_id.code')
is_return = fields.Boolean()
def _compute_invoice_count(self):
"""This compute function used to count the number of invoice for
the picking"""
for picking_id in self:
move_ids = picking_id.env['account.move'].search(
[('transfer_ids', 'in', picking_id.id)])
if move_ids:
self.invoice_count = len(move_ids)
else:
self.invoice_count = 0
def create_invoice(self):
"""This is the function for creating customer invoice
from the picking"""
for picking_id in self:
current_user = self.env.uid
if picking_id.picking_type_id.code == 'outgoing':
customer_journal_id = \
picking_id.env['ir.config_parameter'].sudo().\
get_param('stock_move_invoice.customer_journal_id') or \
False
if not customer_journal_id:
raise UserError(
_("Please configure the journal from settings"))
invoice_line_list = []
for move_ids_without_package in picking_id.\
move_ids_without_package:
vals = (0, 0, {
'name': move_ids_without_package.description_picking,
'product_id': move_ids_without_package.product_id.id,
'price_unit':
move_ids_without_package.product_id.lst_price,
'account_id':
move_ids_without_package.product_id.
property_account_income_id.id if
move_ids_without_package.
product_id.property_account_income_id
else move_ids_without_package.
product_id.categ_id.
property_account_income_categ_id.id,
'tax_ids': [(6, 0, [
picking_id.company_id.account_sale_tax_id.id])],
'quantity': move_ids_without_package.quantity_done,
})
invoice_line_list.append(vals)
invoice = picking_id.env['account.move'].create({
'move_type': 'out_invoice',
'invoice_origin': picking_id.name,
'invoice_user_id': current_user,
'narration': picking_id.name,
'partner_id': picking_id.partner_id.id,
'currency_id':
picking_id.env.user.company_id.currency_id.id,
'journal_id': int(customer_journal_id),
'payment_reference': picking_id.name,
'picking_id': picking_id.id,
'invoice_line_ids': invoice_line_list,
'transfer_ids': self
})
return invoice
def create_bill(self):
"""This is the function for creating vendor bill
from the picking"""
for picking_id in self:
current_user = self.env.uid
if picking_id.picking_type_id.code == 'incoming':
vendor_journal_id = picking_id.env[
'ir.config_parameter'].sudo().get_param(
'stock_move_invoice.vendor_journal_id') or False
if not vendor_journal_id:
raise UserError(
_("Please configure the journal from the settings."))
invoice_line_list = []
for move_ids_without_package in picking_id.\
move_ids_without_package:
vals = (0, 0, {
'name': move_ids_without_package.description_picking,
'product_id': move_ids_without_package.product_id.id,
'price_unit':
move_ids_without_package.product_id.lst_price,
'account_id':
move_ids_without_package.product_id.
property_account_income_id.id if
move_ids_without_package.product_id.
property_account_income_id
else move_ids_without_package.product_id.categ_id.
property_account_income_categ_id.id,
'tax_ids': [(6, 0, [
picking_id.company_id.account_purchase_tax_id.id])],
'quantity': move_ids_without_package.quantity_done,
})
invoice_line_list.append(vals)
invoice = picking_id.env['account.move'].create({
'move_type': 'in_invoice',
'invoice_origin': picking_id.name,
'invoice_user_id': current_user,
'narration': picking_id.name,
'partner_id': picking_id.partner_id.id,
'currency_id':
picking_id.env.user.company_id.currency_id.id,
'journal_id': int(vendor_journal_id),
'payment_reference': picking_id.name,
'picking_id': picking_id.id,
'invoice_line_ids': invoice_line_list,
'transfer_ids': self
})
return invoice
def create_customer_credit(self):
"""This is the function for creating customer credit note
from the picking"""
for picking_id in self:
current_user = picking_id.env.uid
if picking_id.picking_type_id.code == 'incoming':
customer_journal_id = \
picking_id.env['ir.config_parameter'].sudo().\
get_param('stock_move_invoice.customer_journal_id') or \
False
if not customer_journal_id:
raise UserError(
_("Please configure the journal from settings"))
invoice_line_list = []
for move_ids_without_package in picking_id.\
move_ids_without_package:
vals = (0, 0, {
'name': move_ids_without_package.description_picking,
'product_id': move_ids_without_package.product_id.id,
'price_unit':
move_ids_without_package.product_id.lst_price,
'account_id': move_ids_without_package.product_id.
property_account_income_id.id if
move_ids_without_package.product_id.
property_account_income_id
else move_ids_without_package.product_id.categ_id.
property_account_income_categ_id.id,
'tax_ids': [(6, 0, [
picking_id.company_id.account_sale_tax_id.id])],
'quantity': move_ids_without_package.quantity_done,
})
invoice_line_list.append(vals)
invoice = picking_id.env['account.move'].create({
'move_type': 'out_refund',
'invoice_origin': picking_id.name,
'invoice_user_id': current_user,
'narration': picking_id.name,
'partner_id': picking_id.partner_id.id,
'currency_id':
picking_id.env.user.company_id.currency_id.id,
'journal_id': int(customer_journal_id),
'payment_reference': picking_id.name,
'picking_id': picking_id.id,
'invoice_line_ids': invoice_line_list,
'transfer_ids': self
})
return invoice
def create_vendor_credit(self):
"""This is the function for creating refund
from the picking"""
for picking_id in self:
current_user = self.env.uid
if picking_id.picking_type_id.code == 'outgoing':
vendor_journal_id = picking_id.env[
'ir.config_parameter'].sudo().get_param(
'stock_move_invoice.vendor_journal_id') or False
if not vendor_journal_id:
raise UserError(
_("Please configure the journal from the settings."))
invoice_line_list = []
for move_ids_without_package in picking_id.\
move_ids_without_package:
vals = (0, 0, {
'name': move_ids_without_package.description_picking,
'product_id': move_ids_without_package.product_id.id,
'price_unit':
move_ids_without_package.product_id.lst_price,
'account_id': move_ids_without_package.product_id.
property_account_income_id.id if
move_ids_without_package.product_id.
property_account_income_id
else move_ids_without_package.product_id.categ_id.
property_account_income_categ_id.id,
'tax_ids': [(6, 0, [
picking_id.company_id.account_purchase_tax_id.id])],
'quantity': move_ids_without_package.quantity_done,
})
invoice_line_list.append(vals)
invoice = picking_id.env['account.move'].create({
'move_type': 'in_refund',
'invoice_origin': picking_id.name,
'invoice_user_id': current_user,
'narration': picking_id.name,
'partner_id': picking_id.partner_id.id,
'currency_id':
picking_id.env.user.company_id.currency_id.id,
'journal_id': int(vendor_journal_id),
'payment_reference': picking_id.name,
'picking_id': picking_id.id,
'invoice_line_ids': invoice_line_list,
'transfer_ids': self
})
return invoice
def action_open_picking_invoice(self):
"""This is the function of the smart button which redirect to the
invoice related to the current picking"""
return {
'name': 'Invoices',
'type': 'ir.actions.act_window',
'view_mode': 'tree,form',
'res_model': 'account.move',
'domain': [('transfer_ids', 'in', self.id)],
'context': {'create': False},
'target': 'current'
}
def action_create_multi_invoice_for_multi_transfer(self):
"""This is the function for creating customer invoice
from the picking"""
picking_type = list(self.picking_type_id)
if all(first == picking_type[0] for first in picking_type):
if self.picking_type_id.code == 'outgoing':
partner = list(self.partner_id)
if all(first == partner[0] for first in partner):
partner_id = self.partner_id
invoice_line_list = []
customer_journal_id = \
self.env['ir.config_parameter'].sudo().\
get_param('stock_move_invoice.customer_journal_id') \
or False
if not customer_journal_id:
raise UserError(
_("Please configure the journal from settings"))
for picking_id in self:
for move_ids_without_package in picking_id.\
move_ids_without_package:
vals = (0, 0, {
'name':
move_ids_without_package.description_picking
,
'product_id':
move_ids_without_package.product_id.id,
'price_unit': move_ids_without_package.
product_id.lst_price,
'account_id': move_ids_without_package.
product_id.property_account_income_id.id if
move_ids_without_package.product_id.
property_account_income_id
else move_ids_without_package.
product_id.categ_id.
property_account_income_categ_id.id,
'tax_ids': [(6, 0, [picking_id.company_id.
account_purchase_tax_id.id])],
'quantity':
move_ids_without_package.quantity_done,
})
invoice_line_list.append(vals)
invoice = self.env['account.move'].create({
'move_type': 'out_invoice',
'invoice_origin': picking_id.name,
'invoice_user_id': self.env.uid,
'narration': picking_id.name,
'partner_id': partner_id.id,
'currency_id':
picking_id.env.user.company_id.currency_id.id,
'journal_id': int(customer_journal_id),
'payment_reference': picking_id.name,
'invoice_line_ids': invoice_line_list,
'transfer_ids': self
})
else:
for picking_id in self:
picking_id.create_invoice()
elif self.picking_type_id.code == 'incoming':
partner = list(self.partner_id)
if all(first == partner[0] for first in partner):
partner_id = self.partner_id
bill_line_list = []
vendor_journal_id = \
self.env['ir.config_parameter'].sudo().\
get_param('stock_move_invoice.vendor_journal_id') \
or False
if not vendor_journal_id:
raise UserError(_("Please configure the journal from "
"the settings."))
for picking_id in self:
for move_ids_without_package in picking_id.\
move_ids_without_package:
vals = (0, 0, {
'name':
move_ids_without_package.description_picking
,
'product_id':
move_ids_without_package.product_id.id,
'price_unit': move_ids_without_package.
product_id.lst_price,
'account_id': move_ids_without_package.
product_id.property_account_income_id.id if
move_ids_without_package.product_id.
property_account_income_id
else move_ids_without_package.
product_id.categ_id.
property_account_income_categ_id.id,
'tax_ids': [(6, 0, [picking_id.company_id.
account_purchase_tax_id.id])],
'quantity':
move_ids_without_package.quantity_done,
})
bill_line_list.append(vals)
invoice = self.env['account.move'].create({
'move_type': 'in_invoice',
'invoice_origin': picking_id.name,
'invoice_user_id': self.env.uid,
'narration': picking_id.name,
'partner_id': partner_id.id,
'currency_id':
picking_id.env.user.company_id.currency_id.id,
'journal_id': int(vendor_journal_id),
'payment_reference': picking_id.name,
'picking_id': picking_id.id,
'invoice_line_ids': bill_line_list,
'transfer_ids': self
})
else:
for picking_id in self:
picking_id.create_bill()
else:
raise UserError(
_("Please select single type transfer"))
class StockReturnInvoicePicking(models.TransientModel):
_inherit = 'stock.return.picking'
def _create_returns(self):
"""in this function the picking is marked as return"""
new_picking, pick_type_id = \
super(StockReturnInvoicePicking, self)._create_returns()
picking = self.env['stock.picking'].browse(new_picking)
picking.write({'is_return': True})
return new_picking, pick_type_id