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.
		
		
		
		
		
			
		
			
				
					
					
						
							92 lines
						
					
					
						
							3.8 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							92 lines
						
					
					
						
							3.8 KiB
						
					
					
				
								# -*- coding: utf-8 -*-
							 | 
						|
								##############################################################################
							 | 
						|
								#
							 | 
						|
								#    Cybrosys Technologies Pvt. Ltd.
							 | 
						|
								#
							 | 
						|
								#    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
							 | 
						|
								#    Author: Mohammed Irfan T (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/>.
							 | 
						|
								#
							 | 
						|
								##############################################################################
							 | 
						|
								from odoo import api, fields, models, _
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								class SaleOrder(models.Model):
							 | 
						|
								    """Inherits Sales to create sale order versions"""
							 | 
						|
								    _inherit = "sale.order"
							 | 
						|
								
							 | 
						|
								    is_version = fields.Boolean(string="Is Version",
							 | 
						|
								                                help="For checking version or not")
							 | 
						|
								    version_count = fields.Integer(string="Sale Version Count",
							 | 
						|
								                                   compute='_compute_version_ids',
							 | 
						|
								                                   help="Count of version created")
							 | 
						|
								    current_version_id = fields.Many2one("sale.order",
							 | 
						|
								                                         string='Current version',
							 | 
						|
								                                         help="For creating versions")
							 | 
						|
								    version_ids = fields.One2many("sale.order", string='Version',
							 | 
						|
								                                  inverse_name="current_version_id",
							 | 
						|
								                                  help="Versions created")
							 | 
						|
								    state = fields.Selection(selection_add=[('revised', 'Revised')],
							 | 
						|
								                             string='State', help='State of the sale order')
							 | 
						|
								
							 | 
						|
								    def action_create_versions(self):
							 | 
						|
								        """For creating the versions of the sale order."""
							 | 
						|
								        sale_order_copy_id = self.copy()
							 | 
						|
								        sale_order_copy_id.is_version = True
							 | 
						|
								        length = len(self.version_ids)
							 | 
						|
								        sale_order_copy_id.name = "%s-%s" % (self.name, str(length + 1))
							 | 
						|
								        sale_order_copy_id.state = 'revised'
							 | 
						|
								        self.write({'version_ids': [(4, sale_order_copy_id.id)]})
							 | 
						|
								
							 | 
						|
								    @api.depends('version_ids')
							 | 
						|
								    def _compute_version_ids(self):
							 | 
						|
								        """For calculating the number of versions created."""
							 | 
						|
								        for sale in self:
							 | 
						|
								            sale.version_count = len(sale.version_ids)
							 | 
						|
								
							 | 
						|
								    def action_view_versions(self):
							 | 
						|
								        """Action for viewing versions"""
							 | 
						|
								        action = {
							 | 
						|
								            "type": "ir.actions.act_window",
							 | 
						|
								            "view_mode": "kanban,tree,form",
							 | 
						|
								            "name": _("Sale Order Versions"),
							 | 
						|
								            "res_model": self._name,
							 | 
						|
								            "domain": [('id', 'in', self.version_ids.ids)],
							 | 
						|
								            "target": "current"
							 | 
						|
								        }
							 | 
						|
								        return action
							 | 
						|
								
							 | 
						|
								    def action_restore(self):
							 | 
						|
								        """
							 | 
						|
								            Restore the current version of a sale and cancel all other versions
							 | 
						|
								            This method restores the current version of a sale to the 'draft'
							 | 
						|
								            state and cancels all other versions of the sale by setting their
							 | 
						|
								            state to 'cancel'.
							 | 
						|
								            :return: None
							 | 
						|
								        """
							 | 
						|
								        parent_sale = self.current_version_id
							 | 
						|
								        self.write({'state': 'draft'})
							 | 
						|
								        for version in parent_sale.version_ids:
							 | 
						|
								            if version != self:
							 | 
						|
								                version.write({'state': 'cancel'})
							 | 
						|
								
							 | 
						|
								    def set_to_revise(self):
							 | 
						|
								        """
							 | 
						|
								            Set the state of the record to 'revised'.
							 | 
						|
								            This method updates the state of the record to 'revised'. It is
							 | 
						|
								            typically used to indicate that the record has undergone a revision
							 | 
						|
								            or modification.
							 | 
						|
								            :return: None
							 | 
						|
								        """
							 | 
						|
								        self.write({'state': 'revised'})
							 | 
						|
								
							 |