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
 | |
| 
 |