38614-vm/core/models.py
2026-02-19 19:34:34 +00:00

53 lines
1.9 KiB
Python

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