Veliké přejmenovávání

Myslím, že to nefunguje, ještě nejsou změněné templaty.
A není napsaná migrace
A není to zdokumentované
This commit is contained in:
LEdoian 2025-12-17 13:22:07 +00:00
parent 09f6cc6bc3
commit d06be4ccbd
10 changed files with 136 additions and 136 deletions

View file

@ -13,8 +13,7 @@ def zverejnit_fotogalerii(modeladmin, request, queryset):
for galerie in queryset:
galerie.zobrazit = Galerie.Viditelnost.VZDY
galerie.save()
zverejnit_fotogalerii(modeladmin, request,
Galerie.objects.filter(galerie_up = galerie))
zverejnit_fotogalerii(modeladmin, request, galerie.podgalerie.all())
zverejnit_fotogalerii.short_description = 'Zveřejnit fotogalerie'
@ -24,32 +23,29 @@ def prepnout_fotogalerii_do_org_rezimu(modeladmin, request, queryset):
for galerie in queryset:
galerie.zobrazit = Galerie.Viditelnost.ORG
galerie.save()
prepnout_fotogalerii_do_org_rezimu(modeladmin, request,
Galerie.objects.filter(galerie_up = galerie))
prepnout_fotogalerii_do_org_rezimu(modeladmin, request, galerie.podgalerie.all())
prepnout_fotogalerii_do_org_rezimu.short_description = \
'Přepnout do režimu úprav (zneveřejní galerii)'
class GalerieInline(admin.TabularInline):
model = Soubor
fields = ['soubor', 'nazev', 'popis', 'typ', 'poradi']
fields = ['soubor', 'nazev', 'popisek', 'typ', 'poradi']
readonly_fields = ['nazev']
formfield_overrides = {
models.TextField: {'widget': forms.TextInput},
}
@admin.register(Soubor)
class SouborAdmin(admin.ModelAdmin):
list_display = ('soubor', 'nazev', 'popis', 'poradi')
search_fields = ['nazev','popis']
list_display = ('soubor', 'nazev', 'popisek', 'poradi')
search_fields = ['nazev','popisek']
@admin.register(Galerie)
class GalerieAdmin(admin.ModelAdmin):
model = Galerie
fields = ('zobrazit', 'nazev', 'titulni_obrazek', 'popis', 'galerie_up', 'soustredeni', 'poradi')
fields = ('zobrazit', 'nazev', 'titulni_obrazek', 'poznamka', 'nadgalerie', 'soustredeni', 'poradi')
autocomplete_fields = ['titulni_obrazek']
list_display = ('nazev', 'soustredeni', 'galerie_up', 'poradi', 'zobrazit', 'datum_zmeny')
list_display = ('nazev', 'soustredeni', 'nadgalerie', 'poradi', 'zobrazit', 'datum_zmeny')
inlines = [GalerieInline]
actions = [zverejnit_fotogalerii, prepnout_fotogalerii_do_org_rezimu]
save_on_top = True
ordering = ['galerie_up__nazev', 'poradi']
admin.site.register(Soubor, SouborAdmin)
admin.site.register(Galerie, GalerieAdmin)

View file

@ -2,7 +2,7 @@ from django import forms
class KomentarForm(forms.Form):
"""Formulář na přidání/úpravu popisku u souboru (obrázku)"""
komentar = forms.CharField(label = "Komentář:", max_length = 300, required=False)
popisek = forms.CharField(label = "Popisek:", max_length = 300, required=False)
class NewGalerieForm(forms.Form):
nazev = forms.CharField(label = "Název galerie", max_length = 100)

View file

@ -30,8 +30,8 @@ def galerie_filename(self, filename):
# soustředění je v cestě jen pokud galerie pod nějaké patří
cesta = (
['Galerie'] +
(["soustredeni_{}".format(gal.soustredeni.pk)] if gal.soustredeni else []) +
["galerie_{}".format(cislo_gal), self.nazev]
([f"soustredeni_{gal.soustredeni.pk}"] if gal.soustredeni else []) +
[f"galerie_{cislo_gal}", self.nazev]
)
return os.path.join(*cesta)
@ -45,22 +45,22 @@ class Soubor(models.Model):
VIDEO = 'video', 'Video'
NEVIM = 'nevim', 'Neznámý typ'
typ = models.CharField('Typ', max_length=16, blank=False, null=False, choices=Typ.choices, default=Typ.NEVIM)
# Filename by default; slouží k řazení
nazev = models.CharField('Jméno souboru', max_length=50, blank=True, null=True)
# ~~Rádoby~~ vtipný popisek od orgů
popis = models.TextField('Popisek', blank=True, null=True)
nazev = models.CharField('Jméno souboru', max_length=50, blank=True, null=True,
help_text="Název, slouží k řazení. Typicky není potřeba vyplnit, automaticky se použije jméno nahraného souboru.")
#: ~~Rádoby~~ vtipný popisek od orgů
popisek = models.TextField('Popisek', blank=True, null=True)
datum_vlozeni = models.DateTimeField('Datum vložení', auto_now_add=True)
galerie = models.ForeignKey('Galerie', blank=True, null=True, on_delete=models.CASCADE)
# Primární klíč k řazení pro overridování řazení podle názvu
poradi = models.IntegerField('Pořadí', blank=True, null=True)
poradi = models.IntegerField('Pořadí', blank=True, null=True,
help_text='Primární klíč pro řazení v rámci galerie.')
def __str__(self):
return f'Soubor {self.nazev} ({self.soubor.name})'
class Meta:
verbose_name = 'Soubor'
verbose_name_plural = 'Soubory'
db_table = 'galerie_obrazek' # FIXME: přejmenovat
verbose_name = 'Soubor (Obrázek ap.)'
verbose_name_plural = 'Soubory (Obrázky ap.)'
db_table = 'galerie_soubor'
ordering = ['galerie', 'poradi', 'nazev']
def save(self, *args, **kwargs):
@ -82,7 +82,7 @@ class Soubor(models.Model):
case _: raise ValueError("Neznámý typ obrázku, bug v kódu!")
def get_absolute_url(self):
return reverse('galerie_soubor', pk=self.galerie.pk, fotka=self.pk)
return reverse('galerie_soubor', kwargs={'galerie': self.galerie.pk, 'soubor': self.pk})
class Galerie(models.Model):
class Viditelnost(models.IntegerChoices):
@ -95,10 +95,13 @@ class Galerie(models.Model):
datum_vytvoreni = models.DateTimeField('Datum vytvoření', auto_now_add = True)
datum_zmeny = models.DateTimeField('Datum poslední změny', auto_now = True)
poznamka = models.TextField('neveřejná poznámka', blank = True, null = True)
titulni_obrazek = models.ForeignKey(Soubor, blank = True, null = True, related_name = "+", on_delete = models.SET_NULL)
titulni_obrazek = models.ForeignKey(Soubor, verbose_name = 'Titulní obrázek', blank = True, null = True, related_name = "+", on_delete = models.SET_NULL)
zobrazit = models.IntegerField('Zobrazit?', default = Viditelnost.ORG, choices = Viditelnost.choices) # TODO: Dj5 už stačí `choices = Viditelnost`
galerie_up = models.ForeignKey('Galerie', blank = True, null = True,
#: None pro hlavní galerie soustředění
nadgalerie = models.ForeignKey('Galerie', verbose_name = 'Nadgalerie', blank = True, null = True,
related_name='podgalerie',
on_delete=models.PROTECT)
#: None pro podgalerie, not None pro hlavní galerie soustředění
soustredeni = models.ForeignKey(Soustredeni, blank = True, null = True,
on_delete=models.PROTECT)
poradi = models.IntegerField('Pořadí', blank = True, null = False, default = 0)
@ -109,6 +112,7 @@ class Galerie(models.Model):
verbose_name = 'Galerie'
verbose_name_plural = 'Galerie'
db_table = 'galerie_galerie'
ordering = ['nadgalerie__datum_vytvoreni', 'poradi', 'nazev']
def get_absolute_url(self):
return reverse('galerie_galerie', pk=self.pk)
return reverse('galerie_galerie', kwargs={'galerie': self.pk})

View file

@ -3,7 +3,7 @@
{% load bazmeky %}
{% block nadpis1a %}
{{galerie.nazev}}: {{ obrazek.popis | default:"Fotka" }}
{{galerie.nazev}}: {{ obrazek.popisek | default:"Fotka" }}
{% endblock %}
@ -21,17 +21,17 @@
{% if predchozi_obrazek %}
// doleva
if (e.which == 37) {
window.location.assign("{% url 'galerie_soubor' pk=galerie.pk fotka=predchozi_obrazek.pk %}#nahoru");
window.location.assign("{% url 'galerie_soubor' galerie=galerie.pk soubor=predchozi_obrazek.pk %}#nahoru");
}
{% endif %}
{% if dalsi_obrazek %}
// doprava
if (e.which == 39) {
window.location.assign("{% url 'galerie_soubor' pk=galerie.pk fotka=dalsi_obrazek.pk %}#nahoru");
window.location.assign("{% url 'galerie_soubor' galerie=galerie.pk soubor=dalsi_obrazek.pk %}#nahoru");
}
{% endif %}
if (e.which == 27) {
window.location.assign("{% url 'galerie_galerie' pk=galerie.pk %}#obsah");
window.location.assign("{% url 'galerie_galerie' galerie=galerie.pk %}#obsah");
}
});
@ -51,7 +51,7 @@
<h2>
{% for g in cesta %}
<a href="{% url 'galerie_galerie' pk=g.pk %}">{{ g.nazev }}</a>{% if not forloop.last %} >{% endif %}
<a href="{% url 'galerie_galerie' galerie=g.pk %}">{{ g.nazev }}</a>{% if not forloop.last %} >{% endif %}
{% endfor %}
</h2>
@ -60,17 +60,17 @@
{% if obrazky_predchozi %}
{% with obrazky_predchozi|last as predchozi_obrazek %}
<div>
<a title="Předchozí" class="predchozi_obrazek" href="{% url 'galeie_soubor' pk=galerie.pk fotka=predchozi_obrazek.pk %}#nahoru"></a>
<a title="Předchozí" class="predchozi_obrazek" href="{% url 'galeie_soubor' galerie=galerie.pk soubor=predchozi_obrazek.pk %}#nahoru"></a>
</div>
{% endwith %}
{% endif%}
<span id="nahoru" class="kotva_obrazku"></span>
{% zobrazit obrazek.jako_bazmek alt=obrazek.popis title=obrazek.popis class="obrazek" %}
{% zobrazit obrazek.jako_bazmek alt=obrazek.popisek title=obrazek.popisek class="obrazek" %}
{% if obrazky_dalsi %}
{% with obrazky_dalsi|first as dalsi_obrazek %}
<div>
<a title="Další" class="dalsi_obrazek" href="{% url 'galerie_soubor' pk=galerie.pk fotka=dalsi_obrazek.pk %}#nahoru"></a>
<a title="Další" class="dalsi_obrazek" href="{% url 'galerie_soubor' galerie=galerie.pk soubor=dalsi_obrazek.pk %}#nahoru"></a>
</div>
{% endwith %}
{% endif%}
@ -85,14 +85,14 @@
<form action=".#nahoru" method="post" id="komentarform">
{% csrf_token %}
<table>
<tr><td><label>Aktuální komentář:</label></td><td>{{obrazek.popis}}</td>
<tr><td><label>Aktuální komentář:</label></td><td>{{obrazek.popisek}}</td>
{{form.as_table}}
<tr><td></td><td><input name="odeslat" type="submit" value="Změň komentář"></td></tr>
</table>
</form>
{% else %}
{% if obrazek.popis %}
{{obrazek.popis}}
{% if obrazek.popisek %}
{{obrazek.popisek}}
{% endif %}
{% endif %}
</div>
@ -101,24 +101,24 @@
{# odkaz na predchozi galerii #}
<div class="navigace">
{% if predchozi_galerie %}
Předchozí: <a href="{% url 'galerie_soubor' pk=predchozi_galerie.pk fotka=predchozi_galerie.obrazek_set.last.pk %}#nahoru">
Předchozí: <a href="{% url 'galerie_soubor' galerie=predchozi_galerie.pk soubor=predchozi_galerie.obrazek_set.last.pk %}#nahoru">
{{predchozi_galerie}}
</a>
{% endif %}
{# nahledy predchozich obrazku #}
{% for obrazek in obrazky_predchozi %}
<a href="{% url 'galerie_soubor' pk=galerie.pk fotka=obrazek.pk %}#nahoru">{% zmenseny_nahled obrazek.jako_bazmek height=100 %}</a>
<a href="{% url 'galerie_soubor' galerie=galerie.pk soubor=obrazek.pk %}#nahoru">{% zmenseny_nahled obrazek.jako_bazmek height=100 %}</a>
{% endfor %}
{% zmenseny_nahled obrazek.jako_bazmek alt=obrazek.popis class="obrazek" id="prostredni" %}
{% zmenseny_nahled obrazek.jako_bazmek alt=obrazek.popisek class="obrazek" id="prostredni" %}
{# nahledy nasledujicich obrazku #}
{% for obrazek in obrazky_dalsi %}
<a href="{% url 'galerie_soubor' pk=galerie.pk fotka=obrazek.pk %}#nahoru">{% zmenseny_nahled obrazek.jako_bazmek height=100 %}</a>
<a href="{% url 'galerie_soubor' galerie=galerie.pk soubor=obrazek.pk %}#nahoru">{% zmenseny_nahled obrazek.jako_bazmek height=100 %}</a>
{% endfor %}
{# odkaz na nasledujici galerii #}
{% if nasledujici_galerie %}
Následující: <a href="{% url 'galerie_soubor' pk=nasledujici_galerie.pk fotka=nasledujici_galerie.obrazek_set.first.pk %}#nahoru">
Následující: <a href="{% url 'galerie_soubor' galerie=nasledujici_galerie.pk soubor=nasledujici_galerie.obrazek_set.first.pk %}#nahoru">
{{nasledujici_galerie}}
</a>
{% endif %}

View file

@ -3,7 +3,7 @@
{% load bazmeky %}
{% block nadpis1a %}
Galerie {{galerie.nazev}}
Galerie popisekgalerie.nazev}}
{% endblock %}
{% block content %}
@ -18,7 +18,7 @@ Galerie {{galerie.nazev}}
<h2>
{% for g in cesta %}
{% if not forloop.last %}
<a href="{% url 'galerie_galerie pk=g.pk %}">{{ g.nazev }}</a> >
<a href="{% url 'galerie_galerie galerie=g.pk %}">{{ g.nazev }}</a> >
{% else %}
{{ g.nazev }}
{% endif %}
@ -39,7 +39,7 @@ Galerie {{galerie.nazev}}
{% if sourozenci|length > 1 %}
{% for g in sourozenci %}
{% if g.pk != galerie.pk %}
<a href="{% url 'galerie_galerie' pk=g.pk %}">{{ g.nazev }}</a>
<a href="{% url 'galerie_galerie' galerie=g.pk %}">{{ g.nazev }}</a>
{% else %}
{{ g.nazev }}
{% endif %}
@ -51,7 +51,7 @@ Galerie {{galerie.nazev}}
{% with 22 as max_delka_nazvu %}
<div class="galerie_nahledy">
{% for pgalerie in podgalerie %}
<a href="{% url 'galerie_galerie' pk=pgalerie.pk %}"
<a href="{% url 'galerie_galerie' galerie=pgalerie.pk %}"
{% if pgalerie.nazev|length > max_delka_nazvu %}
title="{{ pgalerie.nazev }}"
{% endif %}
@ -67,8 +67,8 @@ Galerie {{galerie.nazev}}
{% if user.je_org %}
<div class="mam-org-only-galerie">
({{pgalerie.poradi}})
<span class="plus"><a href="{% url 'galerie_plus' galerie=galerie.pk subgalerie=pgalerie.pk %}">+</a></span>
<span class="minus"><a href="{% url 'galerie_minus' galerie=galerie.pk subgalerie=pgalerie.pk %}">-</a></span>
<span class="plus"><a href="{% url 'galerie_doprava' galerie=galerie.pk subgalerie=pgalerie.pk %}">+</a></span>
<span class="minus"><a href="{% url 'galerie_doleva' galerie=galerie.pk subgalerie=pgalerie.pk %}">-</a></span>
</div>
{% endif %}
{% endif %}
@ -92,13 +92,13 @@ Galerie {{galerie.nazev}}
<div class="galerie_nahledy">
{% for obrazek in obrazky %}
<a
{% if obrazek.popis %}
title="{{ obrazek.popis }}"
{% if obrazek.popisek %}
title="{{ obrazek.popisek }}"
{% endif %}
href="{% url 'galerie_soubor' pk=galerie.pk fotka=obrazek.pk %}#nahoru" class="galerie_nahled">
href="{% url 'galerie_soubor' galerie=galerie.pk soubor=obrazek.pk %}#nahoru" class="galerie_nahled">
<span class="vystredeno"></span>
{% zmenseny_nahled obrazek.jako_bazmek %}
{# title=obrazek.popis (a byl tu if, že se použil jen když existoval…) width=obrazek.obrazek_maly.width height=obrazek.obrazek_maly.height #}
{# title=obrazek.popisek (a byl tu if, že se použil jen když existoval…) width=obrazek.obrazek_maly.width height=obrazek.obrazek_maly.height #}
</a>
{% endfor %}
<br>
@ -107,12 +107,12 @@ Galerie {{galerie.nazev}}
<div class="galerie_predchozi_nasledujici">
{% if predchozi %}
<div class="predchozi">
<a href="{% url 'galerie_galerie' pk=predchozi.pk %}">Předchozí: {{ predchozi.nazev }}</a>
<a href="{% url 'galerie_galerie' galerie=predchozi.pk %}">Předchozí: {{ predchozi.nazev }}</a>
</div>
{% endif %}
{% if nasledujici %}
<div class="nasledujici">
<a href="{% url 'galerie_galerie' pk=nasledujici.pk %}">Následující: {{ nasledujici.nazev }}</a>
<a href="{% url 'galerie_galerie' galerie=nasledujici.pk %}">Následující: {{ nasledujici.nazev }}</a>
</div>
{% endif %}
</div>

View file

@ -1,5 +1,5 @@
"""
Pomocné tagy pro zobrazování `galerie.typy.ZobrazitelnyBazmek`. Jen volají příslušnou metodu na bazmeku.
Pomocné tagy pro zobrazování :py:class:`galerie.typy.ZobrazitelnyBazmek`. Jen volají příslušnou metodu na bazmeku.
"""
from django import template
register = template.Library()

View file

@ -40,7 +40,7 @@ class ZobrazitelnyBazmek(abc.ABC):
...
@abc.abstractmethod
def zmenseny_nahled(self, **kwargs) -> HTML:
"""Zmenšené obrázky v přehledu obrázků a pod hlavním obrázkem (předchozí/následující)"""
"""Zmenšené obrázky v přehledu obrázků a v navigaci pod hlavním obrázkem"""
...
@property
@ -54,7 +54,7 @@ class ZobrazitelnyBazmek(abc.ABC):
### Obrázky ###
# Odpovídá původnímu chování (bo se mi nechce vymýšlet novoty…
class ObrazekStredniSpec(ImageSpec):
class ObrazekSpec(ImageSpec):
"""Specifikace obrázku pro velké zobrazení"""
processors = [
Transpose(Transpose.AUTO), # Rotuj podle dat v EXIFu
@ -63,7 +63,7 @@ class ObrazekStredniSpec(ImageSpec):
format = 'JPEG'
options = {'quality': 95} # Proč tolik?
class ObrazekMalySpec(ImageSpec):
class ObrazekZmensenySpec(ImageSpec):
"""Specifikace obrázku pro náhledy (pod hlavním obrázkem nebo v přehledu galerie)"""
processors = [
Transpose(Transpose.AUTO),
@ -85,14 +85,14 @@ class Obrazek(ZobrazitelnyBazmek):
"""
def zobrazit(self, **kwargs):
# Jak se takový cachefile používá je potřeba vyčíst ze zdrojáků?
file = ImageCacheFile(ObrazekStredniSpec(source=self.soubor))
file = ImageCacheFile(ObrazekSpec(source=self.soubor))
file.generate()
attrs = _fmt_attrs(kwargs)
html = format_html(r'<img src="{}" {} />', file.url, attrs)
return html
def zmenseny_nahled(self, **kwargs):
file = ImageCacheFile(ObrazekMalySpec(source=self.soubor))
file = ImageCacheFile(ObrazekZmensenySpec(source=self.soubor))
file.generate()
attrs = _fmt_attrs(kwargs)
html = format_html(r'<img src="{}" {} />', file.url, attrs)

View file

@ -3,10 +3,10 @@ from personalni.utils import org_required
from . import views
urlpatterns = [
path('<int:pk>/', views.nahled, name='galerie_galerie'),
path('<int:pk>/<int:fotka>/', views.detail, name='galerie_soubor'),
path('<int:galerie>/', views.galerieView, name='galerie_galerie'),
path('<int:galerie>/<int:soubor>/', views.souborView, name='galerie_soubor'),
path('<int:galerie>/new/', org_required(views.new_galerie), name='galerie_nova'),
path('<int:galerie>/plus/<int:subgalerie>/', org_required(views.plus_galerie), name='galerie_plus'),
path('<int:galerie>/minus/<int:subgalerie>/', org_required(views.minus_galerie), name='galerie_minus'),
path('<int:galerie>/doprava/<int:subgalerie>/', org_required(views.galerie_doprava), name='galerie_doprava'),
path('<int:galerie>/doleva/<int:subgalerie>/', org_required(views.galerie_doleva), name='galerie_doleva'),
]

View file

@ -5,6 +5,6 @@ if TYPE_CHECKING:
# Miluju pythoní typing :-P
def top_galerie(g: Galerie) -> Galerie:
while g.galerie_up is not None:
g = g.galerie_up
while g.nadgalerie is not None:
g = g.nadgalerie
return g

View file

@ -3,6 +3,7 @@ import random
from django.http import HttpResponse, Http404, HttpRequest
from django.shortcuts import render, HttpResponseRedirect, get_object_or_404
from django.template import RequestContext
from django.urls import reverse
from datetime import datetime
from galerie.utils import top_galerie
@ -20,7 +21,7 @@ UCASTNIK = Galerie.Viditelnost.UCASTNIK
import logging
logger = logging.getLogger(__name__)
def galerie_ke_zobrazeni(soustredeni: Soustredeni | None, request: HttpRequest) -> tuple[int]:
def galerie_ke_zobrazeni(soustredeni: Soustredeni | None, request: HttpRequest) -> tuple[Galerie.Viditelnost, ...]:
if request.user.is_superuser: return (VZDY, ORG, UCASTNIK)
if request.user.je_org: return (VZDY, ORG, UCASTNIK)
if request.user.is_anonymous: return (VZDY,)
@ -32,8 +33,7 @@ def galerie_ke_zobrazeni(soustredeni: Soustredeni | None, request: HttpRequest)
return (VZDY,)
logger.warning("Nepodařilo se zjistit, jaké galerie se mají zobrazit!")
return (VZDY,)
def zobrazit(galerie: Galerie, request: HttpRequest) -> bool:
soustredeni = top_galerie(galerie).soustredeni
return galerie.zobrazit in galerie_ke_zobrazeni(soustredeni, request)
@ -42,32 +42,32 @@ def dovolit_upravy_popisku(galerie: Galerie, request: HttpRequest) -> bool:
# FIXME: Dočasné: úpravy jen když je to v org-only stavu. (Odpovídá předchozímu chování)
return request.user.je_org and galerie.zobrazit in (ORG,)
def cesta_od_korene(g):
"""Vrátí seznam galerií od kořene ke g"""
cesta = []
while g is not None:
cesta.append(g)
g = g.galerie_up
g = g.nadgalerie
return reversed(cesta)
def nahled(request, pk, soustredeni):
"""Zobrazeni nahledu vsech fotek ve skupine."""
galerie = get_object_or_404(Galerie, pk=pk)
soustredeni = top_galerie(galerie).soustredeni
def galerieView(request, soustredeni:int, galerie: int):
"""Zobrazení přehledu všech souborů v Galerii."""
galerie: Galerie = get_object_or_404(Galerie, pk=galerie)
assert top_galerie(galerie).soustredeni.id == soustredeni
soustredeni: Soustredeni | None = top_galerie(galerie).soustredeni
# FIXME: přepsat model a použít přímo dolů…
podgalerie = Galerie.objects.filter(galerie_up = galerie).order_by('poradi')
podgalerie = Galerie.objects.filter(nadgalerie = galerie).order_by('poradi')
podgalerie = podgalerie.filter(zobrazit__in=galerie_ke_zobrazeni(soustredeni, request))
obrazky = galerie.soubor_set.all().order_by('poradi', 'nazev')
soubory = galerie.soubor_set.all().order_by('poradi', 'nazev')
ma_se_zobrazit = zobrazit(galerie, request)
if not ma_se_zobrazit: raise Http404("Galerie sice existuje, ale my se tváříme, že ne :-D")
sourozenci = []
if galerie.galerie_up:
sourozenci = galerie.galerie_up.galerie_set.filter(zobrazit__in=galerie_ke_zobrazeni(soustredeni, request)).order_by('poradi')
if galerie.nadgalerie:
sourozenci = galerie.nadgalerie.podgalerie.filter(zobrazit__in=galerie_ke_zobrazeni(soustredeni, request)).order_by('poradi')
predchozi = None
nasledujici = None
@ -85,7 +85,7 @@ def nahled(request, pk, soustredeni):
return render(request, 'galerie/GalerieNahled.html',
{'galerie' : galerie,
'podgalerie' : podgalerie,
'obrazky' : obrazky,
'soubory' : soubory,
'cesta': cesta,
'sourozenci': sourozenci,
'predchozi': predchozi,
@ -93,31 +93,32 @@ def nahled(request, pk, soustredeni):
'object': galerie,
})
def detail(request, pk, fotka, soustredeni):
"""Zobrazeni nahledu fotky s id 'fotka'."""
def souborView(request, soustredeni: int, galerie: int, soubor: int):
"""Zobrazení souboru."""
NAHLEDU = 1
galerie = get_object_or_404(Galerie, pk=pk)
soustredeni = top_galerie(galerie).soustredeni
galerie: Galerie = get_object_or_404(Galerie, pk=galerie)
assert top_galerie(galerie).soustredeni.id == soustredeni
soustredeni: Soustredeni | None = top_galerie(galerie).soustredeni
ma_se_zobrazit = zobrazit(galerie, request)
if not ma_se_zobrazit: raise Http404("Obrázek neukážu!")
obrazek = get_object_or_404(Soubor, pk=fotka)
soubor = get_object_or_404(Soubor, pk=soubor)
# Pořadí není povinné. FIXME: `nazev` je zavádějící… Ale tohle je kanonické pořadí obrázků v galerii…
obrazky = galerie.soubor_set.all().order_by('poradi', 'nazev')
obrazky = list(obrazky)
index_obrazku = obrazky.index(obrazek)
# Explicitní pořadí ničemu neuškodí :-)
soubory = galerie.soubor_set.all().order_by('poradi', 'nazev')
soubory = list(soubory)
index_souboru = soubory.index(soubor)
# Podle mě se nemůže stát, že by volání výš selhalo, kdyžtak shodí web. (původně to byl explicitně ošetřený stav dávající 404)
predchozi_obrazky = list(reversed(obrazky[:index_obrazku]))
nasledujici_obrazky = obrazky[index_obrazku+1:]
predchozi_soubory = list(reversed(soubor[:index_souboru]))
nasledujici_soubory = soubory[index_souboru+1:]
# Může jich být hodně…
predchozi_obrazky = predchozi_obrazky[:NAHLEDU]
nasledujici_obrazky = nasledujici_obrazky[:NAHLEDU]
predchozi_soubory = predchozi_soubory[:NAHLEDU]
nasledujici_soubory = nasledujici_soubory[:NAHLEDU]
# Předchozí obrázky chceme v normálním pořadí
predchozi_obrazky = list(reversed(predchozi_obrazky))
predchozi_soubory = list(reversed(predchozi_soubory))
if galerie.galerie_up is not None:
sousedni_galerie = Galerie.objects.filter(galerie_up=galerie.galerie_up, zobrazit__in=galerie_ke_zobrazeni(soustredeni, request)).order_by('poradi')
if galerie.nadgalerie is not None:
sousedni_galerie = Galerie.objects.filter(nadgalerie=galerie.nadgalerie, zobrazit__in=galerie_ke_zobrazeni(soustredeni, request)).order_by('poradi')
sousedni_galerie = list(sousedni_galerie)
# Teoreticky se můžeme dívat na galerie.poradi, ale jednak už tenhle pattern stejně je výš a druhak je galerií málo, takže pomalost nevadí.
index_galerie = sousedni_galerie.index(galerie)
@ -129,45 +130,45 @@ def detail(request, pk, fotka, soustredeni):
# Pokud je obrázků dost, tak další galerii nepotřebujeme
# (jo, mohli jsme si ušetřit práci, ale takhle je kód imho přehlednější a za pár ušetřených dotazů do DB to nestojí)
if len(predchozi_obrazky) >= NAHLEDU:
if len(predchozi_soubory) >= NAHLEDU:
predchozi_galerie = None
if len(nasledujici_obrazky) >= NAHLEDU:
if len(nasledujici_soubory) >= NAHLEDU:
nasledujici_galerie = None
# vytvoreni a obslouzeni formulare
if request.method == 'POST':
form = KomentarForm(request.POST)
if form.is_valid():
obrazek.popis = form.cleaned_data['komentar']
obrazek.save()
soubor.popisek = form.cleaned_data['popisek']
soubor.save()
else:
form = KomentarForm({'komentar': obrazek.popis})
form = KomentarForm({'popisek': soubor.popisek})
return render(request, 'galerie/Galerie.html',
{'galerie' : galerie,
'predchozi_galerie' : predchozi_galerie,
'nasledujici_galerie' : nasledujici_galerie,
'obrazek' : obrazek,
'obrazky_predchozi' : predchozi_obrazky,
'obrazky_dalsi' : nasledujici_obrazky,
'soubor' : soubor,
'soubory_predchozi' : predchozi_soubory,
'soubory_dalsi' : nasledujici_soubory,
'upravy_popisku' : dovolit_upravy_popisku(galerie, request),
'form' : form,
'cesta': cesta_od_korene(galerie),
'object': obrazek,
'object': soubor,
})
def new_galerie(request, galerie, soustredeni):
def new_galerie(request, galerie: int, soustredeni: int):
# zjistime k jakemu soustredeni se vaze nove vytvarena galerie
soustredeni = get_object_or_404(Soustredeni, pk = soustredeni)
soustredeni: Soustredeni = get_object_or_404(Soustredeni, pk = soustredeni)
# pokud je parametr galerie 0, pak jde o hlavni galerii
# kdyz je nejaky jiny, pak je pk galerie pod kterou tu dalsi vytvarim
if int(galerie) == 0:
galerie_up = False
nadgalerie = False
galerie_text = "Hlavní fotogalerie soustředění"
else:
galerie_up = get_object_or_404(Galerie, pk = int(galerie))
galerie_text = "podgalerii ke galerii " + str(galerie_up)
nadgalerie = get_object_or_404(Galerie, pk = int(galerie))
galerie_text = "podgalerii ke galerii " + str(nadgalerie)
# obsluha formulare umoznujiciho multiple nahravani fotek
if request.method == 'POST':
@ -176,21 +177,20 @@ def new_galerie(request, galerie, soustredeni):
# vytvoreni nove galerie
gal = Galerie()
gal.nazev = form.cleaned_data['nazev']
#gal.popis = form.cleaned_data['popis'] # popis nepouzivame
gal.zobrazit = ORG # galerie je v procesu vytvareni
''' pokud je to podgalerie pridej nadrazenou galerii
a nadrazene soustredeni nechej volne,
pokud je to hlavni galerie, tak nadrazena galerie neexistuje,
ale v takovem pripade musi byt nadrazene soustredeni a ne jinak '''
if galerie_up:
gal.galerie_up = galerie_up
if nadgalerie:
gal.nadgalerie = nadgalerie
else:
gal.soustredeni = soustredeni
if gal.galerie_up:
gal.poradi = int(len(gal.galerie_up.galerie_set.all())) + 1
if gal.nadgalerie:
gal.poradi = int(len(gal.nadgalerie.galerie_set.all())) + 1
gal.save()
# zpracovani obrazku v galerii
# zpracovani souboru v galerii
from galerie.typy import tipniTyp
for obr in request.FILES.getlist('obr'):
o = Soubor()
@ -201,12 +201,11 @@ def new_galerie(request, galerie, soustredeni):
o.save()
# presmerovani na prave vzniklou galerii
return HttpResponseRedirect('../../' + str(gal.pk))
return HttpResponseRedirect(reverse('galerie_galerie', kwargs={'galerie': gal.pk}))
else:
form = NewGalerieForm()
return render(request, 'galerie/GalerieNew.html',
{
'form' : form,
@ -214,21 +213,22 @@ def new_galerie(request, galerie, soustredeni):
'galerie_text' : galerie_text,
})
def plus_galerie(request, galerie, soustredeni, subgalerie):
galerie = get_object_or_404(Galerie, pk=subgalerie)
if galerie.poradi:
galerie.poradi += 1
def galerie_doprava(request, soustredeni: int, galerie: int, subgalerie: int):
subgalerie: Galerie = get_object_or_404(Galerie, pk=subgalerie)
assert subgalerie.nadgalerie.pk == galerie
if subgalerie.poradi:
subgalerie.poradi += 1
else:
galerie.poradi = int(len(galerie.galerie_up.galerie_set.all()))
galerie.save()
return HttpResponseRedirect('../../')
subgalerie.poradi = int(len(subgalerie.nadgalerie.galerie_set.all()))
subgalerie.save()
return HttpResponseRedirect(reverse('galerie_galerie', kwargs={'galerie': galerie}))
def minus_galerie(request, galerie, soustredeni, subgalerie):
galerie = get_object_or_404(Galerie, pk=subgalerie)
if galerie.poradi:
galerie.poradi -= 1
def galerie_doleva(request, soustredeni: int, galerie: int, subgalerie: int):
subgalerie: Galerie = get_object_or_404(Galerie, pk=subgalerie)
assert subgalerie.nadgalerie.pk == galerie
if subgalerie.poradi:
subgalerie.poradi -= 1
else:
galerie.poradi = 1
galerie.save()
return HttpResponseRedirect('../../')
subgalerie.poradi = 1
subgalerie.save()
return HttpResponseRedirect(reverse('galerie_galerie', kwargs={'galerie': galerie}))