| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273 | import { ReactiveCache } from '/imports/reactiveCache';import { TAPi18n } from '/imports/i18n';import { CustomFieldStringTemplate } from '/client/lib/customFields';import { handleFileUpload } from './attachments';import uploadProgressManager from '../../lib/uploadProgressManager';// Template.cards.events({//   'click .member': Popup.open('cardMember')// });BlazeComponent.extendComponent({  template() {    return 'minicard';  },  formattedCurrencyCustomFieldValue(definition) {    const customField = this.data()      .customFieldsWD()      .find(f => f._id === definition._id);    const customFieldTrueValue =      customField && customField.trueValue ? customField.trueValue : '';    const locale = TAPi18n.getLanguage();    return new Intl.NumberFormat(locale, {      style: 'currency',      currency: definition.settings.currencyCode,    }).format(customFieldTrueValue);  },  formattedStringtemplateCustomFieldValue(definition) {    const customField = this.data()      .customFieldsWD()      .find(f => f._id === definition._id);    const customFieldTrueValue =      customField && customField.trueValue ? customField.trueValue : [];    const ret = new CustomFieldStringTemplate(definition).getFormattedValue(customFieldTrueValue);    return ret;  },  showCreatorOnMinicard() {    // cache "board" to reduce the mini-mongodb access    const board = this.data().board();    let ret = false;    if (board) {      ret = board.allowsCreatorOnMinicard ?? false;    }    return ret;  },  isWatching() {    const card = this.currentData();    return card.findWatcher(Meteor.userId());  },  showMembers() {    // cache "board" to reduce the mini-mongodb access    const board = this.data().board();    let ret = false;    if (board) {      ret =        board.allowsMembers === null ||        board.allowsMembers === undefined ||        board.allowsMembers      ;    }    return ret;  },  showAssignee() {    // cache "board" to reduce the mini-mongodb access    const board = this.data().board();    let ret = false;    if (board) {      ret =        board.allowsAssignee === null ||        board.allowsAssignee === undefined ||        board.allowsAssignee      ;    }    return ret;  },  /** opens the card label popup only if clicked onto a label   * <li> this is necessary to have the data context of the minicard.   *      if .js-card-label is used at click event, then only the data context of the label itself is available at this.currentData()   */  cardLabelsPopup(event) {    if (this.find('.js-card-label:hover')) {      Popup.open("cardLabels")(event, {dataContextIfCurrentDataIsUndefined: this.currentData()});    }  },  events() {    return [      {        'click .js-linked-link'() {          if (this.data().isLinkedCard()) Utils.goCardId(this.data().linkedId);          else if (this.data().isLinkedBoard())            Utils.goBoardId(this.data().linkedId);        },        'click .js-toggle-minicard-label-text'() {          if (window.localStorage.getItem('hiddenMinicardLabelText')) {            window.localStorage.removeItem('hiddenMinicardLabelText'); //true          } else {            window.localStorage.setItem('hiddenMinicardLabelText', 'true'); //true          }        },        'click span.badge-icon.fa.fa-sort, click span.badge-text.check-list-sort' : Popup.open("editCardSortOrder"),        'click .minicard-labels' : this.cardLabelsPopup,        'click .js-open-minicard-details-menu': Popup.open('minicardDetailsActions'),        // Drag and drop file upload handlers        'dragover .minicard'(event) {          event.preventDefault();          event.stopPropagation();        },        'dragenter .minicard'(event) {          event.preventDefault();          event.stopPropagation();          const card = this.data();          const board = card.board();          // Only allow drag-and-drop if user can modify card and board allows attachments          if (card.canModifyCard() && board && board.allowsAttachments) {            // Check if the drag contains files            const dataTransfer = event.originalEvent.dataTransfer;            if (dataTransfer && dataTransfer.types && dataTransfer.types.includes('Files')) {              $(event.currentTarget).addClass('is-dragging-over');            }          }        },        'dragleave .minicard'(event) {          event.preventDefault();          event.stopPropagation();          $(event.currentTarget).removeClass('is-dragging-over');        },        'drop .minicard'(event) {          event.preventDefault();          event.stopPropagation();          $(event.currentTarget).removeClass('is-dragging-over');          const card = this.data();          const board = card.board();          // Check permissions          if (!card.canModifyCard() || !board || !board.allowsAttachments) {            return;          }          // Check if this is a file drop (not a card reorder)          const dataTransfer = event.originalEvent.dataTransfer;          if (!dataTransfer || !dataTransfer.files || dataTransfer.files.length === 0) {            return;          }          // Check if the drop contains files (not just text/HTML)          if (!dataTransfer.types.includes('Files')) {            return;          }          const files = dataTransfer.files;          if (files && files.length > 0) {            handleFileUpload(card, files);          }        },      }    ];  },}).register('minicard');Template.minicard.helpers({  hiddenMinicardLabelText() {    const currentUser = ReactiveCache.getCurrentUser();    if (currentUser) {      return (currentUser.profile || {}).hiddenMinicardLabelText;    } else if (window.localStorage.getItem('hiddenMinicardLabelText')) {      return true;    } else {      return false;    }  },  // XXX resolve this nasty hack for https://github.com/veliovgroup/Meteor-Files/issues/763  sess() {    return Meteor.connection && Meteor.connection._lastSessionId      ? Meteor.connection._lastSessionId      : null;  },  isWatching() {    return this.findWatcher(Meteor.userId());  },  // Upload progress helpers  hasActiveUploads() {    return uploadProgressManager.hasActiveUploads(this._id);  },  uploads() {    return uploadProgressManager.getUploadsForCard(this._id);  },  uploadCount() {    return uploadProgressManager.getUploadCountForCard(this._id);  },  listName() {    const list = this.list();    return list ? list.title : '';  },  shouldShowListOnMinicard() {    // Show list name if either:    // 1. Board-wide setting is enabled, OR    // 2. This specific card has the setting enabled    const currentBoard = this.currentBoard;    if (!currentBoard) return false;    return currentBoard.allowsShowListsOnMinicard || this.showListOnMinicard;  }});BlazeComponent.extendComponent({  events() {    return [      {        'keydown input.js-edit-card-sort-popup'(evt) {          // enter = save          if (evt.keyCode === 13) {            this.find('button[type=submit]').click();          }        },        'click button.js-submit-edit-card-sort-popup'(event) {          // save button pressed          event.preventDefault();          const sort = this.$('.js-edit-card-sort-popup')[0]            .value            .trim();          if (!Number.isNaN(sort)) {            let card = this.data();            card.move(card.boardId, card.swimlaneId, card.listId, sort);            Popup.back();          }        },      }    ]  }}).register('editCardSortOrderPopup');Template.minicardDetailsActionsPopup.events({  'click .js-due-date': Popup.open('editCardDueDate'),  'click .js-move-card': Popup.open('moveCard'),  'click .js-copy-card': Popup.open('copyCard'),  'click .js-set-card-color': Popup.open('setCardColor'),  'click .js-add-labels': Popup.open('cardLabels'),  'click .js-link': Popup.open('linkCard'),  'click .js-move-card-to-top'(event) {    event.preventDefault();    const minOrder = this.getMinSort();    this.move(this.boardId, this.swimlaneId, this.listId, minOrder - 1);    Popup.back();  },  'click .js-move-card-to-bottom'(event) {    event.preventDefault();    const maxOrder = this.getMaxSort();    this.move(this.boardId, this.swimlaneId, this.listId, maxOrder + 1);    Popup.back();  },  'click .js-archive': Popup.afterConfirm('cardArchive', function () {    Popup.close();    this.archive();    Utils.goBoardId(this.boardId);  }),  'click .js-toggle-watch-card'() {    const currentCard = this;    const level = currentCard.findWatcher(Meteor.userId()) ? null : 'watching';    Meteor.call('watch', 'card', currentCard._id, level, (err, ret) => {      if (!err && ret) Popup.back();    });  },});
 |