UNPKG

@blueprintjs/core

Version:
118 lines (116 loc) 15 kB
/* * Copyright 2016 Palantir Technologies, Inc. All rights reserved. * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE * and https://github.com/palantir/blueprint/blob/master/PATENTS */ "use strict"; var __assign = (this && this.__assign) || Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; var classNames = require("classnames"); var React = require("react"); var ReactDOM = require("react-dom"); var common_1 = require("../../common"); var components_1 = require("../../components"); var hotkey_1 = require("./hotkey"); var hotkeys_1 = require("./hotkeys"); var HotkeysDialog = (function () { function HotkeysDialog() { var _this = this; this.hotkeysDialogProps = { globalHotkeysGroup: "Global hotkeys", }; this.showing = false; this.hotkeysQueue = []; this.timeoutToken = 0; this.unmount = function () { _this.showing = false; return ReactDOM.unmountComponentAtNode(_this.getContainer()); }; this.destroy = function () { _this.showing = false; if (_this.container != null) { ReactDOM.unmountComponentAtNode(_this.container); _this.container.remove(); delete _this.container; } }; this.renderHotkeysDialog = function () { _this.showing = true; _this.render(React.createElement(components_1.Dialog, __assign({}, _this.hotkeysDialogProps, {className: classNames(_this.hotkeysDialogProps.className, "pt-hotkey-dialog"), inline: true, isOpen: true, onClose: _this.unmount}), React.createElement("div", {className: common_1.Classes.DIALOG_BODY}, _this.renderHotkeys()) )); }; } HotkeysDialog.prototype.render = function (node) { return ReactDOM.render(node, this.getContainer()); }; /** * Because hotkeys can be registered globally and locally and because * event ordering cannot be guaranteed, we use this debouncing method to * allow all hotkey listeners to fire and add their hotkeys to the dialog. * * 10msec after the last listener adds their hotkeys, we render the dialog * and clear the queue. */ HotkeysDialog.prototype.enqueueHotkeysForDisplay = function (hotkeys) { this.hotkeysQueue.push(hotkeys); // reset timeout for debounce clearTimeout(this.timeoutToken); this.timeoutToken = setTimeout(this.renderHotkeysDialog, 10); }; HotkeysDialog.prototype.getContainer = function () { if (this.container == null) { this.container = document.createElement("div"); this.container.classList.add(common_1.Classes.PORTAL); document.body.appendChild(this.container); } return this.container; }; HotkeysDialog.prototype.renderHotkeys = function () { var _this = this; var hotkeys = this.emptyHotkeyQueue(); var elements = hotkeys.map(function (hotkey, index) { var group = (hotkey.global === true && hotkey.group == null) ? _this.hotkeysDialogProps.globalHotkeysGroup : hotkey.group; return React.createElement(hotkey_1.Hotkey, __assign({key: index}, hotkey, {group: group})); }); return React.createElement(hotkeys_1.Hotkeys, null, elements); }; HotkeysDialog.prototype.emptyHotkeyQueue = function () { // flatten then empty the hotkeys queue var hotkeys = this.hotkeysQueue.reduce((function (arr, queued) { return arr.concat(queued); }), []); this.hotkeysQueue.length = 0; return hotkeys; }; return HotkeysDialog; }()); // singleton instance var HOTKEYS_DIALOG = new HotkeysDialog(); function isHotkeysDialogShowing() { return HOTKEYS_DIALOG.showing; } exports.isHotkeysDialogShowing = isHotkeysDialogShowing; function setHotkeysDialogProps(props) { for (var key in props) { if (props.hasOwnProperty(key)) { HOTKEYS_DIALOG.hotkeysDialogProps[key] = props[key]; } } } exports.setHotkeysDialogProps = setHotkeysDialogProps; function showHotkeysDialog(hotkeys) { HOTKEYS_DIALOG.enqueueHotkeysForDisplay(hotkeys); } exports.showHotkeysDialog = showHotkeysDialog; function hideHotkeysDialog() { HOTKEYS_DIALOG.unmount(); } exports.hideHotkeysDialog = hideHotkeysDialog; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/hotkeys/hotkeysDialog.tsx"],"names":[],"mappings":"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","file":"components/hotkeys/hotkeysDialog.js","sourcesContent":["/*\n * Copyright 2016 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport * as classNames from \"classnames\";\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\n\nimport { Classes } from \"../../common\";\nimport { Dialog, IDialogProps } from \"../../components\";\nimport { Hotkey, IHotkeyProps } from \"./hotkey\";\nimport { Hotkeys } from \"./hotkeys\";\n\nexport interface IHotkeysDialogProps extends IDialogProps {\n    /**\n     * This string displayed as the group name in the hotkeys dialog for all\n     * global hotkeys.\n     */\n    globalHotkeysGroup?: string;\n}\n\nclass HotkeysDialog {\n    public hotkeysDialogProps = {\n        globalHotkeysGroup: \"Global hotkeys\",\n    } as any as IHotkeysDialogProps;\n    public showing = false;\n    private hotkeysQueue = [] as IHotkeyProps[][];\n    private timeoutToken = 0;\n    private container: HTMLElement;\n\n    public render(node: React.ReactElement<any>) {\n        return ReactDOM.render(node, this.getContainer());\n    }\n\n    public unmount = () => {\n        this.showing = false;\n        return ReactDOM.unmountComponentAtNode(this.getContainer());\n    }\n\n    public destroy = () => {\n        this.showing = false;\n        if (this.container != null) {\n            ReactDOM.unmountComponentAtNode(this.container);\n            this.container.remove();\n            delete this.container;\n        }\n    }\n\n    /**\n     * Because hotkeys can be registered globally and locally and because\n     * event ordering cannot be guaranteed, we use this debouncing method to\n     * allow all hotkey listeners to fire and add their hotkeys to the dialog.\n     *\n     * 10msec after the last listener adds their hotkeys, we render the dialog\n     * and clear the queue.\n     */\n    public enqueueHotkeysForDisplay(hotkeys: IHotkeyProps[]) {\n        this.hotkeysQueue.push(hotkeys);\n\n        // reset timeout for debounce\n        clearTimeout(this.timeoutToken);\n        this.timeoutToken = setTimeout(this.renderHotkeysDialog, 10);\n    }\n\n    private getContainer() {\n        if (this.container == null) {\n            this.container = document.createElement(\"div\");\n            this.container.classList.add(Classes.PORTAL);\n            document.body.appendChild(this.container);\n        }\n        return this.container;\n    }\n\n    private renderHotkeysDialog = () => {\n        this.showing = true;\n        this.render(\n            <Dialog\n                {...this.hotkeysDialogProps}\n                className={classNames(this.hotkeysDialogProps.className, \"pt-hotkey-dialog\")}\n                inline\n                isOpen\n                onClose={this.unmount}\n            >\n                <div className={Classes.DIALOG_BODY}>{this.renderHotkeys()}</div>\n            </Dialog>,\n        );\n    }\n\n    private renderHotkeys() {\n        const hotkeys = this.emptyHotkeyQueue();\n        const elements = hotkeys.map((hotkey, index) => {\n            const group = (hotkey.global === true && hotkey.group == null) ?\n                this.hotkeysDialogProps.globalHotkeysGroup : hotkey.group;\n\n            return <Hotkey key={index} {...hotkey} group={group} />;\n        });\n\n        return <Hotkeys>{elements}</Hotkeys>;\n    }\n\n    private emptyHotkeyQueue() {\n        // flatten then empty the hotkeys queue\n        const hotkeys = this.hotkeysQueue.reduce(((arr, queued) => arr.concat(queued)), []);\n        this.hotkeysQueue.length = 0;\n        return hotkeys;\n    }\n}\n\n// singleton instance\nconst HOTKEYS_DIALOG = new HotkeysDialog();\n\nexport function isHotkeysDialogShowing() {\n    return HOTKEYS_DIALOG.showing;\n}\n\nexport function setHotkeysDialogProps(props: IHotkeysDialogProps) {\n    for (const key in props) {\n        if (props.hasOwnProperty(key)) {\n            (HOTKEYS_DIALOG.hotkeysDialogProps as any)[key] = (props as any)[key];\n        }\n    }\n}\n\nexport function showHotkeysDialog(hotkeys: IHotkeyProps[]) {\n    HOTKEYS_DIALOG.enqueueHotkeysForDisplay(hotkeys);\n}\n\nexport function hideHotkeysDialog() {\n    HOTKEYS_DIALOG.unmount();\n}\n"],"sourceRoot":"/source/"}