@andreyfedkovich/cozy-ui 0.1.0 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ui-library.es.js","sources":["../src/lib/icons/home.svg?react","../src/lib/icons/clock.svg?react","../src/lib/icons/fileReload.svg?react","../src/lib/icons/folderEdit.svg?react","../src/lib/icons/graduate.svg?react","../src/lib/icons/grid.svg?react","../src/lib/icons/heart.svg?react","../src/lib/icons/help.svg?react","../src/lib/icons/list.svg?react","../src/lib/icons/market.svg?react","../src/lib/icons/plane.svg?react","../src/lib/icons/profile.svg?react","../src/lib/icons/profileSearch.svg?react","../src/lib/icons/trendUp.svg?react","../src/lib/icons/wallet.svg?react","../src/lib/icons/timesheet.svg?react","../src/lib/icons/notebook.svg?react","../src/lib/icons/chart.svg?react","../src/lib/icons/feedback.svg?react","../src/lib/icons/taskList.svg?react","../src/lib/icons/megaphone.svg?react","../src/lib/icons/userSwitch.svg?react","../src/lib/icons/fileSync.svg?react","../src/lib/icons/chat.svg?react","../src/lib/icons/search.svg?react","../src/lib/icons/arrowRight.svg?react","../src/lib/icons/arrowDown.svg?react","../src/lib/icons/arrowDownBlue.svg?react","../src/lib/icons/cross.svg?react","../src/lib/icons/closeRed.svg?react","../src/lib/icons/checkGreen.svg?react","../src/lib/icons/historyBlue.svg?react","../src/lib/icons/done.svg?react","../src/lib/icons/cancel.svg?react","../src/lib/icons/warn.svg?react","../src/lib/icons/envelop.svg?react","../src/lib/icons/message.svg?react","../src/lib/icons/phone.svg?react","../src/lib/icons/camera.svg?react","../src/lib/icons/copy.svg?react","../src/lib/icons/info.svg?react","../src/lib/icons/filter.svg?react","../src/lib/icons/edit.svg?react","../src/lib/icons/reload.svg?react","../src/lib/icons/clockFilled.svg?react","../src/lib/icons/empty.svg?react","../src/lib/icons/settings.svg?react","../src/lib/icons/school.svg?react","../src/lib/icons/island.svg?react","../src/lib/icons/download.svg?react","../src/lib/styles/colors.ts","../node_modules/classnames/index.js","../src/lib/components/BaseBlock/BaseBlock.tsx","../node_modules/@radix-ui/react-compose-refs/dist/index.mjs","../node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/clsx/dist/clsx.mjs","../node_modules/class-variance-authority/dist/index.mjs","../node_modules/tailwind-merge/dist/bundle-mjs.mjs","../src/lib/utils.ts","../src/components/ui/button.tsx","../src/lib/components/Spinner/Spinner.tsx","../src/lib/components/Button/Button.tsx","../src/lib/helpers/hooks/useMeasureElement.ts","../src/lib/helpers/hooks/useDropdownPosition.ts","../src/lib/components/RadioGroupButton/RadioGroupButton.tsx","../src/lib/components/Card/Card.tsx","../src/lib/components/Carousel/Carousel.tsx","../src/lib/components/TooltipDark/getTooltipPosition.ts","../src/lib/components/TooltipDark/Tooltip.tsx","../src/lib/components/CopyTextTrigger/CopyTextTrigger.tsx","../src/components/ui/portal-body.tsx","../node_modules/@radix-ui/primitive/dist/index.mjs","../node_modules/@radix-ui/react-context/dist/index.mjs","../node_modules/@radix-ui/react-primitive/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/@radix-ui/react-use-callback-ref/dist/index.mjs","../node_modules/@radix-ui/react-use-escape-keydown/dist/index.mjs","../node_modules/@radix-ui/react-dismissable-layer/dist/index.mjs","../node_modules/@radix-ui/react-use-layout-effect/dist/index.mjs","../node_modules/@radix-ui/react-id/dist/index.mjs","../node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs","../node_modules/@floating-ui/core/dist/floating-ui.core.mjs","../node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs","../node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.mjs","../node_modules/@radix-ui/react-arrow/dist/index.mjs","../node_modules/@radix-ui/react-use-size/dist/index.mjs","../node_modules/@radix-ui/react-popper/dist/index.mjs","../node_modules/@radix-ui/react-portal/dist/index.mjs","../node_modules/@radix-ui/react-presence/dist/index.mjs","../node_modules/@radix-ui/react-tooltip/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-use-controllable-state/dist/index.mjs","../node_modules/@radix-ui/react-visually-hidden/dist/index.mjs","../node_modules/@radix-ui/react-tooltip/dist/index.mjs","../src/components/ui/tooltip.tsx","../src/lib/components/TooltipLight/TooltipLight.tsx","../node_modules/@radix-ui/react-focus-guards/dist/index.mjs","../node_modules/@radix-ui/react-focus-scope/dist/index.mjs","../node_modules/@radix-ui/react-popover/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/aria-hidden/dist/es2015/index.js","../node_modules/tslib/tslib.es6.mjs","../node_modules/react-remove-scroll-bar/dist/es2015/constants.js","../node_modules/use-callback-ref/dist/es2015/assignRef.js","../node_modules/use-callback-ref/dist/es2015/useRef.js","../node_modules/use-callback-ref/dist/es2015/useMergeRef.js","../node_modules/use-sidecar/dist/es2015/medium.js","../node_modules/use-sidecar/dist/es2015/exports.js","../node_modules/react-remove-scroll/dist/es2015/medium.js","../node_modules/react-remove-scroll/dist/es2015/UI.js","../node_modules/get-nonce/dist/es2015/index.js","../node_modules/react-style-singleton/dist/es2015/singleton.js","../node_modules/react-style-singleton/dist/es2015/hook.js","../node_modules/react-style-singleton/dist/es2015/component.js","../node_modules/react-remove-scroll-bar/dist/es2015/utils.js","../node_modules/react-remove-scroll-bar/dist/es2015/component.js","../node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js","../node_modules/react-remove-scroll/dist/es2015/handleScroll.js","../node_modules/react-remove-scroll/dist/es2015/SideEffect.js","../node_modules/react-remove-scroll/dist/es2015/sidecar.js","../node_modules/react-remove-scroll/dist/es2015/Combination.js","../node_modules/@radix-ui/react-popover/dist/index.mjs","../src/components/ui/popover.tsx","../src/lib/components/Popover/Popover.tsx","../src/lib/components/EmptyComponent/EmptyComponent.tsx","../src/lib/components/Collapse/Collapse.tsx","../src/lib/components/CollapsibleBlock/CollapsableBlock.tsx","../node_modules/@floating-ui/react/dist/floating-ui.react.utils.mjs","../node_modules/@floating-ui/react/dist/floating-ui.react.mjs","../src/lib/components/InputCaption/InputCaption.tsx","../node_modules/@radix-ui/react-label/node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/@radix-ui/react-label/dist/index.mjs","../src/components/ui/label.tsx","../src/lib/components/Label/Label.tsx","../src/lib/components/Tag/Tag.tsx","../src/lib/components/Select/Select.tsx","../node_modules/@radix-ui/react-dialog/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-dialog/dist/index.mjs","../src/components/ui/dialog.tsx","../src/lib/components/DialogSelect/DialogSelect.tsx","../src/lib/components/TreeDialogSelect/TreeDialogSelect.tsx","../src/lib/components/TabsRounded/TabsRounded.tsx","../src/lib/components/Stepper/Stepper.tsx","../src/lib/components/Tabs/Tabs.tsx","../src/lib/components/ApprovalRoute/ApprovalRoute.tsx"],"sourcesContent":["import * as React from \"react\";\nconst SvgHome = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 17, height: 17, viewBox: \"0 0 17 17\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M0.5 8.50634L8.5 0.5L16.5 8.49975\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.5 6.58643V16.4994H14.5V6.56641\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.5 16.4998V10.5H10.5\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }));\nexport default SvgHome;\n","import * as React from \"react\";\nconst SvgClock = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { fillRule: \"evenodd\", clipRule: \"evenodd\", d: \"M8.09237 4.75028C8.31363 4.75028 8.49345 4.92792 8.49345 5.1465V8.80763C8.49345 9.02622 8.31363 9.2032 8.09237 9.2032H5.6565C5.43524 9.2032 5.2561 9.02622 5.2561 8.80763C5.2561 8.58839 5.43524 8.41141 5.6565 8.41141H7.6913V5.1465C7.6913 4.92792 7.87111 4.75028 8.09237 4.75028ZM1 8C1 11.8599 4.17853 15 8.08502 15C11.4053 15 14.2442 12.7712 14.9895 9.58028C15.0397 9.36763 14.9047 9.155 14.6887 9.10547C14.4775 9.05859 14.2582 9.18933 14.2074 9.40264C13.547 12.2317 11.0296 14.2075 8.08502 14.2075C4.62038 14.2075 1.80149 11.4227 1.80149 8C1.80149 4.5766 4.62038 1.79245 8.08502 1.79245C10.5296 1.79245 12.7502 3.20962 13.7756 5.36839H11.3912C11.17 5.36839 10.9901 5.54537 10.9901 5.76396C10.9901 5.98254 11.17 6.16019 11.3912 6.16019H14.424C14.6453 6.16019 14.8244 5.98254 14.8244 5.76396V2.76849C14.8244 2.54991 14.6453 2.37226 14.424 2.37226C14.2028 2.37226 14.023 2.54991 14.023 2.76849V4.18236C12.7335 2.23226 10.5062 1 8.08502 1C4.17853 1 1 4.14009 1 8Z\", fill: \"currentColor\" }));\nexport default SvgClock;\n","import * as React from \"react\";\nconst SvgFileReload = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"g\", { clipPath: \"url(#clip0_27648_5774)\" }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.24567 14.0242H0.666672V0.666992H6.60323L10.5609 4.6247V9.57183\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.60417 0.666992V4.6247H10.5619\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.638 12.54L13.8254 13.7405L15.0127 12.54\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.07781 12.5403L7.89047 11.3398L6.70312 12.5403\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.2564 15.1521C11.7 15.4559 11.0599 15.5703 10.4328 15.4781C9.80562 15.3859 9.22551 15.092 8.78019 14.6409C8.38611 14.2414 8.11251 13.7391 7.99061 13.1914C7.8687 12.6437 7.90348 12.0728 8.09094 11.5439\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.45833 9.9274C10.0147 9.62358 10.6548 9.50915 11.2819 9.60138C11.9091 9.69361 12.4892 9.9875 12.9345 10.4386C13.3288 10.8379 13.6028 11.34 13.7252 11.8877C13.8477 12.4353 13.8138 13.0063 13.6272 13.5355\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" })), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"clipPath\", { id: \"clip0_27648_5774\" }, /* @__PURE__ */ React.createElement(\"rect\", { width: 16, height: 16, fill: \"white\" }))));\nexport default SvgFileReload;\n","import * as React from \"react\";\nconst SvgFolderEdit = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"g\", { clipPath: \"url(#clip0_27648_5680)\" }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.9999 6.31067V3.52381H5.79479V2H0.666595V12.2264C0.666595 12.3432 0.713287 12.4551 0.796637 12.5377C0.879986 12.6202 0.993098 12.6666 1.11097 12.6666H8.35888\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.2521 6L9.0879 11.1766L8 14L10.8358 12.9333L16 7.75667L14.2521 6Z\", stroke: \"currentColor\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.33339 11.333L10.6667 12.6663\", stroke: \"currentColor\", strokeLinejoin: \"round\" })), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"clipPath\", { id: \"clip0_27648_5680\" }, /* @__PURE__ */ React.createElement(\"rect\", { width: 16, height: 16, fill: \"white\" }))));\nexport default SvgFolderEdit;\n","import * as React from \"react\";\nconst SvgGraduate = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.05584 2.58008V5.33656C4.3465 5.33656 4.28125 6.22012 4.28125 6.4379C4.28125 6.65568 4.44608 7.68235 5.15853 7.68235C5.39614 8.66258 5.9937 9.51765 6.83242 10.0779\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.6302 10.0628C10.4691 9.50283 11.0666 8.64767 11.3039 7.66731C12.0102 7.66731 12.1751 6.65932 12.1751 6.43843C12.1751 6.21754 12.2964 5.34953 11.5933 5.33709V2.62109\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.37643 9.79102V10.4669C6.37643 10.9336 6.60665 11.6118 4.04309 12.1003C1.33332 12.6167 1.33333 14.6669 1.33333 14.6669H15.3333C15.3333 14.6669 15.3334 12.6603 12.4338 12.1003C9.94494 11.618 10.1005 10.9336 10.1005 10.4669V9.79102\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.59114 11.9824L8.32766 14.6673L12.061 12.0228\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.3282 3.00033L1.79167 1.60033L8.3282 0.666992L14.8615 1.60033L8.3282 3.00033Z\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.05725 3.93359L8.32711 4.40026L11.5938 3.93359\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.25781 1.69336V7.20001\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }));\nexport default SvgGraduate;\n","import * as React from \"react\";\nconst SvgGrid = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.9329 14H2V9.06713H6.9329V14Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.9329 6.60059H2V1.66765H6.9329V6.60059Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.3343 14H9.40144V9.06713H14.3343V14Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.3343 6.60059H9.40144V1.66765H14.3343V6.60059Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }));\nexport default SvgGrid;\n","import * as React from \"react\";\nconst SvgHeart = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"g\", { clipPath: \"url(#clip0_27648_5733)\" }, /* @__PURE__ */ React.createElement(\"path\", { fillRule: \"evenodd\", clipRule: \"evenodd\", d: \"M15.2984 6.64286C15.2984 10.7453 8.14844 15 8.14844 15C8.14844 15 0.998444 10.7453 0.998444 6.64286C0.998444 6.53654 0.998444 6.2315 0.998444 6.17857C0.998444 3.87061 2.7989 2 5.02032 2C6.28408 2 7.4111 2.60682 8.14755 3.55396C8.88489 2.60682 10.0124 2 11.2766 2C13.498 2 15.2984 3.87061 15.2984 6.17857C15.2984 6.23104 15.2984 6.53607 15.2984 6.64286Z\", stroke: \"currentColor\" })), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"clipPath\", { id: \"clip0_27648_5733\" }, /* @__PURE__ */ React.createElement(\"rect\", { width: 16, height: 16, fill: \"white\" }))));\nexport default SvgHeart;\n","import * as React from \"react\";\nconst SvgHelp = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"g\", { clipPath: \"url(#clip0_27648_5852)\" }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.81389 5.81154C4.79445 6.087 5.00199 6.32606 5.27745 6.3455C5.55291 6.36494 5.79197 6.1574 5.81141 5.88194L5.31265 5.84674L4.81389 5.81154ZM10.6346 4.74381L11.1154 4.6067V4.6067L10.6346 4.74381ZM8.27563 9.0822L7.96537 8.69011L8.27563 9.0822ZM7.09347 11.3614C7.09347 11.6376 7.31733 11.8614 7.59347 11.8614C7.86961 11.8614 8.09347 11.6376 8.09347 11.3614H7.59347H7.09347ZM5.31265 5.84674L5.81141 5.88194C5.90808 4.51228 6.8506 3.80991 7.87427 3.67837C8.94608 3.54065 9.91206 4.03342 10.1537 4.88092L10.6346 4.74381L11.1154 4.6067C10.6897 3.114 9.11102 2.51123 7.74682 2.68653C6.33448 2.868 4.94971 3.88719 4.81389 5.81154L5.31265 5.84674ZM10.6346 4.74381L10.1537 4.88092C10.2697 5.28772 10.347 5.69413 10.1318 6.24186C9.9049 6.81911 9.32895 7.61111 7.96537 8.69011L8.27563 9.0822L8.58589 9.47429C10.01 8.34742 10.7424 7.42216 11.0625 6.60764C11.3942 5.76361 11.2571 5.10376 11.1154 4.6067L10.6346 4.74381ZM8.27563 9.0822L7.96537 8.69011C7.0119 9.44458 7.09347 10.6137 7.09347 11.3614H7.59347H8.09347C8.09347 10.4547 8.08561 9.87017 8.58589 9.47429L8.27563 9.0822Z\", fill: \"currentColor\" }), /* @__PURE__ */ React.createElement(\"circle\", { cx: 7.66097, cy: 13.1607, r: 0.431202, fill: \"currentColor\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.17085 15.3418C12.1312 15.3418 15.3418 12.1313 15.3418 8.17095C15.3418 4.21057 12.1312 1 8.17085 1C4.21047 1 1 4.21057 1 8.17095C1 12.1313 4.21047 15.3418 8.17085 15.3418Z\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" })), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"clipPath\", { id: \"clip0_27648_5852\" }, /* @__PURE__ */ React.createElement(\"rect\", { width: 16, height: 16, fill: \"white\" }))));\nexport default SvgHelp;\n","import * as React from \"react\";\nconst SvgList = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 48 48\", width: 24, height: 24, fill: \"none\", stroke: \"currentColor\", strokeWidth: 3, strokeLinecap: \"round\", strokeLinejoin: \"round\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { fill: \"none\", d: \"m38.46 11.54l-5.85-5.9a3.9 3.9 0 0 0-2.76-1.14h-19.5a2 2 0 0 0-1.95 2v35.1a2 2 0 0 0 1.95 2h27.3a2 2 0 0 0 2-2V14.3a3.9 3.9 0 0 0-1.19-2.76m-25.08 3.15H29.7m-16.32 7.03h21.24m-21.24 7.03h19.5m-19.5 7.03h12.68\" }));\nexport default SvgList;\n","import * as React from \"react\";\nconst SvgMarket = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.26562 6.60009V3.33337C5.26562 2.71452 5.51145 2.12104 5.94904 1.68345C6.38663 1.24586 6.98015 1 7.599 1C8.21784 1 8.81132 1.24586 9.24891 1.68345C9.68651 2.12104 9.93237 2.71452 9.93237 3.33337V6.60009\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.2002 5.66699H2V15.0005H13.2002V5.66699Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }));\nexport default SvgMarket;\n","import * as React from \"react\";\nconst SvgPlane = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"g\", { clipPath: \"url(#clip0_27648_5666)\" }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.3924 13.6144L11.0069 7.30241L13.701 4.60825C14.8557 3.45361 15.2406 1.91409 14.8557 1.14433C14.0859 0.75945 12.5464 1.14433 11.3918 2.29897L8.69759 4.99313L2.38557 3.60756C2.00069 3.53058 1.69278 3.68454 1.53883 3.99244L1.3079 4.37732C1.15395 4.7622 1.23093 5.14708 1.53883 5.37801L5.61856 8.07217L4.07904 10.3814H1.76976L1 11.1512L3.30928 12.6907L4.8488 15L5.61856 14.2302V11.921L7.92784 10.3814L10.622 14.4612C10.8529 14.7691 11.2378 14.846 11.6227 14.6921L12.0076 14.5381C12.3155 14.3072 12.4694 13.9993 12.3924 13.6144Z\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" })), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"clipPath\", { id: \"clip0_27648_5666\" }, /* @__PURE__ */ React.createElement(\"rect\", { width: 16, height: 16, fill: \"white\" }))));\nexport default SvgPlane;\n","import * as React from \"react\";\nconst SvgProfile = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"g\", { clipPath: \"url(#clip0_27648_5649)\" }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.7265 12.0262C9.54829 11.6097 9.54246 10.9341 9.54246 10.4973V9.8042C9.97361 9.38644 10.3133 8.88369 10.5399 8.32776C10.7665 7.77182 10.875 7.17487 10.8587 6.57475V4.478C10.8587 2.20657 9.24835 1.33301 7.80104 1.33301C6.35374 1.33301 4.74336 2.20657 4.74336 4.478V6.57475C4.72731 7.17345 4.83548 7.76895 5.06102 8.32378C5.28656 8.8786 5.62458 9.38067 6.0538 9.79837V10.4973C6.0538 10.9341 6.0538 11.6301 3.86974 12.0262C3.25845 12.135 2.69243 12.4205 2.24165 12.8475C1.79087 13.2744 1.4751 13.8241 1.33333 14.4286H14.2601C14.1154 13.826 13.7992 13.2783 13.3495 12.8519C12.8998 12.4254 12.336 12.1386 11.7265 12.0262V12.0262Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" })), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"clipPath\", { id: \"clip0_27648_5649\" }, /* @__PURE__ */ React.createElement(\"rect\", { width: 16, height: 16, fill: \"white\" }))));\nexport default SvgProfile;\n","import * as React from \"react\";\nconst SvgProfileSearch = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"g\", { clipPath: \"url(#clip0_27648_5794)\" }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.12936 11.9944H1.33333C1.33333 11.9944 1.33335 10.4405 3.42691 10.0372C5.22691 9.69028 5.22975 9.14763 5.22975 8.79178V8.43298C4.77582 8.01292 4.45171 7.47165 4.29568 6.87318V6.87318C3.74708 6.87318 3.6166 5.7463 3.6166 5.58024C3.6166 5.41417 3.59592 4.73811 4.15045 4.73811C3.79164 3.31472 3.85386 2.00989 4.83837 2.00989C7.21069 0.370026 10.3629 1.8765 9.20046 4.73811C9.75795 4.73811 9.74011 5.41121 9.74011 5.58024C9.74011 5.74926 9.61273 6.87318 9.06116 6.87318C8.90437 7.4744 8.57795 8.0179 8.12101 8.43892V8.79475C8.12101 9.03791 8.05281 9.51827 9.01063 9.86522\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.1147 13.3319C12.343 13.3319 13.3387 12.3361 13.3387 11.1078C13.3387 9.87953 12.343 8.88379 11.1147 8.88379C9.88636 8.88379 8.89062 9.87953 8.89062 11.1078C8.89062 12.3361 9.88636 13.3319 11.1147 13.3319Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.6849 12.6797L14.6718 14.6666\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" })), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"clipPath\", { id: \"clip0_27648_5794\" }, /* @__PURE__ */ React.createElement(\"rect\", { width: 16, height: 16, fill: \"white\" }))));\nexport default SvgProfileSearch;\n","import * as React from \"react\";\nconst SvgTrendUp = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"g\", { clipPath: \"url(#clip0_27648_5697)\" }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.4479 1.33301H13.3353V3.22339\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.66681 7.55537L6.66986 3.99973L9.33659 5.3331L13.3367 1.33301\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.4479 14.6664V5.77734H14.2257V14.6664\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.89062 14.6662V10.2246H10.6684V14.6662\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.33333 14.6665V8.8916H7.11411V14.6665\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.77864 14.6667V12.0029H3.55646V14.6667\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.6699 14.667H1.33333\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" })), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"clipPath\", { id: \"clip0_27648_5697\" }, /* @__PURE__ */ React.createElement(\"rect\", { width: 16, height: 16, fill: \"white\" }))));\nexport default SvgTrendUp;\n","import * as React from \"react\";\nconst SvgWallet = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.93759 11.5H1.65C1.47761 11.5 1.31233 11.4285 1.19043 11.3012C1.06853 11.1739 1 11.0014 1 10.8214V2.67857C1 2.4986 1.06853 2.32598 1.19043 2.19873C1.31233 2.07147 1.47761 2 1.65 2H13.35C13.5224 2 13.6877 2.07147 13.8096 2.19873C13.9315 2.32598 14 2.4986 14 2.67857\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.9996 10.5448C14.0057 10.7866 13.9466 11.0252 13.8291 11.2326C13.7117 11.44 13.5407 11.6076 13.3365 11.7156L5.60035 14.9065C4.93136 15.2187 4.71622 14.6817 4.71622 14.2821V6.32045C4.70283 6.07729 4.75896 5.83551 4.87725 5.62665C4.99553 5.41778 5.17049 5.25154 5.37932 5.14963L12.8827 2.05555C13.3748 1.86822 13.9967 2.18353 13.9967 2.57068L13.9996 10.5448Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.5 10.5C8.01283 10.5 8.42857 10.0523 8.42857 9.5C8.42857 8.94772 8.01283 8.5 7.5 8.5C6.98716 8.5 6.57143 8.94772 6.57143 9.5C6.57143 10.0523 6.98716 10.5 7.5 10.5Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.32143 4.5H7.96428\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.32143 7H4.71428\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }));\nexport default SvgWallet;\n","import * as React from \"react\";\nconst SvgTimesheet = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 512 512\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M472 96h-88V40h-32v56H160V40h-32v56H40a24.03 24.03 0 0 0-24 24v336a24.03 24.03 0 0 0 24 24h432a24.03 24.03 0 0 0 24-24V120a24.03 24.03 0 0 0-24-24m-8 352H48V128h80v40h32v-40h192v40h32v-40h80Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M112 224h32v32h-32zm88 0h32v32h-32zm80 0h32v32h-32zm88 0h32v32h-32zm-256 72h32v32h-32zm88 0h32v32h-32zm80 0h32v32h-32zm88 0h32v32h-32zm-256 72h32v32h-32zm88 0h32v32h-32zm80 0h32v32h-32zm88 0h32v32h-32z\" }));\nexport default SvgTimesheet;\n","import * as React from \"react\";\nconst SvgNotebook = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 32 32\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 7.5A1.5 1.5 0 0 1 9.5 6h12A1.5 1.5 0 0 1 23 7.5v3a1.5 1.5 0 0 1-1.5 1.5h-12A1.5 1.5 0 0 1 8 10.5zm2 .5v2h11V8zM4 5.25A3.25 3.25 0 0 1 7.25 2h16.5A3.25 3.25 0 0 1 27 5.25v21.5A3.25 3.25 0 0 1 23.75 30H7.25A3.25 3.25 0 0 1 4 26.75zM7.25 4C6.56 4 6 4.56 6 5.25v21.5c0 .69.56 1.25 1.25 1.25h16.5c.69 0 1.25-.56 1.25-1.25V5.25C25 4.56 24.44 4 23.75 4zm22 4H28v4h1.25a.75.75 0 0 0 .75-.75v-2.5a.75.75 0 0 0-.75-.75M28 14h1.25a.75.75 0 0 1 .75.75v2.5a.75.75 0 0 1-.75.75H28zm1.25 6H28v4h1.25a.75.75 0 0 0 .75-.75v-2.5a.75.75 0 0 0-.75-.75\" }));\nexport default SvgNotebook;\n","import * as React from \"react\";\nconst SvgChart = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 1024 1024\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M888 792H200V168c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v688c0 4.4 3.6 8 8 8h752c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8M305.8 637.7c3.1 3.1 8.1 3.1 11.3 0l138.3-137.6L583 628.5c3.1 3.1 8.2 3.1 11.3 0l275.4-275.3c3.1-3.1 3.1-8.2 0-11.3l-39.6-39.6a8.03 8.03 0 0 0-11.3 0l-230 229.9L461.4 404a8.03 8.03 0 0 0-11.3 0L266.3 586.7a8.03 8.03 0 0 0 0 11.3z\" }));\nexport default SvgChart;\n","import * as React from \"react\";\nconst SvgFeedback = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 16 16\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.5 1A1.5 1.5 0 0 0 8 2.5v2a1.5 1.5 0 0 0 1 1.414V7a.5.5 0 0 0 .82.384L11.48 6h2.02A1.5 1.5 0 0 0 15 4.5v-2A1.5 1.5 0 0 0 13.5 1zM9 2.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-2.2a.5.5 0 0 0-.32.116l-.98.816V5.5a.5.5 0 0 0-.5-.5a.5.5 0 0 1-.5-.5zM3 6a2 2 0 1 1 4 0a2 2 0 0 1-4 0m2-1a1 1 0 1 0 0 2a1 1 0 0 0 0-2M2.5 9h5A1.5 1.5 0 0 1 9 10.5c0 1.116-.459 2.01-1.212 2.615C7.047 13.71 6.053 14 5 14s-2.047-.29-2.788-.885C1.46 12.51 1 11.616 1 10.5A1.5 1.5 0 0 1 2.5 9m5 1h-5a.5.5 0 0 0-.5.5c0 .817.325 1.423.838 1.835C3.364 12.757 4.12 13 5 13s1.636-.243 2.162-.665C7.675 11.923 8 11.317 8 10.5a.5.5 0 0 0-.5-.5\" }));\nexport default SvgFeedback;\n","import * as React from \"react\";\nconst SvgTaskList = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 2048 2048\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1536 640h-512V512h512zm-512 384h512v128h-512zm131 896l128 128H256V0h1536v1283l-128 128V128H384v1792zM941 429L704 666L531 493l90-90l83 83l147-147zm0 512l-237 237l-173-173l90-90l83 83l147-147zm-237 569l147-147l90 90l-237 237l-173-173l90-90zm1325-57l-557 558l-269-270l90-90l179 178l467-466z\" }));\nexport default SvgTaskList;\n","import * as React from \"react\";\nconst SvgMegaphone = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 32 32\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M20.039 4.751a1 1 0 0 0 1.922.551l.827-2.884a1 1 0 1 0-1.922-.55zm8.668-1.458a1 1 0 0 1 0 1.414l-3 3a1 1 0 1 1-1.414-1.414l3-3a1 1 0 0 1 1.414 0M26 11.002a1 1 0 0 1 1-1h3a1 1 0 0 1 0 2h-3a1 1 0 0 1-1-1M11.956 5.659a3 3 0 0 1 4.805-.78l10.36 10.36a3 3 0 0 1-.78 4.804l-4.749 2.375a5.5 5.5 0 0 1-9.813 4.906l-2.717 1.359A3 3 0 0 1 5.6 28.12L3.88 26.4a3 3 0 0 1-.562-3.463zm1.62 20.767a3.5 3.5 0 0 0 6.218-3.109zm1.77-20.133a1 1 0 0 0-1.6.26l-8.64 17.279a1 1 0 0 0 .187 1.154l1.72 1.72a1 1 0 0 0 1.155.188l17.279-8.64a1 1 0 0 0 .26-1.601z\" }));\nexport default SvgMegaphone;\n","import * as React from \"react\";\nconst SvgUserSwitch = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 24 24\", width: 19, height: 19, fill: \"none\", stroke: \"currentColor\", strokeWidth: 1.5, strokeLinecap: \"round\", strokeLinejoin: \"round\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { fill: \"none\", d: \"M17 17a2.5 2.5 0 1 1 0-5a2.5 2.5 0 0 1 0 5m0 0a4.5 4.5 0 0 1 4.5 4.5M17 17a4.5 4.5 0 0 0-4.5 4.5M7 7.5a2.5 2.5 0 1 1 0-5a2.5 2.5 0 0 1 0 5m0 0a4.5 4.5 0 0 1 4.5 4.5M7 7.5A4.5 4.5 0 0 0 2.5 12m1 3.5c0 2.764 2.236 5 5 5l-.5-2m10.5-10c0-2.764-2.236-5-5-5l.5 2\" }));\nexport default SvgUserSwitch;\n","import * as React from \"react\";\nconst SvgFileSync = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 1024 1024\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M296 256c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm192 200v-48c0-4.4-3.6-8-8-8H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8m-48 396H208V148h560v344c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V108c0-17.7-14.3-32-32-32H168c-17.7 0-32 14.3-32 32v784c0 17.7 14.3 32 32 32h272c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8m104.1-115.6c1.8-34.5 16.2-66.8 40.8-91.4c26.2-26.2 62-41 99.1-41c37.4 0 72.6 14.6 99.1 41c3.2 3.2 6.3 6.6 9.2 10.1L769.2 673a8 8 0 0 0 3 14.1l93.3 22.5c5 1.2 9.8-2.6 9.9-7.7l.6-95.4a8 8 0 0 0-12.9-6.4l-20.3 15.8C805.4 569.6 748.1 540 684 540c-109.9 0-199.6 86.9-204 195.7c-.2 4.5 3.5 8.3 8 8.3h48.1c4.3 0 7.8-3.3 8-7.6M880 744h-48.1c-4.3 0-7.8 3.3-8 7.6c-1.8 34.5-16.2 66.8-40.8 91.4c-26.2 26.2-62 41-99.1 41c-37.4 0-72.6-14.6-99.1-41c-3.2-3.2-6.3-6.6-9.2-10.1l23.1-17.9a8 8 0 0 0-3-14.1l-93.3-22.5c-5-1.2-9.8 2.6-9.9 7.7l-.6 95.4a8 8 0 0 0 12.9 6.4l20.3-15.8C562.6 918.4 619.9 948 684 948c109.9 0 199.6-86.9 204-195.7c.2-4.5-3.5-8.3-8-8.3\" }));\nexport default SvgFileSync;\n","import * as React from \"react\";\nconst SvgChat = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 1024 1024\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M573 421c-23.1 0-41 17.9-41 40s17.9 40 41 40c21.1 0 39-17.9 39-40s-17.9-40-39-40m-280 0c-23.1 0-41 17.9-41 40s17.9 40 41 40c21.1 0 39-17.9 39-40s-17.9-40-39-40\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M894 345c-48.1-66-115.3-110.1-189-130v.1c-17.1-19-36.4-36.5-58-52.1c-163.7-119-393.5-82.7-513 81c-96.3 133-92.2 311.9 6 439l.8 132.6c0 3.2.5 6.4 1.5 9.4c5.3 16.9 23.3 26.2 40.1 20.9L309 806c33.5 11.9 68.1 18.7 102.5 20.6l-.5.4c89.1 64.9 205.9 84.4 313 49l127.1 41.4c3.2 1 6.5 1.6 9.9 1.6c17.7 0 32-14.3 32-32V753c88.1-119.6 90.4-284.9 1-408M323 735l-12-5l-99 31l-1-104l-8-9c-84.6-103.2-90.2-251.9-11-361c96.4-132.2 281.2-161.4 413-66c132.2 96.1 161.5 280.6 66 412c-80.1 109.9-223.5 150.5-348 102m505-17l-8 10l1 104l-98-33l-12 5c-56 20.8-115.7 22.5-171 7l-.2-.1C613.7 788.2 680.7 742.2 729 676c76.4-105.3 88.8-237.6 44.4-350.4l.6.4c23 16.5 44.1 37.1 62 62c72.6 99.6 68.5 235.2-8 330\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M433 421c-23.1 0-41 17.9-41 40s17.9 40 41 40c21.1 0 39-17.9 39-40s-17.9-40-39-40\" }));\nexport default SvgChat;\n","import * as React from \"react\";\nconst SvgSearch = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.5433 12.0867C9.6048 12.0867 12.0867 9.60488 12.0867 6.54338C12.0867 3.48188 9.6048 1 6.5433 1C3.4818 1 1 3.48188 1 6.54338C1 9.60488 3.4818 12.0867 6.5433 12.0867Z\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.4727 10.4707L15.9994 16.0007\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" }));\nexport default SvgSearch;\n","import * as React from \"react\";\nconst SvgArrowRight = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 24, height: 24, viewBox: \"0 0 24 24\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M19 12.5H6M19 12.5L14.3333 8M19 12.5L14.3333 17\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" }));\nexport default SvgArrowRight;\n","import * as React from \"react\";\nconst SvgArrowDown = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 24, height: 24, viewBox: \"0 0 24 24\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M17.2929 9.29289C17.6834 8.90237 18.3166 8.90237 18.7071 9.29289C19.0976 9.68342 19.0976 10.3166 18.7071 10.7071L12.7071 16.7071C12.3285 17.0857 11.7189 17.0989 11.3243 16.7372L5.32428 11.2372C4.91716 10.864 4.88965 10.2314 5.26285 9.82427C5.63604 9.41715 6.26861 9.38965 6.67573 9.76284L11.9699 14.6159L17.2929 9.29289Z\", fill: \"currentColor\" }));\nexport default SvgArrowDown;\n","import * as React from \"react\";\nconst SvgArrowDownBlue = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 24, height: 24, viewBox: \"0 0 24 24\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M17.2929 9.29289C17.6834 8.90237 18.3166 8.90237 18.7071 9.29289C19.0976 9.68342 19.0976 10.3166 18.7071 10.7071L12.7071 16.7071C12.3285 17.0857 11.7189 17.0989 11.3243 16.7372L5.32428 11.2372C4.91716 10.864 4.88965 10.2314 5.26285 9.82427C5.63604 9.41715 6.26861 9.38965 6.67573 9.76284L11.9699 14.6159L17.2929 9.29289Z\", fill: \"rgba(0, 109, 240, 0.8)\" }));\nexport default SvgArrowDownBlue;\n","import * as React from \"react\";\nconst SvgCross = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13 3L8 8M3 13L8 8M8 8L3 3L13 13\", stroke: \"currentColor\", strokeLinecap: \"round\", strokeLinejoin: \"round\" }));\nexport default SvgCross;\n","import * as React from \"react\";\nconst SvgCloseRed = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 24, height: 24, viewBox: \"0 0 24 24\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"rect\", { width: 24, height: 24, rx: 12, fill: \"#FFEEEE\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.5 7.5L16.5 16.5M7.5 16.5L16.5 7.5\", stroke: \"#D72D40\", strokeWidth: 1.4, strokeLinecap: \"round\" }));\nexport default SvgCloseRed;\n","import * as React from \"react\";\nconst SvgCheckGreen = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 24, height: 24, viewBox: \"0 0 24 24\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"rect\", { width: 24, height: 24, rx: 12, fill: \"#E0F4F0\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.89997 17C9.7143 17 9.53632 16.9248 9.40507 16.7909L5.20502 12.505C4.93166 12.226 4.93166 11.7739 5.20502 11.495C5.47837 11.216 5.92165 11.216 6.19483 11.495L9.89997 15.2757L17.8052 7.2092C18.0785 6.93027 18.5218 6.93027 18.795 7.2092C19.0683 7.48813 19.0683 7.94045 18.795 8.21939L10.3949 16.7909C10.2636 16.9248 10.0857 17 9.89997 17Z\", fill: \"#00A582\" }));\nexport default SvgCheckGreen;\n","import * as React from \"react\";\nconst SvgHistoryBlue = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 24, height: 24, viewBox: \"0 0 24 24\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"rect\", { width: 24, height: 24, rx: 12, fill: \"#E0F1FF\" }), /* @__PURE__ */ React.createElement(\"path\", { fillRule: \"evenodd\", clipRule: \"evenodd\", d: \"M12.1056 8.28604C12.3584 8.28604 12.5639 8.48905 12.5639 8.73886V12.923C12.5639 13.1728 12.3584 13.3751 12.1056 13.3751H9.32172C9.06885 13.3751 8.86411 13.1728 8.86411 12.923C8.86411 12.6724 9.06885 12.4702 9.32172 12.4702H11.6472V8.73886C11.6472 8.48905 11.8527 8.28604 12.1056 8.28604ZM4 12C4 16.4113 7.63261 20 12.0972 20C15.8917 20 19.1362 17.4528 19.988 13.806C20.0453 13.563 19.891 13.32 19.6443 13.2634C19.4029 13.2098 19.1523 13.3592 19.0942 13.603C18.3394 16.8362 15.4624 19.0943 12.0972 19.0943C8.13758 19.0943 4.91599 15.9117 4.91599 12C4.91599 8.08754 8.13758 4.90566 12.0972 4.90566C14.8909 4.90566 17.4288 6.52528 18.6007 8.99245H15.8757C15.6228 8.99245 15.4173 9.19471 15.4173 9.44452C15.4173 9.69433 15.6228 9.89736 15.8757 9.89736H19.3418C19.5946 9.89736 19.7994 9.69433 19.7994 9.44452V6.02113C19.7994 5.77132 19.5946 5.5683 19.3418 5.5683C19.0889 5.5683 18.8834 5.77132 18.8834 6.02113V7.63698C17.4097 5.4083 14.8642 4 12.0972 4C7.63261 4 4 7.58867 4 12Z\", fill: \"#4573D9\" }));\nexport default SvgHistoryBlue;\n","import * as React from \"react\";\nconst SvgDone = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 24, height: 24, viewBox: \"0 0 24 24\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M21.9006 11.9999C21.9006 6.53258 17.4684 2.10042 12.0011 2.10042C6.53372 2.10042 2.10156 6.53258 2.10156 11.9999C2.10156 17.4673 6.53372 21.8994 12.0011 21.8994C17.4684 21.8994 21.9006 17.4673 21.9006 11.9999Z\", fill: \"#00A582\", stroke: \"#00A582\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 11.6226L10.8813 15L16 9\", stroke: \"white\", strokeWidth: 1.5, strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }));\nexport default SvgDone;\n","import * as React from \"react\";\nconst SvgCancel = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 24, height: 24, viewBox: \"0 0 24 24\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12 22C17.5228 22 22 17.5228 22 12C22 6.47715 17.5228 2 12 2C6.47715 2 2 6.47715 2 12C2 17.5228 6.47715 22 12 22Z\", fill: \"#D72D40\", stroke: \"#D72D40\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M15.6912 8.31348L8.30859 15.6917\", stroke: \"white\", strokeWidth: 1.5, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M15.6947 15.6917L8.31641 8.31348\", stroke: \"white\", strokeWidth: 1.5, strokeLinecap: \"round\", strokeLinejoin: \"round\" }));\nexport default SvgCancel;\n","import * as React from \"react\";\nconst SvgWarn = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 24, height: 24, viewBox: \"0 0 24 24\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.8617 21.7234C17.3082 21.7234 21.7234 17.3082 21.7234 11.8617C21.7234 6.41523 17.3082 2 11.8617 2C6.41523 2 2 6.41523 2 11.8617C2 17.3082 6.41523 21.7234 11.8617 21.7234Z\", fill: \"#FFA300\", stroke: \"#FFA300\", strokeWidth: 1.5, strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.3004 13.9799L11.0046 6.75096C11.0001 6.63834 11.0178 6.52593 11.0567 6.42017C11.0957 6.3144 11.155 6.21731 11.2315 6.1345C11.3079 6.05168 11.3999 5.98475 11.5022 5.93749C11.6046 5.89023 11.7152 5.86359 11.8278 5.85908C11.9404 5.85458 12.0528 5.87228 12.1586 5.91122C12.2644 5.95015 12.3614 6.00959 12.4442 6.08603C12.527 6.16248 12.594 6.25442 12.6413 6.35673C12.6885 6.45905 12.7152 6.56967 12.7197 6.68229C12.7197 6.70373 12.7197 6.72952 12.7197 6.75096L12.4238 13.9799C12.4238 14.1295 12.3644 14.2729 12.2587 14.3787C12.1529 14.4844 12.0095 14.5438 11.86 14.5438C11.7104 14.5438 11.567 14.4844 11.4613 14.3787C11.3555 14.2729 11.2961 14.1295 11.2961 13.9799H11.3004Z\", fill: \"white\" }), /* @__PURE__ */ React.createElement(\"circle\", { cx: 11.8605, cy: 16.7795, r: 1, fill: \"white\", stroke: \"white\", strokeWidth: 0.572616 }));\nexport default SvgWarn;\n","import * as React from \"react\";\nconst SvgEnvelop = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15 3H1V13H15V3Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M1 3L8 10.3433L15 3\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.3359 7.89648L15.0026 12.9998\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M1 12.9998L5.66667 7.89648\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinecap: \"round\", strokeLinejoin: \"round\" }));\nexport default SvgEnvelop;\n","import * as React from \"react\";\nconst SvgMessage = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.61422 14.1333L5.99625 12.4418C6.61289 12.5773 7.2432 12.6457 7.87554 12.6458C11.6739 12.6458 14.7511 10.2623 14.7511 7.32292C14.7511 4.38348 11.6739 2 7.87554 2C4.07718 2 1 4.38348 1 7.32292C1 8.81925 1.79758 10.1707 3.08101 11.1347L1.61422 14.1333Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }), /* @__PURE__ */ React.createElement(\"circle\", { cx: 4.98438, cy: 7.66211, r: 0.75, fill: \"currentColor\" }), /* @__PURE__ */ React.createElement(\"circle\", { cx: 7.875, cy: 7.66211, r: 0.75, fill: \"currentColor\" }), /* @__PURE__ */ React.createElement(\"circle\", { cx: 10.7656, cy: 7.66211, r: 0.75, fill: \"currentColor\" }));\nexport default SvgMessage;\n","import * as React from \"react\";\nconst SvgPhone = (props) => /* @__PURE__ */ React.createElement(\"svg\", { width: 16, height: 16, viewBox: \"0 0 16 16\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.5195 9.99817C11.3265 9.87759 11.0947 9.83572 10.8717 9.88121C10.6488 9.92671 10.4519 10.0561 10.3216 10.2426C9.89136 10.7756 9.35845 11.663 7.34409 9.64859C5.32972 7.63423 6.2171 7.1013 6.74759 6.67105C6.93413 6.54079 7.0635 6.34385 7.109 6.12093C7.15449 5.89801 7.11263 5.66612 6.99205 5.47319C6.84537 5.25073 5.90909 3.80596 5.74285 3.56639C5.57662 3.32681 5.35414 2.93568 4.84077 3.00901C4.31202 3.17497 3.84929 3.50384 3.51868 3.9486C3.18807 4.39337 3.00653 4.93127 3 5.48541C3 7.13308 4.29808 9.15233 6.07287 10.9271C7.84766 12.7019 9.86692 14 11.5146 14C12.0687 13.9935 12.6066 13.8119 13.0514 13.4813C13.4962 13.1507 13.825 12.688 13.991 12.1592C14.0643 11.6434 13.6732 11.4258 13.4336 11.2571C13.194 11.0885 11.7419 10.1448 11.5195 9.99817Z\", stroke: \"currentColor\", strokeMiterlimit: 10, strokeLinejoin: \"round\" }));\nexport default SvgPhone;\n","import * as React from \"react\";\nconst SvgCamera = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 32 32\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M29 26H3a1 1 0 0 1-1-1V8a1 1 0 0 1 1-1h6.46l1.71-2.55A1 1 0 0 1 12 4h8a1 1 0 0 1 .83.45L22.54 7H29a1 1 0 0 1 1 1v17a1 1 0 0 1-1 1M4 24h24V9h-6a1 1 0 0 1-.83-.45L19.46 6h-6.92l-1.71 2.55A1 1 0 0 1 10 9H4Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M16 22a6 6 0 1 1 6-6a6 6 0 0 1-6 6m0-10a4 4 0 1 0 4 4a4 4 0 0 0-4-4\" }));\nexport default SvgCamera;\n","import * as React from \"react\";\nconst SvgCopy = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 24 24\", width: 24, height: 24, fill: \"#000000\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7 6V3a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1v14a1 1 0 0 1-1 1h-3v3c0 .552-.45 1-1.007 1H4.007A1 1 0 0 1 3 21l.003-14c0-.552.45-1 1.006-1zM5.002 8L5 20h10V8zM9 6h8v10h2V4H9z\" }));\nexport default SvgCopy;\n","import * as React from \"react\";\nconst SvgInfo = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 24 24\", width: 24, height: 24, fill: \"none\", stroke: \"currentColor\", strokeWidth: 2, strokeLinecap: \"round\", strokeLinejoin: \"round\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { fill: \"none\", d: \"M12 11v5m0 5a9 9 0 1 1 0-18a9 9 0 0 1 0 18m.05-13v.1h-.1V8z\" }));\nexport default SvgInfo;\n","import * as React from \"react\";\nconst SvgFilter = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 32 32\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M18 28h-4a2 2 0 0 1-2-2v-7.59L4.59 11A2 2 0 0 1 4 9.59V6a2 2 0 0 1 2-2h20a2 2 0 0 1 2 2v3.59a2 2 0 0 1-.59 1.41L20 18.41V26a2 2 0 0 1-2 2M6 6v3.59l8 8V26h4v-8.41l8-8V6Z\" }));\nexport default SvgFilter;\n","import * as React from \"react\";\nconst SvgEdit = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 1024 1024\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M257.7 752c2 0 4-.2 6-.5L431.9 722c2-.4 3.9-1.3 5.3-2.8l423.9-423.9a9.96 9.96 0 0 0 0-14.1L694.9 114.9c-1.9-1.9-4.4-2.9-7.1-2.9s-5.2 1-7.1 2.9L256.8 538.8c-1.5 1.5-2.4 3.3-2.8 5.3l-29.5 168.2a33.5 33.5 0 0 0 9.4 29.8c6.6 6.4 14.9 9.9 23.8 9.9m67.4-174.4L687.8 215l73.3 73.3l-362.7 362.6l-88.9 15.7zM880 836H144c-17.7 0-32 14.3-32 32v36c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-36c0-17.7-14.3-32-32-32\" }));\nexport default SvgEdit;\n","import * as React from \"react\";\nconst SvgReload = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 24 24\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M20.3 13.43a1 1 0 0 0-1.25.65A7.14 7.14 0 0 1 12.18 19A7.1 7.1 0 0 1 5 12a7.1 7.1 0 0 1 7.18-7a7.26 7.26 0 0 1 4.65 1.67l-2.17-.36a1 1 0 0 0-1.15.83a1 1 0 0 0 .83 1.15l4.24.7h.17a1 1 0 0 0 .34-.06a.3.3 0 0 0 .1-.06a.8.8 0 0 0 .2-.11l.09-.11c0-.05.09-.09.13-.15s0-.1.05-.14a1.3 1.3 0 0 0 .07-.18l.75-4a1 1 0 0 0-2-.38l-.27 1.45A9.2 9.2 0 0 0 12.18 3A9.1 9.1 0 0 0 3 12a9.1 9.1 0 0 0 9.18 9A9.12 9.12 0 0 0 21 14.68a1 1 0 0 0-.7-1.25\" }));\nexport default SvgReload;\n","import * as React from \"react\";\nconst SvgClockFilled = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 1024 1024\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448s448-200.6 448-448S759.4 64 512 64m176.5 585.7l-28.6 39a7.99 7.99 0 0 1-11.2 1.7L483.3 569.8a7.92 7.92 0 0 1-3.3-6.5V288c0-4.4 3.6-8 8-8h48.1c4.4 0 8 3.6 8 8v247.5l142.6 103.1c3.6 2.5 4.4 7.5 1.8 11.1\" }));\nexport default SvgClockFilled;\n","import * as React from \"react\";\nconst SvgEmpty = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 48 48\", width: 24, height: 24, fill: \"none\", stroke: \"currentColor\", strokeWidth: 2, strokeLinecap: \"round\", strokeLinejoin: \"round\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { fill: \"none\", d: \"M4.5 11.5a3 3 0 0 1 3-3h8.718a4 4 0 0 1 2.325.745l4.914 3.51a4 4 0 0 0 2.325.745H40.5a3 3 0 0 1 3 3v20a3 3 0 0 1-3 3h-33a3 3 0 0 1-3-3z\" }), /* @__PURE__ */ React.createElement(\"circle\", { cx: 25.435, cy: 25.065, r: 5.565 }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M21.5 29L17 33.5\" }));\nexport default SvgEmpty;\n","import * as React from \"react\";\nconst SvgSettings = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 24 24\", width: 24, height: 24, fill: \"none\", stroke: \"currentColor\", strokeWidth: 2, strokeLinecap: \"round\", strokeLinejoin: \"round\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M19 3v4m0 14V11m-7-8v12m0 6v-2M5 3v2m0 16V9\" }), /* @__PURE__ */ React.createElement(\"circle\", { cx: 19, cy: 9, r: 2, transform: \"rotate(90 19 9)\" }), /* @__PURE__ */ React.createElement(\"circle\", { cx: 12, cy: 17, r: 2, transform: \"rotate(90 12 17)\" }), /* @__PURE__ */ React.createElement(\"circle\", { cx: 5, cy: 7, r: 2, transform: \"rotate(90 5 7)\" }));\nexport default SvgSettings;\n","import * as React from \"react\";\nconst SvgSchool = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 12 12\", width: 24, height: 24, fill: \"#000000\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.84 2.189a1.96 1.96 0 0 0-1.68 0L.286 4.498A.5.5 0 0 0 0 4.976v3.026a.5.5 0 1 0 1 0V5.756l1 .496v2.75a.5.5 0 0 0 .147.354l.025.024l.06.055q.075.072.217.188c.187.153.457.355.794.558c.67.401 1.634.82 2.757.82s2.088-.419 2.757-.82a6.7 6.7 0 0 0 1.012-.746l.06-.055l.023-.024h.002A.5.5 0 0 0 10 9.001v-2.75l1.722-.854a.5.5 0 0 0-.008-.9zm.032 5.615L9 6.748V8.78l-.082.07a6 6 0 0 1-.675.473c-.58.348-1.366.679-2.243.679s-1.662-.33-2.243-.679A6 6 0 0 1 3 8.78V6.748l2.128 1.056c.55.272 1.194.272 1.744 0m-.46-4.711l3.942 1.867l-3.927 1.948a.96.96 0 0 1-.854 0L1.646 4.96l3.942-1.867a.96.96 0 0 1 .824 0M2.149 9.358\" }));\nexport default SvgSchool;\n","import * as React from \"react\";\nconst SvgIsland = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 2048 2048\", width: 24, height: 24, fill: \"currentColor\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1728 1664q26 0 45 19t19 45t-19 45t-45 19H960q-26 0-45-19t-19-45t19-45t45-19zm-128 256q26 0 45 19t19 45t-19 45t-45 19h-512q-26 0-45-19t-19-45t19-45t45-19zm238-512h210v128H537q-10 64-14 128t-7 127t-3 128t-1 129H128v-193q0-81 6-160t17-159H0v-128h172q50-245 151-471t250-427q-146-5-268-61T82 289l-45-46l47-44q104-97 228-147T579 1q156 0 286 58t239 168q77 2 149 24t134 60t113 90t87 115t57 135t20 150v64h-64q-132 0-247-56t-199-159q-76 138-191 227t-269 125q-43 99-76 200t-57 206h289q22-84 69-154t112-122t146-79t167-29q87 0 167 28t145 80t113 121t69 155M1238 380q-6 65-26 132q51 88 134 146t185 74q-10-61-35-115t-63-101t-88-80t-107-56m-126 7q-102 8-192 50T759 547T642 704t-61 189q85-7 161-36t139-78t112-112t81-144q14-33 23-67t15-69M224 247q80 66 177 101t201 35q97 0 187-30t168-88q-80-66-177-101t-201-35q-97 0-187 30t-168 88m318 775q-8 2-16 2t-16 0h-32q-16 0-32-2v-47q-53 118-89 232t-59 230t-32 235t-10 248h128q0-121 8-234t27-223t49-219t74-222m442 386h720q-20-57-56-104t-83-81t-104-52t-117-19q-61 0-117 18t-103 52t-84 81t-56 105\" }));\nexport default SvgIsland;\n","import * as React from \"react\";\nconst SvgDownload = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 24 24\", width: 24, height: 24, fill: \"none\", stroke: \"currentColor\", strokeWidth: 2, strokeLinecap: \"round\", strokeLinejoin: \"round\", style: {\n opacity: 1\n}, ...props }, /* @__PURE__ */ React.createElement(\"path\", { fill: \"none\", d: \"M12 15V3m0 12l-4-4m4 4l4-4M2 17l.621 2.485A2 2 0 0 0 4.561 21h14.877a2 2 0 0 0 1.94-1.515L22 17\" }));\nexport default SvgDownload;\n","export enum Colors {\n BLUE_01 = \"#D3E8FA\",\n BLUE_02 = \"#4573D9\",\n BLUE_03 = \"#4573D9\",\n BLUE_04 = \"#4573D9\",\n BLUE_05 = \"#001A3D\",\n\n GRAY_01 = \"#F4F7FA\",\n GRAY_02 = \"#c8c7cc\",\n GRAY_03 = \"#808080\",\n GRAY_04 = \"#525252\",\n GRAY_05 = \"#2A2A2A\",\n GRAY_06 = \"#AEBFDE\",\n GRAY_07 = \"#DDE5F5\",\n\n WHITE_01 = \"#FFFFFF\",\n BLACK_01 = \"#000000\",\n\n GREEN_01 = \"#C4F2E8\",\n GREEN_02 = \"#00A582\",\n\n ORANGE_01 = \"#F9E1D7\",\n ORANGE_02 = \"#FF6B2C\",\n\n RED_01 = \"#FFEEEE\",\n RED_02 = \"#D72D40\",\n\n YELLOW_01 = \"#FFF1D8\",\n YELLOW_02 = \"#FFA300\",\n}\n","/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = '';\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (arg) {\n\t\t\t\tclasses = appendClass(classes, parseValue(arg));\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction parseValue (arg) {\n\t\tif (typeof arg === 'string' || typeof arg === 'number') {\n\t\t\treturn arg;\n\t\t}\n\n\t\tif (typeof arg !== 'object') {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (Array.isArray(arg)) {\n\t\t\treturn classNames.apply(null, arg);\n\t\t}\n\n\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\treturn arg.toString();\n\t\t}\n\n\t\tvar classes = '';\n\n\t\tfor (var key in arg) {\n\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\tclasses = appendClass(classes, key);\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction appendClass (value, newClass) {\n\t\tif (!newClass) {\n\t\t\treturn value;\n\t\t}\n\t\n\t\tif (value) {\n\t\t\treturn value + ' ' + newClass;\n\t\t}\n\t\n\t\treturn value + newClass;\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","import { FC, ReactNode } from \"react\";\nimport cn from \"classnames\";\nimport css from \"./BaseBlock.module.scss\";\n\ninterface BaseBlockProps {\n id?: string;\n title?: string | ReactNode;\n subtitle?: ReactNode;\n children: ReactNode;\n className?: string;\n}\n\nexport const BaseBlock: FC<BaseBlockProps> = ({ id, title, subtitle, children, className }) => (\n <div className={cn(css.block, className)} id={id}>\n {title && typeof title === \"string\" ? <div className={css.title}>{title}</div> : title}\n {subtitle && <div className={css.subtitle}>{subtitle}</div>}\n {children}\n </div>\n);\n","// packages/react/compose-refs/src/compose-refs.tsx\nimport * as React from \"react\";\nfunction setRef(ref, value) {\n if (typeof ref === \"function\") {\n return ref(value);\n } else if (ref !== null && ref !== void 0) {\n ref.current = value;\n }\n}\nfunction composeRefs(...refs) {\n return (node) => {\n let hasCleanup = false;\n const cleanups = refs.map((ref) => {\n const cleanup = setRef(ref, node);\n if (!hasCleanup && typeof cleanup == \"function\") {\n hasCleanup = true;\n }\n return cleanup;\n });\n if (hasCleanup) {\n return () => {\n for (let i = 0; i < cleanups.length; i++) {\n const cleanup = cleanups[i];\n if (typeof cleanup == \"function\") {\n cleanup();\n } else {\n setRef(refs[i], null);\n }\n }\n };\n }\n };\n}\nfunction useComposedRefs(...refs) {\n return React.useCallback(composeRefs(...refs), refs);\n}\nexport {\n composeRefs,\n useComposedRefs\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\nvar REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nvar use = React[\" use \".trim().toString()];\nfunction isPromiseLike(value) {\n return typeof value === \"object\" && value !== null && \"then\" in value;\n}\nfunction isLazyComponent(element) {\n return element != null && typeof element === \"object\" && \"$$typeof\" in element && element.$$typeof === REACT_LAZY_TYPE && \"_payload\" in element && isPromiseLike(element._payload);\n}\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","/**\n * Copyright 2022 Joe Bell. All rights reserved.\n *\n * This file is licensed to you under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with the\n * License. You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR REPRESENTATIONS OF ANY KIND, either express or implied. See the\n * License for the specific language governing permissions and limitations under\n * the License.\n */ import { clsx } from \"clsx\";\nconst falsyToString = (value)=>typeof value === \"boolean\" ? `${value}` : value === 0 ? \"0\" : value;\nexport const cx = clsx;\nexport const cva = (base, config)=>(props)=>{\n var _config_compoundVariants;\n if ((config === null || config === void 0 ? void 0 : config.variants) == null) return cx(base, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n const { variants, defaultVariants } = config;\n const getVariantClassNames = Object.keys(variants).map((variant)=>{\n const variantProp = props === null || props === void 0 ? void 0 : props[variant];\n const defaultVariantProp = defaultVariants === null || defaultVariants === void 0 ? void 0 : defaultVariants[variant];\n if (variantProp === null) return null;\n const variantKey = falsyToString(variantProp) || falsyToString(defaultVariantProp);\n return variants[variant][variantKey];\n });\n const propsWithoutUndefined = props && Object.entries(props).reduce((acc, param)=>{\n let [key, value] = param;\n if (value === undefined) {\n return acc;\n }\n acc[key] = value;\n return acc;\n }, {});\n const getCompoundVariantClassNames = config === null || config === void 0 ? void 0 : (_config_compoundVariants = config.compoundVariants) === null || _config_compoundVariants === void 0 ? void 0 : _config_compoundVariants.reduce((acc, param)=>{\n let { class: cvClass, className: cvClassName, ...compoundVariantOptions } = param;\n return Object.entries(compoundVariantOptions).every((param)=>{\n let [key, value] = param;\n return Array.isArray(value) ? value.includes({\n ...defaultVariants,\n ...propsWithoutUndefined\n }[key]) : ({\n ...defaultVariants,\n ...propsWithoutUndefined\n })[key] === value;\n }) ? [\n ...acc,\n cvClass,\n cvClassName\n ] : acc;\n }, []);\n return cx(base, getVariantClassNames, getCompoundVariantClassNames, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n };\n\n","/**\n * Concatenates two arrays faster than the array spread operator.\n */\nconst concatArrays = (array1, array2) => {\n // Pre-allocate for better V8 optimization\n const combinedArray = new Array(array1.length + array2.length);\n for (let i = 0; i < array1.length; i++) {\n combinedArray[i] = array1[i];\n }\n for (let i = 0; i < array2.length; i++) {\n combinedArray[array1.length + i] = array2[i];\n }\n return combinedArray;\n};\n\n// Factory function ensures consistent object shapes\nconst createClassValidatorObject = (classGroupId, validator) => ({\n classGroupId,\n validator\n});\n// Factory ensures consistent ClassPartObject shape\nconst createClassPartObject = (nextPart = new Map(), validators = null, classGroupId) => ({\n nextPart,\n validators,\n classGroupId\n});\nconst CLASS_PART_SEPARATOR = '-';\nconst EMPTY_CONFLICTS = [];\n// I use two dots here because one dot is used as prefix for class groups in plugins\nconst ARBITRARY_PROPERTY_PREFIX = 'arbitrary..';\nconst createClassGroupUtils = config => {\n const classMap = createClassMap(config);\n const {\n conflictingClassGroups,\n conflictingClassGroupModifiers\n } = config;\n const getClassGroupId = className => {\n if (className.startsWith('[') && className.endsWith(']')) {\n return getGroupIdForArbitraryProperty(className);\n }\n const classParts = className.split(CLASS_PART_SEPARATOR);\n // Classes like `-inset-1` produce an empty string as first classPart. We assume that classes for negative values are used correctly and skip it.\n const startIndex = classParts[0] === '' && classParts.length > 1 ? 1 : 0;\n return getGroupRecursive(classParts, startIndex, classMap);\n };\n const getConflictingClassGroupIds = (classGroupId, hasPostfixModifier) => {\n if (hasPostfixModifier) {\n const modifierConflicts = conflictingClassGroupModifiers[classGroupId];\n const baseConflicts = conflictingClassGroups[classGroupId];\n if (modifierConflicts) {\n if (baseConflicts) {\n // Merge base conflicts with modifier conflicts\n return concatArrays(baseConflicts, modifierConflicts);\n }\n // Only modifier conflicts\n return modifierConflicts;\n }\n // Fall back to without postfix if no modifier conflicts\n return baseConflicts || EMPTY_CONFLICTS;\n }\n return conflictingClassGroups[classGroupId] || EMPTY_CONFLICTS;\n };\n return {\n getClassGroupId,\n getConflictingClassGroupIds\n };\n};\nconst getGroupRecursive = (classParts, startIndex, classPartObject) => {\n const classPathsLength = classParts.length - startIndex;\n if (classPathsLength === 0) {\n return classPartObject.classGroupId;\n }\n const currentClassPart = classParts[startIndex];\n const nextClassPartObject = classPartObject.nextPart.get(currentClassPart);\n if (nextClassPartObject) {\n const result = getGroupRecursive(classParts, startIndex + 1, nextClassPartObject);\n if (result) return result;\n }\n const validators = classPartObject.validators;\n if (validators === null) {\n return undefined;\n }\n // Build classRest string efficiently by joining from startIndex onwards\n const classRest = startIndex === 0 ? classParts.join(CLASS_PART_SEPARATOR) : classParts.slice(startIndex).join(CLASS_PART_SEPARATOR);\n const validatorsLength = validators.length;\n for (let i = 0; i < validatorsLength; i++) {\n const validatorObj = validators[i];\n if (validatorObj.validator(classRest)) {\n return validatorObj.classGroupId;\n }\n }\n return undefined;\n};\n/**\n * Get the class group ID for an arbitrary property.\n *\n * @param className - The class name to get the group ID for. Is expected to be string starting with `[` and ending with `]`.\n */\nconst getGroupIdForArbitraryProperty = className => className.slice(1, -1).indexOf(':') === -1 ? undefined : (() => {\n const content = className.slice(1, -1);\n const colonIndex = content.indexOf(':');\n const property = content.slice(0, colonIndex);\n return property ? ARBITRARY_PROPERTY_PREFIX + property : undefined;\n})();\n/**\n * Exported for testing only\n */\nconst createClassMap = config => {\n const {\n theme,\n classGroups\n } = config;\n return processClassGroups(classGroups, theme);\n};\n// Split into separate functions to maintain monomorphic call sites\nconst processClassGroups = (classGroups, theme) => {\n const classMap = createClassPartObject();\n for (const classGroupId in classGroups) {\n const group = classGroups[classGroupId];\n processClassesRecursively(group, classMap, classGroupId, theme);\n }\n return classMap;\n};\nconst processClassesRecursively = (classGroup, classPartObject, classGroupId, theme) => {\n const len = classGroup.length;\n for (let i = 0; i < len; i++) {\n const classDefinition = classGroup[i];\n processClassDefinition(classDefinition, classPartObject, classGroupId, theme);\n }\n};\n// Split into separate functions for each type to maintain monomorphic call sites\nconst processClassDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n if (typeof classDefinition === 'string') {\n processStringDefinition(classDefinition, classPartObject, classGroupId);\n return;\n }\n if (typeof classDefinition === 'function') {\n processFunctionDefinition(classDefinition, classPartObject, classGroupId, theme);\n return;\n }\n processObjectDefinition(classDefinition, classPartObject, classGroupId, theme);\n};\nconst processStringDefinition = (classDefinition, classPartObject, classGroupId) => {\n const classPartObjectToEdit = classDefinition === '' ? classPartObject : getPart(classPartObject, classDefinition);\n classPartObjectToEdit.classGroupId = classGroupId;\n};\nconst processFunctionDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n if (isThemeGetter(classDefinition)) {\n processClassesRecursively(classDefinition(theme), classPartObject, classGroupId, theme);\n return;\n }\n if (classPartObject.validators === null) {\n classPartObject.validators = [];\n }\n classPartObject.validators.push(createClassValidatorObject(classGroupId, classDefinition));\n};\nconst processObjectDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n const entries = Object.entries(classDefinition);\n const len = entries.length;\n for (let i = 0; i < len; i++) {\n const [key, value] = entries[i];\n processClassesRecursively(value, getPart(classPartObject, key), classGroupId, theme);\n }\n};\nconst getPart = (classPartObject, path) => {\n let current = classPartObject;\n const parts = path.split(CLASS_PART_SEPARATOR);\n const len = parts.length;\n for (let i = 0; i < len; i++) {\n const part = parts[i];\n let next = current.nextPart.get(part);\n if (!next) {\n next = createClassPartObject();\n current.nextPart.set(part, next);\n }\n current = next;\n }\n return current;\n};\n// Type guard maintains monomorphic check\nconst isThemeGetter = func => 'isThemeGetter' in func && func.isThemeGetter === true;\n\n// LRU cache implementation using plain objects for simplicity\nconst createLruCache = maxCacheSize => {\n if (maxCacheSize < 1) {\n return {\n get: () => undefined,\n set: () => {}\n };\n }\n let cacheSize = 0;\n let cache = Object.create(null);\n let previousCache = Object.create(null);\n const update = (key, value) => {\n cache[key] = value;\n cacheSize++;\n if (cacheSize > maxCacheSize) {\n cacheSize = 0;\n previousCache = cache;\n cache = Object.create(null);\n }\n };\n return {\n get(key) {\n let value = cache[key];\n if (value !== undefined) {\n return value;\n }\n if ((value = previousCache[key]) !== undefined) {\n update(key, value);\n return value;\n }\n },\n set(key, value) {\n if (key in cache) {\n cache[key] = value;\n } else {\n update(key, value);\n }\n }\n };\n};\nconst IMPORTANT_MODIFIER = '!';\nconst MODIFIER_SEPARATOR = ':';\nconst EMPTY_MODIFIERS = [];\n// Pre-allocated result object shape for consistency\nconst createResultObject = (modifiers, hasImportantModifier, baseClassName, maybePostfixModifierPosition, isExternal) => ({\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition,\n isExternal\n});\nconst createParseClassName = config => {\n const {\n prefix,\n experimentalParseClassName\n } = config;\n /**\n * Parse class name into parts.\n *\n * Inspired by `splitAtTopLevelOnly` used in Tailwind CSS\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v3.2.2/src/util/splitAtTopLevelOnly.js\n */\n let parseClassName = className => {\n // Use simple array with push for better performance\n const modifiers = [];\n let bracketDepth = 0;\n let parenDepth = 0;\n let modifierStart = 0;\n let postfixModifierPosition;\n const len = className.length;\n for (let index = 0; index < len; index++) {\n const currentCharacter = className[index];\n if (bracketDepth === 0 && parenDepth === 0) {\n if (currentCharacter === MODIFIER_SEPARATOR) {\n modifiers.push(className.slice(modifierStart, index));\n modifierStart = index + 1;\n continue;\n }\n if (currentCharacter === '/') {\n postfixModifierPosition = index;\n continue;\n }\n }\n if (currentCharacter === '[') bracketDepth++;else if (currentCharacter === ']') bracketDepth--;else if (currentCharacter === '(') parenDepth++;else if (currentCharacter === ')') parenDepth--;\n }\n const baseClassNameWithImportantModifier = modifiers.length === 0 ? className : className.slice(modifierStart);\n // Inline important modifier check\n let baseClassName = baseClassNameWithImportantModifier;\n let hasImportantModifier = false;\n if (baseClassNameWithImportantModifier.endsWith(IMPORTANT_MODIFIER)) {\n baseClassName = baseClassNameWithImportantModifier.slice(0, -1);\n hasImportantModifier = true;\n } else if (\n /**\n * In Tailwind CSS v3 the important modifier was at the start of the base class name. This is still supported for legacy reasons.\n * @see https://github.com/dcastil/tailwind-merge/issues/513#issuecomment-2614029864\n */\n baseClassNameWithImportantModifier.startsWith(IMPORTANT_MODIFIER)) {\n baseClassName = baseClassNameWithImportantModifier.slice(1);\n hasImportantModifier = true;\n }\n const maybePostfixModifierPosition = postfixModifierPosition && postfixModifierPosition > modifierStart ? postfixModifierPosition - modifierStart : undefined;\n return createResultObject(modifiers, hasImportantModifier, baseClassName, maybePostfixModifierPosition);\n };\n if (prefix) {\n const fullPrefix = prefix + MODIFIER_SEPARATOR;\n const parseClassNameOriginal = parseClassName;\n parseClassName = className => className.startsWith(fullPrefix) ? parseClassNameOriginal(className.slice(fullPrefix.length)) : createResultObject(EMPTY_MODIFIERS, false, className, undefined, true);\n }\n if (experimentalParseClassName) {\n const parseClassNameOriginal = parseClassName;\n parseClassName = className => experimentalParseClassName({\n className,\n parseClassName: parseClassNameOriginal\n });\n }\n return parseClassName;\n};\n\n/**\n * Sorts modifiers according to following schema:\n * - Predefined modifiers are sorted alphabetically\n * - When an arbitrary variant appears, it must be preserved which modifiers are before and after it\n */\nconst createSortModifiers = config => {\n // Pre-compute weights for all known modifiers for O(1) comparison\n const modifierWeights = new Map();\n // Assign weights to sensitive modifiers (highest priority, but preserve order)\n config.orderSensitiveModifiers.forEach((mod, index) => {\n modifierWeights.set(mod, 1000000 + index); // High weights for sensitive mods\n });\n return modifiers => {\n const result = [];\n let currentSegment = [];\n // Process modifiers in one pass\n for (let i = 0; i < modifiers.length; i++) {\n const modifier = modifiers[i];\n // Check if modifier is sensitive (starts with '[' or in orderSensitiveModifiers)\n const isArbitrary = modifier[0] === '[';\n const isOrderSensitive = modifierWeights.has(modifier);\n if (isArbitrary || isOrderSensitive) {\n // Sort and flush current segment alphabetically\n if (currentSegment.length > 0) {\n currentSegment.sort();\n result.push(...currentSegment);\n currentSegment = [];\n }\n result.push(modifier);\n } else {\n // Regular modifier - add to current segment for batch sorting\n currentSegment.push(modifier);\n }\n }\n // Sort and add any remaining segment items\n if (currentSegment.length > 0) {\n currentSegment.sort();\n result.push(...currentSegment);\n }\n return result;\n };\n};\nconst createConfigUtils = config => ({\n cache: createLruCache(config.cacheSize),\n parseClassName: createParseClassName(config),\n sortModifiers: createSortModifiers(config),\n ...createClassGroupUtils(config)\n});\nconst SPLIT_CLASSES_REGEX = /\\s+/;\nconst mergeClassList = (classList, configUtils) => {\n const {\n parseClassName,\n getClassGroupId,\n getConflictingClassGroupIds,\n sortModifiers\n } = configUtils;\n /**\n * Set of classGroupIds in following format:\n * `{importantModifier}{variantModifiers}{classGroupId}`\n * @example 'float'\n * @example 'hover:focus:bg-color'\n * @example 'md:!pr'\n */\n const classGroupsInConflict = [];\n const classNames = classList.trim().split(SPLIT_CLASSES_REGEX);\n let result = '';\n for (let index = classNames.length - 1; index >= 0; index -= 1) {\n const originalClassName = classNames[index];\n const {\n isExternal,\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition\n } = parseClassName(originalClassName);\n if (isExternal) {\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n let hasPostfixModifier = !!maybePostfixModifierPosition;\n let classGroupId = getClassGroupId(hasPostfixModifier ? baseClassName.substring(0, maybePostfixModifierPosition) : baseClassName);\n if (!classGroupId) {\n if (!hasPostfixModifier) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n classGroupId = getClassGroupId(baseClassName);\n if (!classGroupId) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n hasPostfixModifier = false;\n }\n // Fast path: skip sorting for empty or single modifier\n const variantModifier = modifiers.length === 0 ? '' : modifiers.length === 1 ? modifiers[0] : sortModifiers(modifiers).join(':');\n const modifierId = hasImportantModifier ? variantModifier + IMPORTANT_MODIFIER : variantModifier;\n const classId = modifierId + classGroupId;\n if (classGroupsInConflict.indexOf(classId) > -1) {\n // Tailwind class omitted due to conflict\n continue;\n }\n classGroupsInConflict.push(classId);\n const conflictGroups = getConflictingClassGroupIds(classGroupId, hasPostfixModifier);\n for (let i = 0; i < conflictGroups.length; ++i) {\n const group = conflictGroups[i];\n classGroupsInConflict.push(modifierId + group);\n }\n // Tailwind class not in conflict\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n }\n return result;\n};\n\n/**\n * The code in this file is copied from https://github.com/lukeed/clsx and modified to suit the needs of tailwind-merge better.\n *\n * Specifically:\n * - Runtime code from https://github.com/lukeed/clsx/blob/v1.2.1/src/index.js\n * - TypeScript types from https://github.com/lukeed/clsx/blob/v1.2.1/clsx.d.ts\n *\n * Original code has MIT license: Copyright (c) Luke Edwards <luke.edwards05@gmail.com> (lukeed.com)\n */\nconst twJoin = (...classLists) => {\n let index = 0;\n let argument;\n let resolvedValue;\n let string = '';\n while (index < classLists.length) {\n if (argument = classLists[index++]) {\n if (resolvedValue = toValue(argument)) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n};\nconst toValue = mix => {\n // Fast path for strings\n if (typeof mix === 'string') {\n return mix;\n }\n let resolvedValue;\n let string = '';\n for (let k = 0; k < mix.length; k++) {\n if (mix[k]) {\n if (resolvedValue = toValue(mix[k])) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n};\nconst createTailwindMerge = (createConfigFirst, ...createConfigRest) => {\n let configUtils;\n let cacheGet;\n let cacheSet;\n let functionToCall;\n const initTailwindMerge = classList => {\n const config = createConfigRest.reduce((previousConfig, createConfigCurrent) => createConfigCurrent(previousConfig), createConfigFirst());\n configUtils = createConfigUtils(config);\n cacheGet = configUtils.cache.get;\n cacheSet = configUtils.cache.set;\n functionToCall = tailwindMerge;\n return tailwindMerge(classList);\n };\n const tailwindMerge = classList => {\n const cachedResult = cacheGet(classList);\n if (cachedResult) {\n return cachedResult;\n }\n const result = mergeClassList(classList, configUtils);\n cacheSet(classList, result);\n return result;\n };\n functionToCall = initTailwindMerge;\n return (...args) => functionToCall(twJoin(...args));\n};\nconst fallbackThemeArr = [];\nconst fromTheme = key => {\n const themeGetter = theme => theme[key] || fallbackThemeArr;\n themeGetter.isThemeGetter = true;\n return themeGetter;\n};\nconst arbitraryValueRegex = /^\\[(?:(\\w[\\w-]*):)?(.+)\\]$/i;\nconst arbitraryVariableRegex = /^\\((?:(\\w[\\w-]*):)?(.+)\\)$/i;\nconst fractionRegex = /^\\d+(?:\\.\\d+)?\\/\\d+(?:\\.\\d+)?$/;\nconst tshirtUnitRegex = /^(\\d+(\\.\\d+)?)?(xs|sm|md|lg|xl)$/;\nconst lengthUnitRegex = /\\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\\b(calc|min|max|clamp)\\(.+\\)|^0$/;\nconst colorFunctionRegex = /^(rgba?|hsla?|hwb|(ok)?(lab|lch)|color-mix)\\(.+\\)$/;\n// Shadow always begins with x and y offset separated by underscore optionally prepended by inset\nconst shadowRegex = /^(inset_)?-?((\\d+)?\\.?(\\d+)[a-z]+|0)_-?((\\d+)?\\.?(\\d+)[a-z]+|0)/;\nconst imageRegex = /^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\\(.+\\)$/;\nconst isFraction = value => fractionRegex.test(value);\nconst isNumber = value => !!value && !Number.isNaN(Number(value));\nconst isInteger = value => !!value && Number.isInteger(Number(value));\nconst isPercent = value => value.endsWith('%') && isNumber(value.slice(0, -1));\nconst isTshirtSize = value => tshirtUnitRegex.test(value);\nconst isAny = () => true;\nconst isLengthOnly = value =>\n// `colorFunctionRegex` check is necessary because color functions can have percentages in them which which would be incorrectly classified as lengths.\n// For example, `hsl(0 0% 0%)` would be classified as a length without this check.\n// I could also use lookbehind assertion in `lengthUnitRegex` but that isn't supported widely enough.\nlengthUnitRegex.test(value) && !colorFunctionRegex.test(value);\nconst isNever = () => false;\nconst isShadow = value => shadowRegex.test(value);\nconst isImage = value => imageRegex.test(value);\nconst isAnyNonArbitrary = value => !isArbitraryValue(value) && !isArbitraryVariable(value);\nconst isArbitrarySize = value => getIsArbitraryValue(value, isLabelSize, isNever);\nconst isArbitraryValue = value => arbitraryValueRegex.test(value);\nconst isArbitraryLength = value => getIsArbitraryValue(value, isLabelLength, isLengthOnly);\nconst isArbitraryNumber = value => getIsArbitraryValue(value, isLabelNumber, isNumber);\nconst isArbitraryWeight = value => getIsArbitraryValue(value, isLabelWeight, isAny);\nconst isArbitraryFamilyName = value => getIsArbitraryValue(value, isLabelFamilyName, isNever);\nconst isArbitraryPosition = value => getIsArbitraryValue(value, isLabelPosition, isNever);\nconst isArbitraryImage = value => getIsArbitraryValue(value, isLabelImage, isImage);\nconst isArbitraryShadow = value => getIsArbitraryValue(value, isLabelShadow, isShadow);\nconst isArbitraryVariable = value => arbitraryVariableRegex.test(value);\nconst isArbitraryVariableLength = value => getIsArbitraryVariable(value, isLabelLength);\nconst isArbitraryVariableFamilyName = value => getIsArbitraryVariable(value, isLabelFamilyName);\nconst isArbitraryVariablePosition = value => getIsArbitraryVariable(value, isLabelPosition);\nconst isArbitraryVariableSize = value => getIsArbitraryVariable(value, isLabelSize);\nconst isArbitraryVariableImage = value => getIsArbitraryVariable(value, isLabelImage);\nconst isArbitraryVariableShadow = value => getIsArbitraryVariable(value, isLabelShadow, true);\nconst isArbitraryVariableWeight = value => getIsArbitraryVariable(value, isLabelWeight, true);\n// Helpers\nconst getIsArbitraryValue = (value, testLabel, testValue) => {\n const result = arbitraryValueRegex.exec(value);\n if (result) {\n if (result[1]) {\n return testLabel(result[1]);\n }\n return testValue(result[2]);\n }\n return false;\n};\nconst getIsArbitraryVariable = (value, testLabel, shouldMatchNoLabel = false) => {\n const result = arbitraryVariableRegex.exec(value);\n if (result) {\n if (result[1]) {\n return testLabel(result[1]);\n }\n return shouldMatchNoLabel;\n }\n return false;\n};\n// Labels\nconst isLabelPosition = label => label === 'position' || label === 'percentage';\nconst isLabelImage = label => label === 'image' || label === 'url';\nconst isLabelSize = label => label === 'length' || label === 'size' || label === 'bg-size';\nconst isLabelLength = label => label === 'length';\nconst isLabelNumber = label => label === 'number';\nconst isLabelFamilyName = label => label === 'family-name';\nconst isLabelWeight = label => label === 'number' || label === 'weight';\nconst isLabelShadow = label => label === 'shadow';\nconst validators = /*#__PURE__*/Object.defineProperty({\n __proto__: null,\n isAny,\n isAnyNonArbitrary,\n isArbitraryFamilyName,\n isArbitraryImage,\n isArbitraryLength,\n isArbitraryNumber,\n isArbitraryPosition,\n isArbitraryShadow,\n isArbitrarySize,\n isArbitraryValue,\n isArbitraryVariable,\n isArbitraryVariableFamilyName,\n isArbitraryVariableImage,\n isArbitraryVariableLength,\n isArbitraryVariablePosition,\n isArbitraryVariableShadow,\n isArbitraryVariableSize,\n isArbitraryVariableWeight,\n isArbitraryWeight,\n isFraction,\n isInteger,\n isNumber,\n isPercent,\n isTshirtSize\n}, Symbol.toStringTag, {\n value: 'Module'\n});\nconst getDefaultConfig = () => {\n /**\n * Theme getters for theme variable namespaces\n * @see https://tailwindcss.com/docs/theme#theme-variable-namespaces\n */\n /***/\n const themeColor = fromTheme('color');\n const themeFont = fromTheme('font');\n const themeText = fromTheme('text');\n const themeFontWeight = fromTheme('font-weight');\n const themeTracking = fromTheme('tracking');\n const themeLeading = fromTheme('leading');\n const themeBreakpoint = fromTheme('breakpoint');\n const themeContainer = fromTheme('container');\n const themeSpacing = fromTheme('spacing');\n const themeRadius = fromTheme('radius');\n const themeShadow = fromTheme('shadow');\n const themeInsetShadow = fromTheme('inset-shadow');\n const themeTextShadow = fromTheme('text-shadow');\n const themeDropShadow = fromTheme('drop-shadow');\n const themeBlur = fromTheme('blur');\n const themePerspective = fromTheme('perspective');\n const themeAspect = fromTheme('aspect');\n const themeEase = fromTheme('ease');\n const themeAnimate = fromTheme('animate');\n /**\n * Helpers to avoid repeating the same scales\n *\n * We use functions that create a new array every time they're called instead of static arrays.\n * This ensures that users who modify any scale by mutating the array (e.g. with `array.push(element)`) don't accidentally mutate arrays in other parts of the config.\n */\n /***/\n const scaleBreak = () => ['auto', 'avoid', 'all', 'avoid-page', 'page', 'left', 'right', 'column'];\n const scalePosition = () => ['center', 'top', 'bottom', 'left', 'right', 'top-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-top', 'top-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-top', 'bottom-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-bottom', 'bottom-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-bottom'];\n const scalePositionWithArbitrary = () => [...scalePosition(), isArbitraryVariable, isArbitraryValue];\n const scaleOverflow = () => ['auto', 'hidden', 'clip', 'visible', 'scroll'];\n const scaleOverscroll = () => ['auto', 'contain', 'none'];\n const scaleUnambiguousSpacing = () => [isArbitraryVariable, isArbitraryValue, themeSpacing];\n const scaleInset = () => [isFraction, 'full', 'auto', ...scaleUnambiguousSpacing()];\n const scaleGridTemplateColsRows = () => [isInteger, 'none', 'subgrid', isArbitraryVariable, isArbitraryValue];\n const scaleGridColRowStartAndEnd = () => ['auto', {\n span: ['full', isInteger, isArbitraryVariable, isArbitraryValue]\n }, isInteger, isArbitraryVariable, isArbitraryValue];\n const scaleGridColRowStartOrEnd = () => [isInteger, 'auto', isArbitraryVariable, isArbitraryValue];\n const scaleGridAutoColsRows = () => ['auto', 'min', 'max', 'fr', isArbitraryVariable, isArbitraryValue];\n const scaleAlignPrimaryAxis = () => ['start', 'end', 'center', 'between', 'around', 'evenly', 'stretch', 'baseline', 'center-safe', 'end-safe'];\n const scaleAlignSecondaryAxis = () => ['start', 'end', 'center', 'stretch', 'center-safe', 'end-safe'];\n const scaleMargin = () => ['auto', ...scaleUnambiguousSpacing()];\n const scaleSizing = () => [isFraction, 'auto', 'full', 'dvw', 'dvh', 'lvw', 'lvh', 'svw', 'svh', 'min', 'max', 'fit', ...scaleUnambiguousSpacing()];\n const scaleSizingInline = () => [isFraction, 'screen', 'full', 'dvw', 'lvw', 'svw', 'min', 'max', 'fit', ...scaleUnambiguousSpacing()];\n const scaleSizingBlock = () => [isFraction, 'screen', 'full', 'lh', 'dvh', 'lvh', 'svh', 'min', 'max', 'fit', ...scaleUnambiguousSpacing()];\n const scaleColor = () => [themeColor, isArbitraryVariable, isArbitraryValue];\n const scaleBgPosition = () => [...scalePosition(), isArbitraryVariablePosition, isArbitraryPosition, {\n position: [isArbitraryVariable, isArbitraryValue]\n }];\n const scaleBgRepeat = () => ['no-repeat', {\n repeat: ['', 'x', 'y', 'space', 'round']\n }];\n const scaleBgSize = () => ['auto', 'cover', 'contain', isArbitraryVariableSize, isArbitrarySize, {\n size: [isArbitraryVariable, isArbitraryValue]\n }];\n const scaleGradientStopPosition = () => [isPercent, isArbitraryVariableLength, isArbitraryLength];\n const scaleRadius = () => [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', 'full', themeRadius, isArbitraryVariable, isArbitraryValue];\n const scaleBorderWidth = () => ['', isNumber, isArbitraryVariableLength, isArbitraryLength];\n const scaleLineStyle = () => ['solid', 'dashed', 'dotted', 'double'];\n const scaleBlendMode = () => ['normal', 'multiply', 'screen', 'overlay', 'darken', 'lighten', 'color-dodge', 'color-burn', 'hard-light', 'soft-light', 'difference', 'exclusion', 'hue', 'saturation', 'color', 'luminosity'];\n const scaleMaskImagePosition = () => [isNumber, isPercent, isArbitraryVariablePosition, isArbitraryPosition];\n const scaleBlur = () => [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeBlur, isArbitraryVariable, isArbitraryValue];\n const scaleRotate = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleScale = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleSkew = () => [isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleTranslate = () => [isFraction, 'full', ...scaleUnambiguousSpacing()];\n return {\n cacheSize: 500,\n theme: {\n animate: ['spin', 'ping', 'pulse', 'bounce'],\n aspect: ['video'],\n blur: [isTshirtSize],\n breakpoint: [isTshirtSize],\n color: [isAny],\n container: [isTshirtSize],\n 'drop-shadow': [isTshirtSize],\n ease: ['in', 'out', 'in-out'],\n font: [isAnyNonArbitrary],\n 'font-weight': ['thin', 'extralight', 'light', 'normal', 'medium', 'semibold', 'bold', 'extrabold', 'black'],\n 'inset-shadow': [isTshirtSize],\n leading: ['none', 'tight', 'snug', 'normal', 'relaxed', 'loose'],\n perspective: ['dramatic', 'near', 'normal', 'midrange', 'distant', 'none'],\n radius: [isTshirtSize],\n shadow: [isTshirtSize],\n spacing: ['px', isNumber],\n text: [isTshirtSize],\n 'text-shadow': [isTshirtSize],\n tracking: ['tighter', 'tight', 'normal', 'wide', 'wider', 'widest']\n },\n classGroups: {\n // --------------\n // --- Layout ---\n // --------------\n /**\n * Aspect Ratio\n * @see https://tailwindcss.com/docs/aspect-ratio\n */\n aspect: [{\n aspect: ['auto', 'square', isFraction, isArbitraryValue, isArbitraryVariable, themeAspect]\n }],\n /**\n * Container\n * @see https://tailwindcss.com/docs/container\n * @deprecated since Tailwind CSS v4.0.0\n */\n container: ['container'],\n /**\n * Columns\n * @see https://tailwindcss.com/docs/columns\n */\n columns: [{\n columns: [isNumber, isArbitraryValue, isArbitraryVariable, themeContainer]\n }],\n /**\n * Break After\n * @see https://tailwindcss.com/docs/break-after\n */\n 'break-after': [{\n 'break-after': scaleBreak()\n }],\n /**\n * Break Before\n * @see https://tailwindcss.com/docs/break-before\n */\n 'break-before': [{\n 'break-before': scaleBreak()\n }],\n /**\n * Break Inside\n * @see https://tailwindcss.com/docs/break-inside\n */\n 'break-inside': [{\n 'break-inside': ['auto', 'avoid', 'avoid-page', 'avoid-column']\n }],\n /**\n * Box Decoration Break\n * @see https://tailwindcss.com/docs/box-decoration-break\n */\n 'box-decoration': [{\n 'box-decoration': ['slice', 'clone']\n }],\n /**\n * Box Sizing\n * @see https://tailwindcss.com/docs/box-sizing\n */\n box: [{\n box: ['border', 'content']\n }],\n /**\n * Display\n * @see https://tailwindcss.com/docs/display\n */\n display: ['block', 'inline-block', 'inline', 'flex', 'inline-flex', 'table', 'inline-table', 'table-caption', 'table-cell', 'table-column', 'table-column-group', 'table-footer-group', 'table-header-group', 'table-row-group', 'table-row', 'flow-root', 'grid', 'inline-grid', 'contents', 'list-item', 'hidden'],\n /**\n * Screen Reader Only\n * @see https://tailwindcss.com/docs/display#screen-reader-only\n */\n sr: ['sr-only', 'not-sr-only'],\n /**\n * Floats\n * @see https://tailwindcss.com/docs/float\n */\n float: [{\n float: ['right', 'left', 'none', 'start', 'end']\n }],\n /**\n * Clear\n * @see https://tailwindcss.com/docs/clear\n */\n clear: [{\n clear: ['left', 'right', 'both', 'none', 'start', 'end']\n }],\n /**\n * Isolation\n * @see https://tailwindcss.com/docs/isolation\n */\n isolation: ['isolate', 'isolation-auto'],\n /**\n * Object Fit\n * @see https://tailwindcss.com/docs/object-fit\n */\n 'object-fit': [{\n object: ['contain', 'cover', 'fill', 'none', 'scale-down']\n }],\n /**\n * Object Position\n * @see https://tailwindcss.com/docs/object-position\n */\n 'object-position': [{\n object: scalePositionWithArbitrary()\n }],\n /**\n * Overflow\n * @see https://tailwindcss.com/docs/overflow\n */\n overflow: [{\n overflow: scaleOverflow()\n }],\n /**\n * Overflow X\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-x': [{\n 'overflow-x': scaleOverflow()\n }],\n /**\n * Overflow Y\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-y': [{\n 'overflow-y': scaleOverflow()\n }],\n /**\n * Overscroll Behavior\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n overscroll: [{\n overscroll: scaleOverscroll()\n }],\n /**\n * Overscroll Behavior X\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-x': [{\n 'overscroll-x': scaleOverscroll()\n }],\n /**\n * Overscroll Behavior Y\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-y': [{\n 'overscroll-y': scaleOverscroll()\n }],\n /**\n * Position\n * @see https://tailwindcss.com/docs/position\n */\n position: ['static', 'fixed', 'absolute', 'relative', 'sticky'],\n /**\n * Inset\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n inset: [{\n inset: scaleInset()\n }],\n /**\n * Inset Inline\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-x': [{\n 'inset-x': scaleInset()\n }],\n /**\n * Inset Block\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-y': [{\n 'inset-y': scaleInset()\n }],\n /**\n * Inset Inline Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n * @todo class group will be renamed to `inset-s` in next major release\n */\n start: [{\n 'inset-s': scaleInset(),\n /**\n * @deprecated since Tailwind CSS v4.2.0 in favor of `inset-s-*` utilities.\n * @see https://github.com/tailwindlabs/tailwindcss/pull/19613\n */\n start: scaleInset()\n }],\n /**\n * Inset Inline End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n * @todo class group will be renamed to `inset-e` in next major release\n */\n end: [{\n 'inset-e': scaleInset(),\n /**\n * @deprecated since Tailwind CSS v4.2.0 in favor of `inset-e-*` utilities.\n * @see https://github.com/tailwindlabs/tailwindcss/pull/19613\n */\n end: scaleInset()\n }],\n /**\n * Inset Block Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-bs': [{\n 'inset-bs': scaleInset()\n }],\n /**\n * Inset Block End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-be': [{\n 'inset-be': scaleInset()\n }],\n /**\n * Top\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n top: [{\n top: scaleInset()\n }],\n /**\n * Right\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n right: [{\n right: scaleInset()\n }],\n /**\n * Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n bottom: [{\n bottom: scaleInset()\n }],\n /**\n * Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n left: [{\n left: scaleInset()\n }],\n /**\n * Visibility\n * @see https://tailwindcss.com/docs/visibility\n */\n visibility: ['visible', 'invisible', 'collapse'],\n /**\n * Z-Index\n * @see https://tailwindcss.com/docs/z-index\n */\n z: [{\n z: [isInteger, 'auto', isArbitraryVariable, isArbitraryValue]\n }],\n // ------------------------\n // --- Flexbox and Grid ---\n // ------------------------\n /**\n * Flex Basis\n * @see https://tailwindcss.com/docs/flex-basis\n */\n basis: [{\n basis: [isFraction, 'full', 'auto', themeContainer, ...scaleUnambiguousSpacing()]\n }],\n /**\n * Flex Direction\n * @see https://tailwindcss.com/docs/flex-direction\n */\n 'flex-direction': [{\n flex: ['row', 'row-reverse', 'col', 'col-reverse']\n }],\n /**\n * Flex Wrap\n * @see https://tailwindcss.com/docs/flex-wrap\n */\n 'flex-wrap': [{\n flex: ['nowrap', 'wrap', 'wrap-reverse']\n }],\n /**\n * Flex\n * @see https://tailwindcss.com/docs/flex\n */\n flex: [{\n flex: [isNumber, isFraction, 'auto', 'initial', 'none', isArbitraryValue]\n }],\n /**\n * Flex Grow\n * @see https://tailwindcss.com/docs/flex-grow\n */\n grow: [{\n grow: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Flex Shrink\n * @see https://tailwindcss.com/docs/flex-shrink\n */\n shrink: [{\n shrink: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Order\n * @see https://tailwindcss.com/docs/order\n */\n order: [{\n order: [isInteger, 'first', 'last', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Grid Template Columns\n * @see https://tailwindcss.com/docs/grid-template-columns\n */\n 'grid-cols': [{\n 'grid-cols': scaleGridTemplateColsRows()\n }],\n /**\n * Grid Column Start / End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start-end': [{\n col: scaleGridColRowStartAndEnd()\n }],\n /**\n * Grid Column Start\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start': [{\n 'col-start': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Column End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-end': [{\n 'col-end': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Template Rows\n * @see https://tailwindcss.com/docs/grid-template-rows\n */\n 'grid-rows': [{\n 'grid-rows': scaleGridTemplateColsRows()\n }],\n /**\n * Grid Row Start / End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start-end': [{\n row: scaleGridColRowStartAndEnd()\n }],\n /**\n * Grid Row Start\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start': [{\n 'row-start': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Row End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-end': [{\n 'row-end': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Auto Flow\n * @see https://tailwindcss.com/docs/grid-auto-flow\n */\n 'grid-flow': [{\n 'grid-flow': ['row', 'col', 'dense', 'row-dense', 'col-dense']\n }],\n /**\n * Grid Auto Columns\n * @see https://tailwindcss.com/docs/grid-auto-columns\n */\n 'auto-cols': [{\n 'auto-cols': scaleGridAutoColsRows()\n }],\n /**\n * Grid Auto Rows\n * @see https://tailwindcss.com/docs/grid-auto-rows\n */\n 'auto-rows': [{\n 'auto-rows': scaleGridAutoColsRows()\n }],\n /**\n * Gap\n * @see https://tailwindcss.com/docs/gap\n */\n gap: [{\n gap: scaleUnambiguousSpacing()\n }],\n /**\n * Gap X\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-x': [{\n 'gap-x': scaleUnambiguousSpacing()\n }],\n /**\n * Gap Y\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-y': [{\n 'gap-y': scaleUnambiguousSpacing()\n }],\n /**\n * Justify Content\n * @see https://tailwindcss.com/docs/justify-content\n */\n 'justify-content': [{\n justify: [...scaleAlignPrimaryAxis(), 'normal']\n }],\n /**\n * Justify Items\n * @see https://tailwindcss.com/docs/justify-items\n */\n 'justify-items': [{\n 'justify-items': [...scaleAlignSecondaryAxis(), 'normal']\n }],\n /**\n * Justify Self\n * @see https://tailwindcss.com/docs/justify-self\n */\n 'justify-self': [{\n 'justify-self': ['auto', ...scaleAlignSecondaryAxis()]\n }],\n /**\n * Align Content\n * @see https://tailwindcss.com/docs/align-content\n */\n 'align-content': [{\n content: ['normal', ...scaleAlignPrimaryAxis()]\n }],\n /**\n * Align Items\n * @see https://tailwindcss.com/docs/align-items\n */\n 'align-items': [{\n items: [...scaleAlignSecondaryAxis(), {\n baseline: ['', 'last']\n }]\n }],\n /**\n * Align Self\n * @see https://tailwindcss.com/docs/align-self\n */\n 'align-self': [{\n self: ['auto', ...scaleAlignSecondaryAxis(), {\n baseline: ['', 'last']\n }]\n }],\n /**\n * Place Content\n * @see https://tailwindcss.com/docs/place-content\n */\n 'place-content': [{\n 'place-content': scaleAlignPrimaryAxis()\n }],\n /**\n * Place Items\n * @see https://tailwindcss.com/docs/place-items\n */\n 'place-items': [{\n 'place-items': [...scaleAlignSecondaryAxis(), 'baseline']\n }],\n /**\n * Place Self\n * @see https://tailwindcss.com/docs/place-self\n */\n 'place-self': [{\n 'place-self': ['auto', ...scaleAlignSecondaryAxis()]\n }],\n // Spacing\n /**\n * Padding\n * @see https://tailwindcss.com/docs/padding\n */\n p: [{\n p: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Inline\n * @see https://tailwindcss.com/docs/padding\n */\n px: [{\n px: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Block\n * @see https://tailwindcss.com/docs/padding\n */\n py: [{\n py: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Inline Start\n * @see https://tailwindcss.com/docs/padding\n */\n ps: [{\n ps: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Inline End\n * @see https://tailwindcss.com/docs/padding\n */\n pe: [{\n pe: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Block Start\n * @see https://tailwindcss.com/docs/padding\n */\n pbs: [{\n pbs: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Block End\n * @see https://tailwindcss.com/docs/padding\n */\n pbe: [{\n pbe: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Top\n * @see https://tailwindcss.com/docs/padding\n */\n pt: [{\n pt: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Right\n * @see https://tailwindcss.com/docs/padding\n */\n pr: [{\n pr: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Bottom\n * @see https://tailwindcss.com/docs/padding\n */\n pb: [{\n pb: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Left\n * @see https://tailwindcss.com/docs/padding\n */\n pl: [{\n pl: scaleUnambiguousSpacing()\n }],\n /**\n * Margin\n * @see https://tailwindcss.com/docs/margin\n */\n m: [{\n m: scaleMargin()\n }],\n /**\n * Margin Inline\n * @see https://tailwindcss.com/docs/margin\n */\n mx: [{\n mx: scaleMargin()\n }],\n /**\n * Margin Block\n * @see https://tailwindcss.com/docs/margin\n */\n my: [{\n my: scaleMargin()\n }],\n /**\n * Margin Inline Start\n * @see https://tailwindcss.com/docs/margin\n */\n ms: [{\n ms: scaleMargin()\n }],\n /**\n * Margin Inline End\n * @see https://tailwindcss.com/docs/margin\n */\n me: [{\n me: scaleMargin()\n }],\n /**\n * Margin Block Start\n * @see https://tailwindcss.com/docs/margin\n */\n mbs: [{\n mbs: scaleMargin()\n }],\n /**\n * Margin Block End\n * @see https://tailwindcss.com/docs/margin\n */\n mbe: [{\n mbe: scaleMargin()\n }],\n /**\n * Margin Top\n * @see https://tailwindcss.com/docs/margin\n */\n mt: [{\n mt: scaleMargin()\n }],\n /**\n * Margin Right\n * @see https://tailwindcss.com/docs/margin\n */\n mr: [{\n mr: scaleMargin()\n }],\n /**\n * Margin Bottom\n * @see https://tailwindcss.com/docs/margin\n */\n mb: [{\n mb: scaleMargin()\n }],\n /**\n * Margin Left\n * @see https://tailwindcss.com/docs/margin\n */\n ml: [{\n ml: scaleMargin()\n }],\n /**\n * Space Between X\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x': [{\n 'space-x': scaleUnambiguousSpacing()\n }],\n /**\n * Space Between X Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x-reverse': ['space-x-reverse'],\n /**\n * Space Between Y\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y': [{\n 'space-y': scaleUnambiguousSpacing()\n }],\n /**\n * Space Between Y Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y-reverse': ['space-y-reverse'],\n // --------------\n // --- Sizing ---\n // --------------\n /**\n * Size\n * @see https://tailwindcss.com/docs/width#setting-both-width-and-height\n */\n size: [{\n size: scaleSizing()\n }],\n /**\n * Inline Size\n * @see https://tailwindcss.com/docs/width\n */\n 'inline-size': [{\n inline: ['auto', ...scaleSizingInline()]\n }],\n /**\n * Min-Inline Size\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-inline-size': [{\n 'min-inline': ['auto', ...scaleSizingInline()]\n }],\n /**\n * Max-Inline Size\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-inline-size': [{\n 'max-inline': ['none', ...scaleSizingInline()]\n }],\n /**\n * Block Size\n * @see https://tailwindcss.com/docs/height\n */\n 'block-size': [{\n block: ['auto', ...scaleSizingBlock()]\n }],\n /**\n * Min-Block Size\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-block-size': [{\n 'min-block': ['auto', ...scaleSizingBlock()]\n }],\n /**\n * Max-Block Size\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-block-size': [{\n 'max-block': ['none', ...scaleSizingBlock()]\n }],\n /**\n * Width\n * @see https://tailwindcss.com/docs/width\n */\n w: [{\n w: [themeContainer, 'screen', ...scaleSizing()]\n }],\n /**\n * Min-Width\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-w': [{\n 'min-w': [themeContainer, 'screen', /** Deprecated. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'none', ...scaleSizing()]\n }],\n /**\n * Max-Width\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-w': [{\n 'max-w': [themeContainer, 'screen', 'none', /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'prose', /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n {\n screen: [themeBreakpoint]\n }, ...scaleSizing()]\n }],\n /**\n * Height\n * @see https://tailwindcss.com/docs/height\n */\n h: [{\n h: ['screen', 'lh', ...scaleSizing()]\n }],\n /**\n * Min-Height\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-h': [{\n 'min-h': ['screen', 'lh', 'none', ...scaleSizing()]\n }],\n /**\n * Max-Height\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-h': [{\n 'max-h': ['screen', 'lh', ...scaleSizing()]\n }],\n // ------------------\n // --- Typography ---\n // ------------------\n /**\n * Font Size\n * @see https://tailwindcss.com/docs/font-size\n */\n 'font-size': [{\n text: ['base', themeText, isArbitraryVariableLength, isArbitraryLength]\n }],\n /**\n * Font Smoothing\n * @see https://tailwindcss.com/docs/font-smoothing\n */\n 'font-smoothing': ['antialiased', 'subpixel-antialiased'],\n /**\n * Font Style\n * @see https://tailwindcss.com/docs/font-style\n */\n 'font-style': ['italic', 'not-italic'],\n /**\n * Font Weight\n * @see https://tailwindcss.com/docs/font-weight\n */\n 'font-weight': [{\n font: [themeFontWeight, isArbitraryVariableWeight, isArbitraryWeight]\n }],\n /**\n * Font Stretch\n * @see https://tailwindcss.com/docs/font-stretch\n */\n 'font-stretch': [{\n 'font-stretch': ['ultra-condensed', 'extra-condensed', 'condensed', 'semi-condensed', 'normal', 'semi-expanded', 'expanded', 'extra-expanded', 'ultra-expanded', isPercent, isArbitraryValue]\n }],\n /**\n * Font Family\n * @see https://tailwindcss.com/docs/font-family\n */\n 'font-family': [{\n font: [isArbitraryVariableFamilyName, isArbitraryFamilyName, themeFont]\n }],\n /**\n * Font Feature Settings\n * @see https://tailwindcss.com/docs/font-feature-settings\n */\n 'font-features': [{\n 'font-features': [isArbitraryValue]\n }],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-normal': ['normal-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-ordinal': ['ordinal'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-slashed-zero': ['slashed-zero'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-figure': ['lining-nums', 'oldstyle-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-spacing': ['proportional-nums', 'tabular-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-fraction': ['diagonal-fractions', 'stacked-fractions'],\n /**\n * Letter Spacing\n * @see https://tailwindcss.com/docs/letter-spacing\n */\n tracking: [{\n tracking: [themeTracking, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Line Clamp\n * @see https://tailwindcss.com/docs/line-clamp\n */\n 'line-clamp': [{\n 'line-clamp': [isNumber, 'none', isArbitraryVariable, isArbitraryNumber]\n }],\n /**\n * Line Height\n * @see https://tailwindcss.com/docs/line-height\n */\n leading: [{\n leading: [/** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n themeLeading, ...scaleUnambiguousSpacing()]\n }],\n /**\n * List Style Image\n * @see https://tailwindcss.com/docs/list-style-image\n */\n 'list-image': [{\n 'list-image': ['none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * List Style Position\n * @see https://tailwindcss.com/docs/list-style-position\n */\n 'list-style-position': [{\n list: ['inside', 'outside']\n }],\n /**\n * List Style Type\n * @see https://tailwindcss.com/docs/list-style-type\n */\n 'list-style-type': [{\n list: ['disc', 'decimal', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Text Alignment\n * @see https://tailwindcss.com/docs/text-align\n */\n 'text-alignment': [{\n text: ['left', 'center', 'right', 'justify', 'start', 'end']\n }],\n /**\n * Placeholder Color\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://v3.tailwindcss.com/docs/placeholder-color\n */\n 'placeholder-color': [{\n placeholder: scaleColor()\n }],\n /**\n * Text Color\n * @see https://tailwindcss.com/docs/text-color\n */\n 'text-color': [{\n text: scaleColor()\n }],\n /**\n * Text Decoration\n * @see https://tailwindcss.com/docs/text-decoration\n */\n 'text-decoration': ['underline', 'overline', 'line-through', 'no-underline'],\n /**\n * Text Decoration Style\n * @see https://tailwindcss.com/docs/text-decoration-style\n */\n 'text-decoration-style': [{\n decoration: [...scaleLineStyle(), 'wavy']\n }],\n /**\n * Text Decoration Thickness\n * @see https://tailwindcss.com/docs/text-decoration-thickness\n */\n 'text-decoration-thickness': [{\n decoration: [isNumber, 'from-font', 'auto', isArbitraryVariable, isArbitraryLength]\n }],\n /**\n * Text Decoration Color\n * @see https://tailwindcss.com/docs/text-decoration-color\n */\n 'text-decoration-color': [{\n decoration: scaleColor()\n }],\n /**\n * Text Underline Offset\n * @see https://tailwindcss.com/docs/text-underline-offset\n */\n 'underline-offset': [{\n 'underline-offset': [isNumber, 'auto', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Text Transform\n * @see https://tailwindcss.com/docs/text-transform\n */\n 'text-transform': ['uppercase', 'lowercase', 'capitalize', 'normal-case'],\n /**\n * Text Overflow\n * @see https://tailwindcss.com/docs/text-overflow\n */\n 'text-overflow': ['truncate', 'text-ellipsis', 'text-clip'],\n /**\n * Text Wrap\n * @see https://tailwindcss.com/docs/text-wrap\n */\n 'text-wrap': [{\n text: ['wrap', 'nowrap', 'balance', 'pretty']\n }],\n /**\n * Text Indent\n * @see https://tailwindcss.com/docs/text-indent\n */\n indent: [{\n indent: scaleUnambiguousSpacing()\n }],\n /**\n * Vertical Alignment\n * @see https://tailwindcss.com/docs/vertical-align\n */\n 'vertical-align': [{\n align: ['baseline', 'top', 'middle', 'bottom', 'text-top', 'text-bottom', 'sub', 'super', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Whitespace\n * @see https://tailwindcss.com/docs/whitespace\n */\n whitespace: [{\n whitespace: ['normal', 'nowrap', 'pre', 'pre-line', 'pre-wrap', 'break-spaces']\n }],\n /**\n * Word Break\n * @see https://tailwindcss.com/docs/word-break\n */\n break: [{\n break: ['normal', 'words', 'all', 'keep']\n }],\n /**\n * Overflow Wrap\n * @see https://tailwindcss.com/docs/overflow-wrap\n */\n wrap: [{\n wrap: ['break-word', 'anywhere', 'normal']\n }],\n /**\n * Hyphens\n * @see https://tailwindcss.com/docs/hyphens\n */\n hyphens: [{\n hyphens: ['none', 'manual', 'auto']\n }],\n /**\n * Content\n * @see https://tailwindcss.com/docs/content\n */\n content: [{\n content: ['none', isArbitraryVariable, isArbitraryValue]\n }],\n // -------------------\n // --- Backgrounds ---\n // -------------------\n /**\n * Background Attachment\n * @see https://tailwindcss.com/docs/background-attachment\n */\n 'bg-attachment': [{\n bg: ['fixed', 'local', 'scroll']\n }],\n /**\n * Background Clip\n * @see https://tailwindcss.com/docs/background-clip\n */\n 'bg-clip': [{\n 'bg-clip': ['border', 'padding', 'content', 'text']\n }],\n /**\n * Background Origin\n * @see https://tailwindcss.com/docs/background-origin\n */\n 'bg-origin': [{\n 'bg-origin': ['border', 'padding', 'content']\n }],\n /**\n * Background Position\n * @see https://tailwindcss.com/docs/background-position\n */\n 'bg-position': [{\n bg: scaleBgPosition()\n }],\n /**\n * Background Repeat\n * @see https://tailwindcss.com/docs/background-repeat\n */\n 'bg-repeat': [{\n bg: scaleBgRepeat()\n }],\n /**\n * Background Size\n * @see https://tailwindcss.com/docs/background-size\n */\n 'bg-size': [{\n bg: scaleBgSize()\n }],\n /**\n * Background Image\n * @see https://tailwindcss.com/docs/background-image\n */\n 'bg-image': [{\n bg: ['none', {\n linear: [{\n to: ['t', 'tr', 'r', 'br', 'b', 'bl', 'l', 'tl']\n }, isInteger, isArbitraryVariable, isArbitraryValue],\n radial: ['', isArbitraryVariable, isArbitraryValue],\n conic: [isInteger, isArbitraryVariable, isArbitraryValue]\n }, isArbitraryVariableImage, isArbitraryImage]\n }],\n /**\n * Background Color\n * @see https://tailwindcss.com/docs/background-color\n */\n 'bg-color': [{\n bg: scaleColor()\n }],\n /**\n * Gradient Color Stops From Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from-pos': [{\n from: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops Via Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via-pos': [{\n via: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops To Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to-pos': [{\n to: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops From\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from': [{\n from: scaleColor()\n }],\n /**\n * Gradient Color Stops Via\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via': [{\n via: scaleColor()\n }],\n /**\n * Gradient Color Stops To\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to': [{\n to: scaleColor()\n }],\n // ---------------\n // --- Borders ---\n // ---------------\n /**\n * Border Radius\n * @see https://tailwindcss.com/docs/border-radius\n */\n rounded: [{\n rounded: scaleRadius()\n }],\n /**\n * Border Radius Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-s': [{\n 'rounded-s': scaleRadius()\n }],\n /**\n * Border Radius End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-e': [{\n 'rounded-e': scaleRadius()\n }],\n /**\n * Border Radius Top\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-t': [{\n 'rounded-t': scaleRadius()\n }],\n /**\n * Border Radius Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-r': [{\n 'rounded-r': scaleRadius()\n }],\n /**\n * Border Radius Bottom\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-b': [{\n 'rounded-b': scaleRadius()\n }],\n /**\n * Border Radius Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-l': [{\n 'rounded-l': scaleRadius()\n }],\n /**\n * Border Radius Start Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ss': [{\n 'rounded-ss': scaleRadius()\n }],\n /**\n * Border Radius Start End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-se': [{\n 'rounded-se': scaleRadius()\n }],\n /**\n * Border Radius End End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ee': [{\n 'rounded-ee': scaleRadius()\n }],\n /**\n * Border Radius End Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-es': [{\n 'rounded-es': scaleRadius()\n }],\n /**\n * Border Radius Top Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tl': [{\n 'rounded-tl': scaleRadius()\n }],\n /**\n * Border Radius Top Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tr': [{\n 'rounded-tr': scaleRadius()\n }],\n /**\n * Border Radius Bottom Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-br': [{\n 'rounded-br': scaleRadius()\n }],\n /**\n * Border Radius Bottom Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-bl': [{\n 'rounded-bl': scaleRadius()\n }],\n /**\n * Border Width\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w': [{\n border: scaleBorderWidth()\n }],\n /**\n * Border Width Inline\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-x': [{\n 'border-x': scaleBorderWidth()\n }],\n /**\n * Border Width Block\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-y': [{\n 'border-y': scaleBorderWidth()\n }],\n /**\n * Border Width Inline Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-s': [{\n 'border-s': scaleBorderWidth()\n }],\n /**\n * Border Width Inline End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-e': [{\n 'border-e': scaleBorderWidth()\n }],\n /**\n * Border Width Block Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-bs': [{\n 'border-bs': scaleBorderWidth()\n }],\n /**\n * Border Width Block End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-be': [{\n 'border-be': scaleBorderWidth()\n }],\n /**\n * Border Width Top\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-t': [{\n 'border-t': scaleBorderWidth()\n }],\n /**\n * Border Width Right\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-r': [{\n 'border-r': scaleBorderWidth()\n }],\n /**\n * Border Width Bottom\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-b': [{\n 'border-b': scaleBorderWidth()\n }],\n /**\n * Border Width Left\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-l': [{\n 'border-l': scaleBorderWidth()\n }],\n /**\n * Divide Width X\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x': [{\n 'divide-x': scaleBorderWidth()\n }],\n /**\n * Divide Width X Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x-reverse': ['divide-x-reverse'],\n /**\n * Divide Width Y\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y': [{\n 'divide-y': scaleBorderWidth()\n }],\n /**\n * Divide Width Y Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y-reverse': ['divide-y-reverse'],\n /**\n * Border Style\n * @see https://tailwindcss.com/docs/border-style\n */\n 'border-style': [{\n border: [...scaleLineStyle(), 'hidden', 'none']\n }],\n /**\n * Divide Style\n * @see https://tailwindcss.com/docs/border-style#setting-the-divider-style\n */\n 'divide-style': [{\n divide: [...scaleLineStyle(), 'hidden', 'none']\n }],\n /**\n * Border Color\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color': [{\n border: scaleColor()\n }],\n /**\n * Border Color Inline\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-x': [{\n 'border-x': scaleColor()\n }],\n /**\n * Border Color Block\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-y': [{\n 'border-y': scaleColor()\n }],\n /**\n * Border Color Inline Start\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-s': [{\n 'border-s': scaleColor()\n }],\n /**\n * Border Color Inline End\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-e': [{\n 'border-e': scaleColor()\n }],\n /**\n * Border Color Block Start\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-bs': [{\n 'border-bs': scaleColor()\n }],\n /**\n * Border Color Block End\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-be': [{\n 'border-be': scaleColor()\n }],\n /**\n * Border Color Top\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-t': [{\n 'border-t': scaleColor()\n }],\n /**\n * Border Color Right\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-r': [{\n 'border-r': scaleColor()\n }],\n /**\n * Border Color Bottom\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-b': [{\n 'border-b': scaleColor()\n }],\n /**\n * Border Color Left\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-l': [{\n 'border-l': scaleColor()\n }],\n /**\n * Divide Color\n * @see https://tailwindcss.com/docs/divide-color\n */\n 'divide-color': [{\n divide: scaleColor()\n }],\n /**\n * Outline Style\n * @see https://tailwindcss.com/docs/outline-style\n */\n 'outline-style': [{\n outline: [...scaleLineStyle(), 'none', 'hidden']\n }],\n /**\n * Outline Offset\n * @see https://tailwindcss.com/docs/outline-offset\n */\n 'outline-offset': [{\n 'outline-offset': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Outline Width\n * @see https://tailwindcss.com/docs/outline-width\n */\n 'outline-w': [{\n outline: ['', isNumber, isArbitraryVariableLength, isArbitraryLength]\n }],\n /**\n * Outline Color\n * @see https://tailwindcss.com/docs/outline-color\n */\n 'outline-color': [{\n outline: scaleColor()\n }],\n // ---------------\n // --- Effects ---\n // ---------------\n /**\n * Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow\n */\n shadow: [{\n shadow: [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-shadow-color\n */\n 'shadow-color': [{\n shadow: scaleColor()\n }],\n /**\n * Inset Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-shadow\n */\n 'inset-shadow': [{\n 'inset-shadow': ['none', themeInsetShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Inset Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-shadow-color\n */\n 'inset-shadow-color': [{\n 'inset-shadow': scaleColor()\n }],\n /**\n * Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-a-ring\n */\n 'ring-w': [{\n ring: scaleBorderWidth()\n }],\n /**\n * Ring Width Inset\n * @see https://v3.tailwindcss.com/docs/ring-width#inset-rings\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-w-inset': ['ring-inset'],\n /**\n * Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-ring-color\n */\n 'ring-color': [{\n ring: scaleColor()\n }],\n /**\n * Ring Offset Width\n * @see https://v3.tailwindcss.com/docs/ring-offset-width\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-w': [{\n 'ring-offset': [isNumber, isArbitraryLength]\n }],\n /**\n * Ring Offset Color\n * @see https://v3.tailwindcss.com/docs/ring-offset-color\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-color': [{\n 'ring-offset': scaleColor()\n }],\n /**\n * Inset Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-ring\n */\n 'inset-ring-w': [{\n 'inset-ring': scaleBorderWidth()\n }],\n /**\n * Inset Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-ring-color\n */\n 'inset-ring-color': [{\n 'inset-ring': scaleColor()\n }],\n /**\n * Text Shadow\n * @see https://tailwindcss.com/docs/text-shadow\n */\n 'text-shadow': [{\n 'text-shadow': ['none', themeTextShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Text Shadow Color\n * @see https://tailwindcss.com/docs/text-shadow#setting-the-shadow-color\n */\n 'text-shadow-color': [{\n 'text-shadow': scaleColor()\n }],\n /**\n * Opacity\n * @see https://tailwindcss.com/docs/opacity\n */\n opacity: [{\n opacity: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Mix Blend Mode\n * @see https://tailwindcss.com/docs/mix-blend-mode\n */\n 'mix-blend': [{\n 'mix-blend': [...scaleBlendMode(), 'plus-darker', 'plus-lighter']\n }],\n /**\n * Background Blend Mode\n * @see https://tailwindcss.com/docs/background-blend-mode\n */\n 'bg-blend': [{\n 'bg-blend': scaleBlendMode()\n }],\n /**\n * Mask Clip\n * @see https://tailwindcss.com/docs/mask-clip\n */\n 'mask-clip': [{\n 'mask-clip': ['border', 'padding', 'content', 'fill', 'stroke', 'view']\n }, 'mask-no-clip'],\n /**\n * Mask Composite\n * @see https://tailwindcss.com/docs/mask-composite\n */\n 'mask-composite': [{\n mask: ['add', 'subtract', 'intersect', 'exclude']\n }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image-linear-pos': [{\n 'mask-linear': [isNumber]\n }],\n 'mask-image-linear-from-pos': [{\n 'mask-linear-from': scaleMaskImagePosition()\n }],\n 'mask-image-linear-to-pos': [{\n 'mask-linear-to': scaleMaskImagePosition()\n }],\n 'mask-image-linear-from-color': [{\n 'mask-linear-from': scaleColor()\n }],\n 'mask-image-linear-to-color': [{\n 'mask-linear-to': scaleColor()\n }],\n 'mask-image-t-from-pos': [{\n 'mask-t-from': scaleMaskImagePosition()\n }],\n 'mask-image-t-to-pos': [{\n 'mask-t-to': scaleMaskImagePosition()\n }],\n 'mask-image-t-from-color': [{\n 'mask-t-from': scaleColor()\n }],\n 'mask-image-t-to-color': [{\n 'mask-t-to': scaleColor()\n }],\n 'mask-image-r-from-pos': [{\n 'mask-r-from': scaleMaskImagePosition()\n }],\n 'mask-image-r-to-pos': [{\n 'mask-r-to': scaleMaskImagePosition()\n }],\n 'mask-image-r-from-color': [{\n 'mask-r-from': scaleColor()\n }],\n 'mask-image-r-to-color': [{\n 'mask-r-to': scaleColor()\n }],\n 'mask-image-b-from-pos': [{\n 'mask-b-from': scaleMaskImagePosition()\n }],\n 'mask-image-b-to-pos': [{\n 'mask-b-to': scaleMaskImagePosition()\n }],\n 'mask-image-b-from-color': [{\n 'mask-b-from': scaleColor()\n }],\n 'mask-image-b-to-color': [{\n 'mask-b-to': scaleColor()\n }],\n 'mask-image-l-from-pos': [{\n 'mask-l-from': scaleMaskImagePosition()\n }],\n 'mask-image-l-to-pos': [{\n 'mask-l-to': scaleMaskImagePosition()\n }],\n 'mask-image-l-from-color': [{\n 'mask-l-from': scaleColor()\n }],\n 'mask-image-l-to-color': [{\n 'mask-l-to': scaleColor()\n }],\n 'mask-image-x-from-pos': [{\n 'mask-x-from': scaleMaskImagePosition()\n }],\n 'mask-image-x-to-pos': [{\n 'mask-x-to': scaleMaskImagePosition()\n }],\n 'mask-image-x-from-color': [{\n 'mask-x-from': scaleColor()\n }],\n 'mask-image-x-to-color': [{\n 'mask-x-to': scaleColor()\n }],\n 'mask-image-y-from-pos': [{\n 'mask-y-from': scaleMaskImagePosition()\n }],\n 'mask-image-y-to-pos': [{\n 'mask-y-to': scaleMaskImagePosition()\n }],\n 'mask-image-y-from-color': [{\n 'mask-y-from': scaleColor()\n }],\n 'mask-image-y-to-color': [{\n 'mask-y-to': scaleColor()\n }],\n 'mask-image-radial': [{\n 'mask-radial': [isArbitraryVariable, isArbitraryValue]\n }],\n 'mask-image-radial-from-pos': [{\n 'mask-radial-from': scaleMaskImagePosition()\n }],\n 'mask-image-radial-to-pos': [{\n 'mask-radial-to': scaleMaskImagePosition()\n }],\n 'mask-image-radial-from-color': [{\n 'mask-radial-from': scaleColor()\n }],\n 'mask-image-radial-to-color': [{\n 'mask-radial-to': scaleColor()\n }],\n 'mask-image-radial-shape': [{\n 'mask-radial': ['circle', 'ellipse']\n }],\n 'mask-image-radial-size': [{\n 'mask-radial': [{\n closest: ['side', 'corner'],\n farthest: ['side', 'corner']\n }]\n }],\n 'mask-image-radial-pos': [{\n 'mask-radial-at': scalePosition()\n }],\n 'mask-image-conic-pos': [{\n 'mask-conic': [isNumber]\n }],\n 'mask-image-conic-from-pos': [{\n 'mask-conic-from': scaleMaskImagePosition()\n }],\n 'mask-image-conic-to-pos': [{\n 'mask-conic-to': scaleMaskImagePosition()\n }],\n 'mask-image-conic-from-color': [{\n 'mask-conic-from': scaleColor()\n }],\n 'mask-image-conic-to-color': [{\n 'mask-conic-to': scaleColor()\n }],\n /**\n * Mask Mode\n * @see https://tailwindcss.com/docs/mask-mode\n */\n 'mask-mode': [{\n mask: ['alpha', 'luminance', 'match']\n }],\n /**\n * Mask Origin\n * @see https://tailwindcss.com/docs/mask-origin\n */\n 'mask-origin': [{\n 'mask-origin': ['border', 'padding', 'content', 'fill', 'stroke', 'view']\n }],\n /**\n * Mask Position\n * @see https://tailwindcss.com/docs/mask-position\n */\n 'mask-position': [{\n mask: scaleBgPosition()\n }],\n /**\n * Mask Repeat\n * @see https://tailwindcss.com/docs/mask-repeat\n */\n 'mask-repeat': [{\n mask: scaleBgRepeat()\n }],\n /**\n * Mask Size\n * @see https://tailwindcss.com/docs/mask-size\n */\n 'mask-size': [{\n mask: scaleBgSize()\n }],\n /**\n * Mask Type\n * @see https://tailwindcss.com/docs/mask-type\n */\n 'mask-type': [{\n 'mask-type': ['alpha', 'luminance']\n }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image': [{\n mask: ['none', isArbitraryVariable, isArbitraryValue]\n }],\n // ---------------\n // --- Filters ---\n // ---------------\n /**\n * Filter\n * @see https://tailwindcss.com/docs/filter\n */\n filter: [{\n filter: [\n // Deprecated since Tailwind CSS v3.0.0\n '', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Blur\n * @see https://tailwindcss.com/docs/blur\n */\n blur: [{\n blur: scaleBlur()\n }],\n /**\n * Brightness\n * @see https://tailwindcss.com/docs/brightness\n */\n brightness: [{\n brightness: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Contrast\n * @see https://tailwindcss.com/docs/contrast\n */\n contrast: [{\n contrast: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Drop Shadow\n * @see https://tailwindcss.com/docs/drop-shadow\n */\n 'drop-shadow': [{\n 'drop-shadow': [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeDropShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Drop Shadow Color\n * @see https://tailwindcss.com/docs/filter-drop-shadow#setting-the-shadow-color\n */\n 'drop-shadow-color': [{\n 'drop-shadow': scaleColor()\n }],\n /**\n * Grayscale\n * @see https://tailwindcss.com/docs/grayscale\n */\n grayscale: [{\n grayscale: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Hue Rotate\n * @see https://tailwindcss.com/docs/hue-rotate\n */\n 'hue-rotate': [{\n 'hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Invert\n * @see https://tailwindcss.com/docs/invert\n */\n invert: [{\n invert: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Saturate\n * @see https://tailwindcss.com/docs/saturate\n */\n saturate: [{\n saturate: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Sepia\n * @see https://tailwindcss.com/docs/sepia\n */\n sepia: [{\n sepia: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Filter\n * @see https://tailwindcss.com/docs/backdrop-filter\n */\n 'backdrop-filter': [{\n 'backdrop-filter': [\n // Deprecated since Tailwind CSS v3.0.0\n '', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Blur\n * @see https://tailwindcss.com/docs/backdrop-blur\n */\n 'backdrop-blur': [{\n 'backdrop-blur': scaleBlur()\n }],\n /**\n * Backdrop Brightness\n * @see https://tailwindcss.com/docs/backdrop-brightness\n */\n 'backdrop-brightness': [{\n 'backdrop-brightness': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Contrast\n * @see https://tailwindcss.com/docs/backdrop-contrast\n */\n 'backdrop-contrast': [{\n 'backdrop-contrast': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Grayscale\n * @see https://tailwindcss.com/docs/backdrop-grayscale\n */\n 'backdrop-grayscale': [{\n 'backdrop-grayscale': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Hue Rotate\n * @see https://tailwindcss.com/docs/backdrop-hue-rotate\n */\n 'backdrop-hue-rotate': [{\n 'backdrop-hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Invert\n * @see https://tailwindcss.com/docs/backdrop-invert\n */\n 'backdrop-invert': [{\n 'backdrop-invert': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Opacity\n * @see https://tailwindcss.com/docs/backdrop-opacity\n */\n 'backdrop-opacity': [{\n 'backdrop-opacity': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Saturate\n * @see https://tailwindcss.com/docs/backdrop-saturate\n */\n 'backdrop-saturate': [{\n 'backdrop-saturate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Sepia\n * @see https://tailwindcss.com/docs/backdrop-sepia\n */\n 'backdrop-sepia': [{\n 'backdrop-sepia': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n // --------------\n // --- Tables ---\n // --------------\n /**\n * Border Collapse\n * @see https://tailwindcss.com/docs/border-collapse\n */\n 'border-collapse': [{\n border: ['collapse', 'separate']\n }],\n /**\n * Border Spacing\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing': [{\n 'border-spacing': scaleUnambiguousSpacing()\n }],\n /**\n * Border Spacing X\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-x': [{\n 'border-spacing-x': scaleUnambiguousSpacing()\n }],\n /**\n * Border Spacing Y\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-y': [{\n 'border-spacing-y': scaleUnambiguousSpacing()\n }],\n /**\n * Table Layout\n * @see https://tailwindcss.com/docs/table-layout\n */\n 'table-layout': [{\n table: ['auto', 'fixed']\n }],\n /**\n * Caption Side\n * @see https://tailwindcss.com/docs/caption-side\n */\n caption: [{\n caption: ['top', 'bottom']\n }],\n // ---------------------------------\n // --- Transitions and Animation ---\n // ---------------------------------\n /**\n * Transition Property\n * @see https://tailwindcss.com/docs/transition-property\n */\n transition: [{\n transition: ['', 'all', 'colors', 'opacity', 'shadow', 'transform', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Behavior\n * @see https://tailwindcss.com/docs/transition-behavior\n */\n 'transition-behavior': [{\n transition: ['normal', 'discrete']\n }],\n /**\n * Transition Duration\n * @see https://tailwindcss.com/docs/transition-duration\n */\n duration: [{\n duration: [isNumber, 'initial', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Timing Function\n * @see https://tailwindcss.com/docs/transition-timing-function\n */\n ease: [{\n ease: ['linear', 'initial', themeEase, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Delay\n * @see https://tailwindcss.com/docs/transition-delay\n */\n delay: [{\n delay: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Animation\n * @see https://tailwindcss.com/docs/animation\n */\n animate: [{\n animate: ['none', themeAnimate, isArbitraryVariable, isArbitraryValue]\n }],\n // ------------------\n // --- Transforms ---\n // ------------------\n /**\n * Backface Visibility\n * @see https://tailwindcss.com/docs/backface-visibility\n */\n backface: [{\n backface: ['hidden', 'visible']\n }],\n /**\n * Perspective\n * @see https://tailwindcss.com/docs/perspective\n */\n perspective: [{\n perspective: [themePerspective, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Perspective Origin\n * @see https://tailwindcss.com/docs/perspective-origin\n */\n 'perspective-origin': [{\n 'perspective-origin': scalePositionWithArbitrary()\n }],\n /**\n * Rotate\n * @see https://tailwindcss.com/docs/rotate\n */\n rotate: [{\n rotate: scaleRotate()\n }],\n /**\n * Rotate X\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-x': [{\n 'rotate-x': scaleRotate()\n }],\n /**\n * Rotate Y\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-y': [{\n 'rotate-y': scaleRotate()\n }],\n /**\n * Rotate Z\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-z': [{\n 'rotate-z': scaleRotate()\n }],\n /**\n * Scale\n * @see https://tailwindcss.com/docs/scale\n */\n scale: [{\n scale: scaleScale()\n }],\n /**\n * Scale X\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-x': [{\n 'scale-x': scaleScale()\n }],\n /**\n * Scale Y\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-y': [{\n 'scale-y': scaleScale()\n }],\n /**\n * Scale Z\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-z': [{\n 'scale-z': scaleScale()\n }],\n /**\n * Scale 3D\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-3d': ['scale-3d'],\n /**\n * Skew\n * @see https://tailwindcss.com/docs/skew\n */\n skew: [{\n skew: scaleSkew()\n }],\n /**\n * Skew X\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-x': [{\n 'skew-x': scaleSkew()\n }],\n /**\n * Skew Y\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-y': [{\n 'skew-y': scaleSkew()\n }],\n /**\n * Transform\n * @see https://tailwindcss.com/docs/transform\n */\n transform: [{\n transform: [isArbitraryVariable, isArbitraryValue, '', 'none', 'gpu', 'cpu']\n }],\n /**\n * Transform Origin\n * @see https://tailwindcss.com/docs/transform-origin\n */\n 'transform-origin': [{\n origin: scalePositionWithArbitrary()\n }],\n /**\n * Transform Style\n * @see https://tailwindcss.com/docs/transform-style\n */\n 'transform-style': [{\n transform: ['3d', 'flat']\n }],\n /**\n * Translate\n * @see https://tailwindcss.com/docs/translate\n */\n translate: [{\n translate: scaleTranslate()\n }],\n /**\n * Translate X\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-x': [{\n 'translate-x': scaleTranslate()\n }],\n /**\n * Translate Y\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-y': [{\n 'translate-y': scaleTranslate()\n }],\n /**\n * Translate Z\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-z': [{\n 'translate-z': scaleTranslate()\n }],\n /**\n * Translate None\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-none': ['translate-none'],\n // ---------------------\n // --- Interactivity ---\n // ---------------------\n /**\n * Accent Color\n * @see https://tailwindcss.com/docs/accent-color\n */\n accent: [{\n accent: scaleColor()\n }],\n /**\n * Appearance\n * @see https://tailwindcss.com/docs/appearance\n */\n appearance: [{\n appearance: ['none', 'auto']\n }],\n /**\n * Caret Color\n * @see https://tailwindcss.com/docs/just-in-time-mode#caret-color-utilities\n */\n 'caret-color': [{\n caret: scaleColor()\n }],\n /**\n * Color Scheme\n * @see https://tailwindcss.com/docs/color-scheme\n */\n 'color-scheme': [{\n scheme: ['normal', 'dark', 'light', 'light-dark', 'only-dark', 'only-light']\n }],\n /**\n * Cursor\n * @see https://tailwindcss.com/docs/cursor\n */\n cursor: [{\n cursor: ['auto', 'default', 'pointer', 'wait', 'text', 'move', 'help', 'not-allowed', 'none', 'context-menu', 'progress', 'cell', 'crosshair', 'vertical-text', 'alias', 'copy', 'no-drop', 'grab', 'grabbing', 'all-scroll', 'col-resize', 'row-resize', 'n-resize', 'e-resize', 's-resize', 'w-resize', 'ne-resize', 'nw-resize', 'se-resize', 'sw-resize', 'ew-resize', 'ns-resize', 'nesw-resize', 'nwse-resize', 'zoom-in', 'zoom-out', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Field Sizing\n * @see https://tailwindcss.com/docs/field-sizing\n */\n 'field-sizing': [{\n 'field-sizing': ['fixed', 'content']\n }],\n /**\n * Pointer Events\n * @see https://tailwindcss.com/docs/pointer-events\n */\n 'pointer-events': [{\n 'pointer-events': ['auto', 'none']\n }],\n /**\n * Resize\n * @see https://tailwindcss.com/docs/resize\n */\n resize: [{\n resize: ['none', '', 'y', 'x']\n }],\n /**\n * Scroll Behavior\n * @see https://tailwindcss.com/docs/scroll-behavior\n */\n 'scroll-behavior': [{\n scroll: ['auto', 'smooth']\n }],\n /**\n * Scroll Margin\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-m': [{\n 'scroll-m': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Inline\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mx': [{\n 'scroll-mx': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Block\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-my': [{\n 'scroll-my': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Inline Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ms': [{\n 'scroll-ms': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Inline End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-me': [{\n 'scroll-me': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Block Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mbs': [{\n 'scroll-mbs': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Block End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mbe': [{\n 'scroll-mbe': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Top\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mt': [{\n 'scroll-mt': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Right\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mr': [{\n 'scroll-mr': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Bottom\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mb': [{\n 'scroll-mb': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Left\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ml': [{\n 'scroll-ml': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-p': [{\n 'scroll-p': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Inline\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-px': [{\n 'scroll-px': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Block\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-py': [{\n 'scroll-py': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Inline Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-ps': [{\n 'scroll-ps': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Inline End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pe': [{\n 'scroll-pe': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Block Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pbs': [{\n 'scroll-pbs': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Block End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pbe': [{\n 'scroll-pbe': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Top\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pt': [{\n 'scroll-pt': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Right\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pr': [{\n 'scroll-pr': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Bottom\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pb': [{\n 'scroll-pb': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Left\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pl': [{\n 'scroll-pl': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Snap Align\n * @see https://tailwindcss.com/docs/scroll-snap-align\n */\n 'snap-align': [{\n snap: ['start', 'end', 'center', 'align-none']\n }],\n /**\n * Scroll Snap Stop\n * @see https://tailwindcss.com/docs/scroll-snap-stop\n */\n 'snap-stop': [{\n snap: ['normal', 'always']\n }],\n /**\n * Scroll Snap Type\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-type': [{\n snap: ['none', 'x', 'y', 'both']\n }],\n /**\n * Scroll Snap Type Strictness\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-strictness': [{\n snap: ['mandatory', 'proximity']\n }],\n /**\n * Touch Action\n * @see https://tailwindcss.com/docs/touch-action\n */\n touch: [{\n touch: ['auto', 'none', 'manipulation']\n }],\n /**\n * Touch Action X\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-x': [{\n 'touch-pan': ['x', 'left', 'right']\n }],\n /**\n * Touch Action Y\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-y': [{\n 'touch-pan': ['y', 'up', 'down']\n }],\n /**\n * Touch Action Pinch Zoom\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-pz': ['touch-pinch-zoom'],\n /**\n * User Select\n * @see https://tailwindcss.com/docs/user-select\n */\n select: [{\n select: ['none', 'text', 'all', 'auto']\n }],\n /**\n * Will Change\n * @see https://tailwindcss.com/docs/will-change\n */\n 'will-change': [{\n 'will-change': ['auto', 'scroll', 'contents', 'transform', isArbitraryVariable, isArbitraryValue]\n }],\n // -----------\n // --- SVG ---\n // -----------\n /**\n * Fill\n * @see https://tailwindcss.com/docs/fill\n */\n fill: [{\n fill: ['none', ...scaleColor()]\n }],\n /**\n * Stroke Width\n * @see https://tailwindcss.com/docs/stroke-width\n */\n 'stroke-w': [{\n stroke: [isNumber, isArbitraryVariableLength, isArbitraryLength, isArbitraryNumber]\n }],\n /**\n * Stroke\n * @see https://tailwindcss.com/docs/stroke\n */\n stroke: [{\n stroke: ['none', ...scaleColor()]\n }],\n // ---------------------\n // --- Accessibility ---\n // ---------------------\n /**\n * Forced Color Adjust\n * @see https://tailwindcss.com/docs/forced-color-adjust\n */\n 'forced-color-adjust': [{\n 'forced-color-adjust': ['auto', 'none']\n }]\n },\n conflictingClassGroups: {\n overflow: ['overflow-x', 'overflow-y'],\n overscroll: ['overscroll-x', 'overscroll-y'],\n inset: ['inset-x', 'inset-y', 'inset-bs', 'inset-be', 'start', 'end', 'top', 'right', 'bottom', 'left'],\n 'inset-x': ['right', 'left'],\n 'inset-y': ['top', 'bottom'],\n flex: ['basis', 'grow', 'shrink'],\n gap: ['gap-x', 'gap-y'],\n p: ['px', 'py', 'ps', 'pe', 'pbs', 'pbe', 'pt', 'pr', 'pb', 'pl'],\n px: ['pr', 'pl'],\n py: ['pt', 'pb'],\n m: ['mx', 'my', 'ms', 'me', 'mbs', 'mbe', 'mt', 'mr', 'mb', 'ml'],\n mx: ['mr', 'ml'],\n my: ['mt', 'mb'],\n size: ['w', 'h'],\n 'font-size': ['leading'],\n 'fvn-normal': ['fvn-ordinal', 'fvn-slashed-zero', 'fvn-figure', 'fvn-spacing', 'fvn-fraction'],\n 'fvn-ordinal': ['fvn-normal'],\n 'fvn-slashed-zero': ['fvn-normal'],\n 'fvn-figure': ['fvn-normal'],\n 'fvn-spacing': ['fvn-normal'],\n 'fvn-fraction': ['fvn-normal'],\n 'line-clamp': ['display', 'overflow'],\n rounded: ['rounded-s', 'rounded-e', 'rounded-t', 'rounded-r', 'rounded-b', 'rounded-l', 'rounded-ss', 'rounded-se', 'rounded-ee', 'rounded-es', 'rounded-tl', 'rounded-tr', 'rounded-br', 'rounded-bl'],\n 'rounded-s': ['rounded-ss', 'rounded-es'],\n 'rounded-e': ['rounded-se', 'rounded-ee'],\n 'rounded-t': ['rounded-tl', 'rounded-tr'],\n 'rounded-r': ['rounded-tr', 'rounded-br'],\n 'rounded-b': ['rounded-br', 'rounded-bl'],\n 'rounded-l': ['rounded-tl', 'rounded-bl'],\n 'border-spacing': ['border-spacing-x', 'border-spacing-y'],\n 'border-w': ['border-w-x', 'border-w-y', 'border-w-s', 'border-w-e', 'border-w-bs', 'border-w-be', 'border-w-t', 'border-w-r', 'border-w-b', 'border-w-l'],\n 'border-w-x': ['border-w-r', 'border-w-l'],\n 'border-w-y': ['border-w-t', 'border-w-b'],\n 'border-color': ['border-color-x', 'border-color-y', 'border-color-s', 'border-color-e', 'border-color-bs', 'border-color-be', 'border-color-t', 'border-color-r', 'border-color-b', 'border-color-l'],\n 'border-color-x': ['border-color-r', 'border-color-l'],\n 'border-color-y': ['border-color-t', 'border-color-b'],\n translate: ['translate-x', 'translate-y', 'translate-none'],\n 'translate-none': ['translate', 'translate-x', 'translate-y', 'translate-z'],\n 'scroll-m': ['scroll-mx', 'scroll-my', 'scroll-ms', 'scroll-me', 'scroll-mbs', 'scroll-mbe', 'scroll-mt', 'scroll-mr', 'scroll-mb', 'scroll-ml'],\n 'scroll-mx': ['scroll-mr', 'scroll-ml'],\n 'scroll-my': ['scroll-mt', 'scroll-mb'],\n 'scroll-p': ['scroll-px', 'scroll-py', 'scroll-ps', 'scroll-pe', 'scroll-pbs', 'scroll-pbe', 'scroll-pt', 'scroll-pr', 'scroll-pb', 'scroll-pl'],\n 'scroll-px': ['scroll-pr', 'scroll-pl'],\n 'scroll-py': ['scroll-pt', 'scroll-pb'],\n touch: ['touch-x', 'touch-y', 'touch-pz'],\n 'touch-x': ['touch'],\n 'touch-y': ['touch'],\n 'touch-pz': ['touch']\n },\n conflictingClassGroupModifiers: {\n 'font-size': ['leading']\n },\n orderSensitiveModifiers: ['*', '**', 'after', 'backdrop', 'before', 'details-content', 'file', 'first-letter', 'first-line', 'marker', 'placeholder', 'selection']\n };\n};\n\n/**\n * @param baseConfig Config where other config will be merged into. This object will be mutated.\n * @param configExtension Partial config to merge into the `baseConfig`.\n */\nconst mergeConfigs = (baseConfig, {\n cacheSize,\n prefix,\n experimentalParseClassName,\n extend = {},\n override = {}\n}) => {\n overrideProperty(baseConfig, 'cacheSize', cacheSize);\n overrideProperty(baseConfig, 'prefix', prefix);\n overrideProperty(baseConfig, 'experimentalParseClassName', experimentalParseClassName);\n overrideConfigProperties(baseConfig.theme, override.theme);\n overrideConfigProperties(baseConfig.classGroups, override.classGroups);\n overrideConfigProperties(baseConfig.conflictingClassGroups, override.conflictingClassGroups);\n overrideConfigProperties(baseConfig.conflictingClassGroupModifiers, override.conflictingClassGroupModifiers);\n overrideProperty(baseConfig, 'orderSensitiveModifiers', override.orderSensitiveModifiers);\n mergeConfigProperties(baseConfig.theme, extend.theme);\n mergeConfigProperties(baseConfig.classGroups, extend.classGroups);\n mergeConfigProperties(baseConfig.conflictingClassGroups, extend.conflictingClassGroups);\n mergeConfigProperties(baseConfig.conflictingClassGroupModifiers, extend.conflictingClassGroupModifiers);\n mergeArrayProperties(baseConfig, extend, 'orderSensitiveModifiers');\n return baseConfig;\n};\nconst overrideProperty = (baseObject, overrideKey, overrideValue) => {\n if (overrideValue !== undefined) {\n baseObject[overrideKey] = overrideValue;\n }\n};\nconst overrideConfigProperties = (baseObject, overrideObject) => {\n if (overrideObject) {\n for (const key in overrideObject) {\n overrideProperty(baseObject, key, overrideObject[key]);\n }\n }\n};\nconst mergeConfigProperties = (baseObject, mergeObject) => {\n if (mergeObject) {\n for (const key in mergeObject) {\n mergeArrayProperties(baseObject, mergeObject, key);\n }\n }\n};\nconst mergeArrayProperties = (baseObject, mergeObject, key) => {\n const mergeValue = mergeObject[key];\n if (mergeValue !== undefined) {\n baseObject[key] = baseObject[key] ? baseObject[key].concat(mergeValue) : mergeValue;\n }\n};\nconst extendTailwindMerge = (configExtension, ...createConfig) => typeof configExtension === 'function' ? createTailwindMerge(getDefaultConfig, configExtension, ...createConfig) : createTailwindMerge(() => mergeConfigs(getDefaultConfig(), configExtension), ...createConfig);\nconst twMerge = /*#__PURE__*/createTailwindMerge(getDefaultConfig);\nexport { createTailwindMerge, extendTailwindMerge, fromTheme, getDefaultConfig, mergeConfigs, twJoin, twMerge, validators };\n//# sourceMappingURL=bundle-mjs.mjs.map\n","import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n","import * as React from \"react\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst buttonVariants = cva(\n \"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0\",\n {\n variants: {\n variant: {\n default: \"bg-primary text-primary-foreground shadow hover:bg-primary/90\",\n destructive: \"bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90\",\n outline:\n \"border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground\",\n secondary: \"bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80\",\n ghost: \"hover:bg-accent hover:text-accent-foreground\",\n link: \"text-primary underline-offset-4 hover:underline\",\n },\n size: {\n default: \"h-9 px-4 py-2\",\n sm: \"h-8 rounded-md px-3 text-xs\",\n lg: \"h-10 rounded-md px-8\",\n icon: \"h-9 w-9\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n },\n);\n\nexport interface ButtonProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement>, VariantProps<typeof buttonVariants> {\n asChild?: boolean;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n ({ className, variant, size, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"button\";\n return (\n <Comp className={cn(buttonVariants({ variant, size, className }))} ref={ref} {...props} />\n );\n },\n);\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n","import cn from \"classnames\";\nimport { useMemo } from \"react\";\nimport * as React from \"react\";\nimport css from \"./Spinner.module.scss\";\n\ninterface Props {\n marginTop?: React.CSSProperties[\"marginTop\"];\n marginBottom?: React.CSSProperties[\"marginBottom\"];\n marginLeft?: React.CSSProperties[\"marginLeft\"];\n size?: \"big\" | \"small\" | \"extraSmall\";\n className?: string;\n}\n\nexport const Spinner: React.FC<Props> = ({\n marginTop,\n marginBottom,\n marginLeft,\n className,\n size = \"big\",\n}) => {\n const styles: React.CSSProperties = useMemo(\n () => ({\n marginTop,\n marginBottom,\n marginLeft,\n }),\n [marginBottom, marginLeft, marginTop],\n );\n\n return (\n <div className={(css.cssloadContainer, className)} style={styles}>\n <div\n className={cn(css.cssloadSpeedingWheel, {\n [css.bigSize]: size === \"big\",\n [css.smallSize]: size === \"small\",\n [css.extraSmallSize]: size === \"extraSmall\",\n })}\n />\n </div>\n );\n};\n","import React, { ButtonHTMLAttributes, forwardRef } from \"react\";\nimport classNames from \"classnames\";\nimport { Button as UiButton } from \"@/components/ui/button\";\nimport { Spinner } from \"../Spinner/Spinner\";\nimport css from \"./Button.module.scss\";\n\nexport type ButtonVariant = \"default\" | \"primary\" | \"secondary\" | \"text\" | \"link\" | \"danger\";\nexport type ButtonSize = \"small\" | \"medium\" | \"large\";\n\nexport interface ButtonProps extends ButtonHTMLAttributes<HTMLButtonElement> {\n variant?: ButtonVariant;\n size?: ButtonSize;\n className?: string;\n loading?: boolean;\n disabled?: boolean;\n children?: React.ReactNode;\n}\n\nconst Button = forwardRef<HTMLButtonElement, ButtonProps>(\n (\n {\n variant = \"default\",\n size = \"medium\",\n className = \"\",\n loading = false,\n disabled = false,\n children,\n type = \"button\",\n ...rest\n },\n ref,\n ) => {\n const buttonClasses = classNames(\n css.button,\n css[`button--variant-${variant}`],\n css[`button--size-${size}`],\n {\n [css[\"button--loading\"]]: loading,\n [css[\"button--disabled\"]]: disabled,\n },\n className,\n );\n\n return (\n <UiButton\n ref={ref}\n variant={null}\n size={null}\n className={buttonClasses}\n disabled={disabled || loading}\n type={type}\n {...rest}\n >\n {children && children}\n\n {loading && (\n <span className={css.button__loader}>\n <Spinner size=\"extraSmall\" />\n </span>\n )}\n </UiButton>\n );\n },\n);\n\nButton.displayName = \"Button\";\n\nexport { Button };\n","import { useEffect, useMemo, useRef, useState } from \"react\";\n\nexport const useMeasureElement = (element?: HTMLElement | null) => {\n const [height, setHeight] = useState(0);\n const [width, setWidth] = useState(0);\n const rafRef = useRef<number | null>(null);\n\n useEffect(() => {\n if (!element) {\n return;\n }\n\n const resizeObserver = new ResizeObserver((entries) => {\n if (rafRef.current) {\n cancelAnimationFrame(rafRef.current);\n }\n\n rafRef.current = requestAnimationFrame(() => {\n for (const entry of entries) {\n if (entry.borderBoxSize) {\n const borderBoxSize = Array.isArray(entry.borderBoxSize)\n ? entry.borderBoxSize[0]\n : entry.borderBoxSize;\n setHeight(borderBoxSize.blockSize);\n setWidth(borderBoxSize.inlineSize);\n } else {\n setHeight(entry.contentRect.height);\n setWidth(entry.contentRect.width);\n }\n }\n });\n });\n\n resizeObserver.observe(element);\n\n const initialHeight = element.getBoundingClientRect().height;\n setHeight(initialHeight);\n\n return () => {\n resizeObserver.disconnect();\n };\n }, [element, setHeight]);\n\n const params = useMemo(\n () => ({\n height,\n width,\n }),\n [height, width],\n );\n\n return params;\n};\n","import { useState, useEffect, useCallback, useRef } from \"react\";\n\ntype DropdownPosition = \"top\" | \"bottom\";\n\ninterface UseDropdownPositionProps {\n triggerRef: React.RefObject<HTMLElement | null>;\n dropdownHeight: number;\n offset?: number;\n /** When false, skips scroll/layout listeners (e.g. closed dropdown). Defaults to true. */\n enabled?: boolean;\n onAnchorFrame?: (placement: DropdownPosition) => void;\n}\n\nconst WINDOW_SCROLL_OPTIONS: AddEventListenerOptions = { capture: true, passive: true };\n\nexport const useDropdownPosition = ({\n triggerRef,\n dropdownHeight,\n offset = 8,\n enabled = true,\n onAnchorFrame,\n}: UseDropdownPositionProps) => {\n const [position, setPosition] = useState<DropdownPosition>(\"bottom\");\n const rafRef = useRef<number | null>(null);\n\n const calculatePosition = useCallback(() => {\n if (!triggerRef.current) {\n return \"bottom\";\n }\n\n const selectRect = triggerRef.current.getBoundingClientRect();\n const viewportHeight = window.innerHeight;\n\n const spaceAbove = selectRect.top - offset;\n const spaceBelow = viewportHeight - selectRect.bottom - offset;\n\n if (spaceBelow >= dropdownHeight) {\n return \"bottom\";\n }\n if (spaceAbove >= dropdownHeight) {\n return \"top\";\n }\n\n return \"bottom\";\n }, [triggerRef, dropdownHeight, offset]);\n\n const updatePosition = useCallback(() => {\n if (rafRef.current) {\n cancelAnimationFrame(rafRef.current);\n }\n\n rafRef.current = requestAnimationFrame(() => {\n const nextPosition = calculatePosition();\n setPosition(nextPosition);\n onAnchorFrame?.(nextPosition);\n });\n }, [calculatePosition, onAnchorFrame]);\n\n useEffect(() => {\n if (!enabled) {\n return;\n }\n\n const trigger = triggerRef.current;\n if (!trigger) {\n return;\n }\n\n updatePosition();\n\n const resizeObserver = new ResizeObserver(() => {\n updatePosition();\n });\n\n resizeObserver.observe(trigger);\n\n const mutationObserver = new MutationObserver(() => {\n updatePosition();\n });\n\n mutationObserver.observe(document.body, {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: [\"style\", \"class\"],\n });\n\n const scrollableParents: HTMLElement[] = [];\n let parent = trigger.parentElement;\n\n while (parent) {\n const style = window.getComputedStyle(parent);\n const overflow = style.overflow + style.overflowY + style.overflowX;\n\n if (/(auto|scroll)/.test(overflow)) {\n scrollableParents.push(parent);\n parent.addEventListener(\"scroll\", updatePosition);\n }\n parent = parent.parentElement;\n }\n\n window.addEventListener(\"scroll\", updatePosition, WINDOW_SCROLL_OPTIONS);\n window.addEventListener(\"resize\", updatePosition);\n window.addEventListener(\"transitionend\", updatePosition);\n window.addEventListener(\"animationend\", updatePosition);\n\n return () => {\n if (rafRef.current) {\n cancelAnimationFrame(rafRef.current);\n }\n\n resizeObserver.disconnect();\n mutationObserver.disconnect();\n\n window.removeEventListener(\"scroll\", updatePosition, WINDOW_SCROLL_OPTIONS);\n window.removeEventListener(\"resize\", updatePosition);\n window.removeEventListener(\"transitionend\", updatePosition);\n window.removeEventListener(\"animationend\", updatePosition);\n\n scrollableParents.forEach((p) => {\n p.removeEventListener(\"scroll\", updatePosition);\n });\n };\n }, [enabled, triggerRef, updatePosition]);\n\n return position;\n};\n","import { useCallback, useEffect, useRef, useState } from \"react\";\nimport cn from \"classnames\";\nimport { Button } from \"../Button/Button\";\nimport { useMeasureElement } from \"../../helpers\";\nimport css from \"./RadioGroupButton.module.scss\";\n\nexport interface RadioGroupButtonOption<T> {\n id: T;\n label: string;\n additionalComponent?: React.ReactNode;\n}\n\ninterface RadioGroupButtonProps<T> {\n data: RadioGroupButtonOption<T>[];\n activeButton?: string | number;\n defaultActiveButton?: string | number;\n onChange?: (id: T) => void;\n}\n\nexport const RadioGroupButton = <T extends string | number>({\n data,\n activeButton,\n defaultActiveButton,\n onChange,\n}: RadioGroupButtonProps<T>) => {\n const [_activeButton, setActiveButton] = useState(defaultActiveButton || data[0]?.id);\n const [sliderPosition, setSliderPosition] = useState({ transform: \"translateX(0)\", width: 0 });\n const buttonRefs = useRef<Map<string | number, HTMLDivElement | null>>(new Map());\n const resolvedActiveButton = activeButton || _activeButton;\n\n const { width: activeButtonWidth } = useMeasureElement(\n buttonRefs.current.get(resolvedActiveButton as string),\n );\n\n const _onChange = (option: RadioGroupButtonOption<T>) => {\n if (option.id === resolvedActiveButton) {\n return;\n }\n onChange?.(option.id);\n setActiveButton(option.id);\n };\n\n const callbackRef = useCallback((el: HTMLDivElement | null, id: string | number) => {\n buttonRefs.current.set(id, el);\n }, []);\n\n useEffect(() => {\n const activeButtonIndex = data.findIndex((option) => option.id === resolvedActiveButton);\n if (activeButtonIndex >= 0) {\n const buttonsBeforeActive = data.slice(0, activeButtonIndex);\n const sliderPosition = buttonsBeforeActive.reduce((acc, button) => {\n const buttonElement = buttonRefs.current.get(button.id);\n if (buttonElement) {\n const buttonWidth = buttonElement.getBoundingClientRect().width;\n acc += buttonWidth;\n }\n\n return acc;\n }, 0);\n\n setSliderPosition({ transform: `translateX(${sliderPosition}px)`, width: activeButtonWidth });\n }\n }, [resolvedActiveButton, activeButtonWidth, data]);\n\n return (\n <div className={css.container}>\n {data.map((option) => (\n <div key={option.id} ref={(el) => callbackRef(el, option.id)}>\n <Button\n size=\"small\"\n onClick={() => _onChange(option)}\n className={cn({ [css.activeButton]: option.id === resolvedActiveButton })}\n >\n {option.label}\n {option.additionalComponent}\n </Button>\n </div>\n ))}\n <div className={css.slider} style={sliderPosition} />\n </div>\n );\n};\n","import { FC, memo, useMemo } from \"react\";\nimport cn from \"classnames\";\nimport css from \"./Card.module.scss\";\n\ninterface CardProps {\n text: string;\n width?: number;\n height?: number;\n className?: string;\n backgroundColor?: string;\n imageUrl?: string;\n textColor?: string;\n link?: string;\n}\n\nexport const Card: FC<CardProps> = memo(\n ({ text, width, height, className, backgroundColor, imageUrl, textColor, link }) => {\n const containerClassname = cn(css.card, { [css.link]: link }, className);\n\n const containerStyle = useMemo(\n () => ({\n backgroundColor,\n ...(textColor && { color: textColor }),\n ...(width && { width }),\n ...(height && { height: `${height}px` }),\n ...(imageUrl && { backgroundImage: `url(${imageUrl})` }),\n }),\n [backgroundColor, height, imageUrl, textColor, width],\n );\n\n return link ? (\n <a className={containerClassname} style={containerStyle} href={link}>\n <span>{text}</span>\n </a>\n ) : (\n <div className={containerClassname} style={containerStyle}>\n <span>{text}</span>\n </div>\n );\n },\n);\n\nexport const MainBlueCard: FC<Omit<CardProps, \"backgroundColor\" | \"textColor\">> = ({\n className,\n ...rest\n}) => (\n <Card className={cn(css.mainBlue, { [css.mainBlue__link]: rest.link }, className)} {...rest} />\n);\n\nexport const LightBlueCard: FC<Omit<CardProps, \"backgroundColor\" | \"textColor\">> = ({\n className,\n ...rest\n}) => (\n <Card className={cn(css.lightBlue, { [css.lightBlue__link]: rest.link }, className)} {...rest} />\n);\n\nexport const DarkBlueCard: FC<Omit<CardProps, \"backgroundColor\" | \"textColor\">> = ({\n className,\n ...rest\n}) => (\n <Card className={cn(css.darkBlue, { [css.darkBlue__link]: rest.link }, className)} {...rest} />\n);\n","import {\n Children,\n ReactNode,\n isValidElement,\n useMemo,\n useState,\n type HTMLAttributes,\n type KeyboardEvent,\n} from \"react\";\nimport styles from \"./Carousel.module.scss\";\n\ntype CarouselSharedProps = Omit<HTMLAttributes<HTMLDivElement>, \"children\"> & {\n dark?: boolean;\n enableTouch?: boolean;\n fade?: boolean;\n interval?: number | string | boolean;\n keyboard?: boolean;\n pause?: \"hover\" | false;\n ride?: \"carousel\";\n slide?: boolean;\n};\n\nexport type CarouselProps<T extends { id: string | number; caption?: string }> =\n | (CarouselSharedProps & { items: T[]; renderItem: (item: T) => ReactNode })\n | (CarouselSharedProps & { children: ReactNode });\n\ntype SlideDescriptor = {\n key: string;\n content: ReactNode;\n caption?: string;\n};\n\nconst isItemsMode = <T extends { id: string | number; caption?: string }>(\n props: CarouselProps<T>,\n): props is CarouselSharedProps & { items: T[]; renderItem: (item: T) => ReactNode } =>\n \"items\" in props &&\n Array.isArray(props.items) &&\n \"renderItem\" in props &&\n typeof props.renderItem === \"function\";\n\nconst buildSlides = <T extends { id: string | number; caption?: string }>(\n props: CarouselProps<T>,\n): SlideDescriptor[] => {\n if (isItemsMode(props)) {\n return props.items.map((item, index) => ({\n key: `${item.id}-${index}`,\n content: props.renderItem(item),\n caption: item.caption,\n }));\n }\n\n return Children.toArray(props.children).map((child, index) => ({\n key:\n isValidElement(child) && child.key !== null && child.key !== undefined && child.key !== \".\"\n ? String(child.key)\n : `slide-${index}`,\n content: child,\n }));\n};\n\nconst pickCarouselSharedProps = <T extends { id: string | number; caption?: string }>(\n props: CarouselProps<T>,\n): CarouselSharedProps => {\n const shared = { ...props } as Record<string, unknown>;\n delete shared.items;\n delete shared.renderItem;\n delete shared.children;\n return shared as CarouselSharedProps;\n};\n\nexport const Carousel = <T extends { id: string | number; caption?: string }>(\n props: CarouselProps<T>,\n) => {\n const slides = buildSlides(props);\n const slideCount = slides.length;\n const carouselSharedProps = pickCarouselSharedProps(props);\n const {\n className,\n dark: _dark,\n enableTouch: _enableTouch,\n fade: _fade,\n interval: _interval,\n keyboard = true,\n pause: _pause,\n ride: _ride,\n slide: _slide,\n ...domProps\n } = carouselSharedProps;\n\n const [activeIndex, setActiveIndex] = useState(0);\n\n const next = () => {\n setActiveIndex((prev) => (prev === slideCount - 1 ? 0 : prev + 1));\n };\n\n const previous = () => {\n setActiveIndex((prev) => (prev === 0 ? slideCount - 1 : prev - 1));\n };\n\n const goToIndex = (newIndex: number) => {\n setActiveIndex(newIndex);\n };\n\n const isMany = slideCount > 1;\n const indicatorItems = useMemo(() => slides.map((slide) => ({ key: slide.key })), [slides]);\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n domProps.onKeyDown?.(event);\n\n if (event.defaultPrevented || !keyboard || !isMany) {\n return;\n }\n\n if (event.key === \"ArrowLeft\") {\n previous();\n }\n\n if (event.key === \"ArrowRight\") {\n next();\n }\n };\n\n if (!slideCount) {\n return null;\n }\n\n if (!isMany) {\n return <div className={styles.carouselWrapper}>{slides[0].content}</div>;\n }\n\n return (\n <div className={styles.carouselWrapper}>\n <div\n {...domProps}\n className={[styles.carousel, className].filter(Boolean).join(\" \")}\n onKeyDown={handleKeyDown}\n role=\"region\"\n aria-roledescription=\"carousel\"\n >\n <div className={styles.viewport}>\n {slides.map((slide, index) => (\n <div\n key={slide.key}\n className={[styles.slide, index === activeIndex ? styles.activeSlide : \"\"]\n .filter(Boolean)\n .join(\" \")}\n aria-hidden={index !== activeIndex}\n >\n <div className={styles.itemContent}>{slide.content}</div>\n </div>\n ))}\n </div>\n\n <div className={styles.controls}>\n <button\n className={styles.carouselControl}\n type=\"button\"\n onClick={previous}\n aria-label=\"Previous slide\"\n >\n <span className={styles.prevIcon} aria-hidden=\"true\" />\n </button>\n\n <div className={styles.indicators}>\n {indicatorItems.map((item, index) => (\n <button\n key={item.key}\n className={index === activeIndex ? styles.activeIndicator : undefined}\n type=\"button\"\n onClick={() => goToIndex(index)}\n aria-label={`Go to slide ${index + 1}`}\n aria-current={index === activeIndex}\n />\n ))}\n </div>\n\n <button\n className={styles.carouselControl}\n type=\"button\"\n onClick={next}\n aria-label=\"Next slide\"\n >\n <span className={styles.nextIcon} aria-hidden=\"true\" />\n </button>\n </div>\n </div>\n </div>\n );\n};\n","const GAP_PX = 8;\n\nexport type TooltipPlacement =\n | \"top\"\n | \"topLeft\"\n | \"topRight\"\n | \"bottom\"\n | \"bottomLeft\"\n | \"bottomRight\"\n | \"left\"\n | \"leftTop\"\n | \"leftBottom\"\n | \"right\"\n | \"rightTop\"\n | \"rightBottom\";\n\nexport function getTooltipPosition(\n rect: DOMRect,\n placement: TooltipPlacement = \"top\",\n): { left: number; top: number; transform: string } {\n const { left, right, top, bottom, width, height } = rect;\n const centerX = left + width / 2;\n const centerY = top + height / 2;\n\n switch (placement) {\n case \"top\":\n return { left: centerX, top: top - GAP_PX, transform: \"translate(-50%, -100%)\" };\n case \"topLeft\":\n return { left, top: top - GAP_PX, transform: \"translateY(-100%)\" };\n case \"topRight\":\n return { left: right, top: top - GAP_PX, transform: \"translate(-100%, -100%)\" };\n case \"bottom\":\n return { left: centerX, top: bottom + GAP_PX, transform: \"translate(-50%, 0)\" };\n case \"bottomLeft\":\n return { left, top: bottom + GAP_PX, transform: \"translateY(0)\" };\n case \"bottomRight\":\n return { left: right, top: bottom + GAP_PX, transform: \"translate(-100%, 0)\" };\n case \"left\":\n return { left: left - GAP_PX, top: centerY, transform: \"translate(-100%, -50%)\" };\n case \"leftTop\":\n return { left: left - GAP_PX, top, transform: \"translate(-100%, 0)\" };\n case \"leftBottom\":\n return { left: left - GAP_PX, top: bottom, transform: \"translate(-100%, -100%)\" };\n case \"right\":\n return { left: right + GAP_PX, top: centerY, transform: \"translate(0, -50%)\" };\n case \"rightTop\":\n return { left: right + GAP_PX, top, transform: \"translate(0, 0)\" };\n case \"rightBottom\":\n return { left: right + GAP_PX, top: bottom, transform: \"translate(0, -100%)\" };\n default:\n return { left: centerX, top: top - GAP_PX, transform: \"translate(-50%, -100%)\" };\n }\n}\n","import { createPortal } from \"react-dom\";\nimport {\n memo,\n useCallback,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n type ReactNode,\n} from \"react\";\nimport cn from \"classnames\";\nimport { getTooltipPosition, type TooltipPlacement } from \"./getTooltipPosition\";\nimport css from \"./Tooltip.module.scss\";\n\nexport type { TooltipPlacement } from \"./getTooltipPosition\";\n\nexport type TooltipTrigger = \"hover\" | \"click\";\n\nfunction getArrowDirection(placement: TooltipPlacement): \"top\" | \"bottom\" | \"left\" | \"right\" {\n if (placement.startsWith(\"top\")) {\n return \"bottom\";\n }\n if (placement.startsWith(\"bottom\")) {\n return \"top\";\n }\n if (placement.startsWith(\"left\")) {\n return \"right\";\n }\n if (placement.startsWith(\"right\")) {\n return \"left\";\n }\n return \"top\";\n}\n\nexport interface TooltipProps {\n title: ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n trigger?: TooltipTrigger | TooltipTrigger[];\n mouseEnterDelay?: number;\n mouseLeaveDelay?: number;\n onOpenChange?: (open: boolean) => void;\n placement?: TooltipPlacement;\n arrow?: boolean;\n children: ReactNode;\n overlayClassName?: string;\n getPopupContainer?: () => HTMLElement;\n}\n\nexport const TooltipDark = memo(\n ({\n title,\n open: openProp,\n defaultOpen = false,\n trigger = \"hover\",\n mouseEnterDelay = 100,\n mouseLeaveDelay = 100,\n onOpenChange,\n placement = \"top\",\n arrow = true,\n children,\n overlayClassName,\n getPopupContainer = () => document.body,\n }: TooltipProps) => {\n const isControlled = openProp !== undefined;\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const open = isControlled ? openProp : internalOpen;\n\n const setOpen = useCallback(\n (value: boolean) => {\n if (!isControlled) {\n setInternalOpen(value);\n }\n onOpenChange?.(value);\n },\n [isControlled, onOpenChange],\n );\n\n const triggerRef = useRef<HTMLSpanElement>(null);\n const [style, setStyle] = useState<{\n left: number;\n top: number;\n transform: string;\n } | null>(null);\n const enterTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n const leaveTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n const triggers = Array.isArray(trigger) ? trigger : [trigger];\n const hasHover = triggers.includes(\"hover\");\n const hasClick = triggers.includes(\"click\");\n\n const clearEnterTimer = useCallback(() => {\n if (enterTimerRef.current) {\n clearTimeout(enterTimerRef.current);\n enterTimerRef.current = null;\n }\n }, []);\n\n const clearLeaveTimer = useCallback(() => {\n if (leaveTimerRef.current) {\n clearTimeout(leaveTimerRef.current);\n leaveTimerRef.current = null;\n }\n }, []);\n\n const handleMouseEnter = useCallback(() => {\n if (!hasHover) {\n return;\n }\n clearLeaveTimer();\n enterTimerRef.current = setTimeout(() => setOpen(true), mouseEnterDelay);\n }, [hasHover, mouseEnterDelay, setOpen, clearLeaveTimer]);\n\n const handleMouseLeave = useCallback(() => {\n if (!hasHover) {\n return;\n }\n clearEnterTimer();\n leaveTimerRef.current = setTimeout(() => setOpen(false), mouseLeaveDelay);\n }, [hasHover, mouseLeaveDelay, setOpen, clearEnterTimer]);\n\n const handleClick = useCallback(\n (e: React.MouseEvent) => {\n if (!hasClick) {\n return;\n }\n e.preventDefault();\n setOpen(!open);\n },\n [hasClick, open, setOpen],\n );\n\n useEffect(() => {\n if (!hasClick || !open || isControlled) {\n return;\n }\n const onDocClick = (e: MouseEvent) => {\n const el = triggerRef.current;\n if (el && !el.contains(e.target as Node)) {\n setOpen(false);\n }\n };\n document.addEventListener(\"mousedown\", onDocClick);\n return () => document.removeEventListener(\"mousedown\", onDocClick);\n }, [hasClick, open, isControlled, setOpen]);\n\n useLayoutEffect(() => {\n if (!open || !triggerRef.current) {\n setStyle(null);\n return;\n }\n const rect = triggerRef.current.getBoundingClientRect();\n setStyle(getTooltipPosition(rect, placement));\n }, [open, placement]);\n\n useEffect(\n () => () => {\n clearEnterTimer();\n clearLeaveTimer();\n },\n [clearEnterTimer, clearLeaveTimer],\n );\n\n const container = typeof document !== \"undefined\" ? getPopupContainer() : null;\n const arrowDirection = getArrowDirection(placement);\n\n const overlay =\n open &&\n // eslint-disable-next-line eqeqeq\n title != null &&\n title !== \"\" &&\n style &&\n container &&\n createPortal(\n <span\n className={cn(css.overlay, overlayClassName)}\n style={{\n left: style.left,\n top: style.top,\n transform: style.transform,\n }}\n role=\"tooltip\"\n >\n {title}\n {arrow && <span className={cn(css.arrow, css[arrowDirection])} />}\n </span>,\n container,\n );\n\n const triggerProps =\n !isControlled && (hasHover || hasClick)\n ? {\n onMouseEnter: handleMouseEnter,\n onMouseLeave: handleMouseLeave,\n onClick: hasClick ? handleClick : undefined,\n }\n : {};\n\n return (\n <>\n <span ref={triggerRef} {...triggerProps}>\n {children}\n </span>\n {overlay}\n </>\n );\n },\n);\n\nTooltipDark.displayName = \"TooltipDark\";\n","import { memo, useCallback, type ReactNode } from \"react\";\nimport cn from \"classnames\";\nimport { Button as UiButton } from \"@/components/ui/button\";\nimport { CopyIcon } from \"../../icons\";\nimport { TooltipDark } from \"../TooltipDark/Tooltip\";\nimport css from \"./CopyTextTrigger.module.scss\";\n\nexport interface CopyTextTriggerProps {\n children: ReactNode;\n onClick: () => void;\n copied: boolean;\n tooltipText?: string;\n ariaLabel?: string;\n showIcon?: boolean;\n className?: string;\n}\n\nexport const CopyTextTrigger = memo(\n ({\n children,\n onClick,\n copied,\n tooltipText = \"Скопировано\",\n ariaLabel,\n showIcon = true,\n className,\n }: CopyTextTriggerProps) => {\n const handleClick = useCallback(() => {\n onClick();\n }, [onClick]);\n\n return (\n <span className={css.wrapper}>\n <TooltipDark open={copied} title={tooltipText} placement=\"top\">\n <UiButton\n type=\"button\"\n variant={null}\n size={null}\n className={cn(css.trigger, className)}\n onClick={handleClick}\n aria-label={ariaLabel}\n aria-live=\"polite\"\n >\n {children}\n {showIcon && <CopyIcon className={css.icon} aria-hidden />}\n </UiButton>\n </TooltipDark>\n </span>\n );\n },\n);\n\nCopyTextTrigger.displayName = \"CopyTextTrigger\";\n","\"use client\";\n\nimport type { ReactNode } from \"react\";\nimport { createPortal } from \"react-dom\";\n\n/** Renders children into `document.body` so `position: fixed` matches viewport coordinates from `getBoundingClientRect()`. */\nexport function portalBody(children: ReactNode): ReactNode {\n if (typeof document === \"undefined\") {\n return null;\n }\n return createPortal(children, document.body);\n}\n","// src/primitive.tsx\nvar canUseDOM = !!(typeof window !== \"undefined\" && window.document && window.document.createElement);\nfunction composeEventHandlers(originalEventHandler, ourEventHandler, { checkForDefaultPrevented = true } = {}) {\n return function handleEvent(event) {\n originalEventHandler?.(event);\n if (checkForDefaultPrevented === false || !event.defaultPrevented) {\n return ourEventHandler?.(event);\n }\n };\n}\nfunction getOwnerWindow(element) {\n if (!canUseDOM) {\n throw new Error(\"Cannot access window outside of the DOM\");\n }\n return element?.ownerDocument?.defaultView ?? window;\n}\nfunction getOwnerDocument(element) {\n if (!canUseDOM) {\n throw new Error(\"Cannot access document outside of the DOM\");\n }\n return element?.ownerDocument ?? document;\n}\nfunction getActiveElement(node, activeDescendant = false) {\n const { activeElement } = getOwnerDocument(node);\n if (!activeElement?.nodeName) {\n return null;\n }\n if (isFrame(activeElement) && activeElement.contentDocument) {\n return getActiveElement(activeElement.contentDocument.body, activeDescendant);\n }\n if (activeDescendant) {\n const id = activeElement.getAttribute(\"aria-activedescendant\");\n if (id) {\n const element = getOwnerDocument(activeElement).getElementById(id);\n if (element) {\n return element;\n }\n }\n }\n return activeElement;\n}\nfunction isFrame(element) {\n return element.tagName === \"IFRAME\";\n}\nexport {\n canUseDOM,\n composeEventHandlers,\n getActiveElement,\n getOwnerDocument,\n getOwnerWindow,\n isFrame\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/context/src/create-context.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createContext2(rootComponentName, defaultContext) {\n const Context = React.createContext(defaultContext);\n const Provider = (props) => {\n const { children, ...context } = props;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName) {\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n}\nfunction createContextScope(scopeName, createContextScopeDeps = []) {\n let defaultContexts = [];\n function createContext3(rootComponentName, defaultContext) {\n const BaseContext = React.createContext(defaultContext);\n const index = defaultContexts.length;\n defaultContexts = [...defaultContexts, defaultContext];\n const Provider = (props) => {\n const { scope, children, ...context } = props;\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName, scope) {\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n }\n const createScope = () => {\n const scopeContexts = defaultContexts.map((defaultContext) => {\n return React.createContext(defaultContext);\n });\n return function useScope(scope) {\n const contexts = scope?.[scopeName] || scopeContexts;\n return React.useMemo(\n () => ({ [`__scope${scopeName}`]: { ...scope, [scopeName]: contexts } }),\n [scope, contexts]\n );\n };\n };\n createScope.scopeName = scopeName;\n return [createContext3, composeContextScopes(createScope, ...createContextScopeDeps)];\n}\nfunction composeContextScopes(...scopes) {\n const baseScope = scopes[0];\n if (scopes.length === 1) return baseScope;\n const createScope = () => {\n const scopeHooks = scopes.map((createScope2) => ({\n useScope: createScope2(),\n scopeName: createScope2.scopeName\n }));\n return function useComposedScopes(overrideScopes) {\n const nextScopes = scopeHooks.reduce((nextScopes2, { useScope, scopeName }) => {\n const scopeProps = useScope(overrideScopes);\n const currentScope = scopeProps[`__scope${scopeName}`];\n return { ...nextScopes2, ...currentScope };\n }, {});\n return React.useMemo(() => ({ [`__scope${baseScope.scopeName}`]: nextScopes }), [nextScopes]);\n };\n };\n createScope.scopeName = baseScope.scopeName;\n return createScope;\n}\nexport {\n createContext2 as createContext,\n createContextScope\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","// src/primitive.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NODES = [\n \"a\",\n \"button\",\n \"div\",\n \"form\",\n \"h2\",\n \"h3\",\n \"img\",\n \"input\",\n \"label\",\n \"li\",\n \"nav\",\n \"ol\",\n \"p\",\n \"select\",\n \"span\",\n \"svg\",\n \"ul\"\n];\nvar Primitive = NODES.reduce((primitive, node) => {\n const Slot = createSlot(`Primitive.${node}`);\n const Node = React.forwardRef((props, forwardedRef) => {\n const { asChild, ...primitiveProps } = props;\n const Comp = asChild ? Slot : node;\n if (typeof window !== \"undefined\") {\n window[Symbol.for(\"radix-ui\")] = true;\n }\n return /* @__PURE__ */ jsx(Comp, { ...primitiveProps, ref: forwardedRef });\n });\n Node.displayName = `Primitive.${node}`;\n return { ...primitive, [node]: Node };\n}, {});\nfunction dispatchDiscreteCustomEvent(target, event) {\n if (target) ReactDOM.flushSync(() => target.dispatchEvent(event));\n}\nvar Root = Primitive;\nexport {\n Primitive,\n Root,\n dispatchDiscreteCustomEvent\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-callback-ref/src/use-callback-ref.tsx\nimport * as React from \"react\";\nfunction useCallbackRef(callback) {\n const callbackRef = React.useRef(callback);\n React.useEffect(() => {\n callbackRef.current = callback;\n });\n return React.useMemo(() => (...args) => callbackRef.current?.(...args), []);\n}\nexport {\n useCallbackRef\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-escape-keydown/src/use-escape-keydown.tsx\nimport * as React from \"react\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nfunction useEscapeKeydown(onEscapeKeyDownProp, ownerDocument = globalThis?.document) {\n const onEscapeKeyDown = useCallbackRef(onEscapeKeyDownProp);\n React.useEffect(() => {\n const handleKeyDown = (event) => {\n if (event.key === \"Escape\") {\n onEscapeKeyDown(event);\n }\n };\n ownerDocument.addEventListener(\"keydown\", handleKeyDown, { capture: true });\n return () => ownerDocument.removeEventListener(\"keydown\", handleKeyDown, { capture: true });\n }, [onEscapeKeyDown, ownerDocument]);\n}\nexport {\n useEscapeKeydown\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/dismissable-layer.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { Primitive, dispatchDiscreteCustomEvent } from \"@radix-ui/react-primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useEscapeKeydown } from \"@radix-ui/react-use-escape-keydown\";\nimport { jsx } from \"react/jsx-runtime\";\nvar DISMISSABLE_LAYER_NAME = \"DismissableLayer\";\nvar CONTEXT_UPDATE = \"dismissableLayer.update\";\nvar POINTER_DOWN_OUTSIDE = \"dismissableLayer.pointerDownOutside\";\nvar FOCUS_OUTSIDE = \"dismissableLayer.focusOutside\";\nvar originalBodyPointerEvents;\nvar DismissableLayerContext = React.createContext({\n layers: /* @__PURE__ */ new Set(),\n layersWithOutsidePointerEventsDisabled: /* @__PURE__ */ new Set(),\n branches: /* @__PURE__ */ new Set()\n});\nvar DismissableLayer = React.forwardRef(\n (props, forwardedRef) => {\n const {\n disableOutsidePointerEvents = false,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside,\n onInteractOutside,\n onDismiss,\n ...layerProps\n } = props;\n const context = React.useContext(DismissableLayerContext);\n const [node, setNode] = React.useState(null);\n const ownerDocument = node?.ownerDocument ?? globalThis?.document;\n const [, force] = React.useState({});\n const composedRefs = useComposedRefs(forwardedRef, (node2) => setNode(node2));\n const layers = Array.from(context.layers);\n const [highestLayerWithOutsidePointerEventsDisabled] = [...context.layersWithOutsidePointerEventsDisabled].slice(-1);\n const highestLayerWithOutsidePointerEventsDisabledIndex = layers.indexOf(highestLayerWithOutsidePointerEventsDisabled);\n const index = node ? layers.indexOf(node) : -1;\n const isBodyPointerEventsDisabled = context.layersWithOutsidePointerEventsDisabled.size > 0;\n const isPointerEventsEnabled = index >= highestLayerWithOutsidePointerEventsDisabledIndex;\n const pointerDownOutside = usePointerDownOutside((event) => {\n const target = event.target;\n const isPointerDownOnBranch = [...context.branches].some((branch) => branch.contains(target));\n if (!isPointerEventsEnabled || isPointerDownOnBranch) return;\n onPointerDownOutside?.(event);\n onInteractOutside?.(event);\n if (!event.defaultPrevented) onDismiss?.();\n }, ownerDocument);\n const focusOutside = useFocusOutside((event) => {\n const target = event.target;\n const isFocusInBranch = [...context.branches].some((branch) => branch.contains(target));\n if (isFocusInBranch) return;\n onFocusOutside?.(event);\n onInteractOutside?.(event);\n if (!event.defaultPrevented) onDismiss?.();\n }, ownerDocument);\n useEscapeKeydown((event) => {\n const isHighestLayer = index === context.layers.size - 1;\n if (!isHighestLayer) return;\n onEscapeKeyDown?.(event);\n if (!event.defaultPrevented && onDismiss) {\n event.preventDefault();\n onDismiss();\n }\n }, ownerDocument);\n React.useEffect(() => {\n if (!node) return;\n if (disableOutsidePointerEvents) {\n if (context.layersWithOutsidePointerEventsDisabled.size === 0) {\n originalBodyPointerEvents = ownerDocument.body.style.pointerEvents;\n ownerDocument.body.style.pointerEvents = \"none\";\n }\n context.layersWithOutsidePointerEventsDisabled.add(node);\n }\n context.layers.add(node);\n dispatchUpdate();\n return () => {\n if (disableOutsidePointerEvents && context.layersWithOutsidePointerEventsDisabled.size === 1) {\n ownerDocument.body.style.pointerEvents = originalBodyPointerEvents;\n }\n };\n }, [node, ownerDocument, disableOutsidePointerEvents, context]);\n React.useEffect(() => {\n return () => {\n if (!node) return;\n context.layers.delete(node);\n context.layersWithOutsidePointerEventsDisabled.delete(node);\n dispatchUpdate();\n };\n }, [node, context]);\n React.useEffect(() => {\n const handleUpdate = () => force({});\n document.addEventListener(CONTEXT_UPDATE, handleUpdate);\n return () => document.removeEventListener(CONTEXT_UPDATE, handleUpdate);\n }, []);\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n ...layerProps,\n ref: composedRefs,\n style: {\n pointerEvents: isBodyPointerEventsDisabled ? isPointerEventsEnabled ? \"auto\" : \"none\" : void 0,\n ...props.style\n },\n onFocusCapture: composeEventHandlers(props.onFocusCapture, focusOutside.onFocusCapture),\n onBlurCapture: composeEventHandlers(props.onBlurCapture, focusOutside.onBlurCapture),\n onPointerDownCapture: composeEventHandlers(\n props.onPointerDownCapture,\n pointerDownOutside.onPointerDownCapture\n )\n }\n );\n }\n);\nDismissableLayer.displayName = DISMISSABLE_LAYER_NAME;\nvar BRANCH_NAME = \"DismissableLayerBranch\";\nvar DismissableLayerBranch = React.forwardRef((props, forwardedRef) => {\n const context = React.useContext(DismissableLayerContext);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n React.useEffect(() => {\n const node = ref.current;\n if (node) {\n context.branches.add(node);\n return () => {\n context.branches.delete(node);\n };\n }\n }, [context.branches]);\n return /* @__PURE__ */ jsx(Primitive.div, { ...props, ref: composedRefs });\n});\nDismissableLayerBranch.displayName = BRANCH_NAME;\nfunction usePointerDownOutside(onPointerDownOutside, ownerDocument = globalThis?.document) {\n const handlePointerDownOutside = useCallbackRef(onPointerDownOutside);\n const isPointerInsideReactTreeRef = React.useRef(false);\n const handleClickRef = React.useRef(() => {\n });\n React.useEffect(() => {\n const handlePointerDown = (event) => {\n if (event.target && !isPointerInsideReactTreeRef.current) {\n let handleAndDispatchPointerDownOutsideEvent2 = function() {\n handleAndDispatchCustomEvent(\n POINTER_DOWN_OUTSIDE,\n handlePointerDownOutside,\n eventDetail,\n { discrete: true }\n );\n };\n var handleAndDispatchPointerDownOutsideEvent = handleAndDispatchPointerDownOutsideEvent2;\n const eventDetail = { originalEvent: event };\n if (event.pointerType === \"touch\") {\n ownerDocument.removeEventListener(\"click\", handleClickRef.current);\n handleClickRef.current = handleAndDispatchPointerDownOutsideEvent2;\n ownerDocument.addEventListener(\"click\", handleClickRef.current, { once: true });\n } else {\n handleAndDispatchPointerDownOutsideEvent2();\n }\n } else {\n ownerDocument.removeEventListener(\"click\", handleClickRef.current);\n }\n isPointerInsideReactTreeRef.current = false;\n };\n const timerId = window.setTimeout(() => {\n ownerDocument.addEventListener(\"pointerdown\", handlePointerDown);\n }, 0);\n return () => {\n window.clearTimeout(timerId);\n ownerDocument.removeEventListener(\"pointerdown\", handlePointerDown);\n ownerDocument.removeEventListener(\"click\", handleClickRef.current);\n };\n }, [ownerDocument, handlePointerDownOutside]);\n return {\n // ensures we check React component tree (not just DOM tree)\n onPointerDownCapture: () => isPointerInsideReactTreeRef.current = true\n };\n}\nfunction useFocusOutside(onFocusOutside, ownerDocument = globalThis?.document) {\n const handleFocusOutside = useCallbackRef(onFocusOutside);\n const isFocusInsideReactTreeRef = React.useRef(false);\n React.useEffect(() => {\n const handleFocus = (event) => {\n if (event.target && !isFocusInsideReactTreeRef.current) {\n const eventDetail = { originalEvent: event };\n handleAndDispatchCustomEvent(FOCUS_OUTSIDE, handleFocusOutside, eventDetail, {\n discrete: false\n });\n }\n };\n ownerDocument.addEventListener(\"focusin\", handleFocus);\n return () => ownerDocument.removeEventListener(\"focusin\", handleFocus);\n }, [ownerDocument, handleFocusOutside]);\n return {\n onFocusCapture: () => isFocusInsideReactTreeRef.current = true,\n onBlurCapture: () => isFocusInsideReactTreeRef.current = false\n };\n}\nfunction dispatchUpdate() {\n const event = new CustomEvent(CONTEXT_UPDATE);\n document.dispatchEvent(event);\n}\nfunction handleAndDispatchCustomEvent(name, handler, detail, { discrete }) {\n const target = detail.originalEvent.target;\n const event = new CustomEvent(name, { bubbles: false, cancelable: true, detail });\n if (handler) target.addEventListener(name, handler, { once: true });\n if (discrete) {\n dispatchDiscreteCustomEvent(target, event);\n } else {\n target.dispatchEvent(event);\n }\n}\nvar Root = DismissableLayer;\nvar Branch = DismissableLayerBranch;\nexport {\n Branch,\n DismissableLayer,\n DismissableLayerBranch,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-layout-effect/src/use-layout-effect.tsx\nimport * as React from \"react\";\nvar useLayoutEffect2 = globalThis?.document ? React.useLayoutEffect : () => {\n};\nexport {\n useLayoutEffect2 as useLayoutEffect\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/id/src/id.tsx\nimport * as React from \"react\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nvar useReactId = React[\" useId \".trim().toString()] || (() => void 0);\nvar count = 0;\nfunction useId(deterministicId) {\n const [id, setId] = React.useState(useReactId());\n useLayoutEffect(() => {\n if (!deterministicId) setId((reactId) => reactId ?? String(count++));\n }, [deterministicId]);\n return deterministicId || (id ? `radix-${id}` : \"\");\n}\nexport {\n useId\n};\n//# sourceMappingURL=index.mjs.map\n","/**\n * Custom positioning reference element.\n * @see https://floating-ui.com/docs/virtual-elements\n */\n\nconst sides = ['top', 'right', 'bottom', 'left'];\nconst alignments = ['start', 'end'];\nconst placements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + \"-\" + alignments[0], side + \"-\" + alignments[1]), []);\nconst min = Math.min;\nconst max = Math.max;\nconst round = Math.round;\nconst floor = Math.floor;\nconst createCoords = v => ({\n x: v,\n y: v\n});\nconst oppositeSideMap = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nfunction clamp(start, value, end) {\n return max(start, min(value, end));\n}\nfunction evaluate(value, param) {\n return typeof value === 'function' ? value(param) : value;\n}\nfunction getSide(placement) {\n return placement.split('-')[0];\n}\nfunction getAlignment(placement) {\n return placement.split('-')[1];\n}\nfunction getOppositeAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}\nfunction getAxisLength(axis) {\n return axis === 'y' ? 'height' : 'width';\n}\nfunction getSideAxis(placement) {\n const firstChar = placement[0];\n return firstChar === 't' || firstChar === 'b' ? 'y' : 'x';\n}\nfunction getAlignmentAxis(placement) {\n return getOppositeAxis(getSideAxis(placement));\n}\nfunction getAlignmentSides(placement, rects, rtl) {\n if (rtl === void 0) {\n rtl = false;\n }\n const alignment = getAlignment(placement);\n const alignmentAxis = getAlignmentAxis(placement);\n const length = getAxisLength(alignmentAxis);\n let mainAlignmentSide = alignmentAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';\n if (rects.reference[length] > rects.floating[length]) {\n mainAlignmentSide = getOppositePlacement(mainAlignmentSide);\n }\n return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)];\n}\nfunction getExpandedPlacements(placement) {\n const oppositePlacement = getOppositePlacement(placement);\n return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];\n}\nfunction getOppositeAlignmentPlacement(placement) {\n return placement.includes('start') ? placement.replace('start', 'end') : placement.replace('end', 'start');\n}\nconst lrPlacement = ['left', 'right'];\nconst rlPlacement = ['right', 'left'];\nconst tbPlacement = ['top', 'bottom'];\nconst btPlacement = ['bottom', 'top'];\nfunction getSideList(side, isStart, rtl) {\n switch (side) {\n case 'top':\n case 'bottom':\n if (rtl) return isStart ? rlPlacement : lrPlacement;\n return isStart ? lrPlacement : rlPlacement;\n case 'left':\n case 'right':\n return isStart ? tbPlacement : btPlacement;\n default:\n return [];\n }\n}\nfunction getOppositeAxisPlacements(placement, flipAlignment, direction, rtl) {\n const alignment = getAlignment(placement);\n let list = getSideList(getSide(placement), direction === 'start', rtl);\n if (alignment) {\n list = list.map(side => side + \"-\" + alignment);\n if (flipAlignment) {\n list = list.concat(list.map(getOppositeAlignmentPlacement));\n }\n }\n return list;\n}\nfunction getOppositePlacement(placement) {\n const side = getSide(placement);\n return oppositeSideMap[side] + placement.slice(side.length);\n}\nfunction expandPaddingObject(padding) {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n ...padding\n };\n}\nfunction getPaddingObject(padding) {\n return typeof padding !== 'number' ? expandPaddingObject(padding) : {\n top: padding,\n right: padding,\n bottom: padding,\n left: padding\n };\n}\nfunction rectToClientRect(rect) {\n const {\n x,\n y,\n width,\n height\n } = rect;\n return {\n width,\n height,\n top: y,\n left: x,\n right: x + width,\n bottom: y + height,\n x,\n y\n };\n}\n\nexport { alignments, clamp, createCoords, evaluate, expandPaddingObject, floor, getAlignment, getAlignmentAxis, getAlignmentSides, getAxisLength, getExpandedPlacements, getOppositeAlignmentPlacement, getOppositeAxis, getOppositeAxisPlacements, getOppositePlacement, getPaddingObject, getSide, getSideAxis, max, min, placements, rectToClientRect, round, sides };\n","import { getSideAxis, getAlignmentAxis, getAxisLength, getSide, getAlignment, evaluate, getPaddingObject, rectToClientRect, min, clamp, placements, getAlignmentSides, getOppositeAlignmentPlacement, getOppositePlacement, getExpandedPlacements, getOppositeAxisPlacements, sides, max, getOppositeAxis } from '@floating-ui/utils';\nexport { rectToClientRect } from '@floating-ui/utils';\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n let {\n reference,\n floating\n } = _ref;\n const sideAxis = getSideAxis(placement);\n const alignmentAxis = getAlignmentAxis(placement);\n const alignLength = getAxisLength(alignmentAxis);\n const side = getSide(placement);\n const isVertical = sideAxis === 'y';\n const commonX = reference.x + reference.width / 2 - floating.width / 2;\n const commonY = reference.y + reference.height / 2 - floating.height / 2;\n const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;\n let coords;\n switch (side) {\n case 'top':\n coords = {\n x: commonX,\n y: reference.y - floating.height\n };\n break;\n case 'bottom':\n coords = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n case 'right':\n coords = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n case 'left':\n coords = {\n x: reference.x - floating.width,\n y: commonY\n };\n break;\n default:\n coords = {\n x: reference.x,\n y: reference.y\n };\n }\n switch (getAlignment(placement)) {\n case 'start':\n coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n case 'end':\n coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n }\n return coords;\n}\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nasync function detectOverflow(state, options) {\n var _await$platform$isEle;\n if (options === void 0) {\n options = {};\n }\n const {\n x,\n y,\n platform,\n rects,\n elements,\n strategy\n } = state;\n const {\n boundary = 'clippingAncestors',\n rootBoundary = 'viewport',\n elementContext = 'floating',\n altBoundary = false,\n padding = 0\n } = evaluate(options, state);\n const paddingObject = getPaddingObject(padding);\n const altContext = elementContext === 'floating' ? 'reference' : 'floating';\n const element = elements[altBoundary ? altContext : elementContext];\n const clippingClientRect = rectToClientRect(await platform.getClippingRect({\n element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),\n boundary,\n rootBoundary,\n strategy\n }));\n const rect = elementContext === 'floating' ? {\n x,\n y,\n width: rects.floating.width,\n height: rects.floating.height\n } : rects.reference;\n const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));\n const offsetScale = (await (platform.isElement == null ? void 0 : platform.isElement(offsetParent))) ? (await (platform.getScale == null ? void 0 : platform.getScale(offsetParent))) || {\n x: 1,\n y: 1\n } : {\n x: 1,\n y: 1\n };\n const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n elements,\n rect,\n offsetParent,\n strategy\n }) : rect);\n return {\n top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,\n bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,\n left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,\n right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x\n };\n}\n\n// Maximum number of resets that can occur before bailing to avoid infinite reset loops.\nconst MAX_RESET_COUNT = 50;\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n *\n * This export does not have any `platform` interface logic. You will need to\n * write one for the platform you are using Floating UI with.\n */\nconst computePosition = async (reference, floating, config) => {\n const {\n placement = 'bottom',\n strategy = 'absolute',\n middleware = [],\n platform\n } = config;\n const platformWithDetectOverflow = platform.detectOverflow ? platform : {\n ...platform,\n detectOverflow\n };\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n let rects = await platform.getElementRects({\n reference,\n floating,\n strategy\n });\n let {\n x,\n y\n } = computeCoordsFromPlacement(rects, placement, rtl);\n let statefulPlacement = placement;\n let resetCount = 0;\n const middlewareData = {};\n for (let i = 0; i < middleware.length; i++) {\n const currentMiddleware = middleware[i];\n if (!currentMiddleware) {\n continue;\n }\n const {\n name,\n fn\n } = currentMiddleware;\n const {\n x: nextX,\n y: nextY,\n data,\n reset\n } = await fn({\n x,\n y,\n initialPlacement: placement,\n placement: statefulPlacement,\n strategy,\n middlewareData,\n rects,\n platform: platformWithDetectOverflow,\n elements: {\n reference,\n floating\n }\n });\n x = nextX != null ? nextX : x;\n y = nextY != null ? nextY : y;\n middlewareData[name] = {\n ...middlewareData[name],\n ...data\n };\n if (reset && resetCount < MAX_RESET_COUNT) {\n resetCount++;\n if (typeof reset === 'object') {\n if (reset.placement) {\n statefulPlacement = reset.placement;\n }\n if (reset.rects) {\n rects = reset.rects === true ? await platform.getElementRects({\n reference,\n floating,\n strategy\n }) : reset.rects;\n }\n ({\n x,\n y\n } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n }\n i = -1;\n }\n }\n return {\n x,\n y,\n placement: statefulPlacement,\n strategy,\n middlewareData\n };\n};\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => ({\n name: 'arrow',\n options,\n async fn(state) {\n const {\n x,\n y,\n placement,\n rects,\n platform,\n elements,\n middlewareData\n } = state;\n // Since `element` is required, we don't Partial<> the type.\n const {\n element,\n padding = 0\n } = evaluate(options, state) || {};\n if (element == null) {\n return {};\n }\n const paddingObject = getPaddingObject(padding);\n const coords = {\n x,\n y\n };\n const axis = getAlignmentAxis(placement);\n const length = getAxisLength(axis);\n const arrowDimensions = await platform.getDimensions(element);\n const isYAxis = axis === 'y';\n const minProp = isYAxis ? 'top' : 'left';\n const maxProp = isYAxis ? 'bottom' : 'right';\n const clientProp = isYAxis ? 'clientHeight' : 'clientWidth';\n const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];\n const startDiff = coords[axis] - rects.reference[axis];\n const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));\n let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;\n\n // DOM platform can return `window` as the `offsetParent`.\n if (!clientSize || !(await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent)))) {\n clientSize = elements.floating[clientProp] || rects.floating[length];\n }\n const centerToReference = endDiff / 2 - startDiff / 2;\n\n // If the padding is large enough that it causes the arrow to no longer be\n // centered, modify the padding so that it is centered.\n const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;\n const minPadding = min(paddingObject[minProp], largestPossiblePadding);\n const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);\n\n // Make sure the arrow doesn't overflow the floating element if the center\n // point is outside the floating element's bounds.\n const min$1 = minPadding;\n const max = clientSize - arrowDimensions[length] - maxPadding;\n const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n const offset = clamp(min$1, center, max);\n\n // If the reference is small enough that the arrow's padding causes it to\n // to point to nothing for an aligned placement, adjust the offset of the\n // floating element itself. To ensure `shift()` continues to take action,\n // a single reset is performed when this is true.\n const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center !== offset && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;\n const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max : 0;\n return {\n [axis]: coords[axis] + alignmentOffset,\n data: {\n [axis]: offset,\n centerOffset: center - offset - alignmentOffset,\n ...(shouldAddOffset && {\n alignmentOffset\n })\n },\n reset: shouldAddOffset\n };\n }\n});\n\nfunction getPlacementList(alignment, autoAlignment, allowedPlacements) {\n const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);\n return allowedPlacementsSortedByAlignment.filter(placement => {\n if (alignment) {\n return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);\n }\n return true;\n });\n}\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'autoPlacement',\n options,\n async fn(state) {\n var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;\n const {\n rects,\n middlewareData,\n placement,\n platform,\n elements\n } = state;\n const {\n crossAxis = false,\n alignment,\n allowedPlacements = placements,\n autoAlignment = true,\n ...detectOverflowOptions\n } = evaluate(options, state);\n const placements$1 = alignment !== undefined || allowedPlacements === placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;\n const overflow = await platform.detectOverflow(state, detectOverflowOptions);\n const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;\n const currentPlacement = placements$1[currentIndex];\n if (currentPlacement == null) {\n return {};\n }\n const alignmentSides = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n\n // Make `computeCoords` start from the right place.\n if (placement !== currentPlacement) {\n return {\n reset: {\n placement: placements$1[0]\n }\n };\n }\n const currentOverflows = [overflow[getSide(currentPlacement)], overflow[alignmentSides[0]], overflow[alignmentSides[1]]];\n const allOverflows = [...(((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || []), {\n placement: currentPlacement,\n overflows: currentOverflows\n }];\n const nextPlacement = placements$1[currentIndex + 1];\n\n // There are more placements to check.\n if (nextPlacement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n const placementsSortedByMostSpace = allOverflows.map(d => {\n const alignment = getAlignment(d.placement);\n return [d.placement, alignment && crossAxis ?\n // Check along the mainAxis and main crossAxis side.\n d.overflows.slice(0, 2).reduce((acc, v) => acc + v, 0) :\n // Check only the mainAxis.\n d.overflows[0], d.overflows];\n }).sort((a, b) => a[1] - b[1]);\n const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter(d => d[2].slice(0,\n // Aligned placements should not check their opposite crossAxis\n // side.\n getAlignment(d[0]) ? 2 : 3).every(v => v <= 0));\n const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];\n if (resetPlacement !== placement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: resetPlacement\n }\n };\n }\n return {};\n }\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'flip',\n options,\n async fn(state) {\n var _middlewareData$arrow, _middlewareData$flip;\n const {\n placement,\n middlewareData,\n rects,\n initialPlacement,\n platform,\n elements\n } = state;\n const {\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true,\n fallbackPlacements: specifiedFallbackPlacements,\n fallbackStrategy = 'bestFit',\n fallbackAxisSideDirection = 'none',\n flipAlignment = true,\n ...detectOverflowOptions\n } = evaluate(options, state);\n\n // If a reset by the arrow was caused due to an alignment offset being\n // added, we should skip any logic now since `flip()` has already done its\n // work.\n // https://github.com/floating-ui/floating-ui/issues/2549#issuecomment-1719601643\n if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n return {};\n }\n const side = getSide(placement);\n const initialSideAxis = getSideAxis(initialPlacement);\n const isBasePlacement = getSide(initialPlacement) === initialPlacement;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));\n const hasFallbackAxisSideDirection = fallbackAxisSideDirection !== 'none';\n if (!specifiedFallbackPlacements && hasFallbackAxisSideDirection) {\n fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));\n }\n const placements = [initialPlacement, ...fallbackPlacements];\n const overflow = await platform.detectOverflow(state, detectOverflowOptions);\n const overflows = [];\n let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n if (checkMainAxis) {\n overflows.push(overflow[side]);\n }\n if (checkCrossAxis) {\n const sides = getAlignmentSides(placement, rects, rtl);\n overflows.push(overflow[sides[0]], overflow[sides[1]]);\n }\n overflowsData = [...overflowsData, {\n placement,\n overflows\n }];\n\n // One or more sides is overflowing.\n if (!overflows.every(side => side <= 0)) {\n var _middlewareData$flip2, _overflowsData$filter;\n const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;\n const nextPlacement = placements[nextIndex];\n if (nextPlacement) {\n const ignoreCrossAxisOverflow = checkCrossAxis === 'alignment' ? initialSideAxis !== getSideAxis(nextPlacement) : false;\n if (!ignoreCrossAxisOverflow ||\n // We leave the current main axis only if every placement on that axis\n // overflows the main axis.\n overflowsData.every(d => getSideAxis(d.placement) === initialSideAxis ? d.overflows[0] > 0 : true)) {\n // Try next placement and re-run the lifecycle.\n return {\n data: {\n index: nextIndex,\n overflows: overflowsData\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n }\n\n // First, find the candidates that fit on the mainAxis side of overflow,\n // then find the placement that fits the best on the main crossAxis side.\n let resetPlacement = (_overflowsData$filter = overflowsData.filter(d => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;\n\n // Otherwise fallback.\n if (!resetPlacement) {\n switch (fallbackStrategy) {\n case 'bestFit':\n {\n var _overflowsData$filter2;\n const placement = (_overflowsData$filter2 = overflowsData.filter(d => {\n if (hasFallbackAxisSideDirection) {\n const currentSideAxis = getSideAxis(d.placement);\n return currentSideAxis === initialSideAxis ||\n // Create a bias to the `y` side axis due to horizontal\n // reading directions favoring greater width.\n currentSideAxis === 'y';\n }\n return true;\n }).map(d => [d.placement, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$filter2[0];\n if (placement) {\n resetPlacement = placement;\n }\n break;\n }\n case 'initialPlacement':\n resetPlacement = initialPlacement;\n break;\n }\n }\n if (placement !== resetPlacement) {\n return {\n reset: {\n placement: resetPlacement\n }\n };\n }\n }\n return {};\n }\n };\n};\n\nfunction getSideOffsets(overflow, rect) {\n return {\n top: overflow.top - rect.height,\n right: overflow.right - rect.width,\n bottom: overflow.bottom - rect.height,\n left: overflow.left - rect.width\n };\n}\nfunction isAnySideFullyClipped(overflow) {\n return sides.some(side => overflow[side] >= 0);\n}\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'hide',\n options,\n async fn(state) {\n const {\n rects,\n platform\n } = state;\n const {\n strategy = 'referenceHidden',\n ...detectOverflowOptions\n } = evaluate(options, state);\n switch (strategy) {\n case 'referenceHidden':\n {\n const overflow = await platform.detectOverflow(state, {\n ...detectOverflowOptions,\n elementContext: 'reference'\n });\n const offsets = getSideOffsets(overflow, rects.reference);\n return {\n data: {\n referenceHiddenOffsets: offsets,\n referenceHidden: isAnySideFullyClipped(offsets)\n }\n };\n }\n case 'escaped':\n {\n const overflow = await platform.detectOverflow(state, {\n ...detectOverflowOptions,\n altBoundary: true\n });\n const offsets = getSideOffsets(overflow, rects.floating);\n return {\n data: {\n escapedOffsets: offsets,\n escaped: isAnySideFullyClipped(offsets)\n }\n };\n }\n default:\n {\n return {};\n }\n }\n }\n };\n};\n\nfunction getBoundingRect(rects) {\n const minX = min(...rects.map(rect => rect.left));\n const minY = min(...rects.map(rect => rect.top));\n const maxX = max(...rects.map(rect => rect.right));\n const maxY = max(...rects.map(rect => rect.bottom));\n return {\n x: minX,\n y: minY,\n width: maxX - minX,\n height: maxY - minY\n };\n}\nfunction getRectsByLine(rects) {\n const sortedRects = rects.slice().sort((a, b) => a.y - b.y);\n const groups = [];\n let prevRect = null;\n for (let i = 0; i < sortedRects.length; i++) {\n const rect = sortedRects[i];\n if (!prevRect || rect.y - prevRect.y > prevRect.height / 2) {\n groups.push([rect]);\n } else {\n groups[groups.length - 1].push(rect);\n }\n prevRect = rect;\n }\n return groups.map(rect => rectToClientRect(getBoundingRect(rect)));\n}\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'inline',\n options,\n async fn(state) {\n const {\n placement,\n elements,\n rects,\n platform,\n strategy\n } = state;\n // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a\n // ClientRect's bounds, despite the event listener being triggered. A\n // padding of 2 seems to handle this issue.\n const {\n padding = 2,\n x,\n y\n } = evaluate(options, state);\n const nativeClientRects = Array.from((await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) || []);\n const clientRects = getRectsByLine(nativeClientRects);\n const fallback = rectToClientRect(getBoundingRect(nativeClientRects));\n const paddingObject = getPaddingObject(padding);\n function getBoundingClientRect() {\n // There are two rects and they are disjoined.\n if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {\n // Find the first rect in which the point is fully inside.\n return clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom) || fallback;\n }\n\n // There are 2 or more connected rects.\n if (clientRects.length >= 2) {\n if (getSideAxis(placement) === 'y') {\n const firstRect = clientRects[0];\n const lastRect = clientRects[clientRects.length - 1];\n const isTop = getSide(placement) === 'top';\n const top = firstRect.top;\n const bottom = lastRect.bottom;\n const left = isTop ? firstRect.left : lastRect.left;\n const right = isTop ? firstRect.right : lastRect.right;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n const isLeftSide = getSide(placement) === 'left';\n const maxRight = max(...clientRects.map(rect => rect.right));\n const minLeft = min(...clientRects.map(rect => rect.left));\n const measureRects = clientRects.filter(rect => isLeftSide ? rect.left === minLeft : rect.right === maxRight);\n const top = measureRects[0].top;\n const bottom = measureRects[measureRects.length - 1].bottom;\n const left = minLeft;\n const right = maxRight;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n return fallback;\n }\n const resetRects = await platform.getElementRects({\n reference: {\n getBoundingClientRect\n },\n floating: elements.floating,\n strategy\n });\n if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {\n return {\n reset: {\n rects: resetRects\n }\n };\n }\n return {};\n }\n };\n};\n\nconst originSides = /*#__PURE__*/new Set(['left', 'top']);\n\n// For type backwards-compatibility, the `OffsetOptions` type was also\n// Derivable.\n\nasync function convertValueToCoords(state, options) {\n const {\n placement,\n platform,\n elements\n } = state;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const side = getSide(placement);\n const alignment = getAlignment(placement);\n const isVertical = getSideAxis(placement) === 'y';\n const mainAxisMulti = originSides.has(side) ? -1 : 1;\n const crossAxisMulti = rtl && isVertical ? -1 : 1;\n const rawValue = evaluate(options, state);\n\n // eslint-disable-next-line prefer-const\n let {\n mainAxis,\n crossAxis,\n alignmentAxis\n } = typeof rawValue === 'number' ? {\n mainAxis: rawValue,\n crossAxis: 0,\n alignmentAxis: null\n } : {\n mainAxis: rawValue.mainAxis || 0,\n crossAxis: rawValue.crossAxis || 0,\n alignmentAxis: rawValue.alignmentAxis\n };\n if (alignment && typeof alignmentAxis === 'number') {\n crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;\n }\n return isVertical ? {\n x: crossAxis * crossAxisMulti,\n y: mainAxis * mainAxisMulti\n } : {\n x: mainAxis * mainAxisMulti,\n y: crossAxis * crossAxisMulti\n };\n}\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = function (options) {\n if (options === void 0) {\n options = 0;\n }\n return {\n name: 'offset',\n options,\n async fn(state) {\n var _middlewareData$offse, _middlewareData$arrow;\n const {\n x,\n y,\n placement,\n middlewareData\n } = state;\n const diffCoords = await convertValueToCoords(state, options);\n\n // If the placement is the same and the arrow caused an alignment offset\n // then we don't need to change the positioning coordinates.\n if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n return {};\n }\n return {\n x: x + diffCoords.x,\n y: y + diffCoords.y,\n data: {\n ...diffCoords,\n placement\n }\n };\n }\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'shift',\n options,\n async fn(state) {\n const {\n x,\n y,\n placement,\n platform\n } = state;\n const {\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = false,\n limiter = {\n fn: _ref => {\n let {\n x,\n y\n } = _ref;\n return {\n x,\n y\n };\n }\n },\n ...detectOverflowOptions\n } = evaluate(options, state);\n const coords = {\n x,\n y\n };\n const overflow = await platform.detectOverflow(state, detectOverflowOptions);\n const crossAxis = getSideAxis(getSide(placement));\n const mainAxis = getOppositeAxis(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n if (checkMainAxis) {\n const minSide = mainAxis === 'y' ? 'top' : 'left';\n const maxSide = mainAxis === 'y' ? 'bottom' : 'right';\n const min = mainAxisCoord + overflow[minSide];\n const max = mainAxisCoord - overflow[maxSide];\n mainAxisCoord = clamp(min, mainAxisCoord, max);\n }\n if (checkCrossAxis) {\n const minSide = crossAxis === 'y' ? 'top' : 'left';\n const maxSide = crossAxis === 'y' ? 'bottom' : 'right';\n const min = crossAxisCoord + overflow[minSide];\n const max = crossAxisCoord - overflow[maxSide];\n crossAxisCoord = clamp(min, crossAxisCoord, max);\n }\n const limitedCoords = limiter.fn({\n ...state,\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n });\n return {\n ...limitedCoords,\n data: {\n x: limitedCoords.x - x,\n y: limitedCoords.y - y,\n enabled: {\n [mainAxis]: checkMainAxis,\n [crossAxis]: checkCrossAxis\n }\n }\n };\n }\n };\n};\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n options,\n fn(state) {\n const {\n x,\n y,\n placement,\n rects,\n middlewareData\n } = state;\n const {\n offset = 0,\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true\n } = evaluate(options, state);\n const coords = {\n x,\n y\n };\n const crossAxis = getSideAxis(placement);\n const mainAxis = getOppositeAxis(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n const rawOffset = evaluate(offset, state);\n const computedOffset = typeof rawOffset === 'number' ? {\n mainAxis: rawOffset,\n crossAxis: 0\n } : {\n mainAxis: 0,\n crossAxis: 0,\n ...rawOffset\n };\n if (checkMainAxis) {\n const len = mainAxis === 'y' ? 'height' : 'width';\n const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;\n const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;\n if (mainAxisCoord < limitMin) {\n mainAxisCoord = limitMin;\n } else if (mainAxisCoord > limitMax) {\n mainAxisCoord = limitMax;\n }\n }\n if (checkCrossAxis) {\n var _middlewareData$offse, _middlewareData$offse2;\n const len = mainAxis === 'y' ? 'width' : 'height';\n const isOriginSide = originSides.has(getSide(placement));\n const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n if (crossAxisCoord < limitMin) {\n crossAxisCoord = limitMin;\n } else if (crossAxisCoord > limitMax) {\n crossAxisCoord = limitMax;\n }\n }\n return {\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n };\n }\n };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'size',\n options,\n async fn(state) {\n var _state$middlewareData, _state$middlewareData2;\n const {\n placement,\n rects,\n platform,\n elements\n } = state;\n const {\n apply = () => {},\n ...detectOverflowOptions\n } = evaluate(options, state);\n const overflow = await platform.detectOverflow(state, detectOverflowOptions);\n const side = getSide(placement);\n const alignment = getAlignment(placement);\n const isYAxis = getSideAxis(placement) === 'y';\n const {\n width,\n height\n } = rects.floating;\n let heightSide;\n let widthSide;\n if (side === 'top' || side === 'bottom') {\n heightSide = side;\n widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';\n } else {\n widthSide = side;\n heightSide = alignment === 'end' ? 'top' : 'bottom';\n }\n const maximumClippingHeight = height - overflow.top - overflow.bottom;\n const maximumClippingWidth = width - overflow.left - overflow.right;\n const overflowAvailableHeight = min(height - overflow[heightSide], maximumClippingHeight);\n const overflowAvailableWidth = min(width - overflow[widthSide], maximumClippingWidth);\n const noShift = !state.middlewareData.shift;\n let availableHeight = overflowAvailableHeight;\n let availableWidth = overflowAvailableWidth;\n if ((_state$middlewareData = state.middlewareData.shift) != null && _state$middlewareData.enabled.x) {\n availableWidth = maximumClippingWidth;\n }\n if ((_state$middlewareData2 = state.middlewareData.shift) != null && _state$middlewareData2.enabled.y) {\n availableHeight = maximumClippingHeight;\n }\n if (noShift && !alignment) {\n const xMin = max(overflow.left, 0);\n const xMax = max(overflow.right, 0);\n const yMin = max(overflow.top, 0);\n const yMax = max(overflow.bottom, 0);\n if (isYAxis) {\n availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));\n } else {\n availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));\n }\n }\n await apply({\n ...state,\n availableWidth,\n availableHeight\n });\n const nextDimensions = await platform.getDimensions(elements.floating);\n if (width !== nextDimensions.width || height !== nextDimensions.height) {\n return {\n reset: {\n rects: true\n }\n };\n }\n return {};\n }\n };\n};\n\nexport { arrow, autoPlacement, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, shift, size };\n","function hasWindow() {\n return typeof window !== 'undefined';\n}\nfunction getNodeName(node) {\n if (isNode(node)) {\n return (node.nodeName || '').toLowerCase();\n }\n // Mocked nodes in testing environments may not be instances of Node. By\n // returning `#document` an infinite loop won't occur.\n // https://github.com/floating-ui/floating-ui/issues/2317\n return '#document';\n}\nfunction getWindow(node) {\n var _node$ownerDocument;\n return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n var _ref;\n return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n if (!hasWindow() || typeof ShadowRoot === 'undefined') {\n return false;\n }\n return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nfunction isOverflowElement(element) {\n const {\n overflow,\n overflowX,\n overflowY,\n display\n } = getComputedStyle(element);\n return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && display !== 'inline' && display !== 'contents';\n}\nfunction isTableElement(element) {\n return /^(table|td|th)$/.test(getNodeName(element));\n}\nfunction isTopLayer(element) {\n try {\n if (element.matches(':popover-open')) {\n return true;\n }\n } catch (_e) {\n // no-op\n }\n try {\n return element.matches(':modal');\n } catch (_e) {\n return false;\n }\n}\nconst willChangeRe = /transform|translate|scale|rotate|perspective|filter/;\nconst containRe = /paint|layout|strict|content/;\nconst isNotNone = value => !!value && value !== 'none';\nlet isWebKitValue;\nfunction isContainingBlock(elementOrCss) {\n const css = isElement(elementOrCss) ? getComputedStyle(elementOrCss) : elementOrCss;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n // https://drafts.csswg.org/css-transforms-2/#individual-transforms\n return isNotNone(css.transform) || isNotNone(css.translate) || isNotNone(css.scale) || isNotNone(css.rotate) || isNotNone(css.perspective) || !isWebKit() && (isNotNone(css.backdropFilter) || isNotNone(css.filter)) || willChangeRe.test(css.willChange || '') || containRe.test(css.contain || '');\n}\nfunction getContainingBlock(element) {\n let currentNode = getParentNode(element);\n while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n if (isContainingBlock(currentNode)) {\n return currentNode;\n } else if (isTopLayer(currentNode)) {\n return null;\n }\n currentNode = getParentNode(currentNode);\n }\n return null;\n}\nfunction isWebKit() {\n if (isWebKitValue == null) {\n isWebKitValue = typeof CSS !== 'undefined' && CSS.supports && CSS.supports('-webkit-backdrop-filter', 'none');\n }\n return isWebKitValue;\n}\nfunction isLastTraversableNode(node) {\n return /^(html|body|#document)$/.test(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n if (isElement(element)) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n }\n return {\n scrollLeft: element.scrollX,\n scrollTop: element.scrollY\n };\n}\nfunction getParentNode(node) {\n if (getNodeName(node) === 'html') {\n return node;\n }\n const result =\n // Step into the shadow DOM of the parent of a slotted node.\n node.assignedSlot ||\n // DOM Element detected.\n node.parentNode ||\n // ShadowRoot detected.\n isShadowRoot(node) && node.host ||\n // Fallback.\n getDocumentElement(node);\n return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n const parentNode = getParentNode(node);\n if (isLastTraversableNode(parentNode)) {\n return node.ownerDocument ? node.ownerDocument.body : node.body;\n }\n if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n return parentNode;\n }\n return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list, traverseIframes) {\n var _node$ownerDocument2;\n if (list === void 0) {\n list = [];\n }\n if (traverseIframes === void 0) {\n traverseIframes = true;\n }\n const scrollableAncestor = getNearestOverflowAncestor(node);\n const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n const win = getWindow(scrollableAncestor);\n if (isBody) {\n const frameElement = getFrameElement(win);\n return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);\n } else {\n return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));\n }\n}\nfunction getFrameElement(win) {\n return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getFrameElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isTopLayer, isWebKit };\n","import { rectToClientRect, arrow as arrow$1, autoPlacement as autoPlacement$1, detectOverflow as detectOverflow$1, flip as flip$1, hide as hide$1, inline as inline$1, limitShift as limitShift$1, offset as offset$1, shift as shift$1, size as size$1, computePosition as computePosition$1 } from '@floating-ui/core';\nimport { round, createCoords, max, min, floor } from '@floating-ui/utils';\nimport { getComputedStyle as getComputedStyle$1, isHTMLElement, isElement, getWindow, isWebKit, getFrameElement, getNodeScroll, getDocumentElement, isTopLayer, getNodeName, isOverflowElement, getOverflowAncestors, getParentNode, isLastTraversableNode, isContainingBlock, isTableElement, getContainingBlock } from '@floating-ui/utils/dom';\nexport { getOverflowAncestors } from '@floating-ui/utils/dom';\n\nfunction getCssDimensions(element) {\n const css = getComputedStyle$1(element);\n // In testing environments, the `width` and `height` properties are empty\n // strings for SVG elements, returning NaN. Fallback to `0` in this case.\n let width = parseFloat(css.width) || 0;\n let height = parseFloat(css.height) || 0;\n const hasOffset = isHTMLElement(element);\n const offsetWidth = hasOffset ? element.offsetWidth : width;\n const offsetHeight = hasOffset ? element.offsetHeight : height;\n const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight;\n if (shouldFallback) {\n width = offsetWidth;\n height = offsetHeight;\n }\n return {\n width,\n height,\n $: shouldFallback\n };\n}\n\nfunction unwrapElement(element) {\n return !isElement(element) ? element.contextElement : element;\n}\n\nfunction getScale(element) {\n const domElement = unwrapElement(element);\n if (!isHTMLElement(domElement)) {\n return createCoords(1);\n }\n const rect = domElement.getBoundingClientRect();\n const {\n width,\n height,\n $\n } = getCssDimensions(domElement);\n let x = ($ ? round(rect.width) : rect.width) / width;\n let y = ($ ? round(rect.height) : rect.height) / height;\n\n // 0, NaN, or Infinity should always fallback to 1.\n\n if (!x || !Number.isFinite(x)) {\n x = 1;\n }\n if (!y || !Number.isFinite(y)) {\n y = 1;\n }\n return {\n x,\n y\n };\n}\n\nconst noOffsets = /*#__PURE__*/createCoords(0);\nfunction getVisualOffsets(element) {\n const win = getWindow(element);\n if (!isWebKit() || !win.visualViewport) {\n return noOffsets;\n }\n return {\n x: win.visualViewport.offsetLeft,\n y: win.visualViewport.offsetTop\n };\n}\nfunction shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow(element)) {\n return false;\n }\n return isFixed;\n}\n\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n const clientRect = element.getBoundingClientRect();\n const domElement = unwrapElement(element);\n let scale = createCoords(1);\n if (includeScale) {\n if (offsetParent) {\n if (isElement(offsetParent)) {\n scale = getScale(offsetParent);\n }\n } else {\n scale = getScale(element);\n }\n }\n const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0);\n let x = (clientRect.left + visualOffsets.x) / scale.x;\n let y = (clientRect.top + visualOffsets.y) / scale.y;\n let width = clientRect.width / scale.x;\n let height = clientRect.height / scale.y;\n if (domElement) {\n const win = getWindow(domElement);\n const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;\n let currentWin = win;\n let currentIFrame = getFrameElement(currentWin);\n while (currentIFrame && offsetParent && offsetWin !== currentWin) {\n const iframeScale = getScale(currentIFrame);\n const iframeRect = currentIFrame.getBoundingClientRect();\n const css = getComputedStyle$1(currentIFrame);\n const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;\n const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;\n x *= iframeScale.x;\n y *= iframeScale.y;\n width *= iframeScale.x;\n height *= iframeScale.y;\n x += left;\n y += top;\n currentWin = getWindow(currentIFrame);\n currentIFrame = getFrameElement(currentWin);\n }\n }\n return rectToClientRect({\n width,\n height,\n x,\n y\n });\n}\n\n// If <html> has a CSS width greater than the viewport, then this will be\n// incorrect for RTL.\nfunction getWindowScrollBarX(element, rect) {\n const leftScroll = getNodeScroll(element).scrollLeft;\n if (!rect) {\n return getBoundingClientRect(getDocumentElement(element)).left + leftScroll;\n }\n return rect.left + leftScroll;\n}\n\nfunction getHTMLOffset(documentElement, scroll) {\n const htmlRect = documentElement.getBoundingClientRect();\n const x = htmlRect.left + scroll.scrollLeft - getWindowScrollBarX(documentElement, htmlRect);\n const y = htmlRect.top + scroll.scrollTop;\n return {\n x,\n y\n };\n}\n\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n let {\n elements,\n rect,\n offsetParent,\n strategy\n } = _ref;\n const isFixed = strategy === 'fixed';\n const documentElement = getDocumentElement(offsetParent);\n const topLayer = elements ? isTopLayer(elements.floating) : false;\n if (offsetParent === documentElement || topLayer && isFixed) {\n return rect;\n }\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n let scale = createCoords(1);\n const offsets = createCoords(0);\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isOffsetParentAnElement) {\n const offsetRect = getBoundingClientRect(offsetParent);\n scale = getScale(offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n }\n }\n const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll) : createCoords(0);\n return {\n width: rect.width * scale.x,\n height: rect.height * scale.y,\n x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x + htmlOffset.x,\n y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y + htmlOffset.y\n };\n}\n\nfunction getClientRects(element) {\n return Array.from(element.getClientRects());\n}\n\n// Gets the entire size of the scrollable document area, even extending outside\n// of the `<html>` and `<body>` rect bounds if horizontally scrollable.\nfunction getDocumentRect(element) {\n const html = getDocumentElement(element);\n const scroll = getNodeScroll(element);\n const body = element.ownerDocument.body;\n const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);\n const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);\n let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n const y = -scroll.scrollTop;\n if (getComputedStyle$1(body).direction === 'rtl') {\n x += max(html.clientWidth, body.clientWidth) - width;\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\n// Safety check: ensure the scrollbar space is reasonable in case this\n// calculation is affected by unusual styles.\n// Most scrollbars leave 15-18px of space.\nconst SCROLLBAR_MAX = 25;\nfunction getViewportRect(element, strategy) {\n const win = getWindow(element);\n const html = getDocumentElement(element);\n const visualViewport = win.visualViewport;\n let width = html.clientWidth;\n let height = html.clientHeight;\n let x = 0;\n let y = 0;\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n const visualViewportBased = isWebKit();\n if (!visualViewportBased || visualViewportBased && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n const windowScrollbarX = getWindowScrollBarX(html);\n // <html> `overflow: hidden` + `scrollbar-gutter: stable` reduces the\n // visual width of the <html> but this is not considered in the size\n // of `html.clientWidth`.\n if (windowScrollbarX <= 0) {\n const doc = html.ownerDocument;\n const body = doc.body;\n const bodyStyles = getComputedStyle(body);\n const bodyMarginInline = doc.compatMode === 'CSS1Compat' ? parseFloat(bodyStyles.marginLeft) + parseFloat(bodyStyles.marginRight) || 0 : 0;\n const clippingStableScrollbarWidth = Math.abs(html.clientWidth - body.clientWidth - bodyMarginInline);\n if (clippingStableScrollbarWidth <= SCROLLBAR_MAX) {\n width -= clippingStableScrollbarWidth;\n }\n } else if (windowScrollbarX <= SCROLLBAR_MAX) {\n // If the <body> scrollbar is on the left, the width needs to be extended\n // by the scrollbar amount so there isn't extra space on the right.\n width += windowScrollbarX;\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\n// Returns the inner client rect, subtracting scrollbars if present.\nfunction getInnerBoundingClientRect(element, strategy) {\n const clientRect = getBoundingClientRect(element, true, strategy === 'fixed');\n const top = clientRect.top + element.clientTop;\n const left = clientRect.left + element.clientLeft;\n const scale = isHTMLElement(element) ? getScale(element) : createCoords(1);\n const width = element.clientWidth * scale.x;\n const height = element.clientHeight * scale.y;\n const x = left * scale.x;\n const y = top * scale.y;\n return {\n width,\n height,\n x,\n y\n };\n}\nfunction getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {\n let rect;\n if (clippingAncestor === 'viewport') {\n rect = getViewportRect(element, strategy);\n } else if (clippingAncestor === 'document') {\n rect = getDocumentRect(getDocumentElement(element));\n } else if (isElement(clippingAncestor)) {\n rect = getInnerBoundingClientRect(clippingAncestor, strategy);\n } else {\n const visualOffsets = getVisualOffsets(element);\n rect = {\n x: clippingAncestor.x - visualOffsets.x,\n y: clippingAncestor.y - visualOffsets.y,\n width: clippingAncestor.width,\n height: clippingAncestor.height\n };\n }\n return rectToClientRect(rect);\n}\nfunction hasFixedPositionAncestor(element, stopNode) {\n const parentNode = getParentNode(element);\n if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) {\n return false;\n }\n return getComputedStyle$1(parentNode).position === 'fixed' || hasFixedPositionAncestor(parentNode, stopNode);\n}\n\n// A \"clipping ancestor\" is an `overflow` element with the characteristic of\n// clipping (or hiding) child elements. This returns all clipping ancestors\n// of the given element up the tree.\nfunction getClippingElementAncestors(element, cache) {\n const cachedResult = cache.get(element);\n if (cachedResult) {\n return cachedResult;\n }\n let result = getOverflowAncestors(element, [], false).filter(el => isElement(el) && getNodeName(el) !== 'body');\n let currentContainingBlockComputedStyle = null;\n const elementIsFixed = getComputedStyle$1(element).position === 'fixed';\n let currentNode = elementIsFixed ? getParentNode(element) : element;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n while (isElement(currentNode) && !isLastTraversableNode(currentNode)) {\n const computedStyle = getComputedStyle$1(currentNode);\n const currentNodeIsContaining = isContainingBlock(currentNode);\n if (!currentNodeIsContaining && computedStyle.position === 'fixed') {\n currentContainingBlockComputedStyle = null;\n }\n const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === 'static' && !!currentContainingBlockComputedStyle && (currentContainingBlockComputedStyle.position === 'absolute' || currentContainingBlockComputedStyle.position === 'fixed') || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);\n if (shouldDropCurrentNode) {\n // Drop non-containing blocks.\n result = result.filter(ancestor => ancestor !== currentNode);\n } else {\n // Record last containing block for next iteration.\n currentContainingBlockComputedStyle = computedStyle;\n }\n currentNode = getParentNode(currentNode);\n }\n cache.set(element, result);\n return result;\n}\n\n// Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors.\nfunction getClippingRect(_ref) {\n let {\n element,\n boundary,\n rootBoundary,\n strategy\n } = _ref;\n const elementClippingAncestors = boundary === 'clippingAncestors' ? isTopLayer(element) ? [] : getClippingElementAncestors(element, this._c) : [].concat(boundary);\n const clippingAncestors = [...elementClippingAncestors, rootBoundary];\n const firstRect = getClientRectFromClippingAncestor(element, clippingAncestors[0], strategy);\n let top = firstRect.top;\n let right = firstRect.right;\n let bottom = firstRect.bottom;\n let left = firstRect.left;\n for (let i = 1; i < clippingAncestors.length; i++) {\n const rect = getClientRectFromClippingAncestor(element, clippingAncestors[i], strategy);\n top = max(rect.top, top);\n right = min(rect.right, right);\n bottom = min(rect.bottom, bottom);\n left = max(rect.left, left);\n }\n return {\n width: right - left,\n height: bottom - top,\n x: left,\n y: top\n };\n}\n\nfunction getDimensions(element) {\n const {\n width,\n height\n } = getCssDimensions(element);\n return {\n width,\n height\n };\n}\n\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy) {\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n const documentElement = getDocumentElement(offsetParent);\n const isFixed = strategy === 'fixed';\n const rect = getBoundingClientRect(element, true, isFixed, offsetParent);\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n const offsets = createCoords(0);\n\n // If the <body> scrollbar appears on the left (e.g. RTL systems). Use\n // Firefox with layout.scrollbar.side = 3 in about:config to test this.\n function setLeftRTLScrollbarOffset() {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isOffsetParentAnElement) {\n const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n } else if (documentElement) {\n setLeftRTLScrollbarOffset();\n }\n }\n if (isFixed && !isOffsetParentAnElement && documentElement) {\n setLeftRTLScrollbarOffset();\n }\n const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll) : createCoords(0);\n const x = rect.left + scroll.scrollLeft - offsets.x - htmlOffset.x;\n const y = rect.top + scroll.scrollTop - offsets.y - htmlOffset.y;\n return {\n x,\n y,\n width: rect.width,\n height: rect.height\n };\n}\n\nfunction isStaticPositioned(element) {\n return getComputedStyle$1(element).position === 'static';\n}\n\nfunction getTrueOffsetParent(element, polyfill) {\n if (!isHTMLElement(element) || getComputedStyle$1(element).position === 'fixed') {\n return null;\n }\n if (polyfill) {\n return polyfill(element);\n }\n let rawOffsetParent = element.offsetParent;\n\n // Firefox returns the <html> element as the offsetParent if it's non-static,\n // while Chrome and Safari return the <body> element. The <body> element must\n // be used to perform the correct calculations even if the <html> element is\n // non-static.\n if (getDocumentElement(element) === rawOffsetParent) {\n rawOffsetParent = rawOffsetParent.ownerDocument.body;\n }\n return rawOffsetParent;\n}\n\n// Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\nfunction getOffsetParent(element, polyfill) {\n const win = getWindow(element);\n if (isTopLayer(element)) {\n return win;\n }\n if (!isHTMLElement(element)) {\n let svgOffsetParent = getParentNode(element);\n while (svgOffsetParent && !isLastTraversableNode(svgOffsetParent)) {\n if (isElement(svgOffsetParent) && !isStaticPositioned(svgOffsetParent)) {\n return svgOffsetParent;\n }\n svgOffsetParent = getParentNode(svgOffsetParent);\n }\n return win;\n }\n let offsetParent = getTrueOffsetParent(element, polyfill);\n while (offsetParent && isTableElement(offsetParent) && isStaticPositioned(offsetParent)) {\n offsetParent = getTrueOffsetParent(offsetParent, polyfill);\n }\n if (offsetParent && isLastTraversableNode(offsetParent) && isStaticPositioned(offsetParent) && !isContainingBlock(offsetParent)) {\n return win;\n }\n return offsetParent || getContainingBlock(element) || win;\n}\n\nconst getElementRects = async function (data) {\n const getOffsetParentFn = this.getOffsetParent || getOffsetParent;\n const getDimensionsFn = this.getDimensions;\n const floatingDimensions = await getDimensionsFn(data.floating);\n return {\n reference: getRectRelativeToOffsetParent(data.reference, await getOffsetParentFn(data.floating), data.strategy),\n floating: {\n x: 0,\n y: 0,\n width: floatingDimensions.width,\n height: floatingDimensions.height\n }\n };\n};\n\nfunction isRTL(element) {\n return getComputedStyle$1(element).direction === 'rtl';\n}\n\nconst platform = {\n convertOffsetParentRelativeRectToViewportRelativeRect,\n getDocumentElement,\n getClippingRect,\n getOffsetParent,\n getElementRects,\n getClientRects,\n getDimensions,\n getScale,\n isElement,\n isRTL\n};\n\nfunction rectsAreEqual(a, b) {\n return a.x === b.x && a.y === b.y && a.width === b.width && a.height === b.height;\n}\n\n// https://samthor.au/2021/observing-dom/\nfunction observeMove(element, onMove) {\n let io = null;\n let timeoutId;\n const root = getDocumentElement(element);\n function cleanup() {\n var _io;\n clearTimeout(timeoutId);\n (_io = io) == null || _io.disconnect();\n io = null;\n }\n function refresh(skip, threshold) {\n if (skip === void 0) {\n skip = false;\n }\n if (threshold === void 0) {\n threshold = 1;\n }\n cleanup();\n const elementRectForRootMargin = element.getBoundingClientRect();\n const {\n left,\n top,\n width,\n height\n } = elementRectForRootMargin;\n if (!skip) {\n onMove();\n }\n if (!width || !height) {\n return;\n }\n const insetTop = floor(top);\n const insetRight = floor(root.clientWidth - (left + width));\n const insetBottom = floor(root.clientHeight - (top + height));\n const insetLeft = floor(left);\n const rootMargin = -insetTop + \"px \" + -insetRight + \"px \" + -insetBottom + \"px \" + -insetLeft + \"px\";\n const options = {\n rootMargin,\n threshold: max(0, min(1, threshold)) || 1\n };\n let isFirstUpdate = true;\n function handleObserve(entries) {\n const ratio = entries[0].intersectionRatio;\n if (ratio !== threshold) {\n if (!isFirstUpdate) {\n return refresh();\n }\n if (!ratio) {\n // If the reference is clipped, the ratio is 0. Throttle the refresh\n // to prevent an infinite loop of updates.\n timeoutId = setTimeout(() => {\n refresh(false, 1e-7);\n }, 1000);\n } else {\n refresh(false, ratio);\n }\n }\n if (ratio === 1 && !rectsAreEqual(elementRectForRootMargin, element.getBoundingClientRect())) {\n // It's possible that even though the ratio is reported as 1, the\n // element is not actually fully within the IntersectionObserver's root\n // area anymore. This can happen under performance constraints. This may\n // be a bug in the browser's IntersectionObserver implementation. To\n // work around this, we compare the element's bounding rect now with\n // what it was at the time we created the IntersectionObserver. If they\n // are not equal then the element moved, so we refresh.\n refresh();\n }\n isFirstUpdate = false;\n }\n\n // Older browsers don't support a `document` as the root and will throw an\n // error.\n try {\n io = new IntersectionObserver(handleObserve, {\n ...options,\n // Handle <iframe>s\n root: root.ownerDocument\n });\n } catch (_e) {\n io = new IntersectionObserver(handleObserve, options);\n }\n io.observe(element);\n }\n refresh(true);\n return cleanup;\n}\n\n/**\n * Automatically updates the position of the floating element when necessary.\n * Should only be called when the floating element is mounted on the DOM or\n * visible on the screen.\n * @returns cleanup function that should be invoked when the floating element is\n * removed from the DOM or hidden from the screen.\n * @see https://floating-ui.com/docs/autoUpdate\n */\nfunction autoUpdate(reference, floating, update, options) {\n if (options === void 0) {\n options = {};\n }\n const {\n ancestorScroll = true,\n ancestorResize = true,\n elementResize = typeof ResizeObserver === 'function',\n layoutShift = typeof IntersectionObserver === 'function',\n animationFrame = false\n } = options;\n const referenceEl = unwrapElement(reference);\n const ancestors = ancestorScroll || ancestorResize ? [...(referenceEl ? getOverflowAncestors(referenceEl) : []), ...(floating ? getOverflowAncestors(floating) : [])] : [];\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.addEventListener('scroll', update, {\n passive: true\n });\n ancestorResize && ancestor.addEventListener('resize', update);\n });\n const cleanupIo = referenceEl && layoutShift ? observeMove(referenceEl, update) : null;\n let reobserveFrame = -1;\n let resizeObserver = null;\n if (elementResize) {\n resizeObserver = new ResizeObserver(_ref => {\n let [firstEntry] = _ref;\n if (firstEntry && firstEntry.target === referenceEl && resizeObserver && floating) {\n // Prevent update loops when using the `size` middleware.\n // https://github.com/floating-ui/floating-ui/issues/1740\n resizeObserver.unobserve(floating);\n cancelAnimationFrame(reobserveFrame);\n reobserveFrame = requestAnimationFrame(() => {\n var _resizeObserver;\n (_resizeObserver = resizeObserver) == null || _resizeObserver.observe(floating);\n });\n }\n update();\n });\n if (referenceEl && !animationFrame) {\n resizeObserver.observe(referenceEl);\n }\n if (floating) {\n resizeObserver.observe(floating);\n }\n }\n let frameId;\n let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;\n if (animationFrame) {\n frameLoop();\n }\n function frameLoop() {\n const nextRefRect = getBoundingClientRect(reference);\n if (prevRefRect && !rectsAreEqual(prevRefRect, nextRefRect)) {\n update();\n }\n prevRefRect = nextRefRect;\n frameId = requestAnimationFrame(frameLoop);\n }\n update();\n return () => {\n var _resizeObserver2;\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.removeEventListener('scroll', update);\n ancestorResize && ancestor.removeEventListener('resize', update);\n });\n cleanupIo == null || cleanupIo();\n (_resizeObserver2 = resizeObserver) == null || _resizeObserver2.disconnect();\n resizeObserver = null;\n if (animationFrame) {\n cancelAnimationFrame(frameId);\n }\n };\n}\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nconst detectOverflow = detectOverflow$1;\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = offset$1;\n\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = autoPlacement$1;\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = shift$1;\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = flip$1;\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = size$1;\n\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = hide$1;\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = arrow$1;\n\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = inline$1;\n\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = limitShift$1;\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n */\nconst computePosition = (reference, floating, options) => {\n // This caches the expensive `getClippingElementAncestors` function so that\n // multiple lifecycle resets re-use the same result. It only lives for a\n // single call. If other functions become expensive, we can add them as well.\n const cache = new Map();\n const mergedOptions = {\n platform,\n ...options\n };\n const platformWithCache = {\n ...mergedOptions.platform,\n _c: cache\n };\n return computePosition$1(reference, floating, {\n ...mergedOptions,\n platform: platformWithCache\n });\n};\n\nexport { arrow, autoPlacement, autoUpdate, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, platform, shift, size };\n","import { computePosition, arrow as arrow$2, autoPlacement as autoPlacement$1, flip as flip$1, hide as hide$1, inline as inline$1, limitShift as limitShift$1, offset as offset$1, shift as shift$1, size as size$1 } from '@floating-ui/dom';\nexport { autoUpdate, computePosition, detectOverflow, getOverflowAncestors, platform } from '@floating-ui/dom';\nimport * as React from 'react';\nimport { useLayoutEffect } from 'react';\nimport * as ReactDOM from 'react-dom';\n\nvar isClient = typeof document !== 'undefined';\n\nvar noop = function noop() {};\nvar index = isClient ? useLayoutEffect : noop;\n\n// Fork of `fast-deep-equal` that only does the comparisons we need and compares\n// functions\nfunction deepEqual(a, b) {\n if (a === b) {\n return true;\n }\n if (typeof a !== typeof b) {\n return false;\n }\n if (typeof a === 'function' && a.toString() === b.toString()) {\n return true;\n }\n let length;\n let i;\n let keys;\n if (a && b && typeof a === 'object') {\n if (Array.isArray(a)) {\n length = a.length;\n if (length !== b.length) return false;\n for (i = length; i-- !== 0;) {\n if (!deepEqual(a[i], b[i])) {\n return false;\n }\n }\n return true;\n }\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) {\n return false;\n }\n for (i = length; i-- !== 0;) {\n if (!{}.hasOwnProperty.call(b, keys[i])) {\n return false;\n }\n }\n for (i = length; i-- !== 0;) {\n const key = keys[i];\n if (key === '_owner' && a.$$typeof) {\n continue;\n }\n if (!deepEqual(a[key], b[key])) {\n return false;\n }\n }\n return true;\n }\n return a !== a && b !== b;\n}\n\nfunction getDPR(element) {\n if (typeof window === 'undefined') {\n return 1;\n }\n const win = element.ownerDocument.defaultView || window;\n return win.devicePixelRatio || 1;\n}\n\nfunction roundByDPR(element, value) {\n const dpr = getDPR(element);\n return Math.round(value * dpr) / dpr;\n}\n\nfunction useLatestRef(value) {\n const ref = React.useRef(value);\n index(() => {\n ref.current = value;\n });\n return ref;\n}\n\n/**\n * Provides data to position a floating element.\n * @see https://floating-ui.com/docs/useFloating\n */\nfunction useFloating(options) {\n if (options === void 0) {\n options = {};\n }\n const {\n placement = 'bottom',\n strategy = 'absolute',\n middleware = [],\n platform,\n elements: {\n reference: externalReference,\n floating: externalFloating\n } = {},\n transform = true,\n whileElementsMounted,\n open\n } = options;\n const [data, setData] = React.useState({\n x: 0,\n y: 0,\n strategy,\n placement,\n middlewareData: {},\n isPositioned: false\n });\n const [latestMiddleware, setLatestMiddleware] = React.useState(middleware);\n if (!deepEqual(latestMiddleware, middleware)) {\n setLatestMiddleware(middleware);\n }\n const [_reference, _setReference] = React.useState(null);\n const [_floating, _setFloating] = React.useState(null);\n const setReference = React.useCallback(node => {\n if (node !== referenceRef.current) {\n referenceRef.current = node;\n _setReference(node);\n }\n }, []);\n const setFloating = React.useCallback(node => {\n if (node !== floatingRef.current) {\n floatingRef.current = node;\n _setFloating(node);\n }\n }, []);\n const referenceEl = externalReference || _reference;\n const floatingEl = externalFloating || _floating;\n const referenceRef = React.useRef(null);\n const floatingRef = React.useRef(null);\n const dataRef = React.useRef(data);\n const hasWhileElementsMounted = whileElementsMounted != null;\n const whileElementsMountedRef = useLatestRef(whileElementsMounted);\n const platformRef = useLatestRef(platform);\n const openRef = useLatestRef(open);\n const update = React.useCallback(() => {\n if (!referenceRef.current || !floatingRef.current) {\n return;\n }\n const config = {\n placement,\n strategy,\n middleware: latestMiddleware\n };\n if (platformRef.current) {\n config.platform = platformRef.current;\n }\n computePosition(referenceRef.current, floatingRef.current, config).then(data => {\n const fullData = {\n ...data,\n // The floating element's position may be recomputed while it's closed\n // but still mounted (such as when transitioning out). To ensure\n // `isPositioned` will be `false` initially on the next open, avoid\n // setting it to `true` when `open === false` (must be specified).\n isPositioned: openRef.current !== false\n };\n if (isMountedRef.current && !deepEqual(dataRef.current, fullData)) {\n dataRef.current = fullData;\n ReactDOM.flushSync(() => {\n setData(fullData);\n });\n }\n });\n }, [latestMiddleware, placement, strategy, platformRef, openRef]);\n index(() => {\n if (open === false && dataRef.current.isPositioned) {\n dataRef.current.isPositioned = false;\n setData(data => ({\n ...data,\n isPositioned: false\n }));\n }\n }, [open]);\n const isMountedRef = React.useRef(false);\n index(() => {\n isMountedRef.current = true;\n return () => {\n isMountedRef.current = false;\n };\n }, []);\n index(() => {\n if (referenceEl) referenceRef.current = referenceEl;\n if (floatingEl) floatingRef.current = floatingEl;\n if (referenceEl && floatingEl) {\n if (whileElementsMountedRef.current) {\n return whileElementsMountedRef.current(referenceEl, floatingEl, update);\n }\n update();\n }\n }, [referenceEl, floatingEl, update, whileElementsMountedRef, hasWhileElementsMounted]);\n const refs = React.useMemo(() => ({\n reference: referenceRef,\n floating: floatingRef,\n setReference,\n setFloating\n }), [setReference, setFloating]);\n const elements = React.useMemo(() => ({\n reference: referenceEl,\n floating: floatingEl\n }), [referenceEl, floatingEl]);\n const floatingStyles = React.useMemo(() => {\n const initialStyles = {\n position: strategy,\n left: 0,\n top: 0\n };\n if (!elements.floating) {\n return initialStyles;\n }\n const x = roundByDPR(elements.floating, data.x);\n const y = roundByDPR(elements.floating, data.y);\n if (transform) {\n return {\n ...initialStyles,\n transform: \"translate(\" + x + \"px, \" + y + \"px)\",\n ...(getDPR(elements.floating) >= 1.5 && {\n willChange: 'transform'\n })\n };\n }\n return {\n position: strategy,\n left: x,\n top: y\n };\n }, [strategy, transform, elements.floating, data.x, data.y]);\n return React.useMemo(() => ({\n ...data,\n update,\n refs,\n elements,\n floatingStyles\n }), [data, update, refs, elements, floatingStyles]);\n}\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * This wraps the core `arrow` middleware to allow React refs as the element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow$1 = options => {\n function isRef(value) {\n return {}.hasOwnProperty.call(value, 'current');\n }\n return {\n name: 'arrow',\n options,\n fn(state) {\n const {\n element,\n padding\n } = typeof options === 'function' ? options(state) : options;\n if (element && isRef(element)) {\n if (element.current != null) {\n return arrow$2({\n element: element.current,\n padding\n }).fn(state);\n }\n return {};\n }\n if (element) {\n return arrow$2({\n element,\n padding\n }).fn(state);\n }\n return {};\n }\n };\n};\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = (options, deps) => {\n const result = offset$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = (options, deps) => {\n const result = shift$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = (options, deps) => {\n const result = limitShift$1(options);\n return {\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = (options, deps) => {\n const result = flip$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = (options, deps) => {\n const result = size$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = (options, deps) => {\n const result = autoPlacement$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = (options, deps) => {\n const result = hide$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = (options, deps) => {\n const result = inline$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * This wraps the core `arrow` middleware to allow React refs as the element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = (options, deps) => {\n const result = arrow$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\nexport { arrow, autoPlacement, flip, hide, inline, limitShift, offset, shift, size, useFloating };\n","// src/arrow.tsx\nimport * as React from \"react\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NAME = \"Arrow\";\nvar Arrow = React.forwardRef((props, forwardedRef) => {\n const { children, width = 10, height = 5, ...arrowProps } = props;\n return /* @__PURE__ */ jsx(\n Primitive.svg,\n {\n ...arrowProps,\n ref: forwardedRef,\n width,\n height,\n viewBox: \"0 0 30 10\",\n preserveAspectRatio: \"none\",\n children: props.asChild ? children : /* @__PURE__ */ jsx(\"polygon\", { points: \"0,0 30,0 15,10\" })\n }\n );\n});\nArrow.displayName = NAME;\nvar Root = Arrow;\nexport {\n Arrow,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-size/src/use-size.tsx\nimport * as React from \"react\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nfunction useSize(element) {\n const [size, setSize] = React.useState(void 0);\n useLayoutEffect(() => {\n if (element) {\n setSize({ width: element.offsetWidth, height: element.offsetHeight });\n const resizeObserver = new ResizeObserver((entries) => {\n if (!Array.isArray(entries)) {\n return;\n }\n if (!entries.length) {\n return;\n }\n const entry = entries[0];\n let width;\n let height;\n if (\"borderBoxSize\" in entry) {\n const borderSizeEntry = entry[\"borderBoxSize\"];\n const borderSize = Array.isArray(borderSizeEntry) ? borderSizeEntry[0] : borderSizeEntry;\n width = borderSize[\"inlineSize\"];\n height = borderSize[\"blockSize\"];\n } else {\n width = element.offsetWidth;\n height = element.offsetHeight;\n }\n setSize({ width, height });\n });\n resizeObserver.observe(element, { box: \"border-box\" });\n return () => resizeObserver.unobserve(element);\n } else {\n setSize(void 0);\n }\n }, [element]);\n return size;\n}\nexport {\n useSize\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/popper.tsx\nimport * as React from \"react\";\nimport {\n useFloating,\n autoUpdate,\n offset,\n shift,\n limitShift,\n hide,\n arrow as floatingUIarrow,\n flip,\n size\n} from \"@floating-ui/react-dom\";\nimport * as ArrowPrimitive from \"@radix-ui/react-arrow\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { useSize } from \"@radix-ui/react-use-size\";\nimport { jsx } from \"react/jsx-runtime\";\nvar SIDE_OPTIONS = [\"top\", \"right\", \"bottom\", \"left\"];\nvar ALIGN_OPTIONS = [\"start\", \"center\", \"end\"];\nvar POPPER_NAME = \"Popper\";\nvar [createPopperContext, createPopperScope] = createContextScope(POPPER_NAME);\nvar [PopperProvider, usePopperContext] = createPopperContext(POPPER_NAME);\nvar Popper = (props) => {\n const { __scopePopper, children } = props;\n const [anchor, setAnchor] = React.useState(null);\n return /* @__PURE__ */ jsx(PopperProvider, { scope: __scopePopper, anchor, onAnchorChange: setAnchor, children });\n};\nPopper.displayName = POPPER_NAME;\nvar ANCHOR_NAME = \"PopperAnchor\";\nvar PopperAnchor = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopper, virtualRef, ...anchorProps } = props;\n const context = usePopperContext(ANCHOR_NAME, __scopePopper);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const anchorRef = React.useRef(null);\n React.useEffect(() => {\n const previousAnchor = anchorRef.current;\n anchorRef.current = virtualRef?.current || ref.current;\n if (previousAnchor !== anchorRef.current) {\n context.onAnchorChange(anchorRef.current);\n }\n });\n return virtualRef ? null : /* @__PURE__ */ jsx(Primitive.div, { ...anchorProps, ref: composedRefs });\n }\n);\nPopperAnchor.displayName = ANCHOR_NAME;\nvar CONTENT_NAME = \"PopperContent\";\nvar [PopperContentProvider, useContentContext] = createPopperContext(CONTENT_NAME);\nvar PopperContent = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopePopper,\n side = \"bottom\",\n sideOffset = 0,\n align = \"center\",\n alignOffset = 0,\n arrowPadding = 0,\n avoidCollisions = true,\n collisionBoundary = [],\n collisionPadding: collisionPaddingProp = 0,\n sticky = \"partial\",\n hideWhenDetached = false,\n updatePositionStrategy = \"optimized\",\n onPlaced,\n ...contentProps\n } = props;\n const context = usePopperContext(CONTENT_NAME, __scopePopper);\n const [content, setContent] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContent(node));\n const [arrow, setArrow] = React.useState(null);\n const arrowSize = useSize(arrow);\n const arrowWidth = arrowSize?.width ?? 0;\n const arrowHeight = arrowSize?.height ?? 0;\n const desiredPlacement = side + (align !== \"center\" ? \"-\" + align : \"\");\n const collisionPadding = typeof collisionPaddingProp === \"number\" ? collisionPaddingProp : { top: 0, right: 0, bottom: 0, left: 0, ...collisionPaddingProp };\n const boundary = Array.isArray(collisionBoundary) ? collisionBoundary : [collisionBoundary];\n const hasExplicitBoundaries = boundary.length > 0;\n const detectOverflowOptions = {\n padding: collisionPadding,\n boundary: boundary.filter(isNotNull),\n // with `strategy: 'fixed'`, this is the only way to get it to respect boundaries\n altBoundary: hasExplicitBoundaries\n };\n const { refs, floatingStyles, placement, isPositioned, middlewareData } = useFloating({\n // default to `fixed` strategy so users don't have to pick and we also avoid focus scroll issues\n strategy: \"fixed\",\n placement: desiredPlacement,\n whileElementsMounted: (...args) => {\n const cleanup = autoUpdate(...args, {\n animationFrame: updatePositionStrategy === \"always\"\n });\n return cleanup;\n },\n elements: {\n reference: context.anchor\n },\n middleware: [\n offset({ mainAxis: sideOffset + arrowHeight, alignmentAxis: alignOffset }),\n avoidCollisions && shift({\n mainAxis: true,\n crossAxis: false,\n limiter: sticky === \"partial\" ? limitShift() : void 0,\n ...detectOverflowOptions\n }),\n avoidCollisions && flip({ ...detectOverflowOptions }),\n size({\n ...detectOverflowOptions,\n apply: ({ elements, rects, availableWidth, availableHeight }) => {\n const { width: anchorWidth, height: anchorHeight } = rects.reference;\n const contentStyle = elements.floating.style;\n contentStyle.setProperty(\"--radix-popper-available-width\", `${availableWidth}px`);\n contentStyle.setProperty(\"--radix-popper-available-height\", `${availableHeight}px`);\n contentStyle.setProperty(\"--radix-popper-anchor-width\", `${anchorWidth}px`);\n contentStyle.setProperty(\"--radix-popper-anchor-height\", `${anchorHeight}px`);\n }\n }),\n arrow && floatingUIarrow({ element: arrow, padding: arrowPadding }),\n transformOrigin({ arrowWidth, arrowHeight }),\n hideWhenDetached && hide({ strategy: \"referenceHidden\", ...detectOverflowOptions })\n ]\n });\n const [placedSide, placedAlign] = getSideAndAlignFromPlacement(placement);\n const handlePlaced = useCallbackRef(onPlaced);\n useLayoutEffect(() => {\n if (isPositioned) {\n handlePlaced?.();\n }\n }, [isPositioned, handlePlaced]);\n const arrowX = middlewareData.arrow?.x;\n const arrowY = middlewareData.arrow?.y;\n const cannotCenterArrow = middlewareData.arrow?.centerOffset !== 0;\n const [contentZIndex, setContentZIndex] = React.useState();\n useLayoutEffect(() => {\n if (content) setContentZIndex(window.getComputedStyle(content).zIndex);\n }, [content]);\n return /* @__PURE__ */ jsx(\n \"div\",\n {\n ref: refs.setFloating,\n \"data-radix-popper-content-wrapper\": \"\",\n style: {\n ...floatingStyles,\n transform: isPositioned ? floatingStyles.transform : \"translate(0, -200%)\",\n // keep off the page when measuring\n minWidth: \"max-content\",\n zIndex: contentZIndex,\n [\"--radix-popper-transform-origin\"]: [\n middlewareData.transformOrigin?.x,\n middlewareData.transformOrigin?.y\n ].join(\" \"),\n // hide the content if using the hide middleware and should be hidden\n // set visibility to hidden and disable pointer events so the UI behaves\n // as if the PopperContent isn't there at all\n ...middlewareData.hide?.referenceHidden && {\n visibility: \"hidden\",\n pointerEvents: \"none\"\n }\n },\n dir: props.dir,\n children: /* @__PURE__ */ jsx(\n PopperContentProvider,\n {\n scope: __scopePopper,\n placedSide,\n onArrowChange: setArrow,\n arrowX,\n arrowY,\n shouldHideArrow: cannotCenterArrow,\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-side\": placedSide,\n \"data-align\": placedAlign,\n ...contentProps,\n ref: composedRefs,\n style: {\n ...contentProps.style,\n // if the PopperContent hasn't been placed yet (not all measurements done)\n // we prevent animations so that users's animation don't kick in too early referring wrong sides\n animation: !isPositioned ? \"none\" : void 0\n }\n }\n )\n }\n )\n }\n );\n }\n);\nPopperContent.displayName = CONTENT_NAME;\nvar ARROW_NAME = \"PopperArrow\";\nvar OPPOSITE_SIDE = {\n top: \"bottom\",\n right: \"left\",\n bottom: \"top\",\n left: \"right\"\n};\nvar PopperArrow = React.forwardRef(function PopperArrow2(props, forwardedRef) {\n const { __scopePopper, ...arrowProps } = props;\n const contentContext = useContentContext(ARROW_NAME, __scopePopper);\n const baseSide = OPPOSITE_SIDE[contentContext.placedSide];\n return (\n // we have to use an extra wrapper because `ResizeObserver` (used by `useSize`)\n // doesn't report size as we'd expect on SVG elements.\n // it reports their bounding box which is effectively the largest path inside the SVG.\n /* @__PURE__ */ jsx(\n \"span\",\n {\n ref: contentContext.onArrowChange,\n style: {\n position: \"absolute\",\n left: contentContext.arrowX,\n top: contentContext.arrowY,\n [baseSide]: 0,\n transformOrigin: {\n top: \"\",\n right: \"0 0\",\n bottom: \"center 0\",\n left: \"100% 0\"\n }[contentContext.placedSide],\n transform: {\n top: \"translateY(100%)\",\n right: \"translateY(50%) rotate(90deg) translateX(-50%)\",\n bottom: `rotate(180deg)`,\n left: \"translateY(50%) rotate(-90deg) translateX(50%)\"\n }[contentContext.placedSide],\n visibility: contentContext.shouldHideArrow ? \"hidden\" : void 0\n },\n children: /* @__PURE__ */ jsx(\n ArrowPrimitive.Root,\n {\n ...arrowProps,\n ref: forwardedRef,\n style: {\n ...arrowProps.style,\n // ensures the element can be measured correctly (mostly for if SVG)\n display: \"block\"\n }\n }\n )\n }\n )\n );\n});\nPopperArrow.displayName = ARROW_NAME;\nfunction isNotNull(value) {\n return value !== null;\n}\nvar transformOrigin = (options) => ({\n name: \"transformOrigin\",\n options,\n fn(data) {\n const { placement, rects, middlewareData } = data;\n const cannotCenterArrow = middlewareData.arrow?.centerOffset !== 0;\n const isArrowHidden = cannotCenterArrow;\n const arrowWidth = isArrowHidden ? 0 : options.arrowWidth;\n const arrowHeight = isArrowHidden ? 0 : options.arrowHeight;\n const [placedSide, placedAlign] = getSideAndAlignFromPlacement(placement);\n const noArrowAlign = { start: \"0%\", center: \"50%\", end: \"100%\" }[placedAlign];\n const arrowXCenter = (middlewareData.arrow?.x ?? 0) + arrowWidth / 2;\n const arrowYCenter = (middlewareData.arrow?.y ?? 0) + arrowHeight / 2;\n let x = \"\";\n let y = \"\";\n if (placedSide === \"bottom\") {\n x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;\n y = `${-arrowHeight}px`;\n } else if (placedSide === \"top\") {\n x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;\n y = `${rects.floating.height + arrowHeight}px`;\n } else if (placedSide === \"right\") {\n x = `${-arrowHeight}px`;\n y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;\n } else if (placedSide === \"left\") {\n x = `${rects.floating.width + arrowHeight}px`;\n y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;\n }\n return { data: { x, y } };\n }\n});\nfunction getSideAndAlignFromPlacement(placement) {\n const [side, align = \"center\"] = placement.split(\"-\");\n return [side, align];\n}\nvar Root2 = Popper;\nvar Anchor = PopperAnchor;\nvar Content = PopperContent;\nvar Arrow = PopperArrow;\nexport {\n ALIGN_OPTIONS,\n Anchor,\n Arrow,\n Content,\n Popper,\n PopperAnchor,\n PopperArrow,\n PopperContent,\n Root2 as Root,\n SIDE_OPTIONS,\n createPopperScope\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/portal.tsx\nimport * as React from \"react\";\nimport ReactDOM from \"react-dom\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { jsx } from \"react/jsx-runtime\";\nvar PORTAL_NAME = \"Portal\";\nvar Portal = React.forwardRef((props, forwardedRef) => {\n const { container: containerProp, ...portalProps } = props;\n const [mounted, setMounted] = React.useState(false);\n useLayoutEffect(() => setMounted(true), []);\n const container = containerProp || mounted && globalThis?.document?.body;\n return container ? ReactDOM.createPortal(/* @__PURE__ */ jsx(Primitive.div, { ...portalProps, ref: forwardedRef }), container) : null;\n});\nPortal.displayName = PORTAL_NAME;\nvar Root = Portal;\nexport {\n Portal,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/presence.tsx\nimport * as React2 from \"react\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\n\n// src/use-state-machine.tsx\nimport * as React from \"react\";\nfunction useStateMachine(initialState, machine) {\n return React.useReducer((state, event) => {\n const nextState = machine[state][event];\n return nextState ?? state;\n }, initialState);\n}\n\n// src/presence.tsx\nvar Presence = (props) => {\n const { present, children } = props;\n const presence = usePresence(present);\n const child = typeof children === \"function\" ? children({ present: presence.isPresent }) : React2.Children.only(children);\n const ref = useComposedRefs(presence.ref, getElementRef(child));\n const forceMount = typeof children === \"function\";\n return forceMount || presence.isPresent ? React2.cloneElement(child, { ref }) : null;\n};\nPresence.displayName = \"Presence\";\nfunction usePresence(present) {\n const [node, setNode] = React2.useState();\n const stylesRef = React2.useRef(null);\n const prevPresentRef = React2.useRef(present);\n const prevAnimationNameRef = React2.useRef(\"none\");\n const initialState = present ? \"mounted\" : \"unmounted\";\n const [state, send] = useStateMachine(initialState, {\n mounted: {\n UNMOUNT: \"unmounted\",\n ANIMATION_OUT: \"unmountSuspended\"\n },\n unmountSuspended: {\n MOUNT: \"mounted\",\n ANIMATION_END: \"unmounted\"\n },\n unmounted: {\n MOUNT: \"mounted\"\n }\n });\n React2.useEffect(() => {\n const currentAnimationName = getAnimationName(stylesRef.current);\n prevAnimationNameRef.current = state === \"mounted\" ? currentAnimationName : \"none\";\n }, [state]);\n useLayoutEffect(() => {\n const styles = stylesRef.current;\n const wasPresent = prevPresentRef.current;\n const hasPresentChanged = wasPresent !== present;\n if (hasPresentChanged) {\n const prevAnimationName = prevAnimationNameRef.current;\n const currentAnimationName = getAnimationName(styles);\n if (present) {\n send(\"MOUNT\");\n } else if (currentAnimationName === \"none\" || styles?.display === \"none\") {\n send(\"UNMOUNT\");\n } else {\n const isAnimating = prevAnimationName !== currentAnimationName;\n if (wasPresent && isAnimating) {\n send(\"ANIMATION_OUT\");\n } else {\n send(\"UNMOUNT\");\n }\n }\n prevPresentRef.current = present;\n }\n }, [present, send]);\n useLayoutEffect(() => {\n if (node) {\n let timeoutId;\n const ownerWindow = node.ownerDocument.defaultView ?? window;\n const handleAnimationEnd = (event) => {\n const currentAnimationName = getAnimationName(stylesRef.current);\n const isCurrentAnimation = currentAnimationName.includes(CSS.escape(event.animationName));\n if (event.target === node && isCurrentAnimation) {\n send(\"ANIMATION_END\");\n if (!prevPresentRef.current) {\n const currentFillMode = node.style.animationFillMode;\n node.style.animationFillMode = \"forwards\";\n timeoutId = ownerWindow.setTimeout(() => {\n if (node.style.animationFillMode === \"forwards\") {\n node.style.animationFillMode = currentFillMode;\n }\n });\n }\n }\n };\n const handleAnimationStart = (event) => {\n if (event.target === node) {\n prevAnimationNameRef.current = getAnimationName(stylesRef.current);\n }\n };\n node.addEventListener(\"animationstart\", handleAnimationStart);\n node.addEventListener(\"animationcancel\", handleAnimationEnd);\n node.addEventListener(\"animationend\", handleAnimationEnd);\n return () => {\n ownerWindow.clearTimeout(timeoutId);\n node.removeEventListener(\"animationstart\", handleAnimationStart);\n node.removeEventListener(\"animationcancel\", handleAnimationEnd);\n node.removeEventListener(\"animationend\", handleAnimationEnd);\n };\n } else {\n send(\"ANIMATION_END\");\n }\n }, [node, send]);\n return {\n isPresent: [\"mounted\", \"unmountSuspended\"].includes(state),\n ref: React2.useCallback((node2) => {\n stylesRef.current = node2 ? getComputedStyle(node2) : null;\n setNode(node2);\n }, [])\n };\n}\nfunction getAnimationName(styles) {\n return styles?.animationName || \"none\";\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nvar Root = Presence;\nexport {\n Presence,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","// src/use-controllable-state.tsx\nimport * as React from \"react\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nvar useInsertionEffect = React[\" useInsertionEffect \".trim().toString()] || useLayoutEffect;\nfunction useControllableState({\n prop,\n defaultProp,\n onChange = () => {\n },\n caller\n}) {\n const [uncontrolledProp, setUncontrolledProp, onChangeRef] = useUncontrolledState({\n defaultProp,\n onChange\n });\n const isControlled = prop !== void 0;\n const value = isControlled ? prop : uncontrolledProp;\n if (true) {\n const isControlledRef = React.useRef(prop !== void 0);\n React.useEffect(() => {\n const wasControlled = isControlledRef.current;\n if (wasControlled !== isControlled) {\n const from = wasControlled ? \"controlled\" : \"uncontrolled\";\n const to = isControlled ? \"controlled\" : \"uncontrolled\";\n console.warn(\n `${caller} is changing from ${from} to ${to}. Components should not switch from controlled to uncontrolled (or vice versa). Decide between using a controlled or uncontrolled value for the lifetime of the component.`\n );\n }\n isControlledRef.current = isControlled;\n }, [isControlled, caller]);\n }\n const setValue = React.useCallback(\n (nextValue) => {\n if (isControlled) {\n const value2 = isFunction(nextValue) ? nextValue(prop) : nextValue;\n if (value2 !== prop) {\n onChangeRef.current?.(value2);\n }\n } else {\n setUncontrolledProp(nextValue);\n }\n },\n [isControlled, prop, setUncontrolledProp, onChangeRef]\n );\n return [value, setValue];\n}\nfunction useUncontrolledState({\n defaultProp,\n onChange\n}) {\n const [value, setValue] = React.useState(defaultProp);\n const prevValueRef = React.useRef(value);\n const onChangeRef = React.useRef(onChange);\n useInsertionEffect(() => {\n onChangeRef.current = onChange;\n }, [onChange]);\n React.useEffect(() => {\n if (prevValueRef.current !== value) {\n onChangeRef.current?.(value);\n prevValueRef.current = value;\n }\n }, [value, prevValueRef]);\n return [value, setValue, onChangeRef];\n}\nfunction isFunction(value) {\n return typeof value === \"function\";\n}\n\n// src/use-controllable-state-reducer.tsx\nimport * as React2 from \"react\";\nimport { useEffectEvent } from \"@radix-ui/react-use-effect-event\";\nvar SYNC_STATE = Symbol(\"RADIX:SYNC_STATE\");\nfunction useControllableStateReducer(reducer, userArgs, initialArg, init) {\n const { prop: controlledState, defaultProp, onChange: onChangeProp, caller } = userArgs;\n const isControlled = controlledState !== void 0;\n const onChange = useEffectEvent(onChangeProp);\n if (true) {\n const isControlledRef = React2.useRef(controlledState !== void 0);\n React2.useEffect(() => {\n const wasControlled = isControlledRef.current;\n if (wasControlled !== isControlled) {\n const from = wasControlled ? \"controlled\" : \"uncontrolled\";\n const to = isControlled ? \"controlled\" : \"uncontrolled\";\n console.warn(\n `${caller} is changing from ${from} to ${to}. Components should not switch from controlled to uncontrolled (or vice versa). Decide between using a controlled or uncontrolled value for the lifetime of the component.`\n );\n }\n isControlledRef.current = isControlled;\n }, [isControlled, caller]);\n }\n const args = [{ ...initialArg, state: defaultProp }];\n if (init) {\n args.push(init);\n }\n const [internalState, dispatch] = React2.useReducer(\n (state2, action) => {\n if (action.type === SYNC_STATE) {\n return { ...state2, state: action.state };\n }\n const next = reducer(state2, action);\n if (isControlled && !Object.is(next.state, state2.state)) {\n onChange(next.state);\n }\n return next;\n },\n ...args\n );\n const uncontrolledState = internalState.state;\n const prevValueRef = React2.useRef(uncontrolledState);\n React2.useEffect(() => {\n if (prevValueRef.current !== uncontrolledState) {\n prevValueRef.current = uncontrolledState;\n if (!isControlled) {\n onChange(uncontrolledState);\n }\n }\n }, [onChange, uncontrolledState, prevValueRef, isControlled]);\n const state = React2.useMemo(() => {\n const isControlled2 = controlledState !== void 0;\n if (isControlled2) {\n return { ...internalState, state: controlledState };\n }\n return internalState;\n }, [internalState, controlledState]);\n React2.useEffect(() => {\n if (isControlled && !Object.is(controlledState, internalState.state)) {\n dispatch({ type: SYNC_STATE, state: controlledState });\n }\n }, [controlledState, internalState.state, isControlled]);\n return [state, dispatch];\n}\nexport {\n useControllableState,\n useControllableStateReducer\n};\n//# sourceMappingURL=index.mjs.map\n","// src/visually-hidden.tsx\nimport * as React from \"react\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx } from \"react/jsx-runtime\";\nvar VISUALLY_HIDDEN_STYLES = Object.freeze({\n // See: https://github.com/twbs/bootstrap/blob/main/scss/mixins/_visually-hidden.scss\n position: \"absolute\",\n border: 0,\n width: 1,\n height: 1,\n padding: 0,\n margin: -1,\n overflow: \"hidden\",\n clip: \"rect(0, 0, 0, 0)\",\n whiteSpace: \"nowrap\",\n wordWrap: \"normal\"\n});\nvar NAME = \"VisuallyHidden\";\nvar VisuallyHidden = React.forwardRef(\n (props, forwardedRef) => {\n return /* @__PURE__ */ jsx(\n Primitive.span,\n {\n ...props,\n ref: forwardedRef,\n style: { ...VISUALLY_HIDDEN_STYLES, ...props.style }\n }\n );\n }\n);\nVisuallyHidden.displayName = NAME;\nvar Root = VisuallyHidden;\nexport {\n Root,\n VISUALLY_HIDDEN_STYLES,\n VisuallyHidden\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/tooltip.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { useId } from \"@radix-ui/react-id\";\nimport * as PopperPrimitive from \"@radix-ui/react-popper\";\nimport { createPopperScope } from \"@radix-ui/react-popper\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { createSlottable } from \"@radix-ui/react-slot\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport * as VisuallyHiddenPrimitive from \"@radix-ui/react-visually-hidden\";\nimport { jsx, jsxs } from \"react/jsx-runtime\";\nvar [createTooltipContext, createTooltipScope] = createContextScope(\"Tooltip\", [\n createPopperScope\n]);\nvar usePopperScope = createPopperScope();\nvar PROVIDER_NAME = \"TooltipProvider\";\nvar DEFAULT_DELAY_DURATION = 700;\nvar TOOLTIP_OPEN = \"tooltip.open\";\nvar [TooltipProviderContextProvider, useTooltipProviderContext] = createTooltipContext(PROVIDER_NAME);\nvar TooltipProvider = (props) => {\n const {\n __scopeTooltip,\n delayDuration = DEFAULT_DELAY_DURATION,\n skipDelayDuration = 300,\n disableHoverableContent = false,\n children\n } = props;\n const isOpenDelayedRef = React.useRef(true);\n const isPointerInTransitRef = React.useRef(false);\n const skipDelayTimerRef = React.useRef(0);\n React.useEffect(() => {\n const skipDelayTimer = skipDelayTimerRef.current;\n return () => window.clearTimeout(skipDelayTimer);\n }, []);\n return /* @__PURE__ */ jsx(\n TooltipProviderContextProvider,\n {\n scope: __scopeTooltip,\n isOpenDelayedRef,\n delayDuration,\n onOpen: React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n isOpenDelayedRef.current = false;\n }, []),\n onClose: React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n skipDelayTimerRef.current = window.setTimeout(\n () => isOpenDelayedRef.current = true,\n skipDelayDuration\n );\n }, [skipDelayDuration]),\n isPointerInTransitRef,\n onPointerInTransitChange: React.useCallback((inTransit) => {\n isPointerInTransitRef.current = inTransit;\n }, []),\n disableHoverableContent,\n children\n }\n );\n};\nTooltipProvider.displayName = PROVIDER_NAME;\nvar TOOLTIP_NAME = \"Tooltip\";\nvar [TooltipContextProvider, useTooltipContext] = createTooltipContext(TOOLTIP_NAME);\nvar Tooltip = (props) => {\n const {\n __scopeTooltip,\n children,\n open: openProp,\n defaultOpen,\n onOpenChange,\n disableHoverableContent: disableHoverableContentProp,\n delayDuration: delayDurationProp\n } = props;\n const providerContext = useTooltipProviderContext(TOOLTIP_NAME, props.__scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const [trigger, setTrigger] = React.useState(null);\n const contentId = useId();\n const openTimerRef = React.useRef(0);\n const disableHoverableContent = disableHoverableContentProp ?? providerContext.disableHoverableContent;\n const delayDuration = delayDurationProp ?? providerContext.delayDuration;\n const wasOpenDelayedRef = React.useRef(false);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: (open2) => {\n if (open2) {\n providerContext.onOpen();\n document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));\n } else {\n providerContext.onClose();\n }\n onOpenChange?.(open2);\n },\n caller: TOOLTIP_NAME\n });\n const stateAttribute = React.useMemo(() => {\n return open ? wasOpenDelayedRef.current ? \"delayed-open\" : \"instant-open\" : \"closed\";\n }, [open]);\n const handleOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = 0;\n wasOpenDelayedRef.current = false;\n setOpen(true);\n }, [setOpen]);\n const handleClose = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = 0;\n setOpen(false);\n }, [setOpen]);\n const handleDelayedOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = window.setTimeout(() => {\n wasOpenDelayedRef.current = true;\n setOpen(true);\n openTimerRef.current = 0;\n }, delayDuration);\n }, [delayDuration, setOpen]);\n React.useEffect(() => {\n return () => {\n if (openTimerRef.current) {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = 0;\n }\n };\n }, []);\n return /* @__PURE__ */ jsx(PopperPrimitive.Root, { ...popperScope, children: /* @__PURE__ */ jsx(\n TooltipContextProvider,\n {\n scope: __scopeTooltip,\n contentId,\n open,\n stateAttribute,\n trigger,\n onTriggerChange: setTrigger,\n onTriggerEnter: React.useCallback(() => {\n if (providerContext.isOpenDelayedRef.current) handleDelayedOpen();\n else handleOpen();\n }, [providerContext.isOpenDelayedRef, handleDelayedOpen, handleOpen]),\n onTriggerLeave: React.useCallback(() => {\n if (disableHoverableContent) {\n handleClose();\n } else {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = 0;\n }\n }, [handleClose, disableHoverableContent]),\n onOpen: handleOpen,\n onClose: handleClose,\n disableHoverableContent,\n children\n }\n ) });\n};\nTooltip.displayName = TOOLTIP_NAME;\nvar TRIGGER_NAME = \"TooltipTrigger\";\nvar TooltipTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTooltip, ...triggerProps } = props;\n const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);\n const providerContext = useTooltipProviderContext(TRIGGER_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref, context.onTriggerChange);\n const isPointerDownRef = React.useRef(false);\n const hasPointerMoveOpenedRef = React.useRef(false);\n const handlePointerUp = React.useCallback(() => isPointerDownRef.current = false, []);\n React.useEffect(() => {\n return () => document.removeEventListener(\"pointerup\", handlePointerUp);\n }, [handlePointerUp]);\n return /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { asChild: true, ...popperScope, children: /* @__PURE__ */ jsx(\n Primitive.button,\n {\n \"aria-describedby\": context.open ? context.contentId : void 0,\n \"data-state\": context.stateAttribute,\n ...triggerProps,\n ref: composedRefs,\n onPointerMove: composeEventHandlers(props.onPointerMove, (event) => {\n if (event.pointerType === \"touch\") return;\n if (!hasPointerMoveOpenedRef.current && !providerContext.isPointerInTransitRef.current) {\n context.onTriggerEnter();\n hasPointerMoveOpenedRef.current = true;\n }\n }),\n onPointerLeave: composeEventHandlers(props.onPointerLeave, () => {\n context.onTriggerLeave();\n hasPointerMoveOpenedRef.current = false;\n }),\n onPointerDown: composeEventHandlers(props.onPointerDown, () => {\n if (context.open) {\n context.onClose();\n }\n isPointerDownRef.current = true;\n document.addEventListener(\"pointerup\", handlePointerUp, { once: true });\n }),\n onFocus: composeEventHandlers(props.onFocus, () => {\n if (!isPointerDownRef.current) context.onOpen();\n }),\n onBlur: composeEventHandlers(props.onBlur, context.onClose),\n onClick: composeEventHandlers(props.onClick, context.onClose)\n }\n ) });\n }\n);\nTooltipTrigger.displayName = TRIGGER_NAME;\nvar PORTAL_NAME = \"TooltipPortal\";\nvar [PortalProvider, usePortalContext] = createTooltipContext(PORTAL_NAME, {\n forceMount: void 0\n});\nvar TooltipPortal = (props) => {\n const { __scopeTooltip, forceMount, children, container } = props;\n const context = useTooltipContext(PORTAL_NAME, __scopeTooltip);\n return /* @__PURE__ */ jsx(PortalProvider, { scope: __scopeTooltip, forceMount, children: /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, container, children }) }) });\n};\nTooltipPortal.displayName = PORTAL_NAME;\nvar CONTENT_NAME = \"TooltipContent\";\nvar TooltipContent = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeTooltip);\n const { forceMount = portalContext.forceMount, side = \"top\", ...contentProps } = props;\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: context.disableHoverableContent ? /* @__PURE__ */ jsx(TooltipContentImpl, { side, ...contentProps, ref: forwardedRef }) : /* @__PURE__ */ jsx(TooltipContentHoverable, { side, ...contentProps, ref: forwardedRef }) });\n }\n);\nvar TooltipContentHoverable = React.forwardRef((props, forwardedRef) => {\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n const providerContext = useTooltipProviderContext(CONTENT_NAME, props.__scopeTooltip);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const [pointerGraceArea, setPointerGraceArea] = React.useState(null);\n const { trigger, onClose } = context;\n const content = ref.current;\n const { onPointerInTransitChange } = providerContext;\n const handleRemoveGraceArea = React.useCallback(() => {\n setPointerGraceArea(null);\n onPointerInTransitChange(false);\n }, [onPointerInTransitChange]);\n const handleCreateGraceArea = React.useCallback(\n (event, hoverTarget) => {\n const currentTarget = event.currentTarget;\n const exitPoint = { x: event.clientX, y: event.clientY };\n const exitSide = getExitSideFromRect(exitPoint, currentTarget.getBoundingClientRect());\n const paddedExitPoints = getPaddedExitPoints(exitPoint, exitSide);\n const hoverTargetPoints = getPointsFromRect(hoverTarget.getBoundingClientRect());\n const graceArea = getHull([...paddedExitPoints, ...hoverTargetPoints]);\n setPointerGraceArea(graceArea);\n onPointerInTransitChange(true);\n },\n [onPointerInTransitChange]\n );\n React.useEffect(() => {\n return () => handleRemoveGraceArea();\n }, [handleRemoveGraceArea]);\n React.useEffect(() => {\n if (trigger && content) {\n const handleTriggerLeave = (event) => handleCreateGraceArea(event, content);\n const handleContentLeave = (event) => handleCreateGraceArea(event, trigger);\n trigger.addEventListener(\"pointerleave\", handleTriggerLeave);\n content.addEventListener(\"pointerleave\", handleContentLeave);\n return () => {\n trigger.removeEventListener(\"pointerleave\", handleTriggerLeave);\n content.removeEventListener(\"pointerleave\", handleContentLeave);\n };\n }\n }, [trigger, content, handleCreateGraceArea, handleRemoveGraceArea]);\n React.useEffect(() => {\n if (pointerGraceArea) {\n const handleTrackPointerGrace = (event) => {\n const target = event.target;\n const pointerPosition = { x: event.clientX, y: event.clientY };\n const hasEnteredTarget = trigger?.contains(target) || content?.contains(target);\n const isPointerOutsideGraceArea = !isPointInPolygon(pointerPosition, pointerGraceArea);\n if (hasEnteredTarget) {\n handleRemoveGraceArea();\n } else if (isPointerOutsideGraceArea) {\n handleRemoveGraceArea();\n onClose();\n }\n };\n document.addEventListener(\"pointermove\", handleTrackPointerGrace);\n return () => document.removeEventListener(\"pointermove\", handleTrackPointerGrace);\n }\n }, [trigger, content, pointerGraceArea, onClose, handleRemoveGraceArea]);\n return /* @__PURE__ */ jsx(TooltipContentImpl, { ...props, ref: composedRefs });\n});\nvar [VisuallyHiddenContentContextProvider, useVisuallyHiddenContentContext] = createTooltipContext(TOOLTIP_NAME, { isInside: false });\nvar Slottable = createSlottable(\"TooltipContent\");\nvar TooltipContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeTooltip,\n children,\n \"aria-label\": ariaLabel,\n onEscapeKeyDown,\n onPointerDownOutside,\n ...contentProps\n } = props;\n const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const { onClose } = context;\n React.useEffect(() => {\n document.addEventListener(TOOLTIP_OPEN, onClose);\n return () => document.removeEventListener(TOOLTIP_OPEN, onClose);\n }, [onClose]);\n React.useEffect(() => {\n if (context.trigger) {\n const handleScroll = (event) => {\n const target = event.target;\n if (target?.contains(context.trigger)) onClose();\n };\n window.addEventListener(\"scroll\", handleScroll, { capture: true });\n return () => window.removeEventListener(\"scroll\", handleScroll, { capture: true });\n }\n }, [context.trigger, onClose]);\n return /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n asChild: true,\n disableOutsidePointerEvents: false,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside: (event) => event.preventDefault(),\n onDismiss: onClose,\n children: /* @__PURE__ */ jsxs(\n PopperPrimitive.Content,\n {\n \"data-state\": context.stateAttribute,\n ...popperScope,\n ...contentProps,\n ref: forwardedRef,\n style: {\n ...contentProps.style,\n // re-namespace exposed content custom properties\n ...{\n \"--radix-tooltip-content-transform-origin\": \"var(--radix-popper-transform-origin)\",\n \"--radix-tooltip-content-available-width\": \"var(--radix-popper-available-width)\",\n \"--radix-tooltip-content-available-height\": \"var(--radix-popper-available-height)\",\n \"--radix-tooltip-trigger-width\": \"var(--radix-popper-anchor-width)\",\n \"--radix-tooltip-trigger-height\": \"var(--radix-popper-anchor-height)\"\n }\n },\n children: [\n /* @__PURE__ */ jsx(Slottable, { children }),\n /* @__PURE__ */ jsx(VisuallyHiddenContentContextProvider, { scope: __scopeTooltip, isInside: true, children: /* @__PURE__ */ jsx(VisuallyHiddenPrimitive.Root, { id: context.contentId, role: \"tooltip\", children: ariaLabel || children }) })\n ]\n }\n )\n }\n );\n }\n);\nTooltipContent.displayName = CONTENT_NAME;\nvar ARROW_NAME = \"TooltipArrow\";\nvar TooltipArrow = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTooltip, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeTooltip);\n const visuallyHiddenContentContext = useVisuallyHiddenContentContext(\n ARROW_NAME,\n __scopeTooltip\n );\n return visuallyHiddenContentContext.isInside ? null : /* @__PURE__ */ jsx(PopperPrimitive.Arrow, { ...popperScope, ...arrowProps, ref: forwardedRef });\n }\n);\nTooltipArrow.displayName = ARROW_NAME;\nfunction getExitSideFromRect(point, rect) {\n const top = Math.abs(rect.top - point.y);\n const bottom = Math.abs(rect.bottom - point.y);\n const right = Math.abs(rect.right - point.x);\n const left = Math.abs(rect.left - point.x);\n switch (Math.min(top, bottom, right, left)) {\n case left:\n return \"left\";\n case right:\n return \"right\";\n case top:\n return \"top\";\n case bottom:\n return \"bottom\";\n default:\n throw new Error(\"unreachable\");\n }\n}\nfunction getPaddedExitPoints(exitPoint, exitSide, padding = 5) {\n const paddedExitPoints = [];\n switch (exitSide) {\n case \"top\":\n paddedExitPoints.push(\n { x: exitPoint.x - padding, y: exitPoint.y + padding },\n { x: exitPoint.x + padding, y: exitPoint.y + padding }\n );\n break;\n case \"bottom\":\n paddedExitPoints.push(\n { x: exitPoint.x - padding, y: exitPoint.y - padding },\n { x: exitPoint.x + padding, y: exitPoint.y - padding }\n );\n break;\n case \"left\":\n paddedExitPoints.push(\n { x: exitPoint.x + padding, y: exitPoint.y - padding },\n { x: exitPoint.x + padding, y: exitPoint.y + padding }\n );\n break;\n case \"right\":\n paddedExitPoints.push(\n { x: exitPoint.x - padding, y: exitPoint.y - padding },\n { x: exitPoint.x - padding, y: exitPoint.y + padding }\n );\n break;\n }\n return paddedExitPoints;\n}\nfunction getPointsFromRect(rect) {\n const { top, right, bottom, left } = rect;\n return [\n { x: left, y: top },\n { x: right, y: top },\n { x: right, y: bottom },\n { x: left, y: bottom }\n ];\n}\nfunction isPointInPolygon(point, polygon) {\n const { x, y } = point;\n let inside = false;\n for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {\n const ii = polygon[i];\n const jj = polygon[j];\n const xi = ii.x;\n const yi = ii.y;\n const xj = jj.x;\n const yj = jj.y;\n const intersect = yi > y !== yj > y && x < (xj - xi) * (y - yi) / (yj - yi) + xi;\n if (intersect) inside = !inside;\n }\n return inside;\n}\nfunction getHull(points) {\n const newPoints = points.slice();\n newPoints.sort((a, b) => {\n if (a.x < b.x) return -1;\n else if (a.x > b.x) return 1;\n else if (a.y < b.y) return -1;\n else if (a.y > b.y) return 1;\n else return 0;\n });\n return getHullPresorted(newPoints);\n}\nfunction getHullPresorted(points) {\n if (points.length <= 1) return points.slice();\n const upperHull = [];\n for (let i = 0; i < points.length; i++) {\n const p = points[i];\n while (upperHull.length >= 2) {\n const q = upperHull[upperHull.length - 1];\n const r = upperHull[upperHull.length - 2];\n if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) upperHull.pop();\n else break;\n }\n upperHull.push(p);\n }\n upperHull.pop();\n const lowerHull = [];\n for (let i = points.length - 1; i >= 0; i--) {\n const p = points[i];\n while (lowerHull.length >= 2) {\n const q = lowerHull[lowerHull.length - 1];\n const r = lowerHull[lowerHull.length - 2];\n if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) lowerHull.pop();\n else break;\n }\n lowerHull.push(p);\n }\n lowerHull.pop();\n if (upperHull.length === 1 && lowerHull.length === 1 && upperHull[0].x === lowerHull[0].x && upperHull[0].y === lowerHull[0].y) {\n return upperHull;\n } else {\n return upperHull.concat(lowerHull);\n }\n}\nvar Provider = TooltipProvider;\nvar Root3 = Tooltip;\nvar Trigger = TooltipTrigger;\nvar Portal = TooltipPortal;\nvar Content2 = TooltipContent;\nvar Arrow2 = TooltipArrow;\nexport {\n Arrow2 as Arrow,\n Content2 as Content,\n Portal,\n Provider,\n Root3 as Root,\n Tooltip,\n TooltipArrow,\n TooltipContent,\n TooltipPortal,\n TooltipProvider,\n TooltipTrigger,\n Trigger,\n createTooltipScope\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst TooltipProvider = TooltipPrimitive.Provider;\n\nconst Tooltip = TooltipPrimitive.Root;\n\nconst TooltipTrigger = TooltipPrimitive.Trigger;\n\nconst TooltipContent = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 overflow-hidden rounded-md bg-primary px-3 py-1.5 text-xs text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-(--radix-tooltip-content-transform-origin)\",\n className,\n )}\n {...props}\n />\n </TooltipPrimitive.Portal>\n));\nTooltipContent.displayName = TooltipPrimitive.Content.displayName;\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider };\n","import { FC, RefObject, ReactNode, useCallback, useEffect, useMemo, useState } from \"react\";\nimport cn from \"classnames\";\nimport { portalBody } from \"@/components/ui/portal-body\";\nimport {\n Tooltip,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from \"@/components/ui/tooltip\";\nimport css from \"./TooltipLight.module.scss\";\n\ntype TooltipTarget = string | HTMLElement | RefObject<HTMLElement | null>;\ntype TooltipPlacement = \"top\" | \"bottom\" | \"left\" | \"right\" | `${\"top\" | \"bottom\" | \"left\" | \"right\"}-${\"start\" | \"end\"}`;\n\ninterface TooltipLightProps {\n children?: ReactNode;\n target: TooltipTarget;\n placement?: TooltipPlacement;\n popperClassName?: string;\n isOpen?: boolean;\n toggle?: () => void;\n delay?: number | { show?: number; hide?: number };\n autohide?: boolean;\n}\n\nconst getTargetElement = (target: TooltipTarget) => {\n if (typeof target === \"string\") {\n return document.getElementById(target);\n }\n\n if (\"current\" in target) {\n return target.current;\n }\n\n return target;\n};\n\nconst getPlacement = (placement: TooltipPlacement = \"top\") => {\n const [side, align] = placement.split(\"-\") as [\"top\" | \"bottom\" | \"left\" | \"right\", \"start\" | \"end\" | undefined];\n return { side, align: (align ?? \"center\") as \"start\" | \"center\" | \"end\" };\n};\n\nconst getDelay = (delay: TooltipLightProps[\"delay\"], key: \"show\" | \"hide\") =>\n typeof delay === \"number\" ? delay : delay?.[key] ?? 0;\n\nexport const TooltipLight: FC<TooltipLightProps> = ({\n children,\n target,\n placement = \"top\",\n popperClassName,\n isOpen,\n toggle,\n delay,\n autohide = true,\n}) => {\n const [internalOpen, setInternalOpen] = useState(false);\n const [rect, setRect] = useState<DOMRect | null>(null);\n const open = isOpen ?? internalOpen;\n const { side, align } = useMemo(() => getPlacement(placement), [placement]);\n\n const updateRect = useCallback(() => {\n const element = getTargetElement(target);\n setRect(element?.getBoundingClientRect() ?? null);\n }, [target]);\n\n const setOpen = useCallback(\n (value: boolean) => {\n if (isOpen === undefined) {\n setInternalOpen(value);\n }\n toggle?.();\n },\n [isOpen, toggle],\n );\n\n useEffect(() => {\n const element = getTargetElement(target);\n if (!element) {\n return;\n }\n\n let showTimer: ReturnType<typeof setTimeout> | null = null;\n let hideTimer: ReturnType<typeof setTimeout> | null = null;\n const clearTimers = () => {\n if (showTimer) clearTimeout(showTimer);\n if (hideTimer) clearTimeout(hideTimer);\n };\n const show = () => {\n clearTimers();\n updateRect();\n showTimer = setTimeout(() => setOpen(true), getDelay(delay, \"show\"));\n };\n const hide = () => {\n if (!autohide) return;\n clearTimers();\n hideTimer = setTimeout(() => setOpen(false), getDelay(delay, \"hide\"));\n };\n\n element.addEventListener(\"mouseenter\", show);\n element.addEventListener(\"mouseleave\", hide);\n element.addEventListener(\"focus\", show);\n element.addEventListener(\"blur\", hide);\n window.addEventListener(\"scroll\", updateRect, true);\n window.addEventListener(\"resize\", updateRect);\n\n return () => {\n clearTimers();\n element.removeEventListener(\"mouseenter\", show);\n element.removeEventListener(\"mouseleave\", hide);\n element.removeEventListener(\"focus\", show);\n element.removeEventListener(\"blur\", hide);\n window.removeEventListener(\"scroll\", updateRect, true);\n window.removeEventListener(\"resize\", updateRect);\n };\n }, [autohide, delay, setOpen, target, updateRect]);\n\n if (!rect) {\n return null;\n }\n\n return (\n <TooltipProvider delayDuration={0}>\n <Tooltip open={open} onOpenChange={setOpen}>\n {portalBody(\n <TooltipTrigger asChild>\n <span\n className={css.anchor}\n style={{ left: rect.left, top: rect.top, width: rect.width, height: rect.height }}\n />\n </TooltipTrigger>,\n )}\n <TooltipContent side={side} align={align} className={cn(css.tooltip, popperClassName)}>\n {children}\n </TooltipContent>\n </Tooltip>\n </TooltipProvider>\n );\n};\n","\"use client\";\n\n// src/focus-guards.tsx\nimport * as React from \"react\";\nvar count = 0;\nfunction FocusGuards(props) {\n useFocusGuards();\n return props.children;\n}\nfunction useFocusGuards() {\n React.useEffect(() => {\n const edgeGuards = document.querySelectorAll(\"[data-radix-focus-guard]\");\n document.body.insertAdjacentElement(\"afterbegin\", edgeGuards[0] ?? createFocusGuard());\n document.body.insertAdjacentElement(\"beforeend\", edgeGuards[1] ?? createFocusGuard());\n count++;\n return () => {\n if (count === 1) {\n document.querySelectorAll(\"[data-radix-focus-guard]\").forEach((node) => node.remove());\n }\n count--;\n };\n }, []);\n}\nfunction createFocusGuard() {\n const element = document.createElement(\"span\");\n element.setAttribute(\"data-radix-focus-guard\", \"\");\n element.tabIndex = 0;\n element.style.outline = \"none\";\n element.style.opacity = \"0\";\n element.style.position = \"fixed\";\n element.style.pointerEvents = \"none\";\n return element;\n}\nexport {\n FocusGuards,\n FocusGuards as Root,\n useFocusGuards\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/focus-scope.tsx\nimport * as React from \"react\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { jsx } from \"react/jsx-runtime\";\nvar AUTOFOCUS_ON_MOUNT = \"focusScope.autoFocusOnMount\";\nvar AUTOFOCUS_ON_UNMOUNT = \"focusScope.autoFocusOnUnmount\";\nvar EVENT_OPTIONS = { bubbles: false, cancelable: true };\nvar FOCUS_SCOPE_NAME = \"FocusScope\";\nvar FocusScope = React.forwardRef((props, forwardedRef) => {\n const {\n loop = false,\n trapped = false,\n onMountAutoFocus: onMountAutoFocusProp,\n onUnmountAutoFocus: onUnmountAutoFocusProp,\n ...scopeProps\n } = props;\n const [container, setContainer] = React.useState(null);\n const onMountAutoFocus = useCallbackRef(onMountAutoFocusProp);\n const onUnmountAutoFocus = useCallbackRef(onUnmountAutoFocusProp);\n const lastFocusedElementRef = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContainer(node));\n const focusScope = React.useRef({\n paused: false,\n pause() {\n this.paused = true;\n },\n resume() {\n this.paused = false;\n }\n }).current;\n React.useEffect(() => {\n if (trapped) {\n let handleFocusIn2 = function(event) {\n if (focusScope.paused || !container) return;\n const target = event.target;\n if (container.contains(target)) {\n lastFocusedElementRef.current = target;\n } else {\n focus(lastFocusedElementRef.current, { select: true });\n }\n }, handleFocusOut2 = function(event) {\n if (focusScope.paused || !container) return;\n const relatedTarget = event.relatedTarget;\n if (relatedTarget === null) return;\n if (!container.contains(relatedTarget)) {\n focus(lastFocusedElementRef.current, { select: true });\n }\n }, handleMutations2 = function(mutations) {\n const focusedElement = document.activeElement;\n if (focusedElement !== document.body) return;\n for (const mutation of mutations) {\n if (mutation.removedNodes.length > 0) focus(container);\n }\n };\n var handleFocusIn = handleFocusIn2, handleFocusOut = handleFocusOut2, handleMutations = handleMutations2;\n document.addEventListener(\"focusin\", handleFocusIn2);\n document.addEventListener(\"focusout\", handleFocusOut2);\n const mutationObserver = new MutationObserver(handleMutations2);\n if (container) mutationObserver.observe(container, { childList: true, subtree: true });\n return () => {\n document.removeEventListener(\"focusin\", handleFocusIn2);\n document.removeEventListener(\"focusout\", handleFocusOut2);\n mutationObserver.disconnect();\n };\n }\n }, [trapped, container, focusScope.paused]);\n React.useEffect(() => {\n if (container) {\n focusScopesStack.add(focusScope);\n const previouslyFocusedElement = document.activeElement;\n const hasFocusedCandidate = container.contains(previouslyFocusedElement);\n if (!hasFocusedCandidate) {\n const mountEvent = new CustomEvent(AUTOFOCUS_ON_MOUNT, EVENT_OPTIONS);\n container.addEventListener(AUTOFOCUS_ON_MOUNT, onMountAutoFocus);\n container.dispatchEvent(mountEvent);\n if (!mountEvent.defaultPrevented) {\n focusFirst(removeLinks(getTabbableCandidates(container)), { select: true });\n if (document.activeElement === previouslyFocusedElement) {\n focus(container);\n }\n }\n }\n return () => {\n container.removeEventListener(AUTOFOCUS_ON_MOUNT, onMountAutoFocus);\n setTimeout(() => {\n const unmountEvent = new CustomEvent(AUTOFOCUS_ON_UNMOUNT, EVENT_OPTIONS);\n container.addEventListener(AUTOFOCUS_ON_UNMOUNT, onUnmountAutoFocus);\n container.dispatchEvent(unmountEvent);\n if (!unmountEvent.defaultPrevented) {\n focus(previouslyFocusedElement ?? document.body, { select: true });\n }\n container.removeEventListener(AUTOFOCUS_ON_UNMOUNT, onUnmountAutoFocus);\n focusScopesStack.remove(focusScope);\n }, 0);\n };\n }\n }, [container, onMountAutoFocus, onUnmountAutoFocus, focusScope]);\n const handleKeyDown = React.useCallback(\n (event) => {\n if (!loop && !trapped) return;\n if (focusScope.paused) return;\n const isTabKey = event.key === \"Tab\" && !event.altKey && !event.ctrlKey && !event.metaKey;\n const focusedElement = document.activeElement;\n if (isTabKey && focusedElement) {\n const container2 = event.currentTarget;\n const [first, last] = getTabbableEdges(container2);\n const hasTabbableElementsInside = first && last;\n if (!hasTabbableElementsInside) {\n if (focusedElement === container2) event.preventDefault();\n } else {\n if (!event.shiftKey && focusedElement === last) {\n event.preventDefault();\n if (loop) focus(first, { select: true });\n } else if (event.shiftKey && focusedElement === first) {\n event.preventDefault();\n if (loop) focus(last, { select: true });\n }\n }\n }\n },\n [loop, trapped, focusScope.paused]\n );\n return /* @__PURE__ */ jsx(Primitive.div, { tabIndex: -1, ...scopeProps, ref: composedRefs, onKeyDown: handleKeyDown });\n});\nFocusScope.displayName = FOCUS_SCOPE_NAME;\nfunction focusFirst(candidates, { select = false } = {}) {\n const previouslyFocusedElement = document.activeElement;\n for (const candidate of candidates) {\n focus(candidate, { select });\n if (document.activeElement !== previouslyFocusedElement) return;\n }\n}\nfunction getTabbableEdges(container) {\n const candidates = getTabbableCandidates(container);\n const first = findVisible(candidates, container);\n const last = findVisible(candidates.reverse(), container);\n return [first, last];\n}\nfunction getTabbableCandidates(container) {\n const nodes = [];\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_ELEMENT, {\n acceptNode: (node) => {\n const isHiddenInput = node.tagName === \"INPUT\" && node.type === \"hidden\";\n if (node.disabled || node.hidden || isHiddenInput) return NodeFilter.FILTER_SKIP;\n return node.tabIndex >= 0 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;\n }\n });\n while (walker.nextNode()) nodes.push(walker.currentNode);\n return nodes;\n}\nfunction findVisible(elements, container) {\n for (const element of elements) {\n if (!isHidden(element, { upTo: container })) return element;\n }\n}\nfunction isHidden(node, { upTo }) {\n if (getComputedStyle(node).visibility === \"hidden\") return true;\n while (node) {\n if (upTo !== void 0 && node === upTo) return false;\n if (getComputedStyle(node).display === \"none\") return true;\n node = node.parentElement;\n }\n return false;\n}\nfunction isSelectableInput(element) {\n return element instanceof HTMLInputElement && \"select\" in element;\n}\nfunction focus(element, { select = false } = {}) {\n if (element && element.focus) {\n const previouslyFocusedElement = document.activeElement;\n element.focus({ preventScroll: true });\n if (element !== previouslyFocusedElement && isSelectableInput(element) && select)\n element.select();\n }\n}\nvar focusScopesStack = createFocusScopesStack();\nfunction createFocusScopesStack() {\n let stack = [];\n return {\n add(focusScope) {\n const activeFocusScope = stack[0];\n if (focusScope !== activeFocusScope) {\n activeFocusScope?.pause();\n }\n stack = arrayRemove(stack, focusScope);\n stack.unshift(focusScope);\n },\n remove(focusScope) {\n stack = arrayRemove(stack, focusScope);\n stack[0]?.resume();\n }\n };\n}\nfunction arrayRemove(array, item) {\n const updatedArray = [...array];\n const index = updatedArray.indexOf(item);\n if (index !== -1) {\n updatedArray.splice(index, 1);\n }\n return updatedArray;\n}\nfunction removeLinks(items) {\n return items.filter((item) => item.tagName !== \"A\");\n}\nvar Root = FocusScope;\nexport {\n FocusScope,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","var getDefaultParent = function (originalTarget) {\n if (typeof document === 'undefined') {\n return null;\n }\n var sampleTarget = Array.isArray(originalTarget) ? originalTarget[0] : originalTarget;\n return sampleTarget.ownerDocument.body;\n};\nvar counterMap = new WeakMap();\nvar uncontrolledNodes = new WeakMap();\nvar markerMap = {};\nvar lockCount = 0;\nvar unwrapHost = function (node) {\n return node && (node.host || unwrapHost(node.parentNode));\n};\nvar correctTargets = function (parent, targets) {\n return targets\n .map(function (target) {\n if (parent.contains(target)) {\n return target;\n }\n var correctedTarget = unwrapHost(target);\n if (correctedTarget && parent.contains(correctedTarget)) {\n return correctedTarget;\n }\n console.error('aria-hidden', target, 'in not contained inside', parent, '. Doing nothing');\n return null;\n })\n .filter(function (x) { return Boolean(x); });\n};\n/**\n * Marks everything except given node(or nodes) as aria-hidden\n * @param {Element | Element[]} originalTarget - elements to keep on the page\n * @param [parentNode] - top element, defaults to document.body\n * @param {String} [markerName] - a special attribute to mark every node\n * @param {String} [controlAttribute] - html Attribute to control\n * @return {Undo} undo command\n */\nvar applyAttributeToOthers = function (originalTarget, parentNode, markerName, controlAttribute) {\n var targets = correctTargets(parentNode, Array.isArray(originalTarget) ? originalTarget : [originalTarget]);\n if (!markerMap[markerName]) {\n markerMap[markerName] = new WeakMap();\n }\n var markerCounter = markerMap[markerName];\n var hiddenNodes = [];\n var elementsToKeep = new Set();\n var elementsToStop = new Set(targets);\n var keep = function (el) {\n if (!el || elementsToKeep.has(el)) {\n return;\n }\n elementsToKeep.add(el);\n keep(el.parentNode);\n };\n targets.forEach(keep);\n var deep = function (parent) {\n if (!parent || elementsToStop.has(parent)) {\n return;\n }\n Array.prototype.forEach.call(parent.children, function (node) {\n if (elementsToKeep.has(node)) {\n deep(node);\n }\n else {\n try {\n var attr = node.getAttribute(controlAttribute);\n var alreadyHidden = attr !== null && attr !== 'false';\n var counterValue = (counterMap.get(node) || 0) + 1;\n var markerValue = (markerCounter.get(node) || 0) + 1;\n counterMap.set(node, counterValue);\n markerCounter.set(node, markerValue);\n hiddenNodes.push(node);\n if (counterValue === 1 && alreadyHidden) {\n uncontrolledNodes.set(node, true);\n }\n if (markerValue === 1) {\n node.setAttribute(markerName, 'true');\n }\n if (!alreadyHidden) {\n node.setAttribute(controlAttribute, 'true');\n }\n }\n catch (e) {\n console.error('aria-hidden: cannot operate on ', node, e);\n }\n }\n });\n };\n deep(parentNode);\n elementsToKeep.clear();\n lockCount++;\n return function () {\n hiddenNodes.forEach(function (node) {\n var counterValue = counterMap.get(node) - 1;\n var markerValue = markerCounter.get(node) - 1;\n counterMap.set(node, counterValue);\n markerCounter.set(node, markerValue);\n if (!counterValue) {\n if (!uncontrolledNodes.has(node)) {\n node.removeAttribute(controlAttribute);\n }\n uncontrolledNodes.delete(node);\n }\n if (!markerValue) {\n node.removeAttribute(markerName);\n }\n });\n lockCount--;\n if (!lockCount) {\n // clear\n counterMap = new WeakMap();\n counterMap = new WeakMap();\n uncontrolledNodes = new WeakMap();\n markerMap = {};\n }\n };\n};\n/**\n * Marks everything except given node(or nodes) as aria-hidden\n * @param {Element | Element[]} originalTarget - elements to keep on the page\n * @param [parentNode] - top element, defaults to document.body\n * @param {String} [markerName] - a special attribute to mark every node\n * @return {Undo} undo command\n */\nexport var hideOthers = function (originalTarget, parentNode, markerName) {\n if (markerName === void 0) { markerName = 'data-aria-hidden'; }\n var targets = Array.from(Array.isArray(originalTarget) ? originalTarget : [originalTarget]);\n var activeParentNode = parentNode || getDefaultParent(originalTarget);\n if (!activeParentNode) {\n return function () { return null; };\n }\n // we should not hide aria-live elements - https://github.com/theKashey/aria-hidden/issues/10\n // and script elements, as they have no impact on accessibility.\n targets.push.apply(targets, Array.from(activeParentNode.querySelectorAll('[aria-live], script')));\n return applyAttributeToOthers(targets, activeParentNode, markerName, 'aria-hidden');\n};\n/**\n * Marks everything except given node(or nodes) as inert\n * @param {Element | Element[]} originalTarget - elements to keep on the page\n * @param [parentNode] - top element, defaults to document.body\n * @param {String} [markerName] - a special attribute to mark every node\n * @return {Undo} undo command\n */\nexport var inertOthers = function (originalTarget, parentNode, markerName) {\n if (markerName === void 0) { markerName = 'data-inert-ed'; }\n var activeParentNode = parentNode || getDefaultParent(originalTarget);\n if (!activeParentNode) {\n return function () { return null; };\n }\n return applyAttributeToOthers(originalTarget, activeParentNode, markerName, 'inert');\n};\n/**\n * @returns if current browser supports inert\n */\nexport var supportsInert = function () {\n return typeof HTMLElement !== 'undefined' && HTMLElement.prototype.hasOwnProperty('inert');\n};\n/**\n * Automatic function to \"suppress\" DOM elements - _hide_ or _inert_ in the best possible way\n * @param {Element | Element[]} originalTarget - elements to keep on the page\n * @param [parentNode] - top element, defaults to document.body\n * @param {String} [markerName] - a special attribute to mark every node\n * @return {Undo} undo command\n */\nexport var suppressOthers = function (originalTarget, parentNode, markerName) {\n if (markerName === void 0) { markerName = 'data-suppressed'; }\n return (supportsInert() ? inertOthers : hideOthers)(originalTarget, parentNode, markerName);\n};\n","/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\n\nvar extendStatics = function(d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n};\n\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\n\nexport var __assign = function() {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n }\n return __assign.apply(this, arguments);\n}\n\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n}\n\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\n\nexport function __param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n}\n\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n var _, done = false;\n for (var i = decorators.length - 1; i >= 0; i--) {\n var context = {};\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\n if (kind === \"accessor\") {\n if (result === void 0) continue;\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n if (_ = accept(result.get)) descriptor.get = _;\n if (_ = accept(result.set)) descriptor.set = _;\n if (_ = accept(result.init)) initializers.unshift(_);\n }\n else if (_ = accept(result)) {\n if (kind === \"field\") initializers.unshift(_);\n else descriptor[key] = _;\n }\n }\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\n done = true;\n};\n\nexport function __runInitializers(thisArg, initializers, value) {\n var useValue = arguments.length > 2;\n for (var i = 0; i < initializers.length; i++) {\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n }\n return useValue ? value : void 0;\n};\n\nexport function __propKey(x) {\n return typeof x === \"symbol\" ? x : \"\".concat(x);\n};\n\nexport function __setFunctionName(f, name, prefix) {\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\n};\n\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\n\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\n\nexport function __generator(thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n}\n\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\n\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\n\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\n\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++)\n ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n}\n\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\n\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\n\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\n function fulfill(value) { resume(\"next\", value); }\n function reject(value) { resume(\"throw\", value); }\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\n}\n\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\n}\n\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator], i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\n}\n\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\n return cooked;\n};\n\nvar __setModuleDefault = Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n};\n\nvar ownKeys = function(o) {\n ownKeys = Object.getOwnPropertyNames || function (o) {\n var ar = [];\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n return ar;\n };\n return ownKeys(o);\n};\n\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n __setModuleDefault(result, mod);\n return result;\n}\n\nexport function __importDefault(mod) {\n return (mod && mod.__esModule) ? mod : { default: mod };\n}\n\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\n\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n}\n\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\n\nexport function __addDisposableResource(env, value, async) {\n if (value !== null && value !== void 0) {\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n var dispose, inner;\n if (async) {\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n dispose = value[Symbol.asyncDispose];\n }\n if (dispose === void 0) {\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n dispose = value[Symbol.dispose];\n if (async) inner = dispose;\n }\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\n env.stack.push({ value: value, dispose: dispose, async: async });\n }\n else if (async) {\n env.stack.push({ async: true });\n }\n return value;\n}\n\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n var e = new Error(message);\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\n\nexport function __disposeResources(env) {\n function fail(e) {\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n env.hasError = true;\n }\n var r, s = 0;\n function next() {\n while (r = env.stack.pop()) {\n try {\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\n if (r.dispose) {\n var result = r.dispose.call(r.value);\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\n }\n else s |= 1;\n }\n catch (e) {\n fail(e);\n }\n }\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\n if (env.hasError) throw env.error;\n }\n return next();\n}\n\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\n });\n }\n return path;\n}\n\nexport default {\n __extends,\n __assign,\n __rest,\n __decorate,\n __param,\n __esDecorate,\n __runInitializers,\n __propKey,\n __setFunctionName,\n __metadata,\n __awaiter,\n __generator,\n __createBinding,\n __exportStar,\n __values,\n __read,\n __spread,\n __spreadArrays,\n __spreadArray,\n __await,\n __asyncGenerator,\n __asyncDelegator,\n __asyncValues,\n __makeTemplateObject,\n __importStar,\n __importDefault,\n __classPrivateFieldGet,\n __classPrivateFieldSet,\n __classPrivateFieldIn,\n __addDisposableResource,\n __disposeResources,\n __rewriteRelativeImportExtension,\n};\n","export var zeroRightClassName = 'right-scroll-bar-position';\nexport var fullWidthClassName = 'width-before-scroll-bar';\nexport var noScrollbarsClassName = 'with-scroll-bars-hidden';\n/**\n * Name of a CSS variable containing the amount of \"hidden\" scrollbar\n * ! might be undefined ! use will fallback!\n */\nexport var removedBarSizeVariable = '--removed-body-scroll-bar-size';\n","/**\n * Assigns a value for a given ref, no matter of the ref format\n * @param {RefObject} ref - a callback function or ref object\n * @param value - a new value\n *\n * @see https://github.com/theKashey/use-callback-ref#assignref\n * @example\n * const refObject = useRef();\n * const refFn = (ref) => {....}\n *\n * assignRef(refObject, \"refValue\");\n * assignRef(refFn, \"refValue\");\n */\nexport function assignRef(ref, value) {\n if (typeof ref === 'function') {\n ref(value);\n }\n else if (ref) {\n ref.current = value;\n }\n return ref;\n}\n","import { useState } from 'react';\n/**\n * creates a MutableRef with ref change callback\n * @param initialValue - initial ref value\n * @param {Function} callback - a callback to run when value changes\n *\n * @example\n * const ref = useCallbackRef(0, (newValue, oldValue) => console.log(oldValue, '->', newValue);\n * ref.current = 1;\n * // prints 0 -> 1\n *\n * @see https://reactjs.org/docs/hooks-reference.html#useref\n * @see https://github.com/theKashey/use-callback-ref#usecallbackref---to-replace-reactuseref\n * @returns {MutableRefObject}\n */\nexport function useCallbackRef(initialValue, callback) {\n var ref = useState(function () { return ({\n // value\n value: initialValue,\n // last callback\n callback: callback,\n // \"memoized\" public interface\n facade: {\n get current() {\n return ref.value;\n },\n set current(value) {\n var last = ref.value;\n if (last !== value) {\n ref.value = value;\n ref.callback(value, last);\n }\n },\n },\n }); })[0];\n // update callback\n ref.callback = callback;\n return ref.facade;\n}\n","import * as React from 'react';\nimport { assignRef } from './assignRef';\nimport { useCallbackRef } from './useRef';\nvar useIsomorphicLayoutEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\nvar currentValues = new WeakMap();\n/**\n * Merges two or more refs together providing a single interface to set their value\n * @param {RefObject|Ref} refs\n * @returns {MutableRefObject} - a new ref, which translates all changes to {refs}\n *\n * @see {@link mergeRefs} a version without buit-in memoization\n * @see https://github.com/theKashey/use-callback-ref#usemergerefs\n * @example\n * const Component = React.forwardRef((props, ref) => {\n * const ownRef = useRef();\n * const domRef = useMergeRefs([ref, ownRef]); // 👈 merge together\n * return <div ref={domRef}>...</div>\n * }\n */\nexport function useMergeRefs(refs, defaultValue) {\n var callbackRef = useCallbackRef(defaultValue || null, function (newValue) {\n return refs.forEach(function (ref) { return assignRef(ref, newValue); });\n });\n // handle refs changes - added or removed\n useIsomorphicLayoutEffect(function () {\n var oldValue = currentValues.get(callbackRef);\n if (oldValue) {\n var prevRefs_1 = new Set(oldValue);\n var nextRefs_1 = new Set(refs);\n var current_1 = callbackRef.current;\n prevRefs_1.forEach(function (ref) {\n if (!nextRefs_1.has(ref)) {\n assignRef(ref, null);\n }\n });\n nextRefs_1.forEach(function (ref) {\n if (!prevRefs_1.has(ref)) {\n assignRef(ref, current_1);\n }\n });\n }\n currentValues.set(callbackRef, refs);\n }, [refs]);\n return callbackRef;\n}\n","import { __assign } from \"tslib\";\nfunction ItoI(a) {\n return a;\n}\nfunction innerCreateMedium(defaults, middleware) {\n if (middleware === void 0) { middleware = ItoI; }\n var buffer = [];\n var assigned = false;\n var medium = {\n read: function () {\n if (assigned) {\n throw new Error('Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.');\n }\n if (buffer.length) {\n return buffer[buffer.length - 1];\n }\n return defaults;\n },\n useMedium: function (data) {\n var item = middleware(data, assigned);\n buffer.push(item);\n return function () {\n buffer = buffer.filter(function (x) { return x !== item; });\n };\n },\n assignSyncMedium: function (cb) {\n assigned = true;\n while (buffer.length) {\n var cbs = buffer;\n buffer = [];\n cbs.forEach(cb);\n }\n buffer = {\n push: function (x) { return cb(x); },\n filter: function () { return buffer; },\n };\n },\n assignMedium: function (cb) {\n assigned = true;\n var pendingQueue = [];\n if (buffer.length) {\n var cbs = buffer;\n buffer = [];\n cbs.forEach(cb);\n pendingQueue = buffer;\n }\n var executeQueue = function () {\n var cbs = pendingQueue;\n pendingQueue = [];\n cbs.forEach(cb);\n };\n var cycle = function () { return Promise.resolve().then(executeQueue); };\n cycle();\n buffer = {\n push: function (x) {\n pendingQueue.push(x);\n cycle();\n },\n filter: function (filter) {\n pendingQueue = pendingQueue.filter(filter);\n return buffer;\n },\n };\n },\n };\n return medium;\n}\nexport function createMedium(defaults, middleware) {\n if (middleware === void 0) { middleware = ItoI; }\n return innerCreateMedium(defaults, middleware);\n}\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function createSidecarMedium(options) {\n if (options === void 0) { options = {}; }\n var medium = innerCreateMedium(null);\n medium.options = __assign({ async: true, ssr: false }, options);\n return medium;\n}\n","import { __assign, __rest } from \"tslib\";\nimport * as React from 'react';\nvar SideCar = function (_a) {\n var sideCar = _a.sideCar, rest = __rest(_a, [\"sideCar\"]);\n if (!sideCar) {\n throw new Error('Sidecar: please provide `sideCar` property to import the right car');\n }\n var Target = sideCar.read();\n if (!Target) {\n throw new Error('Sidecar medium not found');\n }\n return React.createElement(Target, __assign({}, rest));\n};\nSideCar.isSideCarExport = true;\nexport function exportSidecar(medium, exported) {\n medium.useMedium(exported);\n return SideCar;\n}\n","import { createSidecarMedium } from 'use-sidecar';\nexport var effectCar = createSidecarMedium();\n","import { __assign, __rest } from \"tslib\";\nimport * as React from 'react';\nimport { fullWidthClassName, zeroRightClassName } from 'react-remove-scroll-bar/constants';\nimport { useMergeRefs } from 'use-callback-ref';\nimport { effectCar } from './medium';\nvar nothing = function () {\n return;\n};\n/**\n * Removes scrollbar from the page and contain the scroll within the Lock\n */\nvar RemoveScroll = React.forwardRef(function (props, parentRef) {\n var ref = React.useRef(null);\n var _a = React.useState({\n onScrollCapture: nothing,\n onWheelCapture: nothing,\n onTouchMoveCapture: nothing,\n }), callbacks = _a[0], setCallbacks = _a[1];\n var forwardProps = props.forwardProps, children = props.children, className = props.className, removeScrollBar = props.removeScrollBar, enabled = props.enabled, shards = props.shards, sideCar = props.sideCar, noRelative = props.noRelative, noIsolation = props.noIsolation, inert = props.inert, allowPinchZoom = props.allowPinchZoom, _b = props.as, Container = _b === void 0 ? 'div' : _b, gapMode = props.gapMode, rest = __rest(props, [\"forwardProps\", \"children\", \"className\", \"removeScrollBar\", \"enabled\", \"shards\", \"sideCar\", \"noRelative\", \"noIsolation\", \"inert\", \"allowPinchZoom\", \"as\", \"gapMode\"]);\n var SideCar = sideCar;\n var containerRef = useMergeRefs([ref, parentRef]);\n var containerProps = __assign(__assign({}, rest), callbacks);\n return (React.createElement(React.Fragment, null,\n enabled && (React.createElement(SideCar, { sideCar: effectCar, removeScrollBar: removeScrollBar, shards: shards, noRelative: noRelative, noIsolation: noIsolation, inert: inert, setCallbacks: setCallbacks, allowPinchZoom: !!allowPinchZoom, lockRef: ref, gapMode: gapMode })),\n forwardProps ? (React.cloneElement(React.Children.only(children), __assign(__assign({}, containerProps), { ref: containerRef }))) : (React.createElement(Container, __assign({}, containerProps, { className: className, ref: containerRef }), children))));\n});\nRemoveScroll.defaultProps = {\n enabled: true,\n removeScrollBar: true,\n inert: false,\n};\nRemoveScroll.classNames = {\n fullWidth: fullWidthClassName,\n zeroRight: zeroRightClassName,\n};\nexport { RemoveScroll };\n","var currentNonce;\nexport var setNonce = function (nonce) {\n currentNonce = nonce;\n};\nexport var getNonce = function () {\n if (currentNonce) {\n return currentNonce;\n }\n if (typeof __webpack_nonce__ !== 'undefined') {\n return __webpack_nonce__;\n }\n return undefined;\n};\n","import { getNonce } from 'get-nonce';\nfunction makeStyleTag() {\n if (!document)\n return null;\n var tag = document.createElement('style');\n tag.type = 'text/css';\n var nonce = getNonce();\n if (nonce) {\n tag.setAttribute('nonce', nonce);\n }\n return tag;\n}\nfunction injectStyles(tag, css) {\n // @ts-ignore\n if (tag.styleSheet) {\n // @ts-ignore\n tag.styleSheet.cssText = css;\n }\n else {\n tag.appendChild(document.createTextNode(css));\n }\n}\nfunction insertStyleTag(tag) {\n var head = document.head || document.getElementsByTagName('head')[0];\n head.appendChild(tag);\n}\nexport var stylesheetSingleton = function () {\n var counter = 0;\n var stylesheet = null;\n return {\n add: function (style) {\n if (counter == 0) {\n if ((stylesheet = makeStyleTag())) {\n injectStyles(stylesheet, style);\n insertStyleTag(stylesheet);\n }\n }\n counter++;\n },\n remove: function () {\n counter--;\n if (!counter && stylesheet) {\n stylesheet.parentNode && stylesheet.parentNode.removeChild(stylesheet);\n stylesheet = null;\n }\n },\n };\n};\n","import * as React from 'react';\nimport { stylesheetSingleton } from './singleton';\n/**\n * creates a hook to control style singleton\n * @see {@link styleSingleton} for a safer component version\n * @example\n * ```tsx\n * const useStyle = styleHookSingleton();\n * ///\n * useStyle('body { overflow: hidden}');\n */\nexport var styleHookSingleton = function () {\n var sheet = stylesheetSingleton();\n return function (styles, isDynamic) {\n React.useEffect(function () {\n sheet.add(styles);\n return function () {\n sheet.remove();\n };\n }, [styles && isDynamic]);\n };\n};\n","import { styleHookSingleton } from './hook';\n/**\n * create a Component to add styles on demand\n * - styles are added when first instance is mounted\n * - styles are removed when the last instance is unmounted\n * - changing styles in runtime does nothing unless dynamic is set. But with multiple components that can lead to the undefined behavior\n */\nexport var styleSingleton = function () {\n var useStyle = styleHookSingleton();\n var Sheet = function (_a) {\n var styles = _a.styles, dynamic = _a.dynamic;\n useStyle(styles, dynamic);\n return null;\n };\n return Sheet;\n};\n","export var zeroGap = {\n left: 0,\n top: 0,\n right: 0,\n gap: 0,\n};\nvar parse = function (x) { return parseInt(x || '', 10) || 0; };\nvar getOffset = function (gapMode) {\n var cs = window.getComputedStyle(document.body);\n var left = cs[gapMode === 'padding' ? 'paddingLeft' : 'marginLeft'];\n var top = cs[gapMode === 'padding' ? 'paddingTop' : 'marginTop'];\n var right = cs[gapMode === 'padding' ? 'paddingRight' : 'marginRight'];\n return [parse(left), parse(top), parse(right)];\n};\nexport var getGapWidth = function (gapMode) {\n if (gapMode === void 0) { gapMode = 'margin'; }\n if (typeof window === 'undefined') {\n return zeroGap;\n }\n var offsets = getOffset(gapMode);\n var documentWidth = document.documentElement.clientWidth;\n var windowWidth = window.innerWidth;\n return {\n left: offsets[0],\n top: offsets[1],\n right: offsets[2],\n gap: Math.max(0, windowWidth - documentWidth + offsets[2] - offsets[0]),\n };\n};\n","import * as React from 'react';\nimport { styleSingleton } from 'react-style-singleton';\nimport { fullWidthClassName, zeroRightClassName, noScrollbarsClassName, removedBarSizeVariable } from './constants';\nimport { getGapWidth } from './utils';\nvar Style = styleSingleton();\nexport var lockAttribute = 'data-scroll-locked';\n// important tip - once we measure scrollBar width and remove them\n// we could not repeat this operation\n// thus we are using style-singleton - only the first \"yet correct\" style will be applied.\nvar getStyles = function (_a, allowRelative, gapMode, important) {\n var left = _a.left, top = _a.top, right = _a.right, gap = _a.gap;\n if (gapMode === void 0) { gapMode = 'margin'; }\n return \"\\n .\".concat(noScrollbarsClassName, \" {\\n overflow: hidden \").concat(important, \";\\n padding-right: \").concat(gap, \"px \").concat(important, \";\\n }\\n body[\").concat(lockAttribute, \"] {\\n overflow: hidden \").concat(important, \";\\n overscroll-behavior: contain;\\n \").concat([\n allowRelative && \"position: relative \".concat(important, \";\"),\n gapMode === 'margin' &&\n \"\\n padding-left: \".concat(left, \"px;\\n padding-top: \").concat(top, \"px;\\n padding-right: \").concat(right, \"px;\\n margin-left:0;\\n margin-top:0;\\n margin-right: \").concat(gap, \"px \").concat(important, \";\\n \"),\n gapMode === 'padding' && \"padding-right: \".concat(gap, \"px \").concat(important, \";\"),\n ]\n .filter(Boolean)\n .join(''), \"\\n }\\n \\n .\").concat(zeroRightClassName, \" {\\n right: \").concat(gap, \"px \").concat(important, \";\\n }\\n \\n .\").concat(fullWidthClassName, \" {\\n margin-right: \").concat(gap, \"px \").concat(important, \";\\n }\\n \\n .\").concat(zeroRightClassName, \" .\").concat(zeroRightClassName, \" {\\n right: 0 \").concat(important, \";\\n }\\n \\n .\").concat(fullWidthClassName, \" .\").concat(fullWidthClassName, \" {\\n margin-right: 0 \").concat(important, \";\\n }\\n \\n body[\").concat(lockAttribute, \"] {\\n \").concat(removedBarSizeVariable, \": \").concat(gap, \"px;\\n }\\n\");\n};\nvar getCurrentUseCounter = function () {\n var counter = parseInt(document.body.getAttribute(lockAttribute) || '0', 10);\n return isFinite(counter) ? counter : 0;\n};\nexport var useLockAttribute = function () {\n React.useEffect(function () {\n document.body.setAttribute(lockAttribute, (getCurrentUseCounter() + 1).toString());\n return function () {\n var newCounter = getCurrentUseCounter() - 1;\n if (newCounter <= 0) {\n document.body.removeAttribute(lockAttribute);\n }\n else {\n document.body.setAttribute(lockAttribute, newCounter.toString());\n }\n };\n }, []);\n};\n/**\n * Removes page scrollbar and blocks page scroll when mounted\n */\nexport var RemoveScrollBar = function (_a) {\n var noRelative = _a.noRelative, noImportant = _a.noImportant, _b = _a.gapMode, gapMode = _b === void 0 ? 'margin' : _b;\n useLockAttribute();\n /*\n gap will be measured on every component mount\n however it will be used only by the \"first\" invocation\n due to singleton nature of <Style\n */\n var gap = React.useMemo(function () { return getGapWidth(gapMode); }, [gapMode]);\n return React.createElement(Style, { styles: getStyles(gap, !noRelative, gapMode, !noImportant ? '!important' : '') });\n};\n","var passiveSupported = false;\nif (typeof window !== 'undefined') {\n try {\n var options = Object.defineProperty({}, 'passive', {\n get: function () {\n passiveSupported = true;\n return true;\n },\n });\n // @ts-ignore\n window.addEventListener('test', options, options);\n // @ts-ignore\n window.removeEventListener('test', options, options);\n }\n catch (err) {\n passiveSupported = false;\n }\n}\nexport var nonPassive = passiveSupported ? { passive: false } : false;\n","var alwaysContainsScroll = function (node) {\n // textarea will always _contain_ scroll inside self. It only can be hidden\n return node.tagName === 'TEXTAREA';\n};\nvar elementCanBeScrolled = function (node, overflow) {\n if (!(node instanceof Element)) {\n return false;\n }\n var styles = window.getComputedStyle(node);\n return (\n // not-not-scrollable\n styles[overflow] !== 'hidden' &&\n // contains scroll inside self\n !(styles.overflowY === styles.overflowX && !alwaysContainsScroll(node) && styles[overflow] === 'visible'));\n};\nvar elementCouldBeVScrolled = function (node) { return elementCanBeScrolled(node, 'overflowY'); };\nvar elementCouldBeHScrolled = function (node) { return elementCanBeScrolled(node, 'overflowX'); };\nexport var locationCouldBeScrolled = function (axis, node) {\n var ownerDocument = node.ownerDocument;\n var current = node;\n do {\n // Skip over shadow root\n if (typeof ShadowRoot !== 'undefined' && current instanceof ShadowRoot) {\n current = current.host;\n }\n var isScrollable = elementCouldBeScrolled(axis, current);\n if (isScrollable) {\n var _a = getScrollVariables(axis, current), scrollHeight = _a[1], clientHeight = _a[2];\n if (scrollHeight > clientHeight) {\n return true;\n }\n }\n current = current.parentNode;\n } while (current && current !== ownerDocument.body);\n return false;\n};\nvar getVScrollVariables = function (_a) {\n var scrollTop = _a.scrollTop, scrollHeight = _a.scrollHeight, clientHeight = _a.clientHeight;\n return [\n scrollTop,\n scrollHeight,\n clientHeight,\n ];\n};\nvar getHScrollVariables = function (_a) {\n var scrollLeft = _a.scrollLeft, scrollWidth = _a.scrollWidth, clientWidth = _a.clientWidth;\n return [\n scrollLeft,\n scrollWidth,\n clientWidth,\n ];\n};\nvar elementCouldBeScrolled = function (axis, node) {\n return axis === 'v' ? elementCouldBeVScrolled(node) : elementCouldBeHScrolled(node);\n};\nvar getScrollVariables = function (axis, node) {\n return axis === 'v' ? getVScrollVariables(node) : getHScrollVariables(node);\n};\nvar getDirectionFactor = function (axis, direction) {\n /**\n * If the element's direction is rtl (right-to-left), then scrollLeft is 0 when the scrollbar is at its rightmost position,\n * and then increasingly negative as you scroll towards the end of the content.\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollLeft\n */\n return axis === 'h' && direction === 'rtl' ? -1 : 1;\n};\nexport var handleScroll = function (axis, endTarget, event, sourceDelta, noOverscroll) {\n var directionFactor = getDirectionFactor(axis, window.getComputedStyle(endTarget).direction);\n var delta = directionFactor * sourceDelta;\n // find scrollable target\n var target = event.target;\n var targetInLock = endTarget.contains(target);\n var shouldCancelScroll = false;\n var isDeltaPositive = delta > 0;\n var availableScroll = 0;\n var availableScrollTop = 0;\n do {\n if (!target) {\n break;\n }\n var _a = getScrollVariables(axis, target), position = _a[0], scroll_1 = _a[1], capacity = _a[2];\n var elementScroll = scroll_1 - capacity - directionFactor * position;\n if (position || elementScroll) {\n if (elementCouldBeScrolled(axis, target)) {\n availableScroll += elementScroll;\n availableScrollTop += position;\n }\n }\n var parent_1 = target.parentNode;\n // we will \"bubble\" from ShadowDom in case we are, or just to the parent in normal case\n // this is the same logic used in focus-lock\n target = (parent_1 && parent_1.nodeType === Node.DOCUMENT_FRAGMENT_NODE ? parent_1.host : parent_1);\n } while (\n // portaled content\n (!targetInLock && target !== document.body) ||\n // self content\n (targetInLock && (endTarget.contains(target) || endTarget === target)));\n // handle epsilon around 0 (non standard zoom levels)\n if (isDeltaPositive &&\n ((noOverscroll && Math.abs(availableScroll) < 1) || (!noOverscroll && delta > availableScroll))) {\n shouldCancelScroll = true;\n }\n else if (!isDeltaPositive &&\n ((noOverscroll && Math.abs(availableScrollTop) < 1) || (!noOverscroll && -delta > availableScrollTop))) {\n shouldCancelScroll = true;\n }\n return shouldCancelScroll;\n};\n","import { __spreadArray } from \"tslib\";\nimport * as React from 'react';\nimport { RemoveScrollBar } from 'react-remove-scroll-bar';\nimport { styleSingleton } from 'react-style-singleton';\nimport { nonPassive } from './aggresiveCapture';\nimport { handleScroll, locationCouldBeScrolled } from './handleScroll';\nexport var getTouchXY = function (event) {\n return 'changedTouches' in event ? [event.changedTouches[0].clientX, event.changedTouches[0].clientY] : [0, 0];\n};\nexport var getDeltaXY = function (event) { return [event.deltaX, event.deltaY]; };\nvar extractRef = function (ref) {\n return ref && 'current' in ref ? ref.current : ref;\n};\nvar deltaCompare = function (x, y) { return x[0] === y[0] && x[1] === y[1]; };\nvar generateStyle = function (id) { return \"\\n .block-interactivity-\".concat(id, \" {pointer-events: none;}\\n .allow-interactivity-\").concat(id, \" {pointer-events: all;}\\n\"); };\nvar idCounter = 0;\nvar lockStack = [];\nexport function RemoveScrollSideCar(props) {\n var shouldPreventQueue = React.useRef([]);\n var touchStartRef = React.useRef([0, 0]);\n var activeAxis = React.useRef();\n var id = React.useState(idCounter++)[0];\n var Style = React.useState(styleSingleton)[0];\n var lastProps = React.useRef(props);\n React.useEffect(function () {\n lastProps.current = props;\n }, [props]);\n React.useEffect(function () {\n if (props.inert) {\n document.body.classList.add(\"block-interactivity-\".concat(id));\n var allow_1 = __spreadArray([props.lockRef.current], (props.shards || []).map(extractRef), true).filter(Boolean);\n allow_1.forEach(function (el) { return el.classList.add(\"allow-interactivity-\".concat(id)); });\n return function () {\n document.body.classList.remove(\"block-interactivity-\".concat(id));\n allow_1.forEach(function (el) { return el.classList.remove(\"allow-interactivity-\".concat(id)); });\n };\n }\n return;\n }, [props.inert, props.lockRef.current, props.shards]);\n var shouldCancelEvent = React.useCallback(function (event, parent) {\n if (('touches' in event && event.touches.length === 2) || (event.type === 'wheel' && event.ctrlKey)) {\n return !lastProps.current.allowPinchZoom;\n }\n var touch = getTouchXY(event);\n var touchStart = touchStartRef.current;\n var deltaX = 'deltaX' in event ? event.deltaX : touchStart[0] - touch[0];\n var deltaY = 'deltaY' in event ? event.deltaY : touchStart[1] - touch[1];\n var currentAxis;\n var target = event.target;\n var moveDirection = Math.abs(deltaX) > Math.abs(deltaY) ? 'h' : 'v';\n // allow horizontal touch move on Range inputs. They will not cause any scroll\n if ('touches' in event && moveDirection === 'h' && target.type === 'range') {\n return false;\n }\n // allow drag selection (iOS); check if selection's anchorNode is the same as target or contains target\n var selection = window.getSelection();\n var anchorNode = selection && selection.anchorNode;\n var isTouchingSelection = anchorNode ? anchorNode === target || anchorNode.contains(target) : false;\n if (isTouchingSelection) {\n return false;\n }\n var canBeScrolledInMainDirection = locationCouldBeScrolled(moveDirection, target);\n if (!canBeScrolledInMainDirection) {\n return true;\n }\n if (canBeScrolledInMainDirection) {\n currentAxis = moveDirection;\n }\n else {\n currentAxis = moveDirection === 'v' ? 'h' : 'v';\n canBeScrolledInMainDirection = locationCouldBeScrolled(moveDirection, target);\n // other axis might be not scrollable\n }\n if (!canBeScrolledInMainDirection) {\n return false;\n }\n if (!activeAxis.current && 'changedTouches' in event && (deltaX || deltaY)) {\n activeAxis.current = currentAxis;\n }\n if (!currentAxis) {\n return true;\n }\n var cancelingAxis = activeAxis.current || currentAxis;\n return handleScroll(cancelingAxis, parent, event, cancelingAxis === 'h' ? deltaX : deltaY, true);\n }, []);\n var shouldPrevent = React.useCallback(function (_event) {\n var event = _event;\n if (!lockStack.length || lockStack[lockStack.length - 1] !== Style) {\n // not the last active\n return;\n }\n var delta = 'deltaY' in event ? getDeltaXY(event) : getTouchXY(event);\n var sourceEvent = shouldPreventQueue.current.filter(function (e) { return e.name === event.type && (e.target === event.target || event.target === e.shadowParent) && deltaCompare(e.delta, delta); })[0];\n // self event, and should be canceled\n if (sourceEvent && sourceEvent.should) {\n if (event.cancelable) {\n event.preventDefault();\n }\n return;\n }\n // outside or shard event\n if (!sourceEvent) {\n var shardNodes = (lastProps.current.shards || [])\n .map(extractRef)\n .filter(Boolean)\n .filter(function (node) { return node.contains(event.target); });\n var shouldStop = shardNodes.length > 0 ? shouldCancelEvent(event, shardNodes[0]) : !lastProps.current.noIsolation;\n if (shouldStop) {\n if (event.cancelable) {\n event.preventDefault();\n }\n }\n }\n }, []);\n var shouldCancel = React.useCallback(function (name, delta, target, should) {\n var event = { name: name, delta: delta, target: target, should: should, shadowParent: getOutermostShadowParent(target) };\n shouldPreventQueue.current.push(event);\n setTimeout(function () {\n shouldPreventQueue.current = shouldPreventQueue.current.filter(function (e) { return e !== event; });\n }, 1);\n }, []);\n var scrollTouchStart = React.useCallback(function (event) {\n touchStartRef.current = getTouchXY(event);\n activeAxis.current = undefined;\n }, []);\n var scrollWheel = React.useCallback(function (event) {\n shouldCancel(event.type, getDeltaXY(event), event.target, shouldCancelEvent(event, props.lockRef.current));\n }, []);\n var scrollTouchMove = React.useCallback(function (event) {\n shouldCancel(event.type, getTouchXY(event), event.target, shouldCancelEvent(event, props.lockRef.current));\n }, []);\n React.useEffect(function () {\n lockStack.push(Style);\n props.setCallbacks({\n onScrollCapture: scrollWheel,\n onWheelCapture: scrollWheel,\n onTouchMoveCapture: scrollTouchMove,\n });\n document.addEventListener('wheel', shouldPrevent, nonPassive);\n document.addEventListener('touchmove', shouldPrevent, nonPassive);\n document.addEventListener('touchstart', scrollTouchStart, nonPassive);\n return function () {\n lockStack = lockStack.filter(function (inst) { return inst !== Style; });\n document.removeEventListener('wheel', shouldPrevent, nonPassive);\n document.removeEventListener('touchmove', shouldPrevent, nonPassive);\n document.removeEventListener('touchstart', scrollTouchStart, nonPassive);\n };\n }, []);\n var removeScrollBar = props.removeScrollBar, inert = props.inert;\n return (React.createElement(React.Fragment, null,\n inert ? React.createElement(Style, { styles: generateStyle(id) }) : null,\n removeScrollBar ? React.createElement(RemoveScrollBar, { noRelative: props.noRelative, gapMode: props.gapMode }) : null));\n}\nfunction getOutermostShadowParent(node) {\n var shadowParent = null;\n while (node !== null) {\n if (node instanceof ShadowRoot) {\n shadowParent = node.host;\n node = node.host;\n }\n node = node.parentNode;\n }\n return shadowParent;\n}\n","import { exportSidecar } from 'use-sidecar';\nimport { RemoveScrollSideCar } from './SideEffect';\nimport { effectCar } from './medium';\nexport default exportSidecar(effectCar, RemoveScrollSideCar);\n","import { __assign } from \"tslib\";\nimport * as React from 'react';\nimport { RemoveScroll } from './UI';\nimport SideCar from './sidecar';\nvar ReactRemoveScroll = React.forwardRef(function (props, ref) { return (React.createElement(RemoveScroll, __assign({}, props, { ref: ref, sideCar: SideCar }))); });\nReactRemoveScroll.classNames = RemoveScroll.classNames;\nexport default ReactRemoveScroll;\n","\"use client\";\n\n// src/popover.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { useFocusGuards } from \"@radix-ui/react-focus-guards\";\nimport { FocusScope } from \"@radix-ui/react-focus-scope\";\nimport { useId } from \"@radix-ui/react-id\";\nimport * as PopperPrimitive from \"@radix-ui/react-popper\";\nimport { createPopperScope } from \"@radix-ui/react-popper\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { hideOthers } from \"aria-hidden\";\nimport { RemoveScroll } from \"react-remove-scroll\";\nimport { jsx } from \"react/jsx-runtime\";\nvar POPOVER_NAME = \"Popover\";\nvar [createPopoverContext, createPopoverScope] = createContextScope(POPOVER_NAME, [\n createPopperScope\n]);\nvar usePopperScope = createPopperScope();\nvar [PopoverProvider, usePopoverContext] = createPopoverContext(POPOVER_NAME);\nvar Popover = (props) => {\n const {\n __scopePopover,\n children,\n open: openProp,\n defaultOpen,\n onOpenChange,\n modal = false\n } = props;\n const popperScope = usePopperScope(__scopePopover);\n const triggerRef = React.useRef(null);\n const [hasCustomAnchor, setHasCustomAnchor] = React.useState(false);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: POPOVER_NAME\n });\n return /* @__PURE__ */ jsx(PopperPrimitive.Root, { ...popperScope, children: /* @__PURE__ */ jsx(\n PopoverProvider,\n {\n scope: __scopePopover,\n contentId: useId(),\n triggerRef,\n open,\n onOpenChange: setOpen,\n onOpenToggle: React.useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen]),\n hasCustomAnchor,\n onCustomAnchorAdd: React.useCallback(() => setHasCustomAnchor(true), []),\n onCustomAnchorRemove: React.useCallback(() => setHasCustomAnchor(false), []),\n modal,\n children\n }\n ) });\n};\nPopover.displayName = POPOVER_NAME;\nvar ANCHOR_NAME = \"PopoverAnchor\";\nvar PopoverAnchor = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopover, ...anchorProps } = props;\n const context = usePopoverContext(ANCHOR_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n const { onCustomAnchorAdd, onCustomAnchorRemove } = context;\n React.useEffect(() => {\n onCustomAnchorAdd();\n return () => onCustomAnchorRemove();\n }, [onCustomAnchorAdd, onCustomAnchorRemove]);\n return /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { ...popperScope, ...anchorProps, ref: forwardedRef });\n }\n);\nPopoverAnchor.displayName = ANCHOR_NAME;\nvar TRIGGER_NAME = \"PopoverTrigger\";\nvar PopoverTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopover, ...triggerProps } = props;\n const context = usePopoverContext(TRIGGER_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.triggerRef);\n const trigger = /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n \"aria-haspopup\": \"dialog\",\n \"aria-expanded\": context.open,\n \"aria-controls\": context.contentId,\n \"data-state\": getState(context.open),\n ...triggerProps,\n ref: composedTriggerRef,\n onClick: composeEventHandlers(props.onClick, context.onOpenToggle)\n }\n );\n return context.hasCustomAnchor ? trigger : /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { asChild: true, ...popperScope, children: trigger });\n }\n);\nPopoverTrigger.displayName = TRIGGER_NAME;\nvar PORTAL_NAME = \"PopoverPortal\";\nvar [PortalProvider, usePortalContext] = createPopoverContext(PORTAL_NAME, {\n forceMount: void 0\n});\nvar PopoverPortal = (props) => {\n const { __scopePopover, forceMount, children, container } = props;\n const context = usePopoverContext(PORTAL_NAME, __scopePopover);\n return /* @__PURE__ */ jsx(PortalProvider, { scope: __scopePopover, forceMount, children: /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, container, children }) }) });\n};\nPopoverPortal.displayName = PORTAL_NAME;\nvar CONTENT_NAME = \"PopoverContent\";\nvar PopoverContent = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopePopover);\n const { forceMount = portalContext.forceMount, ...contentProps } = props;\n const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: context.modal ? /* @__PURE__ */ jsx(PopoverContentModal, { ...contentProps, ref: forwardedRef }) : /* @__PURE__ */ jsx(PopoverContentNonModal, { ...contentProps, ref: forwardedRef }) });\n }\n);\nPopoverContent.displayName = CONTENT_NAME;\nvar Slot = createSlot(\"PopoverContent.RemoveScroll\");\nvar PopoverContentModal = React.forwardRef(\n (props, forwardedRef) => {\n const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);\n const contentRef = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, contentRef);\n const isRightClickOutsideRef = React.useRef(false);\n React.useEffect(() => {\n const content = contentRef.current;\n if (content) return hideOthers(content);\n }, []);\n return /* @__PURE__ */ jsx(RemoveScroll, { as: Slot, allowPinchZoom: true, children: /* @__PURE__ */ jsx(\n PopoverContentImpl,\n {\n ...props,\n ref: composedRefs,\n trapFocus: context.open,\n disableOutsidePointerEvents: true,\n onCloseAutoFocus: composeEventHandlers(props.onCloseAutoFocus, (event) => {\n event.preventDefault();\n if (!isRightClickOutsideRef.current) context.triggerRef.current?.focus();\n }),\n onPointerDownOutside: composeEventHandlers(\n props.onPointerDownOutside,\n (event) => {\n const originalEvent = event.detail.originalEvent;\n const ctrlLeftClick = originalEvent.button === 0 && originalEvent.ctrlKey === true;\n const isRightClick = originalEvent.button === 2 || ctrlLeftClick;\n isRightClickOutsideRef.current = isRightClick;\n },\n { checkForDefaultPrevented: false }\n ),\n onFocusOutside: composeEventHandlers(\n props.onFocusOutside,\n (event) => event.preventDefault(),\n { checkForDefaultPrevented: false }\n )\n }\n ) });\n }\n);\nvar PopoverContentNonModal = React.forwardRef(\n (props, forwardedRef) => {\n const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);\n const hasInteractedOutsideRef = React.useRef(false);\n const hasPointerDownOutsideRef = React.useRef(false);\n return /* @__PURE__ */ jsx(\n PopoverContentImpl,\n {\n ...props,\n ref: forwardedRef,\n trapFocus: false,\n disableOutsidePointerEvents: false,\n onCloseAutoFocus: (event) => {\n props.onCloseAutoFocus?.(event);\n if (!event.defaultPrevented) {\n if (!hasInteractedOutsideRef.current) context.triggerRef.current?.focus();\n event.preventDefault();\n }\n hasInteractedOutsideRef.current = false;\n hasPointerDownOutsideRef.current = false;\n },\n onInteractOutside: (event) => {\n props.onInteractOutside?.(event);\n if (!event.defaultPrevented) {\n hasInteractedOutsideRef.current = true;\n if (event.detail.originalEvent.type === \"pointerdown\") {\n hasPointerDownOutsideRef.current = true;\n }\n }\n const target = event.target;\n const targetIsTrigger = context.triggerRef.current?.contains(target);\n if (targetIsTrigger) event.preventDefault();\n if (event.detail.originalEvent.type === \"focusin\" && hasPointerDownOutsideRef.current) {\n event.preventDefault();\n }\n }\n }\n );\n }\n);\nvar PopoverContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopePopover,\n trapFocus,\n onOpenAutoFocus,\n onCloseAutoFocus,\n disableOutsidePointerEvents,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside,\n onInteractOutside,\n ...contentProps\n } = props;\n const context = usePopoverContext(CONTENT_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n useFocusGuards();\n return /* @__PURE__ */ jsx(\n FocusScope,\n {\n asChild: true,\n loop: true,\n trapped: trapFocus,\n onMountAutoFocus: onOpenAutoFocus,\n onUnmountAutoFocus: onCloseAutoFocus,\n children: /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n asChild: true,\n disableOutsidePointerEvents,\n onInteractOutside,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside,\n onDismiss: () => context.onOpenChange(false),\n children: /* @__PURE__ */ jsx(\n PopperPrimitive.Content,\n {\n \"data-state\": getState(context.open),\n role: \"dialog\",\n id: context.contentId,\n ...popperScope,\n ...contentProps,\n ref: forwardedRef,\n style: {\n ...contentProps.style,\n // re-namespace exposed content custom properties\n ...{\n \"--radix-popover-content-transform-origin\": \"var(--radix-popper-transform-origin)\",\n \"--radix-popover-content-available-width\": \"var(--radix-popper-available-width)\",\n \"--radix-popover-content-available-height\": \"var(--radix-popper-available-height)\",\n \"--radix-popover-trigger-width\": \"var(--radix-popper-anchor-width)\",\n \"--radix-popover-trigger-height\": \"var(--radix-popper-anchor-height)\"\n }\n }\n }\n )\n }\n )\n }\n );\n }\n);\nvar CLOSE_NAME = \"PopoverClose\";\nvar PopoverClose = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopover, ...closeProps } = props;\n const context = usePopoverContext(CLOSE_NAME, __scopePopover);\n return /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n ...closeProps,\n ref: forwardedRef,\n onClick: composeEventHandlers(props.onClick, () => context.onOpenChange(false))\n }\n );\n }\n);\nPopoverClose.displayName = CLOSE_NAME;\nvar ARROW_NAME = \"PopoverArrow\";\nvar PopoverArrow = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopover, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopePopover);\n return /* @__PURE__ */ jsx(PopperPrimitive.Arrow, { ...popperScope, ...arrowProps, ref: forwardedRef });\n }\n);\nPopoverArrow.displayName = ARROW_NAME;\nfunction getState(open) {\n return open ? \"open\" : \"closed\";\n}\nvar Root2 = Popover;\nvar Anchor2 = PopoverAnchor;\nvar Trigger = PopoverTrigger;\nvar Portal = PopoverPortal;\nvar Content2 = PopoverContent;\nvar Close = PopoverClose;\nvar Arrow2 = PopoverArrow;\nexport {\n Anchor2 as Anchor,\n Arrow2 as Arrow,\n Close,\n Content2 as Content,\n Popover,\n PopoverAnchor,\n PopoverArrow,\n PopoverClose,\n PopoverContent,\n PopoverPortal,\n PopoverTrigger,\n Portal,\n Root2 as Root,\n Trigger,\n createPopoverScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as React from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Popover = PopoverPrimitive.Root;\n\nconst PopoverTrigger = PopoverPrimitive.Trigger;\n\nconst PopoverAnchor = PopoverPrimitive.Anchor;\n\nconst PopoverContent = React.forwardRef<\n React.ElementRef<typeof PopoverPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content>\n>(({ className, align = \"center\", sideOffset = 4, ...props }, ref) => (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n ref={ref}\n align={align}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-(--radix-popover-content-transform-origin)\",\n className,\n )}\n {...props}\n />\n </PopoverPrimitive.Portal>\n));\nPopoverContent.displayName = PopoverPrimitive.Content.displayName;\n\nexport { Popover, PopoverTrigger, PopoverContent, PopoverAnchor };\n","import { ReactNode, RefObject, useCallback, useEffect, useMemo, useState } from \"react\";\nimport cn from \"classnames\";\nimport { portalBody } from \"@/components/ui/portal-body\";\nimport { Popover as UiPopover, PopoverContent, PopoverTrigger } from \"@/components/ui/popover\";\nimport css from \"./Popover.module.scss\";\n\ntype PopoverPlacement = \"top\" | \"bottom\" | \"left\" | \"right\" | `${\"top\" | \"bottom\" | \"left\" | \"right\"}-${\"start\" | \"end\"}`;\n\ninterface PopoverProps {\n children?: ReactNode;\n target: RefObject<HTMLElement | null>;\n placement?: PopoverPlacement;\n className?: string;\n isOpen?: boolean;\n toggle?: () => void;\n onOpenChange?: (isOpen: boolean) => void;\n}\n\nconst getPlacement = (placement: PopoverPlacement = \"bottom\") => {\n const [side, align] = placement.split(\"-\") as [\"top\" | \"bottom\" | \"left\" | \"right\", \"start\" | \"end\" | undefined];\n return { side, align: (align ?? \"center\") as \"start\" | \"center\" | \"end\" };\n};\n\nexport const Popover = ({\n children,\n placement = \"bottom\",\n target,\n className,\n isOpen,\n toggle,\n onOpenChange,\n}: PopoverProps) => {\n const [internalOpen, setInternalOpen] = useState(false);\n const [rect, setRect] = useState<DOMRect | null>(null);\n const open = isOpen ?? internalOpen;\n const { side, align } = useMemo(() => getPlacement(placement), [placement]);\n\n const updateRect = useCallback(() => {\n setRect(target.current?.getBoundingClientRect() ?? null);\n }, [target]);\n\n const setOpen = useCallback(\n (value: boolean) => {\n if (isOpen === undefined) {\n setInternalOpen(value);\n }\n onOpenChange?.(value);\n },\n [isOpen, onOpenChange],\n );\n\n useEffect(() => {\n const targetElement = target.current;\n if (!targetElement) {\n return;\n }\n\n const handleClick = () => {\n updateRect();\n if (isOpen === undefined) {\n setInternalOpen((prev) => {\n const next = !prev;\n onOpenChange?.(next);\n return next;\n });\n } else {\n onOpenChange?.(!isOpen);\n }\n toggle?.();\n };\n\n targetElement.addEventListener(\"click\", handleClick);\n window.addEventListener(\"scroll\", updateRect, true);\n window.addEventListener(\"resize\", updateRect);\n\n return () => {\n targetElement.removeEventListener(\"click\", handleClick);\n window.removeEventListener(\"scroll\", updateRect, true);\n window.removeEventListener(\"resize\", updateRect);\n };\n }, [isOpen, onOpenChange, target, toggle, updateRect]);\n\n return (\n <UiPopover open={open} onOpenChange={setOpen}>\n {portalBody(\n <PopoverTrigger asChild>\n <span\n className={css.anchor}\n style={\n rect\n ? { left: rect.left, top: rect.top, width: rect.width, height: rect.height }\n : { left: 0, top: 0, width: 0, height: 0 }\n }\n aria-hidden\n />\n </PopoverTrigger>,\n )}\n <PopoverContent side={side} align={align} className={cn(css.popover, className)}>\n {children}\n </PopoverContent>\n </UiPopover>\n );\n};\n","import React, { ReactNode } from \"react\";\nimport cn from \"classnames\";\nimport { EmptyIcon } from \"../../icons\";\nimport css from \"./EmptyComponent.module.scss\";\n\ninterface EmptyComponentProps {\n svg?: React.ReactNode;\n title?: string;\n subtitle?: string;\n content?: ReactNode;\n className?: string;\n}\n\nexport const EmptyComponent: React.FC<EmptyComponentProps> = ({\n svg = <EmptyIcon />,\n title = \"Нет данных для отображения\",\n subtitle,\n content,\n className,\n}) => (\n <div className={cn(css.emptyComponent, className)}>\n <div className={css.svgWrapper}>{svg}</div>\n {title && <span className={css.title}>{title}</span>}\n {subtitle && <span className={css.subtitle}>{subtitle}</span>}\n {content && content}\n </div>\n);\n","import cn from \"classnames\";\nimport { FC, MouseEventHandler, ReactNode, useCallback, useEffect, useRef, useState } from \"react\";\nimport { ArrowDownIcon } from \"../../icons\";\nimport css from \"./Collapse.module.scss\";\n\nexport interface CollapseProps {\n header: ReactNode;\n content: ReactNode;\n onToggle?: () => void;\n isOpen?: boolean;\n defaultOpen?: boolean;\n className?: string;\n id?: string;\n headerClassName?: string;\n contentClassName?: string;\n iconClassName?: string;\n}\n\nexport const Collapse: FC<CollapseProps> = ({\n header,\n className,\n content,\n onToggle,\n isOpen,\n defaultOpen = false,\n id,\n headerClassName,\n contentClassName,\n iconClassName,\n}) => {\n const [_isOpen, set_IsOpen] = useState(defaultOpen);\n const isMounted = useRef(false);\n\n const resolvedOpen = typeof isOpen === \"boolean\" ? isOpen : _isOpen;\n const ref = useRef<HTMLDivElement>(null);\n\n const _header =\n typeof header === \"string\" ? (\n <div className={css.header_text}>\n <span>{header}</span>\n </div>\n ) : (\n header\n );\n\n const _content =\n typeof content === \"string\" ? <span className={css.content_text}>{content}</span> : content;\n\n useEffect(() => {\n const el = ref.current;\n if (!el) {\n return;\n }\n\n if (!isMounted.current) {\n el.style.height = defaultOpen ? \"auto\" : \"0px\";\n isMounted.current = true;\n return;\n }\n\n if (resolvedOpen) {\n el.style.height = `${el.scrollHeight}px`;\n\n const onEnd = () => {\n el.style.height = \"auto\";\n };\n\n el.addEventListener(\"transitionend\", onEnd, { once: true });\n } else {\n el.style.height = `${el.scrollHeight}px`;\n\n requestAnimationFrame(() => {\n el.style.height = \"0px\";\n });\n }\n }, [resolvedOpen, defaultOpen]);\n\n const handleToggle: MouseEventHandler = useCallback(\n (e) => {\n e.stopPropagation();\n onToggle ? onToggle() : set_IsOpen((open) => !open);\n },\n [onToggle],\n );\n\n return (\n <div className={cn(css.container, className)} id={id}>\n <div className={cn(css.header, headerClassName)}>\n {_header}\n <div className={cn(css.header_icon, iconClassName)} onClick={handleToggle}>\n <ArrowDownIcon\n className={cn(css.iconArrow, css.iconTransition, { [css.rotateIcon]: resolvedOpen })}\n />\n </div>\n </div>\n <div className={cn(css.content, contentClassName, { [css.padding]: resolvedOpen })} ref={ref}>\n {_content}\n </div>\n </div>\n );\n};\n","import cn from \"classnames\";\nimport * as React from \"react\";\nimport { ReactNode, useState } from \"react\";\nimport { InfoIcon } from \"../../icons\";\nimport { Collapse, type CollapseProps } from \"../Collapse/Collapse\";\nimport { TooltipLight } from \"../TooltipLight/TooltipLight\";\nimport css from \"./CollapsableBlock.module.scss\";\n\ninterface Props extends CollapseProps {\n infoTooltipContent?: ReactNode;\n}\n\nconst CollapsableBlock: React.FC<Props> = React.memo((props) => {\n const { id, header, content, className, infoTooltipContent, ...rest } = props;\n\n const [tooltipOpen, toggleTooltip] = useState(false);\n const toggle = () => toggleTooltip(!tooltipOpen);\n\n return (\n <Collapse\n id={id}\n className={cn(css.collapsableBlock, className)}\n header={\n infoTooltipContent ? (\n <div className={css.headerWithInfoTooltip}>\n <span>{header}</span>\n <InfoIcon className={css.infoIcon} id=\"CollapsableBlockNewInfoTooltipIcon\" />\n <TooltipLight\n autohide={false}\n delay={{ show: 0, hide: 500 }}\n isOpen={tooltipOpen}\n placement=\"left-start\"\n target=\"CollapsableBlockNewInfoTooltipIcon\"\n toggle={toggle}\n >\n {infoTooltipContent}\n </TooltipLight>\n </div>\n ) : (\n header\n )\n }\n content={content}\n headerClassName={css.header}\n {...rest}\n />\n );\n});\n\nexport { CollapsableBlock };\n","import { isShadowRoot, isHTMLElement } from '@floating-ui/utils/dom';\nimport * as React from 'react';\nimport { useLayoutEffect } from 'react';\nimport { floor } from '@floating-ui/utils';\nimport { tabbable } from 'tabbable';\n\n// Avoid Chrome DevTools blue warning.\nfunction getPlatform() {\n const uaData = navigator.userAgentData;\n if (uaData != null && uaData.platform) {\n return uaData.platform;\n }\n return navigator.platform;\n}\nfunction getUserAgent() {\n const uaData = navigator.userAgentData;\n if (uaData && Array.isArray(uaData.brands)) {\n return uaData.brands.map(_ref => {\n let {\n brand,\n version\n } = _ref;\n return brand + \"/\" + version;\n }).join(' ');\n }\n return navigator.userAgent;\n}\nfunction isSafari() {\n // Chrome DevTools does not complain about navigator.vendor\n return /apple/i.test(navigator.vendor);\n}\nfunction isAndroid() {\n const re = /android/i;\n return re.test(getPlatform()) || re.test(getUserAgent());\n}\nfunction isMac() {\n return getPlatform().toLowerCase().startsWith('mac') && !navigator.maxTouchPoints;\n}\nfunction isJSDOM() {\n return getUserAgent().includes('jsdom/');\n}\n\nconst FOCUSABLE_ATTRIBUTE = 'data-floating-ui-focusable';\nconst TYPEABLE_SELECTOR = \"input:not([type='hidden']):not([disabled]),\" + \"[contenteditable]:not([contenteditable='false']),textarea:not([disabled])\";\nconst ARROW_LEFT = 'ArrowLeft';\nconst ARROW_RIGHT = 'ArrowRight';\nconst ARROW_UP = 'ArrowUp';\nconst ARROW_DOWN = 'ArrowDown';\n\nfunction activeElement(doc) {\n let activeElement = doc.activeElement;\n while (((_activeElement = activeElement) == null || (_activeElement = _activeElement.shadowRoot) == null ? void 0 : _activeElement.activeElement) != null) {\n var _activeElement;\n activeElement = activeElement.shadowRoot.activeElement;\n }\n return activeElement;\n}\nfunction contains(parent, child) {\n if (!parent || !child) {\n return false;\n }\n const rootNode = child.getRootNode == null ? void 0 : child.getRootNode();\n\n // First, attempt with faster native method\n if (parent.contains(child)) {\n return true;\n }\n\n // then fallback to custom implementation with Shadow DOM support\n if (rootNode && isShadowRoot(rootNode)) {\n let next = child;\n while (next) {\n if (parent === next) {\n return true;\n }\n // @ts-ignore\n next = next.parentNode || next.host;\n }\n }\n\n // Give up, the result is false\n return false;\n}\nfunction getTarget(event) {\n if ('composedPath' in event) {\n return event.composedPath()[0];\n }\n\n // TS thinks `event` is of type never as it assumes all browsers support\n // `composedPath()`, but browsers without shadow DOM don't.\n return event.target;\n}\nfunction isEventTargetWithin(event, node) {\n if (node == null) {\n return false;\n }\n if ('composedPath' in event) {\n return event.composedPath().includes(node);\n }\n\n // TS thinks `event` is of type never as it assumes all browsers support composedPath, but browsers without shadow dom don't\n const e = event;\n return e.target != null && node.contains(e.target);\n}\nfunction isRootElement(element) {\n return element.matches('html,body');\n}\nfunction getDocument(node) {\n return (node == null ? void 0 : node.ownerDocument) || document;\n}\nfunction isTypeableElement(element) {\n return isHTMLElement(element) && element.matches(TYPEABLE_SELECTOR);\n}\nfunction isTypeableCombobox(element) {\n if (!element) return false;\n return element.getAttribute('role') === 'combobox' && isTypeableElement(element);\n}\nfunction matchesFocusVisible(element) {\n // We don't want to block focus from working with `visibleOnly`\n // (JSDOM doesn't match `:focus-visible` when the element has `:focus`)\n if (!element || isJSDOM()) return true;\n try {\n return element.matches(':focus-visible');\n } catch (_e) {\n return true;\n }\n}\nfunction getFloatingFocusElement(floatingElement) {\n if (!floatingElement) {\n return null;\n }\n // Try to find the element that has `{...getFloatingProps()}` spread on it.\n // This indicates the floating element is acting as a positioning wrapper, and\n // so focus should be managed on the child element with the event handlers and\n // aria props.\n return floatingElement.hasAttribute(FOCUSABLE_ATTRIBUTE) ? floatingElement : floatingElement.querySelector(\"[\" + FOCUSABLE_ATTRIBUTE + \"]\") || floatingElement;\n}\n\nfunction getNodeChildren(nodes, id, onlyOpenChildren) {\n if (onlyOpenChildren === void 0) {\n onlyOpenChildren = true;\n }\n const directChildren = nodes.filter(node => {\n var _node$context;\n return node.parentId === id && (!onlyOpenChildren || ((_node$context = node.context) == null ? void 0 : _node$context.open));\n });\n return directChildren.flatMap(child => [child, ...getNodeChildren(nodes, child.id, onlyOpenChildren)]);\n}\nfunction getDeepestNode(nodes, id) {\n let deepestNodeId;\n let maxDepth = -1;\n function findDeepest(nodeId, depth) {\n if (depth > maxDepth) {\n deepestNodeId = nodeId;\n maxDepth = depth;\n }\n const children = getNodeChildren(nodes, nodeId);\n children.forEach(child => {\n findDeepest(child.id, depth + 1);\n });\n }\n findDeepest(id, 0);\n return nodes.find(node => node.id === deepestNodeId);\n}\nfunction getNodeAncestors(nodes, id) {\n var _nodes$find;\n let allAncestors = [];\n let currentParentId = (_nodes$find = nodes.find(node => node.id === id)) == null ? void 0 : _nodes$find.parentId;\n while (currentParentId) {\n const currentNode = nodes.find(node => node.id === currentParentId);\n currentParentId = currentNode == null ? void 0 : currentNode.parentId;\n if (currentNode) {\n allAncestors = allAncestors.concat(currentNode);\n }\n }\n return allAncestors;\n}\n\nfunction stopEvent(event) {\n event.preventDefault();\n event.stopPropagation();\n}\nfunction isReactEvent(event) {\n return 'nativeEvent' in event;\n}\n\n// License: https://github.com/adobe/react-spectrum/blob/b35d5c02fe900badccd0cf1a8f23bb593419f238/packages/@react-aria/utils/src/isVirtualEvent.ts\nfunction isVirtualClick(event) {\n // FIXME: Firefox is now emitting a deprecation warning for `mozInputSource`.\n // Try to find a workaround for this. `react-aria` source still has the check.\n if (event.mozInputSource === 0 && event.isTrusted) {\n return true;\n }\n if (isAndroid() && event.pointerType) {\n return event.type === 'click' && event.buttons === 1;\n }\n return event.detail === 0 && !event.pointerType;\n}\nfunction isVirtualPointerEvent(event) {\n if (isJSDOM()) return false;\n return !isAndroid() && event.width === 0 && event.height === 0 || isAndroid() && event.width === 1 && event.height === 1 && event.pressure === 0 && event.detail === 0 && event.pointerType === 'mouse' ||\n // iOS VoiceOver returns 0.333• for width/height.\n event.width < 1 && event.height < 1 && event.pressure === 0 && event.detail === 0 && event.pointerType === 'touch';\n}\nfunction isMouseLikePointerType(pointerType, strict) {\n // On some Linux machines with Chromium, mouse inputs return a `pointerType`\n // of \"pen\": https://github.com/floating-ui/floating-ui/issues/2015\n const values = ['mouse', 'pen'];\n if (!strict) {\n values.push('', undefined);\n }\n return values.includes(pointerType);\n}\n\nvar isClient = typeof document !== 'undefined';\n\nvar noop = function noop() {};\nvar index = isClient ? useLayoutEffect : noop;\n\n// https://github.com/mui/material-ui/issues/41190#issuecomment-2040873379\nconst SafeReact = {\n ...React\n};\n\nfunction useLatestRef(value) {\n const ref = React.useRef(value);\n index(() => {\n ref.current = value;\n });\n return ref;\n}\nconst useInsertionEffect = SafeReact.useInsertionEffect;\nconst useSafeInsertionEffect = useInsertionEffect || (fn => fn());\nfunction useEffectEvent(callback) {\n const ref = React.useRef(() => {\n if (process.env.NODE_ENV !== \"production\") {\n throw new Error('Cannot call an event handler while rendering.');\n }\n });\n useSafeInsertionEffect(() => {\n ref.current = callback;\n });\n return React.useCallback(function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return ref.current == null ? void 0 : ref.current(...args);\n }, []);\n}\n\nfunction isDifferentGridRow(index, cols, prevRow) {\n return Math.floor(index / cols) !== prevRow;\n}\nfunction isIndexOutOfListBounds(listRef, index) {\n return index < 0 || index >= listRef.current.length;\n}\nfunction getMinListIndex(listRef, disabledIndices) {\n return findNonDisabledListIndex(listRef, {\n disabledIndices\n });\n}\nfunction getMaxListIndex(listRef, disabledIndices) {\n return findNonDisabledListIndex(listRef, {\n decrement: true,\n startingIndex: listRef.current.length,\n disabledIndices\n });\n}\nfunction findNonDisabledListIndex(listRef, _temp) {\n let {\n startingIndex = -1,\n decrement = false,\n disabledIndices,\n amount = 1\n } = _temp === void 0 ? {} : _temp;\n let index = startingIndex;\n do {\n index += decrement ? -amount : amount;\n } while (index >= 0 && index <= listRef.current.length - 1 && isListIndexDisabled(listRef, index, disabledIndices));\n return index;\n}\nfunction getGridNavigatedIndex(listRef, _ref) {\n let {\n event,\n orientation,\n loop,\n rtl,\n cols,\n disabledIndices,\n minIndex,\n maxIndex,\n prevIndex,\n stopEvent: stop = false\n } = _ref;\n let nextIndex = prevIndex;\n if (event.key === ARROW_UP) {\n stop && stopEvent(event);\n if (prevIndex === -1) {\n nextIndex = maxIndex;\n } else {\n nextIndex = findNonDisabledListIndex(listRef, {\n startingIndex: nextIndex,\n amount: cols,\n decrement: true,\n disabledIndices\n });\n if (loop && (prevIndex - cols < minIndex || nextIndex < 0)) {\n const col = prevIndex % cols;\n const maxCol = maxIndex % cols;\n const offset = maxIndex - (maxCol - col);\n if (maxCol === col) {\n nextIndex = maxIndex;\n } else {\n nextIndex = maxCol > col ? offset : offset - cols;\n }\n }\n }\n if (isIndexOutOfListBounds(listRef, nextIndex)) {\n nextIndex = prevIndex;\n }\n }\n if (event.key === ARROW_DOWN) {\n stop && stopEvent(event);\n if (prevIndex === -1) {\n nextIndex = minIndex;\n } else {\n nextIndex = findNonDisabledListIndex(listRef, {\n startingIndex: prevIndex,\n amount: cols,\n disabledIndices\n });\n if (loop && prevIndex + cols > maxIndex) {\n nextIndex = findNonDisabledListIndex(listRef, {\n startingIndex: prevIndex % cols - cols,\n amount: cols,\n disabledIndices\n });\n }\n }\n if (isIndexOutOfListBounds(listRef, nextIndex)) {\n nextIndex = prevIndex;\n }\n }\n\n // Remains on the same row/column.\n if (orientation === 'both') {\n const prevRow = floor(prevIndex / cols);\n if (event.key === (rtl ? ARROW_LEFT : ARROW_RIGHT)) {\n stop && stopEvent(event);\n if (prevIndex % cols !== cols - 1) {\n nextIndex = findNonDisabledListIndex(listRef, {\n startingIndex: prevIndex,\n disabledIndices\n });\n if (loop && isDifferentGridRow(nextIndex, cols, prevRow)) {\n nextIndex = findNonDisabledListIndex(listRef, {\n startingIndex: prevIndex - prevIndex % cols - 1,\n disabledIndices\n });\n }\n } else if (loop) {\n nextIndex = findNonDisabledListIndex(listRef, {\n startingIndex: prevIndex - prevIndex % cols - 1,\n disabledIndices\n });\n }\n if (isDifferentGridRow(nextIndex, cols, prevRow)) {\n nextIndex = prevIndex;\n }\n }\n if (event.key === (rtl ? ARROW_RIGHT : ARROW_LEFT)) {\n stop && stopEvent(event);\n if (prevIndex % cols !== 0) {\n nextIndex = findNonDisabledListIndex(listRef, {\n startingIndex: prevIndex,\n decrement: true,\n disabledIndices\n });\n if (loop && isDifferentGridRow(nextIndex, cols, prevRow)) {\n nextIndex = findNonDisabledListIndex(listRef, {\n startingIndex: prevIndex + (cols - prevIndex % cols),\n decrement: true,\n disabledIndices\n });\n }\n } else if (loop) {\n nextIndex = findNonDisabledListIndex(listRef, {\n startingIndex: prevIndex + (cols - prevIndex % cols),\n decrement: true,\n disabledIndices\n });\n }\n if (isDifferentGridRow(nextIndex, cols, prevRow)) {\n nextIndex = prevIndex;\n }\n }\n const lastRow = floor(maxIndex / cols) === prevRow;\n if (isIndexOutOfListBounds(listRef, nextIndex)) {\n if (loop && lastRow) {\n nextIndex = event.key === (rtl ? ARROW_RIGHT : ARROW_LEFT) ? maxIndex : findNonDisabledListIndex(listRef, {\n startingIndex: prevIndex - prevIndex % cols - 1,\n disabledIndices\n });\n } else {\n nextIndex = prevIndex;\n }\n }\n }\n return nextIndex;\n}\n\n/** For each cell index, gets the item index that occupies that cell */\nfunction createGridCellMap(sizes, cols, dense) {\n const cellMap = [];\n let startIndex = 0;\n sizes.forEach((_ref2, index) => {\n let {\n width,\n height\n } = _ref2;\n if (width > cols) {\n if (process.env.NODE_ENV !== \"production\") {\n throw new Error(\"[Floating UI]: Invalid grid - item width at index \" + index + \" is greater than grid columns\");\n }\n }\n let itemPlaced = false;\n if (dense) {\n startIndex = 0;\n }\n while (!itemPlaced) {\n const targetCells = [];\n for (let i = 0; i < width; i++) {\n for (let j = 0; j < height; j++) {\n targetCells.push(startIndex + i + j * cols);\n }\n }\n if (startIndex % cols + width <= cols && targetCells.every(cell => cellMap[cell] == null)) {\n targetCells.forEach(cell => {\n cellMap[cell] = index;\n });\n itemPlaced = true;\n } else {\n startIndex++;\n }\n }\n });\n\n // convert into a non-sparse array\n return [...cellMap];\n}\n\n/** Gets cell index of an item's corner or -1 when index is -1. */\nfunction getGridCellIndexOfCorner(index, sizes, cellMap, cols, corner) {\n if (index === -1) return -1;\n const firstCellIndex = cellMap.indexOf(index);\n const sizeItem = sizes[index];\n switch (corner) {\n case 'tl':\n return firstCellIndex;\n case 'tr':\n if (!sizeItem) {\n return firstCellIndex;\n }\n return firstCellIndex + sizeItem.width - 1;\n case 'bl':\n if (!sizeItem) {\n return firstCellIndex;\n }\n return firstCellIndex + (sizeItem.height - 1) * cols;\n case 'br':\n return cellMap.lastIndexOf(index);\n }\n}\n\n/** Gets all cell indices that correspond to the specified indices */\nfunction getGridCellIndices(indices, cellMap) {\n return cellMap.flatMap((index, cellIndex) => indices.includes(index) ? [cellIndex] : []);\n}\nfunction isListIndexDisabled(listRef, index, disabledIndices) {\n if (typeof disabledIndices === 'function') {\n return disabledIndices(index);\n } else if (disabledIndices) {\n return disabledIndices.includes(index);\n }\n const element = listRef.current[index];\n return element == null || element.hasAttribute('disabled') || element.getAttribute('aria-disabled') === 'true';\n}\n\nconst getTabbableOptions = () => ({\n getShadowRoot: true,\n displayCheck:\n // JSDOM does not support the `tabbable` library. To solve this we can\n // check if `ResizeObserver` is a real function (not polyfilled), which\n // determines if the current environment is JSDOM-like.\n typeof ResizeObserver === 'function' && ResizeObserver.toString().includes('[native code]') ? 'full' : 'none'\n});\nfunction getTabbableIn(container, dir) {\n const list = tabbable(container, getTabbableOptions());\n const len = list.length;\n if (len === 0) return;\n const active = activeElement(getDocument(container));\n const index = list.indexOf(active);\n const nextIndex = index === -1 ? dir === 1 ? 0 : len - 1 : index + dir;\n return list[nextIndex];\n}\nfunction getNextTabbable(referenceElement) {\n return getTabbableIn(getDocument(referenceElement).body, 1) || referenceElement;\n}\nfunction getPreviousTabbable(referenceElement) {\n return getTabbableIn(getDocument(referenceElement).body, -1) || referenceElement;\n}\nfunction isOutsideEvent(event, container) {\n const containerElement = container || event.currentTarget;\n const relatedTarget = event.relatedTarget;\n return !relatedTarget || !contains(containerElement, relatedTarget);\n}\nfunction disableFocusInside(container) {\n const tabbableElements = tabbable(container, getTabbableOptions());\n tabbableElements.forEach(element => {\n element.dataset.tabindex = element.getAttribute('tabindex') || '';\n element.setAttribute('tabindex', '-1');\n });\n}\nfunction enableFocusInside(container) {\n const elements = container.querySelectorAll('[data-tabindex]');\n elements.forEach(element => {\n const tabindex = element.dataset.tabindex;\n delete element.dataset.tabindex;\n if (tabindex) {\n element.setAttribute('tabindex', tabindex);\n } else {\n element.removeAttribute('tabindex');\n }\n });\n}\n\nexport { activeElement, contains, createGridCellMap, disableFocusInside, enableFocusInside, findNonDisabledListIndex, getDeepestNode, getDocument, getFloatingFocusElement, getGridCellIndexOfCorner, getGridCellIndices, getGridNavigatedIndex, getMaxListIndex, getMinListIndex, getNextTabbable, getNodeAncestors, getNodeChildren, getPlatform, getPreviousTabbable, getTabbableOptions, getTarget, getUserAgent, isAndroid, isDifferentGridRow, isEventTargetWithin, isIndexOutOfListBounds, isJSDOM, isListIndexDisabled, isMac, isMouseLikePointerType, isOutsideEvent, isReactEvent, isRootElement, isSafari, isTypeableCombobox, isTypeableElement, isVirtualClick, isVirtualPointerEvent, matchesFocusVisible, stopEvent, useEffectEvent, useLatestRef, index as useModernLayoutEffect };\n","import * as React from 'react';\nimport { useModernLayoutEffect, useEffectEvent, getMinListIndex, getMaxListIndex, createGridCellMap, isListIndexDisabled, getGridNavigatedIndex, getGridCellIndexOfCorner, getGridCellIndices, findNonDisabledListIndex, isIndexOutOfListBounds, useLatestRef, getDocument as getDocument$1, isMouseLikePointerType, contains as contains$1, isSafari, enableFocusInside, isOutsideEvent, getPreviousTabbable, getNextTabbable, disableFocusInside, isTypeableCombobox, getFloatingFocusElement, getTabbableOptions, getNodeAncestors, activeElement, getNodeChildren as getNodeChildren$1, stopEvent, getTarget as getTarget$1, isVirtualClick, isVirtualPointerEvent, getPlatform, isTypeableElement, isReactEvent, isRootElement, isEventTargetWithin, matchesFocusVisible, isMac, getDeepestNode, getUserAgent } from '@floating-ui/react/utils';\nimport { jsx, jsxs, Fragment } from 'react/jsx-runtime';\nimport { getComputedStyle, isElement, isShadowRoot, getNodeName, isNode, isHTMLElement, getWindow, isLastTraversableNode, getParentNode, isWebKit } from '@floating-ui/utils/dom';\nimport { tabbable, isTabbable, focusable } from 'tabbable';\nimport * as ReactDOM from 'react-dom';\nimport { getOverflowAncestors, useFloating as useFloating$1, offset } from '@floating-ui/react-dom';\nexport { arrow, autoPlacement, autoUpdate, computePosition, detectOverflow, flip, getOverflowAncestors, hide, inline, limitShift, offset, platform, shift, size } from '@floating-ui/react-dom';\nimport { evaluate, max, min, round } from '@floating-ui/utils';\n\n/**\n * Merges an array of refs into a single memoized callback ref or `null`.\n * @see https://floating-ui.com/docs/react-utils#usemergerefs\n */\nfunction useMergeRefs(refs) {\n const cleanupRef = React.useRef(undefined);\n const refEffect = React.useCallback(instance => {\n const cleanups = refs.map(ref => {\n if (ref == null) {\n return;\n }\n if (typeof ref === 'function') {\n const refCallback = ref;\n const refCleanup = refCallback(instance);\n return typeof refCleanup === 'function' ? refCleanup : () => {\n refCallback(null);\n };\n }\n ref.current = instance;\n return () => {\n ref.current = null;\n };\n });\n return () => {\n cleanups.forEach(refCleanup => refCleanup == null ? void 0 : refCleanup());\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, refs);\n return React.useMemo(() => {\n if (refs.every(ref => ref == null)) {\n return null;\n }\n return value => {\n if (cleanupRef.current) {\n cleanupRef.current();\n cleanupRef.current = undefined;\n }\n if (value != null) {\n cleanupRef.current = refEffect(value);\n }\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, refs);\n}\n\nfunction sortByDocumentPosition(a, b) {\n const position = a.compareDocumentPosition(b);\n if (position & Node.DOCUMENT_POSITION_FOLLOWING || position & Node.DOCUMENT_POSITION_CONTAINED_BY) {\n return -1;\n }\n if (position & Node.DOCUMENT_POSITION_PRECEDING || position & Node.DOCUMENT_POSITION_CONTAINS) {\n return 1;\n }\n return 0;\n}\nconst FloatingListContext = /*#__PURE__*/React.createContext({\n register: () => {},\n unregister: () => {},\n map: /*#__PURE__*/new Map(),\n elementsRef: {\n current: []\n }\n});\n/**\n * Provides context for a list of items within the floating element.\n * @see https://floating-ui.com/docs/FloatingList\n */\nfunction FloatingList(props) {\n const {\n children,\n elementsRef,\n labelsRef\n } = props;\n const [nodes, setNodes] = React.useState(() => new Set());\n const register = React.useCallback(node => {\n setNodes(prevSet => new Set(prevSet).add(node));\n }, []);\n const unregister = React.useCallback(node => {\n setNodes(prevSet => {\n const set = new Set(prevSet);\n set.delete(node);\n return set;\n });\n }, []);\n const map = React.useMemo(() => {\n const newMap = new Map();\n const sortedNodes = Array.from(nodes.keys()).sort(sortByDocumentPosition);\n sortedNodes.forEach((node, index) => {\n newMap.set(node, index);\n });\n return newMap;\n }, [nodes]);\n return /*#__PURE__*/jsx(FloatingListContext.Provider, {\n value: React.useMemo(() => ({\n register,\n unregister,\n map,\n elementsRef,\n labelsRef\n }), [register, unregister, map, elementsRef, labelsRef]),\n children: children\n });\n}\n/**\n * Used to register a list item and its index (DOM position) in the\n * `FloatingList`.\n * @see https://floating-ui.com/docs/FloatingList#uselistitem\n */\nfunction useListItem(props) {\n if (props === void 0) {\n props = {};\n }\n const {\n label\n } = props;\n const {\n register,\n unregister,\n map,\n elementsRef,\n labelsRef\n } = React.useContext(FloatingListContext);\n const [index, setIndex] = React.useState(null);\n const componentRef = React.useRef(null);\n const ref = React.useCallback(node => {\n componentRef.current = node;\n if (index !== null) {\n elementsRef.current[index] = node;\n if (labelsRef) {\n var _node$textContent;\n const isLabelDefined = label !== undefined;\n labelsRef.current[index] = isLabelDefined ? label : (_node$textContent = node == null ? void 0 : node.textContent) != null ? _node$textContent : null;\n }\n }\n }, [index, elementsRef, labelsRef, label]);\n useModernLayoutEffect(() => {\n const node = componentRef.current;\n if (node) {\n register(node);\n return () => {\n unregister(node);\n };\n }\n }, [register, unregister]);\n useModernLayoutEffect(() => {\n const index = componentRef.current ? map.get(componentRef.current) : null;\n if (index != null) {\n setIndex(index);\n }\n }, [map]);\n return React.useMemo(() => ({\n ref,\n index: index == null ? -1 : index\n }), [index, ref]);\n}\n\nconst FOCUSABLE_ATTRIBUTE = 'data-floating-ui-focusable';\nconst ACTIVE_KEY = 'active';\nconst SELECTED_KEY = 'selected';\nconst ARROW_LEFT = 'ArrowLeft';\nconst ARROW_RIGHT = 'ArrowRight';\nconst ARROW_UP = 'ArrowUp';\nconst ARROW_DOWN = 'ArrowDown';\n\nfunction renderJsx(render, computedProps) {\n if (typeof render === 'function') {\n return render(computedProps);\n }\n if (render) {\n return /*#__PURE__*/React.cloneElement(render, computedProps);\n }\n return /*#__PURE__*/jsx(\"div\", {\n ...computedProps\n });\n}\nconst CompositeContext = /*#__PURE__*/React.createContext({\n activeIndex: 0,\n onNavigate: () => {}\n});\nconst horizontalKeys = [ARROW_LEFT, ARROW_RIGHT];\nconst verticalKeys = [ARROW_UP, ARROW_DOWN];\nconst allKeys = [...horizontalKeys, ...verticalKeys];\n\n/**\n * Creates a single tab stop whose items are navigated by arrow keys, which\n * provides list navigation outside of floating element contexts.\n *\n * This is useful to enable navigation of a list of items that aren’t part of a\n * floating element. A menubar is an example of a composite, with each reference\n * element being an item.\n * @see https://floating-ui.com/docs/Composite\n */\nconst Composite = /*#__PURE__*/React.forwardRef(function Composite(props, forwardedRef) {\n const {\n render,\n orientation = 'both',\n loop = true,\n rtl = false,\n cols = 1,\n disabledIndices,\n activeIndex: externalActiveIndex,\n onNavigate: externalSetActiveIndex,\n itemSizes,\n dense = false,\n ...domProps\n } = props;\n const [internalActiveIndex, internalSetActiveIndex] = React.useState(0);\n const activeIndex = externalActiveIndex != null ? externalActiveIndex : internalActiveIndex;\n const onNavigate = useEffectEvent(externalSetActiveIndex != null ? externalSetActiveIndex : internalSetActiveIndex);\n const elementsRef = React.useRef([]);\n const renderElementProps = render && typeof render !== 'function' ? render.props : {};\n const contextValue = React.useMemo(() => ({\n activeIndex,\n onNavigate\n }), [activeIndex, onNavigate]);\n const isGrid = cols > 1;\n function handleKeyDown(event) {\n if (!allKeys.includes(event.key)) return;\n let nextIndex = activeIndex;\n const minIndex = getMinListIndex(elementsRef, disabledIndices);\n const maxIndex = getMaxListIndex(elementsRef, disabledIndices);\n const horizontalEndKey = rtl ? ARROW_LEFT : ARROW_RIGHT;\n const horizontalStartKey = rtl ? ARROW_RIGHT : ARROW_LEFT;\n if (isGrid) {\n const sizes = itemSizes || Array.from({\n length: elementsRef.current.length\n }, () => ({\n width: 1,\n height: 1\n }));\n // To calculate movements on the grid, we use hypothetical cell indices\n // as if every item was 1x1, then convert back to real indices.\n const cellMap = createGridCellMap(sizes, cols, dense);\n const minGridIndex = cellMap.findIndex(index => index != null && !isListIndexDisabled(elementsRef, index, disabledIndices));\n // last enabled index\n const maxGridIndex = cellMap.reduce((foundIndex, index, cellIndex) => index != null && !isListIndexDisabled(elementsRef, index, disabledIndices) ? cellIndex : foundIndex, -1);\n const maybeNextIndex = cellMap[getGridNavigatedIndex({\n current: cellMap.map(itemIndex => itemIndex ? elementsRef.current[itemIndex] : null)\n }, {\n event,\n orientation,\n loop,\n rtl,\n cols,\n // treat undefined (empty grid spaces) as disabled indices so we\n // don't end up in them\n disabledIndices: getGridCellIndices([...((typeof disabledIndices !== 'function' ? disabledIndices : null) || elementsRef.current.map((_, index) => isListIndexDisabled(elementsRef, index, disabledIndices) ? index : undefined)), undefined], cellMap),\n minIndex: minGridIndex,\n maxIndex: maxGridIndex,\n prevIndex: getGridCellIndexOfCorner(activeIndex > maxIndex ? minIndex : activeIndex, sizes, cellMap, cols,\n // use a corner matching the edge closest to the direction we're\n // moving in so we don't end up in the same item. Prefer\n // top/left over bottom/right.\n event.key === ARROW_DOWN ? 'bl' : event.key === horizontalEndKey ? 'tr' : 'tl')\n })];\n if (maybeNextIndex != null) {\n nextIndex = maybeNextIndex;\n }\n }\n const toEndKeys = {\n horizontal: [horizontalEndKey],\n vertical: [ARROW_DOWN],\n both: [horizontalEndKey, ARROW_DOWN]\n }[orientation];\n const toStartKeys = {\n horizontal: [horizontalStartKey],\n vertical: [ARROW_UP],\n both: [horizontalStartKey, ARROW_UP]\n }[orientation];\n const preventedKeys = isGrid ? allKeys : {\n horizontal: horizontalKeys,\n vertical: verticalKeys,\n both: allKeys\n }[orientation];\n if (nextIndex === activeIndex && [...toEndKeys, ...toStartKeys].includes(event.key)) {\n if (loop && nextIndex === maxIndex && toEndKeys.includes(event.key)) {\n nextIndex = minIndex;\n } else if (loop && nextIndex === minIndex && toStartKeys.includes(event.key)) {\n nextIndex = maxIndex;\n } else {\n nextIndex = findNonDisabledListIndex(elementsRef, {\n startingIndex: nextIndex,\n decrement: toStartKeys.includes(event.key),\n disabledIndices\n });\n }\n }\n if (nextIndex !== activeIndex && !isIndexOutOfListBounds(elementsRef, nextIndex)) {\n var _elementsRef$current$;\n event.stopPropagation();\n if (preventedKeys.includes(event.key)) {\n event.preventDefault();\n }\n onNavigate(nextIndex);\n (_elementsRef$current$ = elementsRef.current[nextIndex]) == null || _elementsRef$current$.focus();\n }\n }\n const computedProps = {\n ...domProps,\n ...renderElementProps,\n ref: forwardedRef,\n 'aria-orientation': orientation === 'both' ? undefined : orientation,\n onKeyDown(e) {\n domProps.onKeyDown == null || domProps.onKeyDown(e);\n renderElementProps.onKeyDown == null || renderElementProps.onKeyDown(e);\n handleKeyDown(e);\n }\n };\n return /*#__PURE__*/jsx(CompositeContext.Provider, {\n value: contextValue,\n children: /*#__PURE__*/jsx(FloatingList, {\n elementsRef: elementsRef,\n children: renderJsx(render, computedProps)\n })\n });\n});\n/**\n * @see https://floating-ui.com/docs/Composite\n */\nconst CompositeItem = /*#__PURE__*/React.forwardRef(function CompositeItem(props, forwardedRef) {\n const {\n render,\n ...domProps\n } = props;\n const renderElementProps = render && typeof render !== 'function' ? render.props : {};\n const {\n activeIndex,\n onNavigate\n } = React.useContext(CompositeContext);\n const {\n ref,\n index\n } = useListItem();\n const mergedRef = useMergeRefs([ref, forwardedRef, renderElementProps.ref]);\n const isActive = activeIndex === index;\n const computedProps = {\n ...domProps,\n ...renderElementProps,\n ref: mergedRef,\n tabIndex: isActive ? 0 : -1,\n 'data-active': isActive ? '' : undefined,\n onFocus(e) {\n domProps.onFocus == null || domProps.onFocus(e);\n renderElementProps.onFocus == null || renderElementProps.onFocus(e);\n onNavigate(index);\n }\n };\n return renderJsx(render, computedProps);\n});\n\n// https://github.com/mui/material-ui/issues/41190#issuecomment-2040873379\nconst SafeReact = {\n ...React\n};\n\nlet serverHandoffComplete = false;\nlet count = 0;\nconst genId = () => // Ensure the id is unique with multiple independent versions of Floating UI\n// on <React 18\n\"floating-ui-\" + Math.random().toString(36).slice(2, 6) + count++;\nfunction useFloatingId() {\n const [id, setId] = React.useState(() => serverHandoffComplete ? genId() : undefined);\n useModernLayoutEffect(() => {\n if (id == null) {\n setId(genId());\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n React.useEffect(() => {\n serverHandoffComplete = true;\n }, []);\n return id;\n}\nconst useReactId = SafeReact.useId;\n\n/**\n * Uses React 18's built-in `useId()` when available, or falls back to a\n * slightly less performant (requiring a double render) implementation for\n * earlier React versions.\n * @see https://floating-ui.com/docs/react-utils#useid\n */\nconst useId = useReactId || useFloatingId;\n\nlet devMessageSet;\nif (process.env.NODE_ENV !== \"production\") {\n devMessageSet = /*#__PURE__*/new Set();\n}\nfunction warn() {\n var _devMessageSet;\n for (var _len = arguments.length, messages = new Array(_len), _key = 0; _key < _len; _key++) {\n messages[_key] = arguments[_key];\n }\n const message = \"Floating UI: \" + messages.join(' ');\n if (!((_devMessageSet = devMessageSet) != null && _devMessageSet.has(message))) {\n var _devMessageSet2;\n (_devMessageSet2 = devMessageSet) == null || _devMessageSet2.add(message);\n console.warn(message);\n }\n}\nfunction error() {\n var _devMessageSet3;\n for (var _len2 = arguments.length, messages = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n messages[_key2] = arguments[_key2];\n }\n const message = \"Floating UI: \" + messages.join(' ');\n if (!((_devMessageSet3 = devMessageSet) != null && _devMessageSet3.has(message))) {\n var _devMessageSet4;\n (_devMessageSet4 = devMessageSet) == null || _devMessageSet4.add(message);\n console.error(message);\n }\n}\n\n/**\n * Renders a pointing arrow triangle.\n * @see https://floating-ui.com/docs/FloatingArrow\n */\nconst FloatingArrow = /*#__PURE__*/React.forwardRef(function FloatingArrow(props, ref) {\n const {\n context: {\n placement,\n elements: {\n floating\n },\n middlewareData: {\n arrow,\n shift\n }\n },\n width = 14,\n height = 7,\n tipRadius = 0,\n strokeWidth = 0,\n staticOffset,\n stroke,\n d,\n style: {\n transform,\n ...restStyle\n } = {},\n ...rest\n } = props;\n if (process.env.NODE_ENV !== \"production\") {\n if (!ref) {\n warn('The `ref` prop is required for `FloatingArrow`.');\n }\n }\n const clipPathId = useId();\n const [isRTL, setIsRTL] = React.useState(false);\n\n // https://github.com/floating-ui/floating-ui/issues/2932\n useModernLayoutEffect(() => {\n if (!floating) return;\n const isRTL = getComputedStyle(floating).direction === 'rtl';\n if (isRTL) {\n setIsRTL(true);\n }\n }, [floating]);\n if (!floating) {\n return null;\n }\n const [side, alignment] = placement.split('-');\n const isVerticalSide = side === 'top' || side === 'bottom';\n let computedStaticOffset = staticOffset;\n if (isVerticalSide && shift != null && shift.x || !isVerticalSide && shift != null && shift.y) {\n computedStaticOffset = null;\n }\n\n // Strokes must be double the border width, this ensures the stroke's width\n // works as you'd expect.\n const computedStrokeWidth = strokeWidth * 2;\n const halfStrokeWidth = computedStrokeWidth / 2;\n const svgX = width / 2 * (tipRadius / -8 + 1);\n const svgY = height / 2 * tipRadius / 4;\n const isCustomShape = !!d;\n const yOffsetProp = computedStaticOffset && alignment === 'end' ? 'bottom' : 'top';\n let xOffsetProp = computedStaticOffset && alignment === 'end' ? 'right' : 'left';\n if (computedStaticOffset && isRTL) {\n xOffsetProp = alignment === 'end' ? 'left' : 'right';\n }\n const arrowX = (arrow == null ? void 0 : arrow.x) != null ? computedStaticOffset || arrow.x : '';\n const arrowY = (arrow == null ? void 0 : arrow.y) != null ? computedStaticOffset || arrow.y : '';\n const dValue = d || 'M0,0' + (\" H\" + width) + (\" L\" + (width - svgX) + \",\" + (height - svgY)) + (\" Q\" + width / 2 + \",\" + height + \" \" + svgX + \",\" + (height - svgY)) + ' Z';\n const rotation = {\n top: isCustomShape ? 'rotate(180deg)' : '',\n left: isCustomShape ? 'rotate(90deg)' : 'rotate(-90deg)',\n bottom: isCustomShape ? '' : 'rotate(180deg)',\n right: isCustomShape ? 'rotate(-90deg)' : 'rotate(90deg)'\n }[side];\n return /*#__PURE__*/jsxs(\"svg\", {\n ...rest,\n \"aria-hidden\": true,\n ref: ref,\n width: isCustomShape ? width : width + computedStrokeWidth,\n height: width,\n viewBox: \"0 0 \" + width + \" \" + (height > width ? height : width),\n style: {\n position: 'absolute',\n pointerEvents: 'none',\n [xOffsetProp]: arrowX,\n [yOffsetProp]: arrowY,\n [side]: isVerticalSide || isCustomShape ? '100%' : \"calc(100% - \" + computedStrokeWidth / 2 + \"px)\",\n transform: [rotation, transform].filter(t => !!t).join(' '),\n ...restStyle\n },\n children: [computedStrokeWidth > 0 && /*#__PURE__*/jsx(\"path\", {\n clipPath: \"url(#\" + clipPathId + \")\",\n fill: \"none\",\n stroke: stroke\n // Account for the stroke on the fill path rendered below.\n ,\n strokeWidth: computedStrokeWidth + (d ? 0 : 1),\n d: dValue\n }), /*#__PURE__*/jsx(\"path\", {\n stroke: computedStrokeWidth && !d ? rest.fill : 'none',\n d: dValue\n }), /*#__PURE__*/jsx(\"clipPath\", {\n id: clipPathId,\n children: /*#__PURE__*/jsx(\"rect\", {\n x: -halfStrokeWidth,\n y: halfStrokeWidth * (isCustomShape ? -1 : 1),\n width: width + computedStrokeWidth,\n height: width\n })\n })]\n });\n});\n\nfunction createEventEmitter() {\n const map = new Map();\n return {\n emit(event, data) {\n var _map$get;\n (_map$get = map.get(event)) == null || _map$get.forEach(listener => listener(data));\n },\n on(event, listener) {\n if (!map.has(event)) {\n map.set(event, new Set());\n }\n map.get(event).add(listener);\n },\n off(event, listener) {\n var _map$get2;\n (_map$get2 = map.get(event)) == null || _map$get2.delete(listener);\n }\n };\n}\n\nconst FloatingNodeContext = /*#__PURE__*/React.createContext(null);\nconst FloatingTreeContext = /*#__PURE__*/React.createContext(null);\n\n/**\n * Returns the parent node id for nested floating elements, if available.\n * Returns `null` for top-level floating elements.\n */\nconst useFloatingParentNodeId = () => {\n var _React$useContext;\n return ((_React$useContext = React.useContext(FloatingNodeContext)) == null ? void 0 : _React$useContext.id) || null;\n};\n\n/**\n * Returns the nearest floating tree context, if available.\n */\nconst useFloatingTree = () => React.useContext(FloatingTreeContext);\n\n/**\n * Registers a node into the `FloatingTree`, returning its id.\n * @see https://floating-ui.com/docs/FloatingTree\n */\nfunction useFloatingNodeId(customParentId) {\n const id = useId();\n const tree = useFloatingTree();\n const reactParentId = useFloatingParentNodeId();\n const parentId = customParentId || reactParentId;\n useModernLayoutEffect(() => {\n if (!id) return;\n const node = {\n id,\n parentId\n };\n tree == null || tree.addNode(node);\n return () => {\n tree == null || tree.removeNode(node);\n };\n }, [tree, id, parentId]);\n return id;\n}\n/**\n * Provides parent node context for nested floating elements.\n * @see https://floating-ui.com/docs/FloatingTree\n */\nfunction FloatingNode(props) {\n const {\n children,\n id\n } = props;\n const parentId = useFloatingParentNodeId();\n return /*#__PURE__*/jsx(FloatingNodeContext.Provider, {\n value: React.useMemo(() => ({\n id,\n parentId\n }), [id, parentId]),\n children: children\n });\n}\n/**\n * Provides context for nested floating elements when they are not children of\n * each other on the DOM.\n * This is not necessary in all cases, except when there must be explicit communication between parent and child floating elements. It is necessary for:\n * - The `bubbles` option in the `useDismiss()` Hook\n * - Nested virtual list navigation\n * - Nested floating elements that each open on hover\n * - Custom communication between parent and child floating elements\n * @see https://floating-ui.com/docs/FloatingTree\n */\nfunction FloatingTree(props) {\n const {\n children\n } = props;\n const nodesRef = React.useRef([]);\n const addNode = React.useCallback(node => {\n nodesRef.current = [...nodesRef.current, node];\n }, []);\n const removeNode = React.useCallback(node => {\n nodesRef.current = nodesRef.current.filter(n => n !== node);\n }, []);\n const [events] = React.useState(() => createEventEmitter());\n return /*#__PURE__*/jsx(FloatingTreeContext.Provider, {\n value: React.useMemo(() => ({\n nodesRef,\n addNode,\n removeNode,\n events\n }), [addNode, removeNode, events]),\n children: children\n });\n}\n\nfunction createAttribute(name) {\n return \"data-floating-ui-\" + name;\n}\n\nfunction clearTimeoutIfSet(timeoutRef) {\n if (timeoutRef.current !== -1) {\n clearTimeout(timeoutRef.current);\n timeoutRef.current = -1;\n }\n}\n\nconst safePolygonIdentifier = /*#__PURE__*/createAttribute('safe-polygon');\nfunction getDelay(value, prop, pointerType) {\n if (pointerType && !isMouseLikePointerType(pointerType)) {\n return 0;\n }\n if (typeof value === 'number') {\n return value;\n }\n if (typeof value === 'function') {\n const result = value();\n if (typeof result === 'number') {\n return result;\n }\n return result == null ? void 0 : result[prop];\n }\n return value == null ? void 0 : value[prop];\n}\nfunction getRestMs(value) {\n if (typeof value === 'function') {\n return value();\n }\n return value;\n}\n/**\n * Opens the floating element while hovering over the reference element, like\n * CSS `:hover`.\n * @see https://floating-ui.com/docs/useHover\n */\nfunction useHover(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n onOpenChange,\n dataRef,\n events,\n elements\n } = context;\n const {\n enabled = true,\n delay = 0,\n handleClose = null,\n mouseOnly = false,\n restMs = 0,\n move = true\n } = props;\n const tree = useFloatingTree();\n const parentId = useFloatingParentNodeId();\n const handleCloseRef = useLatestRef(handleClose);\n const delayRef = useLatestRef(delay);\n const openRef = useLatestRef(open);\n const restMsRef = useLatestRef(restMs);\n const pointerTypeRef = React.useRef();\n const timeoutRef = React.useRef(-1);\n const handlerRef = React.useRef();\n const restTimeoutRef = React.useRef(-1);\n const blockMouseMoveRef = React.useRef(true);\n const performedPointerEventsMutationRef = React.useRef(false);\n const unbindMouseMoveRef = React.useRef(() => {});\n const restTimeoutPendingRef = React.useRef(false);\n const isHoverOpen = useEffectEvent(() => {\n var _dataRef$current$open;\n const type = (_dataRef$current$open = dataRef.current.openEvent) == null ? void 0 : _dataRef$current$open.type;\n return (type == null ? void 0 : type.includes('mouse')) && type !== 'mousedown';\n });\n\n // When closing before opening, clear the delay timeouts to cancel it\n // from showing.\n React.useEffect(() => {\n if (!enabled) return;\n function onOpenChange(_ref) {\n let {\n open\n } = _ref;\n if (!open) {\n clearTimeoutIfSet(timeoutRef);\n clearTimeoutIfSet(restTimeoutRef);\n blockMouseMoveRef.current = true;\n restTimeoutPendingRef.current = false;\n }\n }\n events.on('openchange', onOpenChange);\n return () => {\n events.off('openchange', onOpenChange);\n };\n }, [enabled, events]);\n React.useEffect(() => {\n if (!enabled) return;\n if (!handleCloseRef.current) return;\n if (!open) return;\n function onLeave(event) {\n if (isHoverOpen()) {\n onOpenChange(false, event, 'hover');\n }\n }\n const html = getDocument$1(elements.floating).documentElement;\n html.addEventListener('mouseleave', onLeave);\n return () => {\n html.removeEventListener('mouseleave', onLeave);\n };\n }, [elements.floating, open, onOpenChange, enabled, handleCloseRef, isHoverOpen]);\n const closeWithDelay = React.useCallback(function (event, runElseBranch, reason) {\n if (runElseBranch === void 0) {\n runElseBranch = true;\n }\n if (reason === void 0) {\n reason = 'hover';\n }\n const closeDelay = getDelay(delayRef.current, 'close', pointerTypeRef.current);\n if (closeDelay && !handlerRef.current) {\n clearTimeoutIfSet(timeoutRef);\n timeoutRef.current = window.setTimeout(() => onOpenChange(false, event, reason), closeDelay);\n } else if (runElseBranch) {\n clearTimeoutIfSet(timeoutRef);\n onOpenChange(false, event, reason);\n }\n }, [delayRef, onOpenChange]);\n const cleanupMouseMoveHandler = useEffectEvent(() => {\n unbindMouseMoveRef.current();\n handlerRef.current = undefined;\n });\n const clearPointerEvents = useEffectEvent(() => {\n if (performedPointerEventsMutationRef.current) {\n const body = getDocument$1(elements.floating).body;\n body.style.pointerEvents = '';\n body.removeAttribute(safePolygonIdentifier);\n performedPointerEventsMutationRef.current = false;\n }\n });\n const isClickLikeOpenEvent = useEffectEvent(() => {\n return dataRef.current.openEvent ? ['click', 'mousedown'].includes(dataRef.current.openEvent.type) : false;\n });\n\n // Registering the mouse events on the reference directly to bypass React's\n // delegation system. If the cursor was on a disabled element and then entered\n // the reference (no gap), `mouseenter` doesn't fire in the delegation system.\n React.useEffect(() => {\n if (!enabled) return;\n function onReferenceMouseEnter(event) {\n clearTimeoutIfSet(timeoutRef);\n blockMouseMoveRef.current = false;\n if (mouseOnly && !isMouseLikePointerType(pointerTypeRef.current) || getRestMs(restMsRef.current) > 0 && !getDelay(delayRef.current, 'open')) {\n return;\n }\n const openDelay = getDelay(delayRef.current, 'open', pointerTypeRef.current);\n if (openDelay) {\n timeoutRef.current = window.setTimeout(() => {\n if (!openRef.current) {\n onOpenChange(true, event, 'hover');\n }\n }, openDelay);\n } else if (!open) {\n onOpenChange(true, event, 'hover');\n }\n }\n function onReferenceMouseLeave(event) {\n if (isClickLikeOpenEvent()) {\n clearPointerEvents();\n return;\n }\n unbindMouseMoveRef.current();\n const doc = getDocument$1(elements.floating);\n clearTimeoutIfSet(restTimeoutRef);\n restTimeoutPendingRef.current = false;\n if (handleCloseRef.current && dataRef.current.floatingContext) {\n // Prevent clearing `onScrollMouseLeave` timeout.\n if (!open) {\n clearTimeoutIfSet(timeoutRef);\n }\n handlerRef.current = handleCloseRef.current({\n ...dataRef.current.floatingContext,\n tree,\n x: event.clientX,\n y: event.clientY,\n onClose() {\n clearPointerEvents();\n cleanupMouseMoveHandler();\n if (!isClickLikeOpenEvent()) {\n closeWithDelay(event, true, 'safe-polygon');\n }\n }\n });\n const handler = handlerRef.current;\n doc.addEventListener('mousemove', handler);\n unbindMouseMoveRef.current = () => {\n doc.removeEventListener('mousemove', handler);\n };\n return;\n }\n\n // Allow interactivity without `safePolygon` on touch devices. With a\n // pointer, a short close delay is an alternative, so it should work\n // consistently.\n const shouldClose = pointerTypeRef.current === 'touch' ? !contains$1(elements.floating, event.relatedTarget) : true;\n if (shouldClose) {\n closeWithDelay(event);\n }\n }\n\n // Ensure the floating element closes after scrolling even if the pointer\n // did not move.\n // https://github.com/floating-ui/floating-ui/discussions/1692\n function onScrollMouseLeave(event) {\n if (isClickLikeOpenEvent()) return;\n if (!dataRef.current.floatingContext) return;\n handleCloseRef.current == null || handleCloseRef.current({\n ...dataRef.current.floatingContext,\n tree,\n x: event.clientX,\n y: event.clientY,\n onClose() {\n clearPointerEvents();\n cleanupMouseMoveHandler();\n if (!isClickLikeOpenEvent()) {\n closeWithDelay(event);\n }\n }\n })(event);\n }\n function onFloatingMouseEnter() {\n clearTimeoutIfSet(timeoutRef);\n }\n function onFloatingMouseLeave(event) {\n if (!isClickLikeOpenEvent()) {\n closeWithDelay(event, false);\n }\n }\n if (isElement(elements.domReference)) {\n const reference = elements.domReference;\n const floating = elements.floating;\n if (open) {\n reference.addEventListener('mouseleave', onScrollMouseLeave);\n }\n if (move) {\n reference.addEventListener('mousemove', onReferenceMouseEnter, {\n once: true\n });\n }\n reference.addEventListener('mouseenter', onReferenceMouseEnter);\n reference.addEventListener('mouseleave', onReferenceMouseLeave);\n if (floating) {\n floating.addEventListener('mouseleave', onScrollMouseLeave);\n floating.addEventListener('mouseenter', onFloatingMouseEnter);\n floating.addEventListener('mouseleave', onFloatingMouseLeave);\n }\n return () => {\n if (open) {\n reference.removeEventListener('mouseleave', onScrollMouseLeave);\n }\n if (move) {\n reference.removeEventListener('mousemove', onReferenceMouseEnter);\n }\n reference.removeEventListener('mouseenter', onReferenceMouseEnter);\n reference.removeEventListener('mouseleave', onReferenceMouseLeave);\n if (floating) {\n floating.removeEventListener('mouseleave', onScrollMouseLeave);\n floating.removeEventListener('mouseenter', onFloatingMouseEnter);\n floating.removeEventListener('mouseleave', onFloatingMouseLeave);\n }\n };\n }\n }, [elements, enabled, context, mouseOnly, move, closeWithDelay, cleanupMouseMoveHandler, clearPointerEvents, onOpenChange, open, openRef, tree, delayRef, handleCloseRef, dataRef, isClickLikeOpenEvent, restMsRef]);\n\n // Block pointer-events of every element other than the reference and floating\n // while the floating element is open and has a `handleClose` handler. Also\n // handles nested floating elements.\n // https://github.com/floating-ui/floating-ui/issues/1722\n useModernLayoutEffect(() => {\n var _handleCloseRef$curre;\n if (!enabled) return;\n if (open && (_handleCloseRef$curre = handleCloseRef.current) != null && (_handleCloseRef$curre = _handleCloseRef$curre.__options) != null && _handleCloseRef$curre.blockPointerEvents && isHoverOpen()) {\n performedPointerEventsMutationRef.current = true;\n const floatingEl = elements.floating;\n if (isElement(elements.domReference) && floatingEl) {\n var _tree$nodesRef$curren;\n const body = getDocument$1(elements.floating).body;\n body.setAttribute(safePolygonIdentifier, '');\n const ref = elements.domReference;\n const parentFloating = tree == null || (_tree$nodesRef$curren = tree.nodesRef.current.find(node => node.id === parentId)) == null || (_tree$nodesRef$curren = _tree$nodesRef$curren.context) == null ? void 0 : _tree$nodesRef$curren.elements.floating;\n if (parentFloating) {\n parentFloating.style.pointerEvents = '';\n }\n body.style.pointerEvents = 'none';\n ref.style.pointerEvents = 'auto';\n floatingEl.style.pointerEvents = 'auto';\n return () => {\n body.style.pointerEvents = '';\n ref.style.pointerEvents = '';\n floatingEl.style.pointerEvents = '';\n };\n }\n }\n }, [enabled, open, parentId, elements, tree, handleCloseRef, isHoverOpen]);\n useModernLayoutEffect(() => {\n if (!open) {\n pointerTypeRef.current = undefined;\n restTimeoutPendingRef.current = false;\n cleanupMouseMoveHandler();\n clearPointerEvents();\n }\n }, [open, cleanupMouseMoveHandler, clearPointerEvents]);\n React.useEffect(() => {\n return () => {\n cleanupMouseMoveHandler();\n clearTimeoutIfSet(timeoutRef);\n clearTimeoutIfSet(restTimeoutRef);\n clearPointerEvents();\n };\n }, [enabled, elements.domReference, cleanupMouseMoveHandler, clearPointerEvents]);\n const reference = React.useMemo(() => {\n function setPointerRef(event) {\n pointerTypeRef.current = event.pointerType;\n }\n return {\n onPointerDown: setPointerRef,\n onPointerEnter: setPointerRef,\n onMouseMove(event) {\n const {\n nativeEvent\n } = event;\n function handleMouseMove() {\n if (!blockMouseMoveRef.current && !openRef.current) {\n onOpenChange(true, nativeEvent, 'hover');\n }\n }\n if (mouseOnly && !isMouseLikePointerType(pointerTypeRef.current)) {\n return;\n }\n if (open || getRestMs(restMsRef.current) === 0) {\n return;\n }\n\n // Ignore insignificant movements to account for tremors.\n if (restTimeoutPendingRef.current && event.movementX ** 2 + event.movementY ** 2 < 2) {\n return;\n }\n clearTimeoutIfSet(restTimeoutRef);\n if (pointerTypeRef.current === 'touch') {\n handleMouseMove();\n } else {\n restTimeoutPendingRef.current = true;\n restTimeoutRef.current = window.setTimeout(handleMouseMove, getRestMs(restMsRef.current));\n }\n }\n };\n }, [mouseOnly, onOpenChange, open, openRef, restMsRef]);\n return React.useMemo(() => enabled ? {\n reference\n } : {}, [enabled, reference]);\n}\n\nconst NOOP = () => {};\nconst FloatingDelayGroupContext = /*#__PURE__*/React.createContext({\n delay: 0,\n initialDelay: 0,\n timeoutMs: 0,\n currentId: null,\n setCurrentId: NOOP,\n setState: NOOP,\n isInstantPhase: false\n});\n\n/**\n * @deprecated\n * Use the return value of `useDelayGroup()` instead.\n */\nconst useDelayGroupContext = () => React.useContext(FloatingDelayGroupContext);\n/**\n * Provides context for a group of floating elements that should share a\n * `delay`.\n * @see https://floating-ui.com/docs/FloatingDelayGroup\n */\nfunction FloatingDelayGroup(props) {\n const {\n children,\n delay,\n timeoutMs = 0\n } = props;\n const [state, setState] = React.useReducer((prev, next) => ({\n ...prev,\n ...next\n }), {\n delay,\n timeoutMs,\n initialDelay: delay,\n currentId: null,\n isInstantPhase: false\n });\n const initialCurrentIdRef = React.useRef(null);\n const setCurrentId = React.useCallback(currentId => {\n setState({\n currentId\n });\n }, []);\n useModernLayoutEffect(() => {\n if (state.currentId) {\n if (initialCurrentIdRef.current === null) {\n initialCurrentIdRef.current = state.currentId;\n } else if (!state.isInstantPhase) {\n setState({\n isInstantPhase: true\n });\n }\n } else {\n if (state.isInstantPhase) {\n setState({\n isInstantPhase: false\n });\n }\n initialCurrentIdRef.current = null;\n }\n }, [state.currentId, state.isInstantPhase]);\n return /*#__PURE__*/jsx(FloatingDelayGroupContext.Provider, {\n value: React.useMemo(() => ({\n ...state,\n setState,\n setCurrentId\n }), [state, setCurrentId]),\n children: children\n });\n}\n/**\n * Enables grouping when called inside a component that's a child of a\n * `FloatingDelayGroup`.\n * @see https://floating-ui.com/docs/FloatingDelayGroup\n */\nfunction useDelayGroup(context, options) {\n if (options === void 0) {\n options = {};\n }\n const {\n open,\n onOpenChange,\n floatingId\n } = context;\n const {\n id: optionId,\n enabled = true\n } = options;\n const id = optionId != null ? optionId : floatingId;\n const groupContext = useDelayGroupContext();\n const {\n currentId,\n setCurrentId,\n initialDelay,\n setState,\n timeoutMs\n } = groupContext;\n useModernLayoutEffect(() => {\n if (!enabled) return;\n if (!currentId) return;\n setState({\n delay: {\n open: 1,\n close: getDelay(initialDelay, 'close')\n }\n });\n if (currentId !== id) {\n onOpenChange(false);\n }\n }, [enabled, id, onOpenChange, setState, currentId, initialDelay]);\n useModernLayoutEffect(() => {\n function unset() {\n onOpenChange(false);\n setState({\n delay: initialDelay,\n currentId: null\n });\n }\n if (!enabled) return;\n if (!currentId) return;\n if (!open && currentId === id) {\n if (timeoutMs) {\n const timeout = window.setTimeout(unset, timeoutMs);\n return () => {\n clearTimeout(timeout);\n };\n }\n unset();\n }\n }, [enabled, open, setState, currentId, id, onOpenChange, initialDelay, timeoutMs]);\n useModernLayoutEffect(() => {\n if (!enabled) return;\n if (setCurrentId === NOOP || !open) return;\n setCurrentId(id);\n }, [enabled, open, setCurrentId, id]);\n return groupContext;\n}\n\nconst NextFloatingDelayGroupContext = /*#__PURE__*/React.createContext({\n hasProvider: false,\n timeoutMs: 0,\n delayRef: {\n current: 0\n },\n initialDelayRef: {\n current: 0\n },\n timeoutIdRef: {\n current: -1\n },\n currentIdRef: {\n current: null\n },\n currentContextRef: {\n current: null\n }\n});\n/**\n * Experimental next version of `FloatingDelayGroup` to become the default\n * in the future. This component is not yet stable.\n * Provides context for a group of floating elements that should share a\n * `delay`. Unlike `FloatingDelayGroup`, `useNextDelayGroup` with this\n * component does not cause a re-render of unrelated consumers of the\n * context when the delay changes.\n * @see https://floating-ui.com/docs/FloatingDelayGroup\n */\nfunction NextFloatingDelayGroup(props) {\n const {\n children,\n delay,\n timeoutMs = 0\n } = props;\n const delayRef = React.useRef(delay);\n const initialDelayRef = React.useRef(delay);\n const currentIdRef = React.useRef(null);\n const currentContextRef = React.useRef(null);\n const timeoutIdRef = React.useRef(-1);\n return /*#__PURE__*/jsx(NextFloatingDelayGroupContext.Provider, {\n value: React.useMemo(() => ({\n hasProvider: true,\n delayRef,\n initialDelayRef,\n currentIdRef,\n timeoutMs,\n currentContextRef,\n timeoutIdRef\n }), [timeoutMs]),\n children: children\n });\n}\n/**\n * Enables grouping when called inside a component that's a child of a\n * `NextFloatingDelayGroup`.\n * @see https://floating-ui.com/docs/FloatingDelayGroup\n */\nfunction useNextDelayGroup(context, options) {\n if (options === void 0) {\n options = {};\n }\n const {\n open,\n onOpenChange,\n floatingId\n } = context;\n const {\n enabled = true\n } = options;\n const groupContext = React.useContext(NextFloatingDelayGroupContext);\n const {\n currentIdRef,\n delayRef,\n timeoutMs,\n initialDelayRef,\n currentContextRef,\n hasProvider,\n timeoutIdRef\n } = groupContext;\n const [isInstantPhase, setIsInstantPhase] = React.useState(false);\n useModernLayoutEffect(() => {\n function unset() {\n var _currentContextRef$cu;\n setIsInstantPhase(false);\n (_currentContextRef$cu = currentContextRef.current) == null || _currentContextRef$cu.setIsInstantPhase(false);\n currentIdRef.current = null;\n currentContextRef.current = null;\n delayRef.current = initialDelayRef.current;\n }\n if (!enabled) return;\n if (!currentIdRef.current) return;\n if (!open && currentIdRef.current === floatingId) {\n setIsInstantPhase(false);\n if (timeoutMs) {\n timeoutIdRef.current = window.setTimeout(unset, timeoutMs);\n return () => {\n clearTimeout(timeoutIdRef.current);\n };\n }\n unset();\n }\n }, [enabled, open, floatingId, currentIdRef, delayRef, timeoutMs, initialDelayRef, currentContextRef, timeoutIdRef]);\n useModernLayoutEffect(() => {\n if (!enabled) return;\n if (!open) return;\n const prevContext = currentContextRef.current;\n const prevId = currentIdRef.current;\n currentContextRef.current = {\n onOpenChange,\n setIsInstantPhase\n };\n currentIdRef.current = floatingId;\n delayRef.current = {\n open: 0,\n close: getDelay(initialDelayRef.current, 'close')\n };\n if (prevId !== null && prevId !== floatingId) {\n clearTimeoutIfSet(timeoutIdRef);\n setIsInstantPhase(true);\n prevContext == null || prevContext.setIsInstantPhase(true);\n prevContext == null || prevContext.onOpenChange(false);\n } else {\n setIsInstantPhase(false);\n prevContext == null || prevContext.setIsInstantPhase(false);\n }\n }, [enabled, open, floatingId, onOpenChange, currentIdRef, delayRef, timeoutMs, initialDelayRef, currentContextRef, timeoutIdRef]);\n useModernLayoutEffect(() => {\n return () => {\n currentContextRef.current = null;\n };\n }, [currentContextRef]);\n return React.useMemo(() => ({\n hasProvider,\n delayRef,\n isInstantPhase\n }), [hasProvider, delayRef, isInstantPhase]);\n}\n\nlet rafId = 0;\nfunction enqueueFocus(el, options) {\n if (options === void 0) {\n options = {};\n }\n const {\n preventScroll = false,\n cancelPrevious = true,\n sync = false\n } = options;\n cancelPrevious && cancelAnimationFrame(rafId);\n const exec = () => el == null ? void 0 : el.focus({\n preventScroll\n });\n if (sync) {\n exec();\n } else {\n rafId = requestAnimationFrame(exec);\n }\n}\n\nfunction contains(parent, child) {\n if (!parent || !child) {\n return false;\n }\n const rootNode = child.getRootNode == null ? void 0 : child.getRootNode();\n\n // First, attempt with faster native method\n if (parent.contains(child)) {\n return true;\n }\n\n // then fallback to custom implementation with Shadow DOM support\n if (rootNode && isShadowRoot(rootNode)) {\n let next = child;\n while (next) {\n if (parent === next) {\n return true;\n }\n // @ts-ignore\n next = next.parentNode || next.host;\n }\n }\n\n // Give up, the result is false\n return false;\n}\nfunction getTarget(event) {\n if ('composedPath' in event) {\n return event.composedPath()[0];\n }\n\n // TS thinks `event` is of type never as it assumes all browsers support\n // `composedPath()`, but browsers without shadow DOM don't.\n return event.target;\n}\nfunction getDocument(node) {\n return (node == null ? void 0 : node.ownerDocument) || document;\n}\n\n// Modified to add conditional `aria-hidden` support:\n// https://github.com/theKashey/aria-hidden/blob/9220c8f4a4fd35f63bee5510a9f41a37264382d4/src/index.ts\nconst counters = {\n inert: /*#__PURE__*/new WeakMap(),\n 'aria-hidden': /*#__PURE__*/new WeakMap(),\n none: /*#__PURE__*/new WeakMap()\n};\nfunction getCounterMap(control) {\n if (control === 'inert') return counters.inert;\n if (control === 'aria-hidden') return counters['aria-hidden'];\n return counters.none;\n}\nlet uncontrolledElementsSet = /*#__PURE__*/new WeakSet();\nlet markerMap = {};\nlet lockCount$1 = 0;\nconst supportsInert = () => typeof HTMLElement !== 'undefined' && 'inert' in HTMLElement.prototype;\nfunction unwrapHost(node) {\n if (!node) {\n return null;\n }\n return isShadowRoot(node) ? node.host : unwrapHost(node.parentNode);\n}\nconst correctElements = (parent, targets) => targets.map(target => {\n if (parent.contains(target)) {\n return target;\n }\n const correctedTarget = unwrapHost(target);\n if (parent.contains(correctedTarget)) {\n return correctedTarget;\n }\n return null;\n}).filter(x => x != null);\nfunction applyAttributeToOthers(uncorrectedAvoidElements, body, ariaHidden, inert) {\n const markerName = 'data-floating-ui-inert';\n const controlAttribute = inert ? 'inert' : ariaHidden ? 'aria-hidden' : null;\n const avoidElements = correctElements(body, uncorrectedAvoidElements);\n const elementsToKeep = new Set();\n const elementsToStop = new Set(avoidElements);\n const hiddenElements = [];\n if (!markerMap[markerName]) {\n markerMap[markerName] = new WeakMap();\n }\n const markerCounter = markerMap[markerName];\n avoidElements.forEach(keep);\n deep(body);\n elementsToKeep.clear();\n function keep(el) {\n if (!el || elementsToKeep.has(el)) {\n return;\n }\n elementsToKeep.add(el);\n el.parentNode && keep(el.parentNode);\n }\n function deep(parent) {\n if (!parent || elementsToStop.has(parent)) {\n return;\n }\n [].forEach.call(parent.children, node => {\n if (getNodeName(node) === 'script') return;\n if (elementsToKeep.has(node)) {\n deep(node);\n } else {\n const attr = controlAttribute ? node.getAttribute(controlAttribute) : null;\n const alreadyHidden = attr !== null && attr !== 'false';\n const counterMap = getCounterMap(controlAttribute);\n const counterValue = (counterMap.get(node) || 0) + 1;\n const markerValue = (markerCounter.get(node) || 0) + 1;\n counterMap.set(node, counterValue);\n markerCounter.set(node, markerValue);\n hiddenElements.push(node);\n if (counterValue === 1 && alreadyHidden) {\n uncontrolledElementsSet.add(node);\n }\n if (markerValue === 1) {\n node.setAttribute(markerName, '');\n }\n if (!alreadyHidden && controlAttribute) {\n node.setAttribute(controlAttribute, controlAttribute === 'inert' ? '' : 'true');\n }\n }\n });\n }\n lockCount$1++;\n return () => {\n hiddenElements.forEach(element => {\n const counterMap = getCounterMap(controlAttribute);\n const currentCounterValue = counterMap.get(element) || 0;\n const counterValue = currentCounterValue - 1;\n const markerValue = (markerCounter.get(element) || 0) - 1;\n counterMap.set(element, counterValue);\n markerCounter.set(element, markerValue);\n if (!counterValue) {\n if (!uncontrolledElementsSet.has(element) && controlAttribute) {\n element.removeAttribute(controlAttribute);\n }\n uncontrolledElementsSet.delete(element);\n }\n if (!markerValue) {\n element.removeAttribute(markerName);\n }\n });\n lockCount$1--;\n if (!lockCount$1) {\n counters.inert = new WeakMap();\n counters['aria-hidden'] = new WeakMap();\n counters.none = new WeakMap();\n uncontrolledElementsSet = new WeakSet();\n markerMap = {};\n }\n };\n}\nfunction markOthers(avoidElements, ariaHidden, inert) {\n if (ariaHidden === void 0) {\n ariaHidden = false;\n }\n if (inert === void 0) {\n inert = false;\n }\n const body = getDocument(avoidElements[0]).body;\n return applyAttributeToOthers(avoidElements.concat(Array.from(body.querySelectorAll('[aria-live],[role=\"status\"],output'))), body, ariaHidden, inert);\n}\n\nconst HIDDEN_STYLES = {\n border: 0,\n clip: 'rect(0 0 0 0)',\n height: '1px',\n margin: '-1px',\n overflow: 'hidden',\n padding: 0,\n position: 'fixed',\n whiteSpace: 'nowrap',\n width: '1px',\n top: 0,\n left: 0\n};\nconst FocusGuard = /*#__PURE__*/React.forwardRef(function FocusGuard(props, ref) {\n const [role, setRole] = React.useState();\n useModernLayoutEffect(() => {\n if (isSafari()) {\n // Unlike other screen readers such as NVDA and JAWS, the virtual cursor\n // on VoiceOver does trigger the onFocus event, so we can use the focus\n // trap element. On Safari, only buttons trigger the onFocus event.\n // NB: \"group\" role in the Sandbox no longer appears to work, must be a\n // button role.\n setRole('button');\n }\n }, []);\n const restProps = {\n ref,\n tabIndex: 0,\n // Role is only for VoiceOver\n role,\n 'aria-hidden': role ? undefined : true,\n [createAttribute('focus-guard')]: '',\n style: HIDDEN_STYLES\n };\n return /*#__PURE__*/jsx(\"span\", {\n ...props,\n ...restProps\n });\n});\n\nconst HIDDEN_OWNER_STYLES = {\n clipPath: 'inset(50%)',\n position: 'fixed',\n top: 0,\n left: 0\n};\nconst PortalContext = /*#__PURE__*/React.createContext(null);\nconst attr = /*#__PURE__*/createAttribute('portal');\n/**\n * @see https://floating-ui.com/docs/FloatingPortal#usefloatingportalnode\n */\nfunction useFloatingPortalNode(props) {\n if (props === void 0) {\n props = {};\n }\n const {\n id,\n root\n } = props;\n const uniqueId = useId();\n const portalContext = usePortalContext();\n const [portalNode, setPortalNode] = React.useState(null);\n const portalNodeRef = React.useRef(null);\n useModernLayoutEffect(() => {\n return () => {\n portalNode == null || portalNode.remove();\n // Allow the subsequent layout effects to create a new node on updates.\n // The portal node will still be cleaned up on unmount.\n // https://github.com/floating-ui/floating-ui/issues/2454\n queueMicrotask(() => {\n portalNodeRef.current = null;\n });\n };\n }, [portalNode]);\n useModernLayoutEffect(() => {\n // Wait for the uniqueId to be generated before creating the portal node in\n // React <18 (using `useFloatingId` instead of the native `useId`).\n // https://github.com/floating-ui/floating-ui/issues/2778\n if (!uniqueId) return;\n if (portalNodeRef.current) return;\n const existingIdRoot = id ? document.getElementById(id) : null;\n if (!existingIdRoot) return;\n const subRoot = document.createElement('div');\n subRoot.id = uniqueId;\n subRoot.setAttribute(attr, '');\n existingIdRoot.appendChild(subRoot);\n portalNodeRef.current = subRoot;\n setPortalNode(subRoot);\n }, [id, uniqueId]);\n useModernLayoutEffect(() => {\n // Wait for the root to exist before creating the portal node. The root must\n // be stored in state, not a ref, for this to work reactively.\n if (root === null) return;\n if (!uniqueId) return;\n if (portalNodeRef.current) return;\n let container = root || (portalContext == null ? void 0 : portalContext.portalNode);\n if (container && !isNode(container)) container = container.current;\n container = container || document.body;\n let idWrapper = null;\n if (id) {\n idWrapper = document.createElement('div');\n idWrapper.id = id;\n container.appendChild(idWrapper);\n }\n const subRoot = document.createElement('div');\n subRoot.id = uniqueId;\n subRoot.setAttribute(attr, '');\n container = idWrapper || container;\n container.appendChild(subRoot);\n portalNodeRef.current = subRoot;\n setPortalNode(subRoot);\n }, [id, root, uniqueId, portalContext]);\n return portalNode;\n}\n/**\n * Portals the floating element into a given container element — by default,\n * outside of the app root and into the body.\n * This is necessary to ensure the floating element can appear outside any\n * potential parent containers that cause clipping (such as `overflow: hidden`),\n * while retaining its location in the React tree.\n * @see https://floating-ui.com/docs/FloatingPortal\n */\nfunction FloatingPortal(props) {\n const {\n children,\n id,\n root,\n preserveTabOrder = true\n } = props;\n const portalNode = useFloatingPortalNode({\n id,\n root\n });\n const [focusManagerState, setFocusManagerState] = React.useState(null);\n const beforeOutsideRef = React.useRef(null);\n const afterOutsideRef = React.useRef(null);\n const beforeInsideRef = React.useRef(null);\n const afterInsideRef = React.useRef(null);\n const modal = focusManagerState == null ? void 0 : focusManagerState.modal;\n const open = focusManagerState == null ? void 0 : focusManagerState.open;\n const shouldRenderGuards =\n // The FocusManager and therefore floating element are currently open/\n // rendered.\n !!focusManagerState &&\n // Guards are only for non-modal focus management.\n !focusManagerState.modal &&\n // Don't render if unmount is transitioning.\n focusManagerState.open && preserveTabOrder && !!(root || portalNode);\n\n // https://codesandbox.io/s/tabbable-portal-f4tng?file=/src/TabbablePortal.tsx\n React.useEffect(() => {\n if (!portalNode || !preserveTabOrder || modal) {\n return;\n }\n\n // Make sure elements inside the portal element are tabbable only when the\n // portal has already been focused, either by tabbing into a focus trap\n // element outside or using the mouse.\n function onFocus(event) {\n if (portalNode && isOutsideEvent(event)) {\n const focusing = event.type === 'focusin';\n const manageFocus = focusing ? enableFocusInside : disableFocusInside;\n manageFocus(portalNode);\n }\n }\n // Listen to the event on the capture phase so they run before the focus\n // trap elements onFocus prop is called.\n portalNode.addEventListener('focusin', onFocus, true);\n portalNode.addEventListener('focusout', onFocus, true);\n return () => {\n portalNode.removeEventListener('focusin', onFocus, true);\n portalNode.removeEventListener('focusout', onFocus, true);\n };\n }, [portalNode, preserveTabOrder, modal]);\n React.useEffect(() => {\n if (!portalNode) return;\n if (open) return;\n enableFocusInside(portalNode);\n }, [open, portalNode]);\n return /*#__PURE__*/jsxs(PortalContext.Provider, {\n value: React.useMemo(() => ({\n preserveTabOrder,\n beforeOutsideRef,\n afterOutsideRef,\n beforeInsideRef,\n afterInsideRef,\n portalNode,\n setFocusManagerState\n }), [preserveTabOrder, portalNode]),\n children: [shouldRenderGuards && portalNode && /*#__PURE__*/jsx(FocusGuard, {\n \"data-type\": \"outside\",\n ref: beforeOutsideRef,\n onFocus: event => {\n if (isOutsideEvent(event, portalNode)) {\n var _beforeInsideRef$curr;\n (_beforeInsideRef$curr = beforeInsideRef.current) == null || _beforeInsideRef$curr.focus();\n } else {\n const domReference = focusManagerState ? focusManagerState.domReference : null;\n const prevTabbable = getPreviousTabbable(domReference);\n prevTabbable == null || prevTabbable.focus();\n }\n }\n }), shouldRenderGuards && portalNode && /*#__PURE__*/jsx(\"span\", {\n \"aria-owns\": portalNode.id,\n style: HIDDEN_OWNER_STYLES\n }), portalNode && /*#__PURE__*/ReactDOM.createPortal(children, portalNode), shouldRenderGuards && portalNode && /*#__PURE__*/jsx(FocusGuard, {\n \"data-type\": \"outside\",\n ref: afterOutsideRef,\n onFocus: event => {\n if (isOutsideEvent(event, portalNode)) {\n var _afterInsideRef$curre;\n (_afterInsideRef$curre = afterInsideRef.current) == null || _afterInsideRef$curre.focus();\n } else {\n const domReference = focusManagerState ? focusManagerState.domReference : null;\n const nextTabbable = getNextTabbable(domReference);\n nextTabbable == null || nextTabbable.focus();\n (focusManagerState == null ? void 0 : focusManagerState.closeOnFocusOut) && (focusManagerState == null ? void 0 : focusManagerState.onOpenChange(false, event.nativeEvent, 'focus-out'));\n }\n }\n })]\n });\n}\nconst usePortalContext = () => React.useContext(PortalContext);\n\nfunction useLiteMergeRefs(refs) {\n return React.useMemo(() => {\n return value => {\n refs.forEach(ref => {\n if (ref) {\n ref.current = value;\n }\n });\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, refs);\n}\n\nconst LIST_LIMIT = 20;\nlet previouslyFocusedElements = [];\nfunction clearDisconnectedPreviouslyFocusedElements() {\n previouslyFocusedElements = previouslyFocusedElements.filter(elementRef => {\n var _elementRef$deref;\n return (_elementRef$deref = elementRef.deref()) == null ? void 0 : _elementRef$deref.isConnected;\n });\n}\nfunction addPreviouslyFocusedElement(element) {\n clearDisconnectedPreviouslyFocusedElements();\n if (element && getNodeName(element) !== 'body') {\n previouslyFocusedElements.push(new WeakRef(element));\n if (previouslyFocusedElements.length > LIST_LIMIT) {\n previouslyFocusedElements = previouslyFocusedElements.slice(-LIST_LIMIT);\n }\n }\n}\nfunction getPreviouslyFocusedElement() {\n clearDisconnectedPreviouslyFocusedElements();\n const elementRef = previouslyFocusedElements[previouslyFocusedElements.length - 1];\n return elementRef == null ? void 0 : elementRef.deref();\n}\nfunction getFirstTabbableElement(container) {\n const tabbableOptions = getTabbableOptions();\n if (isTabbable(container, tabbableOptions)) {\n return container;\n }\n return tabbable(container, tabbableOptions)[0] || container;\n}\nfunction handleTabIndex(floatingFocusElement, orderRef) {\n var _floatingFocusElement;\n if (!orderRef.current.includes('floating') && !((_floatingFocusElement = floatingFocusElement.getAttribute('role')) != null && _floatingFocusElement.includes('dialog'))) {\n return;\n }\n const options = getTabbableOptions();\n const focusableElements = focusable(floatingFocusElement, options);\n const tabbableContent = focusableElements.filter(element => {\n const dataTabIndex = element.getAttribute('data-tabindex') || '';\n return isTabbable(element, options) || element.hasAttribute('data-tabindex') && !dataTabIndex.startsWith('-');\n });\n const tabIndex = floatingFocusElement.getAttribute('tabindex');\n if (orderRef.current.includes('floating') || tabbableContent.length === 0) {\n if (tabIndex !== '0') {\n floatingFocusElement.setAttribute('tabindex', '0');\n }\n } else if (tabIndex !== '-1' || floatingFocusElement.hasAttribute('data-tabindex') && floatingFocusElement.getAttribute('data-tabindex') !== '-1') {\n floatingFocusElement.setAttribute('tabindex', '-1');\n floatingFocusElement.setAttribute('data-tabindex', '-1');\n }\n}\nconst VisuallyHiddenDismiss = /*#__PURE__*/React.forwardRef(function VisuallyHiddenDismiss(props, ref) {\n return /*#__PURE__*/jsx(\"button\", {\n ...props,\n type: \"button\",\n ref: ref,\n tabIndex: -1,\n style: HIDDEN_STYLES\n });\n});\n/**\n * Provides focus management for the floating element.\n * @see https://floating-ui.com/docs/FloatingFocusManager\n */\nfunction FloatingFocusManager(props) {\n const {\n context,\n children,\n disabled = false,\n order = ['content'],\n guards: _guards = true,\n initialFocus = 0,\n returnFocus = true,\n restoreFocus = false,\n modal = true,\n visuallyHiddenDismiss = false,\n closeOnFocusOut = true,\n outsideElementsInert = false,\n getInsideElements: _getInsideElements = () => []\n } = props;\n const {\n open,\n onOpenChange,\n events,\n dataRef,\n elements: {\n domReference,\n floating\n }\n } = context;\n const getNodeId = useEffectEvent(() => {\n var _dataRef$current$floa;\n return (_dataRef$current$floa = dataRef.current.floatingContext) == null ? void 0 : _dataRef$current$floa.nodeId;\n });\n const getInsideElements = useEffectEvent(_getInsideElements);\n const ignoreInitialFocus = typeof initialFocus === 'number' && initialFocus < 0;\n // If the reference is a combobox and is typeable (e.g. input/textarea),\n // there are different focus semantics. The guards should not be rendered, but\n // aria-hidden should be applied to all nodes still. Further, the visually\n // hidden dismiss button should only appear at the end of the list, not the\n // start.\n const isUntrappedTypeableCombobox = isTypeableCombobox(domReference) && ignoreInitialFocus;\n\n // Force the guards to be rendered if the `inert` attribute is not supported.\n const inertSupported = supportsInert();\n const guards = inertSupported ? _guards : true;\n const useInert = !guards || inertSupported && outsideElementsInert;\n const orderRef = useLatestRef(order);\n const initialFocusRef = useLatestRef(initialFocus);\n const returnFocusRef = useLatestRef(returnFocus);\n const tree = useFloatingTree();\n const portalContext = usePortalContext();\n const startDismissButtonRef = React.useRef(null);\n const endDismissButtonRef = React.useRef(null);\n const preventReturnFocusRef = React.useRef(false);\n const isPointerDownRef = React.useRef(false);\n const tabbableIndexRef = React.useRef(-1);\n const blurTimeoutRef = React.useRef(-1);\n const isInsidePortal = portalContext != null;\n const floatingFocusElement = getFloatingFocusElement(floating);\n const getTabbableContent = useEffectEvent(function (container) {\n if (container === void 0) {\n container = floatingFocusElement;\n }\n return container ? tabbable(container, getTabbableOptions()) : [];\n });\n const getTabbableElements = useEffectEvent(container => {\n const content = getTabbableContent(container);\n return orderRef.current.map(type => {\n if (domReference && type === 'reference') {\n return domReference;\n }\n if (floatingFocusElement && type === 'floating') {\n return floatingFocusElement;\n }\n return content;\n }).filter(Boolean).flat();\n });\n React.useEffect(() => {\n if (disabled) return;\n if (!modal) return;\n function onKeyDown(event) {\n if (event.key === 'Tab') {\n // The focus guards have nothing to focus, so we need to stop the event.\n if (contains$1(floatingFocusElement, activeElement(getDocument$1(floatingFocusElement))) && getTabbableContent().length === 0 && !isUntrappedTypeableCombobox) {\n stopEvent(event);\n }\n const els = getTabbableElements();\n const target = getTarget$1(event);\n if (orderRef.current[0] === 'reference' && target === domReference) {\n stopEvent(event);\n if (event.shiftKey) {\n enqueueFocus(els[els.length - 1]);\n } else {\n enqueueFocus(els[1]);\n }\n }\n if (orderRef.current[1] === 'floating' && target === floatingFocusElement && event.shiftKey) {\n stopEvent(event);\n enqueueFocus(els[0]);\n }\n }\n }\n const doc = getDocument$1(floatingFocusElement);\n doc.addEventListener('keydown', onKeyDown);\n return () => {\n doc.removeEventListener('keydown', onKeyDown);\n };\n }, [disabled, domReference, floatingFocusElement, modal, orderRef, isUntrappedTypeableCombobox, getTabbableContent, getTabbableElements]);\n React.useEffect(() => {\n if (disabled) return;\n if (!floating) return;\n function handleFocusIn(event) {\n const target = getTarget$1(event);\n const tabbableContent = getTabbableContent();\n const tabbableIndex = tabbableContent.indexOf(target);\n if (tabbableIndex !== -1) {\n tabbableIndexRef.current = tabbableIndex;\n }\n }\n floating.addEventListener('focusin', handleFocusIn);\n return () => {\n floating.removeEventListener('focusin', handleFocusIn);\n };\n }, [disabled, floating, getTabbableContent]);\n React.useEffect(() => {\n if (disabled) return;\n if (!closeOnFocusOut) return;\n\n // In Safari, buttons lose focus when pressing them.\n function handlePointerDown() {\n isPointerDownRef.current = true;\n setTimeout(() => {\n isPointerDownRef.current = false;\n });\n }\n function handleFocusOutside(event) {\n const relatedTarget = event.relatedTarget;\n const currentTarget = event.currentTarget;\n const target = getTarget$1(event);\n queueMicrotask(() => {\n const nodeId = getNodeId();\n const movedToUnrelatedNode = !(contains$1(domReference, relatedTarget) || contains$1(floating, relatedTarget) || contains$1(relatedTarget, floating) || contains$1(portalContext == null ? void 0 : portalContext.portalNode, relatedTarget) || relatedTarget != null && relatedTarget.hasAttribute(createAttribute('focus-guard')) || tree && (getNodeChildren$1(tree.nodesRef.current, nodeId).find(node => {\n var _node$context, _node$context2;\n return contains$1((_node$context = node.context) == null ? void 0 : _node$context.elements.floating, relatedTarget) || contains$1((_node$context2 = node.context) == null ? void 0 : _node$context2.elements.domReference, relatedTarget);\n }) || getNodeAncestors(tree.nodesRef.current, nodeId).find(node => {\n var _node$context3, _node$context4, _node$context5;\n return [(_node$context3 = node.context) == null ? void 0 : _node$context3.elements.floating, getFloatingFocusElement((_node$context4 = node.context) == null ? void 0 : _node$context4.elements.floating)].includes(relatedTarget) || ((_node$context5 = node.context) == null ? void 0 : _node$context5.elements.domReference) === relatedTarget;\n })));\n if (currentTarget === domReference && floatingFocusElement) {\n handleTabIndex(floatingFocusElement, orderRef);\n }\n\n // Restore focus to the previous tabbable element index to prevent\n // focus from being lost outside the floating tree.\n if (restoreFocus && currentTarget !== domReference && !(target != null && target.isConnected) && activeElement(getDocument$1(floatingFocusElement)) === getDocument$1(floatingFocusElement).body) {\n // Let `FloatingPortal` effect knows that focus is still inside the\n // floating tree.\n if (isHTMLElement(floatingFocusElement)) {\n floatingFocusElement.focus();\n }\n const prevTabbableIndex = tabbableIndexRef.current;\n const tabbableContent = getTabbableContent();\n const nodeToFocus = tabbableContent[prevTabbableIndex] || tabbableContent[tabbableContent.length - 1] || floatingFocusElement;\n if (isHTMLElement(nodeToFocus)) {\n nodeToFocus.focus();\n }\n }\n\n // https://github.com/floating-ui/floating-ui/issues/3060\n if (dataRef.current.insideReactTree) {\n dataRef.current.insideReactTree = false;\n return;\n }\n\n // Focus did not move inside the floating tree, and there are no tabbable\n // portal guards to handle closing.\n if ((isUntrappedTypeableCombobox ? true : !modal) && relatedTarget && movedToUnrelatedNode && !isPointerDownRef.current &&\n // Fix React 18 Strict Mode returnFocus due to double rendering.\n relatedTarget !== getPreviouslyFocusedElement()) {\n preventReturnFocusRef.current = true;\n onOpenChange(false, event, 'focus-out');\n }\n });\n }\n const shouldHandleBlurCapture = Boolean(!tree && portalContext);\n function markInsideReactTree() {\n clearTimeoutIfSet(blurTimeoutRef);\n dataRef.current.insideReactTree = true;\n blurTimeoutRef.current = window.setTimeout(() => {\n dataRef.current.insideReactTree = false;\n });\n }\n if (floating && isHTMLElement(domReference)) {\n domReference.addEventListener('focusout', handleFocusOutside);\n domReference.addEventListener('pointerdown', handlePointerDown);\n floating.addEventListener('focusout', handleFocusOutside);\n if (shouldHandleBlurCapture) {\n floating.addEventListener('focusout', markInsideReactTree, true);\n }\n return () => {\n domReference.removeEventListener('focusout', handleFocusOutside);\n domReference.removeEventListener('pointerdown', handlePointerDown);\n floating.removeEventListener('focusout', handleFocusOutside);\n if (shouldHandleBlurCapture) {\n floating.removeEventListener('focusout', markInsideReactTree, true);\n }\n };\n }\n }, [disabled, domReference, floating, floatingFocusElement, modal, tree, portalContext, onOpenChange, closeOnFocusOut, restoreFocus, getTabbableContent, isUntrappedTypeableCombobox, getNodeId, orderRef, dataRef]);\n const beforeGuardRef = React.useRef(null);\n const afterGuardRef = React.useRef(null);\n const mergedBeforeGuardRef = useLiteMergeRefs([beforeGuardRef, portalContext == null ? void 0 : portalContext.beforeInsideRef]);\n const mergedAfterGuardRef = useLiteMergeRefs([afterGuardRef, portalContext == null ? void 0 : portalContext.afterInsideRef]);\n React.useEffect(() => {\n var _portalContext$portal, _ancestors$find;\n if (disabled) return;\n if (!floating) return;\n\n // Don't hide portals nested within the parent portal.\n const portalNodes = Array.from((portalContext == null || (_portalContext$portal = portalContext.portalNode) == null ? void 0 : _portalContext$portal.querySelectorAll(\"[\" + createAttribute('portal') + \"]\")) || []);\n const ancestors = tree ? getNodeAncestors(tree.nodesRef.current, getNodeId()) : [];\n const rootAncestorComboboxDomReference = (_ancestors$find = ancestors.find(node => {\n var _node$context6;\n return isTypeableCombobox(((_node$context6 = node.context) == null ? void 0 : _node$context6.elements.domReference) || null);\n })) == null || (_ancestors$find = _ancestors$find.context) == null ? void 0 : _ancestors$find.elements.domReference;\n const insideElements = [floating, rootAncestorComboboxDomReference, ...portalNodes, ...getInsideElements(), startDismissButtonRef.current, endDismissButtonRef.current, beforeGuardRef.current, afterGuardRef.current, portalContext == null ? void 0 : portalContext.beforeOutsideRef.current, portalContext == null ? void 0 : portalContext.afterOutsideRef.current, orderRef.current.includes('reference') || isUntrappedTypeableCombobox ? domReference : null].filter(x => x != null);\n const cleanup = modal || isUntrappedTypeableCombobox ? markOthers(insideElements, !useInert, useInert) : markOthers(insideElements);\n return () => {\n cleanup();\n };\n }, [disabled, domReference, floating, modal, orderRef, portalContext, isUntrappedTypeableCombobox, guards, useInert, tree, getNodeId, getInsideElements]);\n useModernLayoutEffect(() => {\n if (disabled || !isHTMLElement(floatingFocusElement)) return;\n const doc = getDocument$1(floatingFocusElement);\n const previouslyFocusedElement = activeElement(doc);\n\n // Wait for any layout effect state setters to execute to set `tabIndex`.\n queueMicrotask(() => {\n const focusableElements = getTabbableElements(floatingFocusElement);\n const initialFocusValue = initialFocusRef.current;\n const elToFocus = (typeof initialFocusValue === 'number' ? focusableElements[initialFocusValue] : initialFocusValue.current) || floatingFocusElement;\n const focusAlreadyInsideFloatingEl = contains$1(floatingFocusElement, previouslyFocusedElement);\n if (!ignoreInitialFocus && !focusAlreadyInsideFloatingEl && open) {\n enqueueFocus(elToFocus, {\n preventScroll: elToFocus === floatingFocusElement\n });\n }\n });\n }, [disabled, open, floatingFocusElement, ignoreInitialFocus, getTabbableElements, initialFocusRef]);\n useModernLayoutEffect(() => {\n if (disabled || !floatingFocusElement) return;\n const doc = getDocument$1(floatingFocusElement);\n const previouslyFocusedElement = activeElement(doc);\n addPreviouslyFocusedElement(previouslyFocusedElement);\n\n // Dismissing via outside press should always ignore `returnFocus` to\n // prevent unwanted scrolling.\n function onOpenChange(_ref) {\n let {\n reason,\n event,\n nested\n } = _ref;\n if (['hover', 'safe-polygon'].includes(reason) && event.type === 'mouseleave') {\n preventReturnFocusRef.current = true;\n }\n if (reason !== 'outside-press') return;\n if (nested) {\n preventReturnFocusRef.current = false;\n } else if (isVirtualClick(event) || isVirtualPointerEvent(event)) {\n preventReturnFocusRef.current = false;\n } else {\n let isPreventScrollSupported = false;\n document.createElement('div').focus({\n get preventScroll() {\n isPreventScrollSupported = true;\n return false;\n }\n });\n if (isPreventScrollSupported) {\n preventReturnFocusRef.current = false;\n } else {\n preventReturnFocusRef.current = true;\n }\n }\n }\n events.on('openchange', onOpenChange);\n const fallbackEl = doc.createElement('span');\n fallbackEl.setAttribute('tabindex', '-1');\n fallbackEl.setAttribute('aria-hidden', 'true');\n Object.assign(fallbackEl.style, HIDDEN_STYLES);\n if (isInsidePortal && domReference) {\n domReference.insertAdjacentElement('afterend', fallbackEl);\n }\n function getReturnElement() {\n if (typeof returnFocusRef.current === 'boolean') {\n const el = domReference || getPreviouslyFocusedElement();\n return el && el.isConnected ? el : fallbackEl;\n }\n return returnFocusRef.current.current || fallbackEl;\n }\n return () => {\n events.off('openchange', onOpenChange);\n const activeEl = activeElement(doc);\n const isFocusInsideFloatingTree = contains$1(floating, activeEl) || tree && getNodeChildren$1(tree.nodesRef.current, getNodeId(), false).some(node => {\n var _node$context7;\n return contains$1((_node$context7 = node.context) == null ? void 0 : _node$context7.elements.floating, activeEl);\n });\n const returnElement = getReturnElement();\n queueMicrotask(() => {\n // This is `returnElement`, if it's tabbable, or its first tabbable child.\n const tabbableReturnElement = getFirstTabbableElement(returnElement);\n if (\n // eslint-disable-next-line react-hooks/exhaustive-deps\n returnFocusRef.current && !preventReturnFocusRef.current && isHTMLElement(tabbableReturnElement) && (\n // If the focus moved somewhere else after mount, avoid returning focus\n // since it likely entered a different element which should be\n // respected: https://github.com/floating-ui/floating-ui/issues/2607\n tabbableReturnElement !== activeEl && activeEl !== doc.body ? isFocusInsideFloatingTree : true)) {\n tabbableReturnElement.focus({\n preventScroll: true\n });\n }\n fallbackEl.remove();\n });\n };\n }, [disabled, floating, floatingFocusElement, returnFocusRef, dataRef, events, tree, isInsidePortal, domReference, getNodeId]);\n React.useEffect(() => {\n // The `returnFocus` cleanup behavior is inside a microtask; ensure we\n // wait for it to complete before resetting the flag.\n queueMicrotask(() => {\n preventReturnFocusRef.current = false;\n });\n return () => {\n queueMicrotask(clearDisconnectedPreviouslyFocusedElements);\n };\n }, [disabled]);\n\n // Synchronize the `context` & `modal` value to the FloatingPortal context.\n // It will decide whether or not it needs to render its own guards.\n useModernLayoutEffect(() => {\n if (disabled) return;\n if (!portalContext) return;\n portalContext.setFocusManagerState({\n modal,\n closeOnFocusOut,\n open,\n onOpenChange,\n domReference\n });\n return () => {\n portalContext.setFocusManagerState(null);\n };\n }, [disabled, portalContext, modal, open, onOpenChange, closeOnFocusOut, domReference]);\n useModernLayoutEffect(() => {\n if (disabled) return;\n if (!floatingFocusElement) return;\n handleTabIndex(floatingFocusElement, orderRef);\n }, [disabled, floatingFocusElement, orderRef]);\n function renderDismissButton(location) {\n if (disabled || !visuallyHiddenDismiss || !modal) {\n return null;\n }\n return /*#__PURE__*/jsx(VisuallyHiddenDismiss, {\n ref: location === 'start' ? startDismissButtonRef : endDismissButtonRef,\n onClick: event => onOpenChange(false, event.nativeEvent),\n children: typeof visuallyHiddenDismiss === 'string' ? visuallyHiddenDismiss : 'Dismiss'\n });\n }\n const shouldRenderGuards = !disabled && guards && (modal ? !isUntrappedTypeableCombobox : true) && (isInsidePortal || modal);\n return /*#__PURE__*/jsxs(Fragment, {\n children: [shouldRenderGuards && /*#__PURE__*/jsx(FocusGuard, {\n \"data-type\": \"inside\",\n ref: mergedBeforeGuardRef,\n onFocus: event => {\n if (modal) {\n const els = getTabbableElements();\n enqueueFocus(order[0] === 'reference' ? els[0] : els[els.length - 1]);\n } else if (portalContext != null && portalContext.preserveTabOrder && portalContext.portalNode) {\n preventReturnFocusRef.current = false;\n if (isOutsideEvent(event, portalContext.portalNode)) {\n const nextTabbable = getNextTabbable(domReference);\n nextTabbable == null || nextTabbable.focus();\n } else {\n var _portalContext$before;\n (_portalContext$before = portalContext.beforeOutsideRef.current) == null || _portalContext$before.focus();\n }\n }\n }\n }), !isUntrappedTypeableCombobox && renderDismissButton('start'), children, renderDismissButton('end'), shouldRenderGuards && /*#__PURE__*/jsx(FocusGuard, {\n \"data-type\": \"inside\",\n ref: mergedAfterGuardRef,\n onFocus: event => {\n if (modal) {\n enqueueFocus(getTabbableElements()[0]);\n } else if (portalContext != null && portalContext.preserveTabOrder && portalContext.portalNode) {\n if (closeOnFocusOut) {\n preventReturnFocusRef.current = true;\n }\n if (isOutsideEvent(event, portalContext.portalNode)) {\n const prevTabbable = getPreviousTabbable(domReference);\n prevTabbable == null || prevTabbable.focus();\n } else {\n var _portalContext$afterO;\n (_portalContext$afterO = portalContext.afterOutsideRef.current) == null || _portalContext$afterO.focus();\n }\n }\n }\n })]\n });\n}\n\nlet lockCount = 0;\nconst scrollbarProperty = '--floating-ui-scrollbar-width';\nfunction enableScrollLock() {\n const platform = getPlatform();\n const isIOS = /iP(hone|ad|od)|iOS/.test(platform) ||\n // iPads can claim to be MacIntel\n platform === 'MacIntel' && navigator.maxTouchPoints > 1;\n const bodyStyle = document.body.style;\n // RTL <body> scrollbar\n const scrollbarX = Math.round(document.documentElement.getBoundingClientRect().left) + document.documentElement.scrollLeft;\n const paddingProp = scrollbarX ? 'paddingLeft' : 'paddingRight';\n const scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;\n const scrollX = bodyStyle.left ? parseFloat(bodyStyle.left) : window.scrollX;\n const scrollY = bodyStyle.top ? parseFloat(bodyStyle.top) : window.scrollY;\n bodyStyle.overflow = 'hidden';\n bodyStyle.setProperty(scrollbarProperty, scrollbarWidth + \"px\");\n if (scrollbarWidth) {\n bodyStyle[paddingProp] = scrollbarWidth + \"px\";\n }\n\n // Only iOS doesn't respect `overflow: hidden` on document.body, and this\n // technique has fewer side effects.\n if (isIOS) {\n var _window$visualViewpor, _window$visualViewpor2;\n // iOS 12 does not support `visualViewport`.\n const offsetLeft = ((_window$visualViewpor = window.visualViewport) == null ? void 0 : _window$visualViewpor.offsetLeft) || 0;\n const offsetTop = ((_window$visualViewpor2 = window.visualViewport) == null ? void 0 : _window$visualViewpor2.offsetTop) || 0;\n Object.assign(bodyStyle, {\n position: 'fixed',\n top: -(scrollY - Math.floor(offsetTop)) + \"px\",\n left: -(scrollX - Math.floor(offsetLeft)) + \"px\",\n right: '0'\n });\n }\n return () => {\n Object.assign(bodyStyle, {\n overflow: '',\n [paddingProp]: ''\n });\n bodyStyle.removeProperty(scrollbarProperty);\n if (isIOS) {\n Object.assign(bodyStyle, {\n position: '',\n top: '',\n left: '',\n right: ''\n });\n window.scrollTo(scrollX, scrollY);\n }\n };\n}\nlet cleanup = () => {};\n\n/**\n * Provides base styling for a fixed overlay element to dim content or block\n * pointer events behind a floating element.\n * It's a regular `<div>`, so it can be styled via any CSS solution you prefer.\n * @see https://floating-ui.com/docs/FloatingOverlay\n */\nconst FloatingOverlay = /*#__PURE__*/React.forwardRef(function FloatingOverlay(props, ref) {\n const {\n lockScroll = false,\n ...rest\n } = props;\n useModernLayoutEffect(() => {\n if (!lockScroll) return;\n lockCount++;\n if (lockCount === 1) {\n cleanup = enableScrollLock();\n }\n return () => {\n lockCount--;\n if (lockCount === 0) {\n cleanup();\n }\n };\n }, [lockScroll]);\n return /*#__PURE__*/jsx(\"div\", {\n ref: ref,\n ...rest,\n style: {\n position: 'fixed',\n overflow: 'auto',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n ...rest.style\n }\n });\n});\n\nfunction isButtonTarget(event) {\n return isHTMLElement(event.target) && event.target.tagName === 'BUTTON';\n}\nfunction isAnchorTarget(event) {\n return isHTMLElement(event.target) && event.target.tagName === 'A';\n}\nfunction isSpaceIgnored(element) {\n return isTypeableElement(element);\n}\n/**\n * Opens or closes the floating element when clicking the reference element.\n * @see https://floating-ui.com/docs/useClick\n */\nfunction useClick(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n onOpenChange,\n dataRef,\n elements: {\n domReference\n }\n } = context;\n const {\n enabled = true,\n event: eventOption = 'click',\n toggle = true,\n ignoreMouse = false,\n keyboardHandlers = true,\n stickIfOpen = true\n } = props;\n const pointerTypeRef = React.useRef();\n const didKeyDownRef = React.useRef(false);\n const reference = React.useMemo(() => ({\n onPointerDown(event) {\n pointerTypeRef.current = event.pointerType;\n },\n onMouseDown(event) {\n const pointerType = pointerTypeRef.current;\n\n // Ignore all buttons except for the \"main\" button.\n // https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/button\n if (event.button !== 0) return;\n if (eventOption === 'click') return;\n if (isMouseLikePointerType(pointerType, true) && ignoreMouse) return;\n if (open && toggle && (dataRef.current.openEvent && stickIfOpen ? dataRef.current.openEvent.type === 'mousedown' : true)) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n // Prevent stealing focus from the floating element\n event.preventDefault();\n onOpenChange(true, event.nativeEvent, 'click');\n }\n },\n onClick(event) {\n const pointerType = pointerTypeRef.current;\n if (eventOption === 'mousedown' && pointerTypeRef.current) {\n pointerTypeRef.current = undefined;\n return;\n }\n if (isMouseLikePointerType(pointerType, true) && ignoreMouse) return;\n if (open && toggle && (dataRef.current.openEvent && stickIfOpen ? dataRef.current.openEvent.type === 'click' : true)) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n onOpenChange(true, event.nativeEvent, 'click');\n }\n },\n onKeyDown(event) {\n pointerTypeRef.current = undefined;\n if (event.defaultPrevented || !keyboardHandlers || isButtonTarget(event)) {\n return;\n }\n if (event.key === ' ' && !isSpaceIgnored(domReference)) {\n // Prevent scrolling\n event.preventDefault();\n didKeyDownRef.current = true;\n }\n if (isAnchorTarget(event)) {\n return;\n }\n if (event.key === 'Enter') {\n if (open && toggle) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n onOpenChange(true, event.nativeEvent, 'click');\n }\n }\n },\n onKeyUp(event) {\n if (event.defaultPrevented || !keyboardHandlers || isButtonTarget(event) || isSpaceIgnored(domReference)) {\n return;\n }\n if (event.key === ' ' && didKeyDownRef.current) {\n didKeyDownRef.current = false;\n if (open && toggle) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n onOpenChange(true, event.nativeEvent, 'click');\n }\n }\n }\n }), [dataRef, domReference, eventOption, ignoreMouse, keyboardHandlers, onOpenChange, open, stickIfOpen, toggle]);\n return React.useMemo(() => enabled ? {\n reference\n } : {}, [enabled, reference]);\n}\n\nfunction createVirtualElement(domElement, data) {\n let offsetX = null;\n let offsetY = null;\n let isAutoUpdateEvent = false;\n return {\n contextElement: domElement || undefined,\n getBoundingClientRect() {\n var _data$dataRef$current;\n const domRect = (domElement == null ? void 0 : domElement.getBoundingClientRect()) || {\n width: 0,\n height: 0,\n x: 0,\n y: 0\n };\n const isXAxis = data.axis === 'x' || data.axis === 'both';\n const isYAxis = data.axis === 'y' || data.axis === 'both';\n const canTrackCursorOnAutoUpdate = ['mouseenter', 'mousemove'].includes(((_data$dataRef$current = data.dataRef.current.openEvent) == null ? void 0 : _data$dataRef$current.type) || '') && data.pointerType !== 'touch';\n let width = domRect.width;\n let height = domRect.height;\n let x = domRect.x;\n let y = domRect.y;\n if (offsetX == null && data.x && isXAxis) {\n offsetX = domRect.x - data.x;\n }\n if (offsetY == null && data.y && isYAxis) {\n offsetY = domRect.y - data.y;\n }\n x -= offsetX || 0;\n y -= offsetY || 0;\n width = 0;\n height = 0;\n if (!isAutoUpdateEvent || canTrackCursorOnAutoUpdate) {\n width = data.axis === 'y' ? domRect.width : 0;\n height = data.axis === 'x' ? domRect.height : 0;\n x = isXAxis && data.x != null ? data.x : x;\n y = isYAxis && data.y != null ? data.y : y;\n } else if (isAutoUpdateEvent && !canTrackCursorOnAutoUpdate) {\n height = data.axis === 'x' ? domRect.height : height;\n width = data.axis === 'y' ? domRect.width : width;\n }\n isAutoUpdateEvent = true;\n return {\n width,\n height,\n x,\n y,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x\n };\n }\n };\n}\nfunction isMouseBasedEvent(event) {\n return event != null && event.clientX != null;\n}\n/**\n * Positions the floating element relative to a client point (in the viewport),\n * such as the mouse position. By default, it follows the mouse cursor.\n * @see https://floating-ui.com/docs/useClientPoint\n */\nfunction useClientPoint(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n dataRef,\n elements: {\n floating,\n domReference\n },\n refs\n } = context;\n const {\n enabled = true,\n axis = 'both',\n x = null,\n y = null\n } = props;\n const initialRef = React.useRef(false);\n const cleanupListenerRef = React.useRef(null);\n const [pointerType, setPointerType] = React.useState();\n const [reactive, setReactive] = React.useState([]);\n const setReference = useEffectEvent((x, y) => {\n if (initialRef.current) return;\n\n // Prevent setting if the open event was not a mouse-like one\n // (e.g. focus to open, then hover over the reference element).\n // Only apply if the event exists.\n if (dataRef.current.openEvent && !isMouseBasedEvent(dataRef.current.openEvent)) {\n return;\n }\n refs.setPositionReference(createVirtualElement(domReference, {\n x,\n y,\n axis,\n dataRef,\n pointerType\n }));\n });\n const handleReferenceEnterOrMove = useEffectEvent(event => {\n if (x != null || y != null) return;\n if (!open) {\n setReference(event.clientX, event.clientY);\n } else if (!cleanupListenerRef.current) {\n // If there's no cleanup, there's no listener, but we want to ensure\n // we add the listener if the cursor landed on the floating element and\n // then back on the reference (i.e. it's interactive).\n setReactive([]);\n }\n });\n\n // If the pointer is a mouse-like pointer, we want to continue following the\n // mouse even if the floating element is transitioning out. On touch\n // devices, this is undesirable because the floating element will move to\n // the dismissal touch point.\n const openCheck = isMouseLikePointerType(pointerType) ? floating : open;\n const addListener = React.useCallback(() => {\n // Explicitly specified `x`/`y` coordinates shouldn't add a listener.\n if (!openCheck || !enabled || x != null || y != null) return;\n const win = getWindow(floating);\n function handleMouseMove(event) {\n const target = getTarget$1(event);\n if (!contains$1(floating, target)) {\n setReference(event.clientX, event.clientY);\n } else {\n win.removeEventListener('mousemove', handleMouseMove);\n cleanupListenerRef.current = null;\n }\n }\n if (!dataRef.current.openEvent || isMouseBasedEvent(dataRef.current.openEvent)) {\n win.addEventListener('mousemove', handleMouseMove);\n const cleanup = () => {\n win.removeEventListener('mousemove', handleMouseMove);\n cleanupListenerRef.current = null;\n };\n cleanupListenerRef.current = cleanup;\n return cleanup;\n }\n refs.setPositionReference(domReference);\n }, [openCheck, enabled, x, y, floating, dataRef, refs, domReference, setReference]);\n React.useEffect(() => {\n return addListener();\n }, [addListener, reactive]);\n React.useEffect(() => {\n if (enabled && !floating) {\n initialRef.current = false;\n }\n }, [enabled, floating]);\n React.useEffect(() => {\n if (!enabled && open) {\n initialRef.current = true;\n }\n }, [enabled, open]);\n useModernLayoutEffect(() => {\n if (enabled && (x != null || y != null)) {\n initialRef.current = false;\n setReference(x, y);\n }\n }, [enabled, x, y, setReference]);\n const reference = React.useMemo(() => {\n function setPointerTypeRef(_ref) {\n let {\n pointerType\n } = _ref;\n setPointerType(pointerType);\n }\n return {\n onPointerDown: setPointerTypeRef,\n onPointerEnter: setPointerTypeRef,\n onMouseMove: handleReferenceEnterOrMove,\n onMouseEnter: handleReferenceEnterOrMove\n };\n }, [handleReferenceEnterOrMove]);\n return React.useMemo(() => enabled ? {\n reference\n } : {}, [enabled, reference]);\n}\n\nconst bubbleHandlerKeys = {\n pointerdown: 'onPointerDown',\n mousedown: 'onMouseDown',\n click: 'onClick'\n};\nconst captureHandlerKeys = {\n pointerdown: 'onPointerDownCapture',\n mousedown: 'onMouseDownCapture',\n click: 'onClickCapture'\n};\nconst normalizeProp = normalizable => {\n var _normalizable$escapeK, _normalizable$outside;\n return {\n escapeKey: typeof normalizable === 'boolean' ? normalizable : (_normalizable$escapeK = normalizable == null ? void 0 : normalizable.escapeKey) != null ? _normalizable$escapeK : false,\n outsidePress: typeof normalizable === 'boolean' ? normalizable : (_normalizable$outside = normalizable == null ? void 0 : normalizable.outsidePress) != null ? _normalizable$outside : true\n };\n};\n/**\n * Closes the floating element when a dismissal is requested — by default, when\n * the user presses the `escape` key or outside of the floating element.\n * @see https://floating-ui.com/docs/useDismiss\n */\nfunction useDismiss(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n onOpenChange,\n elements,\n dataRef\n } = context;\n const {\n enabled = true,\n escapeKey = true,\n outsidePress: unstable_outsidePress = true,\n outsidePressEvent = 'pointerdown',\n referencePress = false,\n referencePressEvent = 'pointerdown',\n ancestorScroll = false,\n bubbles,\n capture\n } = props;\n const tree = useFloatingTree();\n const outsidePressFn = useEffectEvent(typeof unstable_outsidePress === 'function' ? unstable_outsidePress : () => false);\n const outsidePress = typeof unstable_outsidePress === 'function' ? outsidePressFn : unstable_outsidePress;\n const endedOrStartedInsideRef = React.useRef(false);\n const {\n escapeKey: escapeKeyBubbles,\n outsidePress: outsidePressBubbles\n } = normalizeProp(bubbles);\n const {\n escapeKey: escapeKeyCapture,\n outsidePress: outsidePressCapture\n } = normalizeProp(capture);\n const isComposingRef = React.useRef(false);\n const closeOnEscapeKeyDown = useEffectEvent(event => {\n var _dataRef$current$floa;\n if (!open || !enabled || !escapeKey || event.key !== 'Escape') {\n return;\n }\n\n // Wait until IME is settled. Pressing `Escape` while composing should\n // close the compose menu, but not the floating element.\n if (isComposingRef.current) {\n return;\n }\n const nodeId = (_dataRef$current$floa = dataRef.current.floatingContext) == null ? void 0 : _dataRef$current$floa.nodeId;\n const children = tree ? getNodeChildren$1(tree.nodesRef.current, nodeId) : [];\n if (!escapeKeyBubbles) {\n event.stopPropagation();\n if (children.length > 0) {\n let shouldDismiss = true;\n children.forEach(child => {\n var _child$context;\n if ((_child$context = child.context) != null && _child$context.open && !child.context.dataRef.current.__escapeKeyBubbles) {\n shouldDismiss = false;\n return;\n }\n });\n if (!shouldDismiss) {\n return;\n }\n }\n }\n onOpenChange(false, isReactEvent(event) ? event.nativeEvent : event, 'escape-key');\n });\n const closeOnEscapeKeyDownCapture = useEffectEvent(event => {\n var _getTarget2;\n const callback = () => {\n var _getTarget;\n closeOnEscapeKeyDown(event);\n (_getTarget = getTarget$1(event)) == null || _getTarget.removeEventListener('keydown', callback);\n };\n (_getTarget2 = getTarget$1(event)) == null || _getTarget2.addEventListener('keydown', callback);\n });\n const closeOnPressOutside = useEffectEvent(event => {\n var _dataRef$current$floa2;\n // Given developers can stop the propagation of the synthetic event,\n // we can only be confident with a positive value.\n const insideReactTree = dataRef.current.insideReactTree;\n dataRef.current.insideReactTree = false;\n\n // When click outside is lazy (`click` event), handle dragging.\n // Don't close if:\n // - The click started inside the floating element.\n // - The click ended inside the floating element.\n const endedOrStartedInside = endedOrStartedInsideRef.current;\n endedOrStartedInsideRef.current = false;\n if (outsidePressEvent === 'click' && endedOrStartedInside) {\n return;\n }\n if (insideReactTree) {\n return;\n }\n if (typeof outsidePress === 'function' && !outsidePress(event)) {\n return;\n }\n const target = getTarget$1(event);\n const inertSelector = \"[\" + createAttribute('inert') + \"]\";\n const markers = getDocument$1(elements.floating).querySelectorAll(inertSelector);\n let targetRootAncestor = isElement(target) ? target : null;\n while (targetRootAncestor && !isLastTraversableNode(targetRootAncestor)) {\n const nextParent = getParentNode(targetRootAncestor);\n if (isLastTraversableNode(nextParent) || !isElement(nextParent)) {\n break;\n }\n targetRootAncestor = nextParent;\n }\n\n // Check if the click occurred on a third-party element injected after the\n // floating element rendered.\n if (markers.length && isElement(target) && !isRootElement(target) &&\n // Clicked on a direct ancestor (e.g. FloatingOverlay).\n !contains$1(target, elements.floating) &&\n // If the target root element contains none of the markers, then the\n // element was injected after the floating element rendered.\n Array.from(markers).every(marker => !contains$1(targetRootAncestor, marker))) {\n return;\n }\n\n // Check if the click occurred on the scrollbar\n if (isHTMLElement(target) && floating) {\n const lastTraversableNode = isLastTraversableNode(target);\n const style = getComputedStyle(target);\n const scrollRe = /auto|scroll/;\n const isScrollableX = lastTraversableNode || scrollRe.test(style.overflowX);\n const isScrollableY = lastTraversableNode || scrollRe.test(style.overflowY);\n const canScrollX = isScrollableX && target.clientWidth > 0 && target.scrollWidth > target.clientWidth;\n const canScrollY = isScrollableY && target.clientHeight > 0 && target.scrollHeight > target.clientHeight;\n const isRTL = style.direction === 'rtl';\n\n // Check click position relative to scrollbar.\n // In some browsers it is possible to change the <body> (or window)\n // scrollbar to the left side, but is very rare and is difficult to\n // check for. Plus, for modal dialogs with backdrops, it is more\n // important that the backdrop is checked but not so much the window.\n const pressedVerticalScrollbar = canScrollY && (isRTL ? event.offsetX <= target.offsetWidth - target.clientWidth : event.offsetX > target.clientWidth);\n const pressedHorizontalScrollbar = canScrollX && event.offsetY > target.clientHeight;\n if (pressedVerticalScrollbar || pressedHorizontalScrollbar) {\n return;\n }\n }\n const nodeId = (_dataRef$current$floa2 = dataRef.current.floatingContext) == null ? void 0 : _dataRef$current$floa2.nodeId;\n const targetIsInsideChildren = tree && getNodeChildren$1(tree.nodesRef.current, nodeId).some(node => {\n var _node$context;\n return isEventTargetWithin(event, (_node$context = node.context) == null ? void 0 : _node$context.elements.floating);\n });\n if (isEventTargetWithin(event, elements.floating) || isEventTargetWithin(event, elements.domReference) || targetIsInsideChildren) {\n return;\n }\n const children = tree ? getNodeChildren$1(tree.nodesRef.current, nodeId) : [];\n if (children.length > 0) {\n let shouldDismiss = true;\n children.forEach(child => {\n var _child$context2;\n if ((_child$context2 = child.context) != null && _child$context2.open && !child.context.dataRef.current.__outsidePressBubbles) {\n shouldDismiss = false;\n return;\n }\n });\n if (!shouldDismiss) {\n return;\n }\n }\n onOpenChange(false, event, 'outside-press');\n });\n const closeOnPressOutsideCapture = useEffectEvent(event => {\n var _getTarget4;\n const callback = () => {\n var _getTarget3;\n closeOnPressOutside(event);\n (_getTarget3 = getTarget$1(event)) == null || _getTarget3.removeEventListener(outsidePressEvent, callback);\n };\n (_getTarget4 = getTarget$1(event)) == null || _getTarget4.addEventListener(outsidePressEvent, callback);\n });\n React.useEffect(() => {\n if (!open || !enabled) {\n return;\n }\n dataRef.current.__escapeKeyBubbles = escapeKeyBubbles;\n dataRef.current.__outsidePressBubbles = outsidePressBubbles;\n let compositionTimeout = -1;\n function onScroll(event) {\n onOpenChange(false, event, 'ancestor-scroll');\n }\n function handleCompositionStart() {\n window.clearTimeout(compositionTimeout);\n isComposingRef.current = true;\n }\n function handleCompositionEnd() {\n // Safari fires `compositionend` before `keydown`, so we need to wait\n // until the next tick to set `isComposing` to `false`.\n // https://bugs.webkit.org/show_bug.cgi?id=165004\n compositionTimeout = window.setTimeout(() => {\n isComposingRef.current = false;\n },\n // 0ms or 1ms don't work in Safari. 5ms appears to consistently work.\n // Only apply to WebKit for the test to remain 0ms.\n isWebKit() ? 5 : 0);\n }\n const doc = getDocument$1(elements.floating);\n if (escapeKey) {\n doc.addEventListener('keydown', escapeKeyCapture ? closeOnEscapeKeyDownCapture : closeOnEscapeKeyDown, escapeKeyCapture);\n doc.addEventListener('compositionstart', handleCompositionStart);\n doc.addEventListener('compositionend', handleCompositionEnd);\n }\n outsidePress && doc.addEventListener(outsidePressEvent, outsidePressCapture ? closeOnPressOutsideCapture : closeOnPressOutside, outsidePressCapture);\n let ancestors = [];\n if (ancestorScroll) {\n if (isElement(elements.domReference)) {\n ancestors = getOverflowAncestors(elements.domReference);\n }\n if (isElement(elements.floating)) {\n ancestors = ancestors.concat(getOverflowAncestors(elements.floating));\n }\n if (!isElement(elements.reference) && elements.reference && elements.reference.contextElement) {\n ancestors = ancestors.concat(getOverflowAncestors(elements.reference.contextElement));\n }\n }\n\n // Ignore the visual viewport for scrolling dismissal (allow pinch-zoom)\n ancestors = ancestors.filter(ancestor => {\n var _doc$defaultView;\n return ancestor !== ((_doc$defaultView = doc.defaultView) == null ? void 0 : _doc$defaultView.visualViewport);\n });\n ancestors.forEach(ancestor => {\n ancestor.addEventListener('scroll', onScroll, {\n passive: true\n });\n });\n return () => {\n if (escapeKey) {\n doc.removeEventListener('keydown', escapeKeyCapture ? closeOnEscapeKeyDownCapture : closeOnEscapeKeyDown, escapeKeyCapture);\n doc.removeEventListener('compositionstart', handleCompositionStart);\n doc.removeEventListener('compositionend', handleCompositionEnd);\n }\n outsidePress && doc.removeEventListener(outsidePressEvent, outsidePressCapture ? closeOnPressOutsideCapture : closeOnPressOutside, outsidePressCapture);\n ancestors.forEach(ancestor => {\n ancestor.removeEventListener('scroll', onScroll);\n });\n window.clearTimeout(compositionTimeout);\n };\n }, [dataRef, elements, escapeKey, outsidePress, outsidePressEvent, open, onOpenChange, ancestorScroll, enabled, escapeKeyBubbles, outsidePressBubbles, closeOnEscapeKeyDown, escapeKeyCapture, closeOnEscapeKeyDownCapture, closeOnPressOutside, outsidePressCapture, closeOnPressOutsideCapture]);\n React.useEffect(() => {\n dataRef.current.insideReactTree = false;\n }, [dataRef, outsidePress, outsidePressEvent]);\n const reference = React.useMemo(() => ({\n onKeyDown: closeOnEscapeKeyDown,\n ...(referencePress && {\n [bubbleHandlerKeys[referencePressEvent]]: event => {\n onOpenChange(false, event.nativeEvent, 'reference-press');\n },\n ...(referencePressEvent !== 'click' && {\n onClick(event) {\n onOpenChange(false, event.nativeEvent, 'reference-press');\n }\n })\n })\n }), [closeOnEscapeKeyDown, onOpenChange, referencePress, referencePressEvent]);\n const floating = React.useMemo(() => {\n function setMouseDownOrUpInside(event) {\n if (event.button !== 0) {\n return;\n }\n endedOrStartedInsideRef.current = true;\n }\n return {\n onKeyDown: closeOnEscapeKeyDown,\n onMouseDown: setMouseDownOrUpInside,\n onMouseUp: setMouseDownOrUpInside,\n [captureHandlerKeys[outsidePressEvent]]: () => {\n dataRef.current.insideReactTree = true;\n }\n };\n }, [closeOnEscapeKeyDown, outsidePressEvent, dataRef]);\n return React.useMemo(() => enabled ? {\n reference,\n floating\n } : {}, [enabled, reference, floating]);\n}\n\nfunction useFloatingRootContext(options) {\n const {\n open = false,\n onOpenChange: onOpenChangeProp,\n elements: elementsProp\n } = options;\n const floatingId = useId();\n const dataRef = React.useRef({});\n const [events] = React.useState(() => createEventEmitter());\n const nested = useFloatingParentNodeId() != null;\n if (process.env.NODE_ENV !== \"production\") {\n const optionDomReference = elementsProp.reference;\n if (optionDomReference && !isElement(optionDomReference)) {\n error('Cannot pass a virtual element to the `elements.reference` option,', 'as it must be a real DOM element. Use `refs.setPositionReference()`', 'instead.');\n }\n }\n const [positionReference, setPositionReference] = React.useState(elementsProp.reference);\n const onOpenChange = useEffectEvent((open, event, reason) => {\n dataRef.current.openEvent = open ? event : undefined;\n events.emit('openchange', {\n open,\n event,\n reason,\n nested\n });\n onOpenChangeProp == null || onOpenChangeProp(open, event, reason);\n });\n const refs = React.useMemo(() => ({\n setPositionReference\n }), []);\n const elements = React.useMemo(() => ({\n reference: positionReference || elementsProp.reference || null,\n floating: elementsProp.floating || null,\n domReference: elementsProp.reference\n }), [positionReference, elementsProp.reference, elementsProp.floating]);\n return React.useMemo(() => ({\n dataRef,\n open,\n onOpenChange,\n elements,\n events,\n floatingId,\n refs\n }), [open, onOpenChange, elements, events, floatingId, refs]);\n}\n\n/**\n * Provides data to position a floating element and context to add interactions.\n * @see https://floating-ui.com/docs/useFloating\n */\nfunction useFloating(options) {\n if (options === void 0) {\n options = {};\n }\n const {\n nodeId\n } = options;\n const internalRootContext = useFloatingRootContext({\n ...options,\n elements: {\n reference: null,\n floating: null,\n ...options.elements\n }\n });\n const rootContext = options.rootContext || internalRootContext;\n const computedElements = rootContext.elements;\n const [_domReference, setDomReference] = React.useState(null);\n const [positionReference, _setPositionReference] = React.useState(null);\n const optionDomReference = computedElements == null ? void 0 : computedElements.domReference;\n const domReference = optionDomReference || _domReference;\n const domReferenceRef = React.useRef(null);\n const tree = useFloatingTree();\n useModernLayoutEffect(() => {\n if (domReference) {\n domReferenceRef.current = domReference;\n }\n }, [domReference]);\n const position = useFloating$1({\n ...options,\n elements: {\n ...computedElements,\n ...(positionReference && {\n reference: positionReference\n })\n }\n });\n const setPositionReference = React.useCallback(node => {\n const computedPositionReference = isElement(node) ? {\n getBoundingClientRect: () => node.getBoundingClientRect(),\n getClientRects: () => node.getClientRects(),\n contextElement: node\n } : node;\n // Store the positionReference in state if the DOM reference is specified externally via the\n // `elements.reference` option. This ensures that it won't be overridden on future renders.\n _setPositionReference(computedPositionReference);\n position.refs.setReference(computedPositionReference);\n }, [position.refs]);\n const setReference = React.useCallback(node => {\n if (isElement(node) || node === null) {\n domReferenceRef.current = node;\n setDomReference(node);\n }\n\n // Backwards-compatibility for passing a virtual element to `reference`\n // after it has set the DOM reference.\n if (isElement(position.refs.reference.current) || position.refs.reference.current === null ||\n // Don't allow setting virtual elements using the old technique back to\n // `null` to support `positionReference` + an unstable `reference`\n // callback ref.\n node !== null && !isElement(node)) {\n position.refs.setReference(node);\n }\n }, [position.refs]);\n const refs = React.useMemo(() => ({\n ...position.refs,\n setReference,\n setPositionReference,\n domReference: domReferenceRef\n }), [position.refs, setReference, setPositionReference]);\n const elements = React.useMemo(() => ({\n ...position.elements,\n domReference: domReference\n }), [position.elements, domReference]);\n const context = React.useMemo(() => ({\n ...position,\n ...rootContext,\n refs,\n elements,\n nodeId\n }), [position, refs, elements, nodeId, rootContext]);\n useModernLayoutEffect(() => {\n rootContext.dataRef.current.floatingContext = context;\n const node = tree == null ? void 0 : tree.nodesRef.current.find(node => node.id === nodeId);\n if (node) {\n node.context = context;\n }\n });\n return React.useMemo(() => ({\n ...position,\n context,\n refs,\n elements\n }), [position, refs, elements, context]);\n}\n\nfunction isMacSafari() {\n return isMac() && isSafari();\n}\n/**\n * Opens the floating element while the reference element has focus, like CSS\n * `:focus`.\n * @see https://floating-ui.com/docs/useFocus\n */\nfunction useFocus(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n onOpenChange,\n events,\n dataRef,\n elements\n } = context;\n const {\n enabled = true,\n visibleOnly = true\n } = props;\n const blockFocusRef = React.useRef(false);\n const timeoutRef = React.useRef(-1);\n const keyboardModalityRef = React.useRef(true);\n React.useEffect(() => {\n if (!enabled) return;\n const win = getWindow(elements.domReference);\n\n // If the reference was focused and the user left the tab/window, and the\n // floating element was not open, the focus should be blocked when they\n // return to the tab/window.\n function onBlur() {\n if (!open && isHTMLElement(elements.domReference) && elements.domReference === activeElement(getDocument$1(elements.domReference))) {\n blockFocusRef.current = true;\n }\n }\n function onKeyDown() {\n keyboardModalityRef.current = true;\n }\n function onPointerDown() {\n keyboardModalityRef.current = false;\n }\n win.addEventListener('blur', onBlur);\n if (isMacSafari()) {\n win.addEventListener('keydown', onKeyDown, true);\n win.addEventListener('pointerdown', onPointerDown, true);\n }\n return () => {\n win.removeEventListener('blur', onBlur);\n if (isMacSafari()) {\n win.removeEventListener('keydown', onKeyDown, true);\n win.removeEventListener('pointerdown', onPointerDown, true);\n }\n };\n }, [elements.domReference, open, enabled]);\n React.useEffect(() => {\n if (!enabled) return;\n function onOpenChange(_ref) {\n let {\n reason\n } = _ref;\n if (reason === 'reference-press' || reason === 'escape-key') {\n blockFocusRef.current = true;\n }\n }\n events.on('openchange', onOpenChange);\n return () => {\n events.off('openchange', onOpenChange);\n };\n }, [events, enabled]);\n React.useEffect(() => {\n return () => {\n clearTimeoutIfSet(timeoutRef);\n };\n }, []);\n const reference = React.useMemo(() => ({\n onMouseLeave() {\n blockFocusRef.current = false;\n },\n onFocus(event) {\n if (blockFocusRef.current) return;\n const target = getTarget$1(event.nativeEvent);\n if (visibleOnly && isElement(target)) {\n // Safari fails to match `:focus-visible` if focus was initially\n // outside the document.\n if (isMacSafari() && !event.relatedTarget) {\n if (!keyboardModalityRef.current && !isTypeableElement(target)) {\n return;\n }\n } else if (!matchesFocusVisible(target)) {\n return;\n }\n }\n onOpenChange(true, event.nativeEvent, 'focus');\n },\n onBlur(event) {\n blockFocusRef.current = false;\n const relatedTarget = event.relatedTarget;\n const nativeEvent = event.nativeEvent;\n\n // Hit the non-modal focus management portal guard. Focus will be\n // moved into the floating element immediately after.\n const movedToFocusGuard = isElement(relatedTarget) && relatedTarget.hasAttribute(createAttribute('focus-guard')) && relatedTarget.getAttribute('data-type') === 'outside';\n\n // Wait for the window blur listener to fire.\n timeoutRef.current = window.setTimeout(() => {\n var _dataRef$current$floa;\n const activeEl = activeElement(elements.domReference ? elements.domReference.ownerDocument : document);\n\n // Focus left the page, keep it open.\n if (!relatedTarget && activeEl === elements.domReference) return;\n\n // When focusing the reference element (e.g. regular click), then\n // clicking into the floating element, prevent it from hiding.\n // Note: it must be focusable, e.g. `tabindex=\"-1\"`.\n // We can not rely on relatedTarget to point to the correct element\n // as it will only point to the shadow host of the newly focused element\n // and not the element that actually has received focus if it is located\n // inside a shadow root.\n if (contains$1((_dataRef$current$floa = dataRef.current.floatingContext) == null ? void 0 : _dataRef$current$floa.refs.floating.current, activeEl) || contains$1(elements.domReference, activeEl) || movedToFocusGuard) {\n return;\n }\n onOpenChange(false, nativeEvent, 'focus');\n });\n }\n }), [dataRef, elements.domReference, onOpenChange, visibleOnly]);\n return React.useMemo(() => enabled ? {\n reference\n } : {}, [enabled, reference]);\n}\n\nfunction mergeProps(userProps, propsList, elementKey) {\n const map = new Map();\n const isItem = elementKey === 'item';\n let domUserProps = userProps;\n if (isItem && userProps) {\n const {\n [ACTIVE_KEY]: _,\n [SELECTED_KEY]: __,\n ...validProps\n } = userProps;\n domUserProps = validProps;\n }\n return {\n ...(elementKey === 'floating' && {\n tabIndex: -1,\n [FOCUSABLE_ATTRIBUTE]: ''\n }),\n ...domUserProps,\n ...propsList.map(value => {\n const propsOrGetProps = value ? value[elementKey] : null;\n if (typeof propsOrGetProps === 'function') {\n return userProps ? propsOrGetProps(userProps) : null;\n }\n return propsOrGetProps;\n }).concat(userProps).reduce((acc, props) => {\n if (!props) {\n return acc;\n }\n Object.entries(props).forEach(_ref => {\n let [key, value] = _ref;\n if (isItem && [ACTIVE_KEY, SELECTED_KEY].includes(key)) {\n return;\n }\n if (key.indexOf('on') === 0) {\n if (!map.has(key)) {\n map.set(key, []);\n }\n if (typeof value === 'function') {\n var _map$get;\n (_map$get = map.get(key)) == null || _map$get.push(value);\n acc[key] = function () {\n var _map$get2;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return (_map$get2 = map.get(key)) == null ? void 0 : _map$get2.map(fn => fn(...args)).find(val => val !== undefined);\n };\n }\n } else {\n acc[key] = value;\n }\n });\n return acc;\n }, {})\n };\n}\n/**\n * Merges an array of interaction hooks' props into prop getters, allowing\n * event handler functions to be composed together without overwriting one\n * another.\n * @see https://floating-ui.com/docs/useInteractions\n */\nfunction useInteractions(propsList) {\n if (propsList === void 0) {\n propsList = [];\n }\n const referenceDeps = propsList.map(key => key == null ? void 0 : key.reference);\n const floatingDeps = propsList.map(key => key == null ? void 0 : key.floating);\n const itemDeps = propsList.map(key => key == null ? void 0 : key.item);\n const getReferenceProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'reference'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n referenceDeps);\n const getFloatingProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'floating'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n floatingDeps);\n const getItemProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'item'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n itemDeps);\n return React.useMemo(() => ({\n getReferenceProps,\n getFloatingProps,\n getItemProps\n }), [getReferenceProps, getFloatingProps, getItemProps]);\n}\n\nconst ESCAPE = 'Escape';\nfunction doSwitch(orientation, vertical, horizontal) {\n switch (orientation) {\n case 'vertical':\n return vertical;\n case 'horizontal':\n return horizontal;\n default:\n return vertical || horizontal;\n }\n}\nfunction isMainOrientationKey(key, orientation) {\n const vertical = key === ARROW_UP || key === ARROW_DOWN;\n const horizontal = key === ARROW_LEFT || key === ARROW_RIGHT;\n return doSwitch(orientation, vertical, horizontal);\n}\nfunction isMainOrientationToEndKey(key, orientation, rtl) {\n const vertical = key === ARROW_DOWN;\n const horizontal = rtl ? key === ARROW_LEFT : key === ARROW_RIGHT;\n return doSwitch(orientation, vertical, horizontal) || key === 'Enter' || key === ' ' || key === '';\n}\nfunction isCrossOrientationOpenKey(key, orientation, rtl) {\n const vertical = rtl ? key === ARROW_LEFT : key === ARROW_RIGHT;\n const horizontal = key === ARROW_DOWN;\n return doSwitch(orientation, vertical, horizontal);\n}\nfunction isCrossOrientationCloseKey(key, orientation, rtl, cols) {\n const vertical = rtl ? key === ARROW_RIGHT : key === ARROW_LEFT;\n const horizontal = key === ARROW_UP;\n if (orientation === 'both' || orientation === 'horizontal' && cols && cols > 1) {\n return key === ESCAPE;\n }\n return doSwitch(orientation, vertical, horizontal);\n}\n/**\n * Adds arrow key-based navigation of a list of items, either using real DOM\n * focus or virtual focus.\n * @see https://floating-ui.com/docs/useListNavigation\n */\nfunction useListNavigation(context, props) {\n const {\n open,\n onOpenChange,\n elements,\n floatingId\n } = context;\n const {\n listRef,\n activeIndex,\n onNavigate: unstable_onNavigate = () => {},\n enabled = true,\n selectedIndex = null,\n allowEscape = false,\n loop = false,\n nested = false,\n rtl = false,\n virtual = false,\n focusItemOnOpen = 'auto',\n focusItemOnHover = true,\n openOnArrowKeyDown = true,\n disabledIndices = undefined,\n orientation = 'vertical',\n parentOrientation,\n cols = 1,\n scrollItemIntoView = true,\n virtualItemRef,\n itemSizes,\n dense = false\n } = props;\n if (process.env.NODE_ENV !== \"production\") {\n if (allowEscape) {\n if (!loop) {\n warn('`useListNavigation` looping must be enabled to allow escaping.');\n }\n if (!virtual) {\n warn('`useListNavigation` must be virtual to allow escaping.');\n }\n }\n if (orientation === 'vertical' && cols > 1) {\n warn('In grid list navigation mode (`cols` > 1), the `orientation` should', 'be either \"horizontal\" or \"both\".');\n }\n }\n const floatingFocusElement = getFloatingFocusElement(elements.floating);\n const floatingFocusElementRef = useLatestRef(floatingFocusElement);\n const parentId = useFloatingParentNodeId();\n const tree = useFloatingTree();\n useModernLayoutEffect(() => {\n context.dataRef.current.orientation = orientation;\n }, [context, orientation]);\n const onNavigate = useEffectEvent(() => {\n unstable_onNavigate(indexRef.current === -1 ? null : indexRef.current);\n });\n const typeableComboboxReference = isTypeableCombobox(elements.domReference);\n const focusItemOnOpenRef = React.useRef(focusItemOnOpen);\n const indexRef = React.useRef(selectedIndex != null ? selectedIndex : -1);\n const keyRef = React.useRef(null);\n const isPointerModalityRef = React.useRef(true);\n const previousOnNavigateRef = React.useRef(onNavigate);\n const previousMountedRef = React.useRef(!!elements.floating);\n const previousOpenRef = React.useRef(open);\n const forceSyncFocusRef = React.useRef(false);\n const forceScrollIntoViewRef = React.useRef(false);\n const disabledIndicesRef = useLatestRef(disabledIndices);\n const latestOpenRef = useLatestRef(open);\n const scrollItemIntoViewRef = useLatestRef(scrollItemIntoView);\n const selectedIndexRef = useLatestRef(selectedIndex);\n const [activeId, setActiveId] = React.useState();\n const [virtualId, setVirtualId] = React.useState();\n const focusItem = useEffectEvent(() => {\n function runFocus(item) {\n if (virtual) {\n var _item$id;\n if ((_item$id = item.id) != null && _item$id.endsWith('-fui-option')) {\n item.id = floatingId + \"-\" + Math.random().toString(16).slice(2, 10);\n }\n setActiveId(item.id);\n tree == null || tree.events.emit('virtualfocus', item);\n if (virtualItemRef) {\n virtualItemRef.current = item;\n }\n } else {\n enqueueFocus(item, {\n sync: forceSyncFocusRef.current,\n preventScroll: true\n });\n }\n }\n const initialItem = listRef.current[indexRef.current];\n const forceScrollIntoView = forceScrollIntoViewRef.current;\n if (initialItem) {\n runFocus(initialItem);\n }\n const scheduler = forceSyncFocusRef.current ? v => v() : requestAnimationFrame;\n scheduler(() => {\n const waitedItem = listRef.current[indexRef.current] || initialItem;\n if (!waitedItem) return;\n if (!initialItem) {\n runFocus(waitedItem);\n }\n const scrollIntoViewOptions = scrollItemIntoViewRef.current;\n const shouldScrollIntoView = scrollIntoViewOptions && item && (forceScrollIntoView || !isPointerModalityRef.current);\n if (shouldScrollIntoView) {\n // JSDOM doesn't support `.scrollIntoView()` but it's widely supported\n // by all browsers.\n waitedItem.scrollIntoView == null || waitedItem.scrollIntoView(typeof scrollIntoViewOptions === 'boolean' ? {\n block: 'nearest',\n inline: 'nearest'\n } : scrollIntoViewOptions);\n }\n });\n });\n\n // Sync `selectedIndex` to be the `activeIndex` upon opening the floating\n // element. Also, reset `activeIndex` upon closing the floating element.\n useModernLayoutEffect(() => {\n if (!enabled) return;\n if (open && elements.floating) {\n if (focusItemOnOpenRef.current && selectedIndex != null) {\n // Regardless of the pointer modality, we want to ensure the selected\n // item comes into view when the floating element is opened.\n forceScrollIntoViewRef.current = true;\n indexRef.current = selectedIndex;\n onNavigate();\n }\n } else if (previousMountedRef.current) {\n // Since the user can specify `onNavigate` conditionally\n // (onNavigate: open ? setActiveIndex : setSelectedIndex),\n // we store and call the previous function.\n indexRef.current = -1;\n previousOnNavigateRef.current();\n }\n }, [enabled, open, elements.floating, selectedIndex, onNavigate]);\n\n // Sync `activeIndex` to be the focused item while the floating element is\n // open.\n useModernLayoutEffect(() => {\n if (!enabled) return;\n if (!open) return;\n if (!elements.floating) return;\n if (activeIndex == null) {\n forceSyncFocusRef.current = false;\n if (selectedIndexRef.current != null) {\n return;\n }\n\n // Reset while the floating element was open (e.g. the list changed).\n if (previousMountedRef.current) {\n indexRef.current = -1;\n focusItem();\n }\n\n // Initial sync.\n if ((!previousOpenRef.current || !previousMountedRef.current) && focusItemOnOpenRef.current && (keyRef.current != null || focusItemOnOpenRef.current === true && keyRef.current == null)) {\n let runs = 0;\n const waitForListPopulated = () => {\n if (listRef.current[0] == null) {\n // Avoid letting the browser paint if possible on the first try,\n // otherwise use rAF. Don't try more than twice, since something\n // is wrong otherwise.\n if (runs < 2) {\n const scheduler = runs ? requestAnimationFrame : queueMicrotask;\n scheduler(waitForListPopulated);\n }\n runs++;\n } else {\n indexRef.current = keyRef.current == null || isMainOrientationToEndKey(keyRef.current, orientation, rtl) || nested ? getMinListIndex(listRef, disabledIndicesRef.current) : getMaxListIndex(listRef, disabledIndicesRef.current);\n keyRef.current = null;\n onNavigate();\n }\n };\n waitForListPopulated();\n }\n } else if (!isIndexOutOfListBounds(listRef, activeIndex)) {\n indexRef.current = activeIndex;\n focusItem();\n forceScrollIntoViewRef.current = false;\n }\n }, [enabled, open, elements.floating, activeIndex, selectedIndexRef, nested, listRef, orientation, rtl, onNavigate, focusItem, disabledIndicesRef]);\n\n // Ensure the parent floating element has focus when a nested child closes\n // to allow arrow key navigation to work after the pointer leaves the child.\n useModernLayoutEffect(() => {\n var _nodes$find;\n if (!enabled || elements.floating || !tree || virtual || !previousMountedRef.current) {\n return;\n }\n const nodes = tree.nodesRef.current;\n const parent = (_nodes$find = nodes.find(node => node.id === parentId)) == null || (_nodes$find = _nodes$find.context) == null ? void 0 : _nodes$find.elements.floating;\n const activeEl = activeElement(getDocument$1(elements.floating));\n const treeContainsActiveEl = nodes.some(node => node.context && contains$1(node.context.elements.floating, activeEl));\n if (parent && !treeContainsActiveEl && isPointerModalityRef.current) {\n parent.focus({\n preventScroll: true\n });\n }\n }, [enabled, elements.floating, tree, parentId, virtual]);\n useModernLayoutEffect(() => {\n if (!enabled) return;\n if (!tree) return;\n if (!virtual) return;\n if (parentId) return;\n function handleVirtualFocus(item) {\n setVirtualId(item.id);\n if (virtualItemRef) {\n virtualItemRef.current = item;\n }\n }\n tree.events.on('virtualfocus', handleVirtualFocus);\n return () => {\n tree.events.off('virtualfocus', handleVirtualFocus);\n };\n }, [enabled, tree, virtual, parentId, virtualItemRef]);\n useModernLayoutEffect(() => {\n previousOnNavigateRef.current = onNavigate;\n previousOpenRef.current = open;\n previousMountedRef.current = !!elements.floating;\n });\n useModernLayoutEffect(() => {\n if (!open) {\n keyRef.current = null;\n focusItemOnOpenRef.current = focusItemOnOpen;\n }\n }, [open, focusItemOnOpen]);\n const hasActiveIndex = activeIndex != null;\n const item = React.useMemo(() => {\n function syncCurrentTarget(currentTarget) {\n if (!latestOpenRef.current) return;\n const index = listRef.current.indexOf(currentTarget);\n if (index !== -1 && indexRef.current !== index) {\n indexRef.current = index;\n onNavigate();\n }\n }\n const props = {\n onFocus(_ref) {\n let {\n currentTarget\n } = _ref;\n forceSyncFocusRef.current = true;\n syncCurrentTarget(currentTarget);\n },\n onClick: _ref2 => {\n let {\n currentTarget\n } = _ref2;\n return currentTarget.focus({\n preventScroll: true\n });\n },\n // Safari\n onMouseMove(_ref3) {\n let {\n currentTarget\n } = _ref3;\n forceSyncFocusRef.current = true;\n forceScrollIntoViewRef.current = false;\n if (focusItemOnHover) {\n syncCurrentTarget(currentTarget);\n }\n },\n onPointerLeave(_ref4) {\n let {\n pointerType\n } = _ref4;\n if (!isPointerModalityRef.current || pointerType === 'touch') {\n return;\n }\n forceSyncFocusRef.current = true;\n if (!focusItemOnHover) {\n return;\n }\n indexRef.current = -1;\n onNavigate();\n if (!virtual) {\n var _floatingFocusElement;\n (_floatingFocusElement = floatingFocusElementRef.current) == null || _floatingFocusElement.focus({\n preventScroll: true\n });\n }\n }\n };\n return props;\n }, [latestOpenRef, floatingFocusElementRef, focusItemOnHover, listRef, onNavigate, virtual]);\n const getParentOrientation = React.useCallback(() => {\n var _tree$nodesRef$curren;\n return parentOrientation != null ? parentOrientation : tree == null || (_tree$nodesRef$curren = tree.nodesRef.current.find(node => node.id === parentId)) == null || (_tree$nodesRef$curren = _tree$nodesRef$curren.context) == null || (_tree$nodesRef$curren = _tree$nodesRef$curren.dataRef) == null ? void 0 : _tree$nodesRef$curren.current.orientation;\n }, [parentId, tree, parentOrientation]);\n const commonOnKeyDown = useEffectEvent(event => {\n isPointerModalityRef.current = false;\n forceSyncFocusRef.current = true;\n\n // When composing a character, Chrome fires ArrowDown twice. Firefox/Safari\n // don't appear to suffer from this. `event.isComposing` is avoided due to\n // Safari not supporting it properly (although it's not needed in the first\n // place for Safari, just avoiding any possible issues).\n if (event.which === 229) {\n return;\n }\n\n // If the floating element is animating out, ignore navigation. Otherwise,\n // the `activeIndex` gets set to 0 despite not being open so the next time\n // the user ArrowDowns, the first item won't be focused.\n if (!latestOpenRef.current && event.currentTarget === floatingFocusElementRef.current) {\n return;\n }\n if (nested && isCrossOrientationCloseKey(event.key, orientation, rtl, cols)) {\n // If the nested list's close key is also the parent navigation key,\n // let the parent navigate. Otherwise, stop propagating the event.\n if (!isMainOrientationKey(event.key, getParentOrientation())) {\n stopEvent(event);\n }\n onOpenChange(false, event.nativeEvent, 'list-navigation');\n if (isHTMLElement(elements.domReference)) {\n if (virtual) {\n tree == null || tree.events.emit('virtualfocus', elements.domReference);\n } else {\n elements.domReference.focus();\n }\n }\n return;\n }\n const currentIndex = indexRef.current;\n const minIndex = getMinListIndex(listRef, disabledIndices);\n const maxIndex = getMaxListIndex(listRef, disabledIndices);\n if (!typeableComboboxReference) {\n if (event.key === 'Home') {\n stopEvent(event);\n indexRef.current = minIndex;\n onNavigate();\n }\n if (event.key === 'End') {\n stopEvent(event);\n indexRef.current = maxIndex;\n onNavigate();\n }\n }\n\n // Grid navigation.\n if (cols > 1) {\n const sizes = itemSizes || Array.from({\n length: listRef.current.length\n }, () => ({\n width: 1,\n height: 1\n }));\n // To calculate movements on the grid, we use hypothetical cell indices\n // as if every item was 1x1, then convert back to real indices.\n const cellMap = createGridCellMap(sizes, cols, dense);\n const minGridIndex = cellMap.findIndex(index => index != null && !isListIndexDisabled(listRef, index, disabledIndices));\n // last enabled index\n const maxGridIndex = cellMap.reduce((foundIndex, index, cellIndex) => index != null && !isListIndexDisabled(listRef, index, disabledIndices) ? cellIndex : foundIndex, -1);\n const index = cellMap[getGridNavigatedIndex({\n current: cellMap.map(itemIndex => itemIndex != null ? listRef.current[itemIndex] : null)\n }, {\n event,\n orientation,\n loop,\n rtl,\n cols,\n // treat undefined (empty grid spaces) as disabled indices so we\n // don't end up in them\n disabledIndices: getGridCellIndices([...((typeof disabledIndices !== 'function' ? disabledIndices : null) || listRef.current.map((_, index) => isListIndexDisabled(listRef, index, disabledIndices) ? index : undefined)), undefined], cellMap),\n minIndex: minGridIndex,\n maxIndex: maxGridIndex,\n prevIndex: getGridCellIndexOfCorner(indexRef.current > maxIndex ? minIndex : indexRef.current, sizes, cellMap, cols,\n // use a corner matching the edge closest to the direction\n // we're moving in so we don't end up in the same item. Prefer\n // top/left over bottom/right.\n event.key === ARROW_DOWN ? 'bl' : event.key === (rtl ? ARROW_LEFT : ARROW_RIGHT) ? 'tr' : 'tl'),\n stopEvent: true\n })];\n if (index != null) {\n indexRef.current = index;\n onNavigate();\n }\n if (orientation === 'both') {\n return;\n }\n }\n if (isMainOrientationKey(event.key, orientation)) {\n stopEvent(event);\n\n // Reset the index if no item is focused.\n if (open && !virtual && activeElement(event.currentTarget.ownerDocument) === event.currentTarget) {\n indexRef.current = isMainOrientationToEndKey(event.key, orientation, rtl) ? minIndex : maxIndex;\n onNavigate();\n return;\n }\n if (isMainOrientationToEndKey(event.key, orientation, rtl)) {\n if (loop) {\n indexRef.current = currentIndex >= maxIndex ? allowEscape && currentIndex !== listRef.current.length ? -1 : minIndex : findNonDisabledListIndex(listRef, {\n startingIndex: currentIndex,\n disabledIndices\n });\n } else {\n indexRef.current = Math.min(maxIndex, findNonDisabledListIndex(listRef, {\n startingIndex: currentIndex,\n disabledIndices\n }));\n }\n } else {\n if (loop) {\n indexRef.current = currentIndex <= minIndex ? allowEscape && currentIndex !== -1 ? listRef.current.length : maxIndex : findNonDisabledListIndex(listRef, {\n startingIndex: currentIndex,\n decrement: true,\n disabledIndices\n });\n } else {\n indexRef.current = Math.max(minIndex, findNonDisabledListIndex(listRef, {\n startingIndex: currentIndex,\n decrement: true,\n disabledIndices\n }));\n }\n }\n if (isIndexOutOfListBounds(listRef, indexRef.current)) {\n indexRef.current = -1;\n }\n onNavigate();\n }\n });\n const ariaActiveDescendantProp = React.useMemo(() => {\n return virtual && open && hasActiveIndex && {\n 'aria-activedescendant': virtualId || activeId\n };\n }, [virtual, open, hasActiveIndex, virtualId, activeId]);\n const floating = React.useMemo(() => {\n return {\n 'aria-orientation': orientation === 'both' ? undefined : orientation,\n ...(!typeableComboboxReference ? ariaActiveDescendantProp : {}),\n onKeyDown: commonOnKeyDown,\n onPointerMove() {\n isPointerModalityRef.current = true;\n }\n };\n }, [ariaActiveDescendantProp, commonOnKeyDown, orientation, typeableComboboxReference]);\n const reference = React.useMemo(() => {\n function checkVirtualMouse(event) {\n if (focusItemOnOpen === 'auto' && isVirtualClick(event.nativeEvent)) {\n focusItemOnOpenRef.current = true;\n }\n }\n function checkVirtualPointer(event) {\n // `pointerdown` fires first, reset the state then perform the checks.\n focusItemOnOpenRef.current = focusItemOnOpen;\n if (focusItemOnOpen === 'auto' && isVirtualPointerEvent(event.nativeEvent)) {\n focusItemOnOpenRef.current = true;\n }\n }\n return {\n ...ariaActiveDescendantProp,\n onKeyDown(event) {\n isPointerModalityRef.current = false;\n const isArrowKey = event.key.startsWith('Arrow');\n const isHomeOrEndKey = ['Home', 'End'].includes(event.key);\n const isMoveKey = isArrowKey || isHomeOrEndKey;\n const isCrossOpenKey = isCrossOrientationOpenKey(event.key, orientation, rtl);\n const isCrossCloseKey = isCrossOrientationCloseKey(event.key, orientation, rtl, cols);\n const isParentCrossOpenKey = isCrossOrientationOpenKey(event.key, getParentOrientation(), rtl);\n const isMainKey = isMainOrientationKey(event.key, orientation);\n const isNavigationKey = (nested ? isParentCrossOpenKey : isMainKey) || event.key === 'Enter' || event.key.trim() === '';\n if (virtual && open) {\n const rootNode = tree == null ? void 0 : tree.nodesRef.current.find(node => node.parentId == null);\n const deepestNode = tree && rootNode ? getDeepestNode(tree.nodesRef.current, rootNode.id) : null;\n if (isMoveKey && deepestNode && virtualItemRef) {\n const eventObject = new KeyboardEvent('keydown', {\n key: event.key,\n bubbles: true\n });\n if (isCrossOpenKey || isCrossCloseKey) {\n var _deepestNode$context, _deepestNode$context2;\n const isCurrentTarget = ((_deepestNode$context = deepestNode.context) == null ? void 0 : _deepestNode$context.elements.domReference) === event.currentTarget;\n const dispatchItem = isCrossCloseKey && !isCurrentTarget ? (_deepestNode$context2 = deepestNode.context) == null ? void 0 : _deepestNode$context2.elements.domReference : isCrossOpenKey ? listRef.current.find(item => (item == null ? void 0 : item.id) === activeId) : null;\n if (dispatchItem) {\n stopEvent(event);\n dispatchItem.dispatchEvent(eventObject);\n setVirtualId(undefined);\n }\n }\n if ((isMainKey || isHomeOrEndKey) && deepestNode.context) {\n if (deepestNode.context.open && deepestNode.parentId && event.currentTarget !== deepestNode.context.elements.domReference) {\n var _deepestNode$context$;\n stopEvent(event);\n (_deepestNode$context$ = deepestNode.context.elements.domReference) == null || _deepestNode$context$.dispatchEvent(eventObject);\n return;\n }\n }\n }\n return commonOnKeyDown(event);\n }\n // If a floating element should not open on arrow key down, avoid\n // setting `activeIndex` while it's closed.\n if (!open && !openOnArrowKeyDown && isArrowKey) {\n return;\n }\n if (isNavigationKey) {\n const isParentMainKey = isMainOrientationKey(event.key, getParentOrientation());\n keyRef.current = nested && isParentMainKey ? null : event.key;\n }\n if (nested) {\n if (isParentCrossOpenKey) {\n stopEvent(event);\n if (open) {\n indexRef.current = getMinListIndex(listRef, disabledIndicesRef.current);\n onNavigate();\n } else {\n onOpenChange(true, event.nativeEvent, 'list-navigation');\n }\n }\n return;\n }\n if (isMainKey) {\n if (selectedIndex != null) {\n indexRef.current = selectedIndex;\n }\n stopEvent(event);\n if (!open && openOnArrowKeyDown) {\n onOpenChange(true, event.nativeEvent, 'list-navigation');\n } else {\n commonOnKeyDown(event);\n }\n if (open) {\n onNavigate();\n }\n }\n },\n onFocus() {\n if (open && !virtual) {\n indexRef.current = -1;\n onNavigate();\n }\n },\n onPointerDown: checkVirtualPointer,\n onPointerEnter: checkVirtualPointer,\n onMouseDown: checkVirtualMouse,\n onClick: checkVirtualMouse\n };\n }, [activeId, ariaActiveDescendantProp, cols, commonOnKeyDown, disabledIndicesRef, focusItemOnOpen, listRef, nested, onNavigate, onOpenChange, open, openOnArrowKeyDown, orientation, getParentOrientation, rtl, selectedIndex, tree, virtual, virtualItemRef]);\n return React.useMemo(() => enabled ? {\n reference,\n floating,\n item\n } : {}, [enabled, reference, floating, item]);\n}\n\nconst componentRoleToAriaRoleMap = /*#__PURE__*/new Map([['select', 'listbox'], ['combobox', 'listbox'], ['label', false]]);\n\n/**\n * Adds base screen reader props to the reference and floating elements for a\n * given floating element `role`.\n * @see https://floating-ui.com/docs/useRole\n */\nfunction useRole(context, props) {\n var _elements$domReferenc, _componentRoleToAriaR;\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n elements,\n floatingId: defaultFloatingId\n } = context;\n const {\n enabled = true,\n role = 'dialog'\n } = props;\n const defaultReferenceId = useId();\n const referenceId = ((_elements$domReferenc = elements.domReference) == null ? void 0 : _elements$domReferenc.id) || defaultReferenceId;\n const floatingId = React.useMemo(() => {\n var _getFloatingFocusElem;\n return ((_getFloatingFocusElem = getFloatingFocusElement(elements.floating)) == null ? void 0 : _getFloatingFocusElem.id) || defaultFloatingId;\n }, [elements.floating, defaultFloatingId]);\n const ariaRole = (_componentRoleToAriaR = componentRoleToAriaRoleMap.get(role)) != null ? _componentRoleToAriaR : role;\n const parentId = useFloatingParentNodeId();\n const isNested = parentId != null;\n const reference = React.useMemo(() => {\n if (ariaRole === 'tooltip' || role === 'label') {\n return {\n [\"aria-\" + (role === 'label' ? 'labelledby' : 'describedby')]: open ? floatingId : undefined\n };\n }\n return {\n 'aria-expanded': open ? 'true' : 'false',\n 'aria-haspopup': ariaRole === 'alertdialog' ? 'dialog' : ariaRole,\n 'aria-controls': open ? floatingId : undefined,\n ...(ariaRole === 'listbox' && {\n role: 'combobox'\n }),\n ...(ariaRole === 'menu' && {\n id: referenceId\n }),\n ...(ariaRole === 'menu' && isNested && {\n role: 'menuitem'\n }),\n ...(role === 'select' && {\n 'aria-autocomplete': 'none'\n }),\n ...(role === 'combobox' && {\n 'aria-autocomplete': 'list'\n })\n };\n }, [ariaRole, floatingId, isNested, open, referenceId, role]);\n const floating = React.useMemo(() => {\n const floatingProps = {\n id: floatingId,\n ...(ariaRole && {\n role: ariaRole\n })\n };\n if (ariaRole === 'tooltip' || role === 'label') {\n return floatingProps;\n }\n return {\n ...floatingProps,\n ...(ariaRole === 'menu' && {\n 'aria-labelledby': referenceId\n })\n };\n }, [ariaRole, floatingId, referenceId, role]);\n const item = React.useCallback(_ref => {\n let {\n active,\n selected\n } = _ref;\n const commonProps = {\n role: 'option',\n ...(active && {\n id: floatingId + \"-fui-option\"\n })\n };\n\n // For `menu`, we are unable to tell if the item is a `menuitemradio`\n // or `menuitemcheckbox`. For backwards-compatibility reasons, also\n // avoid defaulting to `menuitem` as it may overwrite custom role props.\n switch (role) {\n case 'select':\n case 'combobox':\n return {\n ...commonProps,\n 'aria-selected': selected\n };\n }\n return {};\n }, [floatingId, role]);\n return React.useMemo(() => enabled ? {\n reference,\n floating,\n item\n } : {}, [enabled, reference, floating, item]);\n}\n\n// Converts a JS style key like `backgroundColor` to a CSS transition-property\n// like `background-color`.\nconst camelCaseToKebabCase = str => str.replace(/[A-Z]+(?![a-z])|[A-Z]/g, ($, ofs) => (ofs ? '-' : '') + $.toLowerCase());\nfunction execWithArgsOrReturn(valueOrFn, args) {\n return typeof valueOrFn === 'function' ? valueOrFn(args) : valueOrFn;\n}\nfunction useDelayUnmount(open, durationMs) {\n const [isMounted, setIsMounted] = React.useState(open);\n if (open && !isMounted) {\n setIsMounted(true);\n }\n React.useEffect(() => {\n if (!open && isMounted) {\n const timeout = setTimeout(() => setIsMounted(false), durationMs);\n return () => clearTimeout(timeout);\n }\n }, [open, isMounted, durationMs]);\n return isMounted;\n}\n/**\n * Provides a status string to apply CSS transitions to a floating element,\n * correctly handling placement-aware transitions.\n * @see https://floating-ui.com/docs/useTransition#usetransitionstatus\n */\nfunction useTransitionStatus(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n elements: {\n floating\n }\n } = context;\n const {\n duration = 250\n } = props;\n const isNumberDuration = typeof duration === 'number';\n const closeDuration = (isNumberDuration ? duration : duration.close) || 0;\n const [status, setStatus] = React.useState('unmounted');\n const isMounted = useDelayUnmount(open, closeDuration);\n if (!isMounted && status === 'close') {\n setStatus('unmounted');\n }\n useModernLayoutEffect(() => {\n if (!floating) return;\n if (open) {\n setStatus('initial');\n const frame = requestAnimationFrame(() => {\n // Ensure it opens before paint. With `FloatingDelayGroup`,\n // this avoids a flicker when moving between floating elements\n // to ensure one is always open with no missing frames.\n ReactDOM.flushSync(() => {\n setStatus('open');\n });\n });\n return () => {\n cancelAnimationFrame(frame);\n };\n }\n setStatus('close');\n }, [open, floating]);\n return {\n isMounted,\n status\n };\n}\n/**\n * Provides styles to apply CSS transitions to a floating element, correctly\n * handling placement-aware transitions. Wrapper around `useTransitionStatus`.\n * @see https://floating-ui.com/docs/useTransition#usetransitionstyles\n */\nfunction useTransitionStyles(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n initial: unstable_initial = {\n opacity: 0\n },\n open: unstable_open,\n close: unstable_close,\n common: unstable_common,\n duration = 250\n } = props;\n const placement = context.placement;\n const side = placement.split('-')[0];\n const fnArgs = React.useMemo(() => ({\n side,\n placement\n }), [side, placement]);\n const isNumberDuration = typeof duration === 'number';\n const openDuration = (isNumberDuration ? duration : duration.open) || 0;\n const closeDuration = (isNumberDuration ? duration : duration.close) || 0;\n const [styles, setStyles] = React.useState(() => ({\n ...execWithArgsOrReturn(unstable_common, fnArgs),\n ...execWithArgsOrReturn(unstable_initial, fnArgs)\n }));\n const {\n isMounted,\n status\n } = useTransitionStatus(context, {\n duration\n });\n const initialRef = useLatestRef(unstable_initial);\n const openRef = useLatestRef(unstable_open);\n const closeRef = useLatestRef(unstable_close);\n const commonRef = useLatestRef(unstable_common);\n useModernLayoutEffect(() => {\n const initialStyles = execWithArgsOrReturn(initialRef.current, fnArgs);\n const closeStyles = execWithArgsOrReturn(closeRef.current, fnArgs);\n const commonStyles = execWithArgsOrReturn(commonRef.current, fnArgs);\n const openStyles = execWithArgsOrReturn(openRef.current, fnArgs) || Object.keys(initialStyles).reduce((acc, key) => {\n acc[key] = '';\n return acc;\n }, {});\n if (status === 'initial') {\n setStyles(styles => ({\n transitionProperty: styles.transitionProperty,\n ...commonStyles,\n ...initialStyles\n }));\n }\n if (status === 'open') {\n setStyles({\n transitionProperty: Object.keys(openStyles).map(camelCaseToKebabCase).join(','),\n transitionDuration: openDuration + \"ms\",\n ...commonStyles,\n ...openStyles\n });\n }\n if (status === 'close') {\n const styles = closeStyles || initialStyles;\n setStyles({\n transitionProperty: Object.keys(styles).map(camelCaseToKebabCase).join(','),\n transitionDuration: closeDuration + \"ms\",\n ...commonStyles,\n ...styles\n });\n }\n }, [closeDuration, closeRef, initialRef, openRef, commonRef, openDuration, status, fnArgs]);\n return {\n isMounted,\n styles\n };\n}\n\n/**\n * Provides a matching callback that can be used to focus an item as the user\n * types, often used in tandem with `useListNavigation()`.\n * @see https://floating-ui.com/docs/useTypeahead\n */\nfunction useTypeahead(context, props) {\n var _ref;\n const {\n open,\n dataRef\n } = context;\n const {\n listRef,\n activeIndex,\n onMatch: unstable_onMatch,\n onTypingChange: unstable_onTypingChange,\n enabled = true,\n findMatch = null,\n resetMs = 750,\n ignoreKeys = [],\n selectedIndex = null\n } = props;\n const timeoutIdRef = React.useRef(-1);\n const stringRef = React.useRef('');\n const prevIndexRef = React.useRef((_ref = selectedIndex != null ? selectedIndex : activeIndex) != null ? _ref : -1);\n const matchIndexRef = React.useRef(null);\n const onMatch = useEffectEvent(unstable_onMatch);\n const onTypingChange = useEffectEvent(unstable_onTypingChange);\n const findMatchRef = useLatestRef(findMatch);\n const ignoreKeysRef = useLatestRef(ignoreKeys);\n useModernLayoutEffect(() => {\n if (open) {\n clearTimeoutIfSet(timeoutIdRef);\n matchIndexRef.current = null;\n stringRef.current = '';\n }\n }, [open]);\n useModernLayoutEffect(() => {\n // Sync arrow key navigation but not typeahead navigation.\n if (open && stringRef.current === '') {\n var _ref2;\n prevIndexRef.current = (_ref2 = selectedIndex != null ? selectedIndex : activeIndex) != null ? _ref2 : -1;\n }\n }, [open, selectedIndex, activeIndex]);\n const setTypingChange = useEffectEvent(value => {\n if (value) {\n if (!dataRef.current.typing) {\n dataRef.current.typing = value;\n onTypingChange(value);\n }\n } else {\n if (dataRef.current.typing) {\n dataRef.current.typing = value;\n onTypingChange(value);\n }\n }\n });\n const onKeyDown = useEffectEvent(event => {\n function getMatchingIndex(list, orderedList, string) {\n const str = findMatchRef.current ? findMatchRef.current(orderedList, string) : orderedList.find(text => (text == null ? void 0 : text.toLocaleLowerCase().indexOf(string.toLocaleLowerCase())) === 0);\n return str ? list.indexOf(str) : -1;\n }\n const listContent = listRef.current;\n if (stringRef.current.length > 0 && stringRef.current[0] !== ' ') {\n if (getMatchingIndex(listContent, listContent, stringRef.current) === -1) {\n setTypingChange(false);\n } else if (event.key === ' ') {\n stopEvent(event);\n }\n }\n if (listContent == null || ignoreKeysRef.current.includes(event.key) ||\n // Character key.\n event.key.length !== 1 ||\n // Modifier key.\n event.ctrlKey || event.metaKey || event.altKey) {\n return;\n }\n if (open && event.key !== ' ') {\n stopEvent(event);\n setTypingChange(true);\n }\n\n // Bail out if the list contains a word like \"llama\" or \"aaron\". TODO:\n // allow it in this case, too.\n const allowRapidSuccessionOfFirstLetter = listContent.every(text => {\n var _text$, _text$2;\n return text ? ((_text$ = text[0]) == null ? void 0 : _text$.toLocaleLowerCase()) !== ((_text$2 = text[1]) == null ? void 0 : _text$2.toLocaleLowerCase()) : true;\n });\n\n // Allows the user to cycle through items that start with the same letter\n // in rapid succession.\n if (allowRapidSuccessionOfFirstLetter && stringRef.current === event.key) {\n stringRef.current = '';\n prevIndexRef.current = matchIndexRef.current;\n }\n stringRef.current += event.key;\n clearTimeoutIfSet(timeoutIdRef);\n timeoutIdRef.current = window.setTimeout(() => {\n stringRef.current = '';\n prevIndexRef.current = matchIndexRef.current;\n setTypingChange(false);\n }, resetMs);\n const prevIndex = prevIndexRef.current;\n const index = getMatchingIndex(listContent, [...listContent.slice((prevIndex || 0) + 1), ...listContent.slice(0, (prevIndex || 0) + 1)], stringRef.current);\n if (index !== -1) {\n onMatch(index);\n matchIndexRef.current = index;\n } else if (event.key !== ' ') {\n stringRef.current = '';\n setTypingChange(false);\n }\n });\n const reference = React.useMemo(() => ({\n onKeyDown\n }), [onKeyDown]);\n const floating = React.useMemo(() => {\n return {\n onKeyDown,\n onKeyUp(event) {\n if (event.key === ' ') {\n setTypingChange(false);\n }\n }\n };\n }, [onKeyDown, setTypingChange]);\n return React.useMemo(() => enabled ? {\n reference,\n floating\n } : {}, [enabled, reference, floating]);\n}\n\nfunction getArgsWithCustomFloatingHeight(state, height) {\n return {\n ...state,\n rects: {\n ...state.rects,\n floating: {\n ...state.rects.floating,\n height\n }\n }\n };\n}\n/**\n * Positions the floating element such that an inner element inside of it is\n * anchored to the reference element.\n * @see https://floating-ui.com/docs/inner\n * @deprecated\n */\nconst inner = props => ({\n name: 'inner',\n options: props,\n async fn(state) {\n const {\n listRef,\n overflowRef,\n onFallbackChange,\n offset: innerOffset = 0,\n index = 0,\n minItemsVisible = 4,\n referenceOverflowThreshold = 0,\n scrollRef,\n ...detectOverflowOptions\n } = evaluate(props, state);\n const {\n rects,\n platform,\n elements: {\n floating\n }\n } = state;\n const item = listRef.current[index];\n const scrollEl = (scrollRef == null ? void 0 : scrollRef.current) || floating;\n\n // Valid combinations:\n // 1. Floating element is the scrollRef and has a border (default)\n // 2. Floating element is not the scrollRef, floating element has a border\n // 3. Floating element is not the scrollRef, scrollRef has a border\n // Floating > {...getFloatingProps()} wrapper > scrollRef > items is not\n // allowed as VoiceOver doesn't work.\n const clientTop = floating.clientTop || scrollEl.clientTop;\n const floatingIsBordered = floating.clientTop !== 0;\n const scrollElIsBordered = scrollEl.clientTop !== 0;\n const floatingIsScrollEl = floating === scrollEl;\n if (process.env.NODE_ENV !== \"production\") {\n if (!state.placement.startsWith('bottom')) {\n warn('`placement` side must be \"bottom\" when using the `inner`', 'middleware.');\n }\n }\n if (!item) {\n return {};\n }\n const nextArgs = {\n ...state,\n ...(await offset(-item.offsetTop - floating.clientTop - rects.reference.height / 2 - item.offsetHeight / 2 - innerOffset).fn(state))\n };\n const overflow = await platform.detectOverflow(getArgsWithCustomFloatingHeight(nextArgs, scrollEl.scrollHeight + clientTop + floating.clientTop), detectOverflowOptions);\n const refOverflow = await platform.detectOverflow(nextArgs, {\n ...detectOverflowOptions,\n elementContext: 'reference'\n });\n const diffY = max(0, overflow.top);\n const nextY = nextArgs.y + diffY;\n const isScrollable = scrollEl.scrollHeight > scrollEl.clientHeight;\n const rounder = isScrollable ? v => v : round;\n const maxHeight = rounder(max(0, scrollEl.scrollHeight + (floatingIsBordered && floatingIsScrollEl || scrollElIsBordered ? clientTop * 2 : 0) - diffY - max(0, overflow.bottom)));\n scrollEl.style.maxHeight = maxHeight + \"px\";\n scrollEl.scrollTop = diffY;\n\n // There is not enough space, fallback to standard anchored positioning\n if (onFallbackChange) {\n const shouldFallback = scrollEl.offsetHeight < item.offsetHeight * min(minItemsVisible, listRef.current.length) - 1 || refOverflow.top >= -referenceOverflowThreshold || refOverflow.bottom >= -referenceOverflowThreshold;\n ReactDOM.flushSync(() => onFallbackChange(shouldFallback));\n }\n if (overflowRef) {\n overflowRef.current = await platform.detectOverflow(getArgsWithCustomFloatingHeight({\n ...nextArgs,\n y: nextY\n }, scrollEl.offsetHeight + clientTop + floating.clientTop), detectOverflowOptions);\n }\n return {\n y: nextY\n };\n }\n});\n/**\n * Changes the `inner` middleware's `offset` upon a `wheel` event to\n * expand the floating element's height, revealing more list items.\n * @see https://floating-ui.com/docs/inner\n * @deprecated\n */\nfunction useInnerOffset(context, props) {\n const {\n open,\n elements\n } = context;\n const {\n enabled = true,\n overflowRef,\n scrollRef,\n onChange: unstable_onChange\n } = props;\n const onChange = useEffectEvent(unstable_onChange);\n const controlledScrollingRef = React.useRef(false);\n const prevScrollTopRef = React.useRef(null);\n const initialOverflowRef = React.useRef(null);\n React.useEffect(() => {\n if (!enabled) return;\n function onWheel(e) {\n if (e.ctrlKey || !el || overflowRef.current == null) {\n return;\n }\n const dY = e.deltaY;\n const isAtTop = overflowRef.current.top >= -0.5;\n const isAtBottom = overflowRef.current.bottom >= -0.5;\n const remainingScroll = el.scrollHeight - el.clientHeight;\n const sign = dY < 0 ? -1 : 1;\n const method = dY < 0 ? 'max' : 'min';\n if (el.scrollHeight <= el.clientHeight) {\n return;\n }\n if (!isAtTop && dY > 0 || !isAtBottom && dY < 0) {\n e.preventDefault();\n ReactDOM.flushSync(() => {\n onChange(d => d + Math[method](dY, remainingScroll * sign));\n });\n } else if (/firefox/i.test(getUserAgent())) {\n // Needed to propagate scrolling during momentum scrolling phase once\n // it gets limited by the boundary. UX improvement, not critical.\n el.scrollTop += dY;\n }\n }\n const el = (scrollRef == null ? void 0 : scrollRef.current) || elements.floating;\n if (open && el) {\n el.addEventListener('wheel', onWheel);\n\n // Wait for the position to be ready.\n requestAnimationFrame(() => {\n prevScrollTopRef.current = el.scrollTop;\n if (overflowRef.current != null) {\n initialOverflowRef.current = {\n ...overflowRef.current\n };\n }\n });\n return () => {\n prevScrollTopRef.current = null;\n initialOverflowRef.current = null;\n el.removeEventListener('wheel', onWheel);\n };\n }\n }, [enabled, open, elements.floating, overflowRef, scrollRef, onChange]);\n const floating = React.useMemo(() => ({\n onKeyDown() {\n controlledScrollingRef.current = true;\n },\n onWheel() {\n controlledScrollingRef.current = false;\n },\n onPointerMove() {\n controlledScrollingRef.current = false;\n },\n onScroll() {\n const el = (scrollRef == null ? void 0 : scrollRef.current) || elements.floating;\n if (!overflowRef.current || !el || !controlledScrollingRef.current) {\n return;\n }\n if (prevScrollTopRef.current !== null) {\n const scrollDiff = el.scrollTop - prevScrollTopRef.current;\n if (overflowRef.current.bottom < -0.5 && scrollDiff < -1 || overflowRef.current.top < -0.5 && scrollDiff > 1) {\n ReactDOM.flushSync(() => onChange(d => d + scrollDiff));\n }\n }\n\n // [Firefox] Wait for the height change to have been applied.\n requestAnimationFrame(() => {\n prevScrollTopRef.current = el.scrollTop;\n });\n }\n }), [elements.floating, onChange, overflowRef, scrollRef]);\n return React.useMemo(() => enabled ? {\n floating\n } : {}, [enabled, floating]);\n}\n\nfunction getNodeChildren(nodes, id, onlyOpenChildren) {\n if (onlyOpenChildren === void 0) {\n onlyOpenChildren = true;\n }\n const directChildren = nodes.filter(node => {\n var _node$context;\n return node.parentId === id && (!onlyOpenChildren || ((_node$context = node.context) == null ? void 0 : _node$context.open));\n });\n return directChildren.flatMap(child => [child, ...getNodeChildren(nodes, child.id, onlyOpenChildren)]);\n}\n\nfunction isPointInPolygon(point, polygon) {\n const [x, y] = point;\n let isInside = false;\n const length = polygon.length;\n for (let i = 0, j = length - 1; i < length; j = i++) {\n const [xi, yi] = polygon[i] || [0, 0];\n const [xj, yj] = polygon[j] || [0, 0];\n const intersect = yi >= y !== yj >= y && x <= (xj - xi) * (y - yi) / (yj - yi) + xi;\n if (intersect) {\n isInside = !isInside;\n }\n }\n return isInside;\n}\nfunction isInside(point, rect) {\n return point[0] >= rect.x && point[0] <= rect.x + rect.width && point[1] >= rect.y && point[1] <= rect.y + rect.height;\n}\n/**\n * Generates a safe polygon area that the user can traverse without closing the\n * floating element once leaving the reference element.\n * @see https://floating-ui.com/docs/useHover#safepolygon\n */\nfunction safePolygon(options) {\n if (options === void 0) {\n options = {};\n }\n const {\n buffer = 0.5,\n blockPointerEvents = false,\n requireIntent = true\n } = options;\n const timeoutRef = {\n current: -1\n };\n let hasLanded = false;\n let lastX = null;\n let lastY = null;\n let lastCursorTime = typeof performance !== 'undefined' ? performance.now() : 0;\n function getCursorSpeed(x, y) {\n const currentTime = performance.now();\n const elapsedTime = currentTime - lastCursorTime;\n if (lastX === null || lastY === null || elapsedTime === 0) {\n lastX = x;\n lastY = y;\n lastCursorTime = currentTime;\n return null;\n }\n const deltaX = x - lastX;\n const deltaY = y - lastY;\n const distance = Math.sqrt(deltaX * deltaX + deltaY * deltaY);\n const speed = distance / elapsedTime; // px / ms\n\n lastX = x;\n lastY = y;\n lastCursorTime = currentTime;\n return speed;\n }\n const fn = _ref => {\n let {\n x,\n y,\n placement,\n elements,\n onClose,\n nodeId,\n tree\n } = _ref;\n return function onMouseMove(event) {\n function close() {\n clearTimeoutIfSet(timeoutRef);\n onClose();\n }\n clearTimeoutIfSet(timeoutRef);\n if (!elements.domReference || !elements.floating || placement == null || x == null || y == null) {\n return;\n }\n const {\n clientX,\n clientY\n } = event;\n const clientPoint = [clientX, clientY];\n const target = getTarget(event);\n const isLeave = event.type === 'mouseleave';\n const isOverFloatingEl = contains(elements.floating, target);\n const isOverReferenceEl = contains(elements.domReference, target);\n const refRect = elements.domReference.getBoundingClientRect();\n const rect = elements.floating.getBoundingClientRect();\n const side = placement.split('-')[0];\n const cursorLeaveFromRight = x > rect.right - rect.width / 2;\n const cursorLeaveFromBottom = y > rect.bottom - rect.height / 2;\n const isOverReferenceRect = isInside(clientPoint, refRect);\n const isFloatingWider = rect.width > refRect.width;\n const isFloatingTaller = rect.height > refRect.height;\n const left = (isFloatingWider ? refRect : rect).left;\n const right = (isFloatingWider ? refRect : rect).right;\n const top = (isFloatingTaller ? refRect : rect).top;\n const bottom = (isFloatingTaller ? refRect : rect).bottom;\n if (isOverFloatingEl) {\n hasLanded = true;\n if (!isLeave) {\n return;\n }\n }\n if (isOverReferenceEl) {\n hasLanded = false;\n }\n if (isOverReferenceEl && !isLeave) {\n hasLanded = true;\n return;\n }\n\n // Prevent overlapping floating element from being stuck in an open-close\n // loop: https://github.com/floating-ui/floating-ui/issues/1910\n if (isLeave && isElement(event.relatedTarget) && contains(elements.floating, event.relatedTarget)) {\n return;\n }\n\n // If any nested child is open, abort.\n if (tree && getNodeChildren(tree.nodesRef.current, nodeId).length) {\n return;\n }\n\n // If the pointer is leaving from the opposite side, the \"buffer\" logic\n // creates a point where the floating element remains open, but should be\n // ignored.\n // A constant of 1 handles floating point rounding errors.\n if (side === 'top' && y >= refRect.bottom - 1 || side === 'bottom' && y <= refRect.top + 1 || side === 'left' && x >= refRect.right - 1 || side === 'right' && x <= refRect.left + 1) {\n return close();\n }\n\n // Ignore when the cursor is within the rectangular trough between the\n // two elements. Since the triangle is created from the cursor point,\n // which can start beyond the ref element's edge, traversing back and\n // forth from the ref to the floating element can cause it to close. This\n // ensures it always remains open in that case.\n let rectPoly = [];\n switch (side) {\n case 'top':\n rectPoly = [[left, refRect.top + 1], [left, rect.bottom - 1], [right, rect.bottom - 1], [right, refRect.top + 1]];\n break;\n case 'bottom':\n rectPoly = [[left, rect.top + 1], [left, refRect.bottom - 1], [right, refRect.bottom - 1], [right, rect.top + 1]];\n break;\n case 'left':\n rectPoly = [[rect.right - 1, bottom], [rect.right - 1, top], [refRect.left + 1, top], [refRect.left + 1, bottom]];\n break;\n case 'right':\n rectPoly = [[refRect.right - 1, bottom], [refRect.right - 1, top], [rect.left + 1, top], [rect.left + 1, bottom]];\n break;\n }\n function getPolygon(_ref2) {\n let [x, y] = _ref2;\n switch (side) {\n case 'top':\n {\n const cursorPointOne = [isFloatingWider ? x + buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y + buffer + 1];\n const cursorPointTwo = [isFloatingWider ? x - buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y + buffer + 1];\n const commonPoints = [[rect.left, cursorLeaveFromRight ? rect.bottom - buffer : isFloatingWider ? rect.bottom - buffer : rect.top], [rect.right, cursorLeaveFromRight ? isFloatingWider ? rect.bottom - buffer : rect.top : rect.bottom - buffer]];\n return [cursorPointOne, cursorPointTwo, ...commonPoints];\n }\n case 'bottom':\n {\n const cursorPointOne = [isFloatingWider ? x + buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y - buffer];\n const cursorPointTwo = [isFloatingWider ? x - buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y - buffer];\n const commonPoints = [[rect.left, cursorLeaveFromRight ? rect.top + buffer : isFloatingWider ? rect.top + buffer : rect.bottom], [rect.right, cursorLeaveFromRight ? isFloatingWider ? rect.top + buffer : rect.bottom : rect.top + buffer]];\n return [cursorPointOne, cursorPointTwo, ...commonPoints];\n }\n case 'left':\n {\n const cursorPointOne = [x + buffer + 1, isFloatingTaller ? y + buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n const cursorPointTwo = [x + buffer + 1, isFloatingTaller ? y - buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n const commonPoints = [[cursorLeaveFromBottom ? rect.right - buffer : isFloatingTaller ? rect.right - buffer : rect.left, rect.top], [cursorLeaveFromBottom ? isFloatingTaller ? rect.right - buffer : rect.left : rect.right - buffer, rect.bottom]];\n return [...commonPoints, cursorPointOne, cursorPointTwo];\n }\n case 'right':\n {\n const cursorPointOne = [x - buffer, isFloatingTaller ? y + buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n const cursorPointTwo = [x - buffer, isFloatingTaller ? y - buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n const commonPoints = [[cursorLeaveFromBottom ? rect.left + buffer : isFloatingTaller ? rect.left + buffer : rect.right, rect.top], [cursorLeaveFromBottom ? isFloatingTaller ? rect.left + buffer : rect.right : rect.left + buffer, rect.bottom]];\n return [cursorPointOne, cursorPointTwo, ...commonPoints];\n }\n }\n }\n if (isPointInPolygon([clientX, clientY], rectPoly)) {\n return;\n }\n if (hasLanded && !isOverReferenceRect) {\n return close();\n }\n if (!isLeave && requireIntent) {\n const cursorSpeed = getCursorSpeed(event.clientX, event.clientY);\n const cursorSpeedThreshold = 0.1;\n if (cursorSpeed !== null && cursorSpeed < cursorSpeedThreshold) {\n return close();\n }\n }\n if (!isPointInPolygon([clientX, clientY], getPolygon([x, y]))) {\n close();\n } else if (!hasLanded && requireIntent) {\n timeoutRef.current = window.setTimeout(close, 40);\n }\n };\n };\n fn.__options = {\n blockPointerEvents\n };\n return fn;\n}\n\nexport { Composite, CompositeItem, FloatingArrow, FloatingDelayGroup, FloatingFocusManager, FloatingList, FloatingNode, FloatingOverlay, FloatingPortal, FloatingTree, NextFloatingDelayGroup, inner, safePolygon, useClick, useClientPoint, useDelayGroup, useDelayGroupContext, useDismiss, useFloating, useFloatingNodeId, useFloatingParentNodeId, useFloatingPortalNode, useFloatingRootContext, useFloatingTree, useFocus, useHover, useId, useInnerOffset, useInteractions, useListItem, useListNavigation, useMergeRefs, useNextDelayGroup, useRole, useTransitionStatus, useTransitionStyles, useTypeahead };\n","import cn from \"classnames\";\nimport * as React from \"react\";\nimport type { PropsWithChildren } from \"react\";\nimport css from \"./InputCaption.module.scss\";\n\ninterface InputCaptionProps {\n isFullWidth?: boolean;\n}\n\nexport const InputCaption: React.FC<PropsWithChildren<InputCaptionProps>> = ({\n children,\n isFullWidth,\n}) => (\n <p className={cn(css.errorCaption, { [css.fullWidth]: isFullWidth })}>{children}</p>\n);\n","// src/primitive.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NODES = [\n \"a\",\n \"button\",\n \"div\",\n \"form\",\n \"h2\",\n \"h3\",\n \"img\",\n \"input\",\n \"label\",\n \"li\",\n \"nav\",\n \"ol\",\n \"p\",\n \"select\",\n \"span\",\n \"svg\",\n \"ul\"\n];\nvar Primitive = NODES.reduce((primitive, node) => {\n const Slot = createSlot(`Primitive.${node}`);\n const Node = React.forwardRef((props, forwardedRef) => {\n const { asChild, ...primitiveProps } = props;\n const Comp = asChild ? Slot : node;\n if (typeof window !== \"undefined\") {\n window[Symbol.for(\"radix-ui\")] = true;\n }\n return /* @__PURE__ */ jsx(Comp, { ...primitiveProps, ref: forwardedRef });\n });\n Node.displayName = `Primitive.${node}`;\n return { ...primitive, [node]: Node };\n}, {});\nfunction dispatchDiscreteCustomEvent(target, event) {\n if (target) ReactDOM.flushSync(() => target.dispatchEvent(event));\n}\nvar Root = Primitive;\nexport {\n Primitive,\n Root,\n dispatchDiscreteCustomEvent\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/label.tsx\nimport * as React from \"react\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NAME = \"Label\";\nvar Label = React.forwardRef((props, forwardedRef) => {\n return /* @__PURE__ */ jsx(\n Primitive.label,\n {\n ...props,\n ref: forwardedRef,\n onMouseDown: (event) => {\n const target = event.target;\n if (target.closest(\"button, input, select, textarea\")) return;\n props.onMouseDown?.(event);\n if (!event.defaultPrevented && event.detail > 1) event.preventDefault();\n }\n }\n );\n});\nLabel.displayName = NAME;\nvar Root = Label;\nexport {\n Label,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as LabelPrimitive from \"@radix-ui/react-label\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst labelVariants = cva(\n \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\",\n);\n\nconst Label = React.forwardRef<\n React.ElementRef<typeof LabelPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> & VariantProps<typeof labelVariants>\n>(({ className, ...props }, ref) => (\n <LabelPrimitive.Root ref={ref} className={cn(labelVariants(), className)} {...props} />\n));\nLabel.displayName = LabelPrimitive.Root.displayName;\n\nexport { Label };\n","import cn from \"classnames\";\nimport type { ReactNode } from \"react\";\nimport { Label as UiLabel } from \"@/components/ui/label\";\nimport css from \"./Label.module.scss\";\n\nexport interface LabelProps {\n htmlFor?: string;\n children: ReactNode;\n className?: string;\n}\n\nexport const Label = ({ htmlFor, children, className }: LabelProps) => (\n <UiLabel htmlFor={htmlFor} className={cn(css.label, className)}>\n {typeof children === \"string\" ? <div className={css.label__text}>{children}</div> : children}\n </UiLabel>\n);\n","import cn from \"classnames\";\nimport { FC, MouseEvent, PropsWithChildren, memo } from \"react\";\nimport { CrossIcon } from \"../../icons\";\nimport css from \"./Tag.module.scss\";\n\ninterface Props {\n className?: string;\n onClick?: () => void;\n isSubjectEmployee?: boolean;\n isSmall?: boolean;\n}\n\nexport const Tag: FC<PropsWithChildren<Props>> = memo(({ className, children, onClick, isSmall }) => (\n <div className={cn(css.wrapper, className, isSmall && css.wrapper_small)}>\n <span>{children}</span>\n {onClick && (\n <CrossIcon\n className={cn(css.iconCross, { [css.iconCross_small]: isSmall })}\n onClick={(e: MouseEvent<SVGSVGElement>) => {\n e.stopPropagation();\n onClick();\n }}\n />\n )}\n </div>\n));\n","import ReactDOM from \"react-dom\";\nimport { autoUpdate, flip, offset as floatingOffset, size, useFloating } from \"@floating-ui/react\";\nimport cn from \"classnames\";\nimport React, { ReactNode, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { InputCaption } from \"../InputCaption/InputCaption\";\nimport { Label } from \"../Label/Label\";\nimport { Spinner } from \"../Spinner/Spinner\";\nimport { EmptyComponent } from \"../EmptyComponent/EmptyComponent\";\nimport { ArrowDownIcon, SearchIcon, CrossIcon } from \"../../icons\";\nimport { Button } from \"../Button/Button\";\nimport { Tag } from \"../Tag/Tag\";\nimport css from \"./Select.module.scss\";\n\nconst DROPDOWN_MARGIN = 6;\n\nexport interface CustomOption<T, S = string> {\n value: S;\n label: string;\n meta?: T;\n}\n\nexport type SelectColumn<T, S> = {\n key: string;\n title: ReactNode;\n className?: string;\n render: (option: CustomOption<T, S>) => ReactNode;\n};\n\ntype ModeProps<T, S> =\n | {\n mode: \"single\";\n value?: CustomOption<T, S> | null;\n }\n | { mode: \"multiple\"; value: CustomOption<T, S>[] };\n\ntype CustomSelectProps<T, S> = {\n onChange?: (option: CustomOption<T, S>) => void;\n options?: CustomOption<T, S>[];\n placeholder: string;\n dropdownRender?: (menu: ReactNode) => ReactNode;\n optionRender?: (option: CustomOption<T, S>) => ReactNode;\n selectedOptionRender?: (option: CustomOption<T, S>) => ReactNode;\n tagRender?: (option: CustomOption<T, S>) => ReactNode;\n emptyComponent?: ReactNode;\n dropdownIcon?: ReactNode;\n dropDownClassName?: string;\n optionClassName?: string;\n inputClassName?: string;\n tagClassName?: string;\n searchClassName?: string;\n searchPlaceholder?: string;\n deleteIconClassName?: string;\n onDelete?: (option: CustomOption<T, S>) => void;\n onClear?: () => void;\n icon?: ReactNode;\n label?: ReactNode;\n onSearch?: (value: string) => void;\n isLoading?: boolean;\n disabled?: boolean;\n onClose?: () => void;\n portalTarget?: Element;\n error?: string | null;\n fixedHeight?: boolean;\n template?: \"list\" | \"table\";\n columns?: SelectColumn<T, S>[];\n total?: number;\n} & ModeProps<T, S>;\n\nconst SelectedOptions = <T, S>({\n value,\n selectedOptionRender,\n tagRender,\n onDelete,\n}: Pick<\n CustomSelectProps<T, S>,\n \"value\" | \"selectedOptionRender\" | \"tagRender\" | \"onDelete\"\n>): React.ReactElement | null => {\n if (!value) {\n return null;\n }\n\n if (!Array.isArray(value)) {\n return (\n <span className={css.selectedOption}>\n {selectedOptionRender ? selectedOptionRender(value) : value.label}\n </span>\n );\n }\n\n return (\n <div className={css.tagContainer}>\n {value.map((item, index) =>\n tagRender ? (\n <React.Fragment key={index}>{tagRender(item)}</React.Fragment>\n ) : (\n <Tag\n isSmall\n key={index}\n {...(onDelete && {\n onClick: () => onDelete?.(item),\n })}\n >\n {item.label}\n </Tag>\n ),\n )}\n </div>\n );\n};\n\ninterface SearchProps<T, S> extends Pick<\n CustomSelectProps<T, S>,\n \"onSearch\" | \"searchClassName\" | \"isLoading\"\n> {\n searchValue: string;\n placeholder?: string;\n}\n\nconst Search = <T, S>({\n onSearch,\n searchClassName,\n searchValue,\n isLoading,\n placeholder,\n}: SearchProps<T, S>) => (\n <div className={cn(css.search, searchClassName)}>\n <SearchIcon className={css.search__icon} />\n <input\n className={css.search__input}\n value={searchValue}\n onChange={(e) => onSearch?.(e.target.value)}\n placeholder={placeholder}\n />\n {isLoading && <Spinner size=\"extraSmall\" className={css.search__spinner} />}\n </div>\n);\n\ninterface DropdownProps<T, S> extends Pick<\n CustomSelectProps<T, S>,\n | \"value\"\n | \"options\"\n | \"optionClassName\"\n | \"optionRender\"\n | \"onSearch\"\n | \"searchClassName\"\n | \"isLoading\"\n | \"searchPlaceholder\"\n> {\n onChange: (value: CustomOption<T, S>) => void;\n searchValue: string;\n}\n\nconst Dropdown = <T, S>({\n value,\n options,\n optionClassName,\n optionRender,\n onChange,\n onSearch,\n searchClassName,\n isLoading,\n searchValue,\n searchPlaceholder,\n}: DropdownProps<T, S>): React.ReactElement | null => {\n const checkIsActive = (option: CustomOption<T, S>) =>\n Array.isArray(value)\n ? value.some((item) => item.value === option.value)\n : value?.value === option.value;\n return (\n <>\n {onSearch && (\n <Search\n onSearch={onSearch}\n searchValue={searchValue}\n searchClassName={searchClassName}\n isLoading={isLoading}\n placeholder={searchPlaceholder}\n />\n )}\n {options && !!options.length ? (\n <ul className={cn({ [css.withSearch]: onSearch })}>\n {options.map((option, index) => {\n const isActive = checkIsActive(option);\n const isPrevActive = options[index - 1] && checkIsActive(options[index - 1]);\n const isNextActive = options[index + 1] && checkIsActive(options[index + 1]);\n\n return (\n <li\n key={`${option.value}${index}`}\n className={cn(\n css.option,\n {\n [css.option_active]: isActive,\n [css.option_active_prev_active]: isPrevActive,\n [css.option_active_next_active]: isNextActive,\n },\n optionClassName,\n )}\n onClick={() => onChange(option)}\n >\n {optionRender ? optionRender(option) : option.label}\n </li>\n );\n })}\n </ul>\n ) : (\n !isLoading && <EmptyComponent />\n )}\n </>\n );\n};\n\ninterface TableDropdownProps<T, S> extends Pick<\n CustomSelectProps<T, S>,\n | \"value\"\n | \"options\"\n | \"onSearch\"\n | \"searchClassName\"\n | \"isLoading\"\n | \"searchPlaceholder\"\n | \"columns\"\n | \"total\"\n | \"onDelete\"\n> {\n mode: \"single\" | \"multiple\";\n onChange: (value: CustomOption<T, S>) => void;\n searchValue: string;\n}\n\nconst TableDropdown = <T, S>({\n value,\n options,\n onChange,\n onDelete,\n onSearch,\n searchClassName,\n isLoading,\n searchValue,\n searchPlaceholder,\n columns,\n total,\n mode,\n}: TableDropdownProps<T, S>): React.ReactElement | null => {\n const checkIsActive = (option: CustomOption<T, S>) =>\n Array.isArray(value)\n ? value.some((item) => item.value === option.value)\n : value?.value === option.value;\n\n const handleRowToggle = (option: CustomOption<T, S>, isActive: boolean) => {\n if (mode === \"multiple\" && isActive && onDelete) {\n onDelete(option);\n return;\n }\n onChange(option);\n };\n\n const totalLabel = total ?? options?.length ?? 0;\n const safeColumns = columns ?? [];\n\n return (\n <div className={css.tableTemplate}>\n {onSearch && (\n <Search\n onSearch={onSearch}\n searchValue={searchValue}\n searchClassName={searchClassName}\n isLoading={isLoading}\n placeholder={searchPlaceholder}\n />\n )}\n <div className={css.tableContainer}>\n {options && options.length ? (\n <table className={css.table}>\n <thead>\n <tr>\n <th className={css.checkboxCell} aria-label=\"\" />\n {safeColumns.map((column) => (\n <th key={column.key} className={column.className}>\n {column.title}\n </th>\n ))}\n </tr>\n </thead>\n <tbody>\n {options.map((option, index) => {\n const isActive = checkIsActive(option);\n return (\n <tr\n key={`${String(option.value)}${index}`}\n className={cn({ [css.activeRow]: isActive })}\n onClick={() => handleRowToggle(option, isActive)}\n >\n <td className={css.checkboxCell}>\n <input\n type=\"checkbox\"\n className={css.checkbox}\n checked={isActive}\n readOnly\n tabIndex={-1}\n onClick={(e) => e.stopPropagation()}\n onChange={() => handleRowToggle(option, isActive)}\n />\n </td>\n {safeColumns.map((column) => (\n <td key={column.key} className={column.className}>\n {column.render(option)}\n </td>\n ))}\n </tr>\n );\n })}\n </tbody>\n </table>\n ) : (\n !isLoading && <EmptyComponent />\n )}\n </div>\n <div className={css.footerTotal}>Всего {totalLabel}</div>\n </div>\n );\n};\n\nexport const Select = <T, S extends string | number>({\n options,\n value,\n mode,\n placeholder,\n onChange,\n dropdownRender,\n optionRender,\n selectedOptionRender,\n dropdownIcon,\n tagRender,\n dropDownClassName,\n optionClassName,\n inputClassName,\n deleteIconClassName,\n onDelete,\n onClear,\n label,\n onSearch,\n searchClassName,\n searchPlaceholder,\n isLoading,\n disabled,\n onClose,\n portalTarget,\n error,\n fixedHeight = true,\n template = \"list\",\n columns,\n total,\n}: CustomSelectProps<T, S>) => {\n const [isOpen, setIsOpen] = useState(false);\n const [isMounted, setIsMounted] = useState(false);\n const containerRef = useRef<HTMLDivElement>(null);\n const dropDownRef = useRef<HTMLDivElement>(null);\n const inputRef = useRef<HTMLDivElement>(null);\n\n const [searchValue, setSearchValue] = useState(\"\");\n const resolvedPortalTarget =\n portalTarget ?? (isMounted && typeof document !== \"undefined\" ? document.body : undefined);\n\n useEffect(() => {\n setIsMounted(true);\n }, []);\n\n const handleSearch = useCallback(\n (value: string) => {\n setSearchValue(value);\n onSearch?.(value);\n },\n [onSearch],\n );\n\n useEffect(() => {\n if (!isOpen) {\n return;\n }\n\n const handleClickOutside = (event: MouseEvent) => {\n if (\n containerRef.current &&\n !containerRef.current.contains(event.target as Node) &&\n (!dropDownRef.current || !dropDownRef.current.contains(event.target as Node))\n ) {\n handleSearch(\"\");\n setIsOpen(false);\n onClose?.();\n }\n };\n\n document.addEventListener(\"mousedown\", handleClickOutside, true);\n\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside, true);\n };\n }, [handleSearch, isOpen, onClose]);\n\n const { refs, floatingStyles, update } = useFloating({\n strategy: \"absolute\",\n placement: \"bottom-start\",\n open: isOpen,\n whileElementsMounted: (reference, floating, updatePosition) =>\n autoUpdate(reference, floating, updatePosition, {\n ancestorScroll: false,\n elementResize: true,\n ancestorResize: true,\n layoutShift: true,\n }),\n middleware: [\n floatingOffset(DROPDOWN_MARGIN),\n flip({\n fallbackPlacements: [\"top-start\", \"bottom-start\"],\n }),\n size({\n apply({ rects, elements }) {\n const nextWidth = `${Math.round(rects.reference.width)}px`;\n if (elements.floating.style.width !== nextWidth) {\n elements.floating.style.width = nextWidth;\n }\n },\n }),\n ],\n });\n\n const setReference = useCallback(\n (node: HTMLDivElement | null) => {\n inputRef.current = node;\n refs.setReference(node);\n },\n [refs],\n );\n\n const setFloating = useCallback(\n (node: HTMLDivElement | null) => {\n dropDownRef.current = node;\n refs.setFloating(node);\n },\n [refs],\n );\n\n useEffect(() => {\n if (!isOpen) {\n return;\n }\n\n update();\n }, [isOpen, update]);\n\n const handleChange = useCallback(\n (newValue: CustomOption<T, S>) => {\n onChange?.(newValue);\n\n handleSearch(\"\");\n onClose?.();\n\n if (mode === \"single\") {\n setIsOpen(false);\n }\n },\n [handleSearch, mode, onChange, onClose],\n );\n\n const renderDropdown = useCallback(() => {\n const dropdownContent = (\n <div\n ref={setFloating}\n className={cn(css.dropdown, { [css.dropdown_visible]: isOpen }, dropDownClassName)}\n style={floatingStyles}\n onClick={(e) => e.stopPropagation()}\n >\n <div className={css.dropdownContent} style={{ height: fixedHeight ? \"300px\" : \"none\" }}>\n {(() => {\n const menu =\n template === \"table\" ? (\n <TableDropdown\n value={value}\n options={options}\n onChange={handleChange}\n onDelete={onDelete}\n {...(onSearch && { onSearch: handleSearch })}\n searchClassName={searchClassName}\n isLoading={isLoading}\n searchValue={searchValue}\n searchPlaceholder={searchPlaceholder}\n columns={columns}\n total={total}\n mode={mode}\n />\n ) : (\n <Dropdown\n value={value}\n options={options}\n optionClassName={optionClassName}\n optionRender={optionRender}\n onChange={handleChange}\n {...(onSearch && { onSearch: handleSearch })}\n searchClassName={searchClassName}\n isLoading={isLoading}\n searchValue={searchValue}\n searchPlaceholder={searchPlaceholder}\n />\n );\n return dropdownRender ? dropdownRender(menu) : menu;\n })()}\n </div>\n </div>\n );\n\n if (resolvedPortalTarget) {\n return ReactDOM.createPortal(dropdownContent, resolvedPortalTarget);\n }\n\n return dropdownContent;\n }, [\n dropDownClassName,\n dropdownRender,\n fixedHeight,\n floatingStyles,\n handleChange,\n handleSearch,\n isLoading,\n isOpen,\n onSearch,\n optionClassName,\n optionRender,\n options,\n resolvedPortalTarget,\n template,\n columns,\n total,\n mode,\n onDelete,\n searchClassName,\n searchPlaceholder,\n searchValue,\n setFloating,\n value,\n ]);\n\n const dropdown = useMemo(\n () => (isMounted ? renderDropdown() : null),\n [isMounted, renderDropdown],\n );\n\n const hasValue = Array.isArray(value) ? !!value.length : !!value;\n\n return (\n <div className={css.wrapper}>\n {label && <Label htmlFor=\"CustomSelectInput\">{label}</Label>}\n <div className={css.container} ref={containerRef}>\n <div\n role=\"button\"\n id=\"CustomSelectInput\"\n tabIndex={0}\n ref={setReference}\n className={cn(\n css.input,\n { [css.input_fixedHeight]: mode === \"single\", [css.disabled]: disabled },\n error && css.error,\n inputClassName,\n )}\n onClick={() => {\n if (value) {\n handleSearch(\"\");\n onClose?.();\n }\n setIsOpen((value) => !value);\n }}\n >\n <div className={css.selectedOptionContainer}>\n {hasValue ? (\n <SelectedOptions\n value={value}\n selectedOptionRender={selectedOptionRender}\n tagRender={tagRender}\n onDelete={onDelete}\n />\n ) : (\n <span className={css.placeHolder}>{placeholder}</span>\n )}\n </div>\n <div className={css.iconContainer}>\n {onClear && hasValue && (\n <>\n <Button\n variant=\"text\"\n className={cn(css.deleteIcon, deleteIconClassName)}\n onClick={(e) => {\n e.stopPropagation();\n onClear();\n }}\n >\n <span>\n <CrossIcon />\n </span>\n </Button>\n <div className={css.divider}>\n <div />\n </div>\n </>\n )}\n\n {dropdownIcon || (\n <Button\n variant=\"text\"\n className={cn(css.arrowIcon, {\n [css.arrowIconExpanded]: isOpen,\n })}\n >\n <ArrowDownIcon />\n </Button>\n )}\n </div>\n </div>\n {dropdown}\n </div>\n {error && <InputCaption>{error}</InputCaption>}\n </div>\n );\n};\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/dialog.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContext, createContextScope } from \"@radix-ui/react-context\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { FocusScope } from \"@radix-ui/react-focus-scope\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useFocusGuards } from \"@radix-ui/react-focus-guards\";\nimport { RemoveScroll } from \"react-remove-scroll\";\nimport { hideOthers } from \"aria-hidden\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { Fragment, jsx, jsxs } from \"react/jsx-runtime\";\nvar DIALOG_NAME = \"Dialog\";\nvar [createDialogContext, createDialogScope] = createContextScope(DIALOG_NAME);\nvar [DialogProvider, useDialogContext] = createDialogContext(DIALOG_NAME);\nvar Dialog = (props) => {\n const {\n __scopeDialog,\n children,\n open: openProp,\n defaultOpen,\n onOpenChange,\n modal = true\n } = props;\n const triggerRef = React.useRef(null);\n const contentRef = React.useRef(null);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: DIALOG_NAME\n });\n return /* @__PURE__ */ jsx(\n DialogProvider,\n {\n scope: __scopeDialog,\n triggerRef,\n contentRef,\n contentId: useId(),\n titleId: useId(),\n descriptionId: useId(),\n open,\n onOpenChange: setOpen,\n onOpenToggle: React.useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen]),\n modal,\n children\n }\n );\n};\nDialog.displayName = DIALOG_NAME;\nvar TRIGGER_NAME = \"DialogTrigger\";\nvar DialogTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...triggerProps } = props;\n const context = useDialogContext(TRIGGER_NAME, __scopeDialog);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.triggerRef);\n return /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n \"aria-haspopup\": \"dialog\",\n \"aria-expanded\": context.open,\n \"aria-controls\": context.contentId,\n \"data-state\": getState(context.open),\n ...triggerProps,\n ref: composedTriggerRef,\n onClick: composeEventHandlers(props.onClick, context.onOpenToggle)\n }\n );\n }\n);\nDialogTrigger.displayName = TRIGGER_NAME;\nvar PORTAL_NAME = \"DialogPortal\";\nvar [PortalProvider, usePortalContext] = createDialogContext(PORTAL_NAME, {\n forceMount: void 0\n});\nvar DialogPortal = (props) => {\n const { __scopeDialog, forceMount, children, container } = props;\n const context = useDialogContext(PORTAL_NAME, __scopeDialog);\n return /* @__PURE__ */ jsx(PortalProvider, { scope: __scopeDialog, forceMount, children: React.Children.map(children, (child) => /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, container, children: child }) })) });\n};\nDialogPortal.displayName = PORTAL_NAME;\nvar OVERLAY_NAME = \"DialogOverlay\";\nvar DialogOverlay = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(OVERLAY_NAME, props.__scopeDialog);\n const { forceMount = portalContext.forceMount, ...overlayProps } = props;\n const context = useDialogContext(OVERLAY_NAME, props.__scopeDialog);\n return context.modal ? /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(DialogOverlayImpl, { ...overlayProps, ref: forwardedRef }) }) : null;\n }\n);\nDialogOverlay.displayName = OVERLAY_NAME;\nvar Slot = createSlot(\"DialogOverlay.RemoveScroll\");\nvar DialogOverlayImpl = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...overlayProps } = props;\n const context = useDialogContext(OVERLAY_NAME, __scopeDialog);\n return (\n // Make sure `Content` is scrollable even when it doesn't live inside `RemoveScroll`\n // ie. when `Overlay` and `Content` are siblings\n /* @__PURE__ */ jsx(RemoveScroll, { as: Slot, allowPinchZoom: true, shards: [context.contentRef], children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-state\": getState(context.open),\n ...overlayProps,\n ref: forwardedRef,\n style: { pointerEvents: \"auto\", ...overlayProps.style }\n }\n ) })\n );\n }\n);\nvar CONTENT_NAME = \"DialogContent\";\nvar DialogContent = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeDialog);\n const { forceMount = portalContext.forceMount, ...contentProps } = props;\n const context = useDialogContext(CONTENT_NAME, props.__scopeDialog);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: context.modal ? /* @__PURE__ */ jsx(DialogContentModal, { ...contentProps, ref: forwardedRef }) : /* @__PURE__ */ jsx(DialogContentNonModal, { ...contentProps, ref: forwardedRef }) });\n }\n);\nDialogContent.displayName = CONTENT_NAME;\nvar DialogContentModal = React.forwardRef(\n (props, forwardedRef) => {\n const context = useDialogContext(CONTENT_NAME, props.__scopeDialog);\n const contentRef = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, context.contentRef, contentRef);\n React.useEffect(() => {\n const content = contentRef.current;\n if (content) return hideOthers(content);\n }, []);\n return /* @__PURE__ */ jsx(\n DialogContentImpl,\n {\n ...props,\n ref: composedRefs,\n trapFocus: context.open,\n disableOutsidePointerEvents: true,\n onCloseAutoFocus: composeEventHandlers(props.onCloseAutoFocus, (event) => {\n event.preventDefault();\n context.triggerRef.current?.focus();\n }),\n onPointerDownOutside: composeEventHandlers(props.onPointerDownOutside, (event) => {\n const originalEvent = event.detail.originalEvent;\n const ctrlLeftClick = originalEvent.button === 0 && originalEvent.ctrlKey === true;\n const isRightClick = originalEvent.button === 2 || ctrlLeftClick;\n if (isRightClick) event.preventDefault();\n }),\n onFocusOutside: composeEventHandlers(\n props.onFocusOutside,\n (event) => event.preventDefault()\n )\n }\n );\n }\n);\nvar DialogContentNonModal = React.forwardRef(\n (props, forwardedRef) => {\n const context = useDialogContext(CONTENT_NAME, props.__scopeDialog);\n const hasInteractedOutsideRef = React.useRef(false);\n const hasPointerDownOutsideRef = React.useRef(false);\n return /* @__PURE__ */ jsx(\n DialogContentImpl,\n {\n ...props,\n ref: forwardedRef,\n trapFocus: false,\n disableOutsidePointerEvents: false,\n onCloseAutoFocus: (event) => {\n props.onCloseAutoFocus?.(event);\n if (!event.defaultPrevented) {\n if (!hasInteractedOutsideRef.current) context.triggerRef.current?.focus();\n event.preventDefault();\n }\n hasInteractedOutsideRef.current = false;\n hasPointerDownOutsideRef.current = false;\n },\n onInteractOutside: (event) => {\n props.onInteractOutside?.(event);\n if (!event.defaultPrevented) {\n hasInteractedOutsideRef.current = true;\n if (event.detail.originalEvent.type === \"pointerdown\") {\n hasPointerDownOutsideRef.current = true;\n }\n }\n const target = event.target;\n const targetIsTrigger = context.triggerRef.current?.contains(target);\n if (targetIsTrigger) event.preventDefault();\n if (event.detail.originalEvent.type === \"focusin\" && hasPointerDownOutsideRef.current) {\n event.preventDefault();\n }\n }\n }\n );\n }\n);\nvar DialogContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, trapFocus, onOpenAutoFocus, onCloseAutoFocus, ...contentProps } = props;\n const context = useDialogContext(CONTENT_NAME, __scopeDialog);\n const contentRef = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, contentRef);\n useFocusGuards();\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(\n FocusScope,\n {\n asChild: true,\n loop: true,\n trapped: trapFocus,\n onMountAutoFocus: onOpenAutoFocus,\n onUnmountAutoFocus: onCloseAutoFocus,\n children: /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n role: \"dialog\",\n id: context.contentId,\n \"aria-describedby\": context.descriptionId,\n \"aria-labelledby\": context.titleId,\n \"data-state\": getState(context.open),\n ...contentProps,\n ref: composedRefs,\n onDismiss: () => context.onOpenChange(false)\n }\n )\n }\n ),\n /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(TitleWarning, { titleId: context.titleId }),\n /* @__PURE__ */ jsx(DescriptionWarning, { contentRef, descriptionId: context.descriptionId })\n ] })\n ] });\n }\n);\nvar TITLE_NAME = \"DialogTitle\";\nvar DialogTitle = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...titleProps } = props;\n const context = useDialogContext(TITLE_NAME, __scopeDialog);\n return /* @__PURE__ */ jsx(Primitive.h2, { id: context.titleId, ...titleProps, ref: forwardedRef });\n }\n);\nDialogTitle.displayName = TITLE_NAME;\nvar DESCRIPTION_NAME = \"DialogDescription\";\nvar DialogDescription = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...descriptionProps } = props;\n const context = useDialogContext(DESCRIPTION_NAME, __scopeDialog);\n return /* @__PURE__ */ jsx(Primitive.p, { id: context.descriptionId, ...descriptionProps, ref: forwardedRef });\n }\n);\nDialogDescription.displayName = DESCRIPTION_NAME;\nvar CLOSE_NAME = \"DialogClose\";\nvar DialogClose = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...closeProps } = props;\n const context = useDialogContext(CLOSE_NAME, __scopeDialog);\n return /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n ...closeProps,\n ref: forwardedRef,\n onClick: composeEventHandlers(props.onClick, () => context.onOpenChange(false))\n }\n );\n }\n);\nDialogClose.displayName = CLOSE_NAME;\nfunction getState(open) {\n return open ? \"open\" : \"closed\";\n}\nvar TITLE_WARNING_NAME = \"DialogTitleWarning\";\nvar [WarningProvider, useWarningContext] = createContext(TITLE_WARNING_NAME, {\n contentName: CONTENT_NAME,\n titleName: TITLE_NAME,\n docsSlug: \"dialog\"\n});\nvar TitleWarning = ({ titleId }) => {\n const titleWarningContext = useWarningContext(TITLE_WARNING_NAME);\n const MESSAGE = `\\`${titleWarningContext.contentName}\\` requires a \\`${titleWarningContext.titleName}\\` for the component to be accessible for screen reader users.\n\nIf you want to hide the \\`${titleWarningContext.titleName}\\`, you can wrap it with our VisuallyHidden component.\n\nFor more information, see https://radix-ui.com/primitives/docs/components/${titleWarningContext.docsSlug}`;\n React.useEffect(() => {\n if (titleId) {\n const hasTitle = document.getElementById(titleId);\n if (!hasTitle) console.error(MESSAGE);\n }\n }, [MESSAGE, titleId]);\n return null;\n};\nvar DESCRIPTION_WARNING_NAME = \"DialogDescriptionWarning\";\nvar DescriptionWarning = ({ contentRef, descriptionId }) => {\n const descriptionWarningContext = useWarningContext(DESCRIPTION_WARNING_NAME);\n const MESSAGE = `Warning: Missing \\`Description\\` or \\`aria-describedby={undefined}\\` for {${descriptionWarningContext.contentName}}.`;\n React.useEffect(() => {\n const describedById = contentRef.current?.getAttribute(\"aria-describedby\");\n if (descriptionId && describedById) {\n const hasDescription = document.getElementById(descriptionId);\n if (!hasDescription) console.warn(MESSAGE);\n }\n }, [MESSAGE, contentRef, descriptionId]);\n return null;\n};\nvar Root = Dialog;\nvar Trigger = DialogTrigger;\nvar Portal = DialogPortal;\nvar Overlay = DialogOverlay;\nvar Content = DialogContent;\nvar Title = DialogTitle;\nvar Description = DialogDescription;\nvar Close = DialogClose;\nexport {\n Close,\n Content,\n Description,\n Dialog,\n DialogClose,\n DialogContent,\n DialogDescription,\n DialogOverlay,\n DialogPortal,\n DialogTitle,\n DialogTrigger,\n Overlay,\n Portal,\n Root,\n Title,\n Trigger,\n WarningProvider,\n createDialogScope\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Dialog = DialogPrimitive.Root;\n\nconst DialogTrigger = DialogPrimitive.Trigger;\n\nconst DialogPortal = DialogPrimitive.Portal;\n\nconst DialogClose = DialogPrimitive.Close;\n\nconst DialogOverlay = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Overlay\n ref={ref}\n className={cn(\n \"fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n className,\n )}\n {...props}\n />\n));\nDialogOverlay.displayName = DialogPrimitive.Overlay.displayName;\n\nconst DialogContent = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content>\n>(({ className, children, ...props }, ref) => (\n <DialogPortal>\n <DialogOverlay />\n <DialogPrimitive.Content\n ref={ref}\n className={cn(\n \"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg\",\n className,\n )}\n {...props}\n >\n {children}\n </DialogPrimitive.Content>\n </DialogPortal>\n));\nDialogContent.displayName = DialogPrimitive.Content.displayName;\n\nconst DialogHeader = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div className={cn(\"flex flex-col space-y-1.5 text-center sm:text-left\", className)} {...props} />\n);\nDialogHeader.displayName = \"DialogHeader\";\n\nconst DialogFooter = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2\", className)}\n {...props}\n />\n);\nDialogFooter.displayName = \"DialogFooter\";\n\nconst DialogTitle = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Title\n ref={ref}\n className={cn(\"text-lg font-semibold leading-none tracking-tight\", className)}\n {...props}\n />\n));\nDialogTitle.displayName = DialogPrimitive.Title.displayName;\n\nconst DialogDescription = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Description\n ref={ref}\n className={cn(\"text-sm text-muted-foreground\", className)}\n {...props}\n />\n));\nDialogDescription.displayName = DialogPrimitive.Description.displayName;\n\nexport {\n Dialog,\n DialogPortal,\n DialogOverlay,\n DialogTrigger,\n DialogClose,\n DialogContent,\n DialogHeader,\n DialogFooter,\n DialogTitle,\n DialogDescription,\n};\n","import cn from \"classnames\";\nimport React, { ReactNode, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport {\n Dialog,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogTitle,\n} from \"@/components/ui/dialog\";\nimport { Button } from \"../Button/Button\";\nimport { EmptyComponent } from \"../EmptyComponent/EmptyComponent\";\nimport { InputCaption } from \"../InputCaption/InputCaption\";\nimport { Label } from \"../Label/Label\";\nimport { Spinner } from \"../Spinner/Spinner\";\nimport { CrossIcon, SearchIcon } from \"../../icons\";\nimport type { CustomOption } from \"../Select/Select\";\nimport css from \"./DialogSelect.module.scss\";\n\nconst DEFAULT_PAGE_SIZE = 8;\nconst DEFAULT_DEBOUNCE_MS = 350;\n\ntype LoadOptionsParams = {\n search: string;\n page: number;\n pageSize: number;\n};\n\ntype LoadOptionsResult<T, S extends string | number> = {\n options: CustomOption<T, S>[];\n total?: number;\n hasNextPage?: boolean;\n};\n\nexport type DialogSelectColumn<T, S extends string | number> = {\n key: string;\n title: ReactNode;\n className?: string;\n render: (option: CustomOption<T, S>) => ReactNode;\n};\n\nexport interface DialogSelectProps<T, S extends string | number> {\n value?: CustomOption<T, S> | null;\n placeholder: string;\n loadOptions: (params: LoadOptionsParams) => Promise<LoadOptionsResult<T, S>>;\n onChange?: (option: CustomOption<T, S>) => void;\n onClear?: () => void;\n columns?: DialogSelectColumn<T, S>[];\n label?: ReactNode;\n title?: ReactNode;\n searchPlaceholder?: string;\n selectButtonText?: string;\n closeButtonText?: string;\n manualButtonText?: string;\n onManualAdd?: () => void;\n pageSize?: number;\n debounceMs?: number;\n disabled?: boolean;\n error?: string | null;\n className?: string;\n inputClassName?: string;\n selectedOptionRender?: (option: CustomOption<T, S>) => ReactNode;\n}\n\nexport const DialogSelect = <T, S extends string | number>({\n value,\n placeholder,\n loadOptions,\n onChange,\n onClear,\n columns,\n label,\n title = \"Поиск сотрудника\",\n searchPlaceholder = \"Введите запрос\",\n selectButtonText = \"Выбрать\",\n closeButtonText = \"Закрыть\",\n manualButtonText = \"Добавить вручную\",\n onManualAdd,\n pageSize = DEFAULT_PAGE_SIZE,\n debounceMs = DEFAULT_DEBOUNCE_MS,\n disabled,\n error,\n className,\n inputClassName,\n selectedOptionRender,\n}: DialogSelectProps<T, S>) => {\n const [isOpen, setIsOpen] = useState(false);\n const [search, setSearch] = useState(\"\");\n const [debouncedSearch, setDebouncedSearch] = useState(\"\");\n const [page, setPage] = useState(1);\n const [options, setOptions] = useState<CustomOption<T, S>[]>([]);\n const [total, setTotal] = useState<number | undefined>();\n const [hasNextPage, setHasNextPage] = useState(false);\n const [isLoading, setIsLoading] = useState(false);\n const requestIdRef = useRef(0);\n\n const tableColumns = useMemo<DialogSelectColumn<T, S>[]>(\n () =>\n columns ?? [\n {\n key: \"label\",\n title: \"ФИО сотрудника\",\n render: (option) => option.label,\n },\n {\n key: \"birthDate\",\n title: \"День рождения\",\n render: (option) => {\n const meta = option.meta as { birthDate?: ReactNode } | undefined;\n return meta?.birthDate ?? \"—\";\n },\n },\n ],\n [columns],\n );\n\n const totalPages = total ? Math.max(1, Math.ceil(total / pageSize)) : undefined;\n const canGoPrevious = page > 1;\n const canGoNext = totalPages ? page < totalPages : hasNextPage;\n\n useEffect(() => {\n const timeoutId = window.setTimeout(() => {\n setDebouncedSearch(search.trim());\n setPage(1);\n }, debounceMs);\n\n return () => window.clearTimeout(timeoutId);\n }, [debounceMs, search]);\n\n useEffect(() => {\n if (!isOpen) {\n return;\n }\n\n const requestId = requestIdRef.current + 1;\n requestIdRef.current = requestId;\n setIsLoading(true);\n\n loadOptions({ search: debouncedSearch, page, pageSize })\n .then((result) => {\n if (requestIdRef.current !== requestId) {\n return;\n }\n\n setOptions(result.options);\n setTotal(result.total);\n setHasNextPage(result.hasNextPage ?? false);\n })\n .finally(() => {\n if (requestIdRef.current === requestId) {\n setIsLoading(false);\n }\n });\n }, [debouncedSearch, isOpen, loadOptions, page, pageSize]);\n\n const handleOpenChange = useCallback((open: boolean) => {\n setIsOpen(open);\n\n if (!open) {\n setSearch(\"\");\n setDebouncedSearch(\"\");\n setPage(1);\n }\n }, []);\n\n const handleSelect = useCallback(\n (option: CustomOption<T, S>) => {\n onChange?.(option);\n handleOpenChange(false);\n },\n [handleOpenChange, onChange],\n );\n\n const selectedContent = value\n ? selectedOptionRender\n ? selectedOptionRender(value)\n : value.label\n : placeholder;\n\n return (\n <div className={cn(css.wrapper, className)}>\n {label && <Label htmlFor=\"DialogSelectInput\">{label}</Label>}\n <div\n id=\"DialogSelectInput\"\n role=\"button\"\n tabIndex={disabled ? -1 : 0}\n className={cn(css.input, { [css.disabled]: disabled, [css.error]: error }, inputClassName)}\n onClick={() => !disabled && handleOpenChange(true)}\n onKeyDown={(event) => {\n if (!disabled && (event.key === \"Enter\" || event.key === \" \")) {\n event.preventDefault();\n handleOpenChange(true);\n }\n }}\n >\n <span className={cn(css.selectedOption, { [css.placeholder]: !value })}>\n {selectedContent}\n </span>\n <span className={css.actions}>\n {onClear && value && (\n <Button\n variant=\"text\"\n className={css.clearButton}\n aria-label=\"Очистить выбранное значение\"\n onClick={(event) => {\n event.stopPropagation();\n onClear();\n }}\n >\n <CrossIcon />\n </Button>\n )}\n <Button\n variant=\"link\"\n className={css.selectButton}\n disabled={disabled}\n onClick={(event) => {\n event.stopPropagation();\n handleOpenChange(true);\n }}\n >\n {selectButtonText}\n </Button>\n </span>\n </div>\n\n <Dialog open={isOpen} onOpenChange={handleOpenChange}>\n <DialogContent className={css.dialogContent}>\n <DialogHeader className={css.dialogHeader}>\n <DialogTitle className={css.dialogTitle}>{title}</DialogTitle>\n </DialogHeader>\n\n <div className={css.search}>\n <SearchIcon className={css.searchIcon} />\n <input\n className={css.searchInput}\n value={search}\n onChange={(event) => setSearch(event.target.value)}\n placeholder={searchPlaceholder}\n autoFocus\n />\n {isLoading && <Spinner size=\"extraSmall\" className={css.searchSpinner} />}\n </div>\n\n <div className={css.tableContainer}>\n <table className={css.table}>\n <thead>\n <tr>\n {tableColumns.map((column) => (\n <th key={column.key} className={column.className}>\n {column.title}\n </th>\n ))}\n </tr>\n </thead>\n <tbody>\n {options.map((option) => {\n const isActive = value?.value === option.value;\n\n return (\n <tr\n key={String(option.value)}\n className={cn({ [css.activeRow]: isActive })}\n onClick={() => handleSelect(option)}\n >\n {tableColumns.map((column) => (\n <td key={column.key} className={column.className}>\n {column.render(option)}\n </td>\n ))}\n </tr>\n );\n })}\n </tbody>\n </table>\n\n {!isLoading && !options.length && (\n <div className={css.emptyState}>\n <EmptyComponent\n title=\"Ничего не найдено\"\n subtitle=\"Попробуйте изменить поисковый запрос\"\n />\n </div>\n )}\n </div>\n\n <DialogFooter className={css.dialogFooter}>\n <div className={css.pagination}>\n <Button\n variant=\"secondary\"\n size=\"small\"\n disabled={!canGoPrevious || isLoading}\n onClick={() => setPage((currentPage) => Math.max(1, currentPage - 1))}\n >\n Назад\n </Button>\n <span className={css.pageInfo}>\n Страница {page}\n {totalPages ? ` из ${totalPages}` : \"\"}\n </span>\n <Button\n variant=\"secondary\"\n size=\"small\"\n disabled={!canGoNext || isLoading}\n onClick={() => setPage((currentPage) => currentPage + 1)}\n >\n Вперёд\n </Button>\n </div>\n <div className={css.footerActions}>\n {onManualAdd && (\n <Button variant=\"primary\" onClick={onManualAdd}>\n {manualButtonText}\n </Button>\n )}\n <Button variant=\"secondary\" onClick={() => handleOpenChange(false)}>\n {closeButtonText}\n </Button>\n </div>\n </DialogFooter>\n </DialogContent>\n </Dialog>\n\n {error && <InputCaption>{error}</InputCaption>}\n </div>\n );\n};\n","import cn from \"classnames\";\nimport React, {\n ReactNode,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport {\n Dialog,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogTitle,\n} from \"@/components/ui/dialog\";\nimport { Button } from \"../Button/Button\";\nimport { EmptyComponent } from \"../EmptyComponent/EmptyComponent\";\nimport { InputCaption } from \"../InputCaption/InputCaption\";\nimport { Label } from \"../Label/Label\";\nimport { Spinner } from \"../Spinner/Spinner\";\nimport { ArrowDownIcon, CrossIcon, SearchIcon } from \"../../icons\";\nimport css from \"./TreeDialogSelect.module.scss\";\n\nconst DEFAULT_DEBOUNCE_MS = 350;\nconst ROOT_KEY = \"__root__\" as const;\n\nexport type TreeNode<T, S extends string | number> = {\n value: S;\n label: string;\n hasChildren?: boolean;\n meta?: T;\n};\n\nexport type TreeLoadParams<S extends string | number> = {\n parentId: S | null;\n search: string;\n};\n\nexport type TreeLoadResult<T, S extends string | number> = {\n nodes: TreeNode<T, S>[];\n};\n\nexport type TreeSearchResult<T, S extends string | number> = {\n matches: Array<{ node: TreeNode<T, S>; path: TreeNode<T, S>[] }>;\n};\n\nexport interface TreeDialogSelectProps<T, S extends string | number> {\n value?: TreeNode<T, S> | null;\n placeholder: string;\n loadChildren: (params: TreeLoadParams<S>) => Promise<TreeLoadResult<T, S>>;\n searchNodes?: (search: string) => Promise<TreeSearchResult<T, S>>;\n onChange?: (node: TreeNode<T, S>) => void;\n onClear?: () => void;\n label?: ReactNode;\n title?: ReactNode;\n searchPlaceholder?: string;\n selectButtonText?: string;\n closeButtonText?: string;\n confirmButtonText?: string;\n debounceMs?: number;\n disabled?: boolean;\n error?: string | null;\n className?: string;\n inputClassName?: string;\n selectedOptionRender?: (node: TreeNode<T, S>) => ReactNode;\n nodeRender?: (node: TreeNode<T, S>) => ReactNode;\n}\n\ntype Key<S extends string | number> = S | typeof ROOT_KEY;\n\nexport const TreeDialogSelect = <T, S extends string | number>({\n value,\n placeholder,\n loadChildren,\n searchNodes,\n onChange,\n onClear,\n label,\n title = \"Выбор элемента\",\n searchPlaceholder = \"Введите запрос\",\n selectButtonText = \"Выбрать\",\n closeButtonText = \"Закрыть\",\n confirmButtonText = \"Выбрать\",\n debounceMs = DEFAULT_DEBOUNCE_MS,\n disabled,\n error,\n className,\n inputClassName,\n selectedOptionRender,\n nodeRender,\n}: TreeDialogSelectProps<T, S>) => {\n const [isOpen, setIsOpen] = useState(false);\n const [search, setSearch] = useState(\"\");\n const [debouncedSearch, setDebouncedSearch] = useState(\"\");\n\n const [childrenCache, setChildrenCache] = useState<Map<Key<S>, TreeNode<T, S>[]>>(\n () => new Map(),\n );\n const [loadingNodes, setLoadingNodes] = useState<Set<Key<S>>>(() => new Set());\n const [expanded, setExpanded] = useState<Set<S>>(() => new Set());\n const [forcedExpanded, setForcedExpanded] = useState<Set<S>>(() => new Set());\n const [searchMatches, setSearchMatches] = useState<Set<S>>(() => new Set());\n const [isSearching, setIsSearching] = useState(false);\n const [pendingSelection, setPendingSelection] = useState<TreeNode<T, S> | null>(null);\n\n const rootRequestIdRef = useRef(0);\n const searchRequestIdRef = useRef(0);\n\n // Загрузка корня при открытии\n useEffect(() => {\n if (!isOpen) return;\n if (childrenCache.has(ROOT_KEY)) return;\n\n const requestId = rootRequestIdRef.current + 1;\n rootRequestIdRef.current = requestId;\n\n setLoadingNodes((prev) => {\n const next = new Set(prev);\n next.add(ROOT_KEY);\n return next;\n });\n\n loadChildren({ parentId: null, search: \"\" })\n .then((result) => {\n if (rootRequestIdRef.current !== requestId) return;\n setChildrenCache((prev) => {\n const next = new Map(prev);\n next.set(ROOT_KEY, result.nodes);\n return next;\n });\n })\n .finally(() => {\n if (rootRequestIdRef.current !== requestId) return;\n setLoadingNodes((prev) => {\n const next = new Set(prev);\n next.delete(ROOT_KEY);\n return next;\n });\n });\n }, [isOpen, loadChildren, childrenCache]);\n\n // debounce поиска\n useEffect(() => {\n const id = window.setTimeout(() => setDebouncedSearch(search.trim()), debounceMs);\n return () => window.clearTimeout(id);\n }, [search, debounceMs]);\n\n // Серверный поиск\n useEffect(() => {\n if (!isOpen) return;\n if (!searchNodes) return;\n if (!debouncedSearch) {\n setSearchMatches(new Set());\n setForcedExpanded(new Set());\n return;\n }\n\n const requestId = searchRequestIdRef.current + 1;\n searchRequestIdRef.current = requestId;\n setIsSearching(true);\n\n searchNodes(debouncedSearch)\n .then((result) => {\n if (searchRequestIdRef.current !== requestId) return;\n\n const matches = new Set<S>();\n const ancestorsToExpand = new Set<S>();\n // Кэшируем path-узлы как «дети» для авто-раскрытия\n const inferredChildren = new Map<Key<S>, Map<S, TreeNode<T, S>>>();\n\n for (const item of result.matches) {\n matches.add(item.node.value);\n\n const fullPath = [...item.path, item.node];\n for (let i = 0; i < fullPath.length - 1; i++) {\n const parent = fullPath[i];\n const child = fullPath[i + 1];\n ancestorsToExpand.add(parent.value);\n\n const parentKey: Key<S> = parent.value;\n if (!inferredChildren.has(parentKey)) {\n inferredChildren.set(parentKey, new Map());\n }\n inferredChildren.get(parentKey)!.set(child.value, child);\n }\n // корневые узлы пути\n if (fullPath.length > 0) {\n const root = fullPath[0];\n if (!inferredChildren.has(ROOT_KEY)) {\n inferredChildren.set(ROOT_KEY, new Map());\n }\n inferredChildren.get(ROOT_KEY)!.set(root.value, root);\n }\n }\n\n setSearchMatches(matches);\n setForcedExpanded(ancestorsToExpand);\n setChildrenCache((prev) => {\n const next = new Map(prev);\n inferredChildren.forEach((map, key) => {\n const existing = next.get(key) ?? [];\n const merged = new Map<S, TreeNode<T, S>>();\n existing.forEach((n) => merged.set(n.value, n));\n map.forEach((n, k) => merged.set(k, n));\n next.set(key, Array.from(merged.values()));\n });\n return next;\n });\n })\n .finally(() => {\n if (searchRequestIdRef.current === requestId) setIsSearching(false);\n });\n }, [debouncedSearch, isOpen, searchNodes]);\n\n const handleOpenChange = useCallback((open: boolean) => {\n setIsOpen(open);\n if (!open) {\n setSearch(\"\");\n setDebouncedSearch(\"\");\n setPendingSelection(null);\n setSearchMatches(new Set());\n setForcedExpanded(new Set());\n }\n }, []);\n\n const ensureChildrenLoaded = useCallback(\n (parent: TreeNode<T, S>) => {\n const key: Key<S> = parent.value;\n if (childrenCache.has(key)) return;\n if (loadingNodes.has(key)) return;\n\n setLoadingNodes((prev) => {\n const next = new Set(prev);\n next.add(key);\n return next;\n });\n\n loadChildren({ parentId: parent.value, search: \"\" })\n .then((result) => {\n setChildrenCache((prev) => {\n const next = new Map(prev);\n const existing = next.get(key) ?? [];\n const merged = new Map<S, TreeNode<T, S>>();\n existing.forEach((n) => merged.set(n.value, n));\n result.nodes.forEach((n) => merged.set(n.value, n));\n next.set(key, Array.from(merged.values()));\n return next;\n });\n })\n .finally(() => {\n setLoadingNodes((prev) => {\n const next = new Set(prev);\n next.delete(key);\n return next;\n });\n });\n },\n [childrenCache, loadChildren, loadingNodes],\n );\n\n const toggleExpand = useCallback(\n (node: TreeNode<T, S>) => {\n setExpanded((prev) => {\n const next = new Set(prev);\n if (next.has(node.value)) {\n next.delete(node.value);\n } else {\n next.add(node.value);\n ensureChildrenLoaded(node);\n }\n return next;\n });\n },\n [ensureChildrenLoaded],\n );\n\n const handleSelectNode = useCallback((node: TreeNode<T, S>) => {\n setPendingSelection(node);\n }, []);\n\n const handleConfirm = useCallback(() => {\n if (pendingSelection) {\n onChange?.(pendingSelection);\n }\n handleOpenChange(false);\n }, [handleOpenChange, onChange, pendingSelection]);\n\n const isExpanded = useCallback(\n (nodeValue: S) => expanded.has(nodeValue) || forcedExpanded.has(nodeValue),\n [expanded, forcedExpanded],\n );\n\n // Клиентская фильтрация (когда нет searchNodes)\n const clientFilter = useCallback(\n (nodes: TreeNode<T, S>[]): TreeNode<T, S>[] => {\n if (!debouncedSearch || searchNodes) return nodes;\n const q = debouncedSearch.toLowerCase();\n return nodes.filter((n) => n.label.toLowerCase().includes(q));\n },\n [debouncedSearch, searchNodes],\n );\n\n const renderNode = (node: TreeNode<T, S>, level: number): ReactNode => {\n const key: Key<S> = node.value;\n const children = childrenCache.get(key);\n const isNodeExpanded = isExpanded(node.value);\n const isNodeLoading = loadingNodes.has(key);\n const isPending = pendingSelection?.value === node.value;\n const isCurrent = value?.value === node.value;\n const isMatch = searchMatches.has(node.value);\n\n const showChildren = isNodeExpanded && children && children.length > 0;\n const visibleChildren = showChildren ? clientFilter(children!) : [];\n\n return (\n <React.Fragment key={String(node.value)}>\n <div\n className={cn(css.row, {\n [css.row_active]: isPending || isCurrent,\n [css.row_match]: isMatch,\n })}\n style={{ paddingLeft: 16 + level * 20 }}\n onClick={() => handleSelectNode(node)}\n >\n {node.hasChildren ? (\n <button\n type=\"button\"\n className={cn(css.chevron, { [css.chevronExpanded]: isNodeExpanded })}\n onClick={(e) => {\n e.stopPropagation();\n toggleExpand(node);\n }}\n aria-label={isNodeExpanded ? \"Свернуть\" : \"Раскрыть\"}\n >\n <ArrowDownIcon />\n </button>\n ) : (\n <span className={css.chevronPlaceholder} />\n )}\n <span className={css.nodeLabel}>{nodeRender ? nodeRender(node) : node.label}</span>\n {isNodeLoading && <Spinner size=\"extraSmall\" className={css.nodeSpinner} />}\n </div>\n {showChildren &&\n visibleChildren.map((child) => renderNode(child, level + 1))}\n </React.Fragment>\n );\n };\n\n const rootNodes = childrenCache.get(ROOT_KEY) ?? [];\n const visibleRoots = clientFilter(rootNodes);\n const isRootLoading = loadingNodes.has(ROOT_KEY);\n\n const selectedContent = value\n ? selectedOptionRender\n ? selectedOptionRender(value)\n : value.label\n : placeholder;\n\n const showEmpty = !isRootLoading && !isSearching && visibleRoots.length === 0;\n\n const showSearchSpinner = useMemo(\n () => isSearching || (isRootLoading && Boolean(debouncedSearch)),\n [isSearching, isRootLoading, debouncedSearch],\n );\n\n return (\n <div className={cn(css.wrapper, className)}>\n {label && <Label htmlFor=\"TreeDialogSelectInput\">{label}</Label>}\n <div\n id=\"TreeDialogSelectInput\"\n role=\"button\"\n tabIndex={disabled ? -1 : 0}\n className={cn(\n css.input,\n { [css.disabled]: disabled, [css.error]: error },\n inputClassName,\n )}\n onClick={() => !disabled && handleOpenChange(true)}\n onKeyDown={(event) => {\n if (!disabled && (event.key === \"Enter\" || event.key === \" \")) {\n event.preventDefault();\n handleOpenChange(true);\n }\n }}\n >\n <span className={cn(css.selectedOption, { [css.placeholder]: !value })}>\n {selectedContent}\n </span>\n <span className={css.actions}>\n {onClear && value && (\n <Button\n variant=\"text\"\n className={css.clearButton}\n aria-label=\"Очистить выбранное значение\"\n onClick={(event) => {\n event.stopPropagation();\n onClear();\n }}\n >\n <CrossIcon />\n </Button>\n )}\n <Button\n variant=\"link\"\n className={css.selectButton}\n disabled={disabled}\n onClick={(event) => {\n event.stopPropagation();\n handleOpenChange(true);\n }}\n >\n {selectButtonText}\n </Button>\n </span>\n </div>\n\n <Dialog open={isOpen} onOpenChange={handleOpenChange}>\n <DialogContent className={css.dialogContent}>\n <DialogHeader className={css.dialogHeader}>\n <DialogTitle className={css.dialogTitle}>{title}</DialogTitle>\n </DialogHeader>\n\n <div className={css.search}>\n <SearchIcon className={css.searchIcon} />\n <input\n className={css.searchInput}\n value={search}\n onChange={(event) => setSearch(event.target.value)}\n placeholder={searchPlaceholder}\n autoFocus\n />\n {showSearchSpinner && (\n <Spinner size=\"extraSmall\" className={css.searchSpinner} />\n )}\n </div>\n\n <div className={css.treeContainer}>\n {isRootLoading && rootNodes.length === 0 ? (\n <div className={css.loadingState}>\n <Spinner size=\"small\" />\n </div>\n ) : showEmpty ? (\n <div className={css.emptyState}>\n <EmptyComponent\n title=\"Ничего не найдено\"\n subtitle=\"Попробуйте изменить поисковый запрос\"\n />\n </div>\n ) : (\n visibleRoots.map((node) => renderNode(node, 0))\n )}\n </div>\n\n <DialogFooter className={css.dialogFooter}>\n <Button variant=\"secondary\" onClick={() => handleOpenChange(false)}>\n {closeButtonText}\n </Button>\n <Button variant=\"primary\" disabled={!pendingSelection} onClick={handleConfirm}>\n {confirmButtonText}\n </Button>\n </DialogFooter>\n </DialogContent>\n </Dialog>\n\n {error && <InputCaption>{error}</InputCaption>}\n </div>\n );\n};","import cn from \"classnames\";\nimport * as React from \"react\";\nimport css from \"./TabsRounded.module.scss\";\n\ninterface Props {\n className?: string;\n tabsClassName?: string;\n items: { title: string; className?: string; needNotification?: boolean; header?: string }[];\n activeTab: number;\n onClick?: (activeTab: number) => void;\n}\n\nexport const TabsRounded: React.FC<Props> = React.memo(\n ({ className, items = [], activeTab, onClick, tabsClassName }) => (\n <div className={cn(css.wrapper, className)}>\n <div className={cn(css.tabs, tabsClassName)}>\n {items.map(\n (item, index) =>\n item.title && (\n <div\n key={index}\n className={cn(css.tabItem, item.className, {\n [css.active]: activeTab === index,\n [css.first]: index === 0,\n [css.last]: index === items.length - 1,\n })}\n style={{\n zIndex:\n activeTab === index ? items.length : index === 0 ? 0 : items.length - index,\n }}\n onClick={(e) => {\n e.stopPropagation();\n onClick?.(index);\n }}\n >\n {activeTab === index && index !== 0 && <span className={css.before} />}\n {item.title}\n {activeTab === index && index !== items.length - 1 && <span className={css.after} />}\n </div>\n ),\n )}\n </div>\n </div>\n ),\n);\n","import cn from \"classnames\";\nimport React, { ReactNode } from \"react\";\nimport { DoneIcon } from \"../../icons\";\nimport css from \"./Stepper.module.scss\";\n\nexport type StepperItem = {\n label?: ReactNode;\n content?: ReactNode;\n};\n\nexport interface StepperProps {\n items: StepperItem[];\n current: number;\n onChange?: (index: number) => void;\n showCheckOnCompleted?: boolean;\n className?: string;\n}\n\nexport const Stepper: React.FC<StepperProps> = ({\n items,\n current,\n onChange,\n showCheckOnCompleted = false,\n className,\n}) => {\n const isClickable = Boolean(onChange);\n\n return (\n <div className={cn(css.wrapper, className)} role=\"list\">\n {items.map((item, index) => {\n const isCompleted = index < current;\n const isCurrent = index === current;\n const isActive = index <= current;\n const isLast = index === items.length - 1;\n const showCheck = showCheckOnCompleted && isCompleted;\n\n const stepContent = item.content ?? (showCheck ? <DoneIcon /> : index + 1);\n\n const stepNode = (\n <button\n type=\"button\"\n className={cn(css.step, {\n [css.step_inactive]: !isActive,\n [css.step_current]: isCurrent,\n [css.clickable]: isClickable,\n })}\n disabled={!isClickable}\n onClick={() => onChange?.(index)}\n aria-current={isCurrent ? \"step\" : undefined}\n aria-label={typeof item.label === \"string\" ? item.label : `Шаг ${index + 1}`}\n >\n {stepContent}\n </button>\n );\n\n return (\n <React.Fragment key={index}>\n {item.label ? (\n <div className={css.itemBlock} role=\"listitem\">\n {stepNode}\n <span className={cn(css.label, { [css.label_active]: isActive })}>\n {item.label}\n </span>\n </div>\n ) : (\n <div role=\"listitem\">{stepNode}</div>\n )}\n {!isLast && (\n <span\n className={cn(css.connector, { [css.connector_active]: index < current })}\n />\n )}\n </React.Fragment>\n );\n })}\n </div>\n );\n};\n","import cn from \"classnames\";\nimport * as React from \"react\";\nimport { useEffect, useRef, useState } from \"react\";\nimport css from \"./Tabs.module.scss\";\n\ninterface TabsProps {\n items: { title: string; className?: string; header?: string }[];\n activeTab: number;\n changesIndex?: number;\n /** Arbitrary numeric label for the tab at `changesIndex` (semantics defined by the consumer). */\n badgeValue?: number;\n className?: string;\n tabsClassName?: string;\n sliderClassName?: string;\n onClick?: (activeTab: number) => void;\n}\n\nexport const Tabs = React.memo(\n ({\n items = [],\n activeTab,\n className,\n tabsClassName,\n changesIndex,\n badgeValue,\n sliderClassName,\n onClick,\n }: TabsProps) => {\n const tabRef = useRef<HTMLDivElement>(null);\n const animationFrameRef = useRef<number | null>(null);\n const [line, setLine] = useState({ left: 0, width: 0 });\n\n useEffect(() => {\n const node = tabRef.current;\n\n if (!node) {\n return;\n }\n\n const updateLine = () => {\n const nextLine = {\n left: node.offsetLeft || 0,\n width: node.clientWidth || 0,\n };\n\n setLine((prevLine) =>\n prevLine.left === nextLine.left && prevLine.width === nextLine.width\n ? prevLine\n : nextLine,\n );\n };\n\n const scheduleLineUpdate = () => {\n if (!!animationFrameRef.current) {\n cancelAnimationFrame(animationFrameRef.current);\n }\n\n animationFrameRef.current = requestAnimationFrame(() => {\n animationFrameRef.current = null;\n updateLine();\n });\n };\n\n scheduleLineUpdate();\n\n const resizeObserver = new ResizeObserver(() => {\n scheduleLineUpdate();\n });\n resizeObserver.observe(node);\n\n return () => {\n resizeObserver.disconnect();\n\n if (animationFrameRef.current !== null) {\n cancelAnimationFrame(animationFrameRef.current);\n animationFrameRef.current = null;\n }\n };\n }, [activeTab]);\n\n return (\n <div className={cn(css.container, className)}>\n <div className={cn(css.tabs, css.tabs_hasAnimatedIndicator, tabsClassName)}>\n {items.map(\n (item, index) =>\n item.title && (\n <div\n key={index}\n ref={activeTab === index ? tabRef : undefined}\n className={cn(css.tabItem, item.className, {\n [css.active]: activeTab === index,\n })}\n onClick={(e) => {\n e.stopPropagation();\n onClick?.(index);\n }}\n >\n {item.header && <div className={css.header}>{item.header}</div>}\n {item.title}\n {changesIndex === index && (\n <div className={css.notificationChanges}>\n {badgeValue != null\n ? badgeValue > 99\n ? \"99+\"\n : String(badgeValue)\n : null}\n </div>\n )}\n </div>\n ),\n )}\n <div\n className={cn(css.line, sliderClassName)}\n style={{\n left: line.left,\n width: line.width,\n }}\n />\n </div>\n </div>\n );\n },\n);\n","import cn from \"classnames\";\nimport React, { useState } from \"react\";\nimport {\n Dialog,\n DialogContent,\n DialogHeader,\n DialogTitle,\n} from \"@/components/ui/dialog\";\nimport { Button } from \"../Button/Button\";\nimport { DialogSelect } from \"../DialogSelect/DialogSelect\";\nimport { CrossIcon, DoneIcon, WarnIcon } from \"../../icons\";\nimport type { CustomOption } from \"../Select/Select\";\nimport css from \"./ApprovalRoute.module.scss\";\n\nexport type ApprovalStatus = \"pending\" | \"approved\" | \"rejected\";\n\nexport type Approver = {\n id: string;\n fullName: string;\n status?: ApprovalStatus;\n actedAt?: string;\n rejectReason?: string;\n};\n\nexport type ApprovalStage = {\n id: string;\n name: string;\n approvers: Approver[];\n};\n\nexport type ApprovalLevel = {\n id: string;\n name: string;\n status: \"completed\" | \"current\" | \"pending\";\n stages: ApprovalStage[];\n};\n\ntype LoadOptionsParams = { search: string; page: number; pageSize: number };\ntype LoadOptionsResult = { options: CustomOption<unknown, string>[]; total?: number };\n\nexport interface ApprovalRouteProps {\n levels: ApprovalLevel[];\n editable?: boolean;\n title?: string;\n eyebrow?: string;\n className?: string;\n loadApprovers?: (params: LoadOptionsParams) => Promise<LoadOptionsResult>;\n onAddLevel?: (name: string) => void;\n onRemoveLevel?: (levelId: string) => void;\n onAddStage?: (levelId: string, name: string) => void;\n onRemoveStage?: (levelId: string, stageId: string) => void;\n onAddApprover?: (\n levelId: string,\n stageId: string,\n person: CustomOption<unknown, string>,\n ) => void;\n onRemoveApprover?: (levelId: string, stageId: string, approverId: string) => void;\n}\n\nconst PlusIcon = ({ className }: { className?: string }) => (\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2.4\" strokeLinecap=\"round\" className={className} aria-hidden=\"true\">\n <path d=\"M12 5v14M5 12h14\" />\n </svg>\n);\n\nfunction NameDialog({\n open,\n title,\n placeholder,\n onSubmit,\n onClose,\n}: {\n open: boolean;\n title: string;\n placeholder: string;\n onSubmit: (name: string) => void;\n onClose: () => void;\n}) {\n const [value, setValue] = useState(\"\");\n\n React.useEffect(() => {\n if (!open) setValue(\"\");\n }, [open]);\n\n const submit = () => {\n const trimmed = value.trim();\n if (!trimmed) return;\n onSubmit(trimmed);\n onClose();\n };\n\n return (\n <Dialog open={open} onOpenChange={(o) => !o && onClose()}>\n <DialogContent className=\"sm:rounded-2xl\">\n <DialogHeader>\n <DialogTitle>{title}</DialogTitle>\n </DialogHeader>\n <div className={css.dialogContent}>\n <input\n autoFocus\n className={css.dialogInput}\n placeholder={placeholder}\n value={value}\n onChange={(e) => setValue(e.target.value)}\n onKeyDown={(e) => {\n if (e.key === \"Enter\") submit();\n if (e.key === \"Escape\") onClose();\n }}\n />\n <div className={css.dialogActions}>\n <Button variant=\"secondary\" onClick={onClose}>\n Отмена\n </Button>\n <Button variant=\"primary\" onClick={submit} disabled={!value.trim()}>\n Добавить\n </Button>\n </div>\n </div>\n </DialogContent>\n </Dialog>\n );\n}\n\nexport const ApprovalRoute: React.FC<ApprovalRouteProps> = ({\n levels,\n editable = false,\n title = \"Маршрут согласования\",\n eyebrow = \"Workflow\",\n className,\n loadApprovers,\n onAddLevel,\n onRemoveLevel,\n onAddStage,\n onRemoveStage,\n onAddApprover,\n onRemoveApprover,\n}) => {\n const [addLevelOpen, setAddLevelOpen] = useState(false);\n const [addStageFor, setAddStageFor] = useState<string | null>(null);\n\n return (\n <div className={cn(css.root, className)}>\n <div className={css.header}>\n <div className={css.headerText}>\n <span className={css.eyebrow}>{eyebrow}</span>\n <span className={css.title}>{title}</span>\n </div>\n </div>\n\n <div className={css.timeline}>\n {levels.map((level, index) => {\n const next = levels[index + 1];\n const railClass = cn(css.railLine, {\n [css.railLine_completed]: level.status === \"completed\" && next?.status === \"completed\",\n [css.railLine_toCurrent]:\n level.status === \"completed\" && next?.status === \"current\",\n });\n\n return (\n <div key={level.id} className={css.level}>\n <div className={css.rail}>\n {index < levels.length - 1 && <span className={railClass} />}\n <span\n className={cn(css.marker, {\n [css.marker_completed]: level.status === \"completed\",\n [css.marker_current]: level.status === \"current\",\n })}\n >\n {level.status === \"completed\" && <DoneIcon />}\n </span>\n </div>\n\n <div className={css.body}>\n <div className={css.levelHeader}>\n <span\n className={cn(css.levelName, {\n [css.levelName_current]: level.status === \"current\",\n [css.levelName_completed]: level.status === \"completed\",\n })}\n >\n {level.name}\n </span>\n {editable && (\n <>\n <button\n type=\"button\"\n className={css.iconButton}\n onClick={() => setAddStageFor(level.id)}\n aria-label=\"Добавить этап\"\n title=\"Добавить этап\"\n >\n <PlusIcon />\n </button>\n <button\n type=\"button\"\n className={cn(css.iconButton, css.iconButton_danger)}\n onClick={() => onRemoveLevel?.(level.id)}\n aria-label=\"Удалить уровень\"\n title=\"Удалить уровень\"\n >\n <CrossIcon />\n </button>\n </>\n )}\n </div>\n\n {level.stages.length > 0 && (\n <div className={css.stages}>\n {level.stages.map((stage) => (\n <div\n key={stage.id}\n className={cn(css.stage, {\n [css.stage_current]: level.status === \"current\",\n })}\n >\n <div className={css.stageHeader}>\n <span className={css.stageName}>{stage.name}</span>\n <div className={css.stageActions}>\n {editable && (\n <>\n {loadApprovers ? (\n <DialogSelect<unknown, string>\n value={null}\n placeholder=\"\"\n title=\"Добавить согласующего\"\n searchPlaceholder=\"Поиск сотрудника\"\n loadOptions={loadApprovers}\n onChange={(person) =>\n onAddApprover?.(level.id, stage.id, person)\n }\n className={css.approverPickerWrap}\n inputClassName={css.approverPickerInput}\n selectedOptionRender={() => <PlusIcon />}\n />\n ) : null}\n <button\n type=\"button\"\n className={cn(css.iconButton, css.iconButton_danger)}\n onClick={() => onRemoveStage?.(level.id, stage.id)}\n aria-label=\"Удалить этап\"\n title=\"Удалить этап\"\n >\n <CrossIcon />\n </button>\n </>\n )}\n </div>\n </div>\n\n {stage.approvers.length === 0 ? (\n <span className={css.empty}>\n <WarnIcon />\n Согласующий не назначен\n </span>\n ) : (\n <div className={css.approvers}>\n {stage.approvers.map((a) => {\n const status = a.status ?? \"pending\";\n return (\n <div key={a.id} className={css.approver}>\n <div className={css.approverMain}>\n <span\n className={cn(css.approverName, {\n [css.approverName_pending]: status === \"pending\",\n [css.approverName_approved]: status === \"approved\",\n [css.approverName_rejected]: status === \"rejected\",\n })}\n >\n {a.fullName}\n </span>\n {a.actedAt && status !== \"pending\" && (\n <span className={css.approverDate}>{a.actedAt}</span>\n )}\n {status === \"rejected\" && a.rejectReason && (\n <span className={css.rejectReason}>\n Причина: {a.rejectReason}\n </span>\n )}\n </div>\n {editable && (\n <button\n type=\"button\"\n className={cn(css.iconButton, css.iconButton_danger)}\n onClick={() => onRemoveApprover?.(level.id, stage.id, a.id)}\n aria-label=\"Удалить согласующего\"\n title=\"Удалить согласующего\"\n >\n <CrossIcon />\n </button>\n )}\n </div>\n );\n })}\n </div>\n )}\n </div>\n ))}\n </div>\n )}\n\n {editable && (\n <button\n type=\"button\"\n className={css.addStage}\n onClick={() => setAddStageFor(level.id)}\n >\n <PlusIcon /> Добавить этап\n </button>\n )}\n </div>\n </div>\n );\n })}\n\n {editable && (\n <div className={css.level}>\n <div className={css.rail}>\n <span className={cn(css.marker)} aria-hidden />\n </div>\n <div className={css.body}>\n <button\n type=\"button\"\n className={cn(css.addStage, css.addLevel)}\n onClick={() => setAddLevelOpen(true)}\n >\n <PlusIcon /> Добавить уровень\n </button>\n </div>\n </div>\n )}\n </div>\n\n <NameDialog\n open={addLevelOpen}\n title=\"Новый уровень\"\n placeholder=\"Название уровня\"\n onClose={() => setAddLevelOpen(false)}\n onSubmit={(name) => onAddLevel?.(name)}\n />\n\n <NameDialog\n open={addStageFor !== null}\n title=\"Новый этап\"\n placeholder=\"Название этапа\"\n onClose={() => setAddStageFor(null)}\n onSubmit={(name) => addStageFor && onAddStage?.(addStageFor, name)}\n />\n </div>\n );\n};\n"],"names":["SvgHome","props","React","SvgClock","SvgFileReload","SvgFolderEdit","SvgGraduate","SvgGrid","SvgHeart","SvgHelp","SvgList","SvgMarket","SvgPlane","SvgProfile","SvgProfileSearch","SvgTrendUp","SvgWallet","SvgTimesheet","SvgNotebook","SvgChart","SvgFeedback","SvgTaskList","SvgMegaphone","SvgUserSwitch","SvgFileSync","SvgChat","SvgSearch","SvgArrowRight","SvgArrowDown","SvgArrowDownBlue","SvgCross","SvgCloseRed","SvgCheckGreen","SvgHistoryBlue","SvgDone","SvgCancel","SvgWarn","SvgEnvelop","SvgMessage","SvgPhone","SvgCamera","SvgCopy","SvgInfo","SvgFilter","SvgEdit","SvgReload","SvgClockFilled","SvgEmpty","SvgSettings","SvgSchool","SvgIsland","SvgDownload","Colors","hasOwn","classNames","classes","i","arg","appendClass","parseValue","key","value","newClass","module","BaseBlock","id","title","subtitle","children","className","jsxs","cn","css","jsx","setRef","ref","composeRefs","refs","node","hasCleanup","cleanups","cleanup","useComposedRefs","REACT_LAZY_TYPE","use","isPromiseLike","isLazyComponent","element","createSlot","ownerName","SlotClone","createSlotClone","Slot2","forwardedRef","slotProps","childrenArray","slottable","isSlottable","newElement","newChildren","child","Slot","childrenRef","getElementRef","props2","mergeProps","SLOTTABLE_IDENTIFIER","childProps","overrideProps","propName","slotPropValue","childPropValue","args","result","getter","mayWarn","r","f","n","clsx","falsyToString","cx","cva","base","config","_config_compoundVariants","variants","defaultVariants","getVariantClassNames","variant","variantProp","defaultVariantProp","variantKey","propsWithoutUndefined","acc","param","getCompoundVariantClassNames","cvClass","cvClassName","compoundVariantOptions","concatArrays","array1","array2","combinedArray","createClassValidatorObject","classGroupId","validator","createClassPartObject","nextPart","validators","CLASS_PART_SEPARATOR","EMPTY_CONFLICTS","ARBITRARY_PROPERTY_PREFIX","createClassGroupUtils","classMap","createClassMap","conflictingClassGroups","conflictingClassGroupModifiers","getGroupIdForArbitraryProperty","classParts","startIndex","getGroupRecursive","hasPostfixModifier","modifierConflicts","baseConflicts","classPartObject","currentClassPart","nextClassPartObject","classRest","validatorsLength","validatorObj","content","colonIndex","property","theme","classGroups","processClassGroups","group","processClassesRecursively","classGroup","len","classDefinition","processClassDefinition","processStringDefinition","processFunctionDefinition","processObjectDefinition","classPartObjectToEdit","getPart","isThemeGetter","entries","path","current","parts","part","next","func","createLruCache","maxCacheSize","cacheSize","cache","previousCache","update","IMPORTANT_MODIFIER","MODIFIER_SEPARATOR","EMPTY_MODIFIERS","createResultObject","modifiers","hasImportantModifier","baseClassName","maybePostfixModifierPosition","isExternal","createParseClassName","prefix","experimentalParseClassName","parseClassName","bracketDepth","parenDepth","modifierStart","postfixModifierPosition","index","currentCharacter","baseClassNameWithImportantModifier","fullPrefix","parseClassNameOriginal","createSortModifiers","modifierWeights","mod","currentSegment","modifier","isArbitrary","isOrderSensitive","createConfigUtils","SPLIT_CLASSES_REGEX","mergeClassList","classList","configUtils","getClassGroupId","getConflictingClassGroupIds","sortModifiers","classGroupsInConflict","originalClassName","variantModifier","modifierId","classId","conflictGroups","twJoin","classLists","argument","resolvedValue","string","toValue","mix","k","createTailwindMerge","createConfigFirst","createConfigRest","cacheGet","cacheSet","functionToCall","initTailwindMerge","previousConfig","createConfigCurrent","tailwindMerge","cachedResult","fallbackThemeArr","fromTheme","themeGetter","arbitraryValueRegex","arbitraryVariableRegex","fractionRegex","tshirtUnitRegex","lengthUnitRegex","colorFunctionRegex","shadowRegex","imageRegex","isFraction","isNumber","isInteger","isPercent","isTshirtSize","isAny","isLengthOnly","isNever","isShadow","isImage","isAnyNonArbitrary","isArbitraryValue","isArbitraryVariable","isArbitrarySize","getIsArbitraryValue","isLabelSize","isArbitraryLength","isLabelLength","isArbitraryNumber","isLabelNumber","isArbitraryWeight","isLabelWeight","isArbitraryFamilyName","isLabelFamilyName","isArbitraryPosition","isLabelPosition","isArbitraryImage","isLabelImage","isArbitraryShadow","isLabelShadow","isArbitraryVariableLength","getIsArbitraryVariable","isArbitraryVariableFamilyName","isArbitraryVariablePosition","isArbitraryVariableSize","isArbitraryVariableImage","isArbitraryVariableShadow","isArbitraryVariableWeight","testLabel","testValue","shouldMatchNoLabel","label","getDefaultConfig","themeColor","themeFont","themeText","themeFontWeight","themeTracking","themeLeading","themeBreakpoint","themeContainer","themeSpacing","themeRadius","themeShadow","themeInsetShadow","themeTextShadow","themeDropShadow","themeBlur","themePerspective","themeAspect","themeEase","themeAnimate","scaleBreak","scalePosition","scalePositionWithArbitrary","scaleOverflow","scaleOverscroll","scaleUnambiguousSpacing","scaleInset","scaleGridTemplateColsRows","scaleGridColRowStartAndEnd","scaleGridColRowStartOrEnd","scaleGridAutoColsRows","scaleAlignPrimaryAxis","scaleAlignSecondaryAxis","scaleMargin","scaleSizing","scaleSizingInline","scaleSizingBlock","scaleColor","scaleBgPosition","scaleBgRepeat","scaleBgSize","scaleGradientStopPosition","scaleRadius","scaleBorderWidth","scaleLineStyle","scaleBlendMode","scaleMaskImagePosition","scaleBlur","scaleRotate","scaleScale","scaleSkew","scaleTranslate","twMerge","inputs","buttonVariants","Button","size","asChild","Spinner","marginTop","marginBottom","marginLeft","styles","useMemo","forwardRef","loading","disabled","type","rest","buttonClasses","UiButton","useMeasureElement","height","setHeight","useState","width","setWidth","rafRef","useRef","useEffect","resizeObserver","entry","borderBoxSize","initialHeight","WINDOW_SCROLL_OPTIONS","useDropdownPosition","triggerRef","dropdownHeight","offset","enabled","onAnchorFrame","position","setPosition","calculatePosition","useCallback","selectRect","viewportHeight","spaceAbove","updatePosition","nextPosition","trigger","mutationObserver","scrollableParents","parent","style","overflow","p","RadioGroupButton","data","activeButton","defaultActiveButton","onChange","_activeButton","setActiveButton","sliderPosition","setSliderPosition","buttonRefs","resolvedActiveButton","activeButtonWidth","_onChange","option","callbackRef","el","activeButtonIndex","button","buttonElement","buttonWidth","Card","memo","text","backgroundColor","imageUrl","textColor","link","containerClassname","containerStyle","isItemsMode","buildSlides","item","Children","isValidElement","pickCarouselSharedProps","shared","Carousel","slides","slideCount","carouselSharedProps","_dark","_enableTouch","_fade","_interval","keyboard","_pause","_ride","_slide","domProps","activeIndex","setActiveIndex","prev","previous","goToIndex","newIndex","isMany","indicatorItems","slide","handleKeyDown","event","GAP_PX","getTooltipPosition","rect","placement","left","right","top","bottom","centerX","centerY","getArrowDirection","TooltipDark","openProp","defaultOpen","mouseEnterDelay","mouseLeaveDelay","onOpenChange","arrow","overlayClassName","getPopupContainer","isControlled","internalOpen","setInternalOpen","open","setOpen","setStyle","enterTimerRef","leaveTimerRef","triggers","hasHover","hasClick","clearEnterTimer","clearLeaveTimer","handleMouseEnter","handleMouseLeave","handleClick","e","onDocClick","useLayoutEffect","container","arrowDirection","overlay","createPortal","Fragment","CopyTextTrigger","onClick","copied","tooltipText","ariaLabel","showIcon","CopyIcon","portalBody","composeEventHandlers","originalEventHandler","ourEventHandler","checkForDefaultPrevented","createContext2","rootComponentName","defaultContext","Context","Provider","context","useContext2","consumerName","createContextScope","scopeName","createContextScopeDeps","defaultContexts","createContext3","BaseContext","scope","createScope","scopeContexts","contexts","composeContextScopes","scopes","baseScope","scopeHooks","createScope2","overrideScopes","nextScopes","nextScopes2","useScope","currentScope","NODES","Primitive","primitive","Node","primitiveProps","Comp","dispatchDiscreteCustomEvent","target","ReactDOM","useCallbackRef","callback","useEscapeKeydown","onEscapeKeyDownProp","ownerDocument","onEscapeKeyDown","DISMISSABLE_LAYER_NAME","CONTEXT_UPDATE","POINTER_DOWN_OUTSIDE","FOCUS_OUTSIDE","originalBodyPointerEvents","DismissableLayerContext","DismissableLayer","disableOutsidePointerEvents","onPointerDownOutside","onFocusOutside","onInteractOutside","onDismiss","layerProps","setNode","force","composedRefs","node2","layers","highestLayerWithOutsidePointerEventsDisabled","highestLayerWithOutsidePointerEventsDisabledIndex","isBodyPointerEventsDisabled","isPointerEventsEnabled","pointerDownOutside","usePointerDownOutside","isPointerDownOnBranch","branch","focusOutside","useFocusOutside","dispatchUpdate","handleUpdate","BRANCH_NAME","DismissableLayerBranch","handlePointerDownOutside","isPointerInsideReactTreeRef","handleClickRef","handlePointerDown","handleAndDispatchPointerDownOutsideEvent2","handleAndDispatchCustomEvent","eventDetail","timerId","handleFocusOutside","isFocusInsideReactTreeRef","handleFocus","name","handler","detail","discrete","useLayoutEffect2","useReactId","count","useId","deterministicId","setId","reactId","sides","min","max","round","floor","createCoords","v","oppositeSideMap","clamp","start","end","evaluate","getSide","getAlignment","getOppositeAxis","axis","getAxisLength","getSideAxis","firstChar","getAlignmentAxis","getAlignmentSides","rects","rtl","alignment","alignmentAxis","length","mainAlignmentSide","getOppositePlacement","getExpandedPlacements","oppositePlacement","getOppositeAlignmentPlacement","lrPlacement","rlPlacement","tbPlacement","btPlacement","getSideList","side","isStart","getOppositeAxisPlacements","flipAlignment","direction","list","expandPaddingObject","padding","getPaddingObject","rectToClientRect","x","y","computeCoordsFromPlacement","_ref","reference","floating","sideAxis","alignLength","isVertical","commonX","commonY","commonAlign","coords","detectOverflow","state","options","_await$platform$isEle","platform","elements","strategy","boundary","rootBoundary","elementContext","altBoundary","paddingObject","clippingClientRect","offsetParent","offsetScale","elementClientRect","MAX_RESET_COUNT","computePosition","middleware","platformWithDetectOverflow","statefulPlacement","resetCount","middlewareData","currentMiddleware","fn","nextX","nextY","reset","arrowDimensions","isYAxis","minProp","maxProp","clientProp","endDiff","startDiff","arrowOffsetParent","clientSize","centerToReference","largestPossiblePadding","minPadding","maxPadding","min$1","center","shouldAddOffset","alignmentOffset","flip","_middlewareData$arrow","_middlewareData$flip","initialPlacement","checkMainAxis","checkCrossAxis","specifiedFallbackPlacements","fallbackStrategy","fallbackAxisSideDirection","detectOverflowOptions","initialSideAxis","isBasePlacement","fallbackPlacements","hasFallbackAxisSideDirection","placements","overflows","overflowsData","_middlewareData$flip2","_overflowsData$filter","nextIndex","nextPlacement","d","resetPlacement","a","b","_overflowsData$filter2","currentSideAxis","getSideOffsets","isAnySideFullyClipped","hide","offsets","originSides","convertValueToCoords","mainAxisMulti","crossAxisMulti","rawValue","mainAxis","crossAxis","_middlewareData$offse","diffCoords","shift","limiter","mainAxisCoord","crossAxisCoord","minSide","maxSide","limitedCoords","limitShift","rawOffset","computedOffset","limitMin","limitMax","_middlewareData$offse2","isOriginSide","_state$middlewareData","_state$middlewareData2","apply","heightSide","widthSide","maximumClippingHeight","maximumClippingWidth","overflowAvailableHeight","overflowAvailableWidth","noShift","availableHeight","availableWidth","xMin","xMax","yMin","yMax","nextDimensions","hasWindow","getNodeName","isNode","getWindow","_node$ownerDocument","getDocumentElement","isElement","isHTMLElement","isShadowRoot","isOverflowElement","overflowX","overflowY","display","getComputedStyle","isTableElement","isTopLayer","willChangeRe","containRe","isNotNone","isWebKitValue","isContainingBlock","elementOrCss","isWebKit","getContainingBlock","currentNode","getParentNode","isLastTraversableNode","getNodeScroll","getNearestOverflowAncestor","parentNode","getOverflowAncestors","traverseIframes","_node$ownerDocument2","scrollableAncestor","isBody","win","frameElement","getFrameElement","getCssDimensions","getComputedStyle$1","hasOffset","offsetWidth","offsetHeight","shouldFallback","unwrapElement","getScale","domElement","$","noOffsets","getVisualOffsets","shouldAddVisualOffsets","isFixed","floatingOffsetParent","getBoundingClientRect","includeScale","isFixedStrategy","clientRect","scale","visualOffsets","offsetWin","currentWin","currentIFrame","iframeScale","iframeRect","getWindowScrollBarX","leftScroll","getHTMLOffset","documentElement","scroll","htmlRect","convertOffsetParentRelativeRectToViewportRelativeRect","topLayer","isOffsetParentAnElement","offsetRect","htmlOffset","getClientRects","getDocumentRect","html","body","SCROLLBAR_MAX","getViewportRect","visualViewport","visualViewportBased","windowScrollbarX","doc","bodyStyles","bodyMarginInline","clippingStableScrollbarWidth","getInnerBoundingClientRect","getClientRectFromClippingAncestor","clippingAncestor","hasFixedPositionAncestor","stopNode","getClippingElementAncestors","currentContainingBlockComputedStyle","elementIsFixed","computedStyle","currentNodeIsContaining","ancestor","getClippingRect","clippingAncestors","firstRect","getDimensions","getRectRelativeToOffsetParent","setLeftRTLScrollbarOffset","isStaticPositioned","getTrueOffsetParent","polyfill","rawOffsetParent","getOffsetParent","svgOffsetParent","getElementRects","getOffsetParentFn","getDimensionsFn","floatingDimensions","isRTL","rectsAreEqual","observeMove","onMove","io","timeoutId","root","_io","refresh","skip","threshold","elementRectForRootMargin","insetTop","insetRight","insetBottom","insetLeft","isFirstUpdate","handleObserve","ratio","autoUpdate","ancestorScroll","ancestorResize","elementResize","layoutShift","animationFrame","referenceEl","ancestors","cleanupIo","reobserveFrame","firstEntry","_resizeObserver","frameId","prevRefRect","frameLoop","nextRefRect","_resizeObserver2","offset$1","shift$1","flip$1","size$1","hide$1","arrow$1","limitShift$1","mergedOptions","platformWithCache","computePosition$1","isClient","noop","deepEqual","keys","getDPR","roundByDPR","dpr","useLatestRef","useFloating","externalReference","externalFloating","transform","whileElementsMounted","setData","latestMiddleware","setLatestMiddleware","_reference","_setReference","_floating","_setFloating","setReference","referenceRef","setFloating","floatingRef","floatingEl","dataRef","hasWhileElementsMounted","whileElementsMountedRef","platformRef","openRef","fullData","isMountedRef","floatingStyles","initialStyles","isRef","arrow$2","deps","NAME","Arrow","arrowProps","Root","useSize","setSize","borderSizeEntry","borderSize","POPPER_NAME","createPopperContext","createPopperScope","PopperProvider","usePopperContext","Popper","__scopePopper","anchor","setAnchor","ANCHOR_NAME","PopperAnchor","virtualRef","anchorProps","anchorRef","previousAnchor","CONTENT_NAME","PopperContentProvider","useContentContext","PopperContent","sideOffset","align","alignOffset","arrowPadding","avoidCollisions","collisionBoundary","collisionPaddingProp","sticky","hideWhenDetached","updatePositionStrategy","onPlaced","contentProps","setContent","setArrow","arrowSize","arrowWidth","arrowHeight","desiredPlacement","collisionPadding","hasExplicitBoundaries","isNotNull","isPositioned","anchorWidth","anchorHeight","contentStyle","floatingUIarrow","transformOrigin","placedSide","placedAlign","getSideAndAlignFromPlacement","handlePlaced","arrowX","arrowY","cannotCenterArrow","contentZIndex","setContentZIndex","ARROW_NAME","OPPOSITE_SIDE","PopperArrow","contentContext","baseSide","ArrowPrimitive.Root","isArrowHidden","noArrowAlign","arrowXCenter","arrowYCenter","Root2","Anchor","Content","PORTAL_NAME","Portal","containerProp","portalProps","mounted","setMounted","useStateMachine","initialState","machine","Presence","present","presence","usePresence","React2","stylesRef","prevPresentRef","prevAnimationNameRef","send","currentAnimationName","getAnimationName","wasPresent","prevAnimationName","ownerWindow","handleAnimationEnd","isCurrentAnimation","currentFillMode","handleAnimationStart","createSlottable","Slottable2","Fragment2","useInsertionEffect","useControllableState","prop","defaultProp","caller","uncontrolledProp","setUncontrolledProp","onChangeRef","useUncontrolledState","isControlledRef","wasControlled","setValue","nextValue","value2","isFunction","prevValueRef","VISUALLY_HIDDEN_STYLES","VisuallyHidden","createTooltipContext","usePopperScope","PROVIDER_NAME","DEFAULT_DELAY_DURATION","TOOLTIP_OPEN","TooltipProviderContextProvider","useTooltipProviderContext","TooltipProvider","__scopeTooltip","delayDuration","skipDelayDuration","disableHoverableContent","isOpenDelayedRef","isPointerInTransitRef","skipDelayTimerRef","skipDelayTimer","inTransit","TOOLTIP_NAME","TooltipContextProvider","useTooltipContext","Tooltip","disableHoverableContentProp","delayDurationProp","providerContext","popperScope","setTrigger","contentId","openTimerRef","wasOpenDelayedRef","open2","stateAttribute","handleOpen","handleClose","handleDelayedOpen","PopperPrimitive.Root","TRIGGER_NAME","TooltipTrigger","triggerProps","isPointerDownRef","hasPointerMoveOpenedRef","handlePointerUp","PopperPrimitive.Anchor","PortalProvider","usePortalContext","TooltipPortal","forceMount","PortalPrimitive","TooltipContent","portalContext","TooltipContentImpl","TooltipContentHoverable","pointerGraceArea","setPointerGraceArea","onClose","onPointerInTransitChange","handleRemoveGraceArea","handleCreateGraceArea","hoverTarget","currentTarget","exitPoint","exitSide","getExitSideFromRect","paddedExitPoints","getPaddedExitPoints","hoverTargetPoints","getPointsFromRect","graceArea","getHull","handleTriggerLeave","handleContentLeave","handleTrackPointerGrace","pointerPosition","hasEnteredTarget","isPointerOutsideGraceArea","isPointInPolygon","VisuallyHiddenContentContextProvider","useVisuallyHiddenContentContext","Slottable","handleScroll","PopperPrimitive.Content","VisuallyHiddenPrimitive.Root","TooltipArrow","PopperPrimitive.Arrow","point","polygon","inside","j","ii","jj","xi","yi","xj","yj","points","newPoints","getHullPresorted","upperHull","q","lowerHull","Root3","Trigger","Content2","TooltipPrimitive.Provider","TooltipPrimitive.Root","TooltipPrimitive.Trigger","TooltipPrimitive.Portal","TooltipPrimitive.Content","getTargetElement","getPlacement","getDelay","delay","TooltipLight","popperClassName","isOpen","toggle","autohide","setRect","updateRect","showTimer","hideTimer","clearTimers","show","useFocusGuards","edgeGuards","createFocusGuard","AUTOFOCUS_ON_MOUNT","AUTOFOCUS_ON_UNMOUNT","EVENT_OPTIONS","FOCUS_SCOPE_NAME","FocusScope","loop","trapped","onMountAutoFocusProp","onUnmountAutoFocusProp","scopeProps","setContainer","onMountAutoFocus","onUnmountAutoFocus","lastFocusedElementRef","focusScope","handleFocusIn2","focus","handleFocusOut2","relatedTarget","handleMutations2","mutations","mutation","focusScopesStack","previouslyFocusedElement","mountEvent","focusFirst","removeLinks","getTabbableCandidates","unmountEvent","isTabKey","focusedElement","container2","first","last","getTabbableEdges","candidates","select","candidate","findVisible","nodes","walker","isHiddenInput","isHidden","upTo","isSelectableInput","createFocusScopesStack","stack","activeFocusScope","arrayRemove","array","updatedArray","items","getDefaultParent","originalTarget","sampleTarget","counterMap","uncontrolledNodes","markerMap","lockCount","unwrapHost","correctTargets","targets","correctedTarget","applyAttributeToOthers","markerName","controlAttribute","markerCounter","hiddenNodes","elementsToKeep","elementsToStop","keep","deep","attr","alreadyHidden","counterValue","markerValue","hideOthers","activeParentNode","__assign","s","__rest","t","__spreadArray","to","from","pack","l","ar","zeroRightClassName","fullWidthClassName","noScrollbarsClassName","removedBarSizeVariable","assignRef","initialValue","useIsomorphicLayoutEffect","currentValues","useMergeRefs","defaultValue","newValue","oldValue","prevRefs_1","nextRefs_1","current_1","ItoI","innerCreateMedium","defaults","buffer","assigned","medium","cb","cbs","pendingQueue","executeQueue","cycle","filter","createSidecarMedium","SideCar","_a","sideCar","Target","exportSidecar","exported","effectCar","nothing","RemoveScroll","parentRef","callbacks","setCallbacks","forwardProps","removeScrollBar","shards","noRelative","noIsolation","inert","allowPinchZoom","_b","Container","gapMode","containerRef","containerProps","getNonce","makeStyleTag","tag","nonce","injectStyles","insertStyleTag","head","stylesheetSingleton","counter","stylesheet","styleHookSingleton","sheet","isDynamic","styleSingleton","useStyle","Sheet","dynamic","zeroGap","parse","getOffset","cs","getGapWidth","documentWidth","windowWidth","Style","lockAttribute","getStyles","allowRelative","important","gap","getCurrentUseCounter","useLockAttribute","newCounter","RemoveScrollBar","noImportant","passiveSupported","nonPassive","alwaysContainsScroll","elementCanBeScrolled","elementCouldBeVScrolled","elementCouldBeHScrolled","locationCouldBeScrolled","isScrollable","elementCouldBeScrolled","getScrollVariables","scrollHeight","clientHeight","getVScrollVariables","scrollTop","getHScrollVariables","scrollLeft","scrollWidth","clientWidth","getDirectionFactor","endTarget","sourceDelta","noOverscroll","directionFactor","delta","targetInLock","shouldCancelScroll","isDeltaPositive","availableScroll","availableScrollTop","scroll_1","capacity","elementScroll","parent_1","getTouchXY","getDeltaXY","extractRef","deltaCompare","generateStyle","idCounter","lockStack","RemoveScrollSideCar","shouldPreventQueue","touchStartRef","activeAxis","lastProps","allow_1","shouldCancelEvent","touch","touchStart","deltaX","deltaY","currentAxis","moveDirection","selection","anchorNode","isTouchingSelection","canBeScrolledInMainDirection","cancelingAxis","shouldPrevent","_event","sourceEvent","shardNodes","shouldStop","shouldCancel","should","getOutermostShadowParent","scrollTouchStart","scrollWheel","scrollTouchMove","inst","shadowParent","ReactRemoveScroll","POPOVER_NAME","createPopoverContext","PopoverProvider","usePopoverContext","Popover","__scopePopover","modal","hasCustomAnchor","setHasCustomAnchor","prevOpen","PopoverAnchor","onCustomAnchorAdd","onCustomAnchorRemove","PopoverTrigger","composedTriggerRef","getState","PopoverPortal","PopoverContent","PopoverContentModal","PopoverContentNonModal","contentRef","isRightClickOutsideRef","PopoverContentImpl","originalEvent","ctrlLeftClick","isRightClick","hasInteractedOutsideRef","hasPointerDownOutsideRef","trapFocus","onOpenAutoFocus","onCloseAutoFocus","CLOSE_NAME","PopoverClose","closeProps","PopoverArrow","PopoverPrimitive.Root","PopoverPrimitive.Trigger","PopoverPrimitive.Portal","PopoverPrimitive.Content","targetElement","UiPopover","EmptyComponent","svg","EmptyIcon","Collapse","header","onToggle","headerClassName","contentClassName","iconClassName","_isOpen","set_IsOpen","isMounted","resolvedOpen","_header","_content","onEnd","handleToggle","ArrowDownIcon","CollapsableBlock","infoTooltipContent","tooltipOpen","toggleTooltip","InfoIcon","SafeReact","useSafeInsertionEffect","useEffectEvent","_len","_key","serverHandoffComplete","genId","useFloatingId","useModernLayoutEffect","devMessageSet","error","_devMessageSet3","_len2","messages","_key2","message","_devMessageSet4","createEventEmitter","map","_map$get","listener","_map$get2","FloatingNodeContext","FloatingTreeContext","useFloatingParentNodeId","_React$useContext","useFloatingTree","useFloatingRootContext","onOpenChangeProp","elementsProp","floatingId","events","nested","optionDomReference","positionReference","setPositionReference","reason","nodeId","internalRootContext","rootContext","computedElements","_domReference","setDomReference","_setPositionReference","domReference","domReferenceRef","tree","useFloating$1","computedPositionReference","InputCaption","isFullWidth","Label","labelVariants","LabelPrimitive.Root","htmlFor","UiLabel","Tag","isSmall","CrossIcon","DROPDOWN_MARGIN","SelectedOptions","selectedOptionRender","tagRender","onDelete","Search","onSearch","searchClassName","searchValue","isLoading","placeholder","SearchIcon","Dropdown","optionClassName","optionRender","searchPlaceholder","checkIsActive","isActive","isPrevActive","isNextActive","TableDropdown","columns","total","mode","handleRowToggle","totalLabel","safeColumns","column","Select","dropdownRender","dropdownIcon","dropDownClassName","inputClassName","deleteIconClassName","onClear","portalTarget","fixedHeight","template","setIsOpen","setIsMounted","dropDownRef","inputRef","setSearchValue","resolvedPortalTarget","handleSearch","handleClickOutside","floatingOffset","nextWidth","handleChange","renderDropdown","dropdownContent","menu","dropdown","hasValue","DIALOG_NAME","createDialogContext","DialogProvider","useDialogContext","Dialog","__scopeDialog","DialogTrigger","DialogPortal","OVERLAY_NAME","DialogOverlay","overlayProps","DialogOverlayImpl","DialogContent","DialogContentModal","DialogContentNonModal","DialogContentImpl","TitleWarning","DescriptionWarning","TITLE_NAME","DialogTitle","titleProps","DESCRIPTION_NAME","DialogDescription","descriptionProps","DialogClose","TITLE_WARNING_NAME","WarningProvider","useWarningContext","createContext","titleId","titleWarningContext","MESSAGE","DESCRIPTION_WARNING_NAME","descriptionId","describedById","Overlay","Title","Description","DialogPrimitive.Root","DialogPrimitive.Portal","DialogPrimitive.Overlay","DialogPrimitive.Content","DialogHeader","DialogFooter","DialogPrimitive.Title","DialogPrimitive.Description","DEFAULT_PAGE_SIZE","DEFAULT_DEBOUNCE_MS","DialogSelect","loadOptions","selectButtonText","closeButtonText","manualButtonText","onManualAdd","pageSize","debounceMs","search","setSearch","debouncedSearch","setDebouncedSearch","page","setPage","setOptions","setTotal","hasNextPage","setHasNextPage","setIsLoading","requestIdRef","tableColumns","totalPages","canGoPrevious","canGoNext","requestId","handleOpenChange","handleSelect","selectedContent","currentPage","ROOT_KEY","TreeDialogSelect","loadChildren","searchNodes","confirmButtonText","nodeRender","childrenCache","setChildrenCache","loadingNodes","setLoadingNodes","expanded","setExpanded","forcedExpanded","setForcedExpanded","searchMatches","setSearchMatches","isSearching","setIsSearching","pendingSelection","setPendingSelection","rootRequestIdRef","searchRequestIdRef","matches","ancestorsToExpand","inferredChildren","fullPath","parentKey","existing","merged","ensureChildrenLoaded","toggleExpand","handleSelectNode","handleConfirm","isExpanded","nodeValue","clientFilter","renderNode","level","isNodeExpanded","isNodeLoading","isPending","isCurrent","isMatch","showChildren","visibleChildren","rootNodes","visibleRoots","isRootLoading","showEmpty","showSearchSpinner","TabsRounded","activeTab","tabsClassName","Stepper","showCheckOnCompleted","isClickable","isCompleted","isLast","showCheck","stepContent","DoneIcon","stepNode","Tabs","changesIndex","badgeValue","sliderClassName","tabRef","animationFrameRef","line","setLine","updateLine","nextLine","prevLine","scheduleLineUpdate","PlusIcon","NameDialog","onSubmit","submit","trimmed","o","ApprovalRoute","levels","editable","eyebrow","loadApprovers","onAddLevel","onRemoveLevel","onAddStage","onRemoveStage","onAddApprover","onRemoveApprover","addLevelOpen","setAddLevelOpen","addStageFor","setAddStageFor","railClass","stage","person","WarnIcon","status"],"mappings":"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","x_google_ignoreList":[51,53,54,55,56,57,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,126,127,129,130,135,136]}