73 lines
2.3 KiB
JavaScript
73 lines
2.3 KiB
JavaScript
import Controller from '@ember/controller';
|
|
import { get, set } from '@ember/object';
|
|
import Changeset from 'ember-changeset';
|
|
import lookupValidator from 'ember-changeset-validations';
|
|
|
|
import validations from 'consul-ui/validations/intention';
|
|
|
|
export default Controller.extend({
|
|
setProperties: function(model) {
|
|
this.changeset = new Changeset(model.item, lookupValidator(validations), validations);
|
|
const sourceName = get(model.item, 'SourceName');
|
|
const destinationName = get(model.item, 'DestinationName');
|
|
let source = model.items.findBy('Name', sourceName);
|
|
let destination = model.items.findBy('Name', destinationName);
|
|
if (!source) {
|
|
source = { Name: sourceName };
|
|
model.items = [source].concat(model.items);
|
|
}
|
|
if (!destination) {
|
|
destination = { Name: destinationName };
|
|
model.items = [destination].concat(model.items);
|
|
}
|
|
this._super({
|
|
...model,
|
|
...{
|
|
item: this.changeset,
|
|
SourceName: source,
|
|
DestinationName: destination,
|
|
},
|
|
});
|
|
},
|
|
actions: {
|
|
createNewLabel: function(term) {
|
|
return `Use a future Consul Service called '${term}'`;
|
|
},
|
|
isUnique: function(term) {
|
|
return !get(this, 'items').findBy('Name', term);
|
|
},
|
|
change: function(e, value, _target) {
|
|
// normalize back to standard event
|
|
const target = e.target || { ..._target, ...{ name: e, value: value } };
|
|
let name, selected;
|
|
name = selected = target.value;
|
|
// TODO:
|
|
// linter needs this here?
|
|
let match;
|
|
switch (target.name) {
|
|
case 'Description':
|
|
case 'Action':
|
|
set(this.changeset, target.name, target.value);
|
|
break;
|
|
case 'SourceName':
|
|
case 'DestinationName':
|
|
if (typeof name !== 'string') {
|
|
name = get(target.value, 'Name');
|
|
}
|
|
// linter doesn't like const here
|
|
match = get(this, 'items').filterBy('Name', name);
|
|
if (match.length === 0) {
|
|
selected = { Name: name };
|
|
// linter doesn't mind const here?
|
|
const items = [selected].concat(this.items.toArray());
|
|
set(this, 'items', items);
|
|
}
|
|
set(this.changeset, target.name, name);
|
|
set(this, target.name, selected);
|
|
break;
|
|
}
|
|
this.changeset.validate();
|
|
},
|
|
},
|
|
});
|