cardDetails.jade 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631
  1. template(name="cardDetails")
  2. section.card-details.js-card-details: .card-details-canvas
  3. .card-details-header(class='{{#if colorClass}}card-details-{{colorClass}}{{/if}}')
  4. +inlinedForm(classNames="js-card-details-title")
  5. +editCardTitleForm
  6. else
  7. unless isMiniScreen
  8. a.fa.fa-times-thin.close-card-details.js-close-card-details
  9. if currentUser.isBoardMember
  10. a.fa.fa-navicon.card-details-menu.js-open-card-details-menu
  11. input.inline-input(type="text" id="cardURL_copy" value="{{ absoluteUrl }}")
  12. a.fa.fa-link.card-copy-button.js-copy-link(
  13. class="fa-link"
  14. title="{{_ 'copy-card-link-to-clipboard'}}"
  15. value="{{ absoluteUrl }}"
  16. )
  17. if isMiniScreen
  18. a.fa.fa-times-thin.close-card-details-mobile-web.js-close-card-details
  19. if currentUser.isBoardMember
  20. a.fa.fa-navicon.card-details-menu-mobile-web.js-open-card-details-menu
  21. a.fa.fa-link.card-copy-mobile-button
  22. h2.card-details-title.js-card-title(
  23. class="{{#if canModifyCard}}js-open-inlined-form is-editable{{/if}}")
  24. +viewer
  25. = getTitle
  26. if isWatching
  27. i.card-details-watch.fa.fa-eye
  28. .card-details-path
  29. each parentList
  30. |   >  
  31. a.js-parent-card(href=linkForCard) {{title}}
  32. // else
  33. {{_ 'top-level-card'}}
  34. if isLinkedCard
  35. a.linked-card-location.js-go-to-linked-card
  36. +viewer
  37. | {{getBoardTitle}} > {{getTitle}}
  38. if getArchived
  39. if isLinkedBoard
  40. p.warning {{_ 'board-archived'}}
  41. else
  42. p.warning {{_ 'card-archived'}}
  43. .card-details-items
  44. if currentBoard.allowsLabels
  45. .card-details-item.card-details-item-labels
  46. h3.card-details-item-title
  47. i.fa.fa-tags
  48. | {{_ 'labels'}}
  49. a(class="{{#if canModifyCard}}js-add-labels{{else}}is-disabled{{/if}}" title="{{_ 'card-labels-title'}}")
  50. each labels
  51. span.card-label(class="card-label-{{color}}" title=name)
  52. +viewer
  53. = name
  54. if canModifyCard
  55. unless currentUser.isWorker
  56. a.card-label.add-label.js-add-labels(title="{{_ 'card-labels-title'}}")
  57. i.fa.fa-plus
  58. if currentBoard.allowsReceivedDate
  59. hr
  60. .card-details-item.card-details-item-received
  61. h3.card-details-item-title
  62. i.fa.fa-sign-out
  63. | {{_ 'card-received'}}
  64. if getReceived
  65. +cardReceivedDate
  66. else
  67. if canModifyCard
  68. unless currentUser.isWorker
  69. a.card-label.add-label.js-received-date
  70. i.fa.fa-plus
  71. if currentBoard.allowsStartDate
  72. .card-details-item.card-details-item-start
  73. h3.card-details-item-title
  74. i.fa.fa-hourglass-start
  75. | {{_ 'card-start'}}
  76. if getStart
  77. +cardStartDate
  78. else
  79. if canModifyCard
  80. unless currentUser.isWorker
  81. a.card-label.add-label.js-start-date
  82. i.fa.fa-plus
  83. if currentBoard.allowsDueDate
  84. .card-details-item.card-details-item-due
  85. h3.card-details-item-title
  86. i.fa.fa-sign-in
  87. | {{_ 'card-due'}}
  88. if getDue
  89. +cardDueDate
  90. else
  91. if canModifyCard
  92. unless currentUser.isWorker
  93. a.card-label.add-label.js-due-date
  94. i.fa.fa-plus
  95. if currentBoard.allowsEndDate
  96. .card-details-item.card-details-item-end
  97. h3.card-details-item-title
  98. i.fa.fa-hourglass-end
  99. | {{_ 'card-end'}}
  100. if getEnd
  101. +cardEndDate
  102. else
  103. if canModifyCard
  104. unless currentUser.isWorker
  105. a.card-label.add-label.js-end-date
  106. i.fa.fa-plus
  107. //.card-details-items
  108. if currentBoard.allowsMembers
  109. hr
  110. .card-details-item.card-details-item-members
  111. h3.card-details-item-title
  112. i.fa.fa-users
  113. | {{_ 'members'}}
  114. each getMembers
  115. +userAvatar(userId=this cardId=../_id)
  116. | {{! XXX Hack to hide syntaxic coloration /// }}
  117. if canModifyCard
  118. unless currentUser.isWorker
  119. a.member.add-member.card-details-item-add-button.js-add-members(title="{{_ 'card-members-title'}}")
  120. i.fa.fa-plus
  121. //if assigneeSelected
  122. if currentBoard.allowsAssignee
  123. .card-details-item.card-details-item-assignees
  124. h3.card-details-item-title
  125. i.fa.fa-user
  126. | {{_ 'assignee'}}
  127. each getAssignees
  128. +userAvatarAssignee(userId=this cardId=../_id)
  129. | {{! XXX Hack to hide syntaxic coloration /// }}
  130. if canModifyCard
  131. a.assignee.add-assignee.card-details-item-add-button.js-add-assignees(title="{{_ 'assignee'}}")
  132. i.fa.fa-plus
  133. if currentUser.isWorker
  134. unless assigneeSelected
  135. a.assignee.add-assignee.card-details-item-add-button.js-add-assignees(title="{{_ 'assignee'}}")
  136. i.fa.fa-plus
  137. //.card-details-items
  138. if getSpentTime
  139. .card-details-item.card-details-item-spent
  140. if getIsOvertime
  141. h3.card-details-item-title
  142. | {{_ 'overtime-hours'}}
  143. else
  144. h3.card-details-item-title
  145. | {{_ 'spent-time-hours'}}
  146. +cardSpentTime
  147. //.card-details-items
  148. if currentBoard.allowsRequestedBy
  149. .card-details-item.card-details-item-name
  150. h3.card-details-item-title
  151. i.fa.fa-shopping-cart
  152. | {{_ 'requested-by'}}
  153. if canModifyCard
  154. unless currentUser.isWorker
  155. +inlinedForm(classNames="js-card-details-requester")
  156. +editCardRequesterForm
  157. else
  158. a.js-open-inlined-form
  159. if getRequestedBy
  160. +viewer
  161. = getRequestedBy
  162. else
  163. | {{_ 'add'}}
  164. else if getRequestedBy
  165. +viewer
  166. = getRequestedBy
  167. if currentBoard.allowsAssignedBy
  168. .card-details-item.card-details-item-name
  169. h3.card-details-item-title
  170. i.fa.fa-user-plus
  171. | {{_ 'assigned-by'}}
  172. if canModifyCard
  173. unless currentUser.isWorker
  174. +inlinedForm(classNames="js-card-details-assigner")
  175. +editCardAssignerForm
  176. else
  177. a.js-open-inlined-form
  178. if getAssignedBy
  179. +viewer
  180. = getAssignedBy
  181. else
  182. | {{_ 'add'}}
  183. else if getRequestedBy
  184. +viewer
  185. = getAssignedBy
  186. //.card-details-items
  187. if customFieldsWD
  188. hr
  189. each customFieldsWD
  190. .card-details-item.card-details-item-customfield
  191. h3.card-details-item-title
  192. i.fa.fa-list-alt
  193. = definition.name
  194. +cardCustomField
  195. if getVoteQuestion
  196. hr
  197. .vote-title
  198. div.flex
  199. h3
  200. i.fa.fa-thumbs-up
  201. | {{_ 'vote-question'}}
  202. if getVoteEnd
  203. +voteEndDate
  204. .vote-result
  205. if votePublic
  206. a.card-label.card-label-green.js-show-positive-votes {{ voteCountPositive }}
  207. a.card-label.card-label-red.js-show-negative-votes {{ voteCountNegative }}
  208. else
  209. .card-label.card-label-green {{ voteCountPositive }}
  210. .card-label.card-label-red {{ voteCountNegative }}
  211. unless ($and currentBoard.isPublic voteAllowNonBoardMembers )
  212. .card-label.card-label-gray {{ voteCount }} {{_ 'r-of' }} {{ currentBoard.activeMembers.length }}
  213. +viewer
  214. = getVoteQuestion
  215. if showVotingButtons
  216. button.card-details-green.js-vote.js-vote-positive(class="{{#if voteState}}voted{{/if}}")
  217. if voteState
  218. i.fa.fa-thumbs-up
  219. | {{_ 'vote-for-it'}}
  220. button.card-details-red.js-vote.js-vote-negative(class="{{#if $eq voteState false}}voted{{/if}}")
  221. if $eq voteState false
  222. i.fa.fa-thumbs-down
  223. | {{_ 'vote-against'}}
  224. //- XXX We should use "editable" to avoid repetiting ourselves
  225. if canModifyCard
  226. unless currentUser.isWorker
  227. if currentBoard.allowsDescriptionTitle
  228. hr
  229. h3.card-details-item-title
  230. i.fa.fa-align-left
  231. | {{_ 'description'}}
  232. if currentBoard.allowsDescriptionText
  233. +inlinedCardDescription(classNames="card-description js-card-description")
  234. +editor(autofocus=true)
  235. | {{getUnsavedValue 'cardDescription' _id getDescription}}
  236. .edit-controls.clearfix
  237. button.primary(type="submit") {{_ 'save'}}
  238. a.fa.fa-times-thin.js-close-inlined-form
  239. else
  240. if currentBoard.allowsDescriptionText
  241. a.js-open-inlined-form
  242. if getDescription
  243. +viewer
  244. = getDescription
  245. else
  246. | {{_ 'edit'}}
  247. if (hasUnsavedValue 'cardDescription' _id)
  248. p.quiet
  249. | {{_ 'unsaved-description'}}
  250. a.js-open-inlined-form {{_ 'view-it'}}
  251. = ' - '
  252. a.js-close-inlined-form {{_ 'discard'}}
  253. else if getDescription
  254. if currentBoard.allowsDescriptionTitle
  255. hr
  256. h3.card-details-item-title {{_ 'description'}}
  257. if currentBoard.allowsDescriptionText
  258. +viewer
  259. = getDescription
  260. .card-checklist-attachmentGalerys
  261. .card-checklist-attachmentGalery.card-checklists
  262. if currentBoard.allowsChecklists
  263. hr
  264. +checklists(cardId = _id)
  265. if currentBoard.allowsSubtasks
  266. hr
  267. +subtasks(cardId = _id)
  268. if currentBoard.allowsAttachments
  269. hr
  270. h3.card-details-item-title
  271. i.fa.fa-paperclip
  272. | {{_ 'attachments'}}
  273. .card-checklist-attachmentGalery.card-attachmentGalery
  274. +attachmentsGalery
  275. hr
  276. unless currentUser.isNoComments
  277. .activity-title
  278. h3.card-details-item-title
  279. i.fa.fa-history
  280. | {{ _ 'activity'}}
  281. if currentUser.isBoardMember
  282. .material-toggle-switch
  283. span.toggle-switch-title {{_ 'hide-system-messages'}}
  284. if hiddenSystemMessages
  285. input.toggle-switch(type="checkbox" id="toggleButton" checked="checked")
  286. else
  287. input.toggle-switch(type="checkbox" id="toggleButton")
  288. label.toggle-label(for="toggleButton")
  289. if currentBoard.allowsComments
  290. if currentUser.isBoardMember
  291. unless currentUser.isNoComments
  292. +commentForm
  293. unless currentUser.isNoComments
  294. if isLoaded.get
  295. if isLinkedCard
  296. +activities(card=this mode="linkedcard")
  297. else if isLinkedBoard
  298. +activities(card=this mode="linkedboard")
  299. else
  300. +activities(card=this mode="card")
  301. template(name="editCardTitleForm")
  302. textarea.js-edit-card-title(rows='1' autofocus dir="auto")
  303. = getTitle
  304. .edit-controls.clearfix
  305. button.primary.confirm.js-submit-edit-card-title-form(type="submit") {{_ 'save'}}
  306. a.fa.fa-times-thin.js-close-inlined-form
  307. template(name="editCardRequesterForm")
  308. input.js-edit-card-requester(type='text' autofocus value=getRequestedBy dir="auto")
  309. .edit-controls.clearfix
  310. button.primary.confirm.js-submit-edit-card-requester-form(type="submit") {{_ 'save'}}
  311. a.fa.fa-times-thin.js-close-inlined-form
  312. template(name="editCardAssignerForm")
  313. input.js-edit-card-assigner(type='text' autofocus value=getAssignedBy dir="auto")
  314. .edit-controls.clearfix
  315. button.primary.confirm.js-submit-edit-card-assigner-form(type="submit") {{_ 'save'}}
  316. a.fa.fa-times-thin.js-close-inlined-form
  317. template(name="cardDetailsActionsPopup")
  318. ul.pop-over-list
  319. li
  320. a.js-toggle-watch-card
  321. if isWatching
  322. i.fa.fa-eye
  323. | {{_ 'unwatch'}}
  324. else
  325. i.fa.fa-eye-slash
  326. | {{_ 'watch'}}
  327. if canModifyCard
  328. unless currentUser.isWorker
  329. hr
  330. ul.pop-over-list
  331. //li: a.js-members {{_ 'card-edit-members'}}
  332. //li: a.js-labels {{_ 'card-edit-labels'}}
  333. //li: a.js-attachments {{_ 'card-edit-attachments'}}
  334. li
  335. a.js-start-voting
  336. i.fa.fa-thumbs-up
  337. | {{_ 'card-edit-voting'}}
  338. li
  339. a.js-custom-fields
  340. i.fa.fa-list-alt
  341. | {{_ 'card-edit-custom-fields'}}
  342. //li: a.js-received-date {{_ 'editCardReceivedDatePopup-title'}}
  343. //li: a.js-start-date {{_ 'editCardStartDatePopup-title'}}
  344. //li: a.js-due-date {{_ 'editCardDueDatePopup-title'}}
  345. //li: a.js-end-date {{_ 'editCardEndDatePopup-title'}}
  346. li
  347. a.js-spent-time
  348. i.fa.fa-clock-o
  349. | {{_ 'editCardSpentTimePopup-title'}}
  350. li
  351. a.js-set-card-color
  352. i.fa.fa-paint-brush
  353. | {{_ 'setCardColorPopup-title'}}
  354. hr
  355. ul.pop-over-list
  356. li
  357. a.js-move-card-to-top
  358. i.fa.fa-arrow-up
  359. | {{_ 'moveCardToTop-title'}}
  360. li
  361. a.js-move-card-to-bottom
  362. i.fa.fa-arrow-down
  363. | {{_ 'moveCardToBottom-title'}}
  364. unless currentUser.isWorker
  365. hr
  366. ul.pop-over-list
  367. li
  368. a.js-move-card
  369. i.fa.fa-arrow-right
  370. | {{_ 'moveCardPopup-title'}}
  371. li
  372. a.js-copy-card
  373. i.fa.fa-copy
  374. | {{_ 'copyCardPopup-title'}}
  375. hr
  376. ul.pop-over-list
  377. li
  378. a.js-copy-checklist-cards
  379. i.fa.fa-list
  380. i.fa.fa-copy
  381. | {{_ 'copyChecklistToManyCardsPopup-title'}}
  382. unless archived
  383. hr
  384. ul.pop-over-list
  385. li
  386. a.js-archive
  387. i.fa.fa-arrow-right
  388. i.fa.fa-archive
  389. | {{_ 'archive-card'}}
  390. hr
  391. ul.pop-over-list
  392. li
  393. a.js-more
  394. i.fa.fa-link
  395. | {{_ 'cardMorePopup-title'}}
  396. template(name="moveCardPopup")
  397. +boardsAndLists
  398. template(name="copyCardPopup")
  399. label(for='copy-card-title') {{_ 'title'}}:
  400. textarea#copy-card-title.minicard-composer-textarea.js-card-title(autofocus)
  401. = getTitle
  402. +boardsAndLists
  403. template(name="copyChecklistToManyCardsPopup")
  404. label(for='copy-checklist-cards-title') {{_ 'copyChecklistToManyCardsPopup-instructions'}}:
  405. textarea#copy-card-title.minicard-composer-textarea.js-card-title(autofocus)
  406. | {{_ 'copyChecklistToManyCardsPopup-format'}}
  407. +boardsAndLists
  408. template(name="boardsAndLists")
  409. label {{_ 'boards'}}:
  410. select.js-select-boards(autofocus)
  411. each boards
  412. if $eq _id currentBoard._id
  413. option(value="{{_id}}" selected) {{_ 'current'}}
  414. else
  415. option(value="{{_id}}") {{title}}
  416. label {{_ 'swimlanes'}}:
  417. select.js-select-swimlanes
  418. each swimlanes
  419. option(value="{{_id}}") {{title}}
  420. label {{_ 'lists'}}:
  421. select.js-select-lists
  422. each aBoardLists
  423. option(value="{{_id}}") {{title}}
  424. .edit-controls.clearfix
  425. button.primary.confirm.js-done {{_ 'done'}}
  426. template(name="cardMembersPopup")
  427. ul.pop-over-list.js-card-member-list
  428. each board.activeMembers
  429. li.item(class="{{#if isCardMember}}active{{/if}}")
  430. a.name.js-select-member(href="#")
  431. +userAvatar(userId=user._id)
  432. span.full-name
  433. = user.profile.fullname
  434. | (<span class="username">{{ user.username }}</span>)
  435. if isCardMember
  436. i.fa.fa-check
  437. template(name="cardAssigneesPopup")
  438. unless currentUser.isWorker
  439. ul.pop-over-list.js-card-assignee-list
  440. each board.activeMembers
  441. li.item(class="{{#if isCardAssignee}}active{{/if}}")
  442. a.name.js-select-assignee(href="#")
  443. +userAvatar(userId=user._id)
  444. span.full-name
  445. = user.profile.fullname
  446. | (<span class="username">{{ user.username }}</span>)
  447. if isCardAssignee
  448. i.fa.fa-check
  449. if currentUser.isWorker
  450. ul.pop-over-list.js-card-assignee-list
  451. li.item(class="{{#if currentUser.isCardAssignee}}active{{/if}}")
  452. a.name.js-select-assignee(href="#")
  453. +userAvatar(userId=currentUser._id)
  454. span.full-name
  455. = currentUser.profile.fullname
  456. | (<span class="username">{{ currentUser.username }}</span>)
  457. if currentUser.isCardAssignee
  458. i.fa.fa-check
  459. template(name="userAvatarAssignee")
  460. a.assignee.js-assignee(title="{{userData.profile.fullname}} ({{userData.username}})")
  461. if userData.profile.avatarUrl
  462. img.avatar.avatar-image(src="{{userData.profile.avatarUrl}}")
  463. else
  464. +userAvatarAssigneeInitials(userId=userData._id)
  465. if showStatus
  466. span.assignee-presence-status(class=presenceStatusClassName)
  467. span.member-type(class=memberType)
  468. unless isSandstorm
  469. if showEdit
  470. if $eq currentUser._id userData._id
  471. a.edit-avatar.js-change-avatar
  472. i.fa.fa-pencil
  473. template(name="cardAssigneePopup")
  474. .board-assignee-menu
  475. .mini-profile-info
  476. +userAvatar(userId=user._id showEdit=true)
  477. .info
  478. h3= user.profile.fullname
  479. p.quiet @{{ user.username }}
  480. ul.pop-over-list
  481. if currentUser.isNotCommentOnly
  482. unless currentUser.isWorker
  483. li: a.js-remove-assignee {{_ 'remove-member-from-card'}}
  484. unless currentUser.isWorker
  485. if $eq currentUser._id user._id
  486. with currentUser
  487. li: a.js-edit-profile {{_ 'edit-profile'}}
  488. template(name="userAvatarAssigneeInitials")
  489. svg.avatar.avatar-assignee-initials(viewBox="0 0 {{viewPortWidth}} 15")
  490. text(x="50%" y="13" text-anchor="middle")= initials
  491. template(name="cardMorePopup")
  492. p.quiet
  493. span.clearfix
  494. span {{_ 'link-card'}}
  495. = ' '
  496. i.fa.colorful(class="{{#if board.isPublic}}fa-globe{{else}}fa-lock{{/if}}")
  497. input.inline-input(type="text" id="cardURL" readonly value="{{ absoluteUrl }}" autofocus="autofocus")
  498. button.js-copy-card-link-to-clipboard(class="btn" id="clipboard") {{_ 'copy-card-link-to-clipboard'}}
  499. span.clearfix
  500. br
  501. h2 {{_ 'change-card-parent'}}
  502. label {{_ 'source-board'}}:
  503. select.js-field-parent-board
  504. if isTopLevel
  505. option(value="none" selected) {{_ 'custom-field-dropdown-none'}}
  506. else
  507. option(value="none") {{_ 'custom-field-dropdown-none'}}
  508. each boards
  509. if isParentBoard
  510. option(value="{{_id}}" selected) {{title}}
  511. else
  512. option(value="{{_id}}") {{title}}
  513. label {{_ 'parent-card'}}:
  514. select.js-field-parent-card
  515. if isTopLevel
  516. option(value="none" selected) {{_ 'custom-field-dropdown-none'}}
  517. else
  518. option(value="none") {{_ 'custom-field-dropdown-none'}}
  519. each cards
  520. if isParentCard
  521. option(value="{{_id}}" selected) {{title}}
  522. else
  523. option(value="{{_id}}") {{title}}
  524. br
  525. | {{_ 'added'}}
  526. span.date(title=card.createdAt) {{ moment createdAt 'LLL' }}
  527. a.js-delete(title="{{_ 'card-delete-notice'}}") {{_ 'delete'}}
  528. template(name="setCardColorPopup")
  529. form.edit-label
  530. .palette-colors: each colors
  531. unless $eq color 'white'
  532. span.card-label.palette-color.js-palette-color(class="card-details-{{color}}")
  533. if(isSelected color)
  534. i.fa.fa-check
  535. button.primary.confirm.js-submit {{_ 'save'}}
  536. button.js-remove-color.negate.wide.right {{_ 'unset-color'}}
  537. template(name="cardDeletePopup")
  538. p {{_ "card-delete-pop"}}
  539. unless archived
  540. p {{_ "card-delete-suggest-archive"}}
  541. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}
  542. template(name="deleteVotePopup")
  543. p {{_ "vote-delete-pop"}}
  544. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}
  545. template(name="cardStartVotingPopup")
  546. form.edit-vote-question
  547. .fields
  548. label(for="vote") {{_ 'vote-question'}}
  549. input.js-vote-field#vote(type="text" name="vote" value="{{getVoteQuestion}}" autofocus disabled="{{#if getVoteQuestion}}disabled{{/if}}")
  550. .check-div
  551. a.flex(class="{{#if getVoteQuestion}}is-disabled{{else}}js-toggle-vote-allow-non-members{{/if}}")
  552. .materialCheckBox#vote-allow-non-members(name="vote-allow-non-members" class="{{#if voteAllowNonBoardMembers}}is-checked{{/if}}")
  553. span {{_ 'allowNonBoardMembers'}}
  554. .check-div
  555. a.flex(class="{{#if getVoteQuestion}}is-disabled{{else}}js-toggle-vote-public{{/if}}")
  556. .materialCheckBox#vote-public(name="vote-public" class="{{#if votePublic}}is-checked{{/if}}")
  557. span {{_ 'vote-public'}}
  558. .check-div.flex
  559. i.fa.fa-hourglass-end
  560. a.js-end-date
  561. span
  562. | {{_ 'card-end'}}
  563. unless getVoteEnd
  564. i.fa.fa-plus
  565. if getVoteEnd
  566. +voteEndDate
  567. button.primary.js-submit {{_ 'save'}}
  568. if getVoteQuestion
  569. button.js-remove-vote.negate.wide.right {{_ 'delete'}}
  570. template(name="positiveVoteMembersPopup")
  571. ul.pop-over-list.js-card-member-list
  572. each m in voteMemberPositive
  573. li.item
  574. a.name
  575. +userAvatar(userId=m._id)
  576. span.full-name
  577. = m.profile.fullname
  578. | (<span class="username">{{ m.username }}</span>)
  579. template(name="negativeVoteMembersPopup")
  580. ul.pop-over-list.js-card-member-list
  581. each m in voteMemberNegative
  582. li.item
  583. a.name
  584. +userAvatar(userId=m._id)
  585. span.full-name
  586. = m.profile.fullname
  587. | (<span class="username">{{ m.username }}</span>)