matrix-react-sdk
Version:
SDK for matrix.org using React
396 lines (366 loc) • 41.4 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.registerShortcut = exports.toggleDialog = exports.CMD_OR_CTRL = exports.Modifiers = exports.Categories = void 0;
var React = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var sdk = _interopRequireWildcard(require("../index"));
var _Modal = _interopRequireDefault(require("../Modal"));
var _languageHandler = require("../languageHandler");
var _Keyboard = require("../Keyboard");
/*
Copyright 2020 The Matrix.org Foundation C.I.C.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// TS: once languageHandler is TS we can probably inline this into the enum
(0, _languageHandler._td)("Navigation");
(0, _languageHandler._td)("Calls");
(0, _languageHandler._td)("Composer");
(0, _languageHandler._td)("Room List");
(0, _languageHandler._td)("Autocomplete");
let Categories; // TS: once languageHandler is TS we can probably inline this into the enum
exports.Categories = Categories;
(function (Categories) {
Categories["NAVIGATION"] = "Navigation";
Categories["CALLS"] = "Calls";
Categories["COMPOSER"] = "Composer";
Categories["ROOM_LIST"] = "Room List";
Categories["ROOM"] = "Room";
Categories["AUTOCOMPLETE"] = "Autocomplete";
})(Categories || (exports.Categories = Categories = {}));
(0, _languageHandler._td)("Alt");
(0, _languageHandler._td)("Alt Gr");
(0, _languageHandler._td)("Shift");
(0, _languageHandler._td)("Super");
(0, _languageHandler._td)("Ctrl");
let Modifiers; // Meta-modifier: isMac ? CMD : CONTROL
exports.Modifiers = Modifiers;
(function (Modifiers) {
Modifiers["ALT"] = "Alt";
Modifiers["ALT_GR"] = "Alt Gr";
Modifiers["SHIFT"] = "Shift";
Modifiers["SUPER"] = "Super";
Modifiers["COMMAND"] = "Command";
Modifiers["CONTROL"] = "Ctrl";
})(Modifiers || (exports.Modifiers = Modifiers = {}));
const CMD_OR_CTRL = _Keyboard.isMac ? Modifiers.COMMAND : Modifiers.CONTROL;
exports.CMD_OR_CTRL = CMD_OR_CTRL;
const shortcuts
/*: Record<Categories, IShortcut[]>*/
= {
[Categories.COMPOSER]: [{
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.B
}],
description: (0, _languageHandler._td)("Toggle Bold")
}, {
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.I
}],
description: (0, _languageHandler._td)("Toggle Italics")
}, {
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.GREATER_THAN
}],
description: (0, _languageHandler._td)("Toggle Quote")
}, {
keybinds: [{
modifiers: [Modifiers.SHIFT],
key: _Keyboard.Key.ENTER
}],
description: (0, _languageHandler._td)("New line")
}, {
keybinds: [{
key: _Keyboard.Key.ARROW_UP
}, {
key: _Keyboard.Key.ARROW_DOWN
}],
description: (0, _languageHandler._td)("Navigate recent messages to edit")
}, {
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.HOME
}, {
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.END
}],
description: (0, _languageHandler._td)("Jump to start/end of the composer")
}, {
keybinds: [{
modifiers: [Modifiers.CONTROL, Modifiers.ALT],
key: _Keyboard.Key.ARROW_UP
}, {
modifiers: [Modifiers.CONTROL, Modifiers.ALT],
key: _Keyboard.Key.ARROW_DOWN
}],
description: (0, _languageHandler._td)("Navigate composer history")
}, {
keybinds: [{
key: _Keyboard.Key.ESCAPE
}],
description: (0, _languageHandler._td)("Cancel replying to a message")
}],
[Categories.CALLS]: [{
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.D
}],
description: (0, _languageHandler._td)("Toggle microphone mute")
}, {
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.E
}],
description: (0, _languageHandler._td)("Toggle video on/off")
}],
[Categories.ROOM]: [{
keybinds: [{
key: _Keyboard.Key.PAGE_UP
}, {
key: _Keyboard.Key.PAGE_DOWN
}],
description: (0, _languageHandler._td)("Scroll up/down in the timeline")
}, {
keybinds: [{
key: _Keyboard.Key.ESCAPE
}],
description: (0, _languageHandler._td)("Dismiss read marker and jump to bottom")
}, {
keybinds: [{
modifiers: [Modifiers.SHIFT],
key: _Keyboard.Key.PAGE_UP
}],
description: (0, _languageHandler._td)("Jump to oldest unread message")
}, {
keybinds: [{
modifiers: [CMD_OR_CTRL, Modifiers.SHIFT],
key: _Keyboard.Key.U
}],
description: (0, _languageHandler._td)("Upload a file")
}, {
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.F
}],
description: (0, _languageHandler._td)("Search (must be enabled)")
}],
[Categories.ROOM_LIST]: [{
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.K
}],
description: (0, _languageHandler._td)("Jump to room search")
}, {
keybinds: [{
key: _Keyboard.Key.ARROW_UP
}, {
key: _Keyboard.Key.ARROW_DOWN
}],
description: (0, _languageHandler._td)("Navigate up/down in the room list")
}, {
keybinds: [{
key: _Keyboard.Key.ENTER
}],
description: (0, _languageHandler._td)("Select room from the room list")
}, {
keybinds: [{
key: _Keyboard.Key.ARROW_LEFT
}],
description: (0, _languageHandler._td)("Collapse room list section")
}, {
keybinds: [{
key: _Keyboard.Key.ARROW_RIGHT
}],
description: (0, _languageHandler._td)("Expand room list section")
}, {
keybinds: [{
key: _Keyboard.Key.ESCAPE
}],
description: (0, _languageHandler._td)("Clear room list filter field")
}],
[Categories.NAVIGATION]: [{
keybinds: [{
modifiers: [Modifiers.ALT, Modifiers.SHIFT],
key: _Keyboard.Key.ARROW_UP
}, {
modifiers: [Modifiers.ALT, Modifiers.SHIFT],
key: _Keyboard.Key.ARROW_DOWN
}],
description: (0, _languageHandler._td)("Previous/next unread room or DM")
}, {
keybinds: [{
modifiers: [Modifiers.ALT],
key: _Keyboard.Key.ARROW_UP
}, {
modifiers: [Modifiers.ALT],
key: _Keyboard.Key.ARROW_DOWN
}],
description: (0, _languageHandler._td)("Previous/next room or DM")
}, {
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.BACKTICK
}],
description: (0, _languageHandler._td)("Toggle the top left menu")
}, {
keybinds: [{
key: _Keyboard.Key.ESCAPE
}],
description: (0, _languageHandler._td)("Close dialog or context menu")
}, {
keybinds: [{
key: _Keyboard.Key.ENTER
}, {
key: _Keyboard.Key.SPACE
}],
description: (0, _languageHandler._td)("Activate selected button")
}, {
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.PERIOD
}],
description: (0, _languageHandler._td)("Toggle right panel")
}, {
keybinds: [{
modifiers: [CMD_OR_CTRL],
key: _Keyboard.Key.SLASH
}],
description: (0, _languageHandler._td)("Toggle this dialog")
}, {
keybinds: [{
modifiers: [Modifiers.CONTROL, _Keyboard.isMac ? Modifiers.SHIFT : Modifiers.ALT],
key: _Keyboard.Key.H
}],
description: (0, _languageHandler._td)("Go to Home View")
}],
[Categories.AUTOCOMPLETE]: [{
keybinds: [{
key: _Keyboard.Key.ARROW_UP
}, {
key: _Keyboard.Key.ARROW_DOWN
}],
description: (0, _languageHandler._td)("Move autocomplete selection up/down")
}, {
keybinds: [{
key: _Keyboard.Key.ESCAPE
}],
description: (0, _languageHandler._td)("Cancel autocomplete")
}]
};
const categoryOrder = [Categories.COMPOSER, Categories.AUTOCOMPLETE, Categories.ROOM, Categories.ROOM_LIST, Categories.NAVIGATION, Categories.CALLS];
const modifierIcon
/*: Record<string, string>*/
= {
[Modifiers.COMMAND]: "⌘"
};
if (_Keyboard.isMac) {
modifierIcon[Modifiers.ALT] = "⌥";
}
const alternateKeyName
/*: Record<string, string>*/
= {
[_Keyboard.Key.PAGE_UP]: (0, _languageHandler._td)("Page Up"),
[_Keyboard.Key.PAGE_DOWN]: (0, _languageHandler._td)("Page Down"),
[_Keyboard.Key.ESCAPE]: (0, _languageHandler._td)("Esc"),
[_Keyboard.Key.ENTER]: (0, _languageHandler._td)("Enter"),
[_Keyboard.Key.SPACE]: (0, _languageHandler._td)("Space"),
[_Keyboard.Key.HOME]: (0, _languageHandler._td)("Home"),
[_Keyboard.Key.END]: (0, _languageHandler._td)("End")
};
const keyIcon
/*: Record<string, string>*/
= {
[_Keyboard.Key.ARROW_UP]: "↑",
[_Keyboard.Key.ARROW_DOWN]: "↓",
[_Keyboard.Key.ARROW_LEFT]: "←",
[_Keyboard.Key.ARROW_RIGHT]: "→"
};
const Shortcut
/*: React.FC<{
shortcut: IShortcut;
}>*/
= ({
shortcut
}) => {
const classes = (0, _classnames.default)({
"mx_KeyboardShortcutsDialog_inline": shortcut.keybinds.every(k => !k.modifiers || k.modifiers.length === 0)
});
return /*#__PURE__*/React.createElement("div", {
className: classes
}, /*#__PURE__*/React.createElement("h5", null, (0, _languageHandler._t)(shortcut.description)), shortcut.keybinds.map(s => {
let text = s.key;
if (alternateKeyName[s.key]) {
text = (0, _languageHandler._t)(alternateKeyName[s.key]);
} else if (keyIcon[s.key]) {
text = keyIcon[s.key];
}
return /*#__PURE__*/React.createElement("div", {
key: s.key
}, s.modifiers && s.modifiers.map(m => {
return /*#__PURE__*/React.createElement(React.Fragment, {
key: m
}, /*#__PURE__*/React.createElement("kbd", null, modifierIcon[m] || (0, _languageHandler._t)(m)), "+");
}), /*#__PURE__*/React.createElement("kbd", null, text));
}));
};
let activeModal
/*: IModal*/
= null;
const toggleDialog = () => {
if (activeModal) {
activeModal.close();
activeModal = null;
return;
}
const sections = categoryOrder.map(category => {
const list = shortcuts[category];
return /*#__PURE__*/React.createElement("div", {
className: "mx_KeyboardShortcutsDialog_category",
key: category
}, /*#__PURE__*/React.createElement("h3", null, (0, _languageHandler._t)(category)), /*#__PURE__*/React.createElement("div", null, list.map(shortcut => /*#__PURE__*/React.createElement(Shortcut, {
key: shortcut.description,
shortcut: shortcut
}))));
});
const InfoDialog = sdk.getComponent('dialogs.InfoDialog');
activeModal = _Modal.default.createTrackedDialog("Keyboard Shortcuts", "", InfoDialog, {
className: "mx_KeyboardShortcutsDialog",
title: (0, _languageHandler._t)("Keyboard Shortcuts"),
description: sections,
hasCloseButton: true,
onKeyDown: ev => {
if (ev.ctrlKey && !ev.shiftKey && !ev.altKey && !ev.metaKey && ev.key === _Keyboard.Key.SLASH) {
// Ctrl + /
ev.stopPropagation();
activeModal.close();
}
},
onFinished: () => {
activeModal = null;
}
});
};
exports.toggleDialog = toggleDialog;
const registerShortcut = (category
/*: Categories*/
, defn
/*: IShortcut*/
) => {
shortcuts[category].push(defn);
};
exports.registerShortcut = registerShortcut;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/accessibility/KeyboardShortcuts.tsx"],"names":["Categories","Modifiers","CMD_OR_CTRL","isMac","COMMAND","CONTROL","shortcuts","COMPOSER","keybinds","modifiers","key","Key","B","description","I","GREATER_THAN","SHIFT","ENTER","ARROW_UP","ARROW_DOWN","HOME","END","ALT","ESCAPE","CALLS","D","E","ROOM","PAGE_UP","PAGE_DOWN","U","F","ROOM_LIST","K","ARROW_LEFT","ARROW_RIGHT","NAVIGATION","BACKTICK","SPACE","PERIOD","SLASH","H","AUTOCOMPLETE","categoryOrder","modifierIcon","alternateKeyName","keyIcon","Shortcut","shortcut","classes","every","k","length","map","s","text","m","activeModal","toggleDialog","close","sections","category","list","InfoDialog","sdk","getComponent","Modal","createTrackedDialog","className","title","hasCloseButton","onKeyDown","ev","ctrlKey","shiftKey","altKey","metaKey","stopPropagation","onFinished","registerShortcut","defn","push"],"mappings":"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","sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport * as React from \"react\";\nimport classNames from \"classnames\";\n\nimport * as sdk from \"../index\";\nimport Modal from \"../Modal\";\nimport { _t, _td } from \"../languageHandler\";\nimport {isMac, Key} from \"../Keyboard\";\n\n// TS: once languageHandler is TS we can probably inline this into the enum\n_td(\"Navigation\");\n_td(\"Calls\");\n_td(\"Composer\");\n_td(\"Room List\");\n_td(\"Autocomplete\");\n\nexport enum Categories {\n    NAVIGATION = \"Navigation\",\n    CALLS = \"Calls\",\n    COMPOSER = \"Composer\",\n    ROOM_LIST = \"Room List\",\n    ROOM = \"Room\",\n    AUTOCOMPLETE = \"Autocomplete\",\n}\n\n// TS: once languageHandler is TS we can probably inline this into the enum\n_td(\"Alt\");\n_td(\"Alt Gr\");\n_td(\"Shift\");\n_td(\"Super\");\n_td(\"Ctrl\");\n\nexport enum Modifiers {\n    ALT = \"Alt\", // Option on Mac and displayed as an Icon\n    ALT_GR = \"Alt Gr\",\n    SHIFT = \"Shift\",\n    SUPER = \"Super\", // should this be \"Windows\"?\n    // Instead of using below, consider CMD_OR_CTRL\n    COMMAND = \"Command\", // This gets displayed as an Icon\n    CONTROL = \"Ctrl\",\n}\n\n// Meta-modifier: isMac ? CMD : CONTROL\nexport const CMD_OR_CTRL = isMac ? Modifiers.COMMAND : Modifiers.CONTROL;\n\ninterface IKeybind {\n    modifiers?: Modifiers[];\n    key: string; // TS: fix this once Key is an enum\n}\n\ninterface IShortcut {\n    keybinds: IKeybind[];\n    description: string;\n}\n\nconst shortcuts: Record<Categories, IShortcut[]> = {\n    [Categories.COMPOSER]: [\n        {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.B,\n            }],\n            description: _td(\"Toggle Bold\"),\n        }, {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.I,\n            }],\n            description: _td(\"Toggle Italics\"),\n        }, {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.GREATER_THAN,\n            }],\n            description: _td(\"Toggle Quote\"),\n        }, {\n            keybinds: [{\n                modifiers: [Modifiers.SHIFT],\n                key: Key.ENTER,\n            }],\n            description: _td(\"New line\"),\n        }, {\n            keybinds: [{\n                key: Key.ARROW_UP,\n            }, {\n                key: Key.ARROW_DOWN,\n            }],\n            description: _td(\"Navigate recent messages to edit\"),\n        }, {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.HOME,\n            }, {\n                modifiers: [CMD_OR_CTRL],\n                key: Key.END,\n            }],\n            description: _td(\"Jump to start/end of the composer\"),\n        }, {\n            keybinds: [{\n                modifiers: [Modifiers.CONTROL, Modifiers.ALT],\n                key: Key.ARROW_UP,\n            }, {\n                modifiers: [Modifiers.CONTROL, Modifiers.ALT],\n                key: Key.ARROW_DOWN,\n            }],\n            description: _td(\"Navigate composer history\"),\n        }, {\n            keybinds: [{\n                key: Key.ESCAPE,\n            }],\n            description: _td(\"Cancel replying to a message\"),\n        },\n    ],\n\n    [Categories.CALLS]: [\n        {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.D,\n            }],\n            description: _td(\"Toggle microphone mute\"),\n        }, {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.E,\n            }],\n            description: _td(\"Toggle video on/off\"),\n        },\n    ],\n\n    [Categories.ROOM]: [\n        {\n            keybinds: [{\n                key: Key.PAGE_UP,\n            }, {\n                key: Key.PAGE_DOWN,\n            }],\n            description: _td(\"Scroll up/down in the timeline\"),\n        }, {\n            keybinds: [{\n                key: Key.ESCAPE,\n            }],\n            description: _td(\"Dismiss read marker and jump to bottom\"),\n        }, {\n            keybinds: [{\n                modifiers: [Modifiers.SHIFT],\n                key: Key.PAGE_UP,\n            }],\n                description: _td(\"Jump to oldest unread message\"),\n        }, {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL, Modifiers.SHIFT],\n                key: Key.U,\n            }],\n            description: _td(\"Upload a file\"),\n        }, {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.F,\n            }],\n            description: _td(\"Search (must be enabled)\"),\n        },\n    ],\n\n    [Categories.ROOM_LIST]: [\n        {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.K,\n            }],\n            description: _td(\"Jump to room search\"),\n        }, {\n            keybinds: [{\n                key: Key.ARROW_UP,\n            }, {\n                key: Key.ARROW_DOWN,\n            }],\n            description: _td(\"Navigate up/down in the room list\"),\n        }, {\n            keybinds: [{\n                key: Key.ENTER,\n            }],\n            description: _td(\"Select room from the room list\"),\n        }, {\n            keybinds: [{\n                key: Key.ARROW_LEFT,\n            }],\n            description: _td(\"Collapse room list section\"),\n        }, {\n            keybinds: [{\n                key: Key.ARROW_RIGHT,\n            }],\n            description: _td(\"Expand room list section\"),\n        }, {\n            keybinds: [{\n                key: Key.ESCAPE,\n            }],\n            description: _td(\"Clear room list filter field\"),\n        },\n    ],\n\n    [Categories.NAVIGATION]: [\n        {\n            keybinds: [{\n                modifiers: [Modifiers.ALT, Modifiers.SHIFT],\n                key: Key.ARROW_UP,\n            }, {\n                modifiers: [Modifiers.ALT, Modifiers.SHIFT],\n                key: Key.ARROW_DOWN,\n            }],\n            description: _td(\"Previous/next unread room or DM\"),\n        }, {\n            keybinds: [{\n                modifiers: [Modifiers.ALT],\n                key: Key.ARROW_UP,\n            }, {\n                modifiers: [Modifiers.ALT],\n                key: Key.ARROW_DOWN,\n            }],\n            description: _td(\"Previous/next room or DM\"),\n        }, {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.BACKTICK,\n            }],\n            description: _td(\"Toggle the top left menu\"),\n        }, {\n            keybinds: [{\n                key: Key.ESCAPE,\n            }],\n            description: _td(\"Close dialog or context menu\"),\n        }, {\n            keybinds: [{\n                key: Key.ENTER,\n            }, {\n                key: Key.SPACE,\n            }],\n            description: _td(\"Activate selected button\"),\n        }, {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.PERIOD,\n            }],\n            description: _td(\"Toggle right panel\"),\n        }, {\n            keybinds: [{\n                modifiers: [CMD_OR_CTRL],\n                key: Key.SLASH,\n            }],\n            description: _td(\"Toggle this dialog\"),\n        }, {\n            keybinds: [{\n                modifiers: [Modifiers.CONTROL, isMac ? Modifiers.SHIFT : Modifiers.ALT],\n                key: Key.H,\n            }],\n            description: _td(\"Go to Home View\"),\n        },\n    ],\n\n    [Categories.AUTOCOMPLETE]: [\n        {\n            keybinds: [{\n                key: Key.ARROW_UP,\n            }, {\n                key: Key.ARROW_DOWN,\n            }],\n            description: _td(\"Move autocomplete selection up/down\"),\n        }, {\n            keybinds: [{\n                key: Key.ESCAPE,\n            }],\n            description: _td(\"Cancel autocomplete\"),\n        },\n    ],\n};\n\nconst categoryOrder = [\n    Categories.COMPOSER,\n    Categories.AUTOCOMPLETE,\n    Categories.ROOM,\n    Categories.ROOM_LIST,\n    Categories.NAVIGATION,\n    Categories.CALLS,\n];\n\ninterface IModal {\n    close: () => void;\n    finished: Promise<any[]>;\n}\n\nconst modifierIcon: Record<string, string> = {\n    [Modifiers.COMMAND]: \"⌘\",\n};\n\nif (isMac) {\n    modifierIcon[Modifiers.ALT] = \"⌥\";\n}\n\nconst alternateKeyName: Record<string, string> = {\n    [Key.PAGE_UP]: _td(\"Page Up\"),\n    [Key.PAGE_DOWN]: _td(\"Page Down\"),\n    [Key.ESCAPE]: _td(\"Esc\"),\n    [Key.ENTER]: _td(\"Enter\"),\n    [Key.SPACE]: _td(\"Space\"),\n    [Key.HOME]: _td(\"Home\"),\n    [Key.END]: _td(\"End\"),\n};\nconst keyIcon: Record<string, string> = {\n    [Key.ARROW_UP]: \"↑\",\n    [Key.ARROW_DOWN]: \"↓\",\n    [Key.ARROW_LEFT]: \"←\",\n    [Key.ARROW_RIGHT]: \"→\",\n};\n\nconst Shortcut: React.FC<{\n    shortcut: IShortcut;\n}> = ({shortcut}) => {\n    const classes = classNames({\n        \"mx_KeyboardShortcutsDialog_inline\": shortcut.keybinds.every(k => !k.modifiers || k.modifiers.length === 0),\n    });\n\n    return <div className={classes}>\n        <h5>{ _t(shortcut.description) }</h5>\n        { shortcut.keybinds.map(s => {\n            let text = s.key;\n            if (alternateKeyName[s.key]) {\n                text = _t(alternateKeyName[s.key]);\n            } else if (keyIcon[s.key]) {\n                text = keyIcon[s.key];\n            }\n\n            return <div key={s.key}>\n                { s.modifiers && s.modifiers.map(m => {\n                    return <React.Fragment key={m}>\n                        <kbd>{ modifierIcon[m] || _t(m) }</kbd>+\n                    </React.Fragment>;\n                }) }\n                <kbd>{ text }</kbd>\n            </div>;\n        }) }\n    </div>;\n};\n\nlet activeModal: IModal = null;\nexport const toggleDialog = () => {\n    if (activeModal) {\n        activeModal.close();\n        activeModal = null;\n        return;\n    }\n\n    const sections = categoryOrder.map(category => {\n        const list = shortcuts[category];\n        return <div className=\"mx_KeyboardShortcutsDialog_category\" key={category}>\n            <h3>{_t(category)}</h3>\n            <div>{list.map(shortcut => <Shortcut key={shortcut.description} shortcut={shortcut} />)}</div>\n        </div>;\n    });\n\n    const InfoDialog = sdk.getComponent('dialogs.InfoDialog');\n    activeModal = Modal.createTrackedDialog(\"Keyboard Shortcuts\", \"\", InfoDialog, {\n        className: \"mx_KeyboardShortcutsDialog\",\n        title: _t(\"Keyboard Shortcuts\"),\n        description: sections,\n        hasCloseButton: true,\n        onKeyDown: (ev) => {\n            if (ev.ctrlKey && !ev.shiftKey && !ev.altKey && !ev.metaKey && ev.key === Key.SLASH) { // Ctrl + /\n                ev.stopPropagation();\n                activeModal.close();\n            }\n        },\n        onFinished: () => {\n            activeModal = null;\n        },\n    });\n};\n\nexport const registerShortcut = (category: Categories, defn: IShortcut) => {\n    shortcuts[category].push(defn);\n};\n"]}