| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240 | let cardColors;Meteor.startup(() => {  cardColors = Cards.simpleSchema()._schema.color.allowedValues;});BlazeComponent.extendComponent({  onCreated() {    this.subscribe('allRules');    this.cardColorButtonValue = new ReactiveVar('green');  },  cardColorButton() {    return this.cardColorButtonValue.get();  },  cardColorButtonText() {    return `color-${this.cardColorButtonValue.get()}`;  },  labels() {    const labels = Utils.getCurrentBoard().labels;    for (let i = 0; i < labels.length; i++) {      if (labels[i].name === '' || labels[i].name === undefined) {        labels[i].name = labels[i].color.toUpperCase();      }    }    return labels;  },  events() {    return [      {        'click .js-set-date-action'(event) {          const ruleName = this.data().ruleName.get();          const trigger = this.data().triggerVar.get();          const triggerId = Triggers.insert(trigger);          const actionSelected = this.find('#setdate-action').value;          const dateFieldSelected = this.find('#setdate-datefield').value;          const boardId = Session.get('currentBoard');          const desc = Utils.getTriggerActionDesc(event, this);          const actionId = Actions.insert({            actionType: actionSelected,            dateField: dateFieldSelected,            boardId,            desc,          });          Rules.insert({            title: ruleName,            triggerId,            actionId,            boardId,            desc,          });        },        'click .js-remove-datevalue-action'(event) {          const ruleName = this.data().ruleName.get();          const trigger = this.data().triggerVar.get();          const triggerId = Triggers.insert(trigger);          const dateFieldSelected = this.find('#setdate-removedatefieldvalue')            .value;          const boardId = Session.get('currentBoard');          const desc = Utils.getTriggerActionDesc(event, this);          const actionId = Actions.insert({            actionType: 'removeDate',            dateField: dateFieldSelected,            boardId,            desc,          });          Rules.insert({            title: ruleName,            triggerId,            actionId,            boardId,            desc,          });        },        'click .js-add-label-action'(event) {          const ruleName = this.data().ruleName.get();          const trigger = this.data().triggerVar.get();          const actionSelected = this.find('#label-action').value;          const labelId = this.find('#label-id').value;          const boardId = Session.get('currentBoard');          const desc = Utils.getTriggerActionDesc(event, this);          if (actionSelected === 'add') {            const triggerId = Triggers.insert(trigger);            const actionId = Actions.insert({              actionType: 'addLabel',              labelId,              boardId,              desc,            });            Rules.insert({              title: ruleName,              triggerId,              actionId,              boardId,            });          }          if (actionSelected === 'remove') {            const triggerId = Triggers.insert(trigger);            const actionId = Actions.insert({              actionType: 'removeLabel',              labelId,              boardId,              desc,            });            Rules.insert({              title: ruleName,              triggerId,              actionId,              boardId,            });          }        },        'click .js-add-member-action'(event) {          const ruleName = this.data().ruleName.get();          const trigger = this.data().triggerVar.get();          const actionSelected = this.find('#member-action').value;          const username = this.find('#member-name').value;          const boardId = Session.get('currentBoard');          const desc = Utils.getTriggerActionDesc(event, this);          if (actionSelected === 'add') {            const triggerId = Triggers.insert(trigger);            const actionId = Actions.insert({              actionType: 'addMember',              username,              boardId,              desc,            });            Rules.insert({              title: ruleName,              triggerId,              actionId,              boardId,              desc,            });          }          if (actionSelected === 'remove') {            const triggerId = Triggers.insert(trigger);            const actionId = Actions.insert({              actionType: 'removeMember',              username,              boardId,              desc,            });            Rules.insert({              title: ruleName,              triggerId,              actionId,              boardId,            });          }        },        'click .js-add-removeall-action'(event) {          const ruleName = this.data().ruleName.get();          const trigger = this.data().triggerVar.get();          const triggerId = Triggers.insert(trigger);          const desc = Utils.getTriggerActionDesc(event, this);          const boardId = Session.get('currentBoard');          const actionId = Actions.insert({            actionType: 'removeMember',            //  deepcode ignore NoHardcodedCredentials: it's no credential            username: '*',            boardId,            desc,          });          Rules.insert({            title: ruleName,            triggerId,            actionId,            boardId,          });        },        'click .js-show-color-palette'(event) {          const funct = Popup.open('setCardActionsColor');          const colorButton = this.find('#color-action');          if (colorButton.value === '') {            colorButton.value = 'green';          }          funct.call(this, event);        },        'click .js-set-color-action'(event) {          const ruleName = this.data().ruleName.get();          const trigger = this.data().triggerVar.get();          const selectedColor = this.cardColorButtonValue.get();          const boardId = Session.get('currentBoard');          const desc = Utils.getTriggerActionDesc(event, this);          const triggerId = Triggers.insert(trigger);          const actionId = Actions.insert({            actionType: 'setColor',            selectedColor,            boardId,            desc,          });          Rules.insert({            title: ruleName,            triggerId,            actionId,            boardId,          });        },      },    ];  },}).register('cardActions');BlazeComponent.extendComponent({  onCreated() {    this.currentAction = this.currentData();    this.colorButtonValue = Popup.getOpenerComponent().cardColorButtonValue;    this.currentColor = new ReactiveVar(this.colorButtonValue.get());  },  colors() {    return cardColors.map(color => ({ color, name: '' }));  },  isSelected(color) {    return this.currentColor.get() === color;  },  events() {    return [      {        'click .js-palette-color'() {          this.currentColor.set(this.currentData().color);        },        'click .js-submit'() {          this.colorButtonValue.set(this.currentColor.get());          Popup.back();        },      },    ];  },}).register('setCardActionsColorPopup');
 |