checklists.jade 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. template(name="checklists")
  2. .checklists-title
  3. h3.card-details-item-title
  4. i.fa.fa-check
  5. | {{_ 'checklists'}}
  6. if currentUser.isBoardMember
  7. .material-toggle-switch(title="{{_ 'hide-checked-items'}}")
  8. //span.toggle-switch-title
  9. if hideCheckedItems
  10. input.toggle-switch(type="checkbox" id="toggleHideCheckedItemsButton" checked="checked")
  11. else
  12. input.toggle-switch(type="checkbox" id="toggleHideCheckedItemsButton")
  13. label.toggle-label(for="toggleHideCheckedItemsButton")
  14. .card-checklist-items
  15. each checklist in checklists
  16. +checklistDetail(checklist = checklist)
  17. if canModifyCard
  18. +inlinedForm(autoclose=false classNames="js-add-checklist" cardId = cardId)
  19. +addChecklistItemForm(checklist=checklist showNewlineBecomesNewChecklistItem=false)
  20. else
  21. a.add-checklist.js-open-inlined-form(title="{{_ 'add-checklist'}}")
  22. i.fa.fa-plus
  23. template(name="checklistDetail")
  24. .js-checklist.checklist
  25. +inlinedForm(classNames="js-edit-checklist-title" checklist = checklist)
  26. +editChecklistItemForm(checklist = checklist)
  27. else
  28. .checklist-title
  29. span
  30. if canModifyCard
  31. a.fa.fa-navicon.checklist-details-menu.js-open-checklist-details-menu(title="{{_ 'checklistActionsPopup-title'}}")
  32. if canModifyCard
  33. h2.title.js-open-inlined-form.is-editable
  34. if isTouchScreenOrShowDesktopDragHandles
  35. span.fa.checklist-handle(class="fa-arrows" title="{{_ 'dragChecklist'}}")
  36. +viewer
  37. = checklist.title
  38. else
  39. h2.title
  40. +viewer
  41. = checklist.title
  42. if $gt finishedPercent 0
  43. .checklist-progress-bar-container
  44. .checklist-progress-text {{finishedPercent}}%
  45. .checklist-progress-bar
  46. .checklist-progress(style="width:{{finishedPercent}}%")
  47. +checklistItems(checklist = checklist)
  48. template(name="checklistDeletePopup")
  49. p {{_ 'confirm-checklist-delete-popup'}}
  50. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}
  51. template(name="addChecklistItemForm")
  52. a.fa.fa-copy(title="{{_ 'copy-text-to-clipboard'}}")
  53. span.copied-tooltip {{_ 'copied'}}
  54. textarea.js-add-checklist-item(rows='1' autofocus)
  55. .edit-controls.clearfix
  56. button.primary.confirm.js-submit-add-checklist-item-form(type="submit") {{_ 'save'}}
  57. a.fa.fa-times-thin.js-close-inlined-form
  58. if showNewlineBecomesNewChecklistItem
  59. .material-toggle-switch(title="{{_ 'newlineBecomesNewChecklistItem'}}")
  60. input.toggle-switch(type="checkbox" id="toggleNewlineBecomesNewChecklistItem")
  61. label.toggle-label(for="toggleNewlineBecomesNewChecklistItem")
  62. template(name="editChecklistItemForm")
  63. a.fa.fa-copy(title="{{_ 'copy-text-to-clipboard'}}")
  64. span.copied-tooltip {{_ 'copied'}}
  65. textarea.js-edit-checklist-item(rows='1' autofocus dir="auto")
  66. if $eq type 'item'
  67. = item.title
  68. else
  69. = checklist.title
  70. .edit-controls.clearfix
  71. button.primary.confirm.js-submit-edit-checklist-item-form(type="submit") {{_ 'save'}}
  72. a.fa.fa-times-thin.js-close-inlined-form
  73. span(title=createdAt) {{ moment createdAt }}
  74. if canModifyCard
  75. a.js-delete-checklist-item {{_ "delete"}}...
  76. a.js-convert-checklist-item-to-card
  77. i.fa.fa-copy
  78. | {{_ 'convertChecklistItemToCardPopup-title'}}
  79. template(name="checklistItems")
  80. .checklist-items.js-checklist-items
  81. each item in checklist.items
  82. +inlinedForm(classNames="js-edit-checklist-item" item = item checklist = checklist)
  83. +editChecklistItemForm(type = 'item' item = item checklist = checklist)
  84. else
  85. +checklistItemDetail(item = item checklist = checklist)
  86. if canModifyCard
  87. +inlinedForm(autoclose=false classNames="js-add-checklist-item" checklist = checklist)
  88. +addChecklistItemForm(checklist=checklist showNewlineBecomesNewChecklistItem=true)
  89. else
  90. a.add-checklist-item.js-open-inlined-form(title="{{_ 'add-checklist-item'}}")
  91. i.fa.fa-plus
  92. template(name='checklistItemDetail')
  93. .js-checklist-item.checklist-item(class="{{#if item.isFinished }}is-checked{{#if hideCheckedItems}} invisible{{/if}}{{/if}}")
  94. if canModifyCard
  95. .check-box-container
  96. .check-box.materialCheckBox(class="{{#if item.isFinished }}is-checked{{/if}}")
  97. if isTouchScreenOrShowDesktopDragHandles
  98. span.fa.checklistitem-handle(class="fa-arrows" title="{{_ 'dragChecklistItem'}}")
  99. .item-title.js-open-inlined-form.is-editable(class="{{#if item.isFinished }}is-checked{{/if}}")
  100. +viewer
  101. = item.title
  102. else
  103. .materialCheckBox(class="{{#if item.isFinished }}is-checked{{/if}}")
  104. .item-title(class="{{#if item.isFinished }}is-checked{{/if}}")
  105. +viewer
  106. = item.title
  107. template(name="checklistActionsPopup")
  108. ul.pop-over-list
  109. li
  110. a.js-delete-checklist.delete-checklist
  111. i.fa.fa-trash
  112. | {{_ "delete"}} ...
  113. a.js-move-checklist.move-checklist
  114. i.fa.fa-arrow-right
  115. | {{_ "moveChecklist"}} ...
  116. a.js-copy-checklist.copy-checklist
  117. i.fa.fa-copy
  118. | {{_ "copyChecklist"}} ...
  119. template(name="copyChecklistPopup")
  120. +copyAndMoveChecklist
  121. template(name="moveChecklistPopup")
  122. +copyAndMoveChecklist
  123. template(name="copyAndMoveChecklist")
  124. unless currentUser.isWorker
  125. label {{_ 'boards'}}:
  126. select.js-select-boards(autofocus)
  127. each boards
  128. if $eq _id currentBoard._id
  129. option(value="{{_id}}" selected) {{_ 'current'}}
  130. else
  131. option(value="{{_id}}" selected="{{#if isDialogOptionBoardId _id}}selected{{/if}}") {{title}}
  132. label {{_ 'swimlanes'}}:
  133. select.js-select-swimlanes
  134. each swimlanes
  135. option(value="{{_id}}" selected="{{#if isDialogOptionSwimlaneId _id}}selected{{/if}}") {{title}}
  136. label {{_ 'lists'}}:
  137. select.js-select-lists
  138. each lists
  139. option(value="{{_id}}" selected="{{#if isDialogOptionListId _id}}selected{{/if}}") {{title}}
  140. label {{_ 'cards'}}:
  141. select.js-select-cards
  142. each cards
  143. option(value="{{_id}}" selected="{{#if isDialogOptionCardId _id}}selected{{/if}}") {{title}}
  144. .edit-controls.clearfix
  145. button.primary.confirm.js-done {{_ 'done'}}