mirror of
https://github.com/status-im/consul.git
synced 2025-01-15 08:14:54 +00:00
ee393e34fb
1. Amends our `base` animation placeholder to always reset transition-duration. This has no effect on other components that are already using this animation. 2. Adds a confirming class whenever a key is pressed, to show the green tick. Uses CSS via `transition-delay` for debouncing.
54 lines
1.6 KiB
JavaScript
54 lines
1.6 KiB
JavaScript
import Controller from '@ember/controller';
|
|
import { get, set } from '@ember/object';
|
|
import { inject as service } from '@ember/service';
|
|
|
|
export default Controller.extend({
|
|
repo: service('settings'),
|
|
dom: service('dom'),
|
|
timeout: service('timeout'),
|
|
confirming: false,
|
|
applyTransition: function() {
|
|
const tick = get(this, 'timeout').tick;
|
|
set(this, 'confirming', true);
|
|
tick().then(() => {
|
|
set(this, 'confirming', false);
|
|
});
|
|
},
|
|
actions: {
|
|
key: function(e) {
|
|
this.applyTransition();
|
|
switch (true) {
|
|
case e.keyCode === 13:
|
|
// disable ENTER
|
|
e.preventDefault();
|
|
}
|
|
},
|
|
change: function(e, value, item) {
|
|
const event = get(this, 'dom').normalizeEvent(e, value);
|
|
// TODO: Switch to using forms like the rest of the app
|
|
// setting utils/form/builder for things to be done before we
|
|
// can do that. For the moment just do things normally its a simple
|
|
// enough form at the moment
|
|
|
|
const target = event.target;
|
|
const blocking = get(this, 'item.client.blocking');
|
|
switch (target.name) {
|
|
case 'client[blocking]':
|
|
if (typeof blocking === 'undefined') {
|
|
set(this, 'item.client', {});
|
|
}
|
|
set(this, 'item.client.blocking', !blocking);
|
|
this.send('update', get(this, 'item'));
|
|
break;
|
|
case 'urls[service]':
|
|
if (typeof get(this, 'item.urls') === 'undefined') {
|
|
set(this, 'item.urls', {});
|
|
}
|
|
set(this, 'item.urls.service', target.value);
|
|
this.send('update', get(this, 'item'));
|
|
break;
|
|
}
|
|
},
|
|
},
|
|
});
|