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.
		
		
		
		
		
			
		
			
				
					
					
						
							87 lines
						
					
					
						
							4.2 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							87 lines
						
					
					
						
							4.2 KiB
						
					
					
				
								# -*- coding: utf-8 -*-
							 | 
						|
								#############################################################################
							 | 
						|
								#
							 | 
						|
								#    Cybrosys Technologies Pvt. Ltd.
							 | 
						|
								#
							 | 
						|
								#    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
							 | 
						|
								#    Author: Gayathri V (<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 api, fields, models, _
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								class GymMembership(models.Model):
							 | 
						|
								    """This model is for gym membership."""
							 | 
						|
								    _name = "gym.membership"
							 | 
						|
								    _inherit = ["mail.thread", "mail.activity.mixin"]
							 | 
						|
								    _description = "Gym Membership"
							 | 
						|
								    _rec_name = "reference"
							 | 
						|
								
							 | 
						|
								    reference = fields.Char(string='GYM reference', readonly=True,
							 | 
						|
								                            default=lambda self: _('New'),
							 | 
						|
								                            help="Member reference")
							 | 
						|
								    member_id = fields.Many2one('res.partner', string='Member',
							 | 
						|
								                                required=True, tracking=True,
							 | 
						|
								                                help="Member taken the membership",
							 | 
						|
								                                domain="[('is_gym_member', '!=',False)]")
							 | 
						|
								    membership_scheme_id = fields.Many2one('product.product',
							 | 
						|
								                                           string='Membership scheme',
							 | 
						|
								                                           help="Member ship scheme",
							 | 
						|
								                                           required=True, tracking=True,
							 | 
						|
								                                           domain="[('membership_date_from', "
							 | 
						|
								                                                  "'!=',False)]")
							 | 
						|
								    paid_amount = fields.Float(string="Paid Amount", tracking=True,
							 | 
						|
								                               help="The amount paid for the membership")
							 | 
						|
								    membership_fees = fields.Float(string="Membership Fees", tracking=True,
							 | 
						|
								                                   help="The membership fees",
							 | 
						|
								                                   related="membership_scheme_id.list_price")
							 | 
						|
								    sale_order_id = fields.Many2one('sale.order', string='Sales Order',
							 | 
						|
								                                    ondelete='cascade', copy=False,
							 | 
						|
								                                    help="Order reference",
							 | 
						|
								                                    readonly=True)
							 | 
						|
								    membership_date_from = fields.Date(string='Membership Start Date',
							 | 
						|
								                                       related="membership_scheme_id."
							 | 
						|
								                                               "membership_date_from",
							 | 
						|
								                                       help='Date from which membership '
							 | 
						|
								                                            'becomes active.')
							 | 
						|
								    membership_date_to = fields.Date(string='Membership End Date',
							 | 
						|
								                                     related="membership_scheme_id.membership_"
							 | 
						|
								                                             "date_to",
							 | 
						|
								                                     help='Date until which membership remains'
							 | 
						|
								                                          'active.')
							 | 
						|
								    company_id = fields.Many2one('res.company', string='Company',
							 | 
						|
								                                 default=lambda self: self.env.company,
							 | 
						|
								                                 help='The field hold the company id')
							 | 
						|
								    state = fields.Selection([
							 | 
						|
								        ('draft', 'Draft'),
							 | 
						|
								        ('confirm', 'Confirm'),
							 | 
						|
								        ('cancelled', 'Cancelled')
							 | 
						|
								    ], default='draft', string='Status',
							 | 
						|
								        help="The status of record defined here")
							 | 
						|
								
							 | 
						|
								    _sql_constraints = [
							 | 
						|
								        ('membership_date_greater',
							 | 
						|
								         'check(membership_date_to >= membership_date_from)',
							 | 
						|
								         'Error ! Ending Date cannot be set before Beginning Date.')
							 | 
						|
								    ]
							 | 
						|
								
							 | 
						|
								    @api.model
							 | 
						|
								    def create_multi(self, vals):
							 | 
						|
								        """Sequence number for membership """
							 | 
						|
								        if vals.get('reference', 'New') == 'New':
							 | 
						|
								            vals['reference'] = self.env['ir.sequence'].next_by_code(
							 | 
						|
								                'gym.membership') or 'New'
							 | 
						|
								        res = super(GymMembership, self).create(vals)
							 | 
						|
								        return res
							 | 
						|
								
							 |