mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-01 15:29:19 +03:00
c51bce7358
refs. https://github.com/TryGhost/Team/issues/205 Major update to Ghost Admin UI including: - improved general consistency (typography, colors and contrast, UI components, icons) - new design for post and pages lists, improved discoverability of filters - search moved to modal - account menu is decoupled from ghost logo - further usability fixes
61 lines
1.6 KiB
JavaScript
61 lines
1.6 KiB
JavaScript
/* global key */
|
|
import Component from '@ember/component';
|
|
import {isBlank} from '@ember/utils';
|
|
|
|
export default Component.extend({
|
|
actions: {
|
|
captureMouseDown(e) {
|
|
e.stopPropagation();
|
|
},
|
|
|
|
search(term) {
|
|
// open dropdown if not open and term is present
|
|
// close dropdown if open and term is blank
|
|
if (isBlank(term) === this.select.isOpen) {
|
|
isBlank(term) ? this.close() : this.open();
|
|
|
|
// ensure focus isn't lost when dropdown is closed
|
|
if (isBlank(term)) {
|
|
this._focusInput();
|
|
}
|
|
}
|
|
|
|
this.select.actions.search(term);
|
|
},
|
|
|
|
focusInput() {
|
|
this._focusInput();
|
|
},
|
|
|
|
// hacky workaround to let Escape clear the input if there's text,
|
|
// but still allow it to close the search modal if there's no text
|
|
handleKeydown(e) {
|
|
if ((e.key === 'Escape' && e.target.value) || e.key === 'Enter') {
|
|
this._previousKeyScope = key.getScope();
|
|
key.setScope('ignore');
|
|
}
|
|
},
|
|
|
|
handleKeyup() {
|
|
if (key.getScope() === 'ignore') {
|
|
key.setScope(this._previousKeyScope);
|
|
}
|
|
}
|
|
},
|
|
|
|
open() {
|
|
this.select.actions.open();
|
|
},
|
|
|
|
close() {
|
|
this.select.actions.close();
|
|
},
|
|
|
|
_focusInput() {
|
|
let input = this.element && this.element.querySelector('input');
|
|
if (input) {
|
|
input.focus();
|
|
}
|
|
}
|
|
});
|