cbd4deedf8
* Initialized keyboard service Neat but funky: dynamic subnav traversal 👻 generalized traverseSubnav method Shift as special modifier key Nice little demo panel Keyboard shortcuts keycard Some animation styles on keyboard shortcuts Handle situations where a link is deeply nested from its parent menu item Keyboard service cleanup helper-based initializer and teardown for new contextual commands Keyboard shortcuts modal component added and demo-ghost removed Removed j and k from subnav traversal Register and unregister methods for subnav plus new subnavs for volumes and volume register main nav method Generalizing the register nav method 12762 table keynav (#12975) * Experimental feature: shortcut visual hints * Long way around to a custom modifier for keyboard shortcuts * dynamic table and list iterative shortcuts * Progress with regular old tether * Delogging * Table Keynav tether fix, server and client navs, and fix to shiftless on modified arrow keys Go to Optimize keyboard link and storage key changed to g r parameterized jobs keyboard nav Dynamic numeric keynav for multiple tables (#13482) * Multiple tables init * URL-bind enumerable keyboard commands and add to more taskRow and allocationRows * Type safety and lint fixes * Consolidated push to keyCommands * Default value when removing keyCommands * Remove the URL-based removal method and perform a recompute on any add Get tests passing in Keynav: remove math helpers and a few other defensive moves (#13761) * Remove ember math helpers * Test fixes for jobparts/body * Kill an unneeded integration helper test * delog * Trying if disabling percy lets this finish * Okay so its not percy; try parallelism in circle * Percyless yet again * Trying a different angle to not have percy * Upgrade percy to 1.6.1 [ui] Keyboard nav: "u" key to go up a level (#13754) * U to go up a level * Mislabelled my conditional * Custom lint ignore rule * Custom lint ignore rule, this time with commas * Since we're getting rid of ember math helpers elsewhere, do the math ourselves here Replace ArrowLeft etc. with an ascii arrow (#13776) * Replace ArrowLeft etc. with an ascii arrow * non-mutative helper cleanup Keyboard Nav: let users rebind their shortcuts (#13781) * click-outside and shortcuts enabled/disabled toggle * Trap focus when modal open * Enabled/disabled saved to localStorage * Autofocus edit button on variable index * Modal overflow styles * Functional rebind * Saving rebinds to localStorage for all majors * Started on defaultCommandBindings * Modal header style and cancel rebind on escape * keyboardable keybindings w buttons instead of spans * recording and defaultvalues * Enter short-circuits rebind * Only some commands are rebindable, and dont show dupes * No unused get import * More visually distinct header on modal * Disallowed keys for rebind, showing buffer as you type, and moving dedupe to modal logic willDestroy hook to prevent tests from doubling/tripling up addEventListener on kb events remove unused tests Keyboard Navigation acceptance tests (#13893) * Acceptance tests for keyboard modal * a11y audit fix and localStorage clear * Bind/rebind/localStorage tests * Keyboard tests for dynamic nav and tables * Rebinder and assert expectation * Second percy snapshot showing hints no longer relevant Weird issue where linktos with query props specifically from the task-groups page would fail to route / hit undefined.shouldSuperCede errors Adds the concept of exclusivity to a keycommand, removing peers that also share its label Lintfix Changelog and PR feedback Changelog and PR feedback Fix to rebinding in firefox by blurring the now-disabled button on rebind (#14053) * Secure Variables shortcuts removed * Variable index route autofocus removed * Updated changelog entry * Updated changelog entry * Keynav docs (#14148) * Section added to the API Docs UI page * Added a note about disabling * Prev and Next order * Remove dev log and unneeded comments
98 lines
2.1 KiB
JavaScript
98 lines
2.1 KiB
JavaScript
/* eslint-disable ember/no-observers */
|
|
import { inject as service } from '@ember/service';
|
|
import Controller from '@ember/controller';
|
|
import { next } from '@ember/runloop';
|
|
import { observes } from '@ember-decorators/object';
|
|
import { computed } from '@ember/object';
|
|
import Ember from 'ember';
|
|
import codesForError from '../utils/codes-for-error';
|
|
import NoLeaderError from '../utils/no-leader-error';
|
|
import OTTExchangeError from '../utils/ott-exchange-error';
|
|
import classic from 'ember-classic-decorator';
|
|
// eslint-disable-next-line no-unused-vars
|
|
import KeyboardService from '../services/keyboard';
|
|
@classic
|
|
export default class ApplicationController extends Controller {
|
|
@service config;
|
|
@service system;
|
|
@service token;
|
|
@service flashMessages;
|
|
|
|
/**
|
|
* @type {KeyboardService}
|
|
*/
|
|
@service keyboard;
|
|
|
|
// eslint-disable-next-line ember/classic-decorator-hooks
|
|
constructor() {
|
|
super(...arguments);
|
|
this.keyboard.listenForKeypress();
|
|
}
|
|
|
|
queryParams = [
|
|
{
|
|
region: 'region',
|
|
},
|
|
{
|
|
oneTimeToken: 'ott',
|
|
},
|
|
];
|
|
|
|
region = null;
|
|
|
|
oneTimeToken = '';
|
|
|
|
error = null;
|
|
|
|
@computed('error')
|
|
get errorStr() {
|
|
return this.error.toString();
|
|
}
|
|
|
|
@computed('error')
|
|
get errorCodes() {
|
|
return codesForError(this.error);
|
|
}
|
|
|
|
@computed('errorCodes.[]')
|
|
get is403() {
|
|
return this.errorCodes.includes('403');
|
|
}
|
|
|
|
@computed('errorCodes.[]')
|
|
get is404() {
|
|
return this.errorCodes.includes('404');
|
|
}
|
|
|
|
@computed('errorCodes.[]')
|
|
get is500() {
|
|
return this.errorCodes.includes('500');
|
|
}
|
|
|
|
@computed('error')
|
|
get isNoLeader() {
|
|
const error = this.error;
|
|
return error instanceof NoLeaderError;
|
|
}
|
|
|
|
@computed('error')
|
|
get isOTTExchange() {
|
|
const error = this.error;
|
|
return error instanceof OTTExchangeError;
|
|
}
|
|
|
|
@observes('error')
|
|
throwError() {
|
|
if (this.get('config.isDev')) {
|
|
next(() => {
|
|
throw this.error;
|
|
});
|
|
} else if (!Ember.testing) {
|
|
next(() => {
|
|
// eslint-disable-next-line
|
|
console.warn('UNRECOVERABLE ERROR:', this.error);
|
|
});
|
|
}
|
|
}
|
|
}
|