from django.db import models from django.utils.text import slugify class Category(models.Model): name = models.CharField(max_length=100) slug = models.SlugField(unique=True, blank=True) image = models.ImageField(upload_to='categories/', blank=True, null=True) def save(self, *args, **kwargs): if not self.slug: self.slug = slugify(self.name) super().save(*args, **kwargs) def __str__(self): return self.name class Meta: verbose_name_plural = "Categories" class Book(models.Model): title = models.CharField(max_length=255) description = models.TextField() price = models.DecimalField(max_digits=10, decimal_places=2) pdf_file = models.FileField(upload_to='books/pdfs/') cover_image = models.ImageField(upload_to='books/covers/', blank=True, null=True) category = models.ForeignKey(Category, on_delete=models.CASCADE, related_name='books') is_featured = models.BooleanField(default=False) created_at = models.DateTimeField(auto_now_add=True) slug = models.SlugField(unique=True, blank=True) def save(self, *args, **kwargs): if not self.slug: self.slug = slugify(self.title) super().save(*args, **kwargs) def __str__(self): return self.title class Order(models.Model): STATUS_CHOICES = ( ('pending', 'Pending'), ('approved', 'Approved'), ('rejected', 'Rejected'), ) book = models.ForeignKey(Book, on_delete=models.CASCADE) user_email = models.EmailField() transaction_id = models.CharField(max_length=100, help_text="Enter your EVC/Zaad/Sahal transaction ID or reference") payment_screenshot = models.ImageField(upload_to='payments/', blank=True, null=True) status = models.CharField(max_length=20, choices=STATUS_CHOICES, default='pending') created_at = models.DateTimeField(auto_now_add=True) def __str__(self): return f"Order for {self.book.title} by {self.user_email}"