author | sylvain.thenault@logilab.fr |
Wed, 29 Apr 2009 10:29:03 +0200 | |
branch | tls-sprint |
changeset 1533 | bcd4bfff658b |
parent 1498 | 2c6eec0b46b9 |
child 1639 | 375c857aa0f5 |
permissions | -rw-r--r-- |
0 | 1 |
"""Primary view for bookmarks + user's bookmarks box |
2 |
||
3 |
:organization: Logilab |
|
1151 | 4 |
:copyright: 2001-2009 LOGILAB S.A. (Paris, FRANCE), all rights reserved. |
0 | 5 |
:contact: http://www.logilab.fr/ -- mailto:contact@logilab.fr |
6 |
""" |
|
7 |
__docformat__ = "restructuredtext en" |
|
8 |
||
9 |
from logilab.mtconverter import html_escape |
|
10 |
||
11 |
from cubicweb import Unauthorized |
|
692
800592b8d39b
replace deprecated cubicweb.common.selectors by its new module path (cubicweb.selectors)
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
631
diff
changeset
|
12 |
from cubicweb.selectors import implements |
0 | 13 |
from cubicweb.web.htmlwidgets import BoxWidget, BoxMenu, RawBoxItem |
1498
2c6eec0b46b9
fix imports, cleanup, repair some ajax calls
sylvain.thenault@logilab.fr
parents:
1321
diff
changeset
|
14 |
from cubicweb.web import uicfg, action, box, formwidgets |
0 | 15 |
from cubicweb.web.views.baseviews import PrimaryView |
1151 | 16 |
|
1533 | 17 |
uicfg.rcategories.tag_relation('primary', ('Bookmark', 'path', '*'), 'subject') |
18 |
uicfg.rwidgets.tag_relation(formwidgets.TextInput, ('Bookmark', 'path', '*'), 'subject') |
|
0 | 19 |
|
20 |
||
1321
c5655237f08a
we have now actual classes in rwidgets
sylvain.thenault@logilab.fr
parents:
1153
diff
changeset
|
21 |
class FollowAction(action.Action): |
631
99f5852f8604
major selector refactoring (mostly to avoid looking for select parameters on the target class), start accept / interface unification)
sylvain.thenault@logilab.fr
parents:
0
diff
changeset
|
22 |
id = 'follow' |
742
99115e029dca
replaced most of __selectors__ assignments with __select__
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
692
diff
changeset
|
23 |
__select__ = implements('Bookmark') |
631
99f5852f8604
major selector refactoring (mostly to avoid looking for select parameters on the target class), start accept / interface unification)
sylvain.thenault@logilab.fr
parents:
0
diff
changeset
|
24 |
|
99f5852f8604
major selector refactoring (mostly to avoid looking for select parameters on the target class), start accept / interface unification)
sylvain.thenault@logilab.fr
parents:
0
diff
changeset
|
25 |
title = _('follow') |
99f5852f8604
major selector refactoring (mostly to avoid looking for select parameters on the target class), start accept / interface unification)
sylvain.thenault@logilab.fr
parents:
0
diff
changeset
|
26 |
category = 'mainactions' |
1498
2c6eec0b46b9
fix imports, cleanup, repair some ajax calls
sylvain.thenault@logilab.fr
parents:
1321
diff
changeset
|
27 |
|
631
99f5852f8604
major selector refactoring (mostly to avoid looking for select parameters on the target class), start accept / interface unification)
sylvain.thenault@logilab.fr
parents:
0
diff
changeset
|
28 |
def url(self): |
99f5852f8604
major selector refactoring (mostly to avoid looking for select parameters on the target class), start accept / interface unification)
sylvain.thenault@logilab.fr
parents:
0
diff
changeset
|
29 |
return self.rset.get_entity(self.row or 0, self.col or 0).actual_url() |
99f5852f8604
major selector refactoring (mostly to avoid looking for select parameters on the target class), start accept / interface unification)
sylvain.thenault@logilab.fr
parents:
0
diff
changeset
|
30 |
|
99f5852f8604
major selector refactoring (mostly to avoid looking for select parameters on the target class), start accept / interface unification)
sylvain.thenault@logilab.fr
parents:
0
diff
changeset
|
31 |
|
0 | 32 |
class BookmarkPrimaryView(PrimaryView): |
742
99115e029dca
replaced most of __selectors__ assignments with __select__
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
692
diff
changeset
|
33 |
__select__ = implements('Bookmark') |
1498
2c6eec0b46b9
fix imports, cleanup, repair some ajax calls
sylvain.thenault@logilab.fr
parents:
1321
diff
changeset
|
34 |
|
0 | 35 |
def cell_call(self, row, col): |
36 |
"""the primary view for bookmark entity""" |
|
37 |
entity = self.complete_entity(row, col) |
|
38 |
self.w(u' ') |
|
39 |
self.w(u"<span class='title'><b>") |
|
40 |
self.w(u"%s : %s" % (self.req._('Bookmark'), html_escape(entity.title))) |
|
41 |
self.w(u"</b></span>") |
|
42 |
self.w(u'<br/><br/><div class="content"><a href="%s">' % ( |
|
43 |
html_escape(entity.actual_url()))) |
|
44 |
self.w(u'</a>') |
|
45 |
self.w(u'<p>%s%s</p>' % (self.req._('Used by:'), ', '.join(html_escape(u.name()) |
|
46 |
for u in entity.bookmarked_by))) |
|
47 |
self.w(u'</div>') |
|
48 |
||
49 |
||
1498
2c6eec0b46b9
fix imports, cleanup, repair some ajax calls
sylvain.thenault@logilab.fr
parents:
1321
diff
changeset
|
50 |
class BookmarksBox(box.UserRQLBoxTemplate): |
0 | 51 |
"""display a box containing all user's bookmarks""" |
52 |
id = 'bookmarks_box' |
|
53 |
order = 40 |
|
54 |
title = _('bookmarks') |
|
55 |
rql = ('Any B,T,P ORDERBY lower(T) ' |
|
56 |
'WHERE B is Bookmark,B title T, B path P, B bookmarked_by U, ' |
|
57 |
'U eid %(x)s') |
|
58 |
etype = 'Bookmark' |
|
59 |
rtype = 'bookmarked_by' |
|
1498
2c6eec0b46b9
fix imports, cleanup, repair some ajax calls
sylvain.thenault@logilab.fr
parents:
1321
diff
changeset
|
60 |
|
2c6eec0b46b9
fix imports, cleanup, repair some ajax calls
sylvain.thenault@logilab.fr
parents:
1321
diff
changeset
|
61 |
|
0 | 62 |
def call(self, **kwargs): |
63 |
req = self.req |
|
64 |
ueid = req.user.eid |
|
65 |
try: |
|
66 |
rset = req.execute(self.rql, {'x': ueid}) |
|
67 |
except Unauthorized: |
|
68 |
# can't access to something in the query, forget this box |
|
69 |
return |
|
70 |
box = BoxWidget(req._(self.title), self.id) |
|
71 |
box.listing_class = 'sideBox' |
|
72 |
rschema = self.schema.rschema(self.rtype) |
|
73 |
eschema = self.schema.eschema(self.etype) |
|
74 |
candelete = rschema.has_perm(req, 'delete', toeid=ueid) |
|
75 |
if candelete: |
|
76 |
req.add_js( ('cubicweb.ajax.js', 'cubicweb.bookmarks.js') ) |
|
77 |
else: |
|
78 |
dlink = None |
|
79 |
for bookmark in rset.entities(): |
|
80 |
label = '<a href="%s">%s</a>' % (html_escape(bookmark.action_url()), |
|
81 |
html_escape(bookmark.title)) |
|
82 |
if candelete: |
|
83 |
dlink = u'[<a href="javascript:removeBookmark(%s)" title="%s">-</a>]' % ( |
|
84 |
bookmark.eid, _('delete this bookmark')) |
|
85 |
label = '%s %s' % (dlink, label) |
|
852
105893288777
simplify css style
Julien Jehannet <julien.jehannet@logilab.fr>
parents:
0
diff
changeset
|
86 |
box.append(RawBoxItem(label)) |
0 | 87 |
if eschema.has_perm(req, 'add') and rschema.has_perm(req, 'add', toeid=ueid): |
852
105893288777
simplify css style
Julien Jehannet <julien.jehannet@logilab.fr>
parents:
0
diff
changeset
|
88 |
boxmenu = BoxMenu(req._('manage bookmarks')) |
0 | 89 |
linkto = 'bookmarked_by:%s:subject' % ueid |
90 |
# use a relative path so that we can move the application without |
|
91 |
# loosing bookmarks |
|
92 |
path = req.relative_path() |
|
93 |
url = self.create_url(self.etype, __linkto=linkto, path=path) |
|
94 |
boxmenu.append(self.mk_action(req._('bookmark this page'), url, |
|
95 |
category='manage', id='bookmark')) |
|
96 |
if rset: |
|
97 |
if req.user.is_in_group('managers'): |
|
98 |
bookmarksrql = 'Bookmark B WHERE B bookmarked_by U, U eid %s' % ueid |
|
99 |
erset = rset |
|
100 |
else: |
|
101 |
# we can't edit shared bookmarks we don't own |
|
102 |
bookmarksrql = 'Bookmark B WHERE B bookmarked_by U, B owned_by U, U eid %(x)s' |
|
103 |
erset = req.execute(bookmarksrql, {'x': ueid}, 'x', |
|
104 |
build_descr=False) |
|
105 |
bookmarksrql %= {'x': ueid} |
|
106 |
if erset: |
|
107 |
url = self.build_url(vid='muledit', rql=bookmarksrql) |
|
108 |
boxmenu.append(self.mk_action(self.req._('edit bookmarks'), url, category='manage')) |
|
109 |
url = req.user.absolute_url(vid='xaddrelation', rtype='bookmarked_by', |
|
110 |
target='subject') |
|
111 |
boxmenu.append(self.mk_action(self.req._('pick existing bookmarks'), url, category='manage')) |
|
112 |
box.append(boxmenu) |
|
113 |
if not box.is_empty(): |
|
114 |
box.render(self.w) |