import ko from 'ko'; import { inFocus } from 'Common/Utils'; import { addObservablesTo, addComputablesTo, addSubscribablesTo } from 'External/ko'; import { Scope } from 'Common/Enums'; import { keyScope, Settings, leftPanelDisabled } from 'Common/Globals'; import { ViewType, showScreenPopup } from 'Knoin/Knoin'; class AbstractView { constructor(templateID, type) { // Object.defineProperty(this, 'viewModelTemplateID', { value: templateID }); this.viewModelTemplateID = templateID; this.viewType = type; this.viewModelDom = null; this.keyScope = { scope: Scope.None, previous: Scope.None, set: function() { this.previous = keyScope(); keyScope(this.scope); }, unset: function() { keyScope(this.previous); } }; } /* onBuild() {} onBeforeShow() {} onShow() {} onHide() {} */ querySelector(selectors) { return this.viewModelDom.querySelector(selectors); } addObservables(observables) { addObservablesTo(this, observables); } addComputables(computables) { addComputablesTo(this, computables); } addSubscribables(subscribables) { addSubscribablesTo(this, subscribables); } } export class AbstractViewPopup extends AbstractView { constructor(name) { super('Popups' + name, ViewType.Popup); if (name in Scope) { this.keyScope.scope = Scope[name]; } this.bDisabeCloseOnEsc = false; this.modalVisibility = ko.observable(false).extend({ rateLimit: 0 }); } /* onShowWithDelay() {} onHideWithDelay() {} cancelCommand() {} closeCommand() {} */ /** * @returns {void} */ registerPopupKeyDown() { addEventListener('keydown', event => { if (event && this.modalVisibility()) { if (!this.bDisabeCloseOnEsc && 'Escape' == event.key) { this.cancelCommand(); return false; } else if ('Backspace' == event.key && !inFocus()) { return false; } } return true; }); } } AbstractViewPopup.showModal = function(params = []) { showScreenPopup(this, params); } AbstractViewPopup.hidden = function() { return !this.__vm || !this.__vm.modalVisibility(); } export class AbstractViewCenter extends AbstractView { constructor(templateID) { super(templateID, ViewType.Content); } } export class AbstractViewLeft extends AbstractView { constructor(templateID) { super(templateID, ViewType.Left); this.leftPanelDisabled = leftPanelDisabled; } } export class AbstractViewRight extends AbstractView { constructor(templateID) { super(templateID, ViewType.Right); } } /* export class AbstractViewSettings { onBuild(viewModelDom) {} onBeforeShow() {} onShow() {} onHide() {} viewModelDom } */ export class AbstractViewLogin extends AbstractViewCenter { constructor(templateID) { super(templateID); this.hideSubmitButton = Settings.app('hideSubmitButton'); this.formError = ko.observable(false).extend({ falseTimeout: 500 }); } onBuild(dom) { dom.classList.add('LoginView'); } onShow() { rl.route.off(); } submitForm() { // return false; } }