delete view added and some refactorig

This commit is contained in:
Thomas Nahuel Rusiecki 2024-12-02 16:55:59 -03:00
parent 4d8f9eac9b
commit 8dc5bf1435
2 changed files with 35 additions and 20 deletions

View file

@ -12,4 +12,5 @@ urlpatterns = [
path("institution/<int:pk>", views.InstitutionView.as_view(), name="institution"), path("institution/<int:pk>", views.InstitutionView.as_view(), name="institution"),
path("states/", views.StatesPanelView.as_view(), name="states"), path("states/", views.StatesPanelView.as_view(), name="states"),
path("states/add", views.AddStateDefinitionView.as_view(), name="add_state_definition"), path("states/add", views.AddStateDefinitionView.as_view(), name="add_state_definition"),
path('states/delete/<int:pk>', views.DeleteStateDefinitionView.as_view(), name='delete_state_definition'),
] ]

View file

@ -3,7 +3,8 @@ from django.contrib import messages
from django.urls import reverse_lazy from django.urls import reverse_lazy
from django.shortcuts import get_object_or_404 from django.shortcuts import get_object_or_404
from django.utils.translation import gettext_lazy as _ from django.utils.translation import gettext_lazy as _
from django.views.generic.base import TemplateView from django.contrib.messages.views import SuccessMessageMixin
from django.views.generic.base import TemplateView, ContextMixin
from django.views.generic.edit import ( from django.views.generic.edit import (
CreateView, CreateView,
UpdateView, UpdateView,
@ -14,8 +15,7 @@ from django.db import IntegrityError
from dashboard.mixins import DashboardView, Http403 from dashboard.mixins import DashboardView, Http403
from user.models import User, Institution from user.models import User, Institution
from admin.email import NotifyActivateUserByEmail from admin.email import NotifyActivateUserByEmail
from action.models import State, StateDefinition from action.models import StateDefinition
class AdminView(DashboardView): class AdminView(DashboardView):
def get(self, *args, **kwargs): def get(self, *args, **kwargs):
@ -129,20 +129,21 @@ class InstitutionView(AdminView, UpdateView):
kwargs = super().get_form_kwargs() kwargs = super().get_form_kwargs()
return kwargs return kwargs
class StatesPanelView(AdminView, TemplateView):
class StateDefinitionContextMixin(ContextMixin):
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
context.update({
"state_definitions": StateDefinition.objects.filter(institution=self.request.user.institution).order_by('order'),
})
return context
class StatesPanelView(AdminView, StateDefinitionContextMixin, TemplateView):
template_name = "states_panel.html" template_name = "states_panel.html"
title = _("States") title = _("States")
breadcrumb = _("admin / States") + " /" breadcrumb = _("admin / States") + " /"
def get_context_data(self, **kwargs): class AddStateDefinitionView(AdminView, StateDefinitionContextMixin, CreateView):
context = super().get_context_data(**kwargs)
context.update({
"state_definitions" : StateDefinition.objects.filter(institution=self.request.user.institution).order_by('order')
})
return context
class AddStateDefinitionView(DashboardView, CreateView):
template_name = "states_panel.html" template_name = "states_panel.html"
title = _("New State Definition") title = _("New State Definition")
breadcrumb = "Admin / New state" breadcrumb = "Admin / New state"
@ -158,12 +159,25 @@ class AddStateDefinitionView(DashboardView, CreateView):
messages.success(self.request, _("State definition successfully added.")) messages.success(self.request, _("State definition successfully added."))
return response return response
except IntegrityError: except IntegrityError:
messages.error(self.request, _("State is already defined.")) messages.error(self.request, _("State is already defined."))
return self.form_invalid(form) return self.form_invalid(form)
def get_context_data(self, **kwargs): def form_invalid(self, form):
context = super().get_context_data(**kwargs) return super().form_invalid(form)
context.update({
"state_definitions": StateDefinition.objects.filter(institution=self.request.user.institution).order_by('order'),
}) class DeleteStateDefinitionView(AdminView, StateDefinitionContextMixin, SuccessMessageMixin, DeleteView):
return context model = StateDefinition
success_url = reverse_lazy('admin:states')
def get_success_message(self, cleaned_data):
return f'State definition: {self.object.state}, has been deleted'
def delete(self, request, *args, **kwargs):
self.object = self.get_object()
#only an admin of current institution can delete
if not object.institution == self.request.user.institution:
raise Http404
return super().delete(request, *args, **kwargs)