Charlie Tran 843a6c5bbb
feat(frontend): update datahub-web client UI code (#1806)
* Releases updated version of datahub-web client UI code

* Fix typo in yarn lock

* Change yarn lock to match yarn registry directories

* Previous commit missed some paths

* Even more changes to yarnlock missing in previous commit

* Include codegen file for typings

* Add files to get parity for datahub-web and current OS datahub-midtier

* Add in typo fix from previous commit - change to proper license

* Implement proper OS fix for person entity picture url

* Workarounds for open source DH issues

* Fixes institutional memory api and removes unopensourced tabs for datasets

* Fixes search dataset deprecation and user search issue as a result of changes

* Remove internal only options in the avatar menu
2020-08-26 15:44:50 -07:00

76 lines
2.1 KiB
TypeScript

import Component from '@ember/component';
import { action } from '@ember/object';
import { inject as service } from '@ember/service';
import HotKeys from 'datahub-web/services/hot-keys';
// Top level component class selector
const emberAppElementSelector = '.ember-application';
/**
* GlobalHotkeys component provides a way to listen for registered keypress events on the DOM by handling the binding or unbinding of listener
* event
* @export
* @class GlobalHotkeys
* @extends {Component}
*/
export default class GlobalHotkeys extends Component {
/**
* A set of DOM keyup event targets for which the hotkey listener will be ignored. Ineligible targets are not useful for the hotkey feature, or
* conflict with the default behavior of the target element for example input elements
*/
inEligibleTargets = new Set(['INPUT', 'TEXTAREA']);
/**
* Service that assists with actually triggering the actions tied to a particular
* target hotkey
*/
@service
hotKeys: HotKeys;
/**
* Returns true if target exists, is not an input, and is not an editable div
* @param {Element} target - target element
*/
isEligibleTarget(target: Element): boolean {
return (
!this.inEligibleTargets.has(target.tagName) &&
!(target.tagName === 'DIV' && target.attributes.getNamedItem('contenteditable'))
);
}
/**
* Method for handling the global keyup.
* @param {KeyboardEvent} e - KeyboardEvent triggered by user input
*/
@action
onKeyUp(e: KeyboardEvent): void {
const target = e.target as Element | null;
if (target && this.isEligibleTarget(target)) {
this.hotKeys.applyKeyMapping(e.keyCode);
}
}
/**
* On DOM insertion, apply handler for keyup events
*/
didInsertElement(): void {
const app = document.querySelector(emberAppElementSelector);
if (app) {
app.addEventListener('keyup', this.onKeyUp);
}
}
/**
* On component destruction, remove hot-keys event handler
*/
willDestroyElement(): void {
const app = document.querySelector(emberAppElementSelector);
if (app) {
app.removeEventListener('keyup', this.onKeyUp);
}
}
}