aboutsummaryrefslogtreecommitdiffstats
path: root/ctrack/register/models.py
diff options
context:
space:
mode:
authorMatthew Lemon <lemon@matthewlemon.com>2020-10-11 15:47:21 +0100
committerMatthew Lemon <lemon@matthewlemon.com>2020-10-11 15:47:21 +0100
commitf69d29b53b6273d1b1d72cbcce4195e42788d556 (patch)
treeb011549b86cf9993c7efc05947f78825f97a3aa9 /ctrack/register/models.py
parentabd1b4926bc3aa1d0daba5bc5594a385898dd753 (diff)
constraint added to CAFSingleDateEvent
Diffstat (limited to 'ctrack/register/models.py')
-rw-r--r--ctrack/register/models.py58
1 files changed, 43 insertions, 15 deletions
diff --git a/ctrack/register/models.py b/ctrack/register/models.py
index 12247e8..06c0959 100644
--- a/ctrack/register/models.py
+++ b/ctrack/register/models.py
@@ -71,8 +71,12 @@ class EventBase(AuditableEventBase):
null=True,
help_text="URL only - do not try to drag a file here.",
)
- comments = models.TextField(max_length=1000, blank=True, null=True,
- help_text="Use this to provide further detail about the event.")
+ comments = models.TextField(
+ max_length=1000,
+ blank=True,
+ null=True,
+ help_text="Use this to provide further detail about the event.",
+ )
class Meta:
abstract = True
@@ -107,7 +111,7 @@ class CAFMixin(models.Model):
class SingleDateTimeEvent(EventBase, ThirdPartyEventMixin, SingleDateTimeEventMixin):
AVAILABLE_TYPES = [
(EventType.PHONE_CALL.name, "Phone Call"),
- (EventType.VIDEO_CALL.name, "Video Call")
+ (EventType.VIDEO_CALL.name, "Video Call"),
]
type_descriptor = models.CharField(max_length=50, choices=AVAILABLE_TYPES)
@@ -116,9 +120,7 @@ class SingleDateTimeEvent(EventBase, ThirdPartyEventMixin, SingleDateTimeEventMi
class MeetingEvent(EventBase, ThirdPartyEventMixin, SingleDateTimeEventMixin):
- AVAILABLE_TYPES = [
- (EventType.MEETING.name, "Meeting")
- ]
+ AVAILABLE_TYPES = [(EventType.MEETING.name, "Meeting")]
type_descriptor = models.CharField(max_length=50, choices=AVAILABLE_TYPES)
@@ -128,9 +130,17 @@ class CAFSingleDateEvent(EventBase, CAFMixin, SingleDateMixin):
]
type_descriptor = models.CharField(max_length=50, choices=AVAILABLE_TYPES)
+ class Meta:
+ constraints = [
+ models.UniqueConstraint(
+ fields=["date", "type_descriptor"], name="unique_caf_for_date"
+ )
+ ]
+
# OLD CODE BELOW
+
class EngagementType(models.Model):
"""
Examples here are Phone, Email, Letter, Site visit, Meeting, Audit, Inspection, etc.
@@ -162,28 +172,46 @@ class EngagementEvent(models.Model):
type = models.ForeignKey(EngagementType, on_delete=models.CASCADE)
short_description = models.CharField(
- max_length=50, help_text="Short description of the event. Use Comments field for full detail."
+ max_length=50,
+ help_text="Short description of the event. Use Comments field for full detail.",
)
participants = models.ManyToManyField(Person, blank=True)
user = models.ForeignKey(get_user_model(), on_delete=models.SET(get_sentinel_user))
date = models.DateTimeField()
- end_date = models.DateTimeField(blank=True, null=True, help_text="Should be used for periodic events.")
- document_link = models.URLField(max_length=1000, blank=True, null=True,
- help_text="URL only - do not try to drag a file here.")
+ end_date = models.DateTimeField(
+ blank=True, null=True, help_text="Should be used for periodic events."
+ )
+ document_link = models.URLField(
+ max_length=1000,
+ blank=True,
+ null=True,
+ help_text="URL only - do not try to drag a file here.",
+ )
response_date_requested = models.DateField(blank=True, null=True)
response_received = models.DateField(blank=True, null=True)
related_caf = models.ForeignKey(
- "caf.CAF", blank=True, on_delete=models.CASCADE, null=True,
- help_text="If the event relates to a CAF, refer to it here."
+ "caf.CAF",
+ blank=True,
+ on_delete=models.CASCADE,
+ null=True,
+ help_text="If the event relates to a CAF, refer to it here.",
+ )
+ comments = models.TextField(
+ max_length=1000,
+ blank=True,
+ null=True,
+ help_text="Use this to provide further detail about the event.",
)
- comments = models.TextField(max_length=1000, blank=True, null=True,
- help_text="Use this to provide further detail about the event.")
def days_to_response_due(self) -> Optional[Dict[int, str]]:
if self.response_date_requested:
today = std_date.today()
diff = self.response_date_requested - today
- return dict(days=diff.days, descriptor=_style_descriptor(diff.days), day_str=_day_string(diff.days))
+ return dict(
+ days=diff.days,
+ descriptor=_style_descriptor(diff.days),
+ day_str=_day_string(diff.days),
+ )
else:
return None