diff --git a/billing/admin.py b/billing/admin.py index 19fd08d..8241083 100644 --- a/billing/admin.py +++ b/billing/admin.py @@ -25,6 +25,7 @@ class TopupAdmin(admin.ModelAdmin): "amount", "paid", "paid_at", + "status", "created_at", "is_expired", "expires_at", diff --git a/billing/migrations/0011_topup_status.py b/billing/migrations/0011_topup_status.py new file mode 100644 index 0000000..8c7a1f3 --- /dev/null +++ b/billing/migrations/0011_topup_status.py @@ -0,0 +1,25 @@ +# Generated by Django 5.2 on 2025-07-05 12:32 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + dependencies = [ + ("billing", "0010_add_expiry_notification_sent_to_topup"), + ] + + operations = [ + migrations.AddField( + model_name="topup", + name="status", + field=models.CharField( + choices=[ + ("PENDING", "Pending"), + ("PAID", "Paid"), + ("CANCELLED", "Cancelled"), + ], + default="PENDING", + max_length=20, + ), + ), + ] diff --git a/billing/models.py b/billing/models.py index e73cbe0..814365a 100644 --- a/billing/models.py +++ b/billing/models.py @@ -52,6 +52,15 @@ class Topup(models.Model): user = models.ForeignKey(User, on_delete=models.CASCADE, related_name="topups") paid = models.BooleanField(default=False) paid_at = models.DateTimeField(null=True, blank=True) + status = models.CharField( + max_length=20, + choices=[ + ("PENDING", "Pending"), + ("PAID", "Paid"), + ("CANCELLED", "Cancelled"), + ], + default="PENDING", + ) mib_reference = models.CharField(default="", null=True, blank=True) expires_at = models.DateTimeField(null=True, blank=True) expiry_notification_sent = models.BooleanField(default=False)