diff --git a/src/fellchensammlung/migrations/0038_rescueorganization_last_checked.py b/src/fellchensammlung/migrations/0038_rescueorganization_last_checked.py
new file mode 100644
index 0000000..299bc44
--- /dev/null
+++ b/src/fellchensammlung/migrations/0038_rescueorganization_last_checked.py
@@ -0,0 +1,20 @@
+# Generated by Django 5.1.4 on 2025-03-09 08:31
+
+import django.utils.timezone
+from django.db import migrations, models
+
+
+class Migration(migrations.Migration):
+
+ dependencies = [
+ ('fellchensammlung', '0037_alter_basenotification_title'),
+ ]
+
+ operations = [
+ migrations.AddField(
+ model_name='rescueorganization',
+ name='last_checked',
+ field=models.DateTimeField(default=django.utils.timezone.now, verbose_name='Datum der letzten Prüfung'),
+ preserve_default=False,
+ ),
+ ]
diff --git a/src/fellchensammlung/models.py b/src/fellchensammlung/models.py
index 55392d0..7c44057 100644
--- a/src/fellchensammlung/models.py
+++ b/src/fellchensammlung/models.py
@@ -122,6 +122,7 @@ class RescueOrganization(models.Model):
website = models.URLField(null=True, blank=True, verbose_name=_('Website'))
updated_at = models.DateTimeField(auto_now=True)
created_at = models.DateTimeField(auto_now_add=True)
+ last_checked = models.DateTimeField(verbose_name=_('Datum der letzten Prüfung'))
internal_comment = models.TextField(verbose_name=_("Interner Kommentar"), null=True, blank=True, )
description = models.TextField(null=True, blank=True, verbose_name=_('Beschreibung')) # Markdown allowed
external_object_identifier = models.CharField(max_length=200, null=True, blank=True,
@@ -151,6 +152,15 @@ class RescueOrganization(models.Model):
if len(self.description) > 200:
return self.description[:200] + _(f" ... [weiterlesen]({self.get_absolute_url()})")
+ def set_checked(self):
+ self.last_checked = timezone.now()
+ self.save()
+
+ @property
+ def last_checked_hr(self):
+ time_since_last_checked = timezone.now() - self.last_checked
+ return time_since_as_hr_string(time_since_last_checked)
+
# Admins can perform all actions and have the highest trust associated with them
# Moderators can make moderation decisions regarding the deletion of content
diff --git a/src/fellchensammlung/templates/fellchensammlung/partials/partial-check-rescue-org.html b/src/fellchensammlung/templates/fellchensammlung/partials/partial-check-rescue-org.html
new file mode 100644
index 0000000..eb642fc
--- /dev/null
+++ b/src/fellchensammlung/templates/fellchensammlung/partials/partial-check-rescue-org.html
@@ -0,0 +1,21 @@
+{% load i18n %}
+{% load custom_tags %}
+
+
+
{% translate 'Zuletzt geprüft:' %} {{ rescue_org.last_checked_hr }}
+ {% if rescue_org.website %}
+
{% translate "Website" %}: {{ rescue_org.website | safe }}
+ {% endif %}
+
+
+
+
\ No newline at end of file
diff --git a/src/fellchensammlung/templates/fellchensammlung/rescue-organization-check.html b/src/fellchensammlung/templates/fellchensammlung/rescue-organization-check.html
new file mode 100644
index 0000000..0119d18
--- /dev/null
+++ b/src/fellchensammlung/templates/fellchensammlung/rescue-organization-check.html
@@ -0,0 +1,12 @@
+{% extends "fellchensammlung/base_generic.html" %}
+{% load i18n %}
+{% block content %}
+ {% translate "Aktualitätscheck" %}
+ {% translate "Überprüfe ob im Tierheim neue Vermittlungen ein Zuhause suchen" %}
+
+
{% translate 'Organisation zur Überprüfung' %}
+ {% for rescue_org in rescue_orgs %}
+ {% include "fellchensammlung/partials/partial-check-rescue-org.html" %}
+ {% endfor %}
+
+{% endblock %}
diff --git a/src/fellchensammlung/urls.py b/src/fellchensammlung/urls.py
index 4b19527..40d73ed 100644
--- a/src/fellchensammlung/urls.py
+++ b/src/fellchensammlung/urls.py
@@ -31,9 +31,11 @@ urlpatterns = [
# ex: /adoption_notice/7/edit
path("vermittlung//edit", views.adoption_notice_edit, name="adoption-notice-edit"),
# ex: /vermittlung/5/add-photo
- path("vermittlung//add-photo", views.add_photo_to_adoption_notice, name="adoption-notice-add-photo"),
+ path("vermittlung//add-photo", views.add_photo_to_adoption_notice,
+ name="adoption-notice-add-photo"),
# ex: /adoption_notice/2/add-animal
- path("vermittlung//add-animal", views.adoption_notice_add_animal, name="adoption-notice-add-animal"),
+ path("vermittlung//add-animal", views.adoption_notice_add_animal,
+ name="adoption-notice-add-animal"),
path("tierschutzorganisationen/", views.list_rescue_organizations, name="rescue-organizations"),
path("organisation//", views.detail_view_rescue_organization,
@@ -57,9 +59,11 @@ urlpatterns = [
path("meldung//", views.report_detail, name="report-detail"),
path("meldung//sucess", views.report_detail_success, name="report-detail-success"),
path("modqueue/", views.modqueue, name="modqueue"),
-
+
path("updatequeue/", views.updatequeue, name="updatequeue"),
+ path("organization-check/", views.rescue_organization_check, name="organization-check"),
+
###########
## USERS ##
###########
diff --git a/src/fellchensammlung/views.py b/src/fellchensammlung/views.py
index 0bdf45f..8e431f6 100644
--- a/src/fellchensammlung/views.py
+++ b/src/fellchensammlung/views.py
@@ -639,3 +639,18 @@ def styleguide(request):
context = {"geocoding_api_url": settings.GEOCODING_API_URL, }
return render(request, 'fellchensammlung/styleguide.html', context=context)
+
+@login_required
+def rescue_organization_check(request):
+ if request.method == "POST":
+ rescue_org = RescueOrganization.objects.get(id=request.POST.get("rescue_organization_id"))
+ edit_permission = user_is_trust_level_or_above(request.user, TrustLevel.MODERATOR)
+ if not edit_permission:
+ return render(request, "fellchensammlung/errors/403.html", status=403)
+ action = request.POST.get("action")
+ if action == "checked":
+ rescue_org.set_checked()
+
+ last_checked_rescue_orgs = RescueOrganization.objects.order_by("last_checked")
+ context = {"rescue_orgs": last_checked_rescue_orgs,}
+ return render(request, 'fellchensammlung/rescue-organization-check.html', context=context)