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.
 
 
 
 
 

57 lines
2.1 KiB

# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions (<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# 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 LESSER GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import models
class PurchaseOrderConfirm(models.Model):
_inherit = 'purchase.order'
def action_multi_confirm(self):
"""
Confirm multiple purchase orders.
This method confirms purchase orders in draft or sent state. It is
intended to be used as a batch confirmation for multiple purchase
orders selected through the context.
:return: None
"""
for order in self.env['purchase.order'].browse(
self.env.context.get('active_ids')).filtered(
lambda o: o.state in ['draft', 'sent']):
order.button_confirm()
def action_multi_cancel(self):
"""
Cancel multiple purchase orders that are not in the 'done' state.
This method cancels purchase orders selected through the context,
excluding those that are already in the 'done' state.
It is intended to be used as a batch cancellation for multiple
purchase orders.
:return: None
"""
for order in self.env['purchase.order'].browse(
self.env.context.get('active_ids')).filtered(
lambda o: o.state != 'done'):
order.button_cancel()