* refactors identifier generator view methods into classes * introduces IdentifierGenerator * introduces AbstractIdentifierGeneratorView
205 lines
7.1 KiB
Python
205 lines
7.1 KiB
Python
"""
|
|
Author: Michel Peltriaux
|
|
Organization: Struktur- und Genehmigungsdirektion Nord, Rhineland-Palatinate, Germany
|
|
Contact: ksp-servicestelle@sgdnord.rlp.de
|
|
Created on: 19.08.22
|
|
|
|
"""
|
|
from django.contrib import messages
|
|
from django.contrib.auth.decorators import login_required
|
|
from django.http import HttpRequest, HttpResponse
|
|
from django.shortcuts import get_object_or_404, render, redirect
|
|
from django.urls import reverse
|
|
from django.utils.translation import gettext_lazy as _
|
|
|
|
from intervention.forms.intervention import EditInterventionForm, NewInterventionForm
|
|
from intervention.models import Intervention
|
|
from intervention.tables import InterventionTable
|
|
from konova.contexts import BaseContext
|
|
from konova.decorators import default_group_required, shared_access_required, login_required_modal
|
|
from konova.forms import SimpleGeomForm
|
|
from konova.forms.modals import RemoveModalForm
|
|
from konova.sub_settings.context_settings import TAB_TITLE_IDENTIFIER
|
|
from konova.utils.message_templates import RECORDED_BLOCKS_EDIT, \
|
|
CHECK_STATE_RESET, FORM_INVALID, IDENTIFIER_REPLACED, GEOMETRY_SIMPLIFIED, \
|
|
GEOMETRIES_IGNORED_TEMPLATE
|
|
from konova.views.identifier import AbstractIdentifierGeneratorView
|
|
from konova.views.index import AbstractIndexView
|
|
|
|
|
|
class IndexInterventionView(AbstractIndexView):
|
|
def get(self, request: HttpRequest, *args, **kwargs) -> HttpResponse:
|
|
"""
|
|
Renders the index view for Interventions
|
|
|
|
Args:
|
|
request (HttpRequest): The incoming request
|
|
|
|
Returns:
|
|
A rendered view
|
|
"""
|
|
# Filtering by user access is performed in table filter inside InterventionTableFilter class
|
|
interventions = Intervention.objects.filter(
|
|
deleted=None, # not deleted
|
|
).select_related(
|
|
"legal"
|
|
).order_by(
|
|
"-modified__timestamp"
|
|
)
|
|
table = InterventionTable(
|
|
request=request,
|
|
queryset=interventions
|
|
)
|
|
context = {
|
|
"table": table,
|
|
TAB_TITLE_IDENTIFIER: _("Interventions - Overview"),
|
|
}
|
|
context = BaseContext(request, context).context
|
|
return render(request, self._TEMPLATE, context)
|
|
|
|
|
|
@login_required
|
|
@default_group_required
|
|
def new_view(request: HttpRequest):
|
|
"""
|
|
Renders a view for a new intervention creation
|
|
|
|
Args:
|
|
request (HttpRequest): The incoming request
|
|
|
|
Returns:
|
|
|
|
"""
|
|
template = "intervention/form/view.html"
|
|
data_form = NewInterventionForm(request.POST or None)
|
|
geom_form = SimpleGeomForm(request.POST or None, read_only=False)
|
|
if request.method == "POST":
|
|
if data_form.is_valid() and geom_form.is_valid():
|
|
generated_identifier = data_form.cleaned_data.get("identifier", None)
|
|
intervention = data_form.save(request.user, geom_form)
|
|
if generated_identifier != intervention.identifier:
|
|
messages.info(
|
|
request,
|
|
IDENTIFIER_REPLACED.format(
|
|
generated_identifier,
|
|
intervention.identifier
|
|
)
|
|
)
|
|
messages.success(request, _("Intervention {} added").format(intervention.identifier))
|
|
if geom_form.has_geometry_simplified():
|
|
messages.info(
|
|
request,
|
|
GEOMETRY_SIMPLIFIED
|
|
)
|
|
|
|
num_ignored_geometries = geom_form.get_num_geometries_ignored()
|
|
if num_ignored_geometries > 0:
|
|
messages.info(
|
|
request,
|
|
GEOMETRIES_IGNORED_TEMPLATE.format(num_ignored_geometries)
|
|
)
|
|
|
|
return redirect("intervention:detail", id=intervention.id)
|
|
else:
|
|
messages.error(request, FORM_INVALID, extra_tags="danger",)
|
|
else:
|
|
# For clarification: nothing in this case
|
|
pass
|
|
context = {
|
|
"form": data_form,
|
|
"geom_form": geom_form,
|
|
TAB_TITLE_IDENTIFIER: _("New intervention"),
|
|
}
|
|
context = BaseContext(request, context).context
|
|
return render(request, template, context)
|
|
|
|
class InterventionIdentifierGeneratorView(AbstractIdentifierGeneratorView):
|
|
_MODEL = Intervention
|
|
|
|
|
|
@login_required
|
|
@default_group_required
|
|
@shared_access_required(Intervention, "id")
|
|
def edit_view(request: HttpRequest, id: str):
|
|
"""
|
|
Renders a view for editing interventions
|
|
|
|
Args:
|
|
request (HttpRequest): The incoming request
|
|
|
|
Returns:
|
|
|
|
"""
|
|
template = "intervention/form/view.html"
|
|
# Get object from db
|
|
intervention = get_object_or_404(Intervention, id=id)
|
|
if intervention.is_recorded:
|
|
messages.info(
|
|
request,
|
|
RECORDED_BLOCKS_EDIT
|
|
)
|
|
return redirect("intervention:detail", id=id)
|
|
|
|
# Create forms, initialize with values from db/from POST request
|
|
data_form = EditInterventionForm(request.POST or None, instance=intervention)
|
|
geom_form = SimpleGeomForm(request.POST or None, read_only=False, instance=intervention)
|
|
if request.method == "POST":
|
|
if data_form.is_valid() and geom_form.is_valid():
|
|
# The data form takes the geom form for processing, as well as the performing user
|
|
# Save the current state of recorded|checked to inform the user in case of a status reset due to editing
|
|
intervention_is_checked = intervention.checked is not None
|
|
intervention = data_form.save(request.user, geom_form)
|
|
messages.success(request, _("Intervention {} edited").format(intervention.identifier))
|
|
if intervention_is_checked:
|
|
messages.info(request, CHECK_STATE_RESET)
|
|
if geom_form.has_geometry_simplified():
|
|
messages.info(
|
|
request,
|
|
GEOMETRY_SIMPLIFIED
|
|
)
|
|
|
|
num_ignored_geometries = geom_form.get_num_geometries_ignored()
|
|
if num_ignored_geometries > 0:
|
|
messages.info(
|
|
request,
|
|
GEOMETRIES_IGNORED_TEMPLATE.format(num_ignored_geometries)
|
|
)
|
|
|
|
return redirect("intervention:detail", id=intervention.id)
|
|
else:
|
|
messages.error(request, FORM_INVALID, extra_tags="danger",)
|
|
else:
|
|
# For clarification: nothing in this case
|
|
pass
|
|
context = {
|
|
"form": data_form,
|
|
"geom_form": geom_form,
|
|
TAB_TITLE_IDENTIFIER: _("Edit {}").format(intervention.identifier),
|
|
}
|
|
context = BaseContext(request, context).context
|
|
return render(request, template, context)
|
|
|
|
|
|
@login_required_modal
|
|
@login_required
|
|
@default_group_required
|
|
@shared_access_required(Intervention, "id")
|
|
def remove_view(request: HttpRequest, id: str):
|
|
""" Renders a remove view for this intervention
|
|
|
|
Args:
|
|
request (HttpRequest): The incoming request
|
|
id (str): The uuid id as string
|
|
|
|
Returns:
|
|
|
|
"""
|
|
obj = Intervention.objects.get(id=id)
|
|
identifier = obj.identifier
|
|
form = RemoveModalForm(request.POST or None, instance=obj, request=request)
|
|
return form.process_request(
|
|
request,
|
|
_("{} removed").format(identifier),
|
|
redirect_url=reverse("intervention:index")
|
|
)
|