matrix-react-sdk
Version:
SDK for matrix.org using React
326 lines (320 loc) • 48.5 kB
JavaScript
"use strict";
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 = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _AccessibleButton = _interopRequireDefault(require("./AccessibleButton"));
var _languageHandler = require("../../../languageHandler");
var _KeyBindingsManager = require("../../../KeyBindingsManager");
var _KeyboardShortcuts = require("../../../accessibility/KeyboardShortcuts");
var _objects = require("../../../utils/objects");
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 2017-2021 The Matrix.org Foundation C.I.C.
Copyright 2019 Michael Telatynski <7t3chguy@gmail.com>
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
class MenuOption extends _react.default.Component {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "onMouseEnter", () => {
this.props.onMouseEnter(this.props.dropdownKey);
});
(0, _defineProperty2.default)(this, "onClick", e => {
e.preventDefault();
e.stopPropagation();
this.props.onClick(this.props.dropdownKey);
});
}
render() {
const optClasses = (0, _classnames.default)({
mx_Dropdown_option: true,
mx_Dropdown_option_highlight: this.props.highlighted
});
return /*#__PURE__*/_react.default.createElement("li", {
id: this.props.id,
className: optClasses,
onClick: this.onClick,
onMouseEnter: this.onMouseEnter,
role: "option",
"aria-selected": this.props.highlighted,
ref: this.props.inputRef
}, this.props.children);
}
}
(0, _defineProperty2.default)(MenuOption, "defaultProps", {
disabled: false
});
/*
* Reusable dropdown select control, akin to react-select,
* but somewhat simpler as react-select is 79KB of minified
* javascript.
*/
class Dropdown extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "buttonRef", /*#__PURE__*/(0, _react.createRef)());
(0, _defineProperty2.default)(this, "dropdownRootElement", null);
(0, _defineProperty2.default)(this, "ignoreEvent", null);
(0, _defineProperty2.default)(this, "childrenByKey", {});
(0, _defineProperty2.default)(this, "onDocumentClick", ev => {
// Close the dropdown if the user clicks anywhere that isn't
// within our root element
if (ev !== this.ignoreEvent) {
this.setState({
expanded: false
});
}
});
(0, _defineProperty2.default)(this, "onRootClick", ev => {
// This captures any clicks that happen within our elements,
// such that we can then ignore them when they're seen by the
// click listener on the document handler, ie. not close the
// dropdown immediately after opening it.
// NB. We can't just stopPropagation() because then the event
// doesn't reach the React onClick().
this.ignoreEvent = ev;
});
(0, _defineProperty2.default)(this, "onAccessibleButtonClick", ev => {
if (this.props.disabled) return;
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(ev);
if (!this.state.expanded) {
this.setState({
expanded: true
});
ev.preventDefault();
} else if (action === _KeyboardShortcuts.KeyBindingAction.Enter) {
// the accessible button consumes enter onKeyDown for firing onClick, so handle it here
this.props.onOptionChange(this.state.highlightedOption);
this.close();
} else if (!ev.key) {
// collapse on other non-keyboard event activations
this.setState({
expanded: false
});
ev.preventDefault();
}
});
(0, _defineProperty2.default)(this, "onMenuOptionClick", dropdownKey => {
this.close();
this.props.onOptionChange(dropdownKey);
});
(0, _defineProperty2.default)(this, "onKeyDown", e => {
let handled = true;
// These keys don't generate keypress events and so needs to be on keyup
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(e);
switch (action) {
case _KeyboardShortcuts.KeyBindingAction.Enter:
this.props.onOptionChange(this.state.highlightedOption);
// fallthrough
case _KeyboardShortcuts.KeyBindingAction.Escape:
this.close();
break;
case _KeyboardShortcuts.KeyBindingAction.ArrowDown:
if (this.state.expanded) {
this.setState({
highlightedOption: this.nextOption(this.state.highlightedOption)
});
} else {
this.setState({
expanded: true
});
}
break;
case _KeyboardShortcuts.KeyBindingAction.ArrowUp:
if (this.state.expanded) {
this.setState({
highlightedOption: this.prevOption(this.state.highlightedOption)
});
} else {
this.setState({
expanded: true
});
}
break;
default:
handled = false;
}
if (handled) {
e.preventDefault();
e.stopPropagation();
}
});
(0, _defineProperty2.default)(this, "onInputChange", e => {
this.setState({
searchQuery: e.currentTarget.value
});
if (this.props.onSearchChange) {
this.props.onSearchChange(e.currentTarget.value);
}
});
(0, _defineProperty2.default)(this, "collectRoot", e => {
if (this.dropdownRootElement) {
this.dropdownRootElement.removeEventListener("click", this.onRootClick, false);
}
if (e) {
e.addEventListener("click", this.onRootClick, false);
}
this.dropdownRootElement = e;
});
(0, _defineProperty2.default)(this, "setHighlightedOption", optionKey => {
this.setState({
highlightedOption: optionKey
});
});
this.reindexChildren(this.props.children);
const firstChild = props.children[0];
this.state = {
// True if the menu is dropped-down
expanded: false,
// The key of the highlighted option
// (the option that would become selected if you pressed enter)
highlightedOption: firstChild.key,
// the current search query
searchQuery: ""
};
// Listen for all clicks on the document so we can close the
// menu when the user clicks somewhere else
document.addEventListener("click", this.onDocumentClick, false);
}
componentDidUpdate(prevProps) {
if ((0, _objects.objectHasDiff)(this.props, prevProps) && this.props.children?.length) {
this.reindexChildren(this.props.children);
const firstChild = this.props.children[0];
this.setState({
highlightedOption: firstChild.key
});
}
}
componentWillUnmount() {
document.removeEventListener("click", this.onDocumentClick, false);
}
reindexChildren(children) {
this.childrenByKey = {};
_react.default.Children.forEach(children, child => {
this.childrenByKey[child.key] = child;
});
}
close() {
this.setState({
expanded: false
});
// their focus was on the input, its getting unmounted, move it to the button
if (this.buttonRef.current) {
this.buttonRef.current.focus();
}
}
nextOption(optionKey) {
const keys = Object.keys(this.childrenByKey);
const index = keys.indexOf(optionKey);
return keys[(index + 1) % keys.length];
}
prevOption(optionKey) {
const keys = Object.keys(this.childrenByKey);
const index = keys.indexOf(optionKey);
return keys[index <= 0 ? keys.length - 1 : (index - 1) % keys.length];
}
scrollIntoView(node) {
node?.scrollIntoView({
block: "nearest",
behavior: "auto"
});
}
getMenuOptions() {
const options = _react.default.Children.map(this.props.children, child => {
const highlighted = this.state.highlightedOption === child.key;
return /*#__PURE__*/_react.default.createElement(MenuOption, {
id: `${this.props.id}__${child.key}`,
key: child.key,
dropdownKey: child.key,
highlighted: highlighted,
onMouseEnter: this.setHighlightedOption,
onClick: this.onMenuOptionClick,
inputRef: highlighted ? this.scrollIntoView : undefined
}, child);
});
if (!options?.length) {
return [/*#__PURE__*/_react.default.createElement("li", {
key: "0",
className: "mx_Dropdown_option",
role: "option",
"aria-selected": false
}, (0, _languageHandler._t)("common|no_results"))];
}
return options;
}
render() {
let currentValue;
const menuStyle = {};
if (this.props.menuWidth) menuStyle.width = this.props.menuWidth;
let menu;
if (this.state.expanded) {
if (this.props.searchEnabled) {
currentValue = /*#__PURE__*/_react.default.createElement("input", {
id: `${this.props.id}_input`,
type: "text",
autoFocus: true,
autoComplete: this.props.autoComplete,
className: "mx_Dropdown_option",
onChange: this.onInputChange,
value: this.state.searchQuery,
role: "combobox",
"aria-autocomplete": "list",
"aria-activedescendant": `${this.props.id}__${this.state.highlightedOption}`,
"aria-expanded": this.state.expanded,
"aria-controls": `${this.props.id}_listbox`,
"aria-disabled": this.props.disabled,
"aria-label": this.props.label,
onKeyDown: this.onKeyDown
});
}
menu = /*#__PURE__*/_react.default.createElement("ul", {
className: "mx_Dropdown_menu",
style: menuStyle,
role: "listbox",
id: `${this.props.id}_listbox`
}, this.getMenuOptions());
}
if (!currentValue) {
let selectedChild;
if (this.props.value) {
selectedChild = this.props.getShortOption ? this.props.getShortOption(this.props.value) : this.childrenByKey[this.props.value];
}
currentValue = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_Dropdown_option",
id: `${this.props.id}_value`
}, selectedChild || this.props.placeholder);
}
const dropdownClasses = (0, _classnames.default)("mx_Dropdown", this.props.className, {
mx_Dropdown_disabled: !!this.props.disabled
});
// Note the menu sits inside the AccessibleButton div so it's anchored
// to the input, but overflows below it. The root contains both.
return /*#__PURE__*/_react.default.createElement("div", {
className: dropdownClasses,
ref: this.collectRoot
}, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_Dropdown_input mx_no_textinput",
onClick: this.onAccessibleButtonClick,
"aria-haspopup": "listbox",
"aria-expanded": this.state.expanded,
disabled: this.props.disabled,
ref: this.buttonRef,
"aria-label": this.props.label,
"aria-describedby": `${this.props.id}_value`,
"aria-owns": `${this.props.id}_input`,
onKeyDown: this.onKeyDown
}, currentValue, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_Dropdown_arrow"
}), menu));
}
}
exports.default = Dropdown;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_AccessibleButton","_languageHandler","_KeyBindingsManager","_KeyboardShortcuts","_objects","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MenuOption","React","Component","constructor","args","_defineProperty2","props","onMouseEnter","dropdownKey","preventDefault","stopPropagation","onClick","render","optClasses","classnames","mx_Dropdown_option","mx_Dropdown_option_highlight","highlighted","createElement","id","className","role","ref","inputRef","children","disabled","Dropdown","createRef","ev","ignoreEvent","setState","expanded","action","getKeyBindingsManager","getAccessibilityAction","state","KeyBindingAction","Enter","onOptionChange","highlightedOption","close","key","handled","Escape","ArrowDown","nextOption","ArrowUp","prevOption","searchQuery","currentTarget","value","onSearchChange","dropdownRootElement","removeEventListener","onRootClick","addEventListener","optionKey","reindexChildren","firstChild","document","onDocumentClick","componentDidUpdate","prevProps","objectHasDiff","length","componentWillUnmount","childrenByKey","Children","forEach","child","buttonRef","current","focus","keys","index","indexOf","scrollIntoView","node","block","behavior","getMenuOptions","options","map","setHighlightedOption","onMenuOptionClick","undefined","_t","currentValue","menuStyle","menuWidth","width","menu","searchEnabled","type","autoFocus","autoComplete","onChange","onInputChange","label","onKeyDown","style","selectedChild","getShortOption","placeholder","dropdownClasses","mx_Dropdown_disabled","collectRoot","onAccessibleButtonClick","exports"],"sources":["../../../../src/components/views/elements/Dropdown.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2017-2021 The Matrix.org Foundation C.I.C.\nCopyright 2019 Michael Telatynski <7t3chguy@gmail.com>\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, { ChangeEvent, createRef, CSSProperties, ReactElement, ReactNode, Ref } from \"react\";\nimport classnames from \"classnames\";\n\nimport AccessibleButton, { ButtonEvent } from \"./AccessibleButton\";\nimport { _t } from \"../../../languageHandler\";\nimport { getKeyBindingsManager } from \"../../../KeyBindingsManager\";\nimport { KeyBindingAction } from \"../../../accessibility/KeyboardShortcuts\";\nimport { objectHasDiff } from \"../../../utils/objects\";\nimport { NonEmptyArray } from \"../../../@types/common\";\n\ninterface IMenuOptionProps {\n    children: ReactElement;\n    highlighted?: boolean;\n    dropdownKey: string;\n    id?: string;\n    inputRef?: Ref<HTMLLIElement>;\n    onClick(dropdownKey: string): void;\n    onMouseEnter(dropdownKey: string): void;\n}\n\nclass MenuOption extends React.Component<IMenuOptionProps> {\n    public static defaultProps = {\n        disabled: false,\n    };\n\n    private onMouseEnter = (): void => {\n        this.props.onMouseEnter(this.props.dropdownKey);\n    };\n\n    private onClick = (e: React.MouseEvent): void => {\n        e.preventDefault();\n        e.stopPropagation();\n        this.props.onClick(this.props.dropdownKey);\n    };\n\n    public render(): React.ReactNode {\n        const optClasses = classnames({\n            mx_Dropdown_option: true,\n            mx_Dropdown_option_highlight: this.props.highlighted,\n        });\n\n        return (\n            <li\n                id={this.props.id}\n                className={optClasses}\n                onClick={this.onClick}\n                onMouseEnter={this.onMouseEnter}\n                role=\"option\"\n                aria-selected={this.props.highlighted}\n                ref={this.props.inputRef}\n            >\n                {this.props.children}\n            </li>\n        );\n    }\n}\n\nexport interface DropdownProps {\n    id: string;\n    // ARIA label\n    label: string;\n    value?: string;\n    className?: string;\n    autoComplete?: string;\n    children: NonEmptyArray<ReactElement & { key: string }>;\n    // negative for consistency with HTML\n    disabled?: boolean;\n    // The width that the dropdown should be. If specified,\n    // the dropped-down part of the menu will be set to this\n    // width.\n    menuWidth?: number;\n    searchEnabled?: boolean;\n    // Placeholder to show when no value is selected\n    placeholder?: string;\n    // Called when the selected option changes\n    onOptionChange(dropdownKey: string): void;\n    // Called when the value of the search field changes\n    onSearchChange?(query: string): void;\n    // Function that, given the key of an option, returns\n    // a node representing that option to be displayed in the\n    // box itself as the currently-selected option (ie. as\n    // opposed to in the actual dropped-down part). If\n    // unspecified, the appropriate child element is used as\n    // in the dropped-down menu.\n    getShortOption?(value: string): ReactNode;\n}\n\ninterface IState {\n    expanded: boolean;\n    highlightedOption: string;\n    searchQuery: string;\n}\n\n/*\n * Reusable dropdown select control, akin to react-select,\n * but somewhat simpler as react-select is 79KB of minified\n * javascript.\n */\nexport default class Dropdown extends React.Component<DropdownProps, IState> {\n    private readonly buttonRef = createRef<HTMLDivElement>();\n    private dropdownRootElement: HTMLDivElement | null = null;\n    private ignoreEvent: MouseEvent | null = null;\n    private childrenByKey: Record<string, ReactNode> = {};\n\n    public constructor(props: DropdownProps) {\n        super(props);\n\n        this.reindexChildren(this.props.children);\n\n        const firstChild = props.children[0];\n\n        this.state = {\n            // True if the menu is dropped-down\n            expanded: false,\n            // The key of the highlighted option\n            // (the option that would become selected if you pressed enter)\n            highlightedOption: firstChild.key,\n            // the current search query\n            searchQuery: \"\",\n        };\n\n        // Listen for all clicks on the document so we can close the\n        // menu when the user clicks somewhere else\n        document.addEventListener(\"click\", this.onDocumentClick, false);\n    }\n\n    public componentDidUpdate(prevProps: Readonly<DropdownProps>): void {\n        if (objectHasDiff(this.props, prevProps) && this.props.children?.length) {\n            this.reindexChildren(this.props.children);\n            const firstChild = this.props.children[0];\n            this.setState({\n                highlightedOption: firstChild.key,\n            });\n        }\n    }\n\n    public componentWillUnmount(): void {\n        document.removeEventListener(\"click\", this.onDocumentClick, false);\n    }\n\n    private reindexChildren(children: ReactElement[]): void {\n        this.childrenByKey = {};\n        React.Children.forEach(children, (child) => {\n            this.childrenByKey[(child as DropdownProps[\"children\"][number]).key] = child;\n        });\n    }\n\n    private onDocumentClick = (ev: MouseEvent): void => {\n        // Close the dropdown if the user clicks anywhere that isn't\n        // within our root element\n        if (ev !== this.ignoreEvent) {\n            this.setState({\n                expanded: false,\n            });\n        }\n    };\n\n    private onRootClick = (ev: MouseEvent): void => {\n        // This captures any clicks that happen within our elements,\n        // such that we can then ignore them when they're seen by the\n        // click listener on the document handler, ie. not close the\n        // dropdown immediately after opening it.\n        // NB. We can't just stopPropagation() because then the event\n        // doesn't reach the React onClick().\n        this.ignoreEvent = ev;\n    };\n\n    private onAccessibleButtonClick = (ev: ButtonEvent): void => {\n        if (this.props.disabled) return;\n\n        const action = getKeyBindingsManager().getAccessibilityAction(ev as React.KeyboardEvent);\n\n        if (!this.state.expanded) {\n            this.setState({ expanded: true });\n            ev.preventDefault();\n        } else if (action === KeyBindingAction.Enter) {\n            // the accessible button consumes enter onKeyDown for firing onClick, so handle it here\n            this.props.onOptionChange(this.state.highlightedOption);\n            this.close();\n        } else if (!(ev as React.KeyboardEvent).key) {\n            // collapse on other non-keyboard event activations\n            this.setState({ expanded: false });\n            ev.preventDefault();\n        }\n    };\n\n    private close(): void {\n        this.setState({\n            expanded: false,\n        });\n        // their focus was on the input, its getting unmounted, move it to the button\n        if (this.buttonRef.current) {\n            this.buttonRef.current.focus();\n        }\n    }\n\n    private onMenuOptionClick = (dropdownKey: string): void => {\n        this.close();\n        this.props.onOptionChange(dropdownKey);\n    };\n\n    private onKeyDown = (e: React.KeyboardEvent): void => {\n        let handled = true;\n\n        // These keys don't generate keypress events and so needs to be on keyup\n        const action = getKeyBindingsManager().getAccessibilityAction(e);\n        switch (action) {\n            case KeyBindingAction.Enter:\n                this.props.onOptionChange(this.state.highlightedOption);\n            // fallthrough\n            case KeyBindingAction.Escape:\n                this.close();\n                break;\n            case KeyBindingAction.ArrowDown:\n                if (this.state.expanded) {\n                    this.setState({\n                        highlightedOption: this.nextOption(this.state.highlightedOption),\n                    });\n                } else {\n                    this.setState({ expanded: true });\n                }\n                break;\n            case KeyBindingAction.ArrowUp:\n                if (this.state.expanded) {\n                    this.setState({\n                        highlightedOption: this.prevOption(this.state.highlightedOption),\n                    });\n                } else {\n                    this.setState({ expanded: true });\n                }\n                break;\n            default:\n                handled = false;\n        }\n\n        if (handled) {\n            e.preventDefault();\n            e.stopPropagation();\n        }\n    };\n\n    private onInputChange = (e: ChangeEvent<HTMLInputElement>): void => {\n        this.setState({\n            searchQuery: e.currentTarget.value,\n        });\n        if (this.props.onSearchChange) {\n            this.props.onSearchChange(e.currentTarget.value);\n        }\n    };\n\n    private collectRoot = (e: HTMLDivElement): void => {\n        if (this.dropdownRootElement) {\n            this.dropdownRootElement.removeEventListener(\"click\", this.onRootClick, false);\n        }\n        if (e) {\n            e.addEventListener(\"click\", this.onRootClick, false);\n        }\n        this.dropdownRootElement = e;\n    };\n\n    private setHighlightedOption = (optionKey: string): void => {\n        this.setState({\n            highlightedOption: optionKey,\n        });\n    };\n\n    private nextOption(optionKey: string): string {\n        const keys = Object.keys(this.childrenByKey);\n        const index = keys.indexOf(optionKey);\n        return keys[(index + 1) % keys.length];\n    }\n\n    private prevOption(optionKey: string): string {\n        const keys = Object.keys(this.childrenByKey);\n        const index = keys.indexOf(optionKey);\n        return keys[index <= 0 ? keys.length - 1 : (index - 1) % keys.length];\n    }\n\n    private scrollIntoView(node: Element | null): void {\n        node?.scrollIntoView({\n            block: \"nearest\",\n            behavior: \"auto\",\n        });\n    }\n\n    private getMenuOptions(): JSX.Element[] {\n        const options = React.Children.map(this.props.children, (child: ReactElement) => {\n            const highlighted = this.state.highlightedOption === child.key;\n            return (\n                <MenuOption\n                    id={`${this.props.id}__${child.key}`}\n                    key={child.key}\n                    dropdownKey={child.key as string}\n                    highlighted={highlighted}\n                    onMouseEnter={this.setHighlightedOption}\n                    onClick={this.onMenuOptionClick}\n                    inputRef={highlighted ? this.scrollIntoView : undefined}\n                >\n                    {child}\n                </MenuOption>\n            );\n        });\n        if (!options?.length) {\n            return [\n                <li key=\"0\" className=\"mx_Dropdown_option\" role=\"option\" aria-selected={false}>\n                    {_t(\"common|no_results\")}\n                </li>,\n            ];\n        }\n        return options;\n    }\n\n    public render(): React.ReactNode {\n        let currentValue: JSX.Element | undefined;\n\n        const menuStyle: CSSProperties = {};\n        if (this.props.menuWidth) menuStyle.width = this.props.menuWidth;\n\n        let menu: JSX.Element | undefined;\n        if (this.state.expanded) {\n            if (this.props.searchEnabled) {\n                currentValue = (\n                    <input\n                        id={`${this.props.id}_input`}\n                        type=\"text\"\n                        autoFocus={true}\n                        autoComplete={this.props.autoComplete}\n                        className=\"mx_Dropdown_option\"\n                        onChange={this.onInputChange}\n                        value={this.state.searchQuery}\n                        role=\"combobox\"\n                        aria-autocomplete=\"list\"\n                        aria-activedescendant={`${this.props.id}__${this.state.highlightedOption}`}\n                        aria-expanded={this.state.expanded}\n                        aria-controls={`${this.props.id}_listbox`}\n                        aria-disabled={this.props.disabled}\n                        aria-label={this.props.label}\n                        onKeyDown={this.onKeyDown}\n                    />\n                );\n            }\n            menu = (\n                <ul className=\"mx_Dropdown_menu\" style={menuStyle} role=\"listbox\" id={`${this.props.id}_listbox`}>\n                    {this.getMenuOptions()}\n                </ul>\n            );\n        }\n\n        if (!currentValue) {\n            let selectedChild: ReactNode | undefined;\n            if (this.props.value) {\n                selectedChild = this.props.getShortOption\n                    ? this.props.getShortOption(this.props.value)\n                    : this.childrenByKey[this.props.value];\n            }\n\n            currentValue = (\n                <div className=\"mx_Dropdown_option\" id={`${this.props.id}_value`}>\n                    {selectedChild || this.props.placeholder}\n                </div>\n            );\n        }\n\n        const dropdownClasses = classnames(\"mx_Dropdown\", this.props.className, {\n            mx_Dropdown_disabled: !!this.props.disabled,\n        });\n\n        // Note the menu sits inside the AccessibleButton div so it's anchored\n        // to the input, but overflows below it. The root contains both.\n        return (\n            <div className={dropdownClasses} ref={this.collectRoot}>\n                <AccessibleButton\n                    className=\"mx_Dropdown_input mx_no_textinput\"\n                    onClick={this.onAccessibleButtonClick}\n                    aria-haspopup=\"listbox\"\n                    aria-expanded={this.state.expanded}\n                    disabled={this.props.disabled}\n                    ref={this.buttonRef}\n                    aria-label={this.props.label}\n                    aria-describedby={`${this.props.id}_value`}\n                    aria-owns={`${this.props.id}_input`}\n                    onKeyDown={this.onKeyDown}\n                >\n                    {currentValue}\n                    <span className=\"mx_Dropdown_arrow\" />\n                    {menu}\n                </AccessibleButton>\n            </div>\n        );\n    }\n}\n"],"mappings":";;;;;;;;AASA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AAEA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,gBAAA,GAAAJ,OAAA;AACA,IAAAK,mBAAA,GAAAL,OAAA;AACA,IAAAM,kBAAA,GAAAN,OAAA;AACA,IAAAO,QAAA,GAAAP,OAAA;AAAuD,SAAAQ,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,SAAAV,wBAAAU,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;AAhBvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAsBA,MAAMW,UAAU,SAASC,cAAK,CAACC,SAAS,CAAmB;EAAAC,YAAA,GAAAC,IAAA;IAAA,SAAAA,IAAA;IAAA,IAAAC,gBAAA,CAAAnB,OAAA,wBAKhC,MAAY;MAC/B,IAAI,CAACoB,KAAK,CAACC,YAAY,CAAC,IAAI,CAACD,KAAK,CAACE,WAAW,CAAC;IACnD,CAAC;IAAA,IAAAH,gBAAA,CAAAnB,OAAA,mBAEkBL,CAAmB,IAAW;MAC7CA,CAAC,CAAC4B,cAAc,CAAC,CAAC;MAClB5B,CAAC,CAAC6B,eAAe,CAAC,CAAC;MACnB,IAAI,CAACJ,KAAK,CAACK,OAAO,CAAC,IAAI,CAACL,KAAK,CAACE,WAAW,CAAC;IAC9C,CAAC;EAAA;EAEMI,MAAMA,CAAA,EAAoB;IAC7B,MAAMC,UAAU,GAAG,IAAAC,mBAAU,EAAC;MAC1BC,kBAAkB,EAAE,IAAI;MACxBC,4BAA4B,EAAE,IAAI,CAACV,KAAK,CAACW;IAC7C,CAAC,CAAC;IAEF,oBACI/C,MAAA,CAAAgB,OAAA,CAAAgC,aAAA;MACIC,EAAE,EAAE,IAAI,CAACb,KAAK,CAACa,EAAG;MAClBC,SAAS,EAAEP,UAAW;MACtBF,OAAO,EAAE,IAAI,CAACA,OAAQ;MACtBJ,YAAY,EAAE,IAAI,CAACA,YAAa;MAChCc,IAAI,EAAC,QAAQ;MACb,iBAAe,IAAI,CAACf,KAAK,CAACW,WAAY;MACtCK,GAAG,EAAE,IAAI,CAAChB,KAAK,CAACiB;IAAS,GAExB,IAAI,CAACjB,KAAK,CAACkB,QACZ,CAAC;EAEb;AACJ;AAAC,IAAAnB,gBAAA,CAAAnB,OAAA,EAnCKc,UAAU,kBACiB;EACzByB,QAAQ,EAAE;AACd,CAAC;AAsEL;AACA;AACA;AACA;AACA;AACe,MAAMC,QAAQ,SAASzB,cAAK,CAACC,SAAS,CAAwB;EAMlEC,WAAWA,CAACG,KAAoB,EAAE;IACrC,KAAK,CAACA,KAAK,CAAC;IAAC,IAAAD,gBAAA,CAAAnB,OAAA,kCANY,IAAAyC,gBAAS,EAAiB,CAAC;IAAA,IAAAtB,gBAAA,CAAAnB,OAAA,+BACH,IAAI;IAAA,IAAAmB,gBAAA,CAAAnB,OAAA,uBAChB,IAAI;IAAA,IAAAmB,gBAAA,CAAAnB,OAAA,yBACM,CAAC,CAAC;IAAA,IAAAmB,gBAAA,CAAAnB,OAAA,2BA6C1B0C,EAAc,IAAW;MAChD;MACA;MACA,IAAIA,EAAE,KAAK,IAAI,CAACC,WAAW,EAAE;QACzB,IAAI,CAACC,QAAQ,CAAC;UACVC,QAAQ,EAAE;QACd,CAAC,CAAC;MACN;IACJ,CAAC;IAAA,IAAA1B,gBAAA,CAAAnB,OAAA,uBAEsB0C,EAAc,IAAW;MAC5C;MACA;MACA;MACA;MACA;MACA;MACA,IAAI,CAACC,WAAW,GAAGD,EAAE;IACzB,CAAC;IAAA,IAAAvB,gBAAA,CAAAnB,OAAA,mCAEkC0C,EAAe,IAAW;MACzD,IAAI,IAAI,CAACtB,KAAK,CAACmB,QAAQ,EAAE;MAEzB,MAAMO,MAAM,GAAG,IAAAC,yCAAqB,EAAC,CAAC,CAACC,sBAAsB,CAACN,EAAyB,CAAC;MAExF,IAAI,CAAC,IAAI,CAACO,KAAK,CAACJ,QAAQ,EAAE;QACtB,IAAI,CAACD,QAAQ,CAAC;UAAEC,QAAQ,EAAE;QAAK,CAAC,CAAC;QACjCH,EAAE,CAACnB,cAAc,CAAC,CAAC;MACvB,CAAC,MAAM,IAAIuB,MAAM,KAAKI,mCAAgB,CAACC,KAAK,EAAE;QAC1C;QACA,IAAI,CAAC/B,KAAK,CAACgC,cAAc,CAAC,IAAI,CAACH,KAAK,CAACI,iBAAiB,CAAC;QACvD,IAAI,CAACC,KAAK,CAAC,CAAC;MAChB,CAAC,MAAM,IAAI,CAAEZ,EAAE,CAAyBa,GAAG,EAAE;QACzC;QACA,IAAI,CAACX,QAAQ,CAAC;UAAEC,QAAQ,EAAE;QAAM,CAAC,CAAC;QAClCH,EAAE,CAACnB,cAAc,CAAC,CAAC;MACvB;IACJ,CAAC;IAAA,IAAAJ,gBAAA,CAAAnB,OAAA,6BAY4BsB,WAAmB,IAAW;MACvD,IAAI,CAACgC,KAAK,CAAC,CAAC;MACZ,IAAI,CAAClC,KAAK,CAACgC,cAAc,CAAC9B,WAAW,CAAC;IAC1C,CAAC;IAAA,IAAAH,gBAAA,CAAAnB,OAAA,qBAEoBL,CAAsB,IAAW;MAClD,IAAI6D,OAAO,GAAG,IAAI;;MAElB;MACA,MAAMV,MAAM,GAAG,IAAAC,yCAAqB,EAAC,CAAC,CAACC,sBAAsB,CAACrD,CAAC,CAAC;MAChE,QAAQmD,MAAM;QACV,KAAKI,mCAAgB,CAACC,KAAK;UACvB,IAAI,CAAC/B,KAAK,CAACgC,cAAc,CAAC,IAAI,CAACH,KAAK,CAACI,iBAAiB,CAAC;QAC3D;QACA,KAAKH,mCAAgB,CAACO,MAAM;UACxB,IAAI,CAACH,KAAK,CAAC,CAAC;UACZ;QACJ,KAAKJ,mCAAgB,CAACQ,SAAS;UAC3B,IAAI,IAAI,CAACT,KAAK,CAACJ,QAAQ,EAAE;YACrB,IAAI,CAACD,QAAQ,CAAC;cACVS,iBAAiB,EAAE,IAAI,CAACM,UAAU,CAAC,IAAI,CAACV,KAAK,CAACI,iBAAiB;YACnE,CAAC,CAAC;UACN,CAAC,MAAM;YACH,IAAI,CAACT,QAAQ,CAAC;cAAEC,QAAQ,EAAE;YAAK,CAAC,CAAC;UACrC;UACA;QACJ,KAAKK,mCAAgB,CAACU,OAAO;UACzB,IAAI,IAAI,CAACX,KAAK,CAACJ,QAAQ,EAAE;YACrB,IAAI,CAACD,QAAQ,CAAC;cACVS,iBAAiB,EAAE,IAAI,CAACQ,UAAU,CAAC,IAAI,CAACZ,KAAK,CAACI,iBAAiB;YACnE,CAAC,CAAC;UACN,CAAC,MAAM;YACH,IAAI,CAACT,QAAQ,CAAC;cAAEC,QAAQ,EAAE;YAAK,CAAC,CAAC;UACrC;UACA;QACJ;UACIW,OAAO,GAAG,KAAK;MACvB;MAEA,IAAIA,OAAO,EAAE;QACT7D,CAAC,CAAC4B,cAAc,CAAC,CAAC;QAClB5B,CAAC,CAAC6B,eAAe,CAAC,CAAC;MACvB;IACJ,CAAC;IAAA,IAAAL,gBAAA,CAAAnB,OAAA,yBAEwBL,CAAgC,IAAW;MAChE,IAAI,CAACiD,QAAQ,CAAC;QACVkB,WAAW,EAAEnE,CAAC,CAACoE,aAAa,CAACC;MACjC,CAAC,CAAC;MACF,IAAI,IAAI,CAAC5C,KAAK,CAAC6C,cAAc,EAAE;QAC3B,IAAI,CAAC7C,KAAK,CAAC6C,cAAc,CAACtE,CAAC,CAACoE,aAAa,CAACC,KAAK,CAAC;MACpD;IACJ,CAAC;IAAA,IAAA7C,gBAAA,CAAAnB,OAAA,uBAEsBL,CAAiB,IAAW;MAC/C,IAAI,IAAI,CAACuE,mBAAmB,EAAE;QAC1B,IAAI,CAACA,mBAAmB,CAACC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAACC,WAAW,EAAE,KAAK,CAAC;MAClF;MACA,IAAIzE,CAAC,EAAE;QACHA,CAAC,CAAC0E,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAACD,WAAW,EAAE,KAAK,CAAC;MACxD;MACA,IAAI,CAACF,mBAAmB,GAAGvE,CAAC;IAChC,CAAC;IAAA,IAAAwB,gBAAA,CAAAnB,OAAA,gCAE+BsE,SAAiB,IAAW;MACxD,IAAI,CAAC1B,QAAQ,CAAC;QACVS,iBAAiB,EAAEiB;MACvB,CAAC,CAAC;IACN,CAAC;IA7JG,IAAI,CAACC,eAAe,CAAC,IAAI,CAACnD,KAAK,CAACkB,QAAQ,CAAC;IAEzC,MAAMkC,UAAU,GAAGpD,KAAK,CAACkB,QAAQ,CAAC,CAAC,CAAC;IAEpC,IAAI,CAACW,KAAK,GAAG;MACT;MACAJ,QAAQ,EAAE,KAAK;MACf;MACA;MACAQ,iBAAiB,EAAEmB,UAAU,CAACjB,GAAG;MACjC;MACAO,WAAW,EAAE;IACjB,CAAC;;IAED;IACA;IACAW,QAAQ,CAACJ,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAACK,eAAe,EAAE,KAAK,CAAC;EACnE;EAEOC,kBAAkBA,CAACC,SAAkC,EAAQ;IAChE,IAAI,IAAAC,sBAAa,EAAC,IAAI,CAACzD,KAAK,EAAEwD,SAAS,CAAC,IAAI,IAAI,CAACxD,KAAK,CAACkB,QAAQ,EAAEwC,MAAM,EAAE;MACrE,IAAI,CAACP,eAAe,CAAC,IAAI,CAACnD,KAAK,CAACkB,QAAQ,CAAC;MACzC,MAAMkC,UAAU,GAAG,IAAI,CAACpD,KAAK,CAACkB,QAAQ,CAAC,CAAC,CAAC;MACzC,IAAI,CAACM,QAAQ,CAAC;QACVS,iBAAiB,EAAEmB,UAAU,CAACjB;MAClC,CAAC,CAAC;IACN;EACJ;EAEOwB,oBAAoBA,CAAA,EAAS;IAChCN,QAAQ,CAACN,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAACO,eAAe,EAAE,KAAK,CAAC;EACtE;EAEQH,eAAeA,CAACjC,QAAwB,EAAQ;IACpD,IAAI,CAAC0C,aAAa,GAAG,CAAC,CAAC;IACvBjE,cAAK,CAACkE,QAAQ,CAACC,OAAO,CAAC5C,QAAQ,EAAG6C,KAAK,IAAK;MACxC,IAAI,CAACH,aAAa,CAAEG,KAAK,CAAuC5B,GAAG,CAAC,GAAG4B,KAAK;IAChF,CAAC,CAAC;EACN;EAyCQ7B,KAAKA,CAAA,EAAS;IAClB,IAAI,CAACV,QAAQ,CAAC;MACVC,QAAQ,EAAE;IACd,CAAC,CAAC;IACF;IACA,IAAI,IAAI,CAACuC,SAAS,CAACC,OAAO,EAAE;MACxB,IAAI,CAACD,SAAS,CAACC,OAAO,CAACC,KAAK,CAAC,CAAC;IAClC;EACJ;EAwEQ3B,UAAUA,CAACW,SAAiB,EAAU;IAC1C,MAAMiB,IAAI,GAAGjF,MAAM,CAACiF,IAAI,CAAC,IAAI,CAACP,aAAa,CAAC;IAC5C,MAAMQ,KAAK,GAAGD,IAAI,CAACE,OAAO,CAACnB,SAAS,CAAC;IACrC,OAAOiB,IAAI,CAAC,CAACC,KAAK,GAAG,CAAC,IAAID,IAAI,CAACT,MAAM,CAAC;EAC1C;EAEQjB,UAAUA,CAACS,SAAiB,EAAU;IAC1C,MAAMiB,IAAI,GAAGjF,MAAM,CAACiF,IAAI,CAAC,IAAI,CAACP,aAAa,CAAC;IAC5C,MAAMQ,KAAK,GAAGD,IAAI,CAACE,OAAO,CAACnB,SAAS,CAAC;IACrC,OAAOiB,IAAI,CAACC,KAAK,IAAI,CAAC,GAAGD,IAAI,CAACT,MAAM,GAAG,CAAC,GAAG,CAACU,KAAK,GAAG,CAAC,IAAID,IAAI,CAACT,MAAM,CAAC;EACzE;EAEQY,cAAcA,CAACC,IAAoB,EAAQ;IAC/CA,IAAI,EAAED,cAAc,CAAC;MACjBE,KAAK,EAAE,SAAS;MAChBC,QAAQ,EAAE;IACd,CAAC,CAAC;EACN;EAEQC,cAAcA,CAAA,EAAkB;IACpC,MAAMC,OAAO,GAAGhF,cAAK,CAACkE,QAAQ,CAACe,GAAG,CAAC,IAAI,CAAC5E,KAAK,CAACkB,QAAQ,EAAG6C,KAAmB,IAAK;MAC7E,MAAMpD,WAAW,GAAG,IAAI,CAACkB,KAAK,CAACI,iBAAiB,KAAK8B,KAAK,CAAC5B,GAAG;MAC9D,oBACIvE,MAAA,CAAAgB,OAAA,CAAAgC,aAAA,CAAClB,UAAU;QACPmB,EAAE,EAAE,GAAG,IAAI,CAACb,KAAK,CAACa,EAAE,KAAKkD,KAAK,CAAC5B,GAAG,EAAG;QACrCA,GAAG,EAAE4B,KAAK,CAAC5B,GAAI;QACfjC,WAAW,EAAE6D,KAAK,CAAC5B,GAAc;QACjCxB,WAAW,EAAEA,WAAY;QACzBV,YAAY,EAAE,IAAI,CAAC4E,oBAAqB;QACxCxE,OAAO,EAAE,IAAI,CAACyE,iBAAkB;QAChC7D,QAAQ,EAAEN,WAAW,GAAG,IAAI,CAAC2D,cAAc,GAAGS;MAAU,GAEvDhB,KACO,CAAC;IAErB,CAAC,CAAC;IACF,IAAI,CAACY,OAAO,EAAEjB,MAAM,EAAE;MAClB,OAAO,cACH9F,MAAA,CAAAgB,OAAA,CAAAgC,aAAA;QAAIuB,GAAG,EAAC,GAAG;QAACrB,SAAS,EAAC,oBAAoB;QAACC,IAAI,EAAC,QAAQ;QAAC,iBAAe;MAAM,GACzE,IAAAiE,mBAAE,EAAC,mBAAmB,CACvB,CAAC,CACR;IACL;IACA,OAAOL,OAAO;EAClB;EAEOrE,MAAMA,CAAA,EAAoB;IAC7B,IAAI2E,YAAqC;IAEzC,MAAMC,SAAwB,GAAG,CAAC,CAAC;IACnC,IAAI,IAAI,CAAClF,KAAK,CAACmF,SAAS,EAAED,SAAS,CAACE,KAAK,GAAG,IAAI,CAACpF,KAAK,CAACmF,SAAS;IAEhE,IAAIE,IAA6B;IACjC,IAAI,IAAI,CAACxD,KAAK,CAACJ,QAAQ,EAAE;MACrB,IAAI,IAAI,CAACzB,KAAK,CAACsF,aAAa,EAAE;QAC1BL,YAAY,gBACRrH,MAAA,CAAAgB,OAAA,CAAAgC,aAAA;UACIC,EAAE,EAAE,GAAG,IAAI,CAACb,KAAK,CAACa,EAAE,QAAS;UAC7B0E,IAAI,EAAC,MAAM;UACXC,SAAS,EAAE,IAAK;UAChBC,YAAY,EAAE,IAAI,CAACzF,KAAK,CAACyF,YAAa;UACtC3E,SAAS,EAAC,oBAAoB;UAC9B4E,QAAQ,EAAE,IAAI,CAACC,aAAc;UAC7B/C,KAAK,EAAE,IAAI,CAACf,KAAK,CAACa,WAAY;UAC9B3B,IAAI,EAAC,UAAU;UACf,qBAAkB,MAAM;UACxB,yBAAuB,GAAG,IAAI,CAACf,KAAK,CAACa,EAAE,KAAK,IAAI,CAACgB,KAAK,CAACI,iBAAiB,EAAG;UAC3E,iBAAe,IAAI,CAACJ,KAAK,CAACJ,QAAS;UACnC,iBAAe,GAAG,IAAI,CAACzB,KAAK,CAACa,EAAE,UAAW;UAC1C,iBAAe,IAAI,CAACb,KAAK,CAACmB,QAAS;UACnC,cAAY,IAAI,CAACnB,KAAK,CAAC4F,KAAM;UAC7BC,SAAS,EAAE,IAAI,CAACA;QAAU,CAC7B,CACJ;MACL;MACAR,IAAI,gBACAzH,MAAA,CAAAgB,OAAA,CAAAgC,aAAA;QAAIE,SAAS,EAAC,kBAAkB;QAACgF,KAAK,EAAEZ,SAAU;QAACnE,IAAI,EAAC,SAAS;QAACF,EAAE,EAAE,GAAG,IAAI,CAACb,KAAK,CAACa,EAAE;MAAW,GAC5F,IAAI,CAAC6D,cAAc,CAAC,CACrB,CACP;IACL;IAEA,IAAI,CAACO,YAAY,EAAE;MACf,IAAIc,aAAoC;MACxC,IAAI,IAAI,CAAC/F,KAAK,CAAC4C,KAAK,EAAE;QAClBmD,aAAa,GAAG,IAAI,CAAC/F,KAAK,CAACgG,cAAc,GACnC,IAAI,CAAChG,KAAK,CAACgG,cAAc,CAAC,IAAI,CAAChG,KAAK,CAAC4C,KAAK,CAAC,GAC3C,IAAI,CAACgB,aAAa,CAAC,IAAI,CAAC5D,KAAK,CAAC4C,KAAK,CAAC;MAC9C;MAEAqC,YAAY,gBACRrH,MAAA,CAAAgB,OAAA,CAAAgC,aAAA;QAAKE,SAAS,EAAC,oBAAoB;QAACD,EAAE,EAAE,GAAG,IAAI,CAACb,KAAK,CAACa,EAAE;MAAS,GAC5DkF,aAAa,IAAI,IAAI,CAAC/F,KAAK,CAACiG,WAC5B,CACR;IACL;IAEA,MAAMC,eAAe,GAAG,IAAA1F,mBAAU,EAAC,aAAa,EAAE,IAAI,CAACR,KAAK,CAACc,SAAS,EAAE;MACpEqF,oBAAoB,EAAE,CAAC,CAAC,IAAI,CAACnG,KAAK,CAACmB;IACvC,CAAC,CAAC;;IAEF;IACA;IACA,oBACIvD,MAAA,CAAAgB,OAAA,CAAAgC,aAAA;MAAKE,SAAS,EAAEoF,eAAgB;MAAClF,GAAG,EAAE,IAAI,CAACoF;IAAY,gBACnDxI,MAAA,CAAAgB,OAAA,CAAAgC,aAAA,CAAC3C,iBAAA,CAAAW,OAAgB;MACbkC,SAAS,EAAC,mCAAmC;MAC7CT,OAAO,EAAE,IAAI,CAACgG,uBAAwB;MACtC,iBAAc,SAAS;MACvB,iBAAe,IAAI,CAACxE,KAAK,CAACJ,QAAS;MACnCN,QAAQ,EAAE,IAAI,CAACnB,KAAK,CAACmB,QAAS;MAC9BH,GAAG,EAAE,IAAI,CAACgD,SAAU;MACpB,cAAY,IAAI,CAAChE,KAAK,CAAC4F,KAAM;MAC7B,oBAAkB,GAAG,IAAI,CAAC5F,KAAK,CAACa,EAAE,QAAS;MAC3C,aAAW,GAAG,IAAI,CAACb,KAAK,CAACa,EAAE,QAAS;MACpCgF,SAAS,EAAE,IAAI,CAACA;IAAU,GAEzBZ,YAAY,eACbrH,MAAA,CAAAgB,OAAA,CAAAgC,aAAA;MAAME,SAAS,EAAC;IAAmB,CAAE,CAAC,EACrCuE,IACa,CACjB,CAAC;EAEd;AACJ;AAACiB,OAAA,CAAA1H,OAAA,GAAAwC,QAAA","ignoreList":[]}