From 00b205e9eb417879c014a921548b8555e0e090d1 Mon Sep 17 00:00:00 2001 From: bart-maykin Date: Wed, 11 Oct 2023 09:16:50 +0200 Subject: [PATCH] :card_file_box: [#62] changed models file into folder and added klantcontacten --- .../components/klantinteracties/admin.py | 3 - .../migrations/0002_klantcontact.py | 124 ++++++++++++++++++ .../klantinteracties/models/__init__.py | 2 + .../{ => models}/constants.py | 0 .../klantinteracties/models/klantcontacten.py | 111 ++++++++++++++++ .../{models.py => models/partijen.py} | 0 .../components/klantinteracties/tests.py | 3 - .../components/klantinteracties/views.py | 3 - 8 files changed, 237 insertions(+), 9 deletions(-) delete mode 100644 src/openklant/components/klantinteracties/admin.py create mode 100644 src/openklant/components/klantinteracties/migrations/0002_klantcontact.py create mode 100644 src/openklant/components/klantinteracties/models/__init__.py rename src/openklant/components/klantinteracties/{ => models}/constants.py (100%) create mode 100644 src/openklant/components/klantinteracties/models/klantcontacten.py rename src/openklant/components/klantinteracties/{models.py => models/partijen.py} (100%) delete mode 100644 src/openklant/components/klantinteracties/tests.py delete mode 100644 src/openklant/components/klantinteracties/views.py diff --git a/src/openklant/components/klantinteracties/admin.py b/src/openklant/components/klantinteracties/admin.py deleted file mode 100644 index 8c38f3f3..00000000 --- a/src/openklant/components/klantinteracties/admin.py +++ /dev/null @@ -1,3 +0,0 @@ -from django.contrib import admin - -# Register your models here. diff --git a/src/openklant/components/klantinteracties/migrations/0002_klantcontact.py b/src/openklant/components/klantinteracties/migrations/0002_klantcontact.py new file mode 100644 index 00000000..0dff772e --- /dev/null +++ b/src/openklant/components/klantinteracties/migrations/0002_klantcontact.py @@ -0,0 +1,124 @@ +# Generated by Django 3.2.18 on 2023-10-10 17:54 + +import django.core.validators +from django.db import migrations, models +import django.db.models.deletion +import uuid + + +class Migration(migrations.Migration): + dependencies = [ + ("klantinteracties", "0001_initial"), + ] + + operations = [ + migrations.CreateModel( + name="Klantcontact", + fields=[ + ( + "id", + models.UUIDField( + default=uuid.uuid4, + help_text="Unieke (technische) identificatiecode van de betrokkene bij klantcontact.", + primary_key=True, + serialize=False, + unique=True, + ), + ), + ( + "nummer", + models.PositiveIntegerField( + help_text="Uniek identificerend nummer dat tijdens communicatie tussen mensen kan worden gebruikt om de specifieke partij aan te duiden.", + validators=[ + django.core.validators.MaxValueValidator(9999999999) + ], + verbose_name="Nummer", + ), + ), + ( + "kanaal", + models.CharField( + help_text="Communicatiekanaal dat bij het klantcontact werd gebruikt.", + max_length=50, + verbose_name="Kanaal", + ), + ), + ( + "onderwerp", + models.CharField( + help_text="Datgene waarover het klantcontact ging.", + max_length=200, + verbose_name="Onderwerp", + ), + ), + ( + "inhoud", + models.CharField( + blank=True, + help_text="Informatie die tijdens het klantcontact werd overgebracht of uitgewisseld, voor zover die voor betrokkenen of actoren relevant is.", + max_length=1000, + verbose_name="Inhoud", + ), + ), + ( + "initiator", + models.CharField( + choices=[ + ("gemeente", "Gemeente"), + ("klant", "Klant"), + ("vertegenwoordiger", "Vertegenwoordiger"), + ], + help_text="Degene die het klantcontact initieerde.", + max_length=17, + verbose_name="Initiator", + ), + ), + ( + "indicatie_contact_gelukt", + models.BooleanField( + help_text="Geeft, indien bekend, aan of de poging contact tussen de gemeente en inwoner(s) of organisatie(s) tot stand te brengen succesvol was.", + null=True, + verbose_name="Indicatie contact gelukt", + ), + ), + ( + "taal", + models.CharField( + help_text="Taal die bij het klantcontact werd gesproken of geschreven.", + max_length=255, + verbose_name="Taal", + ), + ), + ( + "vertrouwelijk", + models.BooleanField( + help_text="Geeft aan of onderwerp, inhoud en kenmerken van het klantcontact vertrouwelijk moeten worden behandeld.", + verbose_name="Vertrouwelijk", + ), + ), + ( + "plaatsgevonden_op", + models.DateTimeField( + help_text="Datum en tijdstip waarop het klantontact plaatsvond. Als het klantcontact een gesprek betrof, is dit het moment waarop het gesprek begon. Als het klantcontact verzending of ontvangst van informatie betrof, is dit bij benadering het moment waarop informatie door gemeente verzonden of ontvangen werd.", + verbose_name="Plaatsgevonden op", + ), + ), + ( + "klantcontact", + models.ForeignKey( + blank=True, + help_text="De persoon of organisatie die betrokken was bij een klantcontact.", + null=True, + on_delete=django.db.models.deletion.SET_NULL, + related_name="klantcontacten", + to="klantinteracties.klantcontact", + verbose_name="Klant contact", + ), + ), + ], + options={ + "verbose_name": "klantcontact", + "verbose_name_plural": "klantcontacten", + }, + ), + ] diff --git a/src/openklant/components/klantinteracties/models/__init__.py b/src/openklant/components/klantinteracties/models/__init__.py new file mode 100644 index 00000000..e87e3b09 --- /dev/null +++ b/src/openklant/components/klantinteracties/models/__init__.py @@ -0,0 +1,2 @@ +from .klantcontacten import * # noqa +from .partijen import * # noqa diff --git a/src/openklant/components/klantinteracties/constants.py b/src/openklant/components/klantinteracties/models/constants.py similarity index 100% rename from src/openklant/components/klantinteracties/constants.py rename to src/openklant/components/klantinteracties/models/constants.py diff --git a/src/openklant/components/klantinteracties/models/klantcontacten.py b/src/openklant/components/klantinteracties/models/klantcontacten.py new file mode 100644 index 00000000..80bae6d1 --- /dev/null +++ b/src/openklant/components/klantinteracties/models/klantcontacten.py @@ -0,0 +1,111 @@ +import uuid + +from django.core.validators import MaxValueValidator +from django.db import models +from django.utils.translation import gettext_lazy as _ + +from .constants import Initiator + + +class Klantcontact(models.Model): + id = models.UUIDField( + primary_key=True, + unique=True, + default=uuid.uuid4, + max_length=40, + help_text=_( + "Unieke (technische) identificatiecode van de betrokkene bij klantcontact." + ), + ) + klantcontact = models.ForeignKey( + "self", + on_delete=models.SET_NULL, + related_name="klantcontacten", + verbose_name=_("Klant contact"), + help_text=_( + "De persoon of organisatie die betrokken was bij een klantcontact." + ), + blank=True, + null=True, + ) + # TODO: add fk to Actor + # TODO: add fk to Onderwerpobject + # TODO: add fk to Inhoudsobject + nummer = models.PositiveIntegerField( + _("Nummer"), + help_text=_( + "Uniek identificerend nummer dat tijdens communicatie tussen mensen kan " + "worden gebruikt om de specifieke partij aan te duiden." + ), + validators=[MaxValueValidator(9999999999)], + blank=False, + ) + kanaal = models.CharField( + _("Kanaal"), + help_text=_("Communicatiekanaal dat bij het klantcontact werd gebruikt."), + max_length=50, + blank=False, + ) + onderwerp = models.CharField( + _("Onderwerp"), + help_text=_("Datgene waarover het klantcontact ging."), + max_length=200, + blank=False, + ) + inhoud = models.CharField( + _("Inhoud"), + help_text=_( + "Informatie die tijdens het klantcontact werd overgebracht of uitgewisseld, " + "voor zover die voor betrokkenen of actoren relevant is." + ), + max_length=1000, + blank=True, + ) + initiator = models.CharField( + _("Initiator"), + help_text=_("Degene die het klantcontact initieerde."), + choices=Initiator.choices, + max_length=17, + blank=False, + ) + indicatie_contact_gelukt = models.BooleanField( + _("Indicatie contact gelukt"), + help_text=( + "Geeft, indien bekend, aan of de poging contact tussen de gemeente " + "en inwoner(s) of organisatie(s) tot stand te brengen succesvol was." + ), + blank=False, + null=True, + ) + # TODO: change max_length to more realistic number + taal = models.CharField( + _("Taal"), + help_text=_("Taal die bij het klantcontact werd gesproken of geschreven."), + max_length=255, + blank=False, + ) + vertrouwelijk = models.BooleanField( + _("Vertrouwelijk"), + help_text=_( + "Geeft aan of onderwerp, inhoud en kenmerken van het klantcontact vertrouwelijk moeten worden behandeld." + ), + blank=False, + ) + # TODO: does this field require auto_now? + plaatsgevonden_op = models.DateTimeField( + _("Plaatsgevonden op"), + help_text=_( + "Datum en tijdstip waarop het klantontact plaatsvond. Als het klantcontact " + "een gesprek betrof, is dit het moment waarop het gesprek begon. " + "Als het klantcontact verzending of ontvangst van informatie betrof, " + "is dit bij benadering het moment waarop informatie door gemeente verzonden of ontvangen werd." + ), + blank=False, + ) + + class Meta: + verbose_name = "klantcontact" + verbose_name_plural = "klantcontacten" + + def __str__(self) -> str: + return self.nummer diff --git a/src/openklant/components/klantinteracties/models.py b/src/openklant/components/klantinteracties/models/partijen.py similarity index 100% rename from src/openklant/components/klantinteracties/models.py rename to src/openklant/components/klantinteracties/models/partijen.py diff --git a/src/openklant/components/klantinteracties/tests.py b/src/openklant/components/klantinteracties/tests.py deleted file mode 100644 index 7ce503c2..00000000 --- a/src/openklant/components/klantinteracties/tests.py +++ /dev/null @@ -1,3 +0,0 @@ -from django.test import TestCase - -# Create your tests here. diff --git a/src/openklant/components/klantinteracties/views.py b/src/openklant/components/klantinteracties/views.py deleted file mode 100644 index 91ea44a2..00000000 --- a/src/openklant/components/klantinteracties/views.py +++ /dev/null @@ -1,3 +0,0 @@ -from django.shortcuts import render - -# Create your views here.