user_workspace_widgets.mak 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. <%namespace name="TIM" file="tracim.templates.pod"/>
  2. <%namespace name="ICON" file="tracim.templates.widgets.icon"/>
  3. <%def name="BREADCRUMB(dom_id, breadcrumb_items)">
  4. <ul id="${dom_id}" class="breadcrumb" style="margin-top: -1.5em; display: none;">
  5. % for item in breadcrumb_items:
  6. % if item.is_active:
  7. <li class="active">${TIM.ICO(16, item.icon)} ${item.label}</li>
  8. % else:
  9. <li>${TIM.ICO(16, item.icon)} <a href="${item.url}">${item.label}</a></li>
  10. % endif
  11. % endfor
  12. </ul>
  13. </%def>
  14. <%def name="EMPTY_CONTENT(empty_content_label)"><p class="pod-empty">${empty_content_label|n}</p></%def>
  15. <%def name="DATA_TARGET_BUTTON(dom_id, label)"><a data-toggle="collapse" data-target="#${dom_id}"><b>${label}</b></a></%def>
  16. <%def name="SECURED_SECTION_TITLE(user, workspace, dom_id, label, action_dom_id='', action_label='', icon_size='', icon_path='')">
  17. <h4 id="${dom_id}">
  18. ${TIM.ICO(icon_size, icon_path) if icon_path else ''}
  19. ${label}
  20. ## Button is shown for contributors (or more), not for readers
  21. % if h.user_role(user, workspace)>1:
  22. % if action_dom_id and action_label:
  23. <small style="margin-left: 1em;"> ${DATA_TARGET_BUTTON(action_dom_id, action_label)}</small>
  24. % endif
  25. % endif
  26. </h4>
  27. </%def>
  28. <%def name="FOLDER_LIST(dom_id, workspace_id, folders)">
  29. % if len(folders)<=0:
  30. ${EMPTY_CONTENT(_('No folder found.'))|n}
  31. % else:
  32. <table id="${dom_id}" class="table table-striped table-hover">
  33. % for folder in folders:
  34. <tr>
  35. <td><a href="${tg.url('/workspaces/{}/folders/{}'.format(workspace_id, folder.id))}">${TIM.ICO(16, 'places/jstree-folder')} ${folder.label}</a></td>
  36. <td>
  37. % if folder.content_nb.all==0:
  38. <span class="pod-empty-item">${_('This folder is empty')}</span>
  39. % else:
  40. % if folder.folder_nb.all>=1:
  41. ${_('{nb_total} subfolder(s)').format(nb_total=folder.folder_nb.all)|n}
  42. % endif
  43. % if folder.thread_nb.all>=1:
  44. ${_('{nb_total} thread(s) &mdash; {nb_open} open').format(nb_total=folder.thread_nb.all, nb_open=folder.thread_nb.open)|n}
  45. <br/>
  46. % endif
  47. % if folder.file_nb.all>=1:
  48. ${_('{nb_total} file(s) &mdash; {nb_open} open').format(nb_total=folder.file_nb.all, nb_open=folder.file_nb.open)|n}
  49. <br/>
  50. % endif
  51. % if folder.page_nb.all>=1:
  52. ${_('{nb_total} page(s) &mdash; {nb_open} open').format(nb_total=folder.page_nb.all, nb_open=folder.page_nb.open)|n}
  53. <br/>
  54. % endif
  55. % endif
  56. </td>
  57. </tr>
  58. % endfor
  59. </table>
  60. % endif
  61. </%def>
  62. <%def name="PAGE_LIST(dom_id, workspace_id, pages)">
  63. % if len(pages)<=0:
  64. ${EMPTY_CONTENT(_('No page found.'))}
  65. % else:
  66. <table id="${dom_id}" class="table table-striped table-hover">
  67. <tr>
  68. <th>${_('Type')}</th>
  69. <th>${_('Title')}</th>
  70. <th colspan="2">${_('Status')}</th>
  71. </tr>
  72. % for page in pages:
  73. <tr>
  74. <td>
  75. <span class="tracim-less-visible"><i class="fa fa-file-text-o fa-tw"></i> page</span>
  76. </td>
  77. <td>
  78. <a href="${tg.url('/workspaces/{}/folders/{}/pages/{}'.format(workspace_id, page.folder.id, page.id))}">${page.label}</a>
  79. </td>
  80. <td>
  81. % if 'open' == page.status.id:
  82. <i class="fa fa-fw fa-square-o"></i>
  83. % elif 'closed-validated' == page.status.id:
  84. <i class="fa fa-fw fa-check-square-o"></i>
  85. % elif 'closed-unvalidated' == page.status.id:
  86. <i class="fa fa-fw fa-check-square-o"></i>
  87. % elif 'closed-deprecated' == page.status.id:
  88. <i class="fa fa-fw fa-bell-slash-o"></i>
  89. % else:
  90. <i class="fa fa-fw fa-close"></i>
  91. % endif
  92. </td>
  93. <td>
  94. ${page.status.label}
  95. ## ${page.status.id}
  96. ## ${TIM.ICO(16, page.status.icon)} <span class="${page.status.css}">${page.status.label}</span>
  97. </td>
  98. </tr>
  99. % endfor
  100. </table>
  101. % endif
  102. </%def>
  103. <%def name="FILE_LIST(dom_id, workspace_id, files)">
  104. % if len(files)<=0:
  105. ${EMPTY_CONTENT(_('No file found.'))}
  106. % else:
  107. <table id="${dom_id}" class="table table-striped table-hover">
  108. % for curfile in files:
  109. <tr>
  110. <td><a href="${tg.url('/workspaces/{}/folders/{}/files/{}'.format(workspace_id, curfile.folder.id, curfile.id))}">${TIM.ICO(16, 'mimetypes/text-html')} ${curfile.label}</a></td>
  111. <td>
  112. ${TIM.ICO(16, curfile.status.icon)} <span class="${curfile.status.css}">${curfile.status.label}</span>
  113. </td>
  114. </tr>
  115. % endfor
  116. </table>
  117. % endif
  118. </%def>
  119. <%def name="THREAD_LIST(dom_id, workspace_id, threads)">
  120. % if len(threads)<=0:
  121. ${EMPTY_CONTENT(_('No thread found.'))}
  122. % else:
  123. <table id="${dom_id}" class="table table-striped table-hover">
  124. % for thread in threads:
  125. <tr>
  126. <td><a href="${tg.url('/workspaces/{}/folders/{}/threads/{}'.format(workspace_id, thread.folder.id, thread.id))}">${TIM.ICO(16, 'apps/internet-group-chat')} ${thread.label}</a></td>
  127. <td>${TIM.ICO(16, thread.status.icon)} <span class="${thread.status.css}">${thread.status.label}</span></td>
  128. <td>${_('{} message(s)').format(thread.comment_nb)}</td>
  129. </tr>
  130. % endfor
  131. </table>
  132. % endif
  133. </%def>
  134. <%def name="TREEVIEW(dom_id, selected_id='', uniq_workspace='0')">
  135. ## <% get_root_url = tg.url("/workspaces/treeview_root", dict(current_id=selected_id)) %>
  136. <div id='sidebarleft_menu'></div>
  137. <script src="${tg.url('/assets/js/sidebarleft.js')}"></script>
  138. <script>
  139. // (function () { })() is equivalent to window.onload (http://stackoverflow.com/questions/9899372/pure-javascript-equivalent-to-jquerys-ready-how-to-call-a-function-when-the)
  140. (function () {
  141. sidebarLeft(document.getElementById('sidebarleft_menu'), '/', '?current_id=${selected_id}')
  142. })()
  143. </script>
  144. </%def>
  145. <%def name="SECURED_SHOW_CHANGE_STATUS_FOR_FILE(user, workspace, item)">
  146. <% target_url = tg.url('/workspaces/{wid}/folders/{fid}/files/{pid}/put_status?status={{status_id}}').format(wid=item.workspace.id, fid=item.parent.id, pid=item.id) %>
  147. <% allow_status_change = h.user_role(user, workspace)>=2 and item.selected_revision=='latest' %>
  148. ${SHOW_CHANGE_STATUS(item, target_url, allow_status_change)}
  149. </%def>
  150. <%def name="SECURED_SHOW_CHANGE_STATUS_FOR_PAGE(user, workspace, item)">
  151. <% target_url = tg.url('/workspaces/{wid}/folders/{fid}/pages/{pid}/put_status?status={{status_id}}').format(wid=item.workspace.id, fid=item.parent.id, pid=item.id) %>
  152. <% allow_status_change = h.user_role(user, workspace)>=2 and item.selected_revision=='latest' %>
  153. ${SHOW_CHANGE_STATUS(item, target_url, allow_status_change)}
  154. </%def>
  155. <%def name="SECURED_SHOW_CHANGE_STATUS_FOR_THREAD(user, workspace, item)">
  156. <% target_url = tg.url('/workspaces/{wid}/folders/{fid}/threads/{pid}/put_status?status={{status_id}}').format(wid=item.workspace.id, fid=item.parent.id, pid=item.id) %>
  157. <% allow_status_change = h.user_role(user, workspace)>=2 and item.selected_revision=='latest' %>
  158. ## The user can't change status if he is a simple reader
  159. ${SHOW_CHANGE_STATUS(item, target_url, allow_status_change)}
  160. </%def>
  161. <%def name="SHOW_CHANGE_STATUS(item, target_url, allow_to_change_status=False)">
  162. <div class="btn-group pull-right">
  163. % if not allow_to_change_status:
  164. <button type="button" class="btn btn-default disable btn-link" title="${_('This operation is locked')}">
  165. <span class="${item.status.css}">${item.status.label} ${ICON.FA_FW_2X(item.status.icon)}</span>
  166. </button>
  167. % else:
  168. <button type="button" class="btn btn-default btn-link dropdown-toggle" data-toggle="dropdown">
  169. <span class="${item.status.css}">${item.status.label} ${ICON.FA_FW_2X(item.status.icon)}</span>
  170. </button>
  171. <ul class="dropdown-menu" role="menu">
  172. % for status in h.AllStatus(item.type):
  173. % if status.id == 'closed-deprecated':
  174. <li class="divider"></li>
  175. % endif
  176. <li class="text-right"><a
  177. class="${('', 'pod-status-selected')[status.id==item.status.id]}"
  178. href="${target_url.format(status_id=status.id)}">
  179. <span class="${status.css}">
  180. ${status.label} ${ICON.FA_FW(status.icon)}
  181. </span>
  182. </a></li>
  183. % endfor
  184. </ul>
  185. % endif
  186. </div>
  187. </%def>
  188. <%def name="SECURED_TIMELINE_ITEM(user, item)">
  189. ## <% created_localized = h.get_with_timezone(item.created) %>
  190. ## <div class="row t-odd-or-even t-hacky-thread-comment-border-top">
  191. ## <div class="col-sm-7 col-sm-offset-3">
  192. ## <div class="t-timeline-item">
  193. ## ## <i class="fa fa-fw fa-3x fa-comment-o t-less-visible" style="margin-left: -1.5em; float:left;"></i>
  194. ## ${ICON.FA_FW('fa fa-3x fa-comment-o t-less-visible t-timeline-item-icon')}
  195. ##
  196. ## <h5 style="margin: 0;">
  197. ## <span class="tracim-less-visible">${_('<strong>{}</strong> wrote:').format(item.owner.name)|n}</span>
  198. ##
  199. ## <div class="pull-right text-right t-timeline-item-moment" title="${h.date_time(created_localized)|n}">
  200. ## ${_('{delta} ago').format(delta=item.created_as_delta)}
  201. ##
  202. ## % if h.is_item_still_editable(item) and item.owner.id==user.id:
  203. ## <br/>
  204. ## ## <div class="btn-group">
  205. ## <a class="t-timeline-comment-delete-button" href="${item.urls.delete}">
  206. ## ${_('delete')} ${ICON.FA('fa fa-trash-o')}
  207. ## ## ${TIM.ICO_TOOLTIP(16, 'status/user-trash-full', h.delete_label_for_item(item))}
  208. ## </a>
  209. ## ## </div>
  210. ## % endif
  211. ## </div>
  212. ## </h5>
  213. ## <div class="t-timeline-item-content">
  214. ## <div>${item.content|n}</div>
  215. ## <br/>
  216. ## </div>
  217. ## </div>
  218. ## </div>
  219. ## </div>
  220. </%def>
  221. <%def name="SECURED_HISTORY_VIRTUAL_EVENT(user, event)">
  222. <% created_localized = h.get_with_timezone(event.created) %>
  223. <% is_new_css_class = 't-is-new-content' if event.is_new else '' %>
  224. <div class="t-odd-or-even t-hacky-thread-comment-border-top ${is_new_css_class}">
  225. <div class="">
  226. <div class="t-timeline-item">
  227. ## <i class="fa fa-fw fa-3x fa-comment-o t-less-visible" style="margin-left: -1.5em; float:left;"></i>
  228. ${ICON.FA_FW('fa fa-3x t-less-visible t-timeline-item-icon '+event.type.icon)}
  229. <h5 style="margin: 0;">
  230. % if 'comment' == event.type.id:
  231. <span class="tracim-less-visible">${_('<strong>{}</strong> wrote:').format(event.owner.name)|n}</span>
  232. %else:
  233. <span class="tracim-less-visible">${_('{} by <strong>{}</strong>').format(event.label, event.owner.name)|n}</span>
  234. % endif
  235. <div class="pull-right text-right t-timeline-item-moment" title="${h.date_time(created_localized)|n}">
  236. ${_('{delta} ago').format(delta=event.created_as_delta)}
  237. % if h.is_item_still_editable(CFG, event) and event.owner.id==user.id:
  238. <br/>
  239. <a class="t-timeline-comment-delete-button" href="${event.urls.delete}">
  240. ${_('delete')} ${ICON.FA('fa fa-trash-o')}
  241. </a>
  242. % endif
  243. </div>
  244. </h5>
  245. <div class="t-timeline-item-content">
  246. <div>${event.content|n}</div>
  247. <br/>
  248. </div>
  249. </div>
  250. </div>
  251. </div>
  252. </%def>
  253. <%def name="SECURED_HISTORY_VIRTUAL_EVENT_AS_TABLE_ROW(user, event, current_revision_id)">
  254. <% created_localized = h.get_with_timezone(event.created) %>
  255. <%
  256. warning_or_not = ('', 'warning')[current_revision_id==event.id]
  257. row_css = 't-is-new-content' if event.is_new else warning_or_not
  258. %>
  259. <tr class="${row_css}">
  260. <td class="t-less-visible">
  261. <span class="label label-default">${ICON.FA_FW(event.type.icon)} ${event.type.label}</span>
  262. </td>
  263. <td title="${h.date_time(created_localized)|n}">${_('{delta} ago').format(delta=event.created_as_delta)}</td>
  264. <td>${event.owner.name}</td>
  265. ## FIXME - REMOVE <td>${event}</td>
  266. % if 'comment' == event.type.id:
  267. <td colspan="2">
  268. ${event.content|n}
  269. </td>
  270. % else:
  271. <td>
  272. % if event.type.id in ('creation', 'edition', 'revision'):
  273. <a href="${'?revision_id={}'.format(event.id)}">${_('View revision')}</a>
  274. % endif
  275. </td>
  276. <td class="t-less-visible" title="${_('Currently shown')}">
  277. % if warning_or_not:
  278. ${ICON.FA_FW('fa fa-caret-left')}&nbsp;${_('shown')}
  279. % endif
  280. </td>
  281. % endif
  282. </tr>
  283. </%def>