matrix-react-sdk
Version:
SDK for matrix.org using React
108 lines (105 loc) • 18.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _compoundWeb = require("@vector-im/compound-web");
var _close = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/close"));
var _chevronLeft = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/chevron-left"));
var _AutoHideScrollbar = _interopRequireDefault(require("../../structures/AutoHideScrollbar"));
var _languageHandler = require("../../../languageHandler");
var _RightPanelStore = _interopRequireDefault(require("../../../stores/right-panel/RightPanelStore"));
var _RightPanelStorePhases = require("../../../stores/right-panel/RightPanelStorePhases");
var _context = require("./context");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
/*
Copyright 2024 New Vector Ltd.
Copyright 2020 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
function closeRightPanel(ev) {
ev.preventDefault();
ev.stopPropagation();
_RightPanelStore.default.instance.popCard();
}
const BaseCard = /*#__PURE__*/(0, _react.forwardRef)(({
closeLabel,
onClose,
onBack,
className,
id,
ariaLabelledBy,
role,
hideHeaderButtons,
header,
footer,
withoutScrollContainer,
children,
onKeyDown,
closeButtonRef
}, ref) => {
let backButton;
const cardHistory = _RightPanelStore.default.instance.roomPhaseHistory;
if (cardHistory.length > 1 && !hideHeaderButtons) {
const prevCard = cardHistory[cardHistory.length - 2];
const onBackClick = ev => {
onBack?.(ev);
_RightPanelStore.default.instance.popCard();
};
const label = (0, _RightPanelStorePhases.backLabelForPhase)(prevCard.phase) ?? (0, _languageHandler._t)("action|back");
backButton = /*#__PURE__*/_react.default.createElement(_compoundWeb.IconButton, {
size: "28px",
"data-testid": "base-card-back-button",
onClick: onBackClick,
tooltip: label,
subtleBackground: true
}, /*#__PURE__*/_react.default.createElement(_chevronLeft.default, null));
}
let closeButton;
if (!hideHeaderButtons) {
closeButton = /*#__PURE__*/_react.default.createElement(_compoundWeb.IconButton, {
size: "28px",
"data-testid": "base-card-close-button",
onClick: onClose ?? closeRightPanel,
ref: closeButtonRef,
tooltip: closeLabel ?? (0, _languageHandler._t)("action|close"),
subtleBackground: true
}, /*#__PURE__*/_react.default.createElement(_close.default, null));
}
if (!withoutScrollContainer) {
children = /*#__PURE__*/_react.default.createElement(_AutoHideScrollbar.default, null, children);
}
const shouldRenderHeader = header || !hideHeaderButtons;
return /*#__PURE__*/_react.default.createElement(_context.CardContext.Provider, {
value: {
isCard: true
}
}, /*#__PURE__*/_react.default.createElement("div", {
id: id,
"aria-labelledby": ariaLabelledBy,
role: role,
className: (0, _classnames.default)("mx_BaseCard", className),
ref: ref,
onKeyDown: onKeyDown
}, shouldRenderHeader && /*#__PURE__*/_react.default.createElement("div", {
className: "mx_BaseCard_header"
}, backButton, typeof header === "string" ? /*#__PURE__*/_react.default.createElement("div", {
className: "mx_BaseCard_header_title"
}, /*#__PURE__*/_react.default.createElement(_compoundWeb.Text, {
size: "md",
weight: "medium",
className: "mx_BaseCard_header_title_heading",
role: "heading"
}, header)) : header ?? /*#__PURE__*/_react.default.createElement("div", {
className: "mx_BaseCard_header_spacer"
}), closeButton), children, footer && /*#__PURE__*/_react.default.createElement("div", {
className: "mx_BaseCard_footer"
}, footer)));
});
var _default = exports.default = BaseCard;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_compoundWeb","_close","_chevronLeft","_AutoHideScrollbar","_languageHandler","_RightPanelStore","_RightPanelStorePhases","_context","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","closeRightPanel","ev","preventDefault","stopPropagation","RightPanelStore","instance","popCard","BaseCard","forwardRef","closeLabel","onClose","onBack","className","id","ariaLabelledBy","role","hideHeaderButtons","header","footer","withoutScrollContainer","children","onKeyDown","closeButtonRef","ref","backButton","cardHistory","roomPhaseHistory","length","prevCard","onBackClick","label","backLabelForPhase","phase","_t","createElement","IconButton","size","onClick","tooltip","subtleBackground","closeButton","shouldRenderHeader","CardContext","Provider","value","isCard","classNames","Text","weight","_default","exports"],"sources":["../../../../src/components/views/right_panel/BaseCard.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020 The Matrix.org Foundation C.I.C.\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, { forwardRef, ReactNode, KeyboardEvent, Ref, MouseEvent } from \"react\";\nimport classNames from \"classnames\";\nimport { IconButton, Text } from \"@vector-im/compound-web\";\nimport CloseIcon from \"@vector-im/compound-design-tokens/assets/web/icons/close\";\nimport ChevronLeftIcon from \"@vector-im/compound-design-tokens/assets/web/icons/chevron-left\";\n\nimport AutoHideScrollbar from \"../../structures/AutoHideScrollbar\";\nimport { _t } from \"../../../languageHandler\";\nimport RightPanelStore from \"../../../stores/right-panel/RightPanelStore\";\nimport { backLabelForPhase } from \"../../../stores/right-panel/RightPanelStorePhases\";\nimport { CardContext } from \"./context\";\n\ninterface IProps {\n    header?: ReactNode | null;\n    hideHeaderButtons?: boolean;\n    footer?: ReactNode;\n    className?: string;\n    id?: string;\n    role?: \"tabpanel\";\n    ariaLabelledBy?: string;\n    withoutScrollContainer?: boolean;\n    closeLabel?: string;\n    onClose?(ev: MouseEvent<HTMLButtonElement>): void;\n    onBack?(ev: MouseEvent<HTMLButtonElement>): void;\n    onKeyDown?(ev: KeyboardEvent): void;\n    cardState?: any;\n    ref?: Ref<HTMLDivElement>;\n    // Ref for the 'close' button the card\n    closeButtonRef?: Ref<HTMLButtonElement>;\n    children: ReactNode;\n}\n\nfunction closeRightPanel(ev: MouseEvent<HTMLButtonElement>): void {\n    ev.preventDefault();\n    ev.stopPropagation();\n    RightPanelStore.instance.popCard();\n}\n\nconst BaseCard: React.FC<IProps> = forwardRef<HTMLDivElement, IProps>(\n    (\n        {\n            closeLabel,\n            onClose,\n            onBack,\n            className,\n            id,\n            ariaLabelledBy,\n            role,\n            hideHeaderButtons,\n            header,\n            footer,\n            withoutScrollContainer,\n            children,\n            onKeyDown,\n            closeButtonRef,\n        },\n        ref,\n    ) => {\n        let backButton;\n        const cardHistory = RightPanelStore.instance.roomPhaseHistory;\n        if (cardHistory.length > 1 && !hideHeaderButtons) {\n            const prevCard = cardHistory[cardHistory.length - 2];\n            const onBackClick = (ev: MouseEvent<HTMLButtonElement>): void => {\n                onBack?.(ev);\n                RightPanelStore.instance.popCard();\n            };\n            const label = backLabelForPhase(prevCard.phase) ?? _t(\"action|back\");\n            backButton = (\n                <IconButton\n                    size=\"28px\"\n                    data-testid=\"base-card-back-button\"\n                    onClick={onBackClick}\n                    tooltip={label}\n                    subtleBackground\n                >\n                    <ChevronLeftIcon />\n                </IconButton>\n            );\n        }\n\n        let closeButton;\n        if (!hideHeaderButtons) {\n            closeButton = (\n                <IconButton\n                    size=\"28px\"\n                    data-testid=\"base-card-close-button\"\n                    onClick={onClose ?? closeRightPanel}\n                    ref={closeButtonRef}\n                    tooltip={closeLabel ?? _t(\"action|close\")}\n                    subtleBackground\n                >\n                    <CloseIcon />\n                </IconButton>\n            );\n        }\n\n        if (!withoutScrollContainer) {\n            children = <AutoHideScrollbar>{children}</AutoHideScrollbar>;\n        }\n\n        const shouldRenderHeader = header || !hideHeaderButtons;\n\n        return (\n            <CardContext.Provider value={{ isCard: true }}>\n                <div\n                    id={id}\n                    aria-labelledby={ariaLabelledBy}\n                    role={role}\n                    className={classNames(\"mx_BaseCard\", className)}\n                    ref={ref}\n                    onKeyDown={onKeyDown}\n                >\n                    {shouldRenderHeader && (\n                        <div className=\"mx_BaseCard_header\">\n                            {backButton}\n                            {typeof header === \"string\" ? (\n                                <div className=\"mx_BaseCard_header_title\">\n                                    <Text\n                                        size=\"md\"\n                                        weight=\"medium\"\n                                        className=\"mx_BaseCard_header_title_heading\"\n                                        role=\"heading\"\n                                    >\n                                        {header}\n                                    </Text>\n                                </div>\n                            ) : (\n                                (header ?? <div className=\"mx_BaseCard_header_spacer\" />)\n                            )}\n                            {closeButton}\n                        </div>\n                    )}\n                    {children}\n                    {footer && <div className=\"mx_BaseCard_footer\">{footer}</div>}\n                </div>\n            </CardContext.Provider>\n        );\n    },\n);\n\nexport default BaseCard;\n"],"mappings":"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","ignoreList":[]}