wekan/client/components/rules/actions/cardActions.js

241 lines
7.2 KiB
JavaScript
Raw Normal View History

let cardColors;
Meteor.startup(() => {
cardColors = Cards.simpleSchema()._schema.color.allowedValues;
});
2018-08-19 18:53:50 +02:00
BlazeComponent.extendComponent({
onCreated() {
this.subscribe('allRules');
this.cardColorButtonValue = new ReactiveVar('green');
},
cardColorButton() {
return this.cardColorButtonValue.get();
},
cardColorButtonText() {
2019-06-28 12:52:09 -05:00
return `color-${this.cardColorButtonValue.get()}`;
2018-08-19 18:53:50 +02:00
},
2018-09-14 17:39:37 +02:00
labels() {
2018-08-19 18:53:50 +02:00
const labels = Boards.findOne(Session.get('currentBoard')).labels;
2018-09-14 17:39:37 +02:00
for (let i = 0; i < labels.length; i++) {
2018-09-16 01:50:36 +03:00
if (labels[i].name === '' || labels[i].name === undefined) {
2018-08-19 18:53:50 +02:00
labels[i].name = labels[i].color.toUpperCase();
}
}
return labels;
},
events() {
2019-06-28 12:52:09 -05:00
return [
{
'click .js-set-date-action'(event) {
const ruleName = this.data().ruleName.get();
const trigger = this.data().triggerVar.get();
2018-09-14 17:39:37 +02:00
const triggerId = Triggers.insert(trigger);
2019-06-28 12:52:09 -05:00
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);
2018-09-14 17:39:37 +02:00
const actionId = Actions.insert({
2019-06-28 12:52:09 -05:00
actionType: actionSelected,
dateField: dateFieldSelected,
2018-09-16 01:50:36 +03:00
boardId,
desc,
2018-09-14 17:39:37 +02:00
});
2019-06-28 12:52:09 -05:00
2018-09-14 17:39:37 +02:00
Rules.insert({
title: ruleName,
2018-09-16 01:50:36 +03:00
triggerId,
actionId,
boardId,
2019-06-28 12:52:09 -05:00
desc,
2018-09-14 17:39:37 +02:00
});
2019-06-28 12:52:09 -05:00
},
'click .js-remove-datevalue-action'(event) {
const ruleName = this.data().ruleName.get();
const trigger = this.data().triggerVar.get();
2018-09-14 17:39:37 +02:00
const triggerId = Triggers.insert(trigger);
2019-06-28 12:52:09 -05:00
const dateFieldSelected = this.find('#setdate-removedatefieldvalue')
.value;
const boardId = Session.get('currentBoard');
const desc = Utils.getTriggerActionDesc(event, this);
2018-09-14 17:39:37 +02:00
const actionId = Actions.insert({
2019-06-28 12:52:09 -05:00
actionType: 'removeDate',
dateField: dateFieldSelected,
2018-09-16 01:50:36 +03:00
boardId,
desc,
2018-09-14 17:39:37 +02:00
});
2019-06-28 12:52:09 -05:00
2018-09-14 17:39:37 +02:00
Rules.insert({
title: ruleName,
2018-09-16 01:50:36 +03:00
triggerId,
actionId,
boardId,
2019-06-28 12:52:09 -05:00
desc,
2018-09-14 17:39:37 +02:00
});
2019-06-28 12:52:09 -05:00
},
'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();
2018-09-14 17:39:37 +02:00
const triggerId = Triggers.insert(trigger);
2019-06-28 12:52:09 -05:00
const desc = Utils.getTriggerActionDesc(event, this);
const boardId = Session.get('currentBoard');
2018-09-14 17:39:37 +02:00
const actionId = Actions.insert({
2019-06-28 12:52:09 -05:00
actionType: 'removeMember',
// deepcode ignore NoHardcodedCredentials: it's no credential
2019-06-28 12:52:09 -05:00
username: '*',
2018-09-16 01:50:36 +03:00
boardId,
desc,
2018-09-14 17:39:37 +02:00
});
Rules.insert({
title: ruleName,
2018-09-16 01:50:36 +03:00
triggerId,
actionId,
boardId,
2018-09-14 17:39:37 +02:00
});
2019-06-28 12:52:09 -05:00
},
'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);
2018-09-14 17:39:37 +02:00
const triggerId = Triggers.insert(trigger);
const actionId = Actions.insert({
2019-06-28 12:52:09 -05:00
actionType: 'setColor',
selectedColor,
2018-09-16 01:50:36 +03:00
boardId,
desc,
2018-09-14 17:39:37 +02:00
});
Rules.insert({
title: ruleName,
2018-09-16 01:50:36 +03:00
triggerId,
actionId,
boardId,
2018-09-14 17:39:37 +02:00
});
2019-06-28 12:52:09 -05:00
},
},
2019-06-28 12:52:09 -05:00
];
2018-09-14 17:39:37 +02:00
},
2018-09-16 01:50:36 +03:00
}).register('cardActions');
BlazeComponent.extendComponent({
onCreated() {
this.currentAction = this.currentData();
this.colorButtonValue = Popup.getOpenerComponent().cardColorButtonValue;
this.currentColor = new ReactiveVar(this.colorButtonValue.get());
},
colors() {
2019-06-28 12:52:09 -05:00
return cardColors.map(color => ({ color, name: '' }));
},
isSelected(color) {
return this.currentColor.get() === color;
},
events() {
2019-06-28 12:52:09 -05:00
return [
{
'click .js-palette-color'() {
this.currentColor.set(this.currentData().color);
},
'click .js-submit'() {
this.colorButtonValue.set(this.currentColor.get());
Popup.close();
},
},
2019-06-28 12:52:09 -05:00
];
},
}).register('setCardActionsColorPopup');