From 063f30ef0b05faaf56220fd85cdac21d84ca77b2 Mon Sep 17 00:00:00 2001 From: dave Date: Thu, 13 Sep 2018 22:59:22 -0700 Subject: [PATCH] centralized tagging --- photoapp/daemon.py | 76 +++++++++++++++++++++++++++++++++++--- templates/album.html | 6 ++- templates/create_tags.html | 30 ++++++++++----- templates/photo.html | 12 ++++-- templates/photo_tag.html | 2 +- 5 files changed, 105 insertions(+), 21 deletions(-) diff --git a/photoapp/daemon.py b/photoapp/daemon.py index 0095b45..87a4c15 100644 --- a/photoapp/daemon.py +++ b/photoapp/daemon.py @@ -14,11 +14,6 @@ import math APPROOT = os.path.abspath(os.path.join(os.path.dirname(__file__), "../")) -def tplglobals(): - print("###", cherrypy.request.path_info) - return dict(path=cherrypy.request.path_info) - - class PhotosWeb(object): def __init__(self, library, template_dir): self.library = library @@ -85,9 +80,47 @@ class PhotosWeb(object): query = query.filter(PhotoSet.uuid == i) yield self.render("map.html", images=query.all(), zoom=int(zoom)) + @cherrypy.expose + def create_tags(self, fromdate=None, tag=None, newtag=None): + """ + Tag multiple items addressable in one of a couple ways + TODO move this somewhere better? + """ + s = self.session() + photos = None + num_photos = None + if fromdate: + dt = datetime.strptime(fromdate, "%Y-%m-%d") + dt_end = dt + timedelta(days=1) + photos = s.query(PhotoSet).filter(and_(PhotoSet.date >= dt, + PhotoSet.date < dt_end)).order_by(PhotoSet.date) + num_photos = s.query(func.count(PhotoSet.id)). \ + filter(and_(PhotoSet.date >= dt, PhotoSet.date < dt_end)).order_by(PhotoSet.date).scalar() + + if newtag: + # TODO validate uuid ? + s.add(Tag(title=newtag)) # TODO slug + # TODO generate slug now or in model? + s.commit() + # raise cherrypy.HTTPRedirect('/photo/{}/tag'.format(uuid), 302) + + if tag: # Create the tag on all the photos + tag = s.query(Tag).filter(Tag.uuid == tag).first() + for photo in photos.all(): + if 0 == s.query(func.count(TagItem.id)).filter(TagItem.tag_id == tag.id, + TagItem.set_id == photo.id).scalar(): + s.add(TagItem(tag_id=tag.id, set_id=photo.id)) + s.commit() + + alltags = s.query(Tag).order_by(Tag.title).all() + yield self.render("create_tags.html", images=photos, alltags=alltags, num_photos=num_photos, fromdate=fromdate) + @cherrypy.popargs('date') class DateView(object): + """ + View all the photos shot on a given date + """ def __init__(self, master): self.master = master @@ -222,6 +255,39 @@ class PhotoView(object): raise cherrypy.HTTPRedirect('/photo/{}/tag'.format(uuid), 302) +@cherrypy.popargs('uuid') +class TagView(object): + """ + View the photos associated with a single tag + """ + def __init__(self, master): + self.master = master + # self._cp_config = {"tools.trailing_slash.on": False} + + @cherrypy.expose + def index(self, uuid, page=0): + page = int(page) + pgsize = 100 + s = self.master.session() + tag = s.query(Tag).filter(Tag.uuid == uuid).first() + numphotos = s.query(func.count(Tag.id)).join(TagItem).join(PhotoSet).filter(Tag.uuid == uuid).scalar() + photos = s.query(PhotoSet).join(TagItem).join(Tag).filter(Tag.uuid == uuid).offset(page * pgsize).limit(pgsize).all() + yield self.master.render("album.html", tag=tag, images=photos, total_items=numphotos, pgsize=100, page=page) + + @cherrypy.expose + def op(self, uuid, op): + s = self.master.session() + tag = s.query(Tag).filter(Tag.uuid == uuid).first() + if op == "Demote to tag": + tag.is_album = 0 + elif op == "Promote to album": + tag.is_album = 1 + else: + raise Exception("Invalid op") + s.commit() + raise cherrypy.HTTPRedirect('/tag/{}'.format(tag.uuid), 302) + + def main(): import argparse import signal diff --git a/templates/album.html b/templates/album.html index 2dd1820..6875638 100644 --- a/templates/album.html +++ b/templates/album.html @@ -3,7 +3,11 @@ {% set subtitle = "By date, descending" %} {% block buttons %} - xxx +
+ {% if tag.is_album %}{% else %} + {% endif %} + +
{% endblock %} {% block body %} diff --git a/templates/create_tags.html b/templates/create_tags.html index 8b4d407..e2a7d84 100644 --- a/templates/create_tags.html +++ b/templates/create_tags.html @@ -1,19 +1,27 @@ +{% extends "page.html" %} {% set title = "Placeholder Title" %} -{% set subtitle = image.uuid %} +{% set subtitle = "Foobar" %} -{% include "page-top.html" %} +{% block body %} +{% set preview = 9 %}
+

Images ({{ num_photos }})

+
+ {% for image in images %}{% if loop.index <= preview %} + + + + {% endif %}{% endfor %} +
+ {% if num_photos > preview %}

...and {{ num_photos - preview }} more

{% endif %}

Current Tags

- {# - - #} @@ -23,7 +31,8 @@
    {% for tag in alltags %}
  • -
    + + {% if fromdate %}{% endif %}
    @@ -33,11 +42,12 @@

Add tag

-
- + + {% if fromdate %}{% endif %} +
-{% include "page-bottom.html" %} +{% endblock %} diff --git a/templates/photo.html b/templates/photo.html index 8f0708b..6412cd6 100644 --- a/templates/photo.html +++ b/templates/photo.html @@ -1,7 +1,12 @@ +{% extends "page.html" %} {% set title = "Placeholder Title" %} {% set subtitle = image.uuid %} -{% include "page-top.html" %} +{% block buttons %} + xxx +{% endblock %} + +{% block body %}
@@ -60,7 +65,7 @@ @@ -68,5 +73,4 @@
- -{% include "page-bottom.html" %} +{% endblock %} diff --git a/templates/photo_tag.html b/templates/photo_tag.html index 1fb73d0..d13802d 100644 --- a/templates/photo_tag.html +++ b/templates/photo_tag.html @@ -5,7 +5,7 @@ {% block buttons %} xxx - +{% endblock %} {% block body %}