| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276 | 
							- 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) {
 
-           // Only prevent default for file drags to avoid interfering with sortable
 
-           const dataTransfer = event.originalEvent.dataTransfer;
 
-           if (dataTransfer && dataTransfer.types && dataTransfer.types.includes('Files')) {
 
-             event.preventDefault();
 
-             event.stopPropagation();
 
-           }
 
-         },
 
-         'dragenter .minicard'(event) {
 
-           const dataTransfer = event.originalEvent.dataTransfer;
 
-           if (dataTransfer && dataTransfer.types && dataTransfer.types.includes('Files')) {
 
-             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 (Utils.canModifyCard() && board && board.allowsAttachments) {
 
-               $(event.currentTarget).addClass('is-dragging-over');
 
-             }
 
-           }
 
-         },
 
-         'dragleave .minicard'(event) {
 
-           const dataTransfer = event.originalEvent.dataTransfer;
 
-           if (dataTransfer && dataTransfer.types && dataTransfer.types.includes('Files')) {
 
-             event.preventDefault();
 
-             event.stopPropagation();
 
-             $(event.currentTarget).removeClass('is-dragging-over');
 
-           }
 
-         },
 
-         'drop .minicard'(event) {
 
-           const dataTransfer = event.originalEvent.dataTransfer;
 
-           if (dataTransfer && dataTransfer.types && dataTransfer.types.includes('Files')) {
 
-             event.preventDefault();
 
-             event.stopPropagation();
 
-             $(event.currentTarget).removeClass('is-dragging-over');
 
-             const card = this.data();
 
-             const board = card.board();
 
-             // Check permissions
 
-             if (!Utils.canModifyCard() || !board || !board.allowsAttachments) {
 
-               return;
 
-             }
 
-             // Check if this is a file drop (not a card reorder)
 
-             if (!dataTransfer.files || dataTransfer.files.length === 0) {
 
-               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();
 
-     });
 
-   },
 
- });
 
 
  |