cardDetails.jade 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949
  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. if currentBoard.allowsShowLists
  219. .card-details-item.card-details-show-lists
  220. h3.card-details-item-title
  221. i.fa.fa-list
  222. | {{_ 'list'}}
  223. select.js-select-card-details-lists(disabled="{{#unless canModifyCard}}disabled{{/unless}}")
  224. each currentBoard.lists
  225. option(value="{{_id}}" selected="{{#if isCurrentListId _id}}selected{{/if}}") {{title}}
  226. //.card-details-items
  227. if getSpentTime
  228. .card-details-item.card-details-item-spent
  229. if getIsOvertime
  230. h3.card-details-item-title
  231. | {{_ 'overtime-hours'}}
  232. else
  233. h3.card-details-item-title
  234. | {{_ 'spent-time-hours'}}
  235. +cardSpentTime
  236. //.card-details-items
  237. if customFieldsWD
  238. unless customFieldsGrid
  239. hr
  240. each customFieldsWD
  241. if customFieldsGrid
  242. hr
  243. .card-details-item.card-details-item-customfield
  244. h3.card-details-item-title
  245. i.fa.fa-list-alt
  246. = definition.name
  247. +cardCustomField
  248. if $gt customFieldsWD.length 1
  249. .material-toggle-switch(title="{{_ 'change'}} {{_ 'custom-fields'}} {{_ 'layout'}}")
  250. if customFieldsGrid
  251. input.toggle-switch(type="checkbox" id="toggleCustomFieldsGridButton" checked="checked")
  252. else
  253. input.toggle-switch(type="checkbox" id="toggleCustomFieldsGridButton")
  254. label.toggle-label(for="toggleCustomFieldsGridButton")
  255. a.fa.fa-plus.js-custom-fields.card-details-item.custom-fields(title="{{_ 'custom-fields'}}")
  256. if getVoteQuestion
  257. hr
  258. .vote-title
  259. div.flex
  260. h3
  261. i.fa.fa-thumbs-up
  262. | {{_ 'vote-question'}}
  263. if getVoteEnd
  264. +voteEndDate
  265. .vote-result
  266. if votePublic
  267. a.card-label.card-label-green.js-show-positive-votes {{ voteCountPositive }}
  268. a.card-label.card-label-red.js-show-negative-votes {{ voteCountNegative }}
  269. else
  270. .card-label.card-label-green {{ voteCountPositive }}
  271. .card-label.card-label-red {{ voteCountNegative }}
  272. unless ($and currentBoard.isPublic voteAllowNonBoardMembers )
  273. .card-label.card-label-gray {{ voteCount }} {{_ 'r-of' }} {{ currentBoard.activeMembers.length }}
  274. +viewer
  275. = getVoteQuestion
  276. if showVotingButtons
  277. button.card-details-green.js-vote.js-vote-positive(class="{{#if voteState}}voted{{/if}}")
  278. if voteState
  279. i.fa.fa-thumbs-up
  280. | {{_ 'vote-for-it'}}
  281. button.card-details-red.js-vote.js-vote-negative(class="{{#if $eq voteState false}}voted{{/if}}")
  282. if $eq voteState false
  283. i.fa.fa-thumbs-down
  284. | {{_ 'vote-against'}}
  285. if getPokerQuestion
  286. hr
  287. .poker-title
  288. div.flex
  289. h3
  290. i.fa.fa-thumbs-up
  291. | {{_ 'poker-question'}}
  292. if getPokerEnd
  293. +pokerEndDate
  294. div.flex
  295. .poker-result
  296. if expiredPoker
  297. unless ($and currentBoard.isPublic pokerAllowNonBoardMembers )
  298. .card-label.card-label-gray {{ pokerCount }} {{_ 'r-of' }} {{ currentBoard.activeMembers.length }}
  299. if showPlanningPokerButtons
  300. .poker-result
  301. .poker-deck
  302. .poker-card
  303. span.inner.js-poker.js-poker-vote-one(class="{{#if $eq pokerState 'one'}}poker-voted{{/if}}") {{_ 'poker-one'}}
  304. if $eq pokerState "one"
  305. i.fa.fa-check
  306. .poker-deck
  307. .poker-card
  308. span.inner.js-poker.js-poker-vote-two(class="{{#if $eq pokerState 'two'}}poker-voted{{/if}}") {{_ 'poker-two'}}
  309. if $eq pokerState "two"
  310. i.fa.fa-check
  311. .poker-deck
  312. .poker-card
  313. span.inner.js-poker.js-poker-vote-three(class="{{#if $eq pokerState 'three'}}poker-voted{{/if}}") {{_ 'poker-three'}}
  314. if $eq pokerState "three"
  315. i.fa.fa-check
  316. .poker-deck
  317. .poker-card
  318. span.inner.js-poker.js-poker-vote-five(class="{{#if $eq pokerState 'five'}}poker-voted{{/if}}") {{_ 'poker-five'}}
  319. if $eq pokerState "five"
  320. i.fa.fa-check
  321. .poker-deck
  322. .poker-card
  323. span.inner.js-poker.js-poker-vote-eight(class="{{#if $eq pokerState 'eight'}}poker-voted{{/if}}") {{_ 'poker-eight'}}
  324. if $eq pokerState "eight"
  325. i.fa.fa-check
  326. .poker-deck
  327. .poker-card
  328. span.inner.js-poker.js-poker-vote-thirteen(class="{{#if $eq pokerState 'thirteen'}}poker-voted{{/if}}") {{_ 'poker-thirteen'}}
  329. if $eq pokerState "thirteen"
  330. i.fa.fa-check
  331. .poker-deck
  332. .poker-card
  333. span.inner.js-poker.js-poker-vote-twenty(class="{{#if $eq pokerState 'twenty'}}poker-voted{{/if}}") {{_ 'poker-twenty'}}
  334. if $eq pokerState "twenty"
  335. i.fa.fa-check
  336. .poker-deck
  337. .poker-card
  338. span.inner.js-poker.js-poker-vote-forty(class="{{#if $eq pokerState 'forty'}}poker-voted{{/if}}") {{_ 'poker-forty'}}
  339. if $eq pokerState "forty"
  340. i.fa.fa-check
  341. .poker-deck
  342. .poker-card
  343. span.inner.js-poker.js-poker-vote-one-hundred(class="{{#if $eq pokerState 'oneHundred'}}poker-voted{{/if}}") {{_ 'poker-oneHundred'}}
  344. if $eq pokerState "oneHundred"
  345. i.fa.fa-check
  346. .poker-deck
  347. .poker-card
  348. span.inner.js-poker.js-poker-vote-unsure(class="{{#if $eq pokerState 'unsure'}}poker-voted{{/if}}") {{_ 'poker-unsure'}}
  349. if $eq pokerState "unsure"
  350. i.fa.fa-check
  351. if currentUser.isBoardAdmin
  352. button.card-details-blue.js-poker-finish(class="{{#if $eq voteState false}}poker-voted{{/if}}") {{_ 'poker-finish'}}
  353. if expiredPoker
  354. .poker-table
  355. .poker-table-side-left
  356. .poker-table-heading-left
  357. .poker-table-row
  358. .poker-table-cell
  359. .poker-table-cell
  360. | {{_ 'poker-result-votes' }}
  361. .poker-table-cell.poker-table-cell-who
  362. | {{_ 'poker-result-who' }}
  363. .poker-table-body
  364. .poker-table-row
  365. .poker-table-cell
  366. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 1}}winner{{else}}loser{{/if}}") {{_ 'poker-one'}}
  367. .poker-table-cell {{ pokerCountOne }}
  368. .poker-table-cell.poker-table-cell-who
  369. .poker-result
  370. each m in pokerMemberOne
  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 2}}winner{{else}}loser{{/if}}") {{_ 'poker-two'}}
  376. .poker-table-cell {{ pokerCountTwo }}
  377. .poker-table-cell.poker-table-cell-who
  378. .poker-result
  379. each m in pokerMemberTwo
  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 3}}winner{{else}}loser{{/if}}") {{_ 'poker-three'}}
  385. .poker-table-cell {{ pokerCountThree }}
  386. .poker-table-cell.poker-table-cell-who
  387. .poker-result
  388. each m in pokerMemberThree
  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 5}}winner{{else}}loser{{/if}}") {{_ 'poker-five'}}
  394. .poker-table-cell {{ pokerCountFive }}
  395. .poker-table-cell.poker-table-cell-who
  396. .poker-result
  397. each m in pokerMemberFive
  398. a.name
  399. +userAvatar(userId=m._id noRemove=true)
  400. .poker-table-row
  401. .poker-table-cell
  402. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 8}}winner{{else}}loser{{/if}}") {{_ 'poker-eight'}}
  403. .poker-table-cell {{ pokerCountEight }}
  404. .poker-table-cell.poker-table-cell-who
  405. .poker-result
  406. each m in pokerMemberEight
  407. a.name
  408. +userAvatar(userId=m._id noRemove=true)
  409. .poker-table-side-right
  410. .poker-table-heading-right
  411. .poker-table-row
  412. .poker-table-cell
  413. .poker-table-cell
  414. | {{_ 'poker-result-votes' }}
  415. .poker-table-cell.poker-table-cell-who
  416. | {{_ 'poker-result-who' }}
  417. .poker-table-body
  418. .poker-table-row
  419. .poker-table-cell
  420. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 13}}winner{{else}}loser{{/if}}") {{_ 'poker-thirteen'}}
  421. .poker-table-cell {{ pokerCountThirteen }}
  422. .poker-table-cell.poker-table-cell-who
  423. .poker-result
  424. each m in pokerMemberThirteen
  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 20}}winner{{else}}loser{{/if}}") {{_ 'poker-twenty'}}
  430. .poker-table-cell {{ pokerCountTwenty }}
  431. .poker-table-cell.poker-table-cell-who
  432. .poker-result
  433. each m in pokerMemberTwenty
  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 40}}winner{{else}}loser{{/if}}") {{_ 'poker-forty'}}
  439. .poker-table-cell {{ pokerCountForty }}
  440. .poker-table-cell.poker-table-cell-who
  441. .poker-result
  442. each m in pokerMemberForty
  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 100}}winner{{else}}loser{{/if}}") {{_ 'poker-oneHundred'}}
  448. .poker-table-cell {{ pokerCountOneHundred }}
  449. .poker-table-cell.poker-table-cell-who
  450. .poker-result
  451. each m in pokerMemberOneHundred
  452. a.name
  453. +userAvatar(userId=m._id noRemove=true)
  454. .poker-table-row
  455. .poker-table-cell
  456. button.card-details-gray.js-poker.poker-card-result(class="{{#if $eq pokerWinner 'unsure'}}winner{{else}}loser{{/if}}") {{_ 'poker-unsure'}}
  457. .poker-table-cell {{ pokerCountUnsure }}
  458. .poker-table-cell.poker-table-cell-who
  459. .poker-result
  460. each m in pokerMemberUnsure
  461. a.name
  462. +userAvatar(userId=m._id noRemove=true)
  463. if currentUser.isBoardAdmin
  464. div.estimation-add
  465. button.card-details-red.js-poker-replay(class="{{#if $eq voteState false}}voted{{/if}}") {{_ 'poker-replay'}}
  466. div.estimation-add
  467. button.js-poker-estimation
  468. i.fa.fa-plus
  469. | {{_ 'set-estimation'}}
  470. input(type=text,autofocus value=getPokerEstimation,id="pokerEstimation")
  471. //- XXX We should use "editable" to avoid repetiting ourselves
  472. if canModifyCard
  473. unless currentUser.isWorker
  474. if currentBoard.allowsDescriptionTitle
  475. hr
  476. h3.card-details-item-title
  477. i.fa.fa-align-left
  478. | {{_ 'description'}}
  479. if currentBoard.allowsDescriptionText
  480. +inlinedCardDescription(classNames="card-description js-card-description")
  481. +descriptionForm
  482. .edit-controls.clearfix
  483. button.primary(type="submit") {{_ 'save'}}
  484. a.fa.fa-times-thin.js-close-inlined-form
  485. else
  486. if currentBoard.allowsDescriptionText
  487. a.js-open-inlined-form
  488. if getDescription
  489. +viewer
  490. = getDescription
  491. else
  492. | {{_ 'edit'}}
  493. if (hasUnsavedValue 'cardDescription' _id)
  494. p.quiet
  495. | {{_ 'unsaved-description'}}
  496. a.js-open-inlined-form {{_ 'view-it'}}
  497. = ' - '
  498. a.js-close-inlined-form {{_ 'discard'}}
  499. else if getDescription
  500. if currentBoard.allowsDescriptionTitle
  501. hr
  502. h3.card-details-item-title {{_ 'description'}}
  503. if currentBoard.allowsDescriptionText
  504. +viewer
  505. = getDescription
  506. .card-checklist-attachmentGalerys
  507. .card-checklist-attachmentGalery.card-checklists
  508. if currentBoard.allowsChecklists
  509. hr
  510. +checklists(cardId = _id)
  511. if currentBoard.allowsSubtasks
  512. hr
  513. +subtasks(cardId = _id)
  514. if currentBoard.allowsAttachments
  515. hr
  516. h3.card-details-item-title
  517. i.fa.fa-paperclip
  518. | {{_ 'attachments'}}
  519. .card-checklist-attachmentGalery.card-attachmentGalery
  520. +attachmentsGalery
  521. hr
  522. .card-details-right
  523. unless currentUser.isNoComments
  524. .activity-title
  525. h3.card-details-item-title
  526. i.fa.fa-history
  527. | {{ _ 'activity'}}
  528. if currentUser.isBoardMember
  529. .material-toggle-switch(title="{{_ 'hide-system-messages'}}")
  530. //span.toggle-switch-title
  531. if hiddenSystemMessages
  532. input.toggle-switch(type="checkbox" id="toggleButton" checked="checked")
  533. else
  534. input.toggle-switch(type="checkbox" id="toggleButton")
  535. label.toggle-label(for="toggleButton")
  536. if currentBoard.allowsComments
  537. if currentUser.isBoardMember
  538. unless currentUser.isNoComments
  539. +commentForm
  540. unless currentUser.isNoComments
  541. if isLoaded.get
  542. if isLinkedCard
  543. +activities(card=this mode="linkedcard")
  544. else if isLinkedBoard
  545. +activities(card=this mode="linkedboard")
  546. else
  547. +activities(card=this mode="card")
  548. template(name="editCardTitleForm")
  549. a.fa.fa-copy(title="{{_ 'copy-text-to-clipboard'}}")
  550. span.copied-tooltip {{_ 'copied'}}
  551. textarea.js-edit-card-title(rows='1' autofocus dir="auto")
  552. = getTitle
  553. .edit-controls.clearfix
  554. button.primary.confirm.js-submit-edit-card-title-form(type="submit") {{_ 'save'}}
  555. a.fa.fa-times-thin.js-close-inlined-form
  556. template(name="editCardRequesterForm")
  557. input.js-edit-card-requester(type='text' autofocus value=getRequestedBy dir="auto")
  558. .edit-controls.clearfix
  559. button.primary.confirm.js-submit-edit-card-requester-form(type="submit") {{_ 'save'}}
  560. a.fa.fa-times-thin.js-close-inlined-form
  561. template(name="editCardAssignerForm")
  562. input.js-edit-card-assigner(type='text' autofocus value=getAssignedBy dir="auto")
  563. .edit-controls.clearfix
  564. button.primary.confirm.js-submit-edit-card-assigner-form(type="submit") {{_ 'save'}}
  565. a.fa.fa-times-thin.js-close-inlined-form
  566. template(name="editCardSortOrderForm")
  567. input.js-edit-card-sort(type='text' autofocus value=sort dir="auto")
  568. .edit-controls.clearfix
  569. button.primary.confirm.js-submit-edit-card-sort-form(type="submit") {{_ 'save'}}
  570. a.fa.fa-times-thin.js-close-inlined-form
  571. template(name="cardDetailsActionsPopup")
  572. ul.pop-over-list
  573. li
  574. a.js-toggle-watch-card
  575. if isWatching
  576. i.fa.fa-eye
  577. | {{_ 'unwatch'}}
  578. else
  579. i.fa.fa-eye-slash
  580. | {{_ 'watch'}}
  581. hr
  582. if canModifyCard
  583. unless currentUser.isWorker
  584. ul.pop-over-list
  585. //li: a.js-members {{_ 'card-edit-members'}}
  586. //li: a.js-labels {{_ 'card-edit-labels'}}
  587. //li: a.js-attachments {{_ 'card-edit-attachments'}}
  588. li
  589. a.js-start-voting
  590. i.fa.fa-thumbs-up
  591. | {{_ 'card-edit-voting'}}
  592. li
  593. a.js-start-planning-poker
  594. i.fa.fa-thumbs-up
  595. | {{_ 'card-edit-planning-poker'}}
  596. if currentUser.isBoardAdmin
  597. li
  598. a.js-custom-fields
  599. i.fa.fa-list-alt
  600. | {{_ 'card-edit-custom-fields'}}
  601. //li: a.js-received-date {{_ 'editCardReceivedDatePopup-title'}}
  602. //li: a.js-start-date {{_ 'editCardStartDatePopup-title'}}
  603. //li: a.js-due-date {{_ 'editCardDueDatePopup-title'}}
  604. //li: a.js-end-date {{_ 'editCardEndDatePopup-title'}}
  605. li
  606. a.js-spent-time
  607. i.fa.fa-clock-o
  608. | {{_ 'editCardSpentTimePopup-title'}}
  609. li
  610. a.js-set-card-color
  611. i.fa.fa-paint-brush
  612. | {{_ 'setCardColorPopup-title'}}
  613. hr
  614. ul.pop-over-list
  615. li
  616. a.js-export-card
  617. i.fa.fa-share-alt
  618. | {{_ 'export-card'}}
  619. hr
  620. ul.pop-over-list
  621. li
  622. a.js-move-card-to-top
  623. i.fa.fa-arrow-up
  624. | {{_ 'moveCardToTop-title'}}
  625. li
  626. a.js-move-card-to-bottom
  627. i.fa.fa-arrow-down
  628. | {{_ 'moveCardToBottom-title'}}
  629. hr
  630. ul.pop-over-list
  631. if currentUser.isBoardAdmin
  632. li
  633. a.js-move-card
  634. i.fa.fa-arrow-right
  635. | {{_ 'moveCardPopup-title'}}
  636. unless currentUser.isWorker
  637. li
  638. a.js-copy-card
  639. i.fa.fa-copy
  640. | {{_ 'copyCardPopup-title'}}
  641. unless currentUser.isWorker
  642. ul.pop-over-list
  643. li
  644. a.js-copy-checklist-cards
  645. i.fa.fa-copy
  646. i.fa.fa-copy
  647. | {{_ 'copyManyCardsPopup-title'}}
  648. unless archived
  649. hr
  650. ul.pop-over-list
  651. li
  652. a.js-archive
  653. i.fa.fa-arrow-right
  654. i.fa.fa-archive
  655. | {{_ 'archive-card'}}
  656. hr
  657. ul.pop-over-list
  658. li
  659. a.js-more
  660. i.fa.fa-link
  661. | {{_ 'cardMorePopup-title'}}
  662. template(name="exportCardPopup")
  663. ul.pop-over-list
  664. li
  665. a(href="{{exportUrlCardPDF}}",, download="{{exportFilenameCardPDF}}")
  666. i.fa.fa-share-alt
  667. | {{_ 'export-card-pdf'}}
  668. template(name="moveCardPopup")
  669. +copyAndMoveCard
  670. template(name="copyCardPopup")
  671. label(for='copy-card-title') {{_ 'title'}}:
  672. textarea#copy-card-title.minicard-composer-textarea.js-card-title(autofocus)
  673. = getTitle
  674. +copyAndMoveCard
  675. template(name="copyManyCardsPopup")
  676. label(for='copy-checklist-cards-title') {{_ 'copyManyCardsPopup-instructions'}}:
  677. textarea#copy-card-title.minicard-composer-textarea.js-card-title(autofocus)
  678. | {{_ 'copyManyCardsPopup-format'}}
  679. +copyAndMoveCard
  680. template(name="convertChecklistItemToCardPopup")
  681. label(for='convert-checklist-item-to-card-title') {{_ 'title'}}:
  682. textarea#copy-card-title.minicard-composer-textarea.js-card-title(autofocus)
  683. = item.title
  684. +copyAndMoveCard
  685. template(name="copyAndMoveCard")
  686. unless currentUser.isWorker
  687. label {{_ 'boards'}}:
  688. select.js-select-boards(autofocus)
  689. each boards
  690. option(value="{{_id}}" selected="{{#if isDialogOptionBoardId _id}}selected{{/if}}") {{title}}
  691. label {{_ 'swimlanes'}}:
  692. select.js-select-swimlanes
  693. each swimlanes
  694. option(value="{{_id}}" selected="{{#if isDialogOptionSwimlaneId _id}}selected{{/if}}") {{title}}
  695. label {{_ 'lists'}}:
  696. select.js-select-lists
  697. each lists
  698. option(value="{{_id}}" selected="{{#if isDialogOptionListId _id}}selected{{/if}}") {{title}}
  699. .edit-controls.clearfix
  700. button.primary.confirm.js-done {{_ 'done'}}
  701. template(name="cardMembersPopup")
  702. input.card-members-filter(type="text" placeholder="{{_ 'search'}}")
  703. ul.pop-over-list.js-card-member-list
  704. each members
  705. li.item(class="{{#if isCardMember}}active{{/if}}")
  706. a.name.js-select-member(href="#")
  707. +userAvatar(userId=user._id)
  708. span.full-name
  709. = user.profile.fullname
  710. | (<span class="username">{{ user.username }}</span>)
  711. if isCardMember
  712. i.fa.fa-check
  713. template(name="cardAssigneesPopup")
  714. input.card-assignees-filter(type="text" placeholder="{{_ 'search'}}")
  715. unless currentUser.isWorker
  716. ul.pop-over-list.js-card-assignee-list
  717. each members
  718. li.item(class="{{#if isCardAssignee}}active{{/if}}")
  719. a.name.js-select-assignee(href="#")
  720. +userAvatar(userId=user._id)
  721. span.full-name
  722. = user.profile.fullname
  723. | (<span class="username">{{ user.username }}</span>)
  724. if isCardAssignee
  725. i.fa.fa-check
  726. if currentUser.isWorker
  727. ul.pop-over-list.js-card-assignee-list
  728. li.item(class="{{#if currentUser.isCardAssignee}}active{{/if}}")
  729. a.name.js-select-assignee(href="#")
  730. +userAvatar(userId=currentUser._id)
  731. span.full-name
  732. = currentUser.profile.fullname
  733. | (<span class="username">{{ currentUser.username }}</span>)
  734. if currentUser.isCardAssignee
  735. i.fa.fa-check
  736. template(name="cardAssigneePopup")
  737. .board-assignee-menu
  738. .mini-profile-info
  739. +userAvatar(userId=user._id showEdit=true)
  740. .info
  741. h3= user.profile.fullname
  742. p.quiet @{{ user.username }}
  743. ul.pop-over-list
  744. if currentUser.isNotCommentOnly
  745. unless currentUser.isWorker
  746. li: a.js-remove-assignee {{_ 'remove-member-from-card'}}
  747. unless currentUser.isWorker
  748. if $eq currentUser._id user._id
  749. with currentUser
  750. li: a.js-edit-profile {{_ 'edit-profile'}}
  751. template(name="cardMorePopup")
  752. p.quiet
  753. span.clearfix
  754. span {{_ 'link-card'}}
  755. = ' '
  756. i.fa.colorful(class="{{#if board.isPublic}}fa-globe{{else}}fa-lock{{/if}}")
  757. input.inline-input(type="text" id="cardURL" readonly value="{{ originRelativeUrl }}" autofocus="autofocus")
  758. button.js-copy-card-link-to-clipboard(class="btn" id="clipboard") {{_ 'copy-card-link-to-clipboard'}}
  759. .copied-tooltip {{_ 'copied'}}
  760. span.clearfix
  761. br
  762. h2 {{_ 'change-card-parent'}}
  763. label {{_ 'source-board'}}:
  764. select.js-field-parent-board
  765. if isTopLevel
  766. option(value="none" selected) {{_ 'custom-field-dropdown-none'}}
  767. else
  768. option(value="none") {{_ 'custom-field-dropdown-none'}}
  769. each boards
  770. if isParentBoard
  771. option(value="{{_id}}" selected) {{title}}
  772. else
  773. option(value="{{_id}}") {{title}}
  774. label {{_ 'parent-card'}}:
  775. select.js-field-parent-card
  776. if isTopLevel
  777. option(value="none" selected) {{_ 'custom-field-dropdown-none'}}
  778. else
  779. option(value="none") {{_ 'custom-field-dropdown-none'}}
  780. each cards
  781. if isParentCard
  782. option(value="{{_id}}" selected) {{title}}
  783. else
  784. option(value="{{_id}}") {{title}}
  785. br
  786. | {{_ 'added'}}
  787. span.date(title=card.createdAt) {{ moment createdAt 'LLL' }}
  788. if currentUser.isBoardAdmin
  789. a.js-delete(title="{{_ 'card-delete-notice'}}") {{_ 'delete'}}
  790. template(name="setCardColorPopup")
  791. form.edit-label
  792. .palette-colors: each colors
  793. unless $eq color 'white'
  794. span.card-label.palette-color.js-palette-color(class="card-details-{{color}}")
  795. if(isSelected color)
  796. i.fa.fa-check
  797. button.primary.confirm.js-submit {{_ 'save'}}
  798. button.js-remove-color.negate.wide.right {{_ 'unset-color'}}
  799. template(name="cardDeletePopup")
  800. p {{_ "card-delete-pop"}}
  801. unless archived
  802. p {{_ "card-delete-suggest-archive"}}
  803. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}
  804. template(name="cardArchivePopup")
  805. p {{_ "card-archive-pop"}}
  806. unless archived
  807. p {{_ "card-archive-suggest-cancel"}}
  808. button.js-confirm.negate.full(type="submit") {{_ 'archive'}}
  809. template(name="deleteVotePopup")
  810. p {{_ "vote-delete-pop"}}
  811. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}
  812. template(name="cardStartVotingPopup")
  813. form.edit-vote-question
  814. .fields
  815. label(for="vote") {{_ 'vote-question'}}
  816. input.js-vote-field#vote(type="text" name="vote" value="{{getVoteQuestion}}" autofocus disabled="{{#if getVoteQuestion}}disabled{{/if}}")
  817. .check-div
  818. a.flex(class="{{#if getVoteQuestion}}is-disabled{{else}}js-toggle-vote-allow-non-members{{/if}}")
  819. .materialCheckBox#vote-allow-non-members(name="vote-allow-non-members" class="{{#if voteAllowNonBoardMembers}}is-checked{{/if}}")
  820. span {{_ 'allowNonBoardMembers'}}
  821. .check-div
  822. a.flex(class="{{#if getVoteQuestion}}is-disabled{{else}}js-toggle-vote-public{{/if}}")
  823. .materialCheckBox#vote-public(name="vote-public" class="{{#if votePublic}}is-checked{{/if}}")
  824. span {{_ 'vote-public'}}
  825. .check-div.flex
  826. i.fa.fa-hourglass-end
  827. a.js-end-date
  828. span
  829. | {{_ 'card-end'}}
  830. unless getVoteEnd
  831. i.fa.fa-plus
  832. if getVoteEnd
  833. +voteEndDate
  834. button.primary.js-submit {{_ 'save'}}
  835. if getVoteQuestion
  836. if currentUser.isBoardAdmin
  837. button.js-remove-vote.negate.wide.right {{_ 'delete'}}
  838. template(name="positiveVoteMembersPopup")
  839. ul.pop-over-list.js-card-member-list
  840. each m in voteMemberPositive
  841. li.item
  842. a.name
  843. +userAvatar(userId=m._id)
  844. span.full-name
  845. = m.profile.fullname
  846. | (<span class="username">{{ m.username }}</span>)
  847. template(name="negativeVoteMembersPopup")
  848. ul.pop-over-list.js-card-member-list
  849. each m in voteMemberNegative
  850. li.item
  851. a.name
  852. +userAvatar(userId=m._id)
  853. span.full-name
  854. = m.profile.fullname
  855. | (<span class="username">{{ m.username }}</span>)
  856. template(name="deletePokerPopup")
  857. p {{_ "poker-delete-pop"}}
  858. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}
  859. template(name="cardStartPlanningPokerPopup")
  860. form.edit-poker-question
  861. .fields
  862. .check-div
  863. a.flex(class="{{#if getPokerQuestion}}is-disabled{{else}}js-toggle-poker-allow-non-members{{/if}}")
  864. .materialCheckBox#poker-allow-non-members(name="poker-allow-non-members" class="{{#if pokerAllowNonBoardMembers}}is-checked{{/if}}")
  865. span {{_ 'allowNonBoardMembers'}}
  866. .check-div.flex
  867. i.fa.fa-hourglass-end
  868. a.js-end-date
  869. span
  870. | {{_ 'card-end'}}
  871. unless getPokerEnd
  872. i.fa.fa-plus
  873. if getPokerEnd
  874. +pokerEndDate
  875. button.primary.js-submit {{_ 'save'}}
  876. if getPokerQuestion
  877. if currentUser.isBoardAdmin
  878. button.js-remove-poker.negate.wide.right {{_ 'delete'}}