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.
 
 
 
 
 

58 lines
2.5 KiB

# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: JANISH BABU (<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 models, fields
class SubscriptionClose(models.TransientModel):
_name = 'subscription.close'
_description = 'Subscription Close Wizard'
close_reason_id = fields.Many2one('subscription.package.stop',
string='Close Reason',
help='Add Subscription Package '
'Close Reason')
closed_by = fields.Many2one('res.users', string='Closed By',
default=lambda self: self.env.user,
help='Choose Subscription Package '
'Closed Person')
close_date = fields.Date(string='Closed On',
default=lambda self: fields.Date.today(),
help='Add Subscription Package Closed Date')
def button_submit(self):
self.ensure_one()
this_sub_id = self.env.context.get('active_id')
sub = self.env['subscription.package'].search(
[('id', '=', this_sub_id)])
sub.is_closed = True
sub.close_reason_id = self.close_reason_id
sub.closed_by = self.closed_by
sub.close_date = self.close_date
stage = (self.env['subscription.package.stage'].search([
('category', '=', 'closed')]).id)
values = {'stage_id': stage, 'is_to_renew': False}
sub.write(values)
for lines in sub.sale_order_id.order_line.filtered(
lambda x: x.product_template_id.is_subscription == True):
lines.qty_invoiced = lines.product_uom_qty
lines.qty_to_invoice = 0