matrix-react-sdk
Version:
SDK for matrix.org using React
108 lines (105 loc) • 15.7 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _lodash = require("lodash");
var _languageHandler = require("../../../languageHandler");
var _KeyBindingsManager = require("../../../KeyBindingsManager");
var _KeyboardShortcuts = require("../../../accessibility/KeyboardShortcuts");
/*
Copyright 2024 New Vector Ltd.
Copyright 2020 The Matrix.org Foundation C.I.C.
Copyright 2019 Tulir Asokan <tulir@maunium.net>
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
class Header extends _react.default.PureComponent {
constructor(...args) {
super(...args);
// Implements ARIA Tabs with Automatic Activation pattern
// https://www.w3.org/TR/wai-aria-practices/examples/tabs/tabs-1/tabs.html
(0, _defineProperty2.default)(this, "onKeyDown", ev => {
let handled = true;
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(ev);
switch (action) {
case _KeyboardShortcuts.KeyBindingAction.ArrowLeft:
this.changeCategoryRelative(-1);
break;
case _KeyboardShortcuts.KeyBindingAction.ArrowRight:
this.changeCategoryRelative(1);
break;
case _KeyboardShortcuts.KeyBindingAction.Home:
this.changeCategoryAbsolute(0);
break;
case _KeyboardShortcuts.KeyBindingAction.End:
this.changeCategoryAbsolute(this.props.categories.length - 1, -1);
break;
default:
handled = false;
}
if (handled) {
ev.preventDefault();
ev.stopPropagation();
}
});
}
findNearestEnabled(index, delta) {
index += this.props.categories.length;
const cats = [...this.props.categories, ...this.props.categories, ...this.props.categories];
while (index < cats.length && index >= 0) {
if (cats[index].enabled) return index % this.props.categories.length;
index += delta > 0 ? 1 : -1;
}
}
changeCategoryRelative(delta) {
let current;
// As multiple categories may be visible at once, we want to find the one closest to the relative direction
if (delta < 0) {
current = this.props.categories.findIndex(c => c.visible);
} else {
// XXX: Switch to Array::findLastIndex once we enable ES2023
current = (0, _lodash.findLastIndex)(this.props.categories, c => c.visible);
}
this.changeCategoryAbsolute(current + delta, delta);
}
changeCategoryAbsolute(index, delta = 1) {
const category = this.props.categories[this.findNearestEnabled(index, delta)];
if (category) {
this.props.onAnchorClick(category.id);
category.ref.current?.focus();
}
}
render() {
return /*#__PURE__*/_react.default.createElement("nav", {
className: "mx_EmojiPicker_header",
role: "tablist",
"aria-label": (0, _languageHandler._t)("emoji|categories"),
onKeyDown: this.onKeyDown
}, this.props.categories.map(category => {
const classes = (0, _classnames.default)(`mx_EmojiPicker_anchor mx_EmojiPicker_anchor_${category.id}`, {
mx_EmojiPicker_anchor_visible: category.visible
});
// Properties of this button are also modified by EmojiPicker's updateVisibility in DOM.
return /*#__PURE__*/_react.default.createElement("button", {
disabled: !category.enabled,
key: category.id,
ref: category.ref,
className: classes,
onClick: () => this.props.onAnchorClick(category.id),
title: category.name,
role: "tab",
tabIndex: category.visible ? 0 : -1 // roving
,
"aria-selected": category.visible,
"aria-controls": `mx_EmojiPicker_category_${category.id}`
});
}));
}
}
var _default = exports.default = Header;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_lodash","_languageHandler","_KeyBindingsManager","_KeyboardShortcuts","Header","React","PureComponent","constructor","args","_defineProperty2","default","ev","handled","action","getKeyBindingsManager","getAccessibilityAction","KeyBindingAction","ArrowLeft","changeCategoryRelative","ArrowRight","Home","changeCategoryAbsolute","End","props","categories","length","preventDefault","stopPropagation","findNearestEnabled","index","delta","cats","enabled","current","findIndex","c","visible","findLastIndex","category","onAnchorClick","id","ref","focus","render","createElement","className","role","_t","onKeyDown","map","classes","classNames","mx_EmojiPicker_anchor_visible","disabled","key","onClick","title","name","tabIndex","_default","exports"],"sources":["../../../../src/components/views/emojipicker/Header.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020 The Matrix.org Foundation C.I.C.\nCopyright 2019 Tulir Asokan <tulir@maunium.net>\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React from \"react\";\nimport classNames from \"classnames\";\nimport { findLastIndex } from \"lodash\";\n\nimport { _t } from \"../../../languageHandler\";\nimport { CategoryKey, ICategory } from \"./Category\";\nimport { getKeyBindingsManager } from \"../../../KeyBindingsManager\";\nimport { KeyBindingAction } from \"../../../accessibility/KeyboardShortcuts\";\n\ninterface IProps {\n    categories: ICategory[];\n    onAnchorClick(id: CategoryKey): void;\n}\n\nclass Header extends React.PureComponent<IProps> {\n    private findNearestEnabled(index: number, delta: number): number | undefined {\n        index += this.props.categories.length;\n        const cats = [...this.props.categories, ...this.props.categories, ...this.props.categories];\n\n        while (index < cats.length && index >= 0) {\n            if (cats[index].enabled) return index % this.props.categories.length;\n            index += delta > 0 ? 1 : -1;\n        }\n    }\n\n    private changeCategoryRelative(delta: number): void {\n        let current: number;\n        // As multiple categories may be visible at once, we want to find the one closest to the relative direction\n        if (delta < 0) {\n            current = this.props.categories.findIndex((c) => c.visible);\n        } else {\n            // XXX: Switch to Array::findLastIndex once we enable ES2023\n            current = findLastIndex(this.props.categories, (c) => c.visible);\n        }\n        this.changeCategoryAbsolute(current + delta, delta);\n    }\n\n    private changeCategoryAbsolute(index: number, delta = 1): void {\n        const category = this.props.categories[this.findNearestEnabled(index, delta)!];\n        if (category) {\n            this.props.onAnchorClick(category.id);\n            category.ref.current?.focus();\n        }\n    }\n\n    // Implements ARIA Tabs with Automatic Activation pattern\n    // https://www.w3.org/TR/wai-aria-practices/examples/tabs/tabs-1/tabs.html\n    private onKeyDown = (ev: React.KeyboardEvent): void => {\n        let handled = true;\n\n        const action = getKeyBindingsManager().getAccessibilityAction(ev);\n        switch (action) {\n            case KeyBindingAction.ArrowLeft:\n                this.changeCategoryRelative(-1);\n                break;\n            case KeyBindingAction.ArrowRight:\n                this.changeCategoryRelative(1);\n                break;\n\n            case KeyBindingAction.Home:\n                this.changeCategoryAbsolute(0);\n                break;\n            case KeyBindingAction.End:\n                this.changeCategoryAbsolute(this.props.categories.length - 1, -1);\n                break;\n            default:\n                handled = false;\n        }\n\n        if (handled) {\n            ev.preventDefault();\n            ev.stopPropagation();\n        }\n    };\n\n    public render(): React.ReactNode {\n        return (\n            <nav\n                className=\"mx_EmojiPicker_header\"\n                role=\"tablist\"\n                aria-label={_t(\"emoji|categories\")}\n                onKeyDown={this.onKeyDown}\n            >\n                {this.props.categories.map((category) => {\n                    const classes = classNames(`mx_EmojiPicker_anchor mx_EmojiPicker_anchor_${category.id}`, {\n                        mx_EmojiPicker_anchor_visible: category.visible,\n                    });\n                    // Properties of this button are also modified by EmojiPicker's updateVisibility in DOM.\n                    return (\n                        <button\n                            disabled={!category.enabled}\n                            key={category.id}\n                            ref={category.ref}\n                            className={classes}\n                            onClick={() => this.props.onAnchorClick(category.id)}\n                            title={category.name}\n                            role=\"tab\"\n                            tabIndex={category.visible ? 0 : -1} // roving\n                            aria-selected={category.visible}\n                            aria-controls={`mx_EmojiPicker_category_${category.id}`}\n                        />\n                    );\n                })}\n            </nav>\n        );\n    }\n}\n\nexport default Header;\n"],"mappings":"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","ignoreList":[]}