mirror of
https://github.com/status-im/consul.git
synced 2025-01-10 13:55:55 +00:00
6589cbbd0d
* ui: Add the most basic workspace root in /ui * We already have a LICENSE file in the repository root * Change directory path in build scripts ui-v2 -> ui * Make yarn install flags configurable from elsewhere * Minimal workspace root makefile * Call the new docker specific target * Update yarn in the docker build image * Reconfigure the netlify target and move to the higher makefile * Move ui-v2 -> ui/packages/consul-ui * Change repo root to refleect new folder structure * Temporarily don't hoist consul-api-double * Fixup CI configuration * Fixup lint errors * Fixup Netlify target
50 lines
1.6 KiB
JavaScript
50 lines
1.6 KiB
JavaScript
import Component from '@ember/component';
|
|
import Slotted from 'block-slots';
|
|
import { inject as service } from '@ember/service';
|
|
import { alias } from '@ember/object/computed';
|
|
// match anything that isn't a [ or ] into multiple groups
|
|
const propRe = /([^[\]])+/g;
|
|
export default Component.extend(Slotted, {
|
|
tagName: '',
|
|
onreset: function() {},
|
|
onchange: function() {},
|
|
onerror: function() {},
|
|
onsuccess: function() {},
|
|
|
|
data: alias('form.data'),
|
|
item: alias('form.data'),
|
|
// TODO: Could probably alias item
|
|
// or just use data/value instead
|
|
|
|
dom: service('dom'),
|
|
container: service('form'),
|
|
|
|
actions: {
|
|
change: function(e, value, item) {
|
|
let event = this.dom.normalizeEvent(e, value);
|
|
// currently form-components don't deal with deeply nested forms, only top level
|
|
// we therefore grab the end of the nest off here,
|
|
// so role[policy][Rules] will end up as policy[Rules]
|
|
// but also policy[Rules] will end up as Rules
|
|
// for now we look for a [ so we know whether this component is deeply
|
|
// nested or not and we pass the name through as an optional argument to handleEvent
|
|
// once this component handles deeply nested forms this can go
|
|
const matches = [...event.target.name.matchAll(propRe)];
|
|
const prop = matches[matches.length - 1][0];
|
|
let name;
|
|
if (prop.indexOf('[') === -1) {
|
|
name = `${this.type}[${prop}]`;
|
|
} else {
|
|
name = prop;
|
|
}
|
|
const form = this.form;
|
|
try {
|
|
form.handleEvent(event, name);
|
|
this.onchange({ target: this });
|
|
} catch (err) {
|
|
throw err;
|
|
}
|
|
},
|
|
},
|
|
});
|