matrix-react-sdk
Version:
SDK for matrix.org using React
271 lines (265 loc) • 47.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.UploadButtonContext = exports.OverflowMenuContext = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classnames = _interopRequireDefault(require("classnames"));
var _matrix = require("matrix-js-sdk/src/matrix");
var _react = _interopRequireWildcard(require("react"));
var _languageHandler = require("../../../languageHandler");
var _CollapsibleButton = require("./CollapsibleButton");
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _ErrorDialog = _interopRequireDefault(require("../dialogs/ErrorDialog"));
var _location = require("../location");
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _PollCreateDialog = _interopRequireDefault(require("../elements/PollCreateDialog"));
var _MatrixClientPeg = require("../../../MatrixClientPeg");
var _ContentMessages = _interopRequireDefault(require("../../../ContentMessages"));
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _RoomContext = _interopRequireDefault(require("../../../contexts/RoomContext"));
var _useDispatcher = require("../../../hooks/useDispatcher");
var _BrowserWorkarounds = require("../../../utils/BrowserWorkarounds");
var _IconizedContextMenu = _interopRequireWildcard(require("../context_menus/IconizedContextMenu"));
var _EmojiButton = require("./EmojiButton");
var _arrays = require("../../../utils/arrays");
var _useSettings = require("../../../hooks/useSettings");
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
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 2022 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.
*/
const OverflowMenuContext = exports.OverflowMenuContext = /*#__PURE__*/(0, _react.createContext)(null);
const MessageComposerButtons = props => {
const matrixClient = (0, _react.useContext)(_MatrixClientContext.default);
const {
room,
narrow
} = (0, _react.useContext)(_RoomContext.default);
const isWysiwygLabEnabled = (0, _useSettings.useSettingValue)("feature_wysiwyg_composer");
if (!matrixClient || !room || props.haveRecording) {
return null;
}
let mainButtons;
let moreButtons;
if (narrow) {
mainButtons = [isWysiwygLabEnabled ? /*#__PURE__*/_react.default.createElement(ComposerModeButton, {
key: "composerModeButton",
isRichTextEnabled: props.isRichTextEnabled,
onClick: props.onComposerModeClick
}) : emojiButton(props)];
moreButtons = [uploadButton(),
// props passed via UploadButtonContext
showStickersButton(props), voiceRecordingButton(props, narrow), startVoiceBroadcastButton(props), props.showPollsButton ? pollButton(room, props.relation) : null, showLocationButton(props, room, matrixClient)];
} else {
mainButtons = [isWysiwygLabEnabled ? /*#__PURE__*/_react.default.createElement(ComposerModeButton, {
key: "composerModeButton",
isRichTextEnabled: props.isRichTextEnabled,
onClick: props.onComposerModeClick
}) : emojiButton(props), uploadButton() // props passed via UploadButtonContext
];
moreButtons = [showStickersButton(props), voiceRecordingButton(props, narrow), startVoiceBroadcastButton(props), props.showPollsButton ? pollButton(room, props.relation) : null, showLocationButton(props, room, matrixClient)];
}
mainButtons = (0, _arrays.filterBoolean)(mainButtons);
moreButtons = (0, _arrays.filterBoolean)(moreButtons);
const moreOptionsClasses = (0, _classnames.default)({
mx_MessageComposer_button: true,
mx_MessageComposer_buttonMenu: true,
mx_MessageComposer_closeButtonMenu: props.isMenuOpen
});
return /*#__PURE__*/_react.default.createElement(UploadButtonContextProvider, {
roomId: room.roomId,
relation: props.relation
}, mainButtons, moreButtons.length > 0 && /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: moreOptionsClasses,
onClick: props.toggleButtonMenu,
title: (0, _languageHandler._t)("quick_settings|sidebar_settings")
}), props.isMenuOpen && /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.default, (0, _extends2.default)({
onFinished: props.toggleButtonMenu
}, props.menuPosition, {
wrapperClassName: "mx_MessageComposer_Menu",
compact: true
}), /*#__PURE__*/_react.default.createElement(OverflowMenuContext.Provider, {
value: props.toggleButtonMenu
}, /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.IconizedContextMenuOptionList, null, moreButtons))));
};
function emojiButton(props) {
return /*#__PURE__*/_react.default.createElement(_EmojiButton.EmojiButton, {
key: "emoji_button",
addEmoji: props.addEmoji,
menuPosition: props.menuPosition,
className: "mx_MessageComposer_button"
});
}
function uploadButton() {
return /*#__PURE__*/_react.default.createElement(UploadButton, {
key: "controls_upload"
});
}
const UploadButtonContext = exports.UploadButtonContext = /*#__PURE__*/(0, _react.createContext)(null);
// We put the file input outside the UploadButton component so that it doesn't get killed when the context menu closes.
const UploadButtonContextProvider = ({
roomId,
relation,
children
}) => {
const cli = (0, _react.useContext)(_MatrixClientContext.default);
const roomContext = (0, _react.useContext)(_RoomContext.default);
const uploadInput = (0, _react.useRef)(null);
const onUploadClick = () => {
if (cli?.isGuest()) {
_dispatcher.default.dispatch({
action: "require_registration"
});
return;
}
uploadInput.current?.click();
};
(0, _useDispatcher.useDispatcher)(_dispatcher.default, payload => {
if (roomContext.timelineRenderingType === payload.context && payload.action === "upload_file") {
onUploadClick();
}
});
const onUploadFileInputChange = ev => {
if (ev.target.files?.length === 0) return;
// Take a copy, so we can safely reset the value of the form control
_ContentMessages.default.sharedInstance().sendContentListToRoom(Array.from(ev.target.files), roomId, relation, cli, roomContext.timelineRenderingType);
// This is the onChange handler for a file form control, but we're
// not keeping any state, so reset the value of the form control
// to empty.
// NB. we need to set 'value': the 'files' property is immutable.
ev.target.value = "";
};
const uploadInputStyle = {
display: "none"
};
return /*#__PURE__*/_react.default.createElement(UploadButtonContext.Provider, {
value: onUploadClick
}, children, /*#__PURE__*/_react.default.createElement("input", {
ref: uploadInput,
type: "file",
style: uploadInputStyle,
multiple: true,
onClick: _BrowserWorkarounds.chromeFileInputFix,
onChange: onUploadFileInputChange
}));
};
// Must be rendered within an UploadButtonContextProvider
const UploadButton = () => {
const overflowMenuCloser = (0, _react.useContext)(OverflowMenuContext);
const uploadButtonFn = (0, _react.useContext)(UploadButtonContext);
const onClick = () => {
uploadButtonFn?.();
overflowMenuCloser?.(); // close overflow menu
};
return /*#__PURE__*/_react.default.createElement(_CollapsibleButton.CollapsibleButton, {
className: "mx_MessageComposer_button",
iconClassName: "mx_MessageComposer_upload",
onClick: onClick,
title: (0, _languageHandler._t)("common|attachment")
});
};
function showStickersButton(props) {
return props.showStickersButton ? /*#__PURE__*/_react.default.createElement(_CollapsibleButton.CollapsibleButton, {
id: "stickersButton",
key: "controls_stickers",
className: "mx_MessageComposer_button",
iconClassName: "mx_MessageComposer_stickers",
onClick: () => props.setStickerPickerOpen(!props.isStickerPickerOpen),
title: props.isStickerPickerOpen ? (0, _languageHandler._t)("composer|close_sticker_picker") : (0, _languageHandler._t)("common|sticker")
}) : null;
}
const startVoiceBroadcastButton = props => {
return props.showVoiceBroadcastButton ? /*#__PURE__*/_react.default.createElement(_CollapsibleButton.CollapsibleButton, {
key: "start_voice_broadcast",
className: "mx_MessageComposer_button",
iconClassName: "mx_MessageComposer_voiceBroadcast",
onClick: props.onStartVoiceBroadcastClick,
title: (0, _languageHandler._t)("voice_broadcast|action")
}) : null;
};
function voiceRecordingButton(props, narrow) {
// XXX: recording UI does not work well in narrow mode, so hide for now
return narrow ? null : /*#__PURE__*/_react.default.createElement(_CollapsibleButton.CollapsibleButton, {
key: "voice_message_send",
className: "mx_MessageComposer_button",
iconClassName: "mx_MessageComposer_voiceMessage",
onClick: props.onRecordStartEndClick,
title: (0, _languageHandler._t)("composer|voice_message_button")
});
}
function pollButton(room, relation) {
return /*#__PURE__*/_react.default.createElement(PollButton, {
key: "polls",
room: room,
relation: relation
});
}
class PollButton extends _react.default.PureComponent {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "onCreateClick", () => {
this.context?.(); // close overflow menu
const canSend = this.props.room.currentState.maySendEvent(_matrix.M_POLL_START.name, _MatrixClientPeg.MatrixClientPeg.safeGet().getSafeUserId());
if (!canSend) {
_Modal.default.createDialog(_ErrorDialog.default, {
title: (0, _languageHandler._t)("composer|poll_button_no_perms_title"),
description: (0, _languageHandler._t)("composer|poll_button_no_perms_description")
});
} else {
const threadId = this.props.relation?.rel_type === _matrix.THREAD_RELATION_TYPE.name ? this.props.relation.event_id : undefined;
_Modal.default.createDialog(_PollCreateDialog.default, {
room: this.props.room,
threadId
}, "mx_CompoundDialog", false,
// isPriorityModal
true // isStaticModal
);
}
});
}
render() {
// do not allow sending polls within threads at this time
if (this.props.relation?.rel_type === _matrix.THREAD_RELATION_TYPE.name) return null;
return /*#__PURE__*/_react.default.createElement(_CollapsibleButton.CollapsibleButton, {
className: "mx_MessageComposer_button",
iconClassName: "mx_MessageComposer_poll",
onClick: this.onCreateClick,
title: (0, _languageHandler._t)("composer|poll_button")
});
}
}
(0, _defineProperty2.default)(PollButton, "contextType", OverflowMenuContext);
function showLocationButton(props, room, matrixClient) {
const sender = room.getMember(matrixClient.getSafeUserId());
return props.showLocationButton && sender ? /*#__PURE__*/_react.default.createElement(_location.LocationButton, {
key: "location",
roomId: room.roomId,
relation: props.relation,
sender: sender,
menuPosition: props.menuPosition
}) : null;
}
function ComposerModeButton({
isRichTextEnabled,
onClick
}) {
const title = isRichTextEnabled ? (0, _languageHandler._t)("composer|mode_plain") : (0, _languageHandler._t)("composer|mode_rich_text");
return /*#__PURE__*/_react.default.createElement(_CollapsibleButton.CollapsibleButton, {
className: "mx_MessageComposer_button",
iconClassName: (0, _classnames.default)({
mx_MessageComposer_plain_text: !isRichTextEnabled,
mx_MessageComposer_rich_text: isRichTextEnabled
}),
onClick: onClick,
title: title
});
}
var _default = exports.default = MessageComposerButtons;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_classnames","_interopRequireDefault","require","_matrix","_react","_interopRequireWildcard","_languageHandler","_CollapsibleButton","_dispatcher","_ErrorDialog","_location","_Modal","_PollCreateDialog","_MatrixClientPeg","_ContentMessages","_MatrixClientContext","_RoomContext","_useDispatcher","_BrowserWorkarounds","_IconizedContextMenu","_EmojiButton","_arrays","_useSettings","_AccessibleButton","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","OverflowMenuContext","exports","createContext","MessageComposerButtons","props","matrixClient","useContext","MatrixClientContext","room","narrow","RoomContext","isWysiwygLabEnabled","useSettingValue","haveRecording","mainButtons","moreButtons","createElement","ComposerModeButton","key","isRichTextEnabled","onClick","onComposerModeClick","emojiButton","uploadButton","showStickersButton","voiceRecordingButton","startVoiceBroadcastButton","showPollsButton","pollButton","relation","showLocationButton","filterBoolean","moreOptionsClasses","classNames","mx_MessageComposer_button","mx_MessageComposer_buttonMenu","mx_MessageComposer_closeButtonMenu","isMenuOpen","UploadButtonContextProvider","roomId","length","className","toggleButtonMenu","title","_t","_extends2","onFinished","menuPosition","wrapperClassName","compact","Provider","value","IconizedContextMenuOptionList","EmojiButton","addEmoji","UploadButton","UploadButtonContext","children","cli","roomContext","uploadInput","useRef","onUploadClick","isGuest","dis","dispatch","action","current","click","useDispatcher","payload","timelineRenderingType","context","onUploadFileInputChange","ev","target","files","ContentMessages","sharedInstance","sendContentListToRoom","Array","from","uploadInputStyle","display","ref","type","style","multiple","chromeFileInputFix","onChange","overflowMenuCloser","uploadButtonFn","CollapsibleButton","iconClassName","id","setStickerPickerOpen","isStickerPickerOpen","showVoiceBroadcastButton","onStartVoiceBroadcastClick","onRecordStartEndClick","PollButton","React","PureComponent","constructor","args","_defineProperty2","canSend","currentState","maySendEvent","M_POLL_START","name","MatrixClientPeg","safeGet","getSafeUserId","Modal","createDialog","ErrorDialog","description","threadId","rel_type","THREAD_RELATION_TYPE","event_id","undefined","PollCreateDialog","render","onCreateClick","sender","getMember","LocationButton","mx_MessageComposer_plain_text","mx_MessageComposer_rich_text","_default"],"sources":["../../../../src/components/views/rooms/MessageComposerButtons.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 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 classNames from \"classnames\";\nimport { IEventRelation, Room, MatrixClient, THREAD_RELATION_TYPE, M_POLL_START } from \"matrix-js-sdk/src/matrix\";\nimport React, { createContext, ReactElement, ReactNode, useContext, useRef } from \"react\";\n\nimport { _t } from \"../../../languageHandler\";\nimport { CollapsibleButton } from \"./CollapsibleButton\";\nimport { MenuProps } from \"../../structures/ContextMenu\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport ErrorDialog from \"../dialogs/ErrorDialog\";\nimport { LocationButton } from \"../location\";\nimport Modal from \"../../../Modal\";\nimport PollCreateDialog from \"../elements/PollCreateDialog\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport ContentMessages from \"../../../ContentMessages\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport RoomContext from \"../../../contexts/RoomContext\";\nimport { useDispatcher } from \"../../../hooks/useDispatcher\";\nimport { chromeFileInputFix } from \"../../../utils/BrowserWorkarounds\";\nimport IconizedContextMenu, { IconizedContextMenuOptionList } from \"../context_menus/IconizedContextMenu\";\nimport { EmojiButton } from \"./EmojiButton\";\nimport { filterBoolean } from \"../../../utils/arrays\";\nimport { useSettingValue } from \"../../../hooks/useSettings\";\nimport AccessibleButton, { ButtonEvent } from \"../elements/AccessibleButton\";\n\ninterface IProps {\n    addEmoji: (emoji: string) => boolean;\n    haveRecording: boolean;\n    isMenuOpen: boolean;\n    isStickerPickerOpen: boolean;\n    menuPosition?: MenuProps;\n    onRecordStartEndClick: () => void;\n    relation?: IEventRelation;\n    setStickerPickerOpen: (isStickerPickerOpen: boolean) => void;\n    showLocationButton: boolean;\n    showPollsButton: boolean;\n    showStickersButton: boolean;\n    toggleButtonMenu: () => void;\n    showVoiceBroadcastButton: boolean;\n    onStartVoiceBroadcastClick: () => void;\n    isRichTextEnabled: boolean;\n    onComposerModeClick: () => void;\n}\n\ntype OverflowMenuCloser = () => void;\nexport const OverflowMenuContext = createContext<OverflowMenuCloser | null>(null);\n\nconst MessageComposerButtons: React.FC<IProps> = (props: IProps) => {\n    const matrixClient = useContext(MatrixClientContext);\n    const { room, narrow } = useContext(RoomContext);\n\n    const isWysiwygLabEnabled = useSettingValue<boolean>(\"feature_wysiwyg_composer\");\n\n    if (!matrixClient || !room || props.haveRecording) {\n        return null;\n    }\n\n    let mainButtons: ReactNode[];\n    let moreButtons: ReactNode[];\n    if (narrow) {\n        mainButtons = [\n            isWysiwygLabEnabled ? (\n                <ComposerModeButton\n                    key=\"composerModeButton\"\n                    isRichTextEnabled={props.isRichTextEnabled}\n                    onClick={props.onComposerModeClick}\n                />\n            ) : (\n                emojiButton(props)\n            ),\n        ];\n        moreButtons = [\n            uploadButton(), // props passed via UploadButtonContext\n            showStickersButton(props),\n            voiceRecordingButton(props, narrow),\n            startVoiceBroadcastButton(props),\n            props.showPollsButton ? pollButton(room, props.relation) : null,\n            showLocationButton(props, room, matrixClient),\n        ];\n    } else {\n        mainButtons = [\n            isWysiwygLabEnabled ? (\n                <ComposerModeButton\n                    key=\"composerModeButton\"\n                    isRichTextEnabled={props.isRichTextEnabled}\n                    onClick={props.onComposerModeClick}\n                />\n            ) : (\n                emojiButton(props)\n            ),\n            uploadButton(), // props passed via UploadButtonContext\n        ];\n        moreButtons = [\n            showStickersButton(props),\n            voiceRecordingButton(props, narrow),\n            startVoiceBroadcastButton(props),\n            props.showPollsButton ? pollButton(room, props.relation) : null,\n            showLocationButton(props, room, matrixClient),\n        ];\n    }\n\n    mainButtons = filterBoolean(mainButtons);\n    moreButtons = filterBoolean(moreButtons);\n\n    const moreOptionsClasses = classNames({\n        mx_MessageComposer_button: true,\n        mx_MessageComposer_buttonMenu: true,\n        mx_MessageComposer_closeButtonMenu: props.isMenuOpen,\n    });\n\n    return (\n        <UploadButtonContextProvider roomId={room.roomId} relation={props.relation}>\n            {mainButtons}\n            {moreButtons.length > 0 && (\n                <AccessibleButton\n                    className={moreOptionsClasses}\n                    onClick={props.toggleButtonMenu}\n                    title={_t(\"quick_settings|sidebar_settings\")}\n                />\n            )}\n            {props.isMenuOpen && (\n                <IconizedContextMenu\n                    onFinished={props.toggleButtonMenu}\n                    {...props.menuPosition}\n                    wrapperClassName=\"mx_MessageComposer_Menu\"\n                    compact={true}\n                >\n                    <OverflowMenuContext.Provider value={props.toggleButtonMenu}>\n                        <IconizedContextMenuOptionList>{moreButtons}</IconizedContextMenuOptionList>\n                    </OverflowMenuContext.Provider>\n                </IconizedContextMenu>\n            )}\n        </UploadButtonContextProvider>\n    );\n};\n\nfunction emojiButton(props: IProps): ReactElement {\n    return (\n        <EmojiButton\n            key=\"emoji_button\"\n            addEmoji={props.addEmoji}\n            menuPosition={props.menuPosition}\n            className=\"mx_MessageComposer_button\"\n        />\n    );\n}\n\nfunction uploadButton(): ReactElement {\n    return <UploadButton key=\"controls_upload\" />;\n}\n\ntype UploadButtonFn = () => void;\nexport const UploadButtonContext = createContext<UploadButtonFn | null>(null);\n\ninterface IUploadButtonProps {\n    roomId: string;\n    relation?: IEventRelation;\n    children: ReactNode;\n}\n\n// We put the file input outside the UploadButton component so that it doesn't get killed when the context menu closes.\nconst UploadButtonContextProvider: React.FC<IUploadButtonProps> = ({ roomId, relation, children }) => {\n    const cli = useContext(MatrixClientContext);\n    const roomContext = useContext(RoomContext);\n    const uploadInput = useRef<HTMLInputElement>(null);\n\n    const onUploadClick = (): void => {\n        if (cli?.isGuest()) {\n            dis.dispatch({ action: \"require_registration\" });\n            return;\n        }\n        uploadInput.current?.click();\n    };\n\n    useDispatcher(dis, (payload) => {\n        if (roomContext.timelineRenderingType === payload.context && payload.action === \"upload_file\") {\n            onUploadClick();\n        }\n    });\n\n    const onUploadFileInputChange = (ev: React.ChangeEvent<HTMLInputElement>): void => {\n        if (ev.target.files?.length === 0) return;\n\n        // Take a copy, so we can safely reset the value of the form control\n        ContentMessages.sharedInstance().sendContentListToRoom(\n            Array.from(ev.target.files!),\n            roomId,\n            relation,\n            cli,\n            roomContext.timelineRenderingType,\n        );\n\n        // This is the onChange handler for a file form control, but we're\n        // not keeping any state, so reset the value of the form control\n        // to empty.\n        // NB. we need to set 'value': the 'files' property is immutable.\n        ev.target.value = \"\";\n    };\n\n    const uploadInputStyle = { display: \"none\" };\n    return (\n        <UploadButtonContext.Provider value={onUploadClick}>\n            {children}\n\n            <input\n                ref={uploadInput}\n                type=\"file\"\n                style={uploadInputStyle}\n                multiple\n                onClick={chromeFileInputFix}\n                onChange={onUploadFileInputChange}\n            />\n        </UploadButtonContext.Provider>\n    );\n};\n\n// Must be rendered within an UploadButtonContextProvider\nconst UploadButton: React.FC = () => {\n    const overflowMenuCloser = useContext(OverflowMenuContext);\n    const uploadButtonFn = useContext(UploadButtonContext);\n\n    const onClick = (): void => {\n        uploadButtonFn?.();\n        overflowMenuCloser?.(); // close overflow menu\n    };\n\n    return (\n        <CollapsibleButton\n            className=\"mx_MessageComposer_button\"\n            iconClassName=\"mx_MessageComposer_upload\"\n            onClick={onClick}\n            title={_t(\"common|attachment\")}\n        />\n    );\n};\n\nfunction showStickersButton(props: IProps): ReactElement | null {\n    return props.showStickersButton ? (\n        <CollapsibleButton\n            id=\"stickersButton\"\n            key=\"controls_stickers\"\n            className=\"mx_MessageComposer_button\"\n            iconClassName=\"mx_MessageComposer_stickers\"\n            onClick={() => props.setStickerPickerOpen(!props.isStickerPickerOpen)}\n            title={props.isStickerPickerOpen ? _t(\"composer|close_sticker_picker\") : _t(\"common|sticker\")}\n        />\n    ) : null;\n}\n\nconst startVoiceBroadcastButton: React.FC<IProps> = (props: IProps): ReactElement | null => {\n    return props.showVoiceBroadcastButton ? (\n        <CollapsibleButton\n            key=\"start_voice_broadcast\"\n            className=\"mx_MessageComposer_button\"\n            iconClassName=\"mx_MessageComposer_voiceBroadcast\"\n            onClick={props.onStartVoiceBroadcastClick}\n            title={_t(\"voice_broadcast|action\")}\n        />\n    ) : null;\n};\n\nfunction voiceRecordingButton(props: IProps, narrow: boolean): ReactElement | null {\n    // XXX: recording UI does not work well in narrow mode, so hide for now\n    return narrow ? null : (\n        <CollapsibleButton\n            key=\"voice_message_send\"\n            className=\"mx_MessageComposer_button\"\n            iconClassName=\"mx_MessageComposer_voiceMessage\"\n            onClick={props.onRecordStartEndClick}\n            title={_t(\"composer|voice_message_button\")}\n        />\n    );\n}\n\nfunction pollButton(room: Room, relation?: IEventRelation): ReactElement {\n    return <PollButton key=\"polls\" room={room} relation={relation} />;\n}\n\ninterface IPollButtonProps {\n    room: Room;\n    relation?: IEventRelation;\n}\n\nclass PollButton extends React.PureComponent<IPollButtonProps> {\n    public static contextType = OverflowMenuContext;\n    public declare context: React.ContextType<typeof OverflowMenuContext>;\n\n    private onCreateClick = (): void => {\n        this.context?.(); // close overflow menu\n        const canSend = this.props.room.currentState.maySendEvent(\n            M_POLL_START.name,\n            MatrixClientPeg.safeGet().getSafeUserId(),\n        );\n        if (!canSend) {\n            Modal.createDialog(ErrorDialog, {\n                title: _t(\"composer|poll_button_no_perms_title\"),\n                description: _t(\"composer|poll_button_no_perms_description\"),\n            });\n        } else {\n            const threadId =\n                this.props.relation?.rel_type === THREAD_RELATION_TYPE.name ? this.props.relation.event_id : undefined;\n\n            Modal.createDialog(\n                PollCreateDialog,\n                {\n                    room: this.props.room,\n                    threadId,\n                },\n                \"mx_CompoundDialog\",\n                false, // isPriorityModal\n                true, // isStaticModal\n            );\n        }\n    };\n\n    public render(): React.ReactNode {\n        // do not allow sending polls within threads at this time\n        if (this.props.relation?.rel_type === THREAD_RELATION_TYPE.name) return null;\n\n        return (\n            <CollapsibleButton\n                className=\"mx_MessageComposer_button\"\n                iconClassName=\"mx_MessageComposer_poll\"\n                onClick={this.onCreateClick}\n                title={_t(\"composer|poll_button\")}\n            />\n        );\n    }\n}\n\nfunction showLocationButton(props: IProps, room: Room, matrixClient: MatrixClient): ReactElement | null {\n    const sender = room.getMember(matrixClient.getSafeUserId());\n\n    return props.showLocationButton && sender ? (\n        <LocationButton\n            key=\"location\"\n            roomId={room.roomId}\n            relation={props.relation}\n            sender={sender}\n            menuPosition={props.menuPosition}\n        />\n    ) : null;\n}\n\ninterface WysiwygToggleButtonProps {\n    isRichTextEnabled: boolean;\n    onClick: (ev: ButtonEvent) => void;\n}\n\nfunction ComposerModeButton({ isRichTextEnabled, onClick }: WysiwygToggleButtonProps): JSX.Element {\n    const title = isRichTextEnabled ? _t(\"composer|mode_plain\") : _t(\"composer|mode_rich_text\");\n\n    return (\n        <CollapsibleButton\n            className=\"mx_MessageComposer_button\"\n            iconClassName={classNames({\n                mx_MessageComposer_plain_text: !isRichTextEnabled,\n                mx_MessageComposer_rich_text: isRichTextEnabled,\n            })}\n            onClick={onClick}\n            title={title}\n        />\n    );\n}\n\nexport default MessageComposerButtons;\n"],"mappings":";;;;;;;;;AAQA,IAAAA,WAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,MAAA,GAAAC,uBAAA,CAAAH,OAAA;AAEA,IAAAI,gBAAA,GAAAJ,OAAA;AACA,IAAAK,kBAAA,GAAAL,OAAA;AAEA,IAAAM,WAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,YAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,SAAA,GAAAR,OAAA;AACA,IAAAS,MAAA,GAAAV,sBAAA,CAAAC,OAAA;AACA,IAAAU,iBAAA,GAAAX,sBAAA,CAAAC,OAAA;AACA,IAAAW,gBAAA,GAAAX,OAAA;AACA,IAAAY,gBAAA,GAAAb,sBAAA,CAAAC,OAAA;AACA,IAAAa,oBAAA,GAAAd,sBAAA,CAAAC,OAAA;AACA,IAAAc,YAAA,GAAAf,sBAAA,CAAAC,OAAA;AACA,IAAAe,cAAA,GAAAf,OAAA;AACA,IAAAgB,mBAAA,GAAAhB,OAAA;AACA,IAAAiB,oBAAA,GAAAd,uBAAA,CAAAH,OAAA;AACA,IAAAkB,YAAA,GAAAlB,OAAA;AACA,IAAAmB,OAAA,GAAAnB,OAAA;AACA,IAAAoB,YAAA,GAAApB,OAAA;AACA,IAAAqB,iBAAA,GAAAtB,sBAAA,CAAAC,OAAA;AAA6E,SAAAsB,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAApB,wBAAAoB,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AA9B7E;AACA;AACA;AACA;AACA;AACA;AACA;;AA8CO,MAAMW,mBAAmB,GAAAC,OAAA,CAAAD,mBAAA,gBAAG,IAAAE,oBAAa,EAA4B,IAAI,CAAC;AAEjF,MAAMC,sBAAwC,GAAIC,KAAa,IAAK;EAChE,MAAMC,YAAY,GAAG,IAAAC,iBAAU,EAACC,4BAAmB,CAAC;EACpD,MAAM;IAAEC,IAAI;IAAEC;EAAO,CAAC,GAAG,IAAAH,iBAAU,EAACI,oBAAW,CAAC;EAEhD,MAAMC,mBAAmB,GAAG,IAAAC,4BAAe,EAAU,0BAA0B,CAAC;EAEhF,IAAI,CAACP,YAAY,IAAI,CAACG,IAAI,IAAIJ,KAAK,CAACS,aAAa,EAAE;IAC/C,OAAO,IAAI;EACf;EAEA,IAAIC,WAAwB;EAC5B,IAAIC,WAAwB;EAC5B,IAAIN,MAAM,EAAE;IACRK,WAAW,GAAG,CACVH,mBAAmB,gBACfnD,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACC,kBAAkB;MACfC,GAAG,EAAC,oBAAoB;MACxBC,iBAAiB,EAAEf,KAAK,CAACe,iBAAkB;MAC3CC,OAAO,EAAEhB,KAAK,CAACiB;IAAoB,CACtC,CAAC,GAEFC,WAAW,CAAClB,KAAK,CACpB,CACJ;IACDW,WAAW,GAAG,CACVQ,YAAY,CAAC,CAAC;IAAE;IAChBC,kBAAkB,CAACpB,KAAK,CAAC,EACzBqB,oBAAoB,CAACrB,KAAK,EAAEK,MAAM,CAAC,EACnCiB,yBAAyB,CAACtB,KAAK,CAAC,EAChCA,KAAK,CAACuB,eAAe,GAAGC,UAAU,CAACpB,IAAI,EAAEJ,KAAK,CAACyB,QAAQ,CAAC,GAAG,IAAI,EAC/DC,kBAAkB,CAAC1B,KAAK,EAAEI,IAAI,EAAEH,YAAY,CAAC,CAChD;EACL,CAAC,MAAM;IACHS,WAAW,GAAG,CACVH,mBAAmB,gBACfnD,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACC,kBAAkB;MACfC,GAAG,EAAC,oBAAoB;MACxBC,iBAAiB,EAAEf,KAAK,CAACe,iBAAkB;MAC3CC,OAAO,EAAEhB,KAAK,CAACiB;IAAoB,CACtC,CAAC,GAEFC,WAAW,CAAClB,KAAK,CACpB,EACDmB,YAAY,CAAC,CAAC,CAAE;IAAA,CACnB;IACDR,WAAW,GAAG,CACVS,kBAAkB,CAACpB,KAAK,CAAC,EACzBqB,oBAAoB,CAACrB,KAAK,EAAEK,MAAM,CAAC,EACnCiB,yBAAyB,CAACtB,KAAK,CAAC,EAChCA,KAAK,CAACuB,eAAe,GAAGC,UAAU,CAACpB,IAAI,EAAEJ,KAAK,CAACyB,QAAQ,CAAC,GAAG,IAAI,EAC/DC,kBAAkB,CAAC1B,KAAK,EAAEI,IAAI,EAAEH,YAAY,CAAC,CAChD;EACL;EAEAS,WAAW,GAAG,IAAAiB,qBAAa,EAACjB,WAAW,CAAC;EACxCC,WAAW,GAAG,IAAAgB,qBAAa,EAAChB,WAAW,CAAC;EAExC,MAAMiB,kBAAkB,GAAG,IAAAC,mBAAU,EAAC;IAClCC,yBAAyB,EAAE,IAAI;IAC/BC,6BAA6B,EAAE,IAAI;IACnCC,kCAAkC,EAAEhC,KAAK,CAACiC;EAC9C,CAAC,CAAC;EAEF,oBACI7E,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACsB,2BAA2B;IAACC,MAAM,EAAE/B,IAAI,CAAC+B,MAAO;IAACV,QAAQ,EAAEzB,KAAK,CAACyB;EAAS,GACtEf,WAAW,EACXC,WAAW,CAACyB,MAAM,GAAG,CAAC,iBACnBhF,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACrC,iBAAA,CAAAO,OAAgB;IACbuD,SAAS,EAAET,kBAAmB;IAC9BZ,OAAO,EAAEhB,KAAK,CAACsC,gBAAiB;IAChCC,KAAK,EAAE,IAAAC,mBAAE,EAAC,iCAAiC;EAAE,CAChD,CACJ,EACAxC,KAAK,CAACiC,UAAU,iBACb7E,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACzC,oBAAA,CAAAW,OAAmB,MAAA2D,SAAA,CAAA3D,OAAA;IAChB4D,UAAU,EAAE1C,KAAK,CAACsC;EAAiB,GAC/BtC,KAAK,CAAC2C,YAAY;IACtBC,gBAAgB,EAAC,yBAAyB;IAC1CC,OAAO,EAAE;EAAK,iBAEdzF,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAAChB,mBAAmB,CAACkD,QAAQ;IAACC,KAAK,EAAE/C,KAAK,CAACsC;EAAiB,gBACxDlF,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACzC,oBAAA,CAAA6E,6BAA6B,QAAErC,WAA2C,CACjD,CACb,CAEA,CAAC;AAEtC,CAAC;AAED,SAASO,WAAWA,CAAClB,KAAa,EAAgB;EAC9C,oBACI5C,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACxC,YAAA,CAAA6E,WAAW;IACRnC,GAAG,EAAC,cAAc;IAClBoC,QAAQ,EAAElD,KAAK,CAACkD,QAAS;IACzBP,YAAY,EAAE3C,KAAK,CAAC2C,YAAa;IACjCN,SAAS,EAAC;EAA2B,CACxC,CAAC;AAEV;AAEA,SAASlB,YAAYA,CAAA,EAAiB;EAClC,oBAAO/D,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACuC,YAAY;IAACrC,GAAG,EAAC;EAAiB,CAAE,CAAC;AACjD;AAGO,MAAMsC,mBAAmB,GAAAvD,OAAA,CAAAuD,mBAAA,gBAAG,IAAAtD,oBAAa,EAAwB,IAAI,CAAC;AAQ7E;AACA,MAAMoC,2BAAyD,GAAGA,CAAC;EAAEC,MAAM;EAAEV,QAAQ;EAAE4B;AAAS,CAAC,KAAK;EAClG,MAAMC,GAAG,GAAG,IAAApD,iBAAU,EAACC,4BAAmB,CAAC;EAC3C,MAAMoD,WAAW,GAAG,IAAArD,iBAAU,EAACI,oBAAW,CAAC;EAC3C,MAAMkD,WAAW,GAAG,IAAAC,aAAM,EAAmB,IAAI,CAAC;EAElD,MAAMC,aAAa,GAAGA,CAAA,KAAY;IAC9B,IAAIJ,GAAG,EAAEK,OAAO,CAAC,CAAC,EAAE;MAChBC,mBAAG,CAACC,QAAQ,CAAC;QAAEC,MAAM,EAAE;MAAuB,CAAC,CAAC;MAChD;IACJ;IACAN,WAAW,CAACO,OAAO,EAAEC,KAAK,CAAC,CAAC;EAChC,CAAC;EAED,IAAAC,4BAAa,EAACL,mBAAG,EAAGM,OAAO,IAAK;IAC5B,IAAIX,WAAW,CAACY,qBAAqB,KAAKD,OAAO,CAACE,OAAO,IAAIF,OAAO,CAACJ,MAAM,KAAK,aAAa,EAAE;MAC3FJ,aAAa,CAAC,CAAC;IACnB;EACJ,CAAC,CAAC;EAEF,MAAMW,uBAAuB,GAAIC,EAAuC,IAAW;IAC/E,IAAIA,EAAE,CAACC,MAAM,CAACC,KAAK,EAAEpC,MAAM,KAAK,CAAC,EAAE;;IAEnC;IACAqC,wBAAe,CAACC,cAAc,CAAC,CAAC,CAACC,qBAAqB,CAClDC,KAAK,CAACC,IAAI,CAACP,EAAE,CAACC,MAAM,CAACC,KAAM,CAAC,EAC5BrC,MAAM,EACNV,QAAQ,EACR6B,GAAG,EACHC,WAAW,CAACY,qBAChB,CAAC;;IAED;IACA;IACA;IACA;IACAG,EAAE,CAACC,MAAM,CAACxB,KAAK,GAAG,EAAE;EACxB,CAAC;EAED,MAAM+B,gBAAgB,GAAG;IAAEC,OAAO,EAAE;EAAO,CAAC;EAC5C,oBACI3H,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACwC,mBAAmB,CAACN,QAAQ;IAACC,KAAK,EAAEW;EAAc,GAC9CL,QAAQ,eAETjG,MAAA,CAAA0B,OAAA,CAAA8B,aAAA;IACIoE,GAAG,EAAExB,WAAY;IACjByB,IAAI,EAAC,MAAM;IACXC,KAAK,EAAEJ,gBAAiB;IACxBK,QAAQ;IACRnE,OAAO,EAAEoE,sCAAmB;IAC5BC,QAAQ,EAAEhB;EAAwB,CACrC,CACyB,CAAC;AAEvC,CAAC;;AAED;AACA,MAAMlB,YAAsB,GAAGA,CAAA,KAAM;EACjC,MAAMmC,kBAAkB,GAAG,IAAApF,iBAAU,EAACN,mBAAmB,CAAC;EAC1D,MAAM2F,cAAc,GAAG,IAAArF,iBAAU,EAACkD,mBAAmB,CAAC;EAEtD,MAAMpC,OAAO,GAAGA,CAAA,KAAY;IACxBuE,cAAc,GAAG,CAAC;IAClBD,kBAAkB,GAAG,CAAC,CAAC,CAAC;EAC5B,CAAC;EAED,oBACIlI,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACrD,kBAAA,CAAAiI,iBAAiB;IACdnD,SAAS,EAAC,2BAA2B;IACrCoD,aAAa,EAAC,2BAA2B;IACzCzE,OAAO,EAAEA,OAAQ;IACjBuB,KAAK,EAAE,IAAAC,mBAAE,EAAC,mBAAmB;EAAE,CAClC,CAAC;AAEV,CAAC;AAED,SAASpB,kBAAkBA,CAACpB,KAAa,EAAuB;EAC5D,OAAOA,KAAK,CAACoB,kBAAkB,gBAC3BhE,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACrD,kBAAA,CAAAiI,iBAAiB;IACdE,EAAE,EAAC,gBAAgB;IACnB5E,GAAG,EAAC,mBAAmB;IACvBuB,SAAS,EAAC,2BAA2B;IACrCoD,aAAa,EAAC,6BAA6B;IAC3CzE,OAAO,EAAEA,CAAA,KAAMhB,KAAK,CAAC2F,oBAAoB,CAAC,CAAC3F,KAAK,CAAC4F,mBAAmB,CAAE;IACtErD,KAAK,EAAEvC,KAAK,CAAC4F,mBAAmB,GAAG,IAAApD,mBAAE,EAAC,+BAA+B,CAAC,GAAG,IAAAA,mBAAE,EAAC,gBAAgB;EAAE,CACjG,CAAC,GACF,IAAI;AACZ;AAEA,MAAMlB,yBAA2C,GAAItB,KAAa,IAA0B;EACxF,OAAOA,KAAK,CAAC6F,wBAAwB,gBACjCzI,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACrD,kBAAA,CAAAiI,iBAAiB;IACd1E,GAAG,EAAC,uBAAuB;IAC3BuB,SAAS,EAAC,2BAA2B;IACrCoD,aAAa,EAAC,mCAAmC;IACjDzE,OAAO,EAAEhB,KAAK,CAAC8F,0BAA2B;IAC1CvD,KAAK,EAAE,IAAAC,mBAAE,EAAC,wBAAwB;EAAE,CACvC,CAAC,GACF,IAAI;AACZ,CAAC;AAED,SAASnB,oBAAoBA,CAACrB,KAAa,EAAEK,MAAe,EAAuB;EAC/E;EACA,OAAOA,MAAM,GAAG,IAAI,gBAChBjD,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACrD,kBAAA,CAAAiI,iBAAiB;IACd1E,GAAG,EAAC,oBAAoB;IACxBuB,SAAS,EAAC,2BAA2B;IACrCoD,aAAa,EAAC,iCAAiC;IAC/CzE,OAAO,EAAEhB,KAAK,CAAC+F,qBAAsB;IACrCxD,KAAK,EAAE,IAAAC,mBAAE,EAAC,+BAA+B;EAAE,CAC9C,CACJ;AACL;AAEA,SAAShB,UAAUA,CAACpB,IAAU,EAAEqB,QAAyB,EAAgB;EACrE,oBAAOrE,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACoF,UAAU;IAAClF,GAAG,EAAC,OAAO;IAACV,IAAI,EAAEA,IAAK;IAACqB,QAAQ,EAAEA;EAAS,CAAE,CAAC;AACrE;AAOA,MAAMuE,UAAU,SAASC,cAAK,CAACC,aAAa,CAAmB;EAAAC,YAAA,GAAAC,IAAA;IAAA,SAAAA,IAAA;IAAA,IAAAC,gBAAA,CAAAvH,OAAA,yBAInC,MAAY;MAChC,IAAI,CAACsF,OAAO,GAAG,CAAC,CAAC,CAAC;MAClB,MAAMkC,OAAO,GAAG,IAAI,CAACtG,KAAK,CAACI,IAAI,CAACmG,YAAY,CAACC,YAAY,CACrDC,oBAAY,CAACC,IAAI,EACjBC,gCAAe,CAACC,OAAO,CAAC,CAAC,CAACC,aAAa,CAAC,CAC5C,CAAC;MACD,IAAI,CAACP,OAAO,EAAE;QACVQ,cAAK,CAACC,YAAY,CAACC,oBAAW,EAAE;UAC5BzE,KAAK,EAAE,IAAAC,mBAAE,EAAC,qCAAqC,CAAC;UAChDyE,WAAW,EAAE,IAAAzE,mBAAE,EAAC,2CAA2C;QAC/D,CAAC,CAAC;MACN,CAAC,MAAM;QACH,MAAM0E,QAAQ,GACV,IAAI,CAAClH,KAAK,CAACyB,QAAQ,EAAE0F,QAAQ,KAAKC,4BAAoB,CAACV,IAAI,GAAG,IAAI,CAAC1G,KAAK,CAACyB,QAAQ,CAAC4F,QAAQ,GAAGC,SAAS;QAE1GR,cAAK,CAACC,YAAY,CACdQ,yBAAgB,EAChB;UACInH,IAAI,EAAE,IAAI,CAACJ,KAAK,CAACI,IAAI;UACrB8G;QACJ,CAAC,EACD,mBAAmB,EACnB,KAAK;QAAE;QACP,IAAI,CAAE;QACV,CAAC;MACL;IACJ,CAAC;EAAA;EAEMM,MAAMA,CAAA,EAAoB;IAC7B;IACA,IAAI,IAAI,CAACxH,KAAK,CAACyB,QAAQ,EAAE0F,QAAQ,KAAKC,4BAAoB,CAACV,IAAI,EAAE,OAAO,IAAI;IAE5E,oBACItJ,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACrD,kBAAA,CAAAiI,iBAAiB;MACdnD,SAAS,EAAC,2BAA2B;MACrCoD,aAAa,EAAC,yBAAyB;MACvCzE,OAAO,EAAE,IAAI,CAACyG,aAAc;MAC5BlF,KAAK,EAAE,IAAAC,mBAAE,EAAC,sBAAsB;IAAE,CACrC,CAAC;EAEV;AACJ;AAAC,IAAA6D,gBAAA,CAAAvH,OAAA,EA7CKkH,UAAU,iBACgBpG,mBAAmB;AA8CnD,SAAS8B,kBAAkBA,CAAC1B,KAAa,EAAEI,IAAU,EAAEH,YAA0B,EAAuB;EACpG,MAAMyH,MAAM,GAAGtH,IAAI,CAACuH,SAAS,CAAC1H,YAAY,CAAC4G,aAAa,CAAC,CAAC,CAAC;EAE3D,OAAO7G,KAAK,CAAC0B,kBAAkB,IAAIgG,MAAM,gBACrCtK,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAAClD,SAAA,CAAAkK,cAAc;IACX9G,GAAG,EAAC,UAAU;IACdqB,MAAM,EAAE/B,IAAI,CAAC+B,MAAO;IACpBV,QAAQ,EAAEzB,KAAK,CAACyB,QAAS;IACzBiG,MAAM,EAAEA,MAAO;IACf/E,YAAY,EAAE3C,KAAK,CAAC2C;EAAa,CACpC,CAAC,GACF,IAAI;AACZ;AAOA,SAAS9B,kBAAkBA,CAAC;EAAEE,iBAAiB;EAAEC;AAAkC,CAAC,EAAe;EAC/F,MAAMuB,KAAK,GAAGxB,iBAAiB,GAAG,IAAAyB,mBAAE,EAAC,qBAAqB,CAAC,GAAG,IAAAA,mBAAE,EAAC,yBAAyB,CAAC;EAE3F,oBACIpF,MAAA,CAAA0B,OAAA,CAAA8B,aAAA,CAACrD,kBAAA,CAAAiI,iBAAiB;IACdnD,SAAS,EAAC,2BAA2B;IACrCoD,aAAa,EAAE,IAAA5D,mBAAU,EAAC;MACtBgG,6BAA6B,EAAE,CAAC9G,iBAAiB;MACjD+G,4BAA4B,EAAE/G;IAClC,CAAC,CAAE;IACHC,OAAO,EAAEA,OAAQ;IACjBuB,KAAK,EAAEA;EAAM,CAChB,CAAC;AAEV;AAAC,IAAAwF,QAAA,GAAAlI,OAAA,CAAAf,OAAA,GAEciB,sBAAsB","ignoreList":[]}