cardDetails.jade 36 KB

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