@blueprintjs/core
Version:
Core styles & components
118 lines (116 loc) • 15 kB
JavaScript
/*
* 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
*/
;
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/"}