| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236 | template(name="minicard")  .minicard.nodragscroll(    class="{{#if isLinkedCard}}linked-card{{/if}}"    class="{{#if isLinkedBoard}}linked-board{{/if}}"    class="{{#if colorClass}}minicard-{{colorClass}}{{/if}}")    if canModifyCard      if isTouchScreenOrShowDesktopDragHandles        a.fa.fa-navicon.minicard-details-menu-with-handle.js-open-minicard-details-menu(title="{{_ 'cardDetailsActionsPopup-title'}}")        .handle          .fa.fa-arrows      else        a.fa.fa-navicon.minicard-details-menu.js-open-minicard-details-menu(title="{{_ 'cardDetailsActionsPopup-title'}}")    .dates      if getReceived        unless getStart          unless getDue            unless getEnd              .date                +minicardReceivedDate      if getStart        .date          +minicardStartDate      if getDue        .date          +minicardDueDate      if getEnd         +minicardEndDate      if getSpentTime        .date          +cardSpentTime    if cover      if currentBoard.allowsCoverAttachmentOnMinicard        .minicard-cover(style="background-image: url('{{cover.link 'original'}}?dummyReloadAfterSessionEstablished={{sess}}');")    .minicard-title      if $eq 'prefix-with-full-path' currentBoard.presentParentTask        .parent-prefix          | {{ parentString ' > ' }}      if $eq 'prefix-with-parent' currentBoard.presentParentTask        .parent-prefix          | {{ parentCardName }}      if isLinkedBoard        a.js-linked-link          span.linked-icon.fa.fa-folder      else if isLinkedCard        a.js-linked-link          span.linked-icon.fa.fa-id-card      if getArchived        span.linked-icon.linked-archived.fa.fa-archive      +viewer        if currentBoard.allowsCardNumber          span.card-number            | ##{getCardNumber}        = getTitle      if $eq 'subtext-with-full-path' currentBoard.presentParentTask        .parent-subtext          | {{ parentString ' > ' }}      if $eq 'subtext-with-parent' currentBoard.presentParentTask        .parent-subtext          | {{ parentCardName }}    if labels      .minicard-labels(class="{{#if hiddenMinicardLabelText}}minicard-labels-no-text{{/if}}")        each labels          unless hiddenMinicardLabelText            span.js-card-label.card-label(class="card-label-{{color}}" title=name)              +viewer                = name          if hiddenMinicardLabelText            .minicard-label(class="card-label-{{color}}" title="{{name}}")    .minicard-custom-fields      each customFieldsWD        if definition.showOnCard          if trueValue            .minicard-custom-field              // If there is custom field label, show label at left,              // and value at right              if definition.showLabelOnMiniCard                .minicard-custom-field-item                  +viewer                    = definition.name                .minicard-custom-field-item                  if $eq definition.type "currency"                    +viewer                      = formattedCurrencyCustomFieldValue(definition)                  else if $eq definition.type "date"                    .date                      +minicardCustomFieldDate                  else if $eq definition.type "checkbox"                    .materialCheckBox(class="{{#if value }}is-checked{{/if}}")                  else if $eq definition.type "stringtemplate"                    +viewer                      = formattedStringtemplateCustomFieldValue(definition)                  else                    +viewer                      = trueValue              else                // If there is no custom field label,                // show value full width                .minicard-custom-field-item-fullwidth                  if $eq definition.type "currency"                    +viewer                      = formattedCurrencyCustomFieldValue(definition)                  else if $eq definition.type "date"                    .date                      +minicardCustomFieldDate                  else if $eq definition.type "checkbox"                    .materialCheckBox(class="{{#if value }}is-checked{{/if}}")                  else if $eq definition.type "stringtemplate"                    +viewer                      = formattedStringtemplateCustomFieldValue(definition)                  else                    +viewer                      = trueValue    if showAssignee      if getAssignees        .minicard-assignees.js-minicard-assignees          each getAssignees            +userAvatar(userId=this)    if showMembers      if getMembers        .minicard-members.js-minicard-members          each getMembers            +userAvatar(userId=this)    if showCreatorOnMinicard      .minicard-creator        +userAvatar(userId=this.userId noRemove=true)    .badges      if canModifyCard        if comments.length          .badge(title="{{_ 'card-comments-title' comments.length }}")            span.badge-icon.fa.fa-comment-o.badge-comment.badge-text              = ' '              = comments.length            //span.badge-comment.badge-text            //|  {{_ 'comment'}}      if getDescription        unless currentBoard.allowsDescriptionTextOnMinicard          .badge.badge-state-image-only(title=getDescription)            span.badge-icon.fa.fa-align-left      if getVoteQuestion        .badge.badge-state-image-only(title=getVoteQuestion)          span.badge-icon.fa.fa-thumbs-up(class="{{#if voteState}}text-green{{/if}}")          span.badge-text {{ voteCountPositive }}          span.badge-icon.fa.fa-thumbs-down(class="{{#if $eq voteState false}}text-red{{/if}}")          span.badge-text {{ voteCountNegative }}      if getPokerQuestion        .badge.badge-state-image-only(title=getPokerQuestion)          span.badge-icon.fa.fa-check(class="{{#if pokerState}}text-green{{/if}}")          if expiredPoker            span.badge-text {{ getPokerEstimation }}      if attachments.length        if currentBoard.allowsBadgeAttachmentOnMinicard          .badge            span.badge-icon.fa.fa-paperclip            span.badge-text= attachments.length      if checklists.length        .badge(class="{{#if checklistFinished}}is-finished{{/if}}")          span.badge-icon.fa.fa-check-square-o          span.badge-text.check-list-text {{checklistFinishedCount}}/{{checklistItemCount}}      if allSubtasks.count        .badge          span.badge-icon.fa.fa-sitemap          span.badge-text.check-list-text {{subtasksFinishedCount}}/{{allSubtasksCount}}          //{{subtasksFinishedCount}}/{{subtasksCount}} does not work because when a subtaks is archived, the count goes down      if currentBoard.allowsCardSortingByNumber        if currentBoard.allowsCardSortingByNumberOnMinicard          .badge            span.badge-icon.fa.fa-sort            span.badge-text.check-list-sort {{ sort }}    if currentBoard.allowsDescriptionTextOnMinicard      if getDescription        .minicard-description          +viewer            | {{ getDescription }}template(name="editCardSortOrderPopup")  input.js-edit-card-sort-popup(type='text' autofocus value=sort dir="auto")  .edit-controls.clearfix    button.primary.confirm.js-submit-edit-card-sort-popup(type="submit") {{_ 'save'}}template(name="minicardDetailsActionsPopup")  ul.pop-over-list    if canModifyCard      li        a.js-move-card          i.fa.fa-arrow-right          | {{_ 'moveCardPopup-title'}}      li        a.js-copy-card          i.fa.fa-copy          | {{_ 'copyCardPopup-title'}}      hr      li        a.js-archive          i.fa.fa-arrow-right          i.fa.fa-archive          | {{_ 'archive-card'}}      hr      li        a.js-move-card-to-top          i.fa.fa-arrow-up          | {{_ 'moveCardToTop-title'}}      li        a.js-move-card-to-bottom          i.fa.fa-arrow-down          | {{_ 'moveCardToBottom-title'}}      hr      li        a.js-add-labels          i.fa.fa-tags          | {{_ 'card-edit-labels'}}      li        a.js-due-date          i.fa.fa-sign-in          | {{_ 'editCardDueDatePopup-title'}}      li        a.js-set-card-color          i.fa.fa-paint-brush          | {{_ 'setCardColorPopup-title'}}      li        a.js-link          i.fa.fa-link          | {{_ 'link-card'}}      li      a.js-toggle-watch-card        if isWatching          i.fa.fa-eye          |  {{_ 'unwatch'}}        else          i.fa.fa-eye-slash          |  {{_ 'watch'}}
 |