cardDetails.jade 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934
  1. template(name="cardDetailsPopup")
  2. +cardDetails(popupCard)
  3. template(name="cardDetails")
  4. section.card-details.js-card-details(class='{{#if cardMaximized}}card-details-maximized{{/if}}' class='{{#if isPopup}}card-details-popup{{/if}}'): .card-details-canvas
  5. .card-details-header(class='{{#if colorClass}}card-details-{{colorClass}}{{/if}}')
  6. +inlinedForm(classNames="js-card-details-title")
  7. +editCardTitleForm
  8. else
  9. unless isMiniScreen
  10. unless isPopup
  11. a.fa.fa-times-thin.close-card-details.js-close-card-details(title="{{_ 'close-card'}}")
  12. if cardMaximized
  13. a.fa.fa-window-minimize.minimize-card-details.js-minimize-card-details(title="{{_ 'minimize-card'}}")
  14. else
  15. a.fa.fa-window-maximize.maximize-card-details.js-maximize-card-details(title="{{_ 'maximize-card'}}")
  16. if currentUser.isBoardMember
  17. a.fa.fa-navicon.card-details-menu.js-open-card-details-menu(title="{{_ 'cardDetailsActionsPopup-title'}}")
  18. a.fa.fa-link.card-copy-button.js-copy-link(
  19. id="cardURL_copy"
  20. class="fa-link"
  21. title="{{_ 'copy-card-link-to-clipboard'}}"
  22. href="{{ originRelativeUrl }}"
  23. )
  24. span.copied-tooltip {{_ 'copied'}}
  25. else
  26. unless isPopup
  27. a.fa.fa-times-thin.close-card-details.js-close-card-details(title="{{_ 'close-card'}}")
  28. if currentUser.isBoardMember
  29. a.fa.fa-navicon.card-details-menu-mobile-web.js-open-card-details-menu(title="{{_ 'cardDetailsActionsPopup-title'}}")
  30. a.fa.fa-link.card-copy-mobile-button.js-copy-link(
  31. id="cardURL_copy"
  32. class="fa-link"
  33. title="{{_ 'copy-card-link-to-clipboard'}}"
  34. href="{{ originRelativeUrl }}"
  35. )
  36. span.copied-tooltip {{_ 'copied'}}
  37. h2.card-details-title.js-card-title(
  38. class="{{#if canModifyCard}}js-open-inlined-form is-editable{{/if}}")
  39. +viewer
  40. if currentBoard.allowsCardNumber
  41. span.card-number
  42. | ##{getCardNumber}
  43. = getTitle
  44. if isWatching
  45. i.card-details-watch.fa.fa-eye
  46. .card-details-path
  47. each parentList
  48. |   >  
  49. a.js-parent-card(href=linkForCard) {{title}}
  50. // else
  51. {{_ 'top-level-card'}}
  52. if isLinkedCard
  53. a.linked-card-location.js-go-to-linked-card
  54. +viewer
  55. | {{getBoardTitle}} > {{getTitle}}
  56. if getArchived
  57. if isLinkedBoard
  58. p.warning {{_ 'board-archived'}}
  59. else
  60. p.warning {{_ 'card-archived'}}
  61. .card-details-left
  62. .card-details-items
  63. if currentBoard.allowsLabels
  64. .card-details-item.card-details-item-labels
  65. h3.card-details-item-title
  66. i.fa.fa-tags
  67. | {{_ 'labels'}}
  68. a(class="{{#if canModifyCard}}js-add-labels{{else}}is-disabled{{/if}}" title="{{_ 'card-labels-title'}}")
  69. each labels
  70. span.card-label(class="card-label-{{color}}" title=name)
  71. +viewer
  72. = name
  73. if canModifyCard
  74. unless currentUser.isWorker
  75. a.card-label.add-label.js-add-labels(title="{{_ 'card-labels-title'}}")
  76. i.fa.fa-plus
  77. if currentBoard.hasAnyAllowsDate
  78. hr
  79. if currentBoard.allowsReceivedDate
  80. .card-details-item.card-details-item-received
  81. h3.card-details-item-title
  82. i.fa.fa-sign-out
  83. | {{_ 'card-received'}}
  84. if getReceived
  85. +cardReceivedDate
  86. else
  87. if canModifyCard
  88. unless currentUser.isWorker
  89. a.card-label.add-label.js-received-date
  90. i.fa.fa-plus
  91. if currentBoard.allowsStartDate
  92. .card-details-item.card-details-item-start
  93. h3.card-details-item-title
  94. i.fa.fa-hourglass-start
  95. | {{_ 'card-start'}}
  96. if getStart
  97. +cardStartDate
  98. else
  99. if canModifyCard
  100. unless currentUser.isWorker
  101. a.card-label.add-label.js-start-date
  102. i.fa.fa-plus
  103. if currentBoard.allowsDueDate
  104. .card-details-item.card-details-item-due
  105. h3.card-details-item-title
  106. i.fa.fa-sign-in
  107. | {{_ 'card-due'}}
  108. if getDue
  109. +cardDueDate
  110. else
  111. if canModifyCard
  112. unless currentUser.isWorker
  113. a.card-label.add-label.js-due-date
  114. i.fa.fa-plus
  115. if currentBoard.allowsEndDate
  116. .card-details-item.card-details-item-end
  117. h3.card-details-item-title
  118. i.fa.fa-hourglass-end
  119. | {{_ 'card-end'}}
  120. if getEnd
  121. +cardEndDate
  122. else
  123. if canModifyCard
  124. unless currentUser.isWorker
  125. a.card-label.add-label.js-end-date
  126. i.fa.fa-plus
  127. if currentBoard.hasAnyAllowsUser
  128. hr
  129. if currentBoard.allowsCreator
  130. .card-details-item.card-details-item-creator
  131. h3.card-details-item-title
  132. i.fa.fa-user
  133. | {{_ 'creator'}}
  134. +userAvatar(userId=userId noRemove=true)
  135. | {{! XXX Hack to hide syntaxic coloration /// }}
  136. //.card-details-items
  137. if currentBoard.allowsMembers
  138. .card-details-item.card-details-item-members
  139. h3.card-details-item-title
  140. i.fa.fa-users
  141. | {{_ 'members'}}
  142. each userId in getMembers
  143. +userAvatar(userId=userId cardId=_id)
  144. | {{! XXX Hack to hide syntaxic coloration /// }}
  145. if canModifyCard
  146. unless currentUser.isWorker
  147. a.member.add-member.card-details-item-add-button.js-add-members(title="{{_ 'card-members-title'}}")
  148. i.fa.fa-plus
  149. //if assigneeSelected
  150. if currentBoard.allowsAssignee
  151. .card-details-item.card-details-item-assignees
  152. h3.card-details-item-title
  153. i.fa.fa-user
  154. | {{_ 'assignee'}}
  155. each userId in getAssignees
  156. +userAvatar(userId=userId cardId=_id assignee=true)
  157. | {{! XXX Hack to hide syntaxic coloration /// }}
  158. if canModifyCard
  159. a.assignee.add-assignee.card-details-item-add-button.js-add-assignees(title="{{_ 'assignee'}}")
  160. i.fa.fa-plus
  161. if currentUser.isWorker
  162. unless assigneeSelected
  163. a.assignee.add-assignee.card-details-item-add-button.js-add-assignees(title="{{_ 'assignee'}}")
  164. i.fa.fa-plus
  165. //.card-details-items
  166. if currentBoard.allowsRequestedBy
  167. .card-details-item.card-details-item-name
  168. h3.card-details-item-title
  169. i.fa.fa-shopping-cart
  170. | {{_ 'requested-by'}}
  171. if canModifyCard
  172. unless currentUser.isWorker
  173. +inlinedForm(classNames="js-card-details-requester")
  174. +editCardRequesterForm
  175. else
  176. a.js-open-inlined-form
  177. if getRequestedBy
  178. +viewer
  179. = getRequestedBy
  180. else
  181. | {{_ 'add'}}
  182. else if getRequestedBy
  183. +viewer
  184. = getRequestedBy
  185. if currentBoard.allowsAssignedBy
  186. .card-details-item.card-details-item-name
  187. h3.card-details-item-title
  188. i.fa.fa-user-plus
  189. | {{_ 'assigned-by'}}
  190. if canModifyCard
  191. unless currentUser.isWorker
  192. +inlinedForm(classNames="js-card-details-assigner")
  193. +editCardAssignerForm
  194. else
  195. a.js-open-inlined-form
  196. if getAssignedBy
  197. +viewer
  198. = getAssignedBy
  199. else
  200. | {{_ 'add'}}
  201. else if getRequestedBy
  202. +viewer
  203. = getAssignedBy
  204. if $or currentBoard.allowsCardSortingByNumber getSpentTime
  205. hr
  206. if currentBoard.allowsCardSortingByNumber
  207. .card-details-item.card-details-sort-order
  208. h3.card-details-item-title
  209. i.fa.fa-sort
  210. | {{_ 'sort'}}
  211. if canModifyCard
  212. +inlinedForm(classNames="js-card-details-sort")
  213. +editCardSortOrderForm
  214. else
  215. a.js-open-inlined-form
  216. +viewer
  217. = sort
  218. //.card-details-items
  219. if getSpentTime
  220. .card-details-item.card-details-item-spent
  221. if getIsOvertime
  222. h3.card-details-item-title
  223. | {{_ 'overtime-hours'}}
  224. else
  225. h3.card-details-item-title
  226. | {{_ 'spent-time-hours'}}
  227. +cardSpentTime
  228. //.card-details-items
  229. if customFieldsWD
  230. unless customFieldsGrid
  231. hr
  232. each customFieldsWD
  233. if customFieldsGrid
  234. hr
  235. .card-details-item.card-details-item-customfield
  236. h3.card-details-item-title
  237. i.fa.fa-list-alt
  238. = definition.name
  239. +cardCustomField
  240. .material-toggle-switch(title="{{_ 'change'}} {{_ 'custom-fields'}} {{_ 'layout'}}")
  241. if customFieldsGrid
  242. input.toggle-switch(type="checkbox" id="toggleCustomFieldsGridButton" checked="checked")
  243. else
  244. input.toggle-switch(type="checkbox" id="toggleCustomFieldsGridButton")
  245. label.toggle-label(for="toggleCustomFieldsGridButton")
  246. a.fa.fa-plus.js-custom-fields.card-details-item.custom-fields(title="{{_ 'custom-fields'}}")
  247. if getVoteQuestion
  248. hr
  249. .vote-title
  250. div.flex
  251. h3
  252. i.fa.fa-thumbs-up
  253. | {{_ 'vote-question'}}
  254. if getVoteEnd
  255. +voteEndDate
  256. .vote-result
  257. if votePublic
  258. a.card-label.card-label-green.js-show-positive-votes {{ voteCountPositive }}
  259. a.card-label.card-label-red.js-show-negative-votes {{ voteCountNegative }}
  260. else
  261. .card-label.card-label-green {{ voteCountPositive }}
  262. .card-label.card-label-red {{ voteCountNegative }}
  263. unless ($and currentBoard.isPublic voteAllowNonBoardMembers )
  264. .card-label.card-label-gray {{ voteCount }} {{_ 'r-of' }} {{ currentBoard.activeMembers.length }}
  265. +viewer
  266. = getVoteQuestion
  267. if showVotingButtons
  268. button.card-details-green.js-vote.js-vote-positive(class="{{#if voteState}}voted{{/if}}")
  269. if voteState
  270. i.fa.fa-thumbs-up
  271. | {{_ 'vote-for-it'}}
  272. button.card-details-red.js-vote.js-vote-negative(class="{{#if $eq voteState false}}voted{{/if}}")
  273. if $eq voteState false
  274. i.fa.fa-thumbs-down
  275. | {{_ 'vote-against'}}
  276. if getPokerQuestion
  277. hr
  278. .poker-title
  279. div.flex
  280. h3
  281. i.fa.fa-thumbs-up
  282. | {{_ 'poker-question'}}
  283. if getPokerEnd
  284. +pokerEndDate
  285. div.flex
  286. .poker-result
  287. if expiredPoker
  288. unless ($and currentBoard.isPublic pokerAllowNonBoardMembers )
  289. .card-label.card-label-gray {{ pokerCount }} {{_ 'r-of' }} {{ currentBoard.activeMembers.length }}
  290. if showPlanningPokerButtons
  291. .poker-result
  292. .poker-deck
  293. .poker-card
  294. span.inner.js-poker.js-poker-vote-one(class="{{#if $eq pokerState 'one'}}poker-voted{{/if}}") {{_ 'poker-one'}}
  295. if $eq pokerState "one"
  296. i.fa.fa-check
  297. .poker-deck
  298. .poker-card
  299. span.inner.js-poker.js-poker-vote-two(class="{{#if $eq pokerState 'two'}}poker-voted{{/if}}") {{_ 'poker-two'}}
  300. if $eq pokerState "two"
  301. i.fa.fa-check
  302. .poker-deck
  303. .poker-card
  304. span.inner.js-poker.js-poker-vote-three(class="{{#if $eq pokerState 'three'}}poker-voted{{/if}}") {{_ 'poker-three'}}
  305. if $eq pokerState "three"
  306. i.fa.fa-check
  307. .poker-deck
  308. .poker-card
  309. span.inner.js-poker.js-poker-vote-five(class="{{#if $eq pokerState 'five'}}poker-voted{{/if}}") {{_ 'poker-five'}}
  310. if $eq pokerState "five"
  311. i.fa.fa-check
  312. .poker-deck
  313. .poker-card
  314. span.inner.js-poker.js-poker-vote-eight(class="{{#if $eq pokerState 'eight'}}poker-voted{{/if}}") {{_ 'poker-eight'}}
  315. if $eq pokerState "eight"
  316. i.fa.fa-check
  317. .poker-deck
  318. .poker-card
  319. span.inner.js-poker.js-poker-vote-thirteen(class="{{#if $eq pokerState 'thirteen'}}poker-voted{{/if}}") {{_ 'poker-thirteen'}}
  320. if $eq pokerState "thirteen"
  321. i.fa.fa-check
  322. .poker-deck
  323. .poker-card
  324. span.inner.js-poker.js-poker-vote-twenty(class="{{#if $eq pokerState 'twenty'}}poker-voted{{/if}}") {{_ 'poker-twenty'}}
  325. if $eq pokerState "twenty"
  326. i.fa.fa-check
  327. .poker-deck
  328. .poker-card
  329. span.inner.js-poker.js-poker-vote-forty(class="{{#if $eq pokerState 'forty'}}poker-voted{{/if}}") {{_ 'poker-forty'}}
  330. if $eq pokerState "forty"
  331. i.fa.fa-check
  332. .poker-deck
  333. .poker-card
  334. span.inner.js-poker.js-poker-vote-one-hundred(class="{{#if $eq pokerState 'oneHundred'}}poker-voted{{/if}}") {{_ 'poker-oneHundred'}}
  335. if $eq pokerState "oneHundred"
  336. i.fa.fa-check
  337. .poker-deck
  338. .poker-card
  339. span.inner.js-poker.js-poker-vote-unsure(class="{{#if $eq pokerState 'unsure'}}poker-voted{{/if}}") {{_ 'poker-unsure'}}
  340. if $eq pokerState "unsure"
  341. i.fa.fa-check
  342. if currentUser.isBoardAdmin
  343. button.card-details-blue.js-poker-finish(class="{{#if $eq voteState false}}poker-voted{{/if}}") {{_ 'poker-finish'}}
  344. if expiredPoker
  345. .poker-table
  346. .poker-table-side-left
  347. .poker-table-heading-left
  348. .poker-table-row
  349. .poker-table-cell
  350. .poker-table-cell
  351. | {{_ 'poker-result-votes' }}
  352. .poker-table-cell.poker-table-cell-who
  353. | {{_ 'poker-result-who' }}
  354. .poker-table-body
  355. .poker-table-row
  356. .poker-table-cell
  357. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 1}}winner{{else}}loser{{/if}}") {{_ 'poker-one'}}
  358. .poker-table-cell {{ pokerCountOne }}
  359. .poker-table-cell.poker-table-cell-who
  360. .poker-result
  361. each m in pokerMemberOne
  362. a.name
  363. +userAvatar(userId=m._id noRemove=true)
  364. .poker-table-row
  365. .poker-table-cell
  366. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 2}}winner{{else}}loser{{/if}}") {{_ 'poker-two'}}
  367. .poker-table-cell {{ pokerCountTwo }}
  368. .poker-table-cell.poker-table-cell-who
  369. .poker-result
  370. each m in pokerMemberTwo
  371. a.name
  372. +userAvatar(userId=m._id noRemove=true)
  373. .poker-table-row
  374. .poker-table-cell
  375. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 3}}winner{{else}}loser{{/if}}") {{_ 'poker-three'}}
  376. .poker-table-cell {{ pokerCountThree }}
  377. .poker-table-cell.poker-table-cell-who
  378. .poker-result
  379. each m in pokerMemberThree
  380. a.name
  381. +userAvatar(userId=m._id noRemove=true)
  382. .poker-table-row
  383. .poker-table-cell
  384. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 5}}winner{{else}}loser{{/if}}") {{_ 'poker-five'}}
  385. .poker-table-cell {{ pokerCountFive }}
  386. .poker-table-cell.poker-table-cell-who
  387. .poker-result
  388. each m in pokerMemberFive
  389. a.name
  390. +userAvatar(userId=m._id noRemove=true)
  391. .poker-table-row
  392. .poker-table-cell
  393. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 8}}winner{{else}}loser{{/if}}") {{_ 'poker-eight'}}
  394. .poker-table-cell {{ pokerCountEight }}
  395. .poker-table-cell.poker-table-cell-who
  396. .poker-result
  397. each m in pokerMemberEight
  398. a.name
  399. +userAvatar(userId=m._id noRemove=true)
  400. .poker-table-side-right
  401. .poker-table-heading-right
  402. .poker-table-row
  403. .poker-table-cell
  404. .poker-table-cell
  405. | {{_ 'poker-result-votes' }}
  406. .poker-table-cell.poker-table-cell-who
  407. | {{_ 'poker-result-who' }}
  408. .poker-table-body
  409. .poker-table-row
  410. .poker-table-cell
  411. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 13}}winner{{else}}loser{{/if}}") {{_ 'poker-thirteen'}}
  412. .poker-table-cell {{ pokerCountThirteen }}
  413. .poker-table-cell.poker-table-cell-who
  414. .poker-result
  415. each m in pokerMemberThirteen
  416. a.name
  417. +userAvatar(userId=m._id noRemove=true)
  418. .poker-table-row
  419. .poker-table-cell
  420. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 20}}winner{{else}}loser{{/if}}") {{_ 'poker-twenty'}}
  421. .poker-table-cell {{ pokerCountTwenty }}
  422. .poker-table-cell.poker-table-cell-who
  423. .poker-result
  424. each m in pokerMemberTwenty
  425. a.name
  426. +userAvatar(userId=m._id noRemove=true)
  427. .poker-table-row
  428. .poker-table-cell
  429. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 40}}winner{{else}}loser{{/if}}") {{_ 'poker-forty'}}
  430. .poker-table-cell {{ pokerCountForty }}
  431. .poker-table-cell.poker-table-cell-who
  432. .poker-result
  433. each m in pokerMemberForty
  434. a.name
  435. +userAvatar(userId=m._id noRemove=true)
  436. .poker-table-row
  437. .poker-table-cell
  438. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 100}}winner{{else}}loser{{/if}}") {{_ 'poker-oneHundred'}}
  439. .poker-table-cell {{ pokerCountOneHundred }}
  440. .poker-table-cell.poker-table-cell-who
  441. .poker-result
  442. each m in pokerMemberOneHundred
  443. a.name
  444. +userAvatar(userId=m._id noRemove=true)
  445. .poker-table-row
  446. .poker-table-cell
  447. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 'unsure'}}winner{{else}}loser{{/if}}") {{_ 'poker-unsure'}}
  448. .poker-table-cell {{ pokerCountUnsure }}
  449. .poker-table-cell.poker-table-cell-who
  450. .poker-result
  451. each m in pokerMemberUnsure
  452. a.name
  453. +userAvatar(userId=m._id noRemove=true)
  454. if currentUser.isBoardAdmin
  455. div.estimation-add
  456. button.card-details-red.js-poker-replay(class="{{#if $eq voteState false}}voted{{/if}}") {{_ 'poker-replay'}}
  457. div.estimation-add
  458. button.js-poker-estimation
  459. i.fa.fa-plus
  460. | {{_ 'set-estimation'}}
  461. input(type=text,autofocus value=getPokerEstimation,id="pokerEstimation")
  462. //- XXX We should use "editable" to avoid repetiting ourselves
  463. if canModifyCard
  464. unless currentUser.isWorker
  465. if currentBoard.allowsDescriptionTitle
  466. hr
  467. h3.card-details-item-title
  468. i.fa.fa-align-left
  469. | {{_ 'description'}}
  470. if currentBoard.allowsDescriptionText
  471. +inlinedCardDescription(classNames="card-description js-card-description")
  472. +descriptionForm
  473. .edit-controls.clearfix
  474. button.primary(type="submit") {{_ 'save'}}
  475. a.fa.fa-times-thin.js-close-inlined-form
  476. else
  477. if currentBoard.allowsDescriptionText
  478. a.js-open-inlined-form
  479. if getDescription
  480. +viewer
  481. = getDescription
  482. else
  483. | {{_ 'edit'}}
  484. if (hasUnsavedValue 'cardDescription' _id)
  485. p.quiet
  486. | {{_ 'unsaved-description'}}
  487. a.js-open-inlined-form {{_ 'view-it'}}
  488. = ' - '
  489. a.js-close-inlined-form {{_ 'discard'}}
  490. else if getDescription
  491. if currentBoard.allowsDescriptionTitle
  492. hr
  493. h3.card-details-item-title {{_ 'description'}}
  494. if currentBoard.allowsDescriptionText
  495. +viewer
  496. = getDescription
  497. .card-checklist-attachmentGalerys
  498. .card-checklist-attachmentGalery.card-checklists
  499. if currentBoard.allowsChecklists
  500. hr
  501. +checklists(cardId = _id)
  502. if currentBoard.allowsSubtasks
  503. hr
  504. +subtasks(cardId = _id)
  505. if currentBoard.allowsAttachments
  506. hr
  507. h3.card-details-item-title
  508. i.fa.fa-paperclip
  509. | {{_ 'attachments'}}
  510. .card-checklist-attachmentGalery.card-attachmentGalery
  511. +attachmentsGalery
  512. .card-details-right
  513. unless currentUser.isNoComments
  514. hr
  515. .activity-title
  516. h3.card-details-item-title
  517. i.fa.fa-history
  518. | {{ _ 'activity'}}
  519. if currentUser.isBoardMember
  520. .material-toggle-switch(title="{{_ 'hide-system-messages'}}")
  521. //span.toggle-switch-title
  522. if hiddenSystemMessages
  523. input.toggle-switch(type="checkbox" id="toggleButton" checked="checked")
  524. else
  525. input.toggle-switch(type="checkbox" id="toggleButton")
  526. label.toggle-label(for="toggleButton")
  527. if currentBoard.allowsComments
  528. if currentUser.isBoardMember
  529. unless currentUser.isNoComments
  530. +commentForm
  531. unless currentUser.isNoComments
  532. if isLoaded.get
  533. if isLinkedCard
  534. +activities(card=this mode="linkedcard")
  535. else if isLinkedBoard
  536. +activities(card=this mode="linkedboard")
  537. else
  538. +activities(card=this mode="card")
  539. template(name="editCardTitleForm")
  540. textarea.js-edit-card-title(rows='1' autofocus dir="auto")
  541. = getTitle
  542. .edit-controls.clearfix
  543. button.primary.confirm.js-submit-edit-card-title-form(type="submit") {{_ 'save'}}
  544. a.fa.fa-times-thin.js-close-inlined-form
  545. template(name="editCardRequesterForm")
  546. input.js-edit-card-requester(type='text' autofocus value=getRequestedBy dir="auto")
  547. .edit-controls.clearfix
  548. button.primary.confirm.js-submit-edit-card-requester-form(type="submit") {{_ 'save'}}
  549. a.fa.fa-times-thin.js-close-inlined-form
  550. template(name="editCardAssignerForm")
  551. input.js-edit-card-assigner(type='text' autofocus value=getAssignedBy dir="auto")
  552. .edit-controls.clearfix
  553. button.primary.confirm.js-submit-edit-card-assigner-form(type="submit") {{_ 'save'}}
  554. a.fa.fa-times-thin.js-close-inlined-form
  555. template(name="editCardSortOrderForm")
  556. input.js-edit-card-sort(type='text' autofocus value=sort dir="auto")
  557. .edit-controls.clearfix
  558. button.primary.confirm.js-submit-edit-card-sort-form(type="submit") {{_ 'save'}}
  559. a.fa.fa-times-thin.js-close-inlined-form
  560. template(name="cardDetailsActionsPopup")
  561. ul.pop-over-list
  562. li
  563. a.js-toggle-watch-card
  564. if isWatching
  565. i.fa.fa-eye
  566. | {{_ 'unwatch'}}
  567. else
  568. i.fa.fa-eye-slash
  569. | {{_ 'watch'}}
  570. hr
  571. if canModifyCard
  572. unless currentUser.isWorker
  573. ul.pop-over-list
  574. //li: a.js-members {{_ 'card-edit-members'}}
  575. //li: a.js-labels {{_ 'card-edit-labels'}}
  576. //li: a.js-attachments {{_ 'card-edit-attachments'}}
  577. li
  578. a.js-start-voting
  579. i.fa.fa-thumbs-up
  580. | {{_ 'card-edit-voting'}}
  581. li
  582. a.js-start-planning-poker
  583. i.fa.fa-thumbs-up
  584. | {{_ 'card-edit-planning-poker'}}
  585. if currentUser.isBoardAdmin
  586. li
  587. a.js-custom-fields
  588. i.fa.fa-list-alt
  589. | {{_ 'card-edit-custom-fields'}}
  590. //li: a.js-received-date {{_ 'editCardReceivedDatePopup-title'}}
  591. //li: a.js-start-date {{_ 'editCardStartDatePopup-title'}}
  592. //li: a.js-due-date {{_ 'editCardDueDatePopup-title'}}
  593. //li: a.js-end-date {{_ 'editCardEndDatePopup-title'}}
  594. li
  595. a.js-spent-time
  596. i.fa.fa-clock-o
  597. | {{_ 'editCardSpentTimePopup-title'}}
  598. li
  599. a.js-set-card-color
  600. i.fa.fa-paint-brush
  601. | {{_ 'setCardColorPopup-title'}}
  602. hr
  603. ul.pop-over-list
  604. li
  605. a.js-export-card
  606. i.fa.fa-share-alt
  607. | {{_ 'export-card'}}
  608. hr
  609. ul.pop-over-list
  610. li
  611. a.js-move-card-to-top
  612. i.fa.fa-arrow-up
  613. | {{_ 'moveCardToTop-title'}}
  614. li
  615. a.js-move-card-to-bottom
  616. i.fa.fa-arrow-down
  617. | {{_ 'moveCardToBottom-title'}}
  618. hr
  619. ul.pop-over-list
  620. if currentUser.isBoardAdmin
  621. li
  622. a.js-move-card
  623. i.fa.fa-arrow-right
  624. | {{_ 'moveCardPopup-title'}}
  625. unless currentUser.isWorker
  626. li
  627. a.js-copy-card
  628. i.fa.fa-copy
  629. | {{_ 'copyCardPopup-title'}}
  630. unless currentUser.isWorker
  631. hr
  632. ul.pop-over-list
  633. li
  634. a.js-copy-checklist-cards
  635. i.fa.fa-list
  636. i.fa.fa-copy
  637. | {{_ 'copyChecklistToManyCardsPopup-title'}}
  638. unless archived
  639. hr
  640. ul.pop-over-list
  641. li
  642. a.js-archive
  643. i.fa.fa-arrow-right
  644. i.fa.fa-archive
  645. | {{_ 'archive-card'}}
  646. hr
  647. ul.pop-over-list
  648. li
  649. a.js-more
  650. i.fa.fa-link
  651. | {{_ 'cardMorePopup-title'}}
  652. template(name="exportCardPopup")
  653. ul.pop-over-list
  654. li
  655. a(href="{{exportUrlCardPDF}}",, download="{{exportFilenameCardPDF}}")
  656. i.fa.fa-share-alt
  657. | {{_ 'export-card-pdf'}}
  658. template(name="moveCardPopup")
  659. +boardsAndLists
  660. template(name="copyCardPopup")
  661. label(for='copy-card-title') {{_ 'title'}}:
  662. textarea#copy-card-title.minicard-composer-textarea.js-card-title(autofocus)
  663. = getTitle
  664. +boardsAndLists
  665. template(name="copyChecklistToManyCardsPopup")
  666. label(for='copy-checklist-cards-title') {{_ 'copyChecklistToManyCardsPopup-instructions'}}:
  667. textarea#copy-card-title.minicard-composer-textarea.js-card-title(autofocus)
  668. | {{_ 'copyChecklistToManyCardsPopup-format'}}
  669. +boardsAndLists
  670. template(name="boardsAndLists")
  671. unless currentUser.isWorker
  672. label {{_ 'boards'}}:
  673. select.js-select-boards(autofocus)
  674. each boards
  675. if $eq _id currentBoard._id
  676. option(value="{{_id}}" selected) {{_ 'current'}}
  677. else
  678. option(value="{{_id}}") {{title}}
  679. label {{_ 'swimlanes'}}:
  680. select.js-select-swimlanes
  681. each swimlanes
  682. option(value="{{_id}}") {{title}}
  683. label {{_ 'lists'}}:
  684. select.js-select-lists
  685. each aBoardLists
  686. option(value="{{_id}}") {{title}}
  687. .edit-controls.clearfix
  688. button.primary.confirm.js-done {{_ 'done'}}
  689. template(name="cardMembersPopup")
  690. input.card-members-filter(type="text" placeholder="{{_ 'search'}}")
  691. ul.pop-over-list.js-card-member-list
  692. each members
  693. li.item(class="{{#if isCardMember}}active{{/if}}")
  694. a.name.js-select-member(href="#")
  695. +userAvatar(userId=user._id)
  696. span.full-name
  697. = user.profile.fullname
  698. | (<span class="username">{{ user.username }}</span>)
  699. if isCardMember
  700. i.fa.fa-check
  701. template(name="cardAssigneesPopup")
  702. input.card-assignees-filter(type="text" placeholder="{{_ 'search'}}")
  703. unless currentUser.isWorker
  704. ul.pop-over-list.js-card-assignee-list
  705. each members
  706. li.item(class="{{#if isCardAssignee}}active{{/if}}")
  707. a.name.js-select-assignee(href="#")
  708. +userAvatar(userId=user._id)
  709. span.full-name
  710. = user.profile.fullname
  711. | (<span class="username">{{ user.username }}</span>)
  712. if isCardAssignee
  713. i.fa.fa-check
  714. if currentUser.isWorker
  715. ul.pop-over-list.js-card-assignee-list
  716. li.item(class="{{#if currentUser.isCardAssignee}}active{{/if}}")
  717. a.name.js-select-assignee(href="#")
  718. +userAvatar(userId=currentUser._id)
  719. span.full-name
  720. = currentUser.profile.fullname
  721. | (<span class="username">{{ currentUser.username }}</span>)
  722. if currentUser.isCardAssignee
  723. i.fa.fa-check
  724. template(name="cardAssigneePopup")
  725. .board-assignee-menu
  726. .mini-profile-info
  727. +userAvatar(userId=user._id showEdit=true)
  728. .info
  729. h3= user.profile.fullname
  730. p.quiet @{{ user.username }}
  731. ul.pop-over-list
  732. if currentUser.isNotCommentOnly
  733. unless currentUser.isWorker
  734. li: a.js-remove-assignee {{_ 'remove-member-from-card'}}
  735. unless currentUser.isWorker
  736. if $eq currentUser._id user._id
  737. with currentUser
  738. li: a.js-edit-profile {{_ 'edit-profile'}}
  739. template(name="cardMorePopup")
  740. p.quiet
  741. span.clearfix
  742. span {{_ 'link-card'}}
  743. = ' '
  744. i.fa.colorful(class="{{#if board.isPublic}}fa-globe{{else}}fa-lock{{/if}}")
  745. input.inline-input(type="text" id="cardURL" readonly value="{{ originRelativeUrl }}" autofocus="autofocus")
  746. button.js-copy-card-link-to-clipboard(class="btn" id="clipboard") {{_ 'copy-card-link-to-clipboard'}}
  747. .copied-tooltip {{_ 'copied'}}
  748. span.clearfix
  749. br
  750. h2 {{_ 'change-card-parent'}}
  751. label {{_ 'source-board'}}:
  752. select.js-field-parent-board
  753. if isTopLevel
  754. option(value="none" selected) {{_ 'custom-field-dropdown-none'}}
  755. else
  756. option(value="none") {{_ 'custom-field-dropdown-none'}}
  757. each boards
  758. if isParentBoard
  759. option(value="{{_id}}" selected) {{title}}
  760. else
  761. option(value="{{_id}}") {{title}}
  762. label {{_ 'parent-card'}}:
  763. select.js-field-parent-card
  764. if isTopLevel
  765. option(value="none" selected) {{_ 'custom-field-dropdown-none'}}
  766. else
  767. option(value="none") {{_ 'custom-field-dropdown-none'}}
  768. each cards
  769. if isParentCard
  770. option(value="{{_id}}" selected) {{title}}
  771. else
  772. option(value="{{_id}}") {{title}}
  773. br
  774. | {{_ 'added'}}
  775. span.date(title=card.createdAt) {{ moment createdAt 'LLL' }}
  776. if currentUser.isBoardAdmin
  777. a.js-delete(title="{{_ 'card-delete-notice'}}") {{_ 'delete'}}
  778. template(name="setCardColorPopup")
  779. form.edit-label
  780. .palette-colors: each colors
  781. unless $eq color 'white'
  782. span.card-label.palette-color.js-palette-color(class="card-details-{{color}}")
  783. if(isSelected color)
  784. i.fa.fa-check
  785. button.primary.confirm.js-submit {{_ 'save'}}
  786. button.js-remove-color.negate.wide.right {{_ 'unset-color'}}
  787. template(name="cardDeletePopup")
  788. p {{_ "card-delete-pop"}}
  789. unless archived
  790. p {{_ "card-delete-suggest-archive"}}
  791. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}
  792. template(name="cardArchivePopup")
  793. p {{_ "card-archive-pop"}}
  794. unless archived
  795. p {{_ "card-archive-suggest-cancel"}}
  796. button.js-confirm.negate.full(type="submit") {{_ 'archive'}}
  797. template(name="deleteVotePopup")
  798. p {{_ "vote-delete-pop"}}
  799. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}
  800. template(name="cardStartVotingPopup")
  801. form.edit-vote-question
  802. .fields
  803. label(for="vote") {{_ 'vote-question'}}
  804. input.js-vote-field#vote(type="text" name="vote" value="{{getVoteQuestion}}" autofocus disabled="{{#if getVoteQuestion}}disabled{{/if}}")
  805. .check-div
  806. a.flex(class="{{#if getVoteQuestion}}is-disabled{{else}}js-toggle-vote-allow-non-members{{/if}}")
  807. .materialCheckBox#vote-allow-non-members(name="vote-allow-non-members" class="{{#if voteAllowNonBoardMembers}}is-checked{{/if}}")
  808. span {{_ 'allowNonBoardMembers'}}
  809. .check-div
  810. a.flex(class="{{#if getVoteQuestion}}is-disabled{{else}}js-toggle-vote-public{{/if}}")
  811. .materialCheckBox#vote-public(name="vote-public" class="{{#if votePublic}}is-checked{{/if}}")
  812. span {{_ 'vote-public'}}
  813. .check-div.flex
  814. i.fa.fa-hourglass-end
  815. a.js-end-date
  816. span
  817. | {{_ 'card-end'}}
  818. unless getVoteEnd
  819. i.fa.fa-plus
  820. if getVoteEnd
  821. +voteEndDate
  822. button.primary.js-submit {{_ 'save'}}
  823. if getVoteQuestion
  824. if currentUser.isBoardAdmin
  825. button.js-remove-vote.negate.wide.right {{_ 'delete'}}
  826. template(name="positiveVoteMembersPopup")
  827. ul.pop-over-list.js-card-member-list
  828. each m in voteMemberPositive
  829. li.item
  830. a.name
  831. +userAvatar(userId=m._id)
  832. span.full-name
  833. = m.profile.fullname
  834. | (<span class="username">{{ m.username }}</span>)
  835. template(name="negativeVoteMembersPopup")
  836. ul.pop-over-list.js-card-member-list
  837. each m in voteMemberNegative
  838. li.item
  839. a.name
  840. +userAvatar(userId=m._id)
  841. span.full-name
  842. = m.profile.fullname
  843. | (<span class="username">{{ m.username }}</span>)
  844. template(name="deletePokerPopup")
  845. p {{_ "poker-delete-pop"}}
  846. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}
  847. template(name="cardStartPlanningPokerPopup")
  848. form.edit-poker-question
  849. .fields
  850. .check-div
  851. a.flex(class="{{#if getPokerQuestion}}is-disabled{{else}}js-toggle-poker-allow-non-members{{/if}}")
  852. .materialCheckBox#poker-allow-non-members(name="poker-allow-non-members" class="{{#if pokerAllowNonBoardMembers}}is-checked{{/if}}")
  853. span {{_ 'allowNonBoardMembers'}}
  854. .check-div.flex
  855. i.fa.fa-hourglass-end
  856. a.js-end-date
  857. span
  858. | {{_ 'card-end'}}
  859. unless getPokerEnd
  860. i.fa.fa-plus
  861. if getPokerEnd
  862. +pokerEndDate
  863. button.primary.js-submit {{_ 'save'}}
  864. if getPokerQuestion
  865. if currentUser.isBoardAdmin
  866. button.js-remove-poker.negate.wide.right {{_ 'delete'}}