sidebar.jade 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669
  1. template(name="sidebar")
  2. .board-sidebar.sidebar(class="{{#if isOpen}}is-open{{/if}}")
  3. //a.sidebar-tongue.js-toggle-sidebar(
  4. // class="{{#if isTongueHidden}}is-hidden{{/if}}",
  5. // title="{{showTongueTitle}}")
  6. // i.fa.fa-navicon
  7. .sidebar-shadow
  8. a.sidebar-xmark.js-close-sidebar ✕
  9. .sidebar-content.js-board-sidebar-content
  10. //a.hide-btn.js-hide-sidebar
  11. // i.fa.fa-navicon
  12. unless isDefaultView
  13. h2
  14. a.fa.fa-chevron-left.js-back-home
  15. = getViewTitle
  16. if isOpen
  17. +Template.dynamic(template=getViewTemplate)
  18. template(name='homeSidebar')
  19. hr
  20. +membersWidget
  21. hr
  22. +labelsWidget
  23. ul#cards.label-text-hidden
  24. a.flex.js-toggle-minicard-label-text(title="{{_ 'hide-minicard-label-text'}}")
  25. span {{_ 'hide-minicard-label-text'}}
  26. b  
  27. .materialCheckBox(class="{{#if hiddenMinicardLabelText}}is-checked{{/if}}")
  28. hr
  29. unless currentUser.isNoComments
  30. h3
  31. i.fa.fa-comments-o
  32. | {{_ 'activities'}}
  33. +activities(mode="board")
  34. template(name="membersWidget")
  35. unless currentUser.isCommentOnly
  36. unless currentUser.isWorker
  37. h3
  38. a.board-header-btn.js-open-board-menu(title="{{_ 'boardMenuPopup-title'}}")
  39. i.board-header-btn-icon.fa.fa-cog
  40. | {{_ 'boardMenuPopup-title'}}
  41. .board-widget.board-widget-members
  42. .sidebar-shortcuts
  43. a.board-header-btn.js-shortcuts(title="{{_ 'keyboard-shortcuts' }}")
  44. i.fa.fa-keyboard-o
  45. span {{_ 'keyboard-shortcuts' }}
  46. hr
  47. h3
  48. i.fa.fa-users
  49. | {{_ 'members'}}
  50. +basicTabs(tabs=tabs)
  51. +tabContent(slug="people")
  52. unless currentUser.isWorker
  53. p.quiet
  54. .board-widget-content
  55. each currentBoard.activeMembers
  56. +userAvatar(userId=this.userId showStatus=true)
  57. if isSandstorm
  58. if currentUser.isBoardMember
  59. a.member.add-member.sandstorm-powerbox-request-identity(title="{{_ 'add-members'}}")
  60. i.fa.fa-plus
  61. else if currentUser.isBoardAdmin
  62. a.member.add-member.js-manage-board-members(title="{{_ 'add-members'}}")
  63. i.fa.fa-plus
  64. .clearfix
  65. if isInvited
  66. hr
  67. p
  68. i.fa.fa-exclamation-circle
  69. | {{_ 'just-invited'}}
  70. button.js-member-invite-accept.primary {{_ 'accept'}}
  71. button.js-member-invite-decline {{_ 'decline'}}
  72. +tabContent(slug='organizations')
  73. unless currentUser.isWorker
  74. p.quiet
  75. if AtLeastOneOrgWasCreated
  76. .board-widget.board-widget-members
  77. .board-widget-content
  78. +boardOrgGeneral
  79. .clearfix
  80. +tabContent(slug="teams")
  81. unless currentUser.isWorker
  82. p.quiet
  83. if AtLeastOneTeamWasCreated
  84. .board-widget.board-widget-members
  85. .board-widget-content
  86. +boardTeamGeneral
  87. .clearfix
  88. template(name="boardOrgGeneral")
  89. table
  90. tbody
  91. tr
  92. th
  93. | {{_ 'add-organizations'}}
  94. br
  95. i.addOrganizationsLabel
  96. | {{_ 'to-create-organizations-contact-admin'}}
  97. br
  98. i.addOrganizationsLabel
  99. | {{_ 'add-organizations-label'}}
  100. th
  101. if currentUser.isBoardAdmin
  102. a.member.orgOrTeamMember.add-member.js-manage-board-addOrg(title="{{_ 'add-members'}}")
  103. i.addTeamFaPlus.fa.fa-plus
  104. .divaddfaplusminus
  105. | {{_ 'add'}}
  106. each org in currentBoard.activeOrgs
  107. +boardOrgRow(orgId=org.orgId)
  108. template(name="boardTeamGeneral")
  109. table
  110. tbody
  111. tr
  112. th
  113. | {{_ 'add-teams'}}
  114. br
  115. i.addTeamsLabel
  116. | {{_ 'to-create-teams-contact-admin'}}
  117. br
  118. i.addTeamsLabel
  119. | {{_ 'add-teams-label'}}
  120. th
  121. if currentUser.isBoardAdmin
  122. a.member.orgOrTeamMember.add-member.js-manage-board-addTeam(title="{{_ 'add-members'}}")
  123. i.addTeamFaPlus.fa.fa-plus
  124. .divaddfaplusminus
  125. | {{_ 'add'}}
  126. each currentBoard.activeTeams
  127. +boardTeamRow(teamId=this.teamId)
  128. template(name="boardChangeColorPopup")
  129. .board-backgrounds-list.clearfix
  130. each backgroundColors
  131. .board-background-select.js-select-background
  132. span.background-box(class="board-color-{{this}}")
  133. span {{this}}
  134. if isSelected
  135. i.fa.fa-check
  136. template(name="boardChangeBackgroundImagePopup")
  137. form
  138. label
  139. | {{_ 'board-background-image-url'}}
  140. input.js-board-background-image-url(type="text" value="{{backgroundImageURL}}" autofocus)
  141. div.buttonsContainer
  142. input.primary.wide(type="submit" value="{{_ 'save'}}")
  143. br
  144. br
  145. br
  146. br
  147. br
  148. hr
  149. div
  150. button.js-remove-background-image.negate.wide.card-details-red.right {{_ 'unset-color'}}
  151. template(name="boardInfoOnMyBoardsPopup")
  152. form.board-info-on-my-boards
  153. h3 {{_ 'show-at-all-boards-page'}}
  154. unless currentSetting.hideCardCounterList
  155. div.check-div
  156. a.flex.js-field-has-cardcounterlist(class="{{#if allowsCardCounterList}}is-checked{{/if}}")
  157. .materialCheckBox(class="{{#if allowsCardCounterList}}is-checked{{/if}}")
  158. span
  159. i.fa.fa-sign-out
  160. | {{_ 'show-card-counter-per-list'}}
  161. unless currentSetting.hideBoardMemberList
  162. div.check-div
  163. a.flex.js-field-has-boardmemberlist(class="{{#if allowsBoardMemberList}}is-checked{{/if}}")
  164. .materialCheckBox(class="{{#if allowsBoardMemberList}}is-checked{{/if}}")
  165. span
  166. i.fa.fa-hourglass-start
  167. | {{_ 'show-board_members-avatar'}}
  168. template(name="boardCardSettingsPopup")
  169. form.board-card-settings
  170. h3 {{_ 'show-on-card'}}
  171. div.check-div
  172. a.flex.js-field-has-receiveddate(class="{{#if allowsReceivedDate}}is-checked{{/if}}")
  173. .materialCheckBox(class="{{#if allowsReceivedDate}}is-checked{{/if}}")
  174. span
  175. i.fa.fa-sign-out
  176. | {{_ 'card-received'}}
  177. div.check-div
  178. a.flex.js-field-has-startdate(class="{{#if allowsStartDate}}is-checked{{/if}}")
  179. .materialCheckBox(class="{{#if allowsStartDate}}is-checked{{/if}}")
  180. span
  181. i.fa.fa-hourglass-start
  182. | {{_ 'card-start'}}
  183. div.check-div
  184. a.flex.js-field-has-duedate(class="{{#if allowsDueDate}}is-checked{{/if}}")
  185. .materialCheckBox(class="{{#if allowsDueDate}}is-checked{{/if}}")
  186. span
  187. i.fa.fa-sign-in
  188. | {{_ 'card-due'}}
  189. div.check-div
  190. a.flex.js-field-has-enddate(class="{{#if allowsEndDate}}is-checked{{/if}}")
  191. .materialCheckBox(class="{{#if allowsEndDate}}is-checked{{/if}}")
  192. span
  193. i.fa.fa-hourglass-end
  194. | {{_ 'card-end'}}
  195. div.check-div
  196. a.flex.js-field-has-members(class="{{#if allowsMembers}}is-checked{{/if}}")
  197. .materialCheckBox(class="{{#if allowsMembers}}is-checked{{/if}}")
  198. span
  199. i.fa.fa-users
  200. | {{_ 'members'}}
  201. div.check-div
  202. a.flex.js-field-has-creator(class="{{#if allowsCreator}}is-checked{{/if}}")
  203. .materialCheckBox(class="{{#if allowsCreator}}is-checked{{/if}}")
  204. span
  205. i.fa.fa-user
  206. | {{_ 'creator'}}
  207. div.check-div
  208. a.flex.js-field-has-assignee(class="{{#if allowsAssignee}}is-checked{{/if}}")
  209. .materialCheckBox(class="{{#if allowsAssignee}}is-checked{{/if}}")
  210. span
  211. i.fa.fa-user
  212. | {{_ 'assignee'}}
  213. div.check-div
  214. a.flex.js-field-has-assigned-by(class="{{#if allowsAssignedBy}}is-checked{{/if}}")
  215. .materialCheckBox(class="{{#if allowsAssignedBy}}is-checked{{/if}}")
  216. span
  217. i.fa.fa-shopping-cart
  218. | {{_ 'assigned-by'}}
  219. div.check-div
  220. a.flex.js-field-has-requested-by(class="{{#if allowsRequestedBy}}is-checked{{/if}}")
  221. .materialCheckBox(class="{{#if allowsRequestedBy}}is-checked{{/if}}")
  222. span
  223. i.fa.fa-user-plus
  224. | {{_ 'requested-by'}}
  225. div.check-div
  226. a.flex.js-field-has-card-sorting-by-number(class="{{#if allowsCardSortingByNumber}}is-checked{{/if}}")
  227. .materialCheckBox(class="{{#if allowsCardSortingByNumber}}is-checked{{/if}}")
  228. span
  229. i.fa.fa-sort
  230. | {{_ 'card-sorting-by-number'}}
  231. div.check-div
  232. a.flex.js-field-has-card-show-lists(class="{{#if allowsShowLists}}is-checked{{/if}}")
  233. .materialCheckBox(class="{{#if allowsShowLists}}is-checked{{/if}}")
  234. span
  235. i.fa.fa-list
  236. | {{_ 'card-show-lists'}}
  237. div.check-div
  238. a.flex.js-field-has-labels(class="{{#if allowsLabels}}is-checked{{/if}}")
  239. .materialCheckBox(class="{{#if allowsLabels}}is-checked{{/if}}")
  240. span
  241. i.fa.fa-tags
  242. | {{_ 'labels'}}
  243. div.check-div
  244. a.flex.js-field-has-card-number(class="{{#if allowsCardNumber}}is-checked{{/if}}")
  245. .materialCheckBox(class="{{#if allowsCardNumber}}is-checked{{/if}}")
  246. span
  247. i.fa.fa-hashtag
  248. | {{_ 'card'}}
  249. | {{_ 'number'}}
  250. div.check-div
  251. a.flex.js-field-has-description-title(class="{{#if allowsDescriptionTitle}}is-checked{{/if}}")
  252. .materialCheckBox(class="{{#if allowsDescriptionTitle}}is-checked{{/if}}")
  253. span
  254. i.fa.fa-align-left
  255. | {{_ 'description'}}
  256. | {{_ 'title'}}
  257. div.check-div
  258. a.flex.js-field-has-description-text(class="{{#if allowsDescriptionText}}is-checked{{/if}}")
  259. .materialCheckBox(class="{{#if allowsDescriptionText}}is-checked{{/if}}")
  260. span
  261. i.fa.fa-align-left
  262. | {{_ 'description'}}
  263. | {{_ 'custom-field-text'}}
  264. div.check-div
  265. a.flex.js-field-has-checklists(class="{{#if allowsChecklists}}is-checked{{/if}}")
  266. .materialCheckBox(class="{{#if allowsChecklists}}is-checked{{/if}}")
  267. span
  268. i.fa.fa-check
  269. | {{_ 'checklists'}}
  270. div.check-div
  271. a.flex.js-field-has-subtasks(class="{{#if allowsSubtasks}}is-checked{{/if}}")
  272. .materialCheckBox(class="{{#if allowsSubtasks}}is-checked{{/if}}")
  273. span
  274. i.fa.fa-sitemap
  275. | {{_ 'subtasks'}}
  276. div.check-div
  277. a.flex.js-field-has-attachments(class="{{#if allowsAttachments}}is-checked{{/if}}")
  278. .materialCheckBox(class="{{#if allowsAttachments}}is-checked{{/if}}")
  279. span
  280. i.fa.fa-paperclip
  281. | {{_ 'attachments'}}
  282. //div.check-div
  283. // a.flex.js-field-has-comments(class="{{#if allowsComments}}is-checked{{/if}}")
  284. // .materialCheckBox(class="{{#if allowsComments}}is-checked{{/if}}")
  285. // span
  286. // i.fa.fa-comment-o
  287. // | {{_ 'comment'}}
  288. //div.check-div
  289. // a.flex.js-field-has-activities(class="{{#if allowsActivities}}is-checked{{/if}}")
  290. // .materialCheckBox(class="{{#if allowsActivities}}is-checked{{/if}}")
  291. // span
  292. // i.fa.fa-history
  293. // | {{_ 'activities'}}
  294. template(name="boardMinicardSettingsPopup")
  295. form.board-minicard-settings
  296. h3 {{_ 'show-on-minicard'}}
  297. div.check-div
  298. a.flex.js-field-has-description-text-on-minicard(class="{{#if allowsDescriptionTextOnMinicard}}is-checked{{/if}}")
  299. .materialCheckBox(class="{{#if allowsDescriptionTextOnMinicard}}is-checked{{/if}}")
  300. span
  301. i.fa.fa-align-left
  302. | {{_ 'description-on-minicard'}}
  303. div.check-div
  304. a.flex.js-field-has-cover-attachment-on-minicard(class="{{#if allowsCoverAttachmentOnMinicard}}is-checked{{/if}}")
  305. .materialCheckBox(class="{{#if allowsCoverAttachmentOnMinicard}}is-checked{{/if}}")
  306. span
  307. i.fa.fa-book
  308. i.fa.fa-image
  309. | {{_ 'cover-attachment-on-minicard'}}
  310. div.check-div
  311. a.flex.js-field-has-badge-attachment-on-minicard(class="{{#if allowsBadgeAttachmentOnMinicard}}is-checked{{/if}}")
  312. .materialCheckBox(class="{{#if allowsBadgeAttachmentOnMinicard}}is-checked{{/if}}")
  313. span
  314. i.fa.fa-paperclip
  315. | {{_ 'badge-attachment-on-minicard'}}
  316. div.check-div
  317. a.flex.js-field-has-card-sorting-by-number-on-minicard(class="{{#if allowsCardSortingByNumberOnMinicard}}is-checked{{/if}}")
  318. .materialCheckBox(class="{{#if allowsCardSortingByNumberOnMinicard}}is-checked{{/if}}")
  319. span
  320. i.fa.fa-sort
  321. | {{_ 'card-sorting-by-number-on-minicard'}}
  322. template(name="boardSubtaskSettingsPopup")
  323. form.board-subtask-settings
  324. h3 {{_ 'show-parent-in-minicard'}}
  325. a#prefix-with-full-path.flex.js-field-show-parent-in-minicard(class="{{#if $eq presentParentTask 'prefix-with-full-path'}}is-checked{{/if}}")
  326. .materialCheckBox(class="{{#if $eq presentParentTask 'prefix-with-full-path'}}is-checked{{/if}}")
  327. span {{_ 'prefix-with-full-path'}}
  328. a#prefix-with-parent.flex.js-field-show-parent-in-minicard(class="{{#if $eq presentParentTask 'prefix-with-parent'}}is-checked{{/if}}")
  329. .materialCheckBox(class="{{#if $eq presentParentTask 'prefix-with-parent'}}is-checked{{/if}}")
  330. span {{_ 'prefix-with-parent'}}
  331. a#subtext-with-full-path.flex.js-field-show-parent-in-minicard(class="{{#if $eq presentParentTask 'subtext-with-full-path'}}is-checked{{/if}}")
  332. .materialCheckBox(class="{{#if $eq presentParentTask 'subtext-with-full-path'}}is-checked{{/if}}")
  333. span {{_ 'subtext-with-full-path'}}
  334. a#subtext-with-parent.flex.js-field-show-parent-in-minicard(class="{{#if $eq presentParentTask 'subtext-with-parent'}}is-checked{{/if}}")
  335. .materialCheckBox(class="{{#if $eq presentParentTask 'subtext-with-parent'}}is-checked{{/if}}")
  336. span {{_ 'subtext-with-parent'}}
  337. a#no-parent.flex.js-field-show-parent-in-minicard(class="{{#if $eq presentParentTask 'no-parent'}}is-checked{{/if}}")
  338. .materialCheckBox(class="{{#if $eq presentParentTask 'no-parent'}}is-checked{{/if}}")
  339. span {{_ 'no-parent'}}
  340. div
  341. hr
  342. div.check-div
  343. a.flex.js-field-has-subtasks(class="{{#if allowsSubtasks}}is-checked{{/if}}")
  344. .materialCheckBox(class="{{#if allowsSubtasks}}is-checked{{/if}}")
  345. span {{_ 'show-subtasks-field'}}
  346. label
  347. | {{_ 'deposit-subtasks-board'}}
  348. select.js-field-deposit-board(disabled="{{#unless allowsSubtasks}}disabled{{/unless}}")
  349. each boards
  350. if isBoardSelected
  351. option(value=_id selected="selected") {{title}}
  352. else
  353. option(value=_id) {{title}}
  354. if isNullBoardSelected
  355. option(value='null' selected="selected") {{_ 'custom-field-dropdown-none'}}
  356. else
  357. option(value='null') {{_ 'custom-field-dropdown-none'}}
  358. div
  359. hr
  360. label
  361. | {{_ 'deposit-subtasks-list'}}
  362. select.js-field-deposit-list(disabled="{{#unless hasLists}}disabled{{/unless}}")
  363. each lists
  364. if isListSelected
  365. option(value=_id selected="selected") {{title}}
  366. else
  367. option(value=_id) {{title}}
  368. template(name="chooseBoardSource")
  369. ul.pop-over-list
  370. li
  371. a(href="{{pathFor '/import/trello'}}") {{_ 'from-trello'}}
  372. li
  373. a(href="{{pathFor '/import/wekan'}}") {{_ 'from-wekan'}}
  374. li
  375. a(href="{{pathFor '/import/csv'}}") {{_ 'from-csv'}}
  376. template(name="archiveBoardPopup")
  377. p {{_ 'close-board-pop'}}
  378. button.js-confirm.negate.full(type="submit")
  379. i.fa.fa-archive
  380. | {{_ 'archive'}}
  381. template(name="outgoingWebhooksPopup")
  382. each integrations
  383. form.integration-form
  384. a.flex
  385. span {{_ 'disable-webhook'}}
  386. b  
  387. .materialCheckBox(class="{{#unless enabled}}is-checked{{/unless}}")
  388. input.js-outgoing-webhooks-title(placeholder="{{_ 'webhook-title'}}" type="text" name="title" value=title)
  389. input.js-outgoing-webhooks-url(type="text" name="url" value=url)
  390. input.js-outgoing-webhooks-token(placeholder="{{_ 'webhook-token' }}" type="text" value=token name="token")
  391. select.js-outgoing-webhooks-type(name="type")
  392. each _type in types
  393. if($eq _type this.type)
  394. option(value=_type selected="selected") {{_ _type}}
  395. else
  396. option(value=_type) {{_ _type}}
  397. input(type="hidden" value=this.type name="_type")
  398. input(type="hidden" value=_id name="id")
  399. input.primary.wide(type="submit" value="{{_ 'save'}}")
  400. form.integration-form
  401. input.js-outgoing-webhooks-title(placeholder="{{_ 'webhook-title'}}" type="text" name="title")
  402. input.js-outgoing-webhooks-url(placeholder="{{_ 'URL' }}" type="text" name="url")
  403. input.js-outgoing-webhooks-token(placeholder="{{_ 'webhook-token' }}" type="text" name="token")
  404. select.js-outgoing-webhooks-type(name="type")
  405. each _type in types
  406. option(value=_type) {{_ _type}}
  407. input.primary.wide(type="submit" value="{{_ 'create'}}")
  408. template(name="boardMenuPopup")
  409. ul.pop-over-list
  410. if currentUser.isBoardAdmin
  411. li
  412. a.js-open-rules-view(title="{{_ 'rules'}}")
  413. i.fa.fa-magic
  414. | {{_ 'rules'}}
  415. if currentUser.isBoardAdmin
  416. li
  417. a.js-custom-fields
  418. i.fa.fa-list-alt
  419. | {{_ 'custom-fields'}}
  420. li
  421. a.js-open-archives
  422. i.fa.fa-archive
  423. | {{_ 'archived-items'}}
  424. if currentUser.isBoardAdmin
  425. li
  426. a.js-change-board-color
  427. i.fa.fa-paint-brush
  428. | {{_ 'board-change-color'}}
  429. li
  430. a.js-change-background-image
  431. i.fa.fa-image
  432. | {{_ 'board-change-background-image'}}
  433. //Bug Board icons random dance https://github.com/wekan/wekan/issues/4214
  434. //if currentUser.isBoardAdmin
  435. // unless currentSetting.hideBoardMemberList
  436. // unless currentSetting.hideCardCounterList
  437. // li
  438. // a.js-board-info-on-my-boards(title="{{_ 'board-info-on-my-boards'}}")
  439. // i.fa.fa-id-card-o
  440. // | {{_ 'board-info-on-my-boards'}}
  441. hr
  442. ul.pop-over-list
  443. if withApi
  444. li
  445. a.js-export-board
  446. i.fa.fa-share-alt
  447. | {{_ 'export-board'}}
  448. if currentUser.isBoardAdmin
  449. li
  450. a.js-outgoing-webhooks
  451. i.fa.fa-globe
  452. | {{_ 'outgoing-webhooks'}}
  453. li
  454. a.js-card-settings
  455. i.fa.fa-address-card
  456. | {{_ 'card-settings'}}
  457. li
  458. a.js-minicard-settings
  459. i.fa.fa-id-card
  460. | {{_ 'minicard-settings'}}
  461. li
  462. a.js-subtask-settings
  463. i.fa.fa-sitemap
  464. | {{_ 'subtask-settings'}}
  465. unless currentBoard.isTemplatesBoard
  466. if currentUser.isBoardAdmin
  467. hr
  468. ul.pop-over-list
  469. li
  470. a.js-archive-board
  471. i.fa.fa-arrow-right
  472. i.fa.fa-archive
  473. | {{_ 'archive-board'}}
  474. template(name="exportBoard")
  475. ul.pop-over-list
  476. li
  477. a.download-json-link(href="{{exportUrl}}", download="{{exportJsonFilename}}")
  478. i.fa.fa-share-alt
  479. | {{_ 'export-board-json'}}
  480. li
  481. a(href="{{exportUrlExcel}}", download="{{exportFilenameExcel}}")
  482. i.fa.fa-share-alt
  483. | {{_ 'export-board-excel'}}
  484. li
  485. a(href="{{exportCsvUrl}}", download="{{exportCsvFilename}}")
  486. i.fa.fa-share-alt
  487. | {{_ 'export-board-csv'}} ,
  488. li
  489. a(href="{{exportScsvUrl}}", download="{{exportCsvFilename}}")
  490. i.fa.fa-share-alt
  491. | {{_ 'export-board-csv'}} ;
  492. li
  493. a(href="{{exportTsvUrl}}", download="{{exportTsvFilename}}")
  494. i.fa.fa-share-alt
  495. | {{_ 'export-board-tsv'}}
  496. li
  497. a.html-export-board
  498. i.fa.fa-archive
  499. | {{_ 'export-board-html'}}
  500. template(name="labelsWidget")
  501. .board-widget.board-widget-labels
  502. h3
  503. i.fa.fa-tags
  504. | {{_ 'labels'}}
  505. .board-widget-content
  506. each currentBoard.labels
  507. a.card-label(class="card-label-{{color}}"
  508. class="{{#if currentUser.isNotCommentOnly}}{{#if currentUser.isNotWorker}}js-label{{/if}}{{/if}}")
  509. span.card-label-name
  510. +viewer
  511. = name
  512. if currentUser.isBoardAdmin
  513. a.card-label.add-label.js-add-label(title="{{_ 'label-create'}}")
  514. i.fa.fa-plus
  515. template(name="memberPopup")
  516. .board-member-menu
  517. .miniprofile-header
  518. +userAvatar(userId=user._id showEdit=true)
  519. .info
  520. h3
  521. .js-profile= user.profile.fullname
  522. p.quiet @#{user.username}
  523. if isInvited
  524. p
  525. i.fa.fa-exclamation-circle
  526. | {{_ 'not-accepted-yet'}}
  527. ul.pop-over-list
  528. li
  529. a.js-filter-member {{_ 'filter-cards'}}
  530. if currentUser.isBoardAdmin
  531. li
  532. a.js-change-role
  533. | {{_ 'change-permissions'}}
  534. span.quiet (#{memberType})
  535. unless currentUser.isWorker
  536. li
  537. if $eq currentUser._id userId
  538. a.js-leave-member {{_ 'leave-board'}}
  539. else if currentUser.isBoardAdmin
  540. a.js-remove-member {{_ 'remove-from-board'}}
  541. template(name="removeMemberPopup")
  542. p {{_ 'remove-member-pop' name=user.profile.fullname username=user.username boardTitle=board.title}}
  543. button.js-confirm.negate.full(type="submit") {{_ 'remove-member'}}
  544. template(name="leaveBoardPopup")
  545. p {{_ 'leave-board-pop' boardTitle=board.title}}
  546. button.js-confirm.negate.full(type="submit") {{_ 'leave-board'}}
  547. template(name="addBoardOrgPopup")
  548. select.js-boardOrgs#jsBoardOrgs
  549. option(value="-1") {{_ 'organizations'}} :
  550. each value in orgsDatas
  551. option(value="{{value._id}}") {{value.orgDisplayName}}
  552. template(name="removeBoardOrgPopup")
  553. form
  554. input.hide#hideOrgId(type="text" value=org._id)
  555. label
  556. | {{_ 'remove-organization-from-board'}}
  557. br
  558. hr
  559. div.buttonsContainer
  560. input.primary.wide.leaveBoardBtn#leaveBoardBtn(type="submit" value="{{_ 'confirm-btn'}}")
  561. input.primary.wide.cancelLeaveBoardBtn#cancelLeaveBoardBtn(type="submit" value="{{_ 'cancel'}}")
  562. template(name="addBoardTeamPopup")
  563. select.js-boardTeams#jsBoardTeams
  564. option(value="-1") {{_ 'teams'}} :
  565. each value in teamsDatas
  566. option(value="{{value._id}}") {{_ value.teamDisplayName}}
  567. template(name="removeBoardTeamPopup")
  568. form
  569. input.hide#hideTeamId(type="text" value=team._id)
  570. label
  571. | {{_ 'remove-team-from-table'}}
  572. br
  573. hr
  574. div.buttonsContainer
  575. input.primary.wide.leaveBoardBtn#leaveBoardTeamBtn(type="submit" value="{{_ 'confirm-btn'}}")
  576. input.primary.wide.cancelLeaveBoardBtn#cancelLeaveBoardTeamBtn(type="submit" value="{{_ 'cancel'}}")
  577. template(name="addMemberPopup")
  578. .js-search-member
  579. +EasySearch.Input(index=searchIndex)
  580. if loading.get
  581. +spinner
  582. else if error.get
  583. .warning {{_ error.get}}
  584. else
  585. ul.pop-over-list
  586. +EasySearch.Each(index=searchIndex)
  587. li.item.js-member-item(class="{{#if isBoardMember}}disabled{{/if}}")
  588. a.name.js-select-member(title="{{profile.fullname}} ({{username}})")
  589. +userAvatar(userId=__originalId)
  590. span.full-name
  591. = profile.fullname
  592. | (<span class="username">{{username}}</span>)
  593. if isBoardMember
  594. .quiet ({{_ 'joined'}})
  595. +EasySearch.IfSearching(index=searchIndex)
  596. +spinner
  597. +EasySearch.IfNoResults(index=searchIndex)
  598. .manage-member-section
  599. p.quiet {{_ 'no-results'}}
  600. button.js-email-invite.primary.full {{_ 'email-invite'}}
  601. template(name="changePermissionsPopup")
  602. ul.pop-over-list
  603. li
  604. a(class="{{#if isLastAdmin}}disabled{{else}}js-set-admin{{/if}}")
  605. | {{_ 'admin'}}
  606. if isAdmin
  607. i.fa.fa-check
  608. span.sub-name {{_ 'admin-desc'}}
  609. li
  610. a(class="{{#if isLastAdmin}}disabled{{else}}js-set-normal{{/if}}")
  611. | {{_ 'normal'}}
  612. if isNormal
  613. i.fa.fa-check
  614. span.sub-name {{_ 'normal-desc'}}
  615. li
  616. a(class="{{#if isLastAdmin}}disabled{{else}}js-set-no-comments{{/if}}")
  617. | {{_ 'no-comments'}}
  618. if isNoComments
  619. i.fa.fa-check
  620. span.sub-name {{_ 'no-comments-desc'}}
  621. li
  622. a(class="{{#if isLastAdmin}}disabled{{else}}js-set-comment-only{{/if}}")
  623. | {{_ 'comment-only'}}
  624. if isCommentOnly
  625. i.fa.fa-check
  626. span.sub-name {{_ 'comment-only-desc'}}
  627. li
  628. a(class="{{#if isLastAdmin}}disabled{{else}}js-set-worker{{/if}}")
  629. | {{_ 'worker'}}
  630. if isWorker
  631. i.fa.fa-check
  632. span.sub-name {{_ 'worker-desc'}}
  633. if isLastAdmin
  634. hr
  635. p.quiet.bottom {{_ 'last-admin-desc'}}