From c73efb01e4e9cae23d7daccb6d2decd26a886eaf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniele=20Vigan=C3=B2?= Date: Sat, 7 Oct 2023 22:38:20 +0200 Subject: [PATCH] Introduce private docs and flatpages preview (#26) * Add support for private documents * Fix migrations after merge * Rebase fixtures * Filter private decoder docs * Enable preview of unpublished pages --- ram/metadata/admin.py | 1 + .../0013_decoderdocument_private.py | 18 +++++++ ram/portal/models.py | 9 ++-- ram/portal/templates/cards/rolling_stock.html | 2 +- ram/portal/templates/rollingstock.html | 18 +++---- ram/portal/views.py | 54 +++++++++++-------- ram/ram/__init__.py | 2 +- ram/ram/models.py | 1 + ram/roster/admin.py | 1 + .../0019_rollingstockdocument_private.py | 18 +++++++ 10 files changed, 86 insertions(+), 38 deletions(-) create mode 100644 ram/metadata/migrations/0013_decoderdocument_private.py create mode 100644 ram/roster/migrations/0019_rollingstockdocument_private.py diff --git a/ram/metadata/admin.py b/ram/metadata/admin.py index 1ba1b6c..7f4970e 100644 --- a/ram/metadata/admin.py +++ b/ram/metadata/admin.py @@ -15,6 +15,7 @@ @admin.register(Property) class PropertyAdmin(admin.ModelAdmin): + list_display = ("name", "private") search_fields = ("name",) diff --git a/ram/metadata/migrations/0013_decoderdocument_private.py b/ram/metadata/migrations/0013_decoderdocument_private.py new file mode 100644 index 0000000..af62945 --- /dev/null +++ b/ram/metadata/migrations/0013_decoderdocument_private.py @@ -0,0 +1,18 @@ +# Generated by Django 4.2.5 on 2023-10-06 19:48 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ("metadata", "0012_alter_decoder_manufacturer_decoderdocument"), + ] + + operations = [ + migrations.AddField( + model_name="decoderdocument", + name="private", + field=models.BooleanField(default=False), + ), + ] diff --git a/ram/portal/models.py b/ram/portal/models.py index be84623..7305f8e 100644 --- a/ram/portal/models.py +++ b/ram/portal/models.py @@ -66,12 +66,11 @@ def get_absolute_url(self): return reverse("flatpage", kwargs={"flatpage": self.path}) def get_link(self): - if self.published: - return mark_safe( - 'Link'.format( - self.get_absolute_url() - ) + return mark_safe( + 'Link'.format( + self.get_absolute_url() ) + ) @receiver(models.signals.pre_save, sender=Flatpage) diff --git a/ram/portal/templates/cards/rolling_stock.html b/ram/portal/templates/cards/rolling_stock.html index d69acaf..f82db4c 100644 --- a/ram/portal/templates/cards/rolling_stock.html +++ b/ram/portal/templates/cards/rolling_stock.html @@ -1,7 +1,7 @@ {% load static %}
- {% if d.item.image.count > 0 %} + {% if d.item.image.exists %} {{ d }} {% else %} diff --git a/ram/portal/templates/rollingstock.html b/ram/portal/templates/rollingstock.html index 18de4ea..3b98911 100644 --- a/ram/portal/templates/rollingstock.html +++ b/ram/portal/templates/rollingstock.html @@ -48,8 +48,8 @@ {% if rolling_stock.decoder %}{% endif %} - {% if rolling_stock.document.count > 0 or rolling_stock.decoder.document.count > 0 %}{% endif %} - {% if rolling_stock_journal.count > 0 %}{% endif %} + {% if documents or decoder_documents %}{% endif %} + {% if journal %}{% endif %} {% if rolling_stock.notes %}{% endif %}