2019-07-02 06:49:14 +02:00
|
|
|
import { observes, default as computed } from 'ember-addons/ember-computed-decorators';
|
2017-10-19 04:17:36 +02:00
|
|
|
|
2017-09-23 04:34:07 +02:00
|
|
|
export default Ember.Component.extend({
|
|
|
|
classNames: 'wizard-custom-step',
|
2017-10-06 04:59:02 +02:00
|
|
|
currentField: null,
|
|
|
|
currentAction: null,
|
2017-10-19 04:17:36 +02:00
|
|
|
disableId: Ember.computed.not('step.isNew'),
|
|
|
|
|
|
|
|
@observes('step')
|
|
|
|
resetCurrentObjects() {
|
|
|
|
const fields = this.get('step.fields');
|
|
|
|
const actions = this.get('step.actions');
|
|
|
|
this.setProperties({
|
|
|
|
currentField: fields.length ? fields[0] : null,
|
|
|
|
currentAction: actions.length ? actions[0] : null
|
|
|
|
});
|
2019-07-02 06:49:14 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
@computed('availableFields', 'wizard.steps')
|
|
|
|
requiredContent(availableFields, steps) {
|
|
|
|
let content = availableFields;
|
|
|
|
let actions = [];
|
|
|
|
|
|
|
|
steps.forEach(s => {
|
|
|
|
actions.push(...s.actions);
|
|
|
|
});
|
|
|
|
|
|
|
|
actions.forEach(a => {
|
|
|
|
if (a.type === 'route_to' && a.code) {
|
|
|
|
content.push(Ember.Object.create({
|
|
|
|
id: a.code,
|
2019-07-02 08:52:47 +02:00
|
|
|
label: "code (Route To)"
|
2019-07-02 06:49:14 +02:00
|
|
|
}));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return content;
|
|
|
|
},
|
|
|
|
|
|
|
|
@computed
|
|
|
|
requiredConnectorContent() {
|
|
|
|
const label = (id) => I18n.t(`admin.wizard.step.required_data.connector.${id}`);
|
|
|
|
return [
|
|
|
|
{
|
|
|
|
id: 'equals',
|
|
|
|
label: label('equals')
|
|
|
|
}
|
|
|
|
];
|
|
|
|
},
|
|
|
|
|
|
|
|
@computed('step.id', 'wizard.save_submissions')
|
|
|
|
availableFields(currentStepId, saveSubmissions) {
|
|
|
|
const allSteps = this.get('wizard.steps');
|
|
|
|
let steps = allSteps;
|
|
|
|
let fields = [];
|
|
|
|
|
|
|
|
if (!saveSubmissions) {
|
|
|
|
steps = [allSteps.findBy('id', currentStepId)];
|
|
|
|
}
|
|
|
|
|
|
|
|
steps.forEach((s) => {
|
|
|
|
if (s.fields && s.fields.length > 0) {
|
|
|
|
let stepFields = s.fields.map((f) => {
|
|
|
|
return Ember.Object.create({
|
|
|
|
id: f.id,
|
|
|
|
label: `${f.id} (${s.id})`
|
|
|
|
});
|
|
|
|
});
|
|
|
|
fields.push(...stepFields);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return fields;
|
|
|
|
},
|
2017-09-23 04:34:07 +02:00
|
|
|
});
|