from django.db import models import uuid from events.models import Event from accounts.models import User # Create your models here. class TicketMeta(models.Model): event = models.ForeignKey(Event, on_delete=models.CASCADE) ticket_name = models.CharField(max_length=250) maximum_quantity = models.IntegerField() available_quantity = models.IntegerField(default=0) is_active = models.BooleanField(default=True) created_date = models.DateField(auto_now_add=True) updated_date = models.DateField(auto_now=True) def __str__(self): return self.ticket_name class TicketType(models.Model): ticket_meta = models.ForeignKey(TicketMeta, on_delete=models.CASCADE) ticket_type = models.CharField(max_length=250) ticket_type_description = models.TextField() ticket_type_quantity = models.IntegerField() price = models.DecimalField(max_digits=10, decimal_places=2) is_active = models.BooleanField(default=True) created_date = models.DateField(auto_now_add=True) updated_date = models.DateField(auto_now=True) is_offer = models.BooleanField(default=False) offer_percentage = models.IntegerField(default=0) offer_price = models.DecimalField(max_digits=10, decimal_places=2, default=0) offer_start_date = models.DateField(blank=True, null=True) offer_end_date = models.DateField(blank=True, null=True) def __str__(self): return self.ticket_type class Cart(models.Model): user = models.ForeignKey(User, on_delete=models.CASCADE) ticket_meta = models.ForeignKey(TicketMeta, on_delete=models.CASCADE) ticket_type = models.ForeignKey(TicketType, on_delete=models.CASCADE) quantity = models.IntegerField() price = models.DecimalField(max_digits=10, decimal_places=2) is_active = models.BooleanField(default=True) created_date = models.DateField(auto_now_add=True) updated_date = models.DateField(auto_now=True) def __str__(self): return self.user.username + " - " + self.ticket.event.name class Booking(models.Model): booking_id = models.CharField(max_length=250) user = models.ForeignKey(User, on_delete=models.CASCADE) ticket_meta = models.ForeignKey(TicketMeta, on_delete=models.CASCADE) ticket_type = models.ForeignKey(TicketType, on_delete=models.CASCADE) quantity = models.IntegerField() price = models.DecimalField(max_digits=10, decimal_places=2) created_date = models.DateField(auto_now_add=True, db_index=True) updated_date = models.DateField(auto_now=True) transaction_id = models.CharField(max_length=250, blank=True, null=True) def __save__(self): if not self.booking_id: self.booking_id = str(self.ticket.event.name[:3].upper()) + str(uuid.uuid4().hex[:10]).upper() super().save(*args, **kwargs) def __str__(self): return self.booking_id class Ticket(models.Model): booking = models.ForeignKey(Booking, on_delete=models.CASCADE) ticket_id = models.CharField(max_length=250) is_checked_in = models.BooleanField(default=False) checked_in_date_time = models.DateTimeField(blank=True, null=True) def __save__(self): if not self.ticket_id: self.ticket_id = str(self.booking.ticket_meta.event.name[:3].upper()) + str(uuid.uuid4().hex[:10]).upper() super().save(*args, **kwargs) def __str__(self): return self.ticket_id def check_in(self, ticket_id): if self.ticket_id == ticket_id: self.is_checked_in = True self.checked_in_date_time = datetime.now() self.save() return True return False