boardHeader.jade 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. template(name="boardHeaderBar")
  2. h1.header-board-menu
  3. with currentBoard
  4. if $eq title 'Templates'
  5. | {{_ 'templates'}}
  6. else
  7. +viewer
  8. = title
  9. .board-header-btns.left
  10. unless isMiniScreen
  11. if currentBoard
  12. if currentUser
  13. with currentBoard
  14. if currentUser.isBoardAdmin
  15. a.board-header-btn(class="{{#if currentUser.isBoardAdmin}}js-edit-board-title{{else}}is-disabled{{/if}}" title="{{_ 'edit'}}" value=title)
  16. i.fa.fa-pencil-square-o
  17. a.board-header-btn.js-star-board(class="{{#if isStarred}}is-active{{/if}}"
  18. title="{{#if isStarred}}{{_ 'click-to-unstar'}}{{else}}{{_ 'click-to-star'}}{{/if}} {{_ 'starred-boards-description'}}")
  19. i.fa(class="fa-star{{#unless isStarred}}-o{{/unless}}")
  20. if showStarCounter
  21. span
  22. = currentBoard.stars
  23. a.board-header-btn.js-auto-width-board(
  24. title="{{#if isAutoWidth}}{{_ 'click-to-disable-auto-width'}}{{else}}{{_ 'click-to-enable-auto-width'}}{{/if}}")
  25. i.fa(class="fa-solid fa-{{#if isAutoWidth}}compress{{else}}expand{{/if}}")
  26. a.board-header-btn.js-keyboard-shortcuts-toggle(
  27. title="{{#if isKeyboardShortcuts}}{{_ 'click-to-disable-keyboard-shortcuts'}}{{else}}{{_ 'click-to-enable-keyboard-shortcuts'}}{{/if}}")
  28. i.fa(class="fa-solid fa-{{#if isKeyboardShortcuts}}computer-mouse{{else}}keyboard{{/if}}")
  29. a.board-header-btn(
  30. class="{{#if currentUser.isBoardAdmin}}js-change-visibility{{else}}is-disabled{{/if}}"
  31. title="{{_ currentBoard.permission}}")
  32. i.fa(class="{{#if currentBoard.isPublic}}fa-globe{{else}}fa-lock{{/if}}")
  33. span {{_ currentBoard.permission}}
  34. a.board-header-btn.js-watch-board(
  35. title="{{_ watchLevel }}")
  36. if $eq watchLevel "watching"
  37. i.fa.fa-eye
  38. if $eq watchLevel "tracking"
  39. i.fa.fa-bell
  40. if $eq watchLevel "muted"
  41. i.fa.fa-bell-slash
  42. span {{_ watchLevel}}
  43. a.board-header-btn(title="{{_ 'sort-cards'}}" class="{{#if isSortActive }}emphasis{{else}} js-sort-cards {{/if}}")
  44. i.fa.fa-sort
  45. span {{#if isSortActive }}{{_ 'sort-is-on'}}{{else}}{{_ 'sort-cards'}}{{/if}}
  46. if isSortActive
  47. a.board-header-btn-close.js-sort-reset(title="{{_ 'remove-sort'}}")
  48. i.fa.fa-times-thin
  49. else
  50. a.board-header-btn.js-log-in(
  51. title="{{_ 'log-in'}}")
  52. i.fa.fa-sign-in
  53. span {{_ 'log-in'}}
  54. .board-header-btns.right
  55. if currentBoard
  56. if isMiniScreen
  57. if currentUser
  58. with currentBoard
  59. a.board-header-btn(class="{{#if currentUser.isBoardAdmin}}js-edit-board-title{{else}}is-disabled{{/if}}" title="{{_ 'edit'}}" value=title)
  60. i.fa.fa-pencil-square-o
  61. a.board-header-btn.js-star-board(class="{{#if isStarred}}is-active{{/if}}"
  62. title="{{#if isStarred}}{{_ 'click-to-unstar'}}{{else}}{{_ 'click-to-star'}}{{/if}} {{_ 'starred-boards-description'}}")
  63. i.fa(class="fa-star{{#unless isStarred}}-o{{/unless}}")
  64. if showStarCounter
  65. span
  66. = currentBoard.stars
  67. a.board-header-btn.js-auto-width-board(
  68. title="{{#if isAutoWidth}}{{_ 'click-to-disable-auto-width'}}{{else}}{{_ 'click-to-enable-auto-width'}}{{/if}}")
  69. i.fa(class="fa-solid fa-{{#if isAutoWidth}}compress{{else}}expand{{/if}}")
  70. a.board-header-btn.js-keyboard-shortcuts-toggle(
  71. title="{{#if isKeyboardShortcuts}}{{_ 'click-to-disable-keyboard-shortcuts'}}{{else}}{{_ 'click-to-enable-keyboard-shortcuts'}}{{/if}}")
  72. i.fa(class="fa-solid fa-{{#if isKeyboardShortcuts}}computer-mouse{{else}}keyboard{{/if}}")
  73. a.board-header-btn(
  74. class="{{#if currentUser.isBoardAdmin}}js-change-visibility{{else}}is-disabled{{/if}}"
  75. title="{{_ currentBoard.permission}}")
  76. i.fa(class="{{#if currentBoard.isPublic}}fa-globe{{else}}fa-lock{{/if}}")
  77. span {{_ currentBoard.permission}}
  78. a.board-header-btn.js-watch-board(
  79. title="{{_ watchLevel }}")
  80. if $eq watchLevel "watching"
  81. i.fa.fa-eye
  82. if $eq watchLevel "tracking"
  83. i.fa.fa-bell
  84. if $eq watchLevel "muted"
  85. i.fa.fa-bell-slash
  86. span {{_ watchLevel}}
  87. a.board-header-btn(title="{{_ 'sort-cards'}}" class="{{#if isSortActive }}emphasis{{else}} js-sort-cards {{/if}}")
  88. i.fa.fa-sort
  89. span {{#if isSortActive }}{{_ 'sort-is-on'}}{{else}}{{_ 'sort-cards'}}{{/if}}
  90. if isSortActive
  91. a.board-header-btn-close.js-sort-reset(title="{{_ 'remove-sort'}}")
  92. i.fa.fa-times-thin
  93. else
  94. a.board-header-btn.js-log-in(
  95. title="{{_ 'log-in'}}")
  96. i.fa.fa-sign-in
  97. span {{_ 'log-in'}}
  98. if isSandstorm
  99. if currentUser
  100. a.board-header-btn.js-open-archived-board
  101. i.fa.fa-archive
  102. span {{_ 'archives'}}
  103. //if showSort
  104. // a.board-header-btn.js-open-sort-view(title="{{_ 'sort-desc'}}")
  105. // i.fa(class="{{directionClass}}")
  106. // span {{_ 'sort'}}{{_ listSortShortDesc}}
  107. a.board-header-btn.js-open-filter-view(
  108. title="{{#if Filter.isActive}}{{_ 'filter-on-desc'}}{{else}}{{_ 'filter'}}{{/if}}"
  109. class="{{#if Filter.isActive}}emphasis{{/if}}")
  110. i.fa.fa-filter
  111. span {{#if Filter.isActive}}{{_ 'filter-on'}}{{else}}{{_ 'filter'}}{{/if}}
  112. if Filter.isActive
  113. a.board-header-btn-close.js-filter-reset(title="{{_ 'filter-clear'}}")
  114. i.fa.fa-times-thin
  115. a.board-header-btn.js-open-search-view(title="{{_ 'search'}}")
  116. i.fa.fa-search
  117. span {{_ 'search'}}
  118. unless currentBoard.isTemplatesBoard
  119. a.board-header-btn.js-toggle-board-view(
  120. title="{{_ 'board-view'}}")
  121. i.fa.fa-caret-down
  122. if $eq boardView 'board-view-swimlanes'
  123. i.fa.fa-th-large
  124. if $eq boardView 'board-view-lists'
  125. i.fa.fa-trello
  126. if $eq boardView 'board-view-cal'
  127. i.fa.fa-calendar
  128. span {{#if boardView}}{{_ boardView}}{{else}}{{_ 'board-view-swimlanes'}}{{/if}}
  129. if canModifyBoard
  130. a.board-header-btn.js-multiselection-activate(
  131. title="{{#if MultiSelection.isActive}}{{_ 'multi-selection-on'}}{{else}}{{_ 'multi-selection'}}{{/if}}"
  132. class="{{#if MultiSelection.isActive}}emphasis{{/if}}")
  133. i.fa.fa-check-square-o
  134. span {{#if MultiSelection.isActive}}{{_ 'multi-selection-on'}}{{else}}{{_ 'multi-selection'}}{{/if}}
  135. if MultiSelection.isActive
  136. a.board-header-btn-close.js-multiselection-reset(title="{{_ 'filter-clear'}}")
  137. i.fa.fa-times-thin
  138. .separator
  139. a.board-header-btn.js-toggle-sidebar(title="{{_ 'sidebar-open'}} {{_ 'or'}} {{_ 'sidebar-close'}}")
  140. i.fa.fa-navicon
  141. template(name="boardVisibilityList")
  142. ul.pop-over-list
  143. li
  144. with "private"
  145. a.js-select-visibility
  146. i.fa.fa-lock.colorful
  147. | {{_ 'private'}}
  148. if visibilityCheck
  149. i.fa.fa-check
  150. span.sub-name {{_ 'private-desc'}}
  151. if notAllowPrivateVisibilityOnly
  152. li
  153. with "public"
  154. a.js-select-visibility
  155. i.fa.fa-globe.colorful
  156. | {{_ 'public'}}
  157. if visibilityCheck
  158. i.fa.fa-check
  159. span.sub-name {{_ 'public-desc'}}
  160. template(name="boardChangeVisibilityPopup")
  161. +boardVisibilityList
  162. template(name="boardChangeWatchPopup")
  163. ul.pop-over-list
  164. li
  165. with "watching"
  166. a.js-select-watch
  167. i.fa.fa-eye.colorful
  168. | {{_ 'watching'}}
  169. if watchCheck
  170. i.fa.fa-check
  171. span.sub-name {{_ 'watching-info'}}
  172. li
  173. with "tracking"
  174. a.js-select-watch
  175. i.fa.fa-bell.colorful
  176. | {{_ 'tracking'}}
  177. if watchCheck
  178. i.fa.fa-check
  179. span.sub-name {{_ 'tracking-info'}}
  180. li
  181. with "muted"
  182. a.js-select-watch
  183. i.fa.fa-bell-slash.colorful
  184. | {{_ 'muted'}}
  185. if watchCheck
  186. i.fa.fa-check
  187. span.sub-name {{_ 'muted-info'}}
  188. template(name="boardChangeViewPopup")
  189. ul.pop-over-list
  190. li
  191. with "board-view-swimlanes"
  192. a.js-open-swimlanes-view
  193. i.fa.fa-th-large.colorful
  194. | {{_ 'board-view-swimlanes'}}
  195. if $eq Utils.boardView "board-view-swimlanes"
  196. i.fa.fa-check
  197. li
  198. with "board-view-lists"
  199. a.js-open-lists-view
  200. i.fa.fa-trello.colorful
  201. | {{_ 'board-view-lists'}}
  202. if $eq Utils.boardView "board-view-lists"
  203. i.fa.fa-check
  204. li
  205. with "board-view-cal"
  206. a.js-open-cal-view
  207. i.fa.fa-calendar.colorful
  208. | {{_ 'board-view-cal'}}
  209. if $eq Utils.boardView "board-view-cal"
  210. i.fa.fa-check
  211. template(name="createBoard")
  212. form
  213. label
  214. | {{_ 'title'}}
  215. input.js-new-board-title(type="text" placeholder="{{_ 'bucket-example'}}" autofocus required)
  216. if visibilityMenuIsOpen.get
  217. +boardVisibilityList
  218. else
  219. p.quiet
  220. if $eq visibility.get 'public'
  221. span.fa.fa-globe.colorful
  222. = " "
  223. | {{{_ 'board-public-info'}}}
  224. else
  225. span.fa.fa-lock.colorful
  226. = " "
  227. | {{{_ 'board-private-info'}}}
  228. a.js-change-visibility {{_ 'change'}}.
  229. a.flex.js-toggle-add-template-container
  230. .materialCheckBox#add-template-container
  231. span {{_ 'add-template-container'}}
  232. input.primary.wide(type="submit" value="{{_ 'create'}}")
  233. span.quiet
  234. | {{_ 'or'}}
  235. a.js-import-board {{_ 'import'}}
  236. span.quiet
  237. | /
  238. a.js-board-template {{_ 'template'}}
  239. //template(name="listsortPopup")
  240. // h2
  241. // | {{_ 'list-sort-by'}}
  242. // hr
  243. // ul.pop-over-list
  244. // each value in allowedSortValues
  245. // li
  246. // a.js-sort-by(name="{{value.name}}")
  247. // if $eq sortby value.name
  248. // i(class="fa {{Direction}}")
  249. // | {{_ value.label }}{{_ value.shortLabel}}
  250. // if $eq sortby value.name
  251. // i(class="fa fa-check")
  252. template(name="boardChangeTitlePopup")
  253. form
  254. label
  255. | {{_ 'title'}}
  256. input.js-board-name(type="text" value=title autofocus dir="auto")
  257. label
  258. | {{_ 'description'}}
  259. textarea.js-board-desc(dir="auto")= description
  260. input.primary.wide(type="submit" value="{{_ 'rename'}}")
  261. template(name="boardCreateRulePopup")
  262. p {{_ 'close-board-pop'}}
  263. button.js-confirm.negate.full(type="submit") {{_ 'archive'}}
  264. template(name="cardsSortPopup")
  265. ul.pop-over-list
  266. li
  267. a.js-sort-due {{_ 'due-date'}}
  268. hr
  269. li
  270. a.js-sort-title {{_ 'title-alphabetically'}}
  271. hr
  272. li
  273. a.js-sort-created-desc {{_ 'created-at-newest-first'}}
  274. hr
  275. li
  276. a.js-sort-created-asc {{_ 'created-at-oldest-first'}}