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.
157 lines
7.3 KiB
157 lines
7.3 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 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
|
|
from odoo.exceptions import ValidationError
|
|
|
|
|
|
class MovieMovie(models.Model):
|
|
"""
|
|
Model for managing movie details including name, duration,
|
|
release date, show type, language, poster, time slots, cast,
|
|
screens, price, overview, currency, and status.
|
|
"""
|
|
_name = 'movie.movie'
|
|
_description = 'Movie Movie'
|
|
|
|
name = fields.Char(string='Name', help='Name of the Movie')
|
|
duration = fields.Float(string='Duration of the movie',
|
|
help='Duration of the Movie')
|
|
release_date = fields.Date(string='Release Date',
|
|
help='Release date of the Movie')
|
|
show_type_ids = fields.Many2many('show.type',
|
|
string='Show Type',
|
|
help='Show type of the movie')
|
|
movie_language_id = fields.Many2one('res.lang',
|
|
string='Movie Language',
|
|
help='Language of the movie')
|
|
movie_poster = fields.Binary(string='Movie Poster', help='Poster of the Movie')
|
|
available_time_slots_ids = fields.Many2many('time.slots',
|
|
string='Time Slots',
|
|
help='Time slots of the movie')
|
|
movie_cast_ids = fields.Many2many('movie.cast',
|
|
string='Movie Cast',
|
|
help='Mention the movie casts')
|
|
available_screens_ids = fields.Many2many('movie.screen',
|
|
string='Screens',
|
|
help='Mention the screens')
|
|
show_start_date = fields.Date(string='Show Start Date',
|
|
help='Mention the show start date')
|
|
show_end_date = fields.Date(string='Show End Date',
|
|
help='Mention the show end date')
|
|
price = fields.Monetary(currency_field='currency_id', string='Price',
|
|
help='Mention the ticket price')
|
|
about_movie = fields.Text(string='About Movie', help='Overview of the movie.')
|
|
currency_id = fields.Many2one('res.currency',
|
|
string='Currency',
|
|
help="Currency",
|
|
required=True,
|
|
default=lambda
|
|
self: self.env.user.company_id.currency_id)
|
|
state = fields.Selection([('draft', 'Draft'),
|
|
('ongoing', 'Ongoing'),
|
|
('cancel', 'Cancelled')],
|
|
string='Status', default='draft',
|
|
help='')
|
|
|
|
@api.constrains('show_start_date', 'show_end_date', 'release_date')
|
|
def _check_show_start_date(self):
|
|
""" Function for validating show start date and end date """
|
|
for record in self:
|
|
if (record.show_start_date and record.release_date and
|
|
record.show_start_date < record.release_date):
|
|
raise ValidationError(
|
|
'Show Start date must be on or after the Release Date')
|
|
if (record.show_end_date and record.show_end_date and
|
|
record.show_start_date > record.show_end_date):
|
|
raise ValidationError(
|
|
'Show End date must be on or after the Show Start date')
|
|
|
|
@api.constrains('available_screens_ids', 'show_start_date', 'show_end_date')
|
|
def _check_screen_availability(self):
|
|
""" Function for checking the screen availability if the
|
|
screen is already booked for another movie it raises error"""
|
|
for record in self:
|
|
if record.show_start_date and record.show_end_date:
|
|
overlapping_movies = self.env['movie.movie'].search([
|
|
('id', '!=', record.id),
|
|
('available_screens_ids', 'in',
|
|
record.available_screens_ids.ids),
|
|
('show_start_date', '<=', record.show_end_date),
|
|
('show_end_date', '>=', record.show_start_date),
|
|
])
|
|
if overlapping_movies:
|
|
raise ValidationError(
|
|
'One or more of the selected screens are already booked '
|
|
'for another movie during this period.')
|
|
|
|
@api.model
|
|
def create(self, vals):
|
|
"""Supering create function to check screen availability"""
|
|
res = super(MovieMovie, self).create(vals)
|
|
res._check_screen_availability()
|
|
return res
|
|
|
|
@api.model
|
|
def write(self, vals):
|
|
"""Supering create function to check screen availability"""
|
|
res = super(MovieMovie, self).write(vals)
|
|
self._check_screen_availability()
|
|
return res
|
|
|
|
@api.model
|
|
def check_shows_on_date(self, date, selected_movie):
|
|
""" Function for searching the movies based on the date from js."""
|
|
movie = self.search([('id', '=', selected_movie),
|
|
('show_start_date', '<=', date),
|
|
('show_end_date', '>=', date)])
|
|
return bool(movie)
|
|
|
|
def action_start_show(self):
|
|
""" Function for changing the state into ongoing."""
|
|
for rec in self:
|
|
if fields.Date.today() >= rec.show_start_date:
|
|
self.write({'state': 'ongoing'})
|
|
else:
|
|
raise ValidationError(
|
|
'Show Starts only based on the Show Start Date')
|
|
|
|
def action_cancel_show(self):
|
|
""" Function for changing the state into cancel."""
|
|
self.write({'state': 'cancel'})
|
|
|
|
@api.model
|
|
def update_seats(self, screen_id, time_slot_id, booking_date):
|
|
"""
|
|
Update the seats availability based on the screen, time slot, and booking date.
|
|
"""
|
|
booked_seats = self.env['movie.seats'].search([
|
|
('screen_id', '=', int(screen_id)),
|
|
('time_slot_id', '=', int(time_slot_id)),
|
|
('date', '=', booking_date),
|
|
('is_booked', '=', True)
|
|
]).mapped('seat')
|
|
time_slot = self.env['time.slots'].browse(int(time_slot_id)).name
|
|
screen = self.env['movie.screen'].browse(int(screen_id))
|
|
return {'booked_seats': booked_seats,
|
|
'time_slot': time_slot,
|
|
'booked_seats_count': len(booked_seats),
|
|
'available_seats_count': screen.total_seat_count - len(booked_seats)}
|
|
|