From 78e8e474570281219830844ca29076fad52b5020 Mon Sep 17 00:00:00 2001
From: Nick Retallack <nickretallack@gmil.com>
Date: Sun, 4 Oct 2009 13:20:32 -0700
Subject: [PATCH] delete tags by clicking the x, or typing in -tagtext

---
 floof/controllers/tag.py           | 20 ++++++++++++++++++++
 floof/model/art.py                 | 28 ++++++++++++++++++++--------
 floof/templates/art/show.mako      |  3 ++-
 floof/tests/functional/test_tag.py |  7 +++++++
 4 files changed, 49 insertions(+), 9 deletions(-)
 create mode 100644 floof/controllers/tag.py
 create mode 100644 floof/tests/functional/test_tag.py

diff --git a/floof/controllers/tag.py b/floof/controllers/tag.py
new file mode 100644
index 0000000..3b69ed6
--- /dev/null
+++ b/floof/controllers/tag.py
@@ -0,0 +1,20 @@
+import logging
+
+from pylons import request, response, session, tmpl_context as c
+from pylons.controllers.util import abort, redirect_to
+
+from floof.lib.base import BaseController, render
+
+log = logging.getLogger(__name__)
+
+import elixir
+from floof.model.art import Tag
+
+class TagController(BaseController):
+
+    def delete(self, id):
+        tag = Tag.get(id)
+        if tag:
+            elixir.session.delete(tag)
+            elixir.session.commit()
+        redirect_to(request.referrer)
\ No newline at end of file
diff --git a/floof/model/art.py b/floof/model/art.py
index 420dff8..58601a7 100644
--- a/floof/model/art.py
+++ b/floof/model/art.py
@@ -6,6 +6,7 @@
 
 # from elixir import Entity, Field, Integer, Unicode
 from elixir import *
+import elixir
 
 from pylons import config
 
@@ -42,14 +43,25 @@ class Art(Entity):
 
 
     def add_tags(self, tags, user):
-        for tag in tags.split():
-            if len(tag) > 50:
-                raise "Long Tag!" # can we handle this more gracefully?
-            # sqlite seems happy to store strings much longer than the supplied limit...
-
-            # elixir should really have its own find_or_create.
-            tagtext = find_or_create(TagText, text=tag)
-            tag     = find_or_create(Tag, art=self, tagger=user, tagtext=tagtext)
+        for text in tags.split():
+            if text[0] == '-':
+                # Nega-tags
+                tagtext = TagText.get_by(text=text[1:])
+                if tagtext:
+                    tag = Tag.get_by(art=self, tagger=user, tagtext=tagtext)
+                    if tag:
+                        elixir.session.delete(tag)
+
+            else: 
+                if len(text) > 50:
+                    raise "Long Tag!" # can we handle this more gracefully?
+                # sqlite seems happy to store strings much longer than the supplied limit...
+
+
+
+                # elixir should really have its own find_or_create.
+                tagtext = find_or_create(TagText, text=text)
+                tag     = find_or_create(Tag, art=self, tagger=user, tagtext=tagtext)
 
 
     def __unicode__(self):
diff --git a/floof/templates/art/show.mako b/floof/templates/art/show.mako
index 88e3ec9..d77f364 100644
--- a/floof/templates/art/show.mako
+++ b/floof/templates/art/show.mako
@@ -8,7 +8,8 @@ ${h.submit('submit', 'Tag!')}
 ${h.end_form()}
 
 % for tag in c.art.tags:
-${tag}
+<a href="${h.url_for (controller='tag', action='delete', id=tag.id)}">x</a> 
+<a href="${h.url_for (controller='search', action='results')}?query=${tag}">${tag}</a>
 % endfor
 
 
diff --git a/floof/tests/functional/test_tag.py b/floof/tests/functional/test_tag.py
new file mode 100644
index 0000000..8424b43
--- /dev/null
+++ b/floof/tests/functional/test_tag.py
@@ -0,0 +1,7 @@
+from floof.tests import *
+
+class TestTagController(TestController):
+
+    def test_index(self):
+        response = self.app.get(url(controller='tag', action='index'))
+        # Test response...
-- 
2.7.4