fnp
/
wolnelektury.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Cites: sticky and custom backgrounds.
[wolnelektury.git]
/
apps
/
social
/
templatetags
/
social_tags.py
diff --git
a/apps/social/templatetags/social_tags.py
b/apps/social/templatetags/social_tags.py
index
29a4309
..
8891602
100755
(executable)
--- a/
apps/social/templatetags/social_tags.py
+++ b/
apps/social/templatetags/social_tags.py
@@
-12,9
+12,9
@@
register = template.Library()
register.filter('likes', likes)
register.filter('likes', likes)
-@register.
inclusion_tag('social/cite_promo.html',
takes_context=True)
-def c
ite_promo(context, ctx=None, fallback=Fals
e):
- """Choose"""
+@register.
assignment_tag(
takes_context=True)
+def c
hoose_cite(context, ctx=Non
e):
+ """Choose
a cite for main page, for book or for set of tags.
"""
try:
request = context['request']
assert request.user.is_staff
try:
request = context['request']
assert request.user.is_staff
@@
-29,10
+29,21
@@
def cite_promo(context, ctx=None, fallback=False):
cites = cites_for_tags([ctx.book_tag()])
else:
cites = cites_for_tags(ctx)
cites = cites_for_tags([ctx.book_tag()])
else:
cites = cites_for_tags(ctx)
- cite = cites.order_by('?')[0] if cites.exists() else None
+ cite = cites.order_by('-sticky', '?')[0] if cites.exists() else None
+ return cite
+
+@register.inclusion_tag('social/cite_promo.html')
+def render_cite(cite):
return {
'cite': cite,
return {
'cite': cite,
+ }
+
+
+@register.inclusion_tag('social/cite_promo.html', takes_context=True)
+def cite_promo(context, ctx=None, fallback=False):
+ return {
+ 'cite': choose_cite(context, ctx),
'fallback': fallback,
'ctx': ctx,
}
'fallback': fallback,
'ctx': ctx,
}