Illustrations/web/core/models.py
2025-08-12 20:50:46 -05:00

33 lines
1.5 KiB
Python

from django.db import models
class Entry(models.Model):
# Field names aligned to CSV headers (case-insensitive mapping in importer)
subject = models.TextField(blank=True)
illustration = models.TextField(blank=True)
application = models.TextField(blank=True)
scripture_raw = models.TextField(blank=True) # from CSV 'Scripture'
source = models.CharField(max_length=255, blank=True)
talk_title = models.CharField(max_length=255, blank=True) # 'Talk Title'
talk_number = models.IntegerField(null=True, blank=True) # 'Talk Number'
entry_code = models.CharField(max_length=64, blank=True, db_index=True) # 'Code'
date_added = models.DateField(null=True, blank=True) # 'Date'
date_edited = models.DateField(null=True, blank=True) # 'Date Edited'
created_at = models.DateTimeField(auto_now_add=True)
updated_at = models.DateTimeField(auto_now=True)
def __str__(self):
return f"{self.talk_title or '(untitled)'} [{self.entry_code}]"
class ScriptureRef(models.Model):
entry = models.ForeignKey(Entry, on_delete=models.CASCADE, related_name="scripture_refs")
book = models.CharField(max_length=32)
chapter_from = models.IntegerField(null=True, blank=True)
verse_from = models.IntegerField(null=True, blank=True)
chapter_to = models.IntegerField(null=True, blank=True)
verse_to = models.IntegerField(null=True, blank=True)
def __str__(self):
return f"{self.book} {self.chapter_from}:{self.verse_from}"