All modules are now plugins. The config.py calls load_plugin for each plugin it needs (some plugins may load others automatically). Also each plugin keeps its own template folder which gets added to the template search path, so i.e. if the photo plugin is unloaded completely, the URL endpoints won't work either (with the old system, since the HTML templates still existed in the default root the endpoints would still serve pages, just without any Python logic behind them).
37 lines
1.0 KiB
HTML
37 lines
1.0 KiB
HTML
{% extends "layout.html" %}
|
|
{% block title %}Photo Albums{% endblock %}
|
|
{% block content %}
|
|
|
|
<h1>Photo Albums</h1>
|
|
|
|
{% if albums|length == 0 %}
|
|
<em>There are no photo albums yet.</em>
|
|
{% else %}
|
|
<ul class="photo-grid">
|
|
|
|
{% for album in albums %}
|
|
<li class="portrait">
|
|
<div class="dummy"></div>
|
|
<div class="photo-grid-item">
|
|
<a href="{{ url_for('photo.album_index', name=album['name']) }}">
|
|
<img src="{{ app['photo_url'] }}/{{ album['cover'] }}" width="100%" height="100%">
|
|
<span class="name">{{ album["name"] }}</span>
|
|
</a>
|
|
</div>
|
|
</li>
|
|
{% endfor %}
|
|
|
|
</ul>
|
|
<div class="clear"></div>
|
|
{% endif %}
|
|
|
|
{% if session["login"] %}
|
|
<h1>Administrative Options</h1>
|
|
|
|
<ul>
|
|
<li><a href="{{ url_for('photo.upload') }}">Upload a Photo</a></li>
|
|
{% if albums|length > 0 %}<li><a href="{{ url_for('photo.arrange_albums') }}">Rearrange Albums</a></li>{% endif %}
|
|
</ul>
|
|
{% endif %}
|
|
|
|
{% endblock %} |