fnp
/
redakcja.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge with master.
[redakcja.git]
/
apps
/
catalogue
/
models
/
listeners.py
diff --git
a/apps/catalogue/models/listeners.py
b/apps/catalogue/models/listeners.py
index
de1387e
..
f98fba4
100755
(executable)
--- a/
apps/catalogue/models/listeners.py
+++ b/
apps/catalogue/models/listeners.py
@@
-5,7
+5,8
@@
#
from django.contrib.auth.models import User
from django.db import models
#
from django.contrib.auth.models import User
from django.db import models
-from catalogue.models import Book, Chunk, Image
+from catalogue.models import (Book, Chunk, Image, BookPublishRecord,
+ ImagePublishRecord)
from catalogue.signals import post_publish
from dvcs.signals import post_publishable
from catalogue.signals import post_publish
from dvcs.signals import post_publishable
@@
-39,16
+40,24
@@
models.signals.post_save.connect(user_changed, sender=User)
def publish_listener(sender, *args, **kwargs):
def publish_listener(sender, *args, **kwargs):
- sender.book.touch()
- for c in sender.book:
- c.touch()
+ if isinstance(sender, BookPublishRecord):
+ sender.book.touch()
+ for c in sender.book:
+ c.touch()
+ elif isinstance(sender, ImagePublishRecord):
+ sender.image.touch()
post_publish.connect(publish_listener)
post_publish.connect(publish_listener)
+def chunk_publishable_listener(sender, *args, **kwargs):
+ sender.tree.touch()
+ if isinstance(sender.tree, Chunk):
+ sender.tree.book.touch()
+post_publishable.connect(chunk_publishable_listener)
+
def publishable_listener(sender, *args, **kwargs):
sender.tree.touch()
def publishable_listener(sender, *args, **kwargs):
sender.tree.touch()
- sender.tree.book.touch()
-post_publishable.connect(publishable_listener)
+post_publishable.connect(publishable_listener, sender=Image)
def listener_create(sender, instance, created, **kwargs):
def listener_create(sender, instance, created, **kwargs):