@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.
- package/README.md +11 -0
- package/dist-lib/index.d.ts +2 -0
- package/dist-lib/styles.css +1 -0
- package/dist-lib/ui-library.cjs.js +46 -0
- package/dist-lib/ui-library.cjs.js.map +1 -0
- package/dist-lib/ui-library.es.js +9078 -0
- package/dist-lib/ui-library.es.js.map +1 -0
- package/package.json +19 -17
- package/dist/index.d.ts +0 -661
- package/dist/styles.css +0 -1
- package/dist/ui-library.cjs.js +0 -48
- package/dist/ui-library.cjs.js.map +0 -1
- package/dist/ui-library.es.js +0 -10518
- package/dist/ui-library.es.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
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","../node_modules/react-router/dist/development/chunk-EVOBXE3Y.mjs","../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","../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","/**\n * react-router v7.14.2\n *\n * Copyright (c) Remix Software Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.md file in the root directory of this source tree.\n *\n * @license MIT\n */\nvar __typeError = (msg) => {\n throw TypeError(msg);\n};\nvar __accessCheck = (obj, member, msg) => member.has(obj) || __typeError(\"Cannot \" + msg);\nvar __privateGet = (obj, member, getter) => (__accessCheck(obj, member, \"read from private field\"), getter ? getter.call(obj) : member.get(obj));\nvar __privateAdd = (obj, member, value) => member.has(obj) ? __typeError(\"Cannot add the same private member more than once\") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);\n\n// lib/router/history.ts\nvar Action = /* @__PURE__ */ ((Action2) => {\n Action2[\"Pop\"] = \"POP\";\n Action2[\"Push\"] = \"PUSH\";\n Action2[\"Replace\"] = \"REPLACE\";\n return Action2;\n})(Action || {});\nvar PopStateEventType = \"popstate\";\nfunction isLocation(obj) {\n return typeof obj === \"object\" && obj != null && \"pathname\" in obj && \"search\" in obj && \"hash\" in obj && \"state\" in obj && \"key\" in obj;\n}\nfunction createMemoryHistory(options = {}) {\n let { initialEntries = [\"/\"], initialIndex, v5Compat = false } = options;\n let entries;\n entries = initialEntries.map(\n (entry, index2) => createMemoryLocation(\n entry,\n typeof entry === \"string\" ? null : entry.state,\n index2 === 0 ? \"default\" : void 0,\n typeof entry === \"string\" ? void 0 : entry.unstable_mask\n )\n );\n let index = clampIndex(\n initialIndex == null ? entries.length - 1 : initialIndex\n );\n let action = \"POP\" /* Pop */;\n let listener = null;\n function clampIndex(n) {\n return Math.min(Math.max(n, 0), entries.length - 1);\n }\n function getCurrentLocation() {\n return entries[index];\n }\n function createMemoryLocation(to, state = null, key, unstable_mask) {\n let location = createLocation(\n entries ? getCurrentLocation().pathname : \"/\",\n to,\n state,\n key,\n unstable_mask\n );\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in memory history: ${JSON.stringify(\n to\n )}`\n );\n return location;\n }\n function createHref2(to) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n let history = {\n get index() {\n return index;\n },\n get action() {\n return action;\n },\n get location() {\n return getCurrentLocation();\n },\n createHref: createHref2,\n createURL(to) {\n return new URL(createHref2(to), \"http://localhost\");\n },\n encodeLocation(to) {\n let path = typeof to === \"string\" ? parsePath(to) : to;\n return {\n pathname: path.pathname || \"\",\n search: path.search || \"\",\n hash: path.hash || \"\"\n };\n },\n push(to, state) {\n action = \"PUSH\" /* Push */;\n let nextLocation = isLocation(to) ? to : createMemoryLocation(to, state);\n index += 1;\n entries.splice(index, entries.length, nextLocation);\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 1 });\n }\n },\n replace(to, state) {\n action = \"REPLACE\" /* Replace */;\n let nextLocation = isLocation(to) ? to : createMemoryLocation(to, state);\n entries[index] = nextLocation;\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 0 });\n }\n },\n go(delta) {\n action = \"POP\" /* Pop */;\n let nextIndex = clampIndex(index + delta);\n let nextLocation = entries[nextIndex];\n index = nextIndex;\n if (listener) {\n listener({ action, location: nextLocation, delta });\n }\n },\n listen(fn) {\n listener = fn;\n return () => {\n listener = null;\n };\n }\n };\n return history;\n}\nfunction createBrowserHistory(options = {}) {\n function createBrowserLocation(window2, globalHistory) {\n let maskedLocation = globalHistory.state?.masked;\n let { pathname, search, hash } = maskedLocation || window2.location;\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n globalHistory.state && globalHistory.state.usr || null,\n globalHistory.state && globalHistory.state.key || \"default\",\n maskedLocation ? {\n pathname: window2.location.pathname,\n search: window2.location.search,\n hash: window2.location.hash\n } : void 0\n );\n }\n function createBrowserHref(window2, to) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n return getUrlBasedHistory(\n createBrowserLocation,\n createBrowserHref,\n null,\n options\n );\n}\nfunction createHashHistory(options = {}) {\n function createHashLocation(window2, globalHistory) {\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\"\n } = parsePath(window2.location.hash.substring(1));\n if (!pathname.startsWith(\"/\") && !pathname.startsWith(\".\")) {\n pathname = \"/\" + pathname;\n }\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n globalHistory.state && globalHistory.state.usr || null,\n globalHistory.state && globalHistory.state.key || \"default\"\n );\n }\n function createHashHref(window2, to) {\n let base = window2.document.querySelector(\"base\");\n let href = \"\";\n if (base && base.getAttribute(\"href\")) {\n let url = window2.location.href;\n let hashIndex = url.indexOf(\"#\");\n href = hashIndex === -1 ? url : url.slice(0, hashIndex);\n }\n return href + \"#\" + (typeof to === \"string\" ? to : createPath(to));\n }\n function validateHashLocation(location, to) {\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in hash history.push(${JSON.stringify(\n to\n )})`\n );\n }\n return getUrlBasedHistory(\n createHashLocation,\n createHashHref,\n validateHashLocation,\n options\n );\n}\nfunction invariant(value, message) {\n if (value === false || value === null || typeof value === \"undefined\") {\n throw new Error(message);\n }\n}\nfunction warning(cond, message) {\n if (!cond) {\n if (typeof console !== \"undefined\") console.warn(message);\n try {\n throw new Error(message);\n } catch (e) {\n }\n }\n}\nfunction createKey() {\n return Math.random().toString(36).substring(2, 10);\n}\nfunction getHistoryState(location, index) {\n return {\n usr: location.state,\n key: location.key,\n idx: index,\n masked: location.unstable_mask ? {\n pathname: location.pathname,\n search: location.search,\n hash: location.hash\n } : void 0\n };\n}\nfunction createLocation(current, to, state = null, key, unstable_mask) {\n let location = {\n pathname: typeof current === \"string\" ? current : current.pathname,\n search: \"\",\n hash: \"\",\n ...typeof to === \"string\" ? parsePath(to) : to,\n state,\n // TODO: This could be cleaned up. push/replace should probably just take\n // full Locations now and avoid the need to run through this flow at all\n // But that's a pretty big refactor to the current test suite so going to\n // keep as is for the time being and just let any incoming keys take precedence\n key: to && to.key || key || createKey(),\n unstable_mask\n };\n return location;\n}\nfunction createPath({\n pathname = \"/\",\n search = \"\",\n hash = \"\"\n}) {\n if (search && search !== \"?\")\n pathname += search.charAt(0) === \"?\" ? search : \"?\" + search;\n if (hash && hash !== \"#\")\n pathname += hash.charAt(0) === \"#\" ? hash : \"#\" + hash;\n return pathname;\n}\nfunction parsePath(path) {\n let parsedPath = {};\n if (path) {\n let hashIndex = path.indexOf(\"#\");\n if (hashIndex >= 0) {\n parsedPath.hash = path.substring(hashIndex);\n path = path.substring(0, hashIndex);\n }\n let searchIndex = path.indexOf(\"?\");\n if (searchIndex >= 0) {\n parsedPath.search = path.substring(searchIndex);\n path = path.substring(0, searchIndex);\n }\n if (path) {\n parsedPath.pathname = path;\n }\n }\n return parsedPath;\n}\nfunction getUrlBasedHistory(getLocation, createHref2, validateLocation, options = {}) {\n let { window: window2 = document.defaultView, v5Compat = false } = options;\n let globalHistory = window2.history;\n let action = \"POP\" /* Pop */;\n let listener = null;\n let index = getIndex();\n if (index == null) {\n index = 0;\n globalHistory.replaceState({ ...globalHistory.state, idx: index }, \"\");\n }\n function getIndex() {\n let state = globalHistory.state || { idx: null };\n return state.idx;\n }\n function handlePop() {\n action = \"POP\" /* Pop */;\n let nextIndex = getIndex();\n let delta = nextIndex == null ? null : nextIndex - index;\n index = nextIndex;\n if (listener) {\n listener({ action, location: history.location, delta });\n }\n }\n function push(to, state) {\n action = \"PUSH\" /* Push */;\n let location = isLocation(to) ? to : createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n index = getIndex() + 1;\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location.unstable_mask || location);\n try {\n globalHistory.pushState(historyState, \"\", url);\n } catch (error) {\n if (error instanceof DOMException && error.name === \"DataCloneError\") {\n throw error;\n }\n window2.location.assign(url);\n }\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 1 });\n }\n }\n function replace2(to, state) {\n action = \"REPLACE\" /* Replace */;\n let location = isLocation(to) ? to : createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n index = getIndex();\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location.unstable_mask || location);\n globalHistory.replaceState(historyState, \"\", url);\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 0 });\n }\n }\n function createURL(to) {\n return createBrowserURLImpl(to);\n }\n let history = {\n get action() {\n return action;\n },\n get location() {\n return getLocation(window2, globalHistory);\n },\n listen(fn) {\n if (listener) {\n throw new Error(\"A history only accepts one active listener\");\n }\n window2.addEventListener(PopStateEventType, handlePop);\n listener = fn;\n return () => {\n window2.removeEventListener(PopStateEventType, handlePop);\n listener = null;\n };\n },\n createHref(to) {\n return createHref2(window2, to);\n },\n createURL,\n encodeLocation(to) {\n let url = createURL(to);\n return {\n pathname: url.pathname,\n search: url.search,\n hash: url.hash\n };\n },\n push,\n replace: replace2,\n go(n) {\n return globalHistory.go(n);\n }\n };\n return history;\n}\nfunction createBrowserURLImpl(to, isAbsolute = false) {\n let base = \"http://localhost\";\n if (typeof window !== \"undefined\") {\n base = window.location.origin !== \"null\" ? window.location.origin : window.location.href;\n }\n invariant(base, \"No window.location.(origin|href) available to create URL\");\n let href = typeof to === \"string\" ? to : createPath(to);\n href = href.replace(/ $/, \"%20\");\n if (!isAbsolute && href.startsWith(\"//\")) {\n href = base + href;\n }\n return new URL(href, base);\n}\n\n// lib/router/utils.ts\nfunction createContext(defaultValue) {\n return { defaultValue };\n}\nvar _map;\nvar RouterContextProvider = class {\n /**\n * Create a new `RouterContextProvider` instance\n * @param init An optional initial context map to populate the provider with\n */\n constructor(init) {\n __privateAdd(this, _map, /* @__PURE__ */ new Map());\n if (init) {\n for (let [context, value] of init) {\n this.set(context, value);\n }\n }\n }\n /**\n * Access a value from the context. If no value has been set for the context,\n * it will return the context's `defaultValue` if provided, or throw an error\n * if no `defaultValue` was set.\n * @param context The context to get the value for\n * @returns The value for the context, or the context's `defaultValue` if no\n * value was set\n */\n get(context) {\n if (__privateGet(this, _map).has(context)) {\n return __privateGet(this, _map).get(context);\n }\n if (context.defaultValue !== void 0) {\n return context.defaultValue;\n }\n throw new Error(\"No value found for context\");\n }\n /**\n * Set a value for the context. If the context already has a value set, this\n * will overwrite it.\n *\n * @param context The context to set the value for\n * @param value The value to set for the context\n * @returns {void}\n */\n set(context, value) {\n __privateGet(this, _map).set(context, value);\n }\n};\n_map = new WeakMap();\nvar unsupportedLazyRouteObjectKeys = /* @__PURE__ */ new Set([\n \"lazy\",\n \"caseSensitive\",\n \"path\",\n \"id\",\n \"index\",\n \"children\"\n]);\nfunction isUnsupportedLazyRouteObjectKey(key) {\n return unsupportedLazyRouteObjectKeys.has(\n key\n );\n}\nvar unsupportedLazyRouteFunctionKeys = /* @__PURE__ */ new Set([\n \"lazy\",\n \"caseSensitive\",\n \"path\",\n \"id\",\n \"index\",\n \"middleware\",\n \"children\"\n]);\nfunction isUnsupportedLazyRouteFunctionKey(key) {\n return unsupportedLazyRouteFunctionKeys.has(\n key\n );\n}\nfunction isIndexRoute(route) {\n return route.index === true;\n}\nfunction convertRoutesToDataRoutes(routes, mapRouteProperties2, parentPath = [], manifest = {}, allowInPlaceMutations = false) {\n return routes.map((route, index) => {\n let treePath = [...parentPath, String(index)];\n let id = typeof route.id === \"string\" ? route.id : treePath.join(\"-\");\n invariant(\n route.index !== true || !route.children,\n `Cannot specify children on an index route`\n );\n invariant(\n allowInPlaceMutations || !manifest[id],\n `Found a route id collision on id \"${id}\". Route id's must be globally unique within Data Router usages`\n );\n if (isIndexRoute(route)) {\n let indexRoute = {\n ...route,\n id\n };\n manifest[id] = mergeRouteUpdates(\n indexRoute,\n mapRouteProperties2(indexRoute)\n );\n return indexRoute;\n } else {\n let pathOrLayoutRoute = {\n ...route,\n id,\n children: void 0\n };\n manifest[id] = mergeRouteUpdates(\n pathOrLayoutRoute,\n mapRouteProperties2(pathOrLayoutRoute)\n );\n if (route.children) {\n pathOrLayoutRoute.children = convertRoutesToDataRoutes(\n route.children,\n mapRouteProperties2,\n treePath,\n manifest,\n allowInPlaceMutations\n );\n }\n return pathOrLayoutRoute;\n }\n });\n}\nfunction mergeRouteUpdates(route, updates) {\n return Object.assign(route, {\n ...updates,\n ...typeof updates.lazy === \"object\" && updates.lazy != null ? {\n lazy: {\n ...route.lazy,\n ...updates.lazy\n }\n } : {}\n });\n}\nfunction matchRoutes(routes, locationArg, basename = \"/\") {\n return matchRoutesImpl(routes, locationArg, basename, false);\n}\nfunction matchRoutesImpl(routes, locationArg, basename, allowPartial) {\n let location = typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n let pathname = stripBasename(location.pathname || \"/\", basename);\n if (pathname == null) {\n return null;\n }\n let branches = flattenRoutes(routes);\n rankRouteBranches(branches);\n let matches = null;\n for (let i = 0; matches == null && i < branches.length; ++i) {\n let decoded = decodePath(pathname);\n matches = matchRouteBranch(\n branches[i],\n decoded,\n allowPartial\n );\n }\n return matches;\n}\nfunction convertRouteMatchToUiMatch(match, loaderData) {\n let { route, pathname, params } = match;\n return {\n id: route.id,\n pathname,\n params,\n data: loaderData[route.id],\n loaderData: loaderData[route.id],\n handle: route.handle\n };\n}\nfunction flattenRoutes(routes, branches = [], parentsMeta = [], parentPath = \"\", _hasParentOptionalSegments = false) {\n let flattenRoute = (route, index, hasParentOptionalSegments = _hasParentOptionalSegments, relativePath) => {\n let meta = {\n relativePath: relativePath === void 0 ? route.path || \"\" : relativePath,\n caseSensitive: route.caseSensitive === true,\n childrenIndex: index,\n route\n };\n if (meta.relativePath.startsWith(\"/\")) {\n if (!meta.relativePath.startsWith(parentPath) && hasParentOptionalSegments) {\n return;\n }\n invariant(\n meta.relativePath.startsWith(parentPath),\n `Absolute route path \"${meta.relativePath}\" nested under path \"${parentPath}\" is not valid. An absolute child route path must start with the combined path of all its parent routes.`\n );\n meta.relativePath = meta.relativePath.slice(parentPath.length);\n }\n let path = joinPaths([parentPath, meta.relativePath]);\n let routesMeta = parentsMeta.concat(meta);\n if (route.children && route.children.length > 0) {\n invariant(\n // Our types know better, but runtime JS may not!\n // @ts-expect-error\n route.index !== true,\n `Index routes must not have child routes. Please remove all child routes from route path \"${path}\".`\n );\n flattenRoutes(\n route.children,\n branches,\n routesMeta,\n path,\n hasParentOptionalSegments\n );\n }\n if (route.path == null && !route.index) {\n return;\n }\n branches.push({\n path,\n score: computeScore(path, route.index),\n routesMeta\n });\n };\n routes.forEach((route, index) => {\n if (route.path === \"\" || !route.path?.includes(\"?\")) {\n flattenRoute(route, index);\n } else {\n for (let exploded of explodeOptionalSegments(route.path)) {\n flattenRoute(route, index, true, exploded);\n }\n }\n });\n return branches;\n}\nfunction explodeOptionalSegments(path) {\n let segments = path.split(\"/\");\n if (segments.length === 0) return [];\n let [first, ...rest] = segments;\n let isOptional = first.endsWith(\"?\");\n let required = first.replace(/\\?$/, \"\");\n if (rest.length === 0) {\n return isOptional ? [required, \"\"] : [required];\n }\n let restExploded = explodeOptionalSegments(rest.join(\"/\"));\n let result = [];\n result.push(\n ...restExploded.map(\n (subpath) => subpath === \"\" ? required : [required, subpath].join(\"/\")\n )\n );\n if (isOptional) {\n result.push(...restExploded);\n }\n return result.map(\n (exploded) => path.startsWith(\"/\") && exploded === \"\" ? \"/\" : exploded\n );\n}\nfunction rankRouteBranches(branches) {\n branches.sort(\n (a, b) => a.score !== b.score ? b.score - a.score : compareIndexes(\n a.routesMeta.map((meta) => meta.childrenIndex),\n b.routesMeta.map((meta) => meta.childrenIndex)\n )\n );\n}\nvar paramRe = /^:[\\w-]+$/;\nvar dynamicSegmentValue = 3;\nvar indexRouteValue = 2;\nvar emptySegmentValue = 1;\nvar staticSegmentValue = 10;\nvar splatPenalty = -2;\nvar isSplat = (s) => s === \"*\";\nfunction computeScore(path, index) {\n let segments = path.split(\"/\");\n let initialScore = segments.length;\n if (segments.some(isSplat)) {\n initialScore += splatPenalty;\n }\n if (index) {\n initialScore += indexRouteValue;\n }\n return segments.filter((s) => !isSplat(s)).reduce(\n (score, segment) => score + (paramRe.test(segment) ? dynamicSegmentValue : segment === \"\" ? emptySegmentValue : staticSegmentValue),\n initialScore\n );\n}\nfunction compareIndexes(a, b) {\n let siblings = a.length === b.length && a.slice(0, -1).every((n, i) => n === b[i]);\n return siblings ? (\n // If two routes are siblings, we should try to match the earlier sibling\n // first. This allows people to have fine-grained control over the matching\n // behavior by simply putting routes with identical paths in the order they\n // want them tried.\n a[a.length - 1] - b[b.length - 1]\n ) : (\n // Otherwise, it doesn't really make sense to rank non-siblings by index,\n // so they sort equally.\n 0\n );\n}\nfunction matchRouteBranch(branch, pathname, allowPartial = false) {\n let { routesMeta } = branch;\n let matchedParams = {};\n let matchedPathname = \"/\";\n let matches = [];\n for (let i = 0; i < routesMeta.length; ++i) {\n let meta = routesMeta[i];\n let end = i === routesMeta.length - 1;\n let remainingPathname = matchedPathname === \"/\" ? pathname : pathname.slice(matchedPathname.length) || \"/\";\n let match = matchPath(\n { path: meta.relativePath, caseSensitive: meta.caseSensitive, end },\n remainingPathname\n );\n let route = meta.route;\n if (!match && end && allowPartial && !routesMeta[routesMeta.length - 1].route.index) {\n match = matchPath(\n {\n path: meta.relativePath,\n caseSensitive: meta.caseSensitive,\n end: false\n },\n remainingPathname\n );\n }\n if (!match) {\n return null;\n }\n Object.assign(matchedParams, match.params);\n matches.push({\n // TODO: Can this as be avoided?\n params: matchedParams,\n pathname: joinPaths([matchedPathname, match.pathname]),\n pathnameBase: normalizePathname(\n joinPaths([matchedPathname, match.pathnameBase])\n ),\n route\n });\n if (match.pathnameBase !== \"/\") {\n matchedPathname = joinPaths([matchedPathname, match.pathnameBase]);\n }\n }\n return matches;\n}\nfunction generatePath(originalPath, params = {}) {\n let path = originalPath;\n if (path.endsWith(\"*\") && path !== \"*\" && !path.endsWith(\"/*\")) {\n warning(\n false,\n `Route path \"${path}\" will be treated as if it were \"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must always follow a \\`/\\` in the pattern. To get rid of this warning, please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n );\n path = path.replace(/\\*$/, \"/*\");\n }\n const prefix = path.startsWith(\"/\") ? \"/\" : \"\";\n const stringify2 = (p) => p == null ? \"\" : typeof p === \"string\" ? p : String(p);\n const segments = path.split(/\\/+/).map((segment, index, array) => {\n const isLastSegment = index === array.length - 1;\n if (isLastSegment && segment === \"*\") {\n return stringify2(params[\"*\"]);\n }\n const keyMatch = segment.match(/^:([\\w-]+)(\\??)(.*)/);\n if (keyMatch) {\n const [, key, optional, suffix] = keyMatch;\n let param = params[key];\n invariant(optional === \"?\" || param != null, `Missing \":${key}\" param`);\n return encodeURIComponent(stringify2(param)) + suffix;\n }\n return segment.replace(/\\?$/g, \"\");\n }).filter((segment) => !!segment);\n return prefix + segments.join(\"/\");\n}\nfunction matchPath(pattern, pathname) {\n if (typeof pattern === \"string\") {\n pattern = { path: pattern, caseSensitive: false, end: true };\n }\n let [matcher, compiledParams] = compilePath(\n pattern.path,\n pattern.caseSensitive,\n pattern.end\n );\n let match = pathname.match(matcher);\n if (!match) return null;\n let matchedPathname = match[0];\n let pathnameBase = matchedPathname.replace(/(.)\\/+$/, \"$1\");\n let captureGroups = match.slice(1);\n let params = compiledParams.reduce(\n (memo2, { paramName, isOptional }, index) => {\n if (paramName === \"*\") {\n let splatValue = captureGroups[index] || \"\";\n pathnameBase = matchedPathname.slice(0, matchedPathname.length - splatValue.length).replace(/(.)\\/+$/, \"$1\");\n }\n const value = captureGroups[index];\n if (isOptional && !value) {\n memo2[paramName] = void 0;\n } else {\n memo2[paramName] = (value || \"\").replace(/%2F/g, \"/\");\n }\n return memo2;\n },\n {}\n );\n return {\n params,\n pathname: matchedPathname,\n pathnameBase,\n pattern\n };\n}\nfunction compilePath(path, caseSensitive = false, end = true) {\n warning(\n path === \"*\" || !path.endsWith(\"*\") || path.endsWith(\"/*\"),\n `Route path \"${path}\" will be treated as if it were \"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must always follow a \\`/\\` in the pattern. To get rid of this warning, please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n );\n let params = [];\n let regexpSource = \"^\" + path.replace(/\\/*\\*?$/, \"\").replace(/^\\/*/, \"/\").replace(/[\\\\.*+^${}|()[\\]]/g, \"\\\\$&\").replace(\n /\\/:([\\w-]+)(\\?)?/g,\n (match, paramName, isOptional, index, str) => {\n params.push({ paramName, isOptional: isOptional != null });\n if (isOptional) {\n let nextChar = str.charAt(index + match.length);\n if (nextChar && nextChar !== \"/\") {\n return \"/([^\\\\/]*)\";\n }\n return \"(?:/([^\\\\/]*))?\";\n }\n return \"/([^\\\\/]+)\";\n }\n ).replace(/\\/([\\w-]+)\\?(\\/|$)/g, \"(/$1)?$2\");\n if (path.endsWith(\"*\")) {\n params.push({ paramName: \"*\" });\n regexpSource += path === \"*\" || path === \"/*\" ? \"(.*)$\" : \"(?:\\\\/(.+)|\\\\/*)$\";\n } else if (end) {\n regexpSource += \"\\\\/*$\";\n } else if (path !== \"\" && path !== \"/\") {\n regexpSource += \"(?:(?=\\\\/|$))\";\n } else {\n }\n let matcher = new RegExp(regexpSource, caseSensitive ? void 0 : \"i\");\n return [matcher, params];\n}\nfunction decodePath(value) {\n try {\n return value.split(\"/\").map((v) => decodeURIComponent(v).replace(/\\//g, \"%2F\")).join(\"/\");\n } catch (error) {\n warning(\n false,\n `The URL path \"${value}\" could not be decoded because it is a malformed URL segment. This is probably due to a bad percent encoding (${error}).`\n );\n return value;\n }\n}\nfunction stripBasename(pathname, basename) {\n if (basename === \"/\") return pathname;\n if (!pathname.toLowerCase().startsWith(basename.toLowerCase())) {\n return null;\n }\n let startIndex = basename.endsWith(\"/\") ? basename.length - 1 : basename.length;\n let nextChar = pathname.charAt(startIndex);\n if (nextChar && nextChar !== \"/\") {\n return null;\n }\n return pathname.slice(startIndex) || \"/\";\n}\nfunction prependBasename({\n basename,\n pathname\n}) {\n return pathname === \"/\" ? basename : joinPaths([basename, pathname]);\n}\nvar ABSOLUTE_URL_REGEX = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\nvar isAbsoluteUrl = (url) => ABSOLUTE_URL_REGEX.test(url);\nfunction resolvePath(to, fromPathname = \"/\") {\n let {\n pathname: toPathname,\n search = \"\",\n hash = \"\"\n } = typeof to === \"string\" ? parsePath(to) : to;\n let pathname;\n if (toPathname) {\n toPathname = removeDoubleSlashes(toPathname);\n if (toPathname.startsWith(\"/\")) {\n pathname = resolvePathname(toPathname.substring(1), \"/\");\n } else {\n pathname = resolvePathname(toPathname, fromPathname);\n }\n } else {\n pathname = fromPathname;\n }\n return {\n pathname,\n search: normalizeSearch(search),\n hash: normalizeHash(hash)\n };\n}\nfunction resolvePathname(relativePath, fromPathname) {\n let segments = removeTrailingSlash(fromPathname).split(\"/\");\n let relativeSegments = relativePath.split(\"/\");\n relativeSegments.forEach((segment) => {\n if (segment === \"..\") {\n if (segments.length > 1) segments.pop();\n } else if (segment !== \".\") {\n segments.push(segment);\n }\n });\n return segments.length > 1 ? segments.join(\"/\") : \"/\";\n}\nfunction getInvalidPathError(char, field, dest, path) {\n return `Cannot include a '${char}' character in a manually specified \\`to.${field}\\` field [${JSON.stringify(\n path\n )}]. Please separate it out to the \\`to.${dest}\\` field. Alternatively you may provide the full path as a string in <Link to=\"...\"> and the router will parse it for you.`;\n}\nfunction getPathContributingMatches(matches) {\n return matches.filter(\n (match, index) => index === 0 || match.route.path && match.route.path.length > 0\n );\n}\nfunction getResolveToMatches(matches) {\n let pathMatches = getPathContributingMatches(matches);\n return pathMatches.map(\n (match, idx) => idx === pathMatches.length - 1 ? match.pathname : match.pathnameBase\n );\n}\nfunction resolveTo(toArg, routePathnames, locationPathname, isPathRelative = false) {\n let to;\n if (typeof toArg === \"string\") {\n to = parsePath(toArg);\n } else {\n to = { ...toArg };\n invariant(\n !to.pathname || !to.pathname.includes(\"?\"),\n getInvalidPathError(\"?\", \"pathname\", \"search\", to)\n );\n invariant(\n !to.pathname || !to.pathname.includes(\"#\"),\n getInvalidPathError(\"#\", \"pathname\", \"hash\", to)\n );\n invariant(\n !to.search || !to.search.includes(\"#\"),\n getInvalidPathError(\"#\", \"search\", \"hash\", to)\n );\n }\n let isEmptyPath = toArg === \"\" || to.pathname === \"\";\n let toPathname = isEmptyPath ? \"/\" : to.pathname;\n let from;\n if (toPathname == null) {\n from = locationPathname;\n } else {\n let routePathnameIndex = routePathnames.length - 1;\n if (!isPathRelative && toPathname.startsWith(\"..\")) {\n let toSegments = toPathname.split(\"/\");\n while (toSegments[0] === \"..\") {\n toSegments.shift();\n routePathnameIndex -= 1;\n }\n to.pathname = toSegments.join(\"/\");\n }\n from = routePathnameIndex >= 0 ? routePathnames[routePathnameIndex] : \"/\";\n }\n let path = resolvePath(to, from);\n let hasExplicitTrailingSlash = toPathname && toPathname !== \"/\" && toPathname.endsWith(\"/\");\n let hasCurrentTrailingSlash = (isEmptyPath || toPathname === \".\") && locationPathname.endsWith(\"/\");\n if (!path.pathname.endsWith(\"/\") && (hasExplicitTrailingSlash || hasCurrentTrailingSlash)) {\n path.pathname += \"/\";\n }\n return path;\n}\nvar removeDoubleSlashes = (path) => path.replace(/\\/\\/+/g, \"/\");\nvar joinPaths = (paths) => removeDoubleSlashes(paths.join(\"/\"));\nvar removeTrailingSlash = (path) => path.replace(/\\/+$/, \"\");\nvar normalizePathname = (pathname) => removeTrailingSlash(pathname).replace(/^\\/*/, \"/\");\nvar normalizeSearch = (search) => !search || search === \"?\" ? \"\" : search.startsWith(\"?\") ? search : \"?\" + search;\nvar normalizeHash = (hash) => !hash || hash === \"#\" ? \"\" : hash.startsWith(\"#\") ? hash : \"#\" + hash;\nvar DataWithResponseInit = class {\n constructor(data2, init) {\n this.type = \"DataWithResponseInit\";\n this.data = data2;\n this.init = init || null;\n }\n};\nfunction data(data2, init) {\n return new DataWithResponseInit(\n data2,\n typeof init === \"number\" ? { status: init } : init\n );\n}\nvar redirect = (url, init = 302) => {\n let responseInit = init;\n if (typeof responseInit === \"number\") {\n responseInit = { status: responseInit };\n } else if (typeof responseInit.status === \"undefined\") {\n responseInit.status = 302;\n }\n let headers = new Headers(responseInit.headers);\n headers.set(\"Location\", url);\n return new Response(null, { ...responseInit, headers });\n};\nvar redirectDocument = (url, init) => {\n let response = redirect(url, init);\n response.headers.set(\"X-Remix-Reload-Document\", \"true\");\n return response;\n};\nvar replace = (url, init) => {\n let response = redirect(url, init);\n response.headers.set(\"X-Remix-Replace\", \"true\");\n return response;\n};\nvar ErrorResponseImpl = class {\n constructor(status, statusText, data2, internal = false) {\n this.status = status;\n this.statusText = statusText || \"\";\n this.internal = internal;\n if (data2 instanceof Error) {\n this.data = data2.toString();\n this.error = data2;\n } else {\n this.data = data2;\n }\n }\n};\nfunction isRouteErrorResponse(error) {\n return error != null && typeof error.status === \"number\" && typeof error.statusText === \"string\" && typeof error.internal === \"boolean\" && \"data\" in error;\n}\nfunction getRoutePattern(matches) {\n let parts = matches.map((m) => m.route.path).filter(Boolean);\n return joinPaths(parts) || \"/\";\n}\nvar isBrowser = typeof window !== \"undefined\" && typeof window.document !== \"undefined\" && typeof window.document.createElement !== \"undefined\";\nfunction parseToInfo(_to, basename) {\n let to = _to;\n if (typeof to !== \"string\" || !ABSOLUTE_URL_REGEX.test(to)) {\n return {\n absoluteURL: void 0,\n isExternal: false,\n to\n };\n }\n let absoluteURL = to;\n let isExternal = false;\n if (isBrowser) {\n try {\n let currentUrl = new URL(window.location.href);\n let targetUrl = to.startsWith(\"//\") ? new URL(currentUrl.protocol + to) : new URL(to);\n let path = stripBasename(targetUrl.pathname, basename);\n if (targetUrl.origin === currentUrl.origin && path != null) {\n to = path + targetUrl.search + targetUrl.hash;\n } else {\n isExternal = true;\n }\n } catch (e) {\n warning(\n false,\n `<Link to=\"${to}\"> contains an invalid URL which will probably break when clicked - please update to a valid URL path.`\n );\n }\n }\n return {\n absoluteURL,\n isExternal,\n to\n };\n}\n\n// lib/router/instrumentation.ts\nvar UninstrumentedSymbol = Symbol(\"Uninstrumented\");\nfunction getRouteInstrumentationUpdates(fns, route) {\n let aggregated = {\n lazy: [],\n \"lazy.loader\": [],\n \"lazy.action\": [],\n \"lazy.middleware\": [],\n middleware: [],\n loader: [],\n action: []\n };\n fns.forEach(\n (fn) => fn({\n id: route.id,\n index: route.index,\n path: route.path,\n instrument(i) {\n let keys = Object.keys(aggregated);\n for (let key of keys) {\n if (i[key]) {\n aggregated[key].push(i[key]);\n }\n }\n }\n })\n );\n let updates = {};\n if (typeof route.lazy === \"function\" && aggregated.lazy.length > 0) {\n let instrumented = wrapImpl(aggregated.lazy, route.lazy, () => void 0);\n if (instrumented) {\n updates.lazy = instrumented;\n }\n }\n if (typeof route.lazy === \"object\") {\n let lazyObject = route.lazy;\n [\"middleware\", \"loader\", \"action\"].forEach((key) => {\n let lazyFn = lazyObject[key];\n let instrumentations = aggregated[`lazy.${key}`];\n if (typeof lazyFn === \"function\" && instrumentations.length > 0) {\n let instrumented = wrapImpl(instrumentations, lazyFn, () => void 0);\n if (instrumented) {\n updates.lazy = Object.assign(updates.lazy || {}, {\n [key]: instrumented\n });\n }\n }\n });\n }\n [\"loader\", \"action\"].forEach((key) => {\n let handler = route[key];\n if (typeof handler === \"function\" && aggregated[key].length > 0) {\n let original = handler[UninstrumentedSymbol] ?? handler;\n let instrumented = wrapImpl(\n aggregated[key],\n original,\n (...args) => getHandlerInfo(args[0])\n );\n if (instrumented) {\n if (key === \"loader\" && original.hydrate === true) {\n instrumented.hydrate = true;\n }\n instrumented[UninstrumentedSymbol] = original;\n updates[key] = instrumented;\n }\n }\n });\n if (route.middleware && route.middleware.length > 0 && aggregated.middleware.length > 0) {\n updates.middleware = route.middleware.map((middleware) => {\n let original = middleware[UninstrumentedSymbol] ?? middleware;\n let instrumented = wrapImpl(\n aggregated.middleware,\n original,\n (...args) => getHandlerInfo(args[0])\n );\n if (instrumented) {\n instrumented[UninstrumentedSymbol] = original;\n return instrumented;\n }\n return middleware;\n });\n }\n return updates;\n}\nfunction instrumentClientSideRouter(router, fns) {\n let aggregated = {\n navigate: [],\n fetch: []\n };\n fns.forEach(\n (fn) => fn({\n instrument(i) {\n let keys = Object.keys(i);\n for (let key of keys) {\n if (i[key]) {\n aggregated[key].push(i[key]);\n }\n }\n }\n })\n );\n if (aggregated.navigate.length > 0) {\n let navigate = router.navigate[UninstrumentedSymbol] ?? router.navigate;\n let instrumentedNavigate = wrapImpl(\n aggregated.navigate,\n navigate,\n (...args) => {\n let [to, opts] = args;\n return {\n to: typeof to === \"number\" || typeof to === \"string\" ? to : to ? createPath(to) : \".\",\n ...getRouterInfo(router, opts ?? {})\n };\n }\n );\n if (instrumentedNavigate) {\n instrumentedNavigate[UninstrumentedSymbol] = navigate;\n router.navigate = instrumentedNavigate;\n }\n }\n if (aggregated.fetch.length > 0) {\n let fetch2 = router.fetch[UninstrumentedSymbol] ?? router.fetch;\n let instrumentedFetch = wrapImpl(aggregated.fetch, fetch2, (...args) => {\n let [key, , href, opts] = args;\n return {\n href: href ?? \".\",\n fetcherKey: key,\n ...getRouterInfo(router, opts ?? {})\n };\n });\n if (instrumentedFetch) {\n instrumentedFetch[UninstrumentedSymbol] = fetch2;\n router.fetch = instrumentedFetch;\n }\n }\n return router;\n}\nfunction instrumentHandler(handler, fns) {\n let aggregated = {\n request: []\n };\n fns.forEach(\n (fn) => fn({\n instrument(i) {\n let keys = Object.keys(i);\n for (let key of keys) {\n if (i[key]) {\n aggregated[key].push(i[key]);\n }\n }\n }\n })\n );\n let instrumentedHandler = handler;\n if (aggregated.request.length > 0) {\n instrumentedHandler = wrapImpl(aggregated.request, handler, (...args) => {\n let [request, context] = args;\n return {\n request: getReadonlyRequest(request),\n context: context != null ? getReadonlyContext(context) : context\n };\n });\n }\n return instrumentedHandler;\n}\nfunction wrapImpl(impls, handler, getInfo) {\n if (impls.length === 0) {\n return null;\n }\n return async (...args) => {\n let result = await recurseRight(\n impls,\n getInfo(...args),\n () => handler(...args),\n impls.length - 1\n );\n if (result.type === \"error\") {\n throw result.value;\n }\n return result.value;\n };\n}\nasync function recurseRight(impls, info, handler, index) {\n let impl = impls[index];\n let result;\n if (!impl) {\n try {\n let value = await handler();\n result = { type: \"success\", value };\n } catch (e) {\n result = { type: \"error\", value: e };\n }\n } else {\n let handlerPromise = void 0;\n let callHandler = async () => {\n if (handlerPromise) {\n console.error(\"You cannot call instrumented handlers more than once\");\n } else {\n handlerPromise = recurseRight(impls, info, handler, index - 1);\n }\n result = await handlerPromise;\n invariant(result, \"Expected a result\");\n if (result.type === \"error\" && result.value instanceof Error) {\n return { status: \"error\", error: result.value };\n }\n return { status: \"success\", error: void 0 };\n };\n try {\n await impl(callHandler, info);\n } catch (e) {\n console.error(\"An instrumentation function threw an error:\", e);\n }\n if (!handlerPromise) {\n await callHandler();\n }\n await handlerPromise;\n }\n if (result) {\n return result;\n }\n return {\n type: \"error\",\n value: new Error(\"No result assigned in instrumentation chain.\")\n };\n}\nfunction getHandlerInfo(args) {\n let { request, context, params, unstable_pattern } = args;\n return {\n request: getReadonlyRequest(request),\n params: { ...params },\n unstable_pattern,\n context: getReadonlyContext(context)\n };\n}\nfunction getRouterInfo(router, opts) {\n return {\n currentUrl: createPath(router.state.location),\n ...\"formMethod\" in opts ? { formMethod: opts.formMethod } : {},\n ...\"formEncType\" in opts ? { formEncType: opts.formEncType } : {},\n ...\"formData\" in opts ? { formData: opts.formData } : {},\n ...\"body\" in opts ? { body: opts.body } : {}\n };\n}\nfunction getReadonlyRequest(request) {\n return {\n method: request.method,\n url: request.url,\n headers: {\n get: (...args) => request.headers.get(...args)\n }\n };\n}\nfunction getReadonlyContext(context) {\n if (isPlainObject(context)) {\n let frozen = { ...context };\n Object.freeze(frozen);\n return frozen;\n } else {\n return {\n get: (ctx) => context.get(ctx)\n };\n }\n}\nvar objectProtoNames = Object.getOwnPropertyNames(Object.prototype).sort().join(\"\\0\");\nfunction isPlainObject(thing) {\n if (thing === null || typeof thing !== \"object\") {\n return false;\n }\n const proto = Object.getPrototypeOf(thing);\n return proto === Object.prototype || proto === null || Object.getOwnPropertyNames(proto).sort().join(\"\\0\") === objectProtoNames;\n}\n\n// lib/router/router.ts\nvar validMutationMethodsArr = [\n \"POST\",\n \"PUT\",\n \"PATCH\",\n \"DELETE\"\n];\nvar validMutationMethods = new Set(\n validMutationMethodsArr\n);\nvar validRequestMethodsArr = [\n \"GET\",\n ...validMutationMethodsArr\n];\nvar validRequestMethods = new Set(validRequestMethodsArr);\nvar redirectStatusCodes = /* @__PURE__ */ new Set([301, 302, 303, 307, 308]);\nvar redirectPreserveMethodStatusCodes = /* @__PURE__ */ new Set([307, 308]);\nvar IDLE_NAVIGATION = {\n state: \"idle\",\n location: void 0,\n formMethod: void 0,\n formAction: void 0,\n formEncType: void 0,\n formData: void 0,\n json: void 0,\n text: void 0\n};\nvar IDLE_FETCHER = {\n state: \"idle\",\n data: void 0,\n formMethod: void 0,\n formAction: void 0,\n formEncType: void 0,\n formData: void 0,\n json: void 0,\n text: void 0\n};\nvar IDLE_BLOCKER = {\n state: \"unblocked\",\n proceed: void 0,\n reset: void 0,\n location: void 0\n};\nvar defaultMapRouteProperties = (route) => ({\n hasErrorBoundary: Boolean(route.hasErrorBoundary)\n});\nvar TRANSITIONS_STORAGE_KEY = \"remix-router-transitions\";\nvar ResetLoaderDataSymbol = Symbol(\"ResetLoaderData\");\nfunction createRouter(init) {\n const routerWindow = init.window ? init.window : typeof window !== \"undefined\" ? window : void 0;\n const isBrowser3 = typeof routerWindow !== \"undefined\" && typeof routerWindow.document !== \"undefined\" && typeof routerWindow.document.createElement !== \"undefined\";\n invariant(\n init.routes.length > 0,\n \"You must provide a non-empty routes array to createRouter\"\n );\n let hydrationRouteProperties2 = init.hydrationRouteProperties || [];\n let _mapRouteProperties = init.mapRouteProperties || defaultMapRouteProperties;\n let mapRouteProperties2 = _mapRouteProperties;\n if (init.unstable_instrumentations) {\n let instrumentations = init.unstable_instrumentations;\n mapRouteProperties2 = (route) => {\n return {\n ..._mapRouteProperties(route),\n ...getRouteInstrumentationUpdates(\n instrumentations.map((i) => i.route).filter(Boolean),\n route\n )\n };\n };\n }\n let manifest = {};\n let dataRoutes = convertRoutesToDataRoutes(\n init.routes,\n mapRouteProperties2,\n void 0,\n manifest\n );\n let inFlightDataRoutes;\n let basename = init.basename || \"/\";\n if (!basename.startsWith(\"/\")) {\n basename = `/${basename}`;\n }\n let dataStrategyImpl = init.dataStrategy || defaultDataStrategyWithMiddleware;\n let future = {\n unstable_passThroughRequests: false,\n ...init.future\n };\n let unlistenHistory = null;\n let subscribers = /* @__PURE__ */ new Set();\n let savedScrollPositions2 = null;\n let getScrollRestorationKey2 = null;\n let getScrollPosition = null;\n let initialScrollRestored = init.hydrationData != null;\n let initialMatches = matchRoutes(dataRoutes, init.history.location, basename);\n let initialMatchesIsFOW = false;\n let initialErrors = null;\n let initialized;\n let renderFallback;\n if (initialMatches == null && !init.patchRoutesOnNavigation) {\n let error = getInternalRouterError(404, {\n pathname: init.history.location.pathname\n });\n let { matches, route } = getShortCircuitMatches(dataRoutes);\n initialized = true;\n renderFallback = !initialized;\n initialMatches = matches;\n initialErrors = { [route.id]: error };\n } else {\n if (initialMatches && !init.hydrationData) {\n let fogOfWar = checkFogOfWar(\n initialMatches,\n dataRoutes,\n init.history.location.pathname\n );\n if (fogOfWar.active) {\n initialMatches = null;\n }\n }\n if (!initialMatches) {\n initialized = false;\n renderFallback = !initialized;\n initialMatches = [];\n let fogOfWar = checkFogOfWar(\n null,\n dataRoutes,\n init.history.location.pathname\n );\n if (fogOfWar.active && fogOfWar.matches) {\n initialMatchesIsFOW = true;\n initialMatches = fogOfWar.matches;\n }\n } else if (initialMatches.some((m) => m.route.lazy)) {\n initialized = false;\n renderFallback = !initialized;\n } else if (!initialMatches.some((m) => routeHasLoaderOrMiddleware(m.route))) {\n initialized = true;\n renderFallback = !initialized;\n } else {\n let loaderData = init.hydrationData ? init.hydrationData.loaderData : null;\n let errors = init.hydrationData ? init.hydrationData.errors : null;\n let relevantMatches = initialMatches;\n if (errors) {\n let idx = initialMatches.findIndex(\n (m) => errors[m.route.id] !== void 0\n );\n relevantMatches = relevantMatches.slice(0, idx + 1);\n }\n renderFallback = false;\n initialized = true;\n relevantMatches.forEach((m) => {\n let status = getRouteHydrationStatus(m.route, loaderData, errors);\n renderFallback = renderFallback || status.renderFallback;\n initialized = initialized && !status.shouldLoad;\n });\n }\n }\n let router;\n let state = {\n historyAction: init.history.action,\n location: init.history.location,\n matches: initialMatches,\n initialized,\n renderFallback,\n navigation: IDLE_NAVIGATION,\n // Don't restore on initial updateState() if we were SSR'd\n restoreScrollPosition: init.hydrationData != null ? false : null,\n preventScrollReset: false,\n revalidation: \"idle\",\n loaderData: init.hydrationData && init.hydrationData.loaderData || {},\n actionData: init.hydrationData && init.hydrationData.actionData || null,\n errors: init.hydrationData && init.hydrationData.errors || initialErrors,\n fetchers: /* @__PURE__ */ new Map(),\n blockers: /* @__PURE__ */ new Map()\n };\n let pendingAction = \"POP\" /* Pop */;\n let pendingPopstateNavigationDfd = null;\n let pendingPreventScrollReset = false;\n let pendingNavigationController;\n let pendingViewTransitionEnabled = false;\n let appliedViewTransitions = /* @__PURE__ */ new Map();\n let removePageHideEventListener = null;\n let isUninterruptedRevalidation = false;\n let isRevalidationRequired = false;\n let cancelledFetcherLoads = /* @__PURE__ */ new Set();\n let fetchControllers = /* @__PURE__ */ new Map();\n let incrementingLoadId = 0;\n let pendingNavigationLoadId = -1;\n let fetchReloadIds = /* @__PURE__ */ new Map();\n let fetchRedirectIds = /* @__PURE__ */ new Set();\n let fetchLoadMatches = /* @__PURE__ */ new Map();\n let activeFetchers = /* @__PURE__ */ new Map();\n let fetchersQueuedForDeletion = /* @__PURE__ */ new Set();\n let blockerFunctions = /* @__PURE__ */ new Map();\n let unblockBlockerHistoryUpdate = void 0;\n let pendingRevalidationDfd = null;\n function initialize() {\n unlistenHistory = init.history.listen(\n ({ action: historyAction, location, delta }) => {\n if (unblockBlockerHistoryUpdate) {\n unblockBlockerHistoryUpdate();\n unblockBlockerHistoryUpdate = void 0;\n return;\n }\n warning(\n blockerFunctions.size === 0 || delta != null,\n \"You are trying to use a blocker on a POP navigation to a location that was not created by @remix-run/router. This will fail silently in production. This can happen if you are navigating outside the router via `window.history.pushState`/`window.location.hash` instead of using router navigation APIs. This can also happen if you are using createHashRouter and the user manually changes the URL.\"\n );\n let blockerKey = shouldBlockNavigation({\n currentLocation: state.location,\n nextLocation: location,\n historyAction\n });\n if (blockerKey && delta != null) {\n let nextHistoryUpdatePromise = new Promise((resolve) => {\n unblockBlockerHistoryUpdate = resolve;\n });\n init.history.go(delta * -1);\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location,\n proceed() {\n updateBlocker(blockerKey, {\n state: \"proceeding\",\n proceed: void 0,\n reset: void 0,\n location\n });\n nextHistoryUpdatePromise.then(() => init.history.go(delta));\n },\n reset() {\n let blockers = new Map(state.blockers);\n blockers.set(blockerKey, IDLE_BLOCKER);\n updateState({ blockers });\n }\n });\n pendingPopstateNavigationDfd?.resolve();\n pendingPopstateNavigationDfd = null;\n return;\n }\n return startNavigation(historyAction, location);\n }\n );\n if (isBrowser3) {\n restoreAppliedTransitions(routerWindow, appliedViewTransitions);\n let _saveAppliedTransitions = () => persistAppliedTransitions(routerWindow, appliedViewTransitions);\n routerWindow.addEventListener(\"pagehide\", _saveAppliedTransitions);\n removePageHideEventListener = () => routerWindow.removeEventListener(\"pagehide\", _saveAppliedTransitions);\n }\n if (!state.initialized) {\n startNavigation(\"POP\" /* Pop */, state.location, {\n initialHydration: true\n });\n }\n return router;\n }\n function dispose() {\n if (unlistenHistory) {\n unlistenHistory();\n }\n if (removePageHideEventListener) {\n removePageHideEventListener();\n }\n subscribers.clear();\n pendingNavigationController && pendingNavigationController.abort();\n state.fetchers.forEach((_, key) => deleteFetcher(key));\n state.blockers.forEach((_, key) => deleteBlocker(key));\n }\n function subscribe(fn) {\n subscribers.add(fn);\n return () => subscribers.delete(fn);\n }\n function updateState(newState, opts = {}) {\n if (newState.matches) {\n newState.matches = newState.matches.map((m) => {\n let route = manifest[m.route.id];\n let matchRoute = m.route;\n if (matchRoute.element !== route.element || matchRoute.errorElement !== route.errorElement || matchRoute.hydrateFallbackElement !== route.hydrateFallbackElement) {\n return {\n ...m,\n route\n };\n }\n return m;\n });\n }\n state = {\n ...state,\n ...newState\n };\n let unmountedFetchers = [];\n let mountedFetchers = [];\n state.fetchers.forEach((fetcher, key) => {\n if (fetcher.state === \"idle\") {\n if (fetchersQueuedForDeletion.has(key)) {\n unmountedFetchers.push(key);\n } else {\n mountedFetchers.push(key);\n }\n }\n });\n fetchersQueuedForDeletion.forEach((key) => {\n if (!state.fetchers.has(key) && !fetchControllers.has(key)) {\n unmountedFetchers.push(key);\n }\n });\n [...subscribers].forEach(\n (subscriber) => subscriber(state, {\n deletedFetchers: unmountedFetchers,\n newErrors: newState.errors ?? null,\n viewTransitionOpts: opts.viewTransitionOpts,\n flushSync: opts.flushSync === true\n })\n );\n unmountedFetchers.forEach((key) => deleteFetcher(key));\n mountedFetchers.forEach((key) => state.fetchers.delete(key));\n }\n function completeNavigation(location, newState, { flushSync } = {}) {\n let isActionReload = state.actionData != null && state.navigation.formMethod != null && isMutationMethod(state.navigation.formMethod) && state.navigation.state === \"loading\" && location.state?._isRedirect !== true;\n let actionData;\n if (newState.actionData) {\n if (Object.keys(newState.actionData).length > 0) {\n actionData = newState.actionData;\n } else {\n actionData = null;\n }\n } else if (isActionReload) {\n actionData = state.actionData;\n } else {\n actionData = null;\n }\n let loaderData = newState.loaderData ? mergeLoaderData(\n state.loaderData,\n newState.loaderData,\n newState.matches || [],\n newState.errors\n ) : state.loaderData;\n let blockers = state.blockers;\n if (blockers.size > 0) {\n blockers = new Map(blockers);\n blockers.forEach((_, k) => blockers.set(k, IDLE_BLOCKER));\n }\n let restoreScrollPosition = isUninterruptedRevalidation ? false : getSavedScrollPosition(location, newState.matches || state.matches);\n let preventScrollReset = pendingPreventScrollReset === true || state.navigation.formMethod != null && isMutationMethod(state.navigation.formMethod) && location.state?._isRedirect !== true;\n if (inFlightDataRoutes) {\n dataRoutes = inFlightDataRoutes;\n inFlightDataRoutes = void 0;\n }\n if (isUninterruptedRevalidation) {\n } else if (pendingAction === \"POP\" /* Pop */) {\n } else if (pendingAction === \"PUSH\" /* Push */) {\n init.history.push(location, location.state);\n } else if (pendingAction === \"REPLACE\" /* Replace */) {\n init.history.replace(location, location.state);\n }\n let viewTransitionOpts;\n if (pendingAction === \"POP\" /* Pop */) {\n let priorPaths = appliedViewTransitions.get(state.location.pathname);\n if (priorPaths && priorPaths.has(location.pathname)) {\n viewTransitionOpts = {\n currentLocation: state.location,\n nextLocation: location\n };\n } else if (appliedViewTransitions.has(location.pathname)) {\n viewTransitionOpts = {\n currentLocation: location,\n nextLocation: state.location\n };\n }\n } else if (pendingViewTransitionEnabled) {\n let toPaths = appliedViewTransitions.get(state.location.pathname);\n if (toPaths) {\n toPaths.add(location.pathname);\n } else {\n toPaths = /* @__PURE__ */ new Set([location.pathname]);\n appliedViewTransitions.set(state.location.pathname, toPaths);\n }\n viewTransitionOpts = {\n currentLocation: state.location,\n nextLocation: location\n };\n }\n updateState(\n {\n ...newState,\n // matches, errors, fetchers go through as-is\n actionData,\n loaderData,\n historyAction: pendingAction,\n location,\n initialized: true,\n renderFallback: false,\n navigation: IDLE_NAVIGATION,\n revalidation: \"idle\",\n restoreScrollPosition,\n preventScrollReset,\n blockers\n },\n {\n viewTransitionOpts,\n flushSync: flushSync === true\n }\n );\n pendingAction = \"POP\" /* Pop */;\n pendingPreventScrollReset = false;\n pendingViewTransitionEnabled = false;\n isUninterruptedRevalidation = false;\n isRevalidationRequired = false;\n pendingPopstateNavigationDfd?.resolve();\n pendingPopstateNavigationDfd = null;\n pendingRevalidationDfd?.resolve();\n pendingRevalidationDfd = null;\n }\n async function navigate(to, opts) {\n pendingPopstateNavigationDfd?.resolve();\n pendingPopstateNavigationDfd = null;\n if (typeof to === \"number\") {\n if (!pendingPopstateNavigationDfd) {\n pendingPopstateNavigationDfd = createDeferred();\n }\n let promise = pendingPopstateNavigationDfd.promise;\n init.history.go(to);\n return promise;\n }\n let normalizedPath = normalizeTo(\n state.location,\n state.matches,\n basename,\n to,\n opts?.fromRouteId,\n opts?.relative\n );\n let { path, submission, error } = normalizeNavigateOptions(\n false,\n normalizedPath,\n opts\n );\n let maskPath;\n if (opts?.unstable_mask) {\n let partialPath = typeof opts.unstable_mask === \"string\" ? parsePath(opts.unstable_mask) : {\n ...state.location.unstable_mask,\n ...opts.unstable_mask\n };\n maskPath = {\n pathname: \"\",\n search: \"\",\n hash: \"\",\n ...partialPath\n };\n }\n let currentLocation = state.location;\n let nextLocation = createLocation(\n currentLocation,\n path,\n opts && opts.state,\n void 0,\n maskPath\n );\n nextLocation = {\n ...nextLocation,\n ...init.history.encodeLocation(nextLocation)\n };\n let userReplace = opts && opts.replace != null ? opts.replace : void 0;\n let historyAction = \"PUSH\" /* Push */;\n if (userReplace === true) {\n historyAction = \"REPLACE\" /* Replace */;\n } else if (userReplace === false) {\n } else if (submission != null && isMutationMethod(submission.formMethod) && submission.formAction === state.location.pathname + state.location.search) {\n historyAction = \"REPLACE\" /* Replace */;\n }\n let preventScrollReset = opts && \"preventScrollReset\" in opts ? opts.preventScrollReset === true : void 0;\n let flushSync = (opts && opts.flushSync) === true;\n let blockerKey = shouldBlockNavigation({\n currentLocation,\n nextLocation,\n historyAction\n });\n if (blockerKey) {\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location: nextLocation,\n proceed() {\n updateBlocker(blockerKey, {\n state: \"proceeding\",\n proceed: void 0,\n reset: void 0,\n location: nextLocation\n });\n navigate(to, opts);\n },\n reset() {\n let blockers = new Map(state.blockers);\n blockers.set(blockerKey, IDLE_BLOCKER);\n updateState({ blockers });\n }\n });\n return;\n }\n await startNavigation(historyAction, nextLocation, {\n submission,\n // Send through the formData serialization error if we have one so we can\n // render at the right error boundary after we match routes\n pendingError: error,\n preventScrollReset,\n replace: opts && opts.replace,\n enableViewTransition: opts && opts.viewTransition,\n flushSync,\n callSiteDefaultShouldRevalidate: opts && opts.unstable_defaultShouldRevalidate\n });\n }\n function revalidate() {\n if (!pendingRevalidationDfd) {\n pendingRevalidationDfd = createDeferred();\n }\n interruptActiveLoads();\n updateState({ revalidation: \"loading\" });\n let promise = pendingRevalidationDfd.promise;\n if (state.navigation.state === \"submitting\") {\n return promise;\n }\n if (state.navigation.state === \"idle\") {\n startNavigation(state.historyAction, state.location, {\n startUninterruptedRevalidation: true\n });\n return promise;\n }\n startNavigation(\n pendingAction || state.historyAction,\n state.navigation.location,\n {\n overrideNavigation: state.navigation,\n // Proxy through any rending view transition\n enableViewTransition: pendingViewTransitionEnabled === true\n }\n );\n return promise;\n }\n async function startNavigation(historyAction, location, opts) {\n pendingNavigationController && pendingNavigationController.abort();\n pendingNavigationController = null;\n pendingAction = historyAction;\n isUninterruptedRevalidation = (opts && opts.startUninterruptedRevalidation) === true;\n saveScrollPosition(state.location, state.matches);\n pendingPreventScrollReset = (opts && opts.preventScrollReset) === true;\n pendingViewTransitionEnabled = (opts && opts.enableViewTransition) === true;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let loadingNavigation = opts && opts.overrideNavigation;\n let matches = opts?.initialHydration && state.matches && state.matches.length > 0 && !initialMatchesIsFOW ? (\n // `matchRoutes()` has already been called if we're in here via `router.initialize()`\n state.matches\n ) : matchRoutes(routesToUse, location, basename);\n let flushSync = (opts && opts.flushSync) === true;\n if (matches && state.initialized && !isRevalidationRequired && isHashChangeOnly(state.location, location) && !(opts && opts.submission && isMutationMethod(opts.submission.formMethod))) {\n completeNavigation(location, { matches }, { flushSync });\n return;\n }\n let fogOfWar = checkFogOfWar(matches, routesToUse, location.pathname);\n if (fogOfWar.active && fogOfWar.matches) {\n matches = fogOfWar.matches;\n }\n if (!matches) {\n let { error, notFoundMatches, route } = handleNavigational404(\n location.pathname\n );\n completeNavigation(\n location,\n {\n matches: notFoundMatches,\n loaderData: {},\n errors: {\n [route.id]: error\n }\n },\n { flushSync }\n );\n return;\n }\n pendingNavigationController = new AbortController();\n let request = createClientSideRequest(\n init.history,\n location,\n pendingNavigationController.signal,\n opts && opts.submission\n );\n let scopedContext = init.getContext ? await init.getContext() : new RouterContextProvider();\n let pendingActionResult;\n if (opts && opts.pendingError) {\n pendingActionResult = [\n findNearestBoundary(matches).route.id,\n { type: \"error\" /* error */, error: opts.pendingError }\n ];\n } else if (opts && opts.submission && isMutationMethod(opts.submission.formMethod)) {\n let actionResult = await handleAction(\n request,\n location,\n opts.submission,\n matches,\n scopedContext,\n fogOfWar.active,\n opts && opts.initialHydration === true,\n { replace: opts.replace, flushSync }\n );\n if (actionResult.shortCircuited) {\n return;\n }\n if (actionResult.pendingActionResult) {\n let [routeId, result] = actionResult.pendingActionResult;\n if (isErrorResult(result) && isRouteErrorResponse(result.error) && result.error.status === 404) {\n pendingNavigationController = null;\n completeNavigation(location, {\n matches: actionResult.matches,\n loaderData: {},\n errors: {\n [routeId]: result.error\n }\n });\n return;\n }\n }\n matches = actionResult.matches || matches;\n pendingActionResult = actionResult.pendingActionResult;\n loadingNavigation = getLoadingNavigation(location, opts.submission);\n flushSync = false;\n fogOfWar.active = false;\n request = createClientSideRequest(\n init.history,\n request.url,\n request.signal\n );\n }\n let {\n shortCircuited,\n matches: updatedMatches,\n loaderData,\n errors\n } = await handleLoaders(\n request,\n location,\n matches,\n scopedContext,\n fogOfWar.active,\n loadingNavigation,\n opts && opts.submission,\n opts && opts.fetcherSubmission,\n opts && opts.replace,\n opts && opts.initialHydration === true,\n flushSync,\n pendingActionResult,\n opts && opts.callSiteDefaultShouldRevalidate\n );\n if (shortCircuited) {\n return;\n }\n pendingNavigationController = null;\n completeNavigation(location, {\n matches: updatedMatches || matches,\n ...getActionDataForCommit(pendingActionResult),\n loaderData,\n errors\n });\n }\n async function handleAction(request, location, submission, matches, scopedContext, isFogOfWar, initialHydration, opts = {}) {\n interruptActiveLoads();\n let navigation = getSubmittingNavigation(location, submission);\n updateState({ navigation }, { flushSync: opts.flushSync === true });\n if (isFogOfWar) {\n let discoverResult = await discoverRoutes(\n matches,\n location.pathname,\n request.signal\n );\n if (discoverResult.type === \"aborted\") {\n return { shortCircuited: true };\n } else if (discoverResult.type === \"error\") {\n if (discoverResult.partialMatches.length === 0) {\n let { matches: matches2, route } = getShortCircuitMatches(dataRoutes);\n return {\n matches: matches2,\n pendingActionResult: [\n route.id,\n {\n type: \"error\" /* error */,\n error: discoverResult.error\n }\n ]\n };\n }\n let boundaryId = findNearestBoundary(discoverResult.partialMatches).route.id;\n return {\n matches: discoverResult.partialMatches,\n pendingActionResult: [\n boundaryId,\n {\n type: \"error\" /* error */,\n error: discoverResult.error\n }\n ]\n };\n } else if (!discoverResult.matches) {\n let { notFoundMatches, error, route } = handleNavigational404(\n location.pathname\n );\n return {\n matches: notFoundMatches,\n pendingActionResult: [\n route.id,\n {\n type: \"error\" /* error */,\n error\n }\n ]\n };\n } else {\n matches = discoverResult.matches;\n }\n }\n let result;\n let actionMatch = getTargetMatch(matches, location);\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n result = {\n type: \"error\" /* error */,\n error: getInternalRouterError(405, {\n method: request.method,\n pathname: location.pathname,\n routeId: actionMatch.route.id\n })\n };\n } else {\n let dsMatches = getTargetedDataStrategyMatches(\n mapRouteProperties2,\n manifest,\n request,\n location,\n matches,\n actionMatch,\n initialHydration ? [] : hydrationRouteProperties2,\n scopedContext\n );\n let results = await callDataStrategy(\n request,\n location,\n dsMatches,\n scopedContext,\n null\n );\n result = results[actionMatch.route.id];\n if (!result) {\n for (let match of matches) {\n if (results[match.route.id]) {\n result = results[match.route.id];\n break;\n }\n }\n }\n if (request.signal.aborted) {\n return { shortCircuited: true };\n }\n }\n if (isRedirectResult(result)) {\n let replace2;\n if (opts && opts.replace != null) {\n replace2 = opts.replace;\n } else {\n let location2 = normalizeRedirectLocation(\n result.response.headers.get(\"Location\"),\n new URL(request.url),\n basename,\n init.history\n );\n replace2 = location2 === state.location.pathname + state.location.search;\n }\n await startRedirectNavigation(request, result, true, {\n submission,\n replace: replace2\n });\n return { shortCircuited: true };\n }\n if (isErrorResult(result)) {\n let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);\n if ((opts && opts.replace) !== true) {\n pendingAction = \"PUSH\" /* Push */;\n }\n return {\n matches,\n pendingActionResult: [\n boundaryMatch.route.id,\n result,\n actionMatch.route.id\n ]\n };\n }\n return {\n matches,\n pendingActionResult: [actionMatch.route.id, result]\n };\n }\n async function handleLoaders(request, location, matches, scopedContext, isFogOfWar, overrideNavigation, submission, fetcherSubmission, replace2, initialHydration, flushSync, pendingActionResult, callSiteDefaultShouldRevalidate) {\n let loadingNavigation = overrideNavigation || getLoadingNavigation(location, submission);\n let activeSubmission = submission || fetcherSubmission || getSubmissionFromNavigation(loadingNavigation);\n let shouldUpdateNavigationState = !isUninterruptedRevalidation && !initialHydration;\n if (isFogOfWar) {\n if (shouldUpdateNavigationState) {\n let actionData = getUpdatedActionData(pendingActionResult);\n updateState(\n {\n navigation: loadingNavigation,\n ...actionData !== void 0 ? { actionData } : {}\n },\n {\n flushSync\n }\n );\n }\n let discoverResult = await discoverRoutes(\n matches,\n location.pathname,\n request.signal\n );\n if (discoverResult.type === \"aborted\") {\n return { shortCircuited: true };\n } else if (discoverResult.type === \"error\") {\n if (discoverResult.partialMatches.length === 0) {\n let { matches: matches2, route } = getShortCircuitMatches(dataRoutes);\n return {\n matches: matches2,\n loaderData: {},\n errors: {\n [route.id]: discoverResult.error\n }\n };\n }\n let boundaryId = findNearestBoundary(discoverResult.partialMatches).route.id;\n return {\n matches: discoverResult.partialMatches,\n loaderData: {},\n errors: {\n [boundaryId]: discoverResult.error\n }\n };\n } else if (!discoverResult.matches) {\n let { error, notFoundMatches, route } = handleNavigational404(\n location.pathname\n );\n return {\n matches: notFoundMatches,\n loaderData: {},\n errors: {\n [route.id]: error\n }\n };\n } else {\n matches = discoverResult.matches;\n }\n }\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let { dsMatches, revalidatingFetchers } = getMatchesToLoad(\n request,\n scopedContext,\n mapRouteProperties2,\n manifest,\n init.history,\n state,\n matches,\n activeSubmission,\n location,\n initialHydration ? [] : hydrationRouteProperties2,\n initialHydration === true,\n isRevalidationRequired,\n cancelledFetcherLoads,\n fetchersQueuedForDeletion,\n fetchLoadMatches,\n fetchRedirectIds,\n routesToUse,\n basename,\n init.patchRoutesOnNavigation != null,\n pendingActionResult,\n callSiteDefaultShouldRevalidate\n );\n pendingNavigationLoadId = ++incrementingLoadId;\n if (!init.dataStrategy && !dsMatches.some((m) => m.shouldLoad) && !dsMatches.some(\n (m) => m.route.middleware && m.route.middleware.length > 0\n ) && revalidatingFetchers.length === 0) {\n let updatedFetchers2 = markFetchRedirectsDone();\n completeNavigation(\n location,\n {\n matches,\n loaderData: {},\n // Commit pending error if we're short circuiting\n errors: pendingActionResult && isErrorResult(pendingActionResult[1]) ? { [pendingActionResult[0]]: pendingActionResult[1].error } : null,\n ...getActionDataForCommit(pendingActionResult),\n ...updatedFetchers2 ? { fetchers: new Map(state.fetchers) } : {}\n },\n { flushSync }\n );\n return { shortCircuited: true };\n }\n if (shouldUpdateNavigationState) {\n let updates = {};\n if (!isFogOfWar) {\n updates.navigation = loadingNavigation;\n let actionData = getUpdatedActionData(pendingActionResult);\n if (actionData !== void 0) {\n updates.actionData = actionData;\n }\n }\n if (revalidatingFetchers.length > 0) {\n updates.fetchers = getUpdatedRevalidatingFetchers(revalidatingFetchers);\n }\n updateState(updates, { flushSync });\n }\n revalidatingFetchers.forEach((rf) => {\n abortFetcher(rf.key);\n if (rf.controller) {\n fetchControllers.set(rf.key, rf.controller);\n }\n });\n let abortPendingFetchRevalidations = () => revalidatingFetchers.forEach((f) => abortFetcher(f.key));\n if (pendingNavigationController) {\n pendingNavigationController.signal.addEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n }\n let { loaderResults, fetcherResults } = await callLoadersAndMaybeResolveData(\n dsMatches,\n revalidatingFetchers,\n request,\n location,\n scopedContext\n );\n if (request.signal.aborted) {\n return { shortCircuited: true };\n }\n if (pendingNavigationController) {\n pendingNavigationController.signal.removeEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n }\n revalidatingFetchers.forEach((rf) => fetchControllers.delete(rf.key));\n let redirect2 = findRedirect(loaderResults);\n if (redirect2) {\n await startRedirectNavigation(request, redirect2.result, true, {\n replace: replace2\n });\n return { shortCircuited: true };\n }\n redirect2 = findRedirect(fetcherResults);\n if (redirect2) {\n fetchRedirectIds.add(redirect2.key);\n await startRedirectNavigation(request, redirect2.result, true, {\n replace: replace2\n });\n return { shortCircuited: true };\n }\n let { loaderData, errors } = processLoaderData(\n state,\n matches,\n loaderResults,\n pendingActionResult,\n revalidatingFetchers,\n fetcherResults\n );\n if (initialHydration && state.errors) {\n errors = { ...state.errors, ...errors };\n }\n let updatedFetchers = markFetchRedirectsDone();\n let didAbortFetchLoads = abortStaleFetchLoads(pendingNavigationLoadId);\n let shouldUpdateFetchers = updatedFetchers || didAbortFetchLoads || revalidatingFetchers.length > 0;\n return {\n matches,\n loaderData,\n errors,\n ...shouldUpdateFetchers ? { fetchers: new Map(state.fetchers) } : {}\n };\n }\n function getUpdatedActionData(pendingActionResult) {\n if (pendingActionResult && !isErrorResult(pendingActionResult[1])) {\n return {\n [pendingActionResult[0]]: pendingActionResult[1].data\n };\n } else if (state.actionData) {\n if (Object.keys(state.actionData).length === 0) {\n return null;\n } else {\n return state.actionData;\n }\n }\n }\n function getUpdatedRevalidatingFetchers(revalidatingFetchers) {\n revalidatingFetchers.forEach((rf) => {\n let fetcher = state.fetchers.get(rf.key);\n let revalidatingFetcher = getLoadingFetcher(\n void 0,\n fetcher ? fetcher.data : void 0\n );\n state.fetchers.set(rf.key, revalidatingFetcher);\n });\n return new Map(state.fetchers);\n }\n async function fetch2(key, routeId, href, opts) {\n abortFetcher(key);\n let flushSync = (opts && opts.flushSync) === true;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let normalizedPath = normalizeTo(\n state.location,\n state.matches,\n basename,\n href,\n routeId,\n opts?.relative\n );\n let matches = matchRoutes(routesToUse, normalizedPath, basename);\n let fogOfWar = checkFogOfWar(matches, routesToUse, normalizedPath);\n if (fogOfWar.active && fogOfWar.matches) {\n matches = fogOfWar.matches;\n }\n if (!matches) {\n setFetcherError(\n key,\n routeId,\n getInternalRouterError(404, { pathname: normalizedPath }),\n { flushSync }\n );\n return;\n }\n let { path, submission, error } = normalizeNavigateOptions(\n true,\n normalizedPath,\n opts\n );\n if (error) {\n setFetcherError(key, routeId, error, { flushSync });\n return;\n }\n let scopedContext = init.getContext ? await init.getContext() : new RouterContextProvider();\n let preventScrollReset = (opts && opts.preventScrollReset) === true;\n if (submission && isMutationMethod(submission.formMethod)) {\n await handleFetcherAction(\n key,\n routeId,\n path,\n matches,\n scopedContext,\n fogOfWar.active,\n flushSync,\n preventScrollReset,\n submission,\n opts && opts.unstable_defaultShouldRevalidate\n );\n return;\n }\n fetchLoadMatches.set(key, { routeId, path });\n await handleFetcherLoader(\n key,\n routeId,\n path,\n matches,\n scopedContext,\n fogOfWar.active,\n flushSync,\n preventScrollReset,\n submission\n );\n }\n async function handleFetcherAction(key, routeId, path, requestMatches, scopedContext, isFogOfWar, flushSync, preventScrollReset, submission, callSiteDefaultShouldRevalidate) {\n interruptActiveLoads();\n fetchLoadMatches.delete(key);\n let existingFetcher = state.fetchers.get(key);\n updateFetcherState(key, getSubmittingFetcher(submission, existingFetcher), {\n flushSync\n });\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(\n init.history,\n path,\n abortController.signal,\n submission\n );\n if (isFogOfWar) {\n let discoverResult = await discoverRoutes(\n requestMatches,\n new URL(fetchRequest.url).pathname,\n fetchRequest.signal,\n key\n );\n if (discoverResult.type === \"aborted\") {\n return;\n } else if (discoverResult.type === \"error\") {\n setFetcherError(key, routeId, discoverResult.error, { flushSync });\n return;\n } else if (!discoverResult.matches) {\n setFetcherError(\n key,\n routeId,\n getInternalRouterError(404, { pathname: path }),\n { flushSync }\n );\n return;\n } else {\n requestMatches = discoverResult.matches;\n }\n }\n let match = getTargetMatch(requestMatches, path);\n if (!match.route.action && !match.route.lazy) {\n let error = getInternalRouterError(405, {\n method: submission.formMethod,\n pathname: path,\n routeId\n });\n setFetcherError(key, routeId, error, { flushSync });\n return;\n }\n fetchControllers.set(key, abortController);\n let originatingLoadId = incrementingLoadId;\n let fetchMatches = getTargetedDataStrategyMatches(\n mapRouteProperties2,\n manifest,\n fetchRequest,\n path,\n requestMatches,\n match,\n hydrationRouteProperties2,\n scopedContext\n );\n let actionResults = await callDataStrategy(\n fetchRequest,\n path,\n fetchMatches,\n scopedContext,\n key\n );\n let actionResult = actionResults[match.route.id];\n if (!actionResult) {\n for (let match2 of fetchMatches) {\n if (actionResults[match2.route.id]) {\n actionResult = actionResults[match2.route.id];\n break;\n }\n }\n }\n if (fetchRequest.signal.aborted) {\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n return;\n }\n if (fetchersQueuedForDeletion.has(key)) {\n if (isRedirectResult(actionResult) || isErrorResult(actionResult)) {\n updateFetcherState(key, getDoneFetcher(void 0));\n return;\n }\n } else {\n if (isRedirectResult(actionResult)) {\n fetchControllers.delete(key);\n if (pendingNavigationLoadId > originatingLoadId) {\n updateFetcherState(key, getDoneFetcher(void 0));\n return;\n } else {\n fetchRedirectIds.add(key);\n updateFetcherState(key, getLoadingFetcher(submission));\n return startRedirectNavigation(fetchRequest, actionResult, false, {\n fetcherSubmission: submission,\n preventScrollReset\n });\n }\n }\n if (isErrorResult(actionResult)) {\n setFetcherError(key, routeId, actionResult.error);\n return;\n }\n }\n let nextLocation = state.navigation.location || state.location;\n let revalidationRequest = createClientSideRequest(\n init.history,\n nextLocation,\n abortController.signal\n );\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let matches = state.navigation.state !== \"idle\" ? matchRoutes(routesToUse, state.navigation.location, basename) : state.matches;\n invariant(matches, \"Didn't find any matches after fetcher action\");\n let loadId = ++incrementingLoadId;\n fetchReloadIds.set(key, loadId);\n let loadFetcher = getLoadingFetcher(submission, actionResult.data);\n state.fetchers.set(key, loadFetcher);\n let { dsMatches, revalidatingFetchers } = getMatchesToLoad(\n revalidationRequest,\n scopedContext,\n mapRouteProperties2,\n manifest,\n init.history,\n state,\n matches,\n submission,\n nextLocation,\n hydrationRouteProperties2,\n false,\n isRevalidationRequired,\n cancelledFetcherLoads,\n fetchersQueuedForDeletion,\n fetchLoadMatches,\n fetchRedirectIds,\n routesToUse,\n basename,\n init.patchRoutesOnNavigation != null,\n [match.route.id, actionResult],\n callSiteDefaultShouldRevalidate\n );\n revalidatingFetchers.filter((rf) => rf.key !== key).forEach((rf) => {\n let staleKey = rf.key;\n let existingFetcher2 = state.fetchers.get(staleKey);\n let revalidatingFetcher = getLoadingFetcher(\n void 0,\n existingFetcher2 ? existingFetcher2.data : void 0\n );\n state.fetchers.set(staleKey, revalidatingFetcher);\n abortFetcher(staleKey);\n if (rf.controller) {\n fetchControllers.set(staleKey, rf.controller);\n }\n });\n updateState({ fetchers: new Map(state.fetchers) });\n let abortPendingFetchRevalidations = () => revalidatingFetchers.forEach((rf) => abortFetcher(rf.key));\n abortController.signal.addEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n let { loaderResults, fetcherResults } = await callLoadersAndMaybeResolveData(\n dsMatches,\n revalidatingFetchers,\n revalidationRequest,\n nextLocation,\n scopedContext\n );\n if (abortController.signal.aborted) {\n return;\n }\n abortController.signal.removeEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n fetchReloadIds.delete(key);\n fetchControllers.delete(key);\n revalidatingFetchers.forEach((r) => fetchControllers.delete(r.key));\n if (state.fetchers.has(key)) {\n let doneFetcher = getDoneFetcher(actionResult.data);\n state.fetchers.set(key, doneFetcher);\n }\n let redirect2 = findRedirect(loaderResults);\n if (redirect2) {\n return startRedirectNavigation(\n revalidationRequest,\n redirect2.result,\n false,\n { preventScrollReset }\n );\n }\n redirect2 = findRedirect(fetcherResults);\n if (redirect2) {\n fetchRedirectIds.add(redirect2.key);\n return startRedirectNavigation(\n revalidationRequest,\n redirect2.result,\n false,\n { preventScrollReset }\n );\n }\n let { loaderData, errors } = processLoaderData(\n state,\n matches,\n loaderResults,\n void 0,\n revalidatingFetchers,\n fetcherResults\n );\n abortStaleFetchLoads(loadId);\n if (state.navigation.state === \"loading\" && loadId > pendingNavigationLoadId) {\n invariant(pendingAction, \"Expected pending action\");\n pendingNavigationController && pendingNavigationController.abort();\n completeNavigation(state.navigation.location, {\n matches,\n loaderData,\n errors,\n fetchers: new Map(state.fetchers)\n });\n } else {\n updateState({\n errors,\n loaderData: mergeLoaderData(\n state.loaderData,\n loaderData,\n matches,\n errors\n ),\n fetchers: new Map(state.fetchers)\n });\n isRevalidationRequired = false;\n }\n }\n async function handleFetcherLoader(key, routeId, path, matches, scopedContext, isFogOfWar, flushSync, preventScrollReset, submission) {\n let existingFetcher = state.fetchers.get(key);\n updateFetcherState(\n key,\n getLoadingFetcher(\n submission,\n existingFetcher ? existingFetcher.data : void 0\n ),\n { flushSync }\n );\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(\n init.history,\n path,\n abortController.signal\n );\n if (isFogOfWar) {\n let discoverResult = await discoverRoutes(\n matches,\n new URL(fetchRequest.url).pathname,\n fetchRequest.signal,\n key\n );\n if (discoverResult.type === \"aborted\") {\n return;\n } else if (discoverResult.type === \"error\") {\n setFetcherError(key, routeId, discoverResult.error, { flushSync });\n return;\n } else if (!discoverResult.matches) {\n setFetcherError(\n key,\n routeId,\n getInternalRouterError(404, { pathname: path }),\n { flushSync }\n );\n return;\n } else {\n matches = discoverResult.matches;\n }\n }\n let match = getTargetMatch(matches, path);\n fetchControllers.set(key, abortController);\n let originatingLoadId = incrementingLoadId;\n let dsMatches = getTargetedDataStrategyMatches(\n mapRouteProperties2,\n manifest,\n fetchRequest,\n path,\n matches,\n match,\n hydrationRouteProperties2,\n scopedContext\n );\n let results = await callDataStrategy(\n fetchRequest,\n path,\n dsMatches,\n scopedContext,\n key\n );\n let result = results[match.route.id];\n if (!result) {\n for (let match2 of matches) {\n if (results[match2.route.id]) {\n result = results[match2.route.id];\n break;\n }\n }\n }\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n if (fetchRequest.signal.aborted) {\n return;\n }\n if (fetchersQueuedForDeletion.has(key)) {\n updateFetcherState(key, getDoneFetcher(void 0));\n return;\n }\n if (isRedirectResult(result)) {\n if (pendingNavigationLoadId > originatingLoadId) {\n updateFetcherState(key, getDoneFetcher(void 0));\n return;\n } else {\n fetchRedirectIds.add(key);\n await startRedirectNavigation(fetchRequest, result, false, {\n preventScrollReset\n });\n return;\n }\n }\n if (isErrorResult(result)) {\n setFetcherError(key, routeId, result.error);\n return;\n }\n updateFetcherState(key, getDoneFetcher(result.data));\n }\n async function startRedirectNavigation(request, redirect2, isNavigation, {\n submission,\n fetcherSubmission,\n preventScrollReset,\n replace: replace2\n } = {}) {\n if (!isNavigation) {\n pendingPopstateNavigationDfd?.resolve();\n pendingPopstateNavigationDfd = null;\n }\n if (redirect2.response.headers.has(\"X-Remix-Revalidate\")) {\n isRevalidationRequired = true;\n }\n let location = redirect2.response.headers.get(\"Location\");\n invariant(location, \"Expected a Location header on the redirect Response\");\n location = normalizeRedirectLocation(\n location,\n new URL(request.url),\n basename,\n init.history\n );\n let redirectLocation = createLocation(state.location, location, {\n _isRedirect: true\n });\n if (isBrowser3) {\n let isDocumentReload = false;\n if (redirect2.response.headers.has(\"X-Remix-Reload-Document\")) {\n isDocumentReload = true;\n } else if (isAbsoluteUrl(location)) {\n const url = createBrowserURLImpl(location, true);\n isDocumentReload = // Hard reload if it's an absolute URL to a new origin\n url.origin !== routerWindow.location.origin || // Hard reload if it's an absolute URL that does not match our basename\n stripBasename(url.pathname, basename) == null;\n }\n if (isDocumentReload) {\n if (replace2) {\n routerWindow.location.replace(location);\n } else {\n routerWindow.location.assign(location);\n }\n return;\n }\n }\n pendingNavigationController = null;\n let redirectNavigationType = replace2 === true || redirect2.response.headers.has(\"X-Remix-Replace\") ? \"REPLACE\" /* Replace */ : \"PUSH\" /* Push */;\n let { formMethod, formAction, formEncType } = state.navigation;\n if (!submission && !fetcherSubmission && formMethod && formAction && formEncType) {\n submission = getSubmissionFromNavigation(state.navigation);\n }\n let activeSubmission = submission || fetcherSubmission;\n if (redirectPreserveMethodStatusCodes.has(redirect2.response.status) && activeSubmission && isMutationMethod(activeSubmission.formMethod)) {\n await startNavigation(redirectNavigationType, redirectLocation, {\n submission: {\n ...activeSubmission,\n formAction: location\n },\n // Preserve these flags across redirects\n preventScrollReset: preventScrollReset || pendingPreventScrollReset,\n enableViewTransition: isNavigation ? pendingViewTransitionEnabled : void 0\n });\n } else {\n let overrideNavigation = getLoadingNavigation(\n redirectLocation,\n submission\n );\n await startNavigation(redirectNavigationType, redirectLocation, {\n overrideNavigation,\n // Send fetcher submissions through for shouldRevalidate\n fetcherSubmission,\n // Preserve these flags across redirects\n preventScrollReset: preventScrollReset || pendingPreventScrollReset,\n enableViewTransition: isNavigation ? pendingViewTransitionEnabled : void 0\n });\n }\n }\n async function callDataStrategy(request, path, matches, scopedContext, fetcherKey) {\n let results;\n let dataResults = {};\n try {\n results = await callDataStrategyImpl(\n dataStrategyImpl,\n request,\n path,\n matches,\n fetcherKey,\n scopedContext,\n false\n );\n } catch (e) {\n matches.filter((m) => m.shouldLoad).forEach((m) => {\n dataResults[m.route.id] = {\n type: \"error\" /* error */,\n error: e\n };\n });\n return dataResults;\n }\n if (request.signal.aborted) {\n return dataResults;\n }\n if (!isMutationMethod(request.method)) {\n for (let match of matches) {\n if (results[match.route.id]?.type === \"error\" /* error */) {\n break;\n }\n if (!results.hasOwnProperty(match.route.id) && !state.loaderData.hasOwnProperty(match.route.id) && (!state.errors || !state.errors.hasOwnProperty(match.route.id)) && match.shouldCallHandler()) {\n results[match.route.id] = {\n type: \"error\" /* error */,\n result: new Error(\n `No result returned from dataStrategy for route ${match.route.id}`\n )\n };\n }\n }\n }\n for (let [routeId, result] of Object.entries(results)) {\n if (isRedirectDataStrategyResult(result)) {\n let response = result.result;\n dataResults[routeId] = {\n type: \"redirect\" /* redirect */,\n response: normalizeRelativeRoutingRedirectResponse(\n response,\n request,\n routeId,\n matches,\n basename\n )\n };\n } else {\n dataResults[routeId] = await convertDataStrategyResultToDataResult(result);\n }\n }\n return dataResults;\n }\n async function callLoadersAndMaybeResolveData(matches, fetchersToLoad, request, location, scopedContext) {\n let loaderResultsPromise = callDataStrategy(\n request,\n location,\n matches,\n scopedContext,\n null\n );\n let fetcherResultsPromise = Promise.all(\n fetchersToLoad.map(async (f) => {\n if (f.matches && f.match && f.request && f.controller) {\n let results = await callDataStrategy(\n f.request,\n f.path,\n f.matches,\n scopedContext,\n f.key\n );\n let result = results[f.match.route.id];\n return { [f.key]: result };\n } else {\n return Promise.resolve({\n [f.key]: {\n type: \"error\" /* error */,\n error: getInternalRouterError(404, {\n pathname: f.path\n })\n }\n });\n }\n })\n );\n let loaderResults = await loaderResultsPromise;\n let fetcherResults = (await fetcherResultsPromise).reduce(\n (acc, r) => Object.assign(acc, r),\n {}\n );\n return {\n loaderResults,\n fetcherResults\n };\n }\n function interruptActiveLoads() {\n isRevalidationRequired = true;\n fetchLoadMatches.forEach((_, key) => {\n if (fetchControllers.has(key)) {\n cancelledFetcherLoads.add(key);\n }\n abortFetcher(key);\n });\n }\n function updateFetcherState(key, fetcher, opts = {}) {\n state.fetchers.set(key, fetcher);\n updateState(\n { fetchers: new Map(state.fetchers) },\n { flushSync: (opts && opts.flushSync) === true }\n );\n }\n function setFetcherError(key, routeId, error, opts = {}) {\n let boundaryMatch = findNearestBoundary(state.matches, routeId);\n deleteFetcher(key);\n updateState(\n {\n errors: {\n [boundaryMatch.route.id]: error\n },\n fetchers: new Map(state.fetchers)\n },\n { flushSync: (opts && opts.flushSync) === true }\n );\n }\n function getFetcher(key) {\n activeFetchers.set(key, (activeFetchers.get(key) || 0) + 1);\n if (fetchersQueuedForDeletion.has(key)) {\n fetchersQueuedForDeletion.delete(key);\n }\n return state.fetchers.get(key) || IDLE_FETCHER;\n }\n function resetFetcher(key, opts) {\n abortFetcher(key, opts?.reason);\n updateFetcherState(key, getDoneFetcher(null));\n }\n function deleteFetcher(key) {\n let fetcher = state.fetchers.get(key);\n if (fetchControllers.has(key) && !(fetcher && fetcher.state === \"loading\" && fetchReloadIds.has(key))) {\n abortFetcher(key);\n }\n fetchLoadMatches.delete(key);\n fetchReloadIds.delete(key);\n fetchRedirectIds.delete(key);\n fetchersQueuedForDeletion.delete(key);\n cancelledFetcherLoads.delete(key);\n state.fetchers.delete(key);\n }\n function queueFetcherForDeletion(key) {\n let count = (activeFetchers.get(key) || 0) - 1;\n if (count <= 0) {\n activeFetchers.delete(key);\n fetchersQueuedForDeletion.add(key);\n } else {\n activeFetchers.set(key, count);\n }\n updateState({ fetchers: new Map(state.fetchers) });\n }\n function abortFetcher(key, reason) {\n let controller = fetchControllers.get(key);\n if (controller) {\n controller.abort(reason);\n fetchControllers.delete(key);\n }\n }\n function markFetchersDone(keys) {\n for (let key of keys) {\n let fetcher = getFetcher(key);\n let doneFetcher = getDoneFetcher(fetcher.data);\n state.fetchers.set(key, doneFetcher);\n }\n }\n function markFetchRedirectsDone() {\n let doneKeys = [];\n let updatedFetchers = false;\n for (let key of fetchRedirectIds) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, `Expected fetcher: ${key}`);\n if (fetcher.state === \"loading\") {\n fetchRedirectIds.delete(key);\n doneKeys.push(key);\n updatedFetchers = true;\n }\n }\n markFetchersDone(doneKeys);\n return updatedFetchers;\n }\n function abortStaleFetchLoads(landedId) {\n let yeetedKeys = [];\n for (let [key, id] of fetchReloadIds) {\n if (id < landedId) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, `Expected fetcher: ${key}`);\n if (fetcher.state === \"loading\") {\n abortFetcher(key);\n fetchReloadIds.delete(key);\n yeetedKeys.push(key);\n }\n }\n }\n markFetchersDone(yeetedKeys);\n return yeetedKeys.length > 0;\n }\n function getBlocker(key, fn) {\n let blocker = state.blockers.get(key) || IDLE_BLOCKER;\n if (blockerFunctions.get(key) !== fn) {\n blockerFunctions.set(key, fn);\n }\n return blocker;\n }\n function deleteBlocker(key) {\n state.blockers.delete(key);\n blockerFunctions.delete(key);\n }\n function updateBlocker(key, newBlocker) {\n let blocker = state.blockers.get(key) || IDLE_BLOCKER;\n invariant(\n blocker.state === \"unblocked\" && newBlocker.state === \"blocked\" || blocker.state === \"blocked\" && newBlocker.state === \"blocked\" || blocker.state === \"blocked\" && newBlocker.state === \"proceeding\" || blocker.state === \"blocked\" && newBlocker.state === \"unblocked\" || blocker.state === \"proceeding\" && newBlocker.state === \"unblocked\",\n `Invalid blocker state transition: ${blocker.state} -> ${newBlocker.state}`\n );\n let blockers = new Map(state.blockers);\n blockers.set(key, newBlocker);\n updateState({ blockers });\n }\n function shouldBlockNavigation({\n currentLocation,\n nextLocation,\n historyAction\n }) {\n if (blockerFunctions.size === 0) {\n return;\n }\n if (blockerFunctions.size > 1) {\n warning(false, \"A router only supports one blocker at a time\");\n }\n let entries = Array.from(blockerFunctions.entries());\n let [blockerKey, blockerFunction] = entries[entries.length - 1];\n let blocker = state.blockers.get(blockerKey);\n if (blocker && blocker.state === \"proceeding\") {\n return;\n }\n if (blockerFunction({ currentLocation, nextLocation, historyAction })) {\n return blockerKey;\n }\n }\n function handleNavigational404(pathname) {\n let error = getInternalRouterError(404, { pathname });\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let { matches, route } = getShortCircuitMatches(routesToUse);\n return { notFoundMatches: matches, route, error };\n }\n function enableScrollRestoration(positions, getPosition, getKey) {\n savedScrollPositions2 = positions;\n getScrollPosition = getPosition;\n getScrollRestorationKey2 = getKey || null;\n if (!initialScrollRestored && state.navigation === IDLE_NAVIGATION) {\n initialScrollRestored = true;\n let y = getSavedScrollPosition(state.location, state.matches);\n if (y != null) {\n updateState({ restoreScrollPosition: y });\n }\n }\n return () => {\n savedScrollPositions2 = null;\n getScrollPosition = null;\n getScrollRestorationKey2 = null;\n };\n }\n function getScrollKey(location, matches) {\n if (getScrollRestorationKey2) {\n let key = getScrollRestorationKey2(\n location,\n matches.map((m) => convertRouteMatchToUiMatch(m, state.loaderData))\n );\n return key || location.key;\n }\n return location.key;\n }\n function saveScrollPosition(location, matches) {\n if (savedScrollPositions2 && getScrollPosition) {\n let key = getScrollKey(location, matches);\n savedScrollPositions2[key] = getScrollPosition();\n }\n }\n function getSavedScrollPosition(location, matches) {\n if (savedScrollPositions2) {\n let key = getScrollKey(location, matches);\n let y = savedScrollPositions2[key];\n if (typeof y === \"number\") {\n return y;\n }\n }\n return null;\n }\n function checkFogOfWar(matches, routesToUse, pathname) {\n if (init.patchRoutesOnNavigation) {\n if (!matches) {\n let fogMatches = matchRoutesImpl(\n routesToUse,\n pathname,\n basename,\n true\n );\n return { active: true, matches: fogMatches || [] };\n } else {\n if (Object.keys(matches[0].params).length > 0) {\n let partialMatches = matchRoutesImpl(\n routesToUse,\n pathname,\n basename,\n true\n );\n return { active: true, matches: partialMatches };\n }\n }\n }\n return { active: false, matches: null };\n }\n async function discoverRoutes(matches, pathname, signal, fetcherKey) {\n if (!init.patchRoutesOnNavigation) {\n return { type: \"success\", matches };\n }\n let partialMatches = matches;\n while (true) {\n let isNonHMR = inFlightDataRoutes == null;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let localManifest = manifest;\n try {\n await init.patchRoutesOnNavigation({\n signal,\n path: pathname,\n matches: partialMatches,\n fetcherKey,\n patch: (routeId, children) => {\n if (signal.aborted) return;\n patchRoutesImpl(\n routeId,\n children,\n routesToUse,\n localManifest,\n mapRouteProperties2,\n false\n );\n }\n });\n } catch (e) {\n return { type: \"error\", error: e, partialMatches };\n } finally {\n if (isNonHMR && !signal.aborted) {\n dataRoutes = [...dataRoutes];\n }\n }\n if (signal.aborted) {\n return { type: \"aborted\" };\n }\n let newMatches = matchRoutes(routesToUse, pathname, basename);\n let newPartialMatches = null;\n if (newMatches) {\n if (Object.keys(newMatches[0].params).length === 0) {\n return { type: \"success\", matches: newMatches };\n } else {\n newPartialMatches = matchRoutesImpl(\n routesToUse,\n pathname,\n basename,\n true\n );\n let matchedDeeper = newPartialMatches && partialMatches.length < newPartialMatches.length && compareMatches(\n partialMatches,\n newPartialMatches.slice(0, partialMatches.length)\n );\n if (!matchedDeeper) {\n return { type: \"success\", matches: newMatches };\n }\n }\n }\n if (!newPartialMatches) {\n newPartialMatches = matchRoutesImpl(\n routesToUse,\n pathname,\n basename,\n true\n );\n }\n if (!newPartialMatches || compareMatches(partialMatches, newPartialMatches)) {\n return { type: \"success\", matches: null };\n }\n partialMatches = newPartialMatches;\n }\n }\n function compareMatches(a, b) {\n return a.length === b.length && a.every((m, i) => m.route.id === b[i].route.id);\n }\n function _internalSetRoutes(newRoutes) {\n manifest = {};\n inFlightDataRoutes = convertRoutesToDataRoutes(\n newRoutes,\n mapRouteProperties2,\n void 0,\n manifest\n );\n }\n function patchRoutes(routeId, children, unstable_allowElementMutations = false) {\n let isNonHMR = inFlightDataRoutes == null;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n patchRoutesImpl(\n routeId,\n children,\n routesToUse,\n manifest,\n mapRouteProperties2,\n unstable_allowElementMutations\n );\n if (isNonHMR) {\n dataRoutes = [...dataRoutes];\n updateState({});\n }\n }\n router = {\n get basename() {\n return basename;\n },\n get future() {\n return future;\n },\n get state() {\n return state;\n },\n get routes() {\n return dataRoutes;\n },\n get window() {\n return routerWindow;\n },\n initialize,\n subscribe,\n enableScrollRestoration,\n navigate,\n fetch: fetch2,\n revalidate,\n // Passthrough to history-aware createHref used by useHref so we get proper\n // hash-aware URLs in DOM paths\n createHref: (to) => init.history.createHref(to),\n encodeLocation: (to) => init.history.encodeLocation(to),\n getFetcher,\n resetFetcher,\n deleteFetcher: queueFetcherForDeletion,\n dispose,\n getBlocker,\n deleteBlocker,\n patchRoutes,\n _internalFetchControllers: fetchControllers,\n // TODO: Remove setRoutes, it's temporary to avoid dealing with\n // updating the tree while validating the update algorithm.\n _internalSetRoutes,\n _internalSetStateDoNotUseOrYouWillBreakYourApp(newState) {\n updateState(newState);\n }\n };\n if (init.unstable_instrumentations) {\n router = instrumentClientSideRouter(\n router,\n init.unstable_instrumentations.map((i) => i.router).filter(Boolean)\n );\n }\n return router;\n}\nfunction createStaticHandler(routes, opts) {\n invariant(\n routes.length > 0,\n \"You must provide a non-empty routes array to createStaticHandler\"\n );\n let manifest = {};\n let basename = (opts ? opts.basename : null) || \"/\";\n let _mapRouteProperties = opts?.mapRouteProperties || defaultMapRouteProperties;\n let mapRouteProperties2 = _mapRouteProperties;\n let future = {\n unstable_passThroughRequests: false,\n // unused in static handler\n ...opts?.future\n };\n if (opts?.unstable_instrumentations) {\n let instrumentations = opts.unstable_instrumentations;\n mapRouteProperties2 = (route) => {\n return {\n ..._mapRouteProperties(route),\n ...getRouteInstrumentationUpdates(\n instrumentations.map((i) => i.route).filter(Boolean),\n route\n )\n };\n };\n }\n let dataRoutes = convertRoutesToDataRoutes(\n routes,\n mapRouteProperties2,\n void 0,\n manifest\n );\n async function query(request, {\n requestContext,\n filterMatchesToLoad,\n skipLoaderErrorBubbling,\n skipRevalidation,\n dataStrategy,\n generateMiddlewareResponse,\n unstable_normalizePath\n } = {}) {\n let normalizePath = unstable_normalizePath || defaultNormalizePath;\n let method = request.method;\n let location = createLocation(\"\", normalizePath(request), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n requestContext = requestContext != null ? requestContext : new RouterContextProvider();\n if (!isValidMethod(method) && method !== \"HEAD\") {\n let error = getInternalRouterError(405, { method });\n let { matches: methodNotAllowedMatches, route } = getShortCircuitMatches(dataRoutes);\n let staticContext = {\n basename,\n location,\n matches: methodNotAllowedMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {}\n };\n return generateMiddlewareResponse ? generateMiddlewareResponse(() => Promise.resolve(staticContext)) : staticContext;\n } else if (!matches) {\n let error = getInternalRouterError(404, { pathname: location.pathname });\n let { matches: notFoundMatches, route } = getShortCircuitMatches(dataRoutes);\n let staticContext = {\n basename,\n location,\n matches: notFoundMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {}\n };\n return generateMiddlewareResponse ? generateMiddlewareResponse(() => Promise.resolve(staticContext)) : staticContext;\n }\n if (generateMiddlewareResponse) {\n invariant(\n requestContext instanceof RouterContextProvider,\n \"When using middleware in `staticHandler.query()`, any provided `requestContext` must be an instance of `RouterContextProvider`\"\n );\n try {\n await loadLazyMiddlewareForMatches(\n matches,\n manifest,\n mapRouteProperties2\n );\n let renderedStaticContext;\n let response = await runServerMiddlewarePipeline(\n {\n request,\n unstable_url: createDataFunctionUrl(request, location),\n unstable_pattern: getRoutePattern(matches),\n matches,\n params: matches[0].params,\n // If we're calling middleware then it must be enabled so we can cast\n // this to the proper type knowing it's not an `AppLoadContext`\n context: requestContext\n },\n async () => {\n let res = await generateMiddlewareResponse(\n async (revalidationRequest, opts2 = {}) => {\n let result2 = await queryImpl(\n revalidationRequest,\n location,\n matches,\n requestContext,\n dataStrategy || null,\n skipLoaderErrorBubbling === true,\n null,\n \"filterMatchesToLoad\" in opts2 ? opts2.filterMatchesToLoad ?? null : filterMatchesToLoad ?? null,\n skipRevalidation === true\n );\n if (isResponse(result2)) {\n return result2;\n }\n renderedStaticContext = { location, basename, ...result2 };\n return renderedStaticContext;\n }\n );\n return res;\n },\n async (error, routeId) => {\n if (isRedirectResponse(error)) {\n return error;\n }\n if (isResponse(error)) {\n try {\n error = new ErrorResponseImpl(\n error.status,\n error.statusText,\n await parseResponseBody(error)\n );\n } catch (e) {\n error = e;\n }\n }\n if (isDataWithResponseInit(error)) {\n error = dataWithResponseInitToErrorResponse(error);\n }\n if (renderedStaticContext) {\n if (routeId in renderedStaticContext.loaderData) {\n renderedStaticContext.loaderData[routeId] = void 0;\n }\n let staticContext = getStaticContextFromError(\n dataRoutes,\n renderedStaticContext,\n error,\n skipLoaderErrorBubbling ? routeId : findNearestBoundary(matches, routeId).route.id\n );\n return generateMiddlewareResponse(\n () => Promise.resolve(staticContext)\n );\n } else {\n let boundaryRouteId = skipLoaderErrorBubbling ? routeId : findNearestBoundary(\n matches,\n matches.find(\n (m) => m.route.id === routeId || m.route.loader\n )?.route.id || routeId\n ).route.id;\n let staticContext = {\n matches,\n location,\n basename,\n loaderData: {},\n actionData: null,\n errors: {\n [boundaryRouteId]: error\n },\n statusCode: isRouteErrorResponse(error) ? error.status : 500,\n actionHeaders: {},\n loaderHeaders: {}\n };\n return generateMiddlewareResponse(\n () => Promise.resolve(staticContext)\n );\n }\n }\n );\n invariant(isResponse(response), \"Expected a response in query()\");\n return response;\n } catch (e) {\n if (isResponse(e)) {\n return e;\n }\n throw e;\n }\n }\n let result = await queryImpl(\n request,\n location,\n matches,\n requestContext,\n dataStrategy || null,\n skipLoaderErrorBubbling === true,\n null,\n filterMatchesToLoad || null,\n skipRevalidation === true\n );\n if (isResponse(result)) {\n return result;\n }\n return { location, basename, ...result };\n }\n async function queryRoute(request, {\n routeId,\n requestContext,\n dataStrategy,\n generateMiddlewareResponse,\n unstable_normalizePath\n } = {}) {\n let normalizePath = unstable_normalizePath || defaultNormalizePath;\n let method = request.method;\n let location = createLocation(\"\", normalizePath(request), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n requestContext = requestContext != null ? requestContext : new RouterContextProvider();\n if (!isValidMethod(method) && method !== \"HEAD\" && method !== \"OPTIONS\") {\n throw getInternalRouterError(405, { method });\n } else if (!matches) {\n throw getInternalRouterError(404, { pathname: location.pathname });\n }\n let match = routeId ? matches.find((m) => m.route.id === routeId) : getTargetMatch(matches, location);\n if (routeId && !match) {\n throw getInternalRouterError(403, {\n pathname: location.pathname,\n routeId\n });\n } else if (!match) {\n throw getInternalRouterError(404, { pathname: location.pathname });\n }\n if (generateMiddlewareResponse) {\n invariant(\n requestContext instanceof RouterContextProvider,\n \"When using middleware in `staticHandler.queryRoute()`, any provided `requestContext` must be an instance of `RouterContextProvider`\"\n );\n await loadLazyMiddlewareForMatches(matches, manifest, mapRouteProperties2);\n let response = await runServerMiddlewarePipeline(\n {\n request,\n unstable_url: createDataFunctionUrl(request, location),\n unstable_pattern: getRoutePattern(matches),\n matches,\n params: matches[0].params,\n // If we're calling middleware then it must be enabled so we can cast\n // this to the proper type knowing it's not an `AppLoadContext`\n context: requestContext\n },\n async () => {\n let res = await generateMiddlewareResponse(\n async (innerRequest) => {\n let result2 = await queryImpl(\n innerRequest,\n location,\n matches,\n requestContext,\n dataStrategy || null,\n false,\n match,\n null,\n false\n );\n let processed = handleQueryResult(result2);\n return isResponse(processed) ? processed : typeof processed === \"string\" ? new Response(processed) : Response.json(processed);\n }\n );\n return res;\n },\n (error) => {\n if (isDataWithResponseInit(error)) {\n return Promise.resolve(dataWithResponseInitToResponse(error));\n }\n if (isResponse(error)) {\n return Promise.resolve(error);\n }\n throw error;\n }\n );\n return response;\n }\n let result = await queryImpl(\n request,\n location,\n matches,\n requestContext,\n dataStrategy || null,\n false,\n match,\n null,\n false\n );\n return handleQueryResult(result);\n function handleQueryResult(result2) {\n if (isResponse(result2)) {\n return result2;\n }\n let error = result2.errors ? Object.values(result2.errors)[0] : void 0;\n if (error !== void 0) {\n throw error;\n }\n if (result2.actionData) {\n return Object.values(result2.actionData)[0];\n }\n if (result2.loaderData) {\n return Object.values(result2.loaderData)[0];\n }\n return void 0;\n }\n }\n async function queryImpl(request, location, matches, requestContext, dataStrategy, skipLoaderErrorBubbling, routeMatch, filterMatchesToLoad, skipRevalidation) {\n invariant(\n request.signal,\n \"query()/queryRoute() requests must contain an AbortController signal\"\n );\n try {\n if (isMutationMethod(request.method)) {\n let result2 = await submit(\n request,\n location,\n matches,\n routeMatch || getTargetMatch(matches, location),\n requestContext,\n dataStrategy,\n skipLoaderErrorBubbling,\n routeMatch != null,\n filterMatchesToLoad,\n skipRevalidation\n );\n return result2;\n }\n let result = await loadRouteData(\n request,\n location,\n matches,\n requestContext,\n dataStrategy,\n skipLoaderErrorBubbling,\n routeMatch,\n filterMatchesToLoad\n );\n return isResponse(result) ? result : {\n ...result,\n actionData: null,\n actionHeaders: {}\n };\n } catch (e) {\n if (isDataStrategyResult(e) && isResponse(e.result)) {\n if (e.type === \"error\" /* error */) {\n throw e.result;\n }\n return e.result;\n }\n if (isRedirectResponse(e)) {\n return e;\n }\n throw e;\n }\n }\n async function submit(request, location, matches, actionMatch, requestContext, dataStrategy, skipLoaderErrorBubbling, isRouteRequest, filterMatchesToLoad, skipRevalidation) {\n let result;\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n let error = getInternalRouterError(405, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: actionMatch.route.id\n });\n if (isRouteRequest) {\n throw error;\n }\n result = {\n type: \"error\" /* error */,\n error\n };\n } else {\n let dsMatches = getTargetedDataStrategyMatches(\n mapRouteProperties2,\n manifest,\n request,\n location,\n matches,\n actionMatch,\n [],\n requestContext\n );\n let results = await callDataStrategy(\n request,\n location,\n dsMatches,\n isRouteRequest,\n requestContext,\n dataStrategy\n );\n result = results[actionMatch.route.id];\n if (request.signal.aborted) {\n throwStaticHandlerAbortedError(request, isRouteRequest);\n }\n }\n if (isRedirectResult(result)) {\n throw new Response(null, {\n status: result.response.status,\n headers: {\n Location: result.response.headers.get(\"Location\")\n }\n });\n }\n if (isRouteRequest) {\n if (isErrorResult(result)) {\n throw result.error;\n }\n return {\n matches: [actionMatch],\n loaderData: {},\n actionData: { [actionMatch.route.id]: result.data },\n errors: null,\n // Note: statusCode + headers are unused here since queryRoute will\n // return the raw Response or value\n statusCode: 200,\n loaderHeaders: {},\n actionHeaders: {}\n };\n }\n if (skipRevalidation) {\n if (isErrorResult(result)) {\n let boundaryMatch = skipLoaderErrorBubbling ? actionMatch : findNearestBoundary(matches, actionMatch.route.id);\n return {\n statusCode: isRouteErrorResponse(result.error) ? result.error.status : result.statusCode != null ? result.statusCode : 500,\n actionData: null,\n actionHeaders: {\n ...result.headers ? { [actionMatch.route.id]: result.headers } : {}\n },\n matches,\n loaderData: {},\n errors: {\n [boundaryMatch.route.id]: result.error\n },\n loaderHeaders: {}\n };\n } else {\n return {\n actionData: {\n [actionMatch.route.id]: result.data\n },\n actionHeaders: result.headers ? { [actionMatch.route.id]: result.headers } : {},\n matches,\n loaderData: {},\n errors: null,\n statusCode: result.statusCode || 200,\n loaderHeaders: {}\n };\n }\n }\n let loaderRequest = new Request(request.url, {\n headers: request.headers,\n redirect: request.redirect,\n signal: request.signal\n });\n if (isErrorResult(result)) {\n let boundaryMatch = skipLoaderErrorBubbling ? actionMatch : findNearestBoundary(matches, actionMatch.route.id);\n let handlerContext2 = await loadRouteData(\n loaderRequest,\n location,\n matches,\n requestContext,\n dataStrategy,\n skipLoaderErrorBubbling,\n null,\n filterMatchesToLoad,\n [boundaryMatch.route.id, result]\n );\n return {\n ...handlerContext2,\n statusCode: isRouteErrorResponse(result.error) ? result.error.status : result.statusCode != null ? result.statusCode : 500,\n actionData: null,\n actionHeaders: {\n ...result.headers ? { [actionMatch.route.id]: result.headers } : {}\n }\n };\n }\n let handlerContext = await loadRouteData(\n loaderRequest,\n location,\n matches,\n requestContext,\n dataStrategy,\n skipLoaderErrorBubbling,\n null,\n filterMatchesToLoad\n );\n return {\n ...handlerContext,\n actionData: {\n [actionMatch.route.id]: result.data\n },\n // action status codes take precedence over loader status codes\n ...result.statusCode ? { statusCode: result.statusCode } : {},\n actionHeaders: result.headers ? { [actionMatch.route.id]: result.headers } : {}\n };\n }\n async function loadRouteData(request, location, matches, requestContext, dataStrategy, skipLoaderErrorBubbling, routeMatch, filterMatchesToLoad, pendingActionResult) {\n let isRouteRequest = routeMatch != null;\n if (isRouteRequest && !routeMatch?.route.loader && !routeMatch?.route.lazy) {\n throw getInternalRouterError(400, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: routeMatch?.route.id\n });\n }\n let dsMatches;\n if (routeMatch) {\n dsMatches = getTargetedDataStrategyMatches(\n mapRouteProperties2,\n manifest,\n request,\n location,\n matches,\n routeMatch,\n [],\n requestContext\n );\n } else {\n let maxIdx = pendingActionResult && isErrorResult(pendingActionResult[1]) ? (\n // Up to but not including the boundary\n matches.findIndex((m) => m.route.id === pendingActionResult[0]) - 1\n ) : void 0;\n let pattern = getRoutePattern(matches);\n dsMatches = matches.map((match, index) => {\n if (maxIdx != null && index > maxIdx) {\n return getDataStrategyMatch(\n mapRouteProperties2,\n manifest,\n request,\n location,\n pattern,\n match,\n [],\n requestContext,\n false\n );\n }\n return getDataStrategyMatch(\n mapRouteProperties2,\n manifest,\n request,\n location,\n pattern,\n match,\n [],\n requestContext,\n (match.route.loader || match.route.lazy) != null && (!filterMatchesToLoad || filterMatchesToLoad(match))\n );\n });\n }\n if (!dataStrategy && !dsMatches.some((m) => m.shouldLoad)) {\n return {\n matches,\n loaderData: {},\n errors: pendingActionResult && isErrorResult(pendingActionResult[1]) ? {\n [pendingActionResult[0]]: pendingActionResult[1].error\n } : null,\n statusCode: 200,\n loaderHeaders: {}\n };\n }\n let results = await callDataStrategy(\n request,\n location,\n dsMatches,\n isRouteRequest,\n requestContext,\n dataStrategy\n );\n if (request.signal.aborted) {\n throwStaticHandlerAbortedError(request, isRouteRequest);\n }\n let handlerContext = processRouteLoaderData(\n matches,\n results,\n pendingActionResult,\n true,\n skipLoaderErrorBubbling\n );\n return {\n ...handlerContext,\n matches\n };\n }\n async function callDataStrategy(request, location, matches, isRouteRequest, requestContext, dataStrategy) {\n let results = await callDataStrategyImpl(\n dataStrategy || defaultDataStrategy,\n request,\n location,\n matches,\n null,\n requestContext,\n true\n );\n let dataResults = {};\n await Promise.all(\n matches.map(async (match) => {\n if (!(match.route.id in results)) {\n return;\n }\n let result = results[match.route.id];\n if (isRedirectDataStrategyResult(result)) {\n let response = result.result;\n throw normalizeRelativeRoutingRedirectResponse(\n response,\n request,\n match.route.id,\n matches,\n basename\n );\n }\n if (isRouteRequest) {\n if (isResponse(result.result)) {\n throw result;\n } else if (isDataWithResponseInit(result.result)) {\n throw dataWithResponseInitToResponse(result.result);\n }\n }\n dataResults[match.route.id] = await convertDataStrategyResultToDataResult(result);\n })\n );\n return dataResults;\n }\n return {\n dataRoutes,\n query,\n queryRoute\n };\n}\nfunction getStaticContextFromError(routes, handlerContext, error, boundaryId) {\n let errorBoundaryId = boundaryId || handlerContext._deepestRenderedBoundaryId || routes[0].id;\n return {\n ...handlerContext,\n statusCode: isRouteErrorResponse(error) ? error.status : 500,\n errors: {\n [errorBoundaryId]: error\n }\n };\n}\nfunction throwStaticHandlerAbortedError(request, isRouteRequest) {\n if (request.signal.reason !== void 0) {\n throw request.signal.reason;\n }\n let method = isRouteRequest ? \"queryRoute\" : \"query\";\n throw new Error(\n `${method}() call aborted without an \\`AbortSignal.reason\\`: ${request.method} ${request.url}`\n );\n}\nfunction isSubmissionNavigation(opts) {\n return opts != null && (\"formData\" in opts && opts.formData != null || \"body\" in opts && opts.body !== void 0);\n}\nfunction defaultNormalizePath(request) {\n let url = new URL(request.url);\n return {\n pathname: url.pathname,\n search: url.search,\n hash: url.hash\n };\n}\nfunction normalizeTo(location, matches, basename, to, fromRouteId, relative) {\n let contextualMatches;\n let activeRouteMatch;\n if (fromRouteId) {\n contextualMatches = [];\n for (let match of matches) {\n contextualMatches.push(match);\n if (match.route.id === fromRouteId) {\n activeRouteMatch = match;\n break;\n }\n }\n } else {\n contextualMatches = matches;\n activeRouteMatch = matches[matches.length - 1];\n }\n let path = resolveTo(\n to ? to : \".\",\n getResolveToMatches(contextualMatches),\n stripBasename(location.pathname, basename) || location.pathname,\n relative === \"path\"\n );\n if (to == null) {\n path.search = location.search;\n path.hash = location.hash;\n }\n if ((to == null || to === \"\" || to === \".\") && activeRouteMatch) {\n let nakedIndex = hasNakedIndexQuery(path.search);\n if (activeRouteMatch.route.index && !nakedIndex) {\n path.search = path.search ? path.search.replace(/^\\?/, \"?index&\") : \"?index\";\n } else if (!activeRouteMatch.route.index && nakedIndex) {\n let params = new URLSearchParams(path.search);\n let indexValues = params.getAll(\"index\");\n params.delete(\"index\");\n indexValues.filter((v) => v).forEach((v) => params.append(\"index\", v));\n let qs = params.toString();\n path.search = qs ? `?${qs}` : \"\";\n }\n }\n if (basename !== \"/\") {\n path.pathname = prependBasename({ basename, pathname: path.pathname });\n }\n return createPath(path);\n}\nfunction normalizeNavigateOptions(isFetcher, path, opts) {\n if (!opts || !isSubmissionNavigation(opts)) {\n return { path };\n }\n if (opts.formMethod && !isValidMethod(opts.formMethod)) {\n return {\n path,\n error: getInternalRouterError(405, { method: opts.formMethod })\n };\n }\n let getInvalidBodyError = () => ({\n path,\n error: getInternalRouterError(400, { type: \"invalid-body\" })\n });\n let rawFormMethod = opts.formMethod || \"get\";\n let formMethod = rawFormMethod.toUpperCase();\n let formAction = stripHashFromPath(path);\n if (opts.body !== void 0) {\n if (opts.formEncType === \"text/plain\") {\n if (!isMutationMethod(formMethod)) {\n return getInvalidBodyError();\n }\n let text = typeof opts.body === \"string\" ? opts.body : opts.body instanceof FormData || opts.body instanceof URLSearchParams ? (\n // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#plain-text-form-data\n Array.from(opts.body.entries()).reduce(\n (acc, [name, value]) => `${acc}${name}=${value}\n`,\n \"\"\n )\n ) : String(opts.body);\n return {\n path,\n submission: {\n formMethod,\n formAction,\n formEncType: opts.formEncType,\n formData: void 0,\n json: void 0,\n text\n }\n };\n } else if (opts.formEncType === \"application/json\") {\n if (!isMutationMethod(formMethod)) {\n return getInvalidBodyError();\n }\n try {\n let json = typeof opts.body === \"string\" ? JSON.parse(opts.body) : opts.body;\n return {\n path,\n submission: {\n formMethod,\n formAction,\n formEncType: opts.formEncType,\n formData: void 0,\n json,\n text: void 0\n }\n };\n } catch (e) {\n return getInvalidBodyError();\n }\n }\n }\n invariant(\n typeof FormData === \"function\",\n \"FormData is not available in this environment\"\n );\n let searchParams;\n let formData;\n if (opts.formData) {\n searchParams = convertFormDataToSearchParams(opts.formData);\n formData = opts.formData;\n } else if (opts.body instanceof FormData) {\n searchParams = convertFormDataToSearchParams(opts.body);\n formData = opts.body;\n } else if (opts.body instanceof URLSearchParams) {\n searchParams = opts.body;\n formData = convertSearchParamsToFormData(searchParams);\n } else if (opts.body == null) {\n searchParams = new URLSearchParams();\n formData = new FormData();\n } else {\n try {\n searchParams = new URLSearchParams(opts.body);\n formData = convertSearchParamsToFormData(searchParams);\n } catch (e) {\n return getInvalidBodyError();\n }\n }\n let submission = {\n formMethod,\n formAction,\n formEncType: opts && opts.formEncType || \"application/x-www-form-urlencoded\",\n formData,\n json: void 0,\n text: void 0\n };\n if (isMutationMethod(submission.formMethod)) {\n return { path, submission };\n }\n let parsedPath = parsePath(path);\n if (isFetcher && parsedPath.search && hasNakedIndexQuery(parsedPath.search)) {\n searchParams.append(\"index\", \"\");\n }\n parsedPath.search = `?${searchParams}`;\n return { path: createPath(parsedPath), submission };\n}\nfunction getMatchesToLoad(request, scopedContext, mapRouteProperties2, manifest, history, state, matches, submission, location, lazyRoutePropertiesToSkip, initialHydration, isRevalidationRequired, cancelledFetcherLoads, fetchersQueuedForDeletion, fetchLoadMatches, fetchRedirectIds, routesToUse, basename, hasPatchRoutesOnNavigation, pendingActionResult, callSiteDefaultShouldRevalidate) {\n let actionResult = pendingActionResult ? isErrorResult(pendingActionResult[1]) ? pendingActionResult[1].error : pendingActionResult[1].data : void 0;\n let currentUrl = history.createURL(state.location);\n let nextUrl = history.createURL(location);\n let maxIdx;\n if (initialHydration && state.errors) {\n let boundaryId = Object.keys(state.errors)[0];\n maxIdx = matches.findIndex((m) => m.route.id === boundaryId);\n } else if (pendingActionResult && isErrorResult(pendingActionResult[1])) {\n let boundaryId = pendingActionResult[0];\n maxIdx = matches.findIndex((m) => m.route.id === boundaryId) - 1;\n }\n let actionStatus = pendingActionResult ? pendingActionResult[1].statusCode : void 0;\n let shouldSkipRevalidation = actionStatus && actionStatus >= 400;\n let baseShouldRevalidateArgs = {\n currentUrl,\n currentParams: state.matches[0]?.params || {},\n nextUrl,\n nextParams: matches[0].params,\n ...submission,\n actionResult,\n actionStatus\n };\n let pattern = getRoutePattern(matches);\n let dsMatches = matches.map((match, index) => {\n let { route } = match;\n let forceShouldLoad = null;\n if (maxIdx != null && index > maxIdx) {\n forceShouldLoad = false;\n } else if (route.lazy) {\n forceShouldLoad = true;\n } else if (!routeHasLoaderOrMiddleware(route)) {\n forceShouldLoad = false;\n } else if (initialHydration) {\n let { shouldLoad: shouldLoad2 } = getRouteHydrationStatus(\n route,\n state.loaderData,\n state.errors\n );\n forceShouldLoad = shouldLoad2;\n } else if (isNewLoader(state.loaderData, state.matches[index], match)) {\n forceShouldLoad = true;\n }\n if (forceShouldLoad !== null) {\n return getDataStrategyMatch(\n mapRouteProperties2,\n manifest,\n request,\n location,\n pattern,\n match,\n lazyRoutePropertiesToSkip,\n scopedContext,\n forceShouldLoad\n );\n }\n let defaultShouldRevalidate = false;\n if (typeof callSiteDefaultShouldRevalidate === \"boolean\") {\n defaultShouldRevalidate = callSiteDefaultShouldRevalidate;\n } else if (shouldSkipRevalidation) {\n defaultShouldRevalidate = false;\n } else if (isRevalidationRequired) {\n defaultShouldRevalidate = true;\n } else if (currentUrl.pathname + currentUrl.search === nextUrl.pathname + nextUrl.search) {\n defaultShouldRevalidate = true;\n } else if (currentUrl.search !== nextUrl.search) {\n defaultShouldRevalidate = true;\n } else if (isNewRouteInstance(state.matches[index], match)) {\n defaultShouldRevalidate = true;\n }\n let shouldRevalidateArgs = {\n ...baseShouldRevalidateArgs,\n defaultShouldRevalidate\n };\n let shouldLoad = shouldRevalidateLoader(match, shouldRevalidateArgs);\n return getDataStrategyMatch(\n mapRouteProperties2,\n manifest,\n request,\n location,\n pattern,\n match,\n lazyRoutePropertiesToSkip,\n scopedContext,\n shouldLoad,\n shouldRevalidateArgs,\n callSiteDefaultShouldRevalidate\n );\n });\n let revalidatingFetchers = [];\n fetchLoadMatches.forEach((f, key) => {\n if (initialHydration || !matches.some((m) => m.route.id === f.routeId) || fetchersQueuedForDeletion.has(key)) {\n return;\n }\n let fetcher = state.fetchers.get(key);\n let isMidInitialLoad = fetcher && fetcher.state !== \"idle\" && fetcher.data === void 0;\n let fetcherMatches = matchRoutes(routesToUse, f.path, basename);\n if (!fetcherMatches) {\n if (hasPatchRoutesOnNavigation && isMidInitialLoad) {\n return;\n }\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: null,\n match: null,\n request: null,\n controller: null\n });\n return;\n }\n if (fetchRedirectIds.has(key)) {\n return;\n }\n let fetcherMatch = getTargetMatch(fetcherMatches, f.path);\n let fetchController = new AbortController();\n let fetchRequest = createClientSideRequest(\n history,\n f.path,\n fetchController.signal\n );\n let fetcherDsMatches = null;\n if (cancelledFetcherLoads.has(key)) {\n cancelledFetcherLoads.delete(key);\n fetcherDsMatches = getTargetedDataStrategyMatches(\n mapRouteProperties2,\n manifest,\n fetchRequest,\n f.path,\n fetcherMatches,\n fetcherMatch,\n lazyRoutePropertiesToSkip,\n scopedContext\n );\n } else if (isMidInitialLoad) {\n if (isRevalidationRequired) {\n fetcherDsMatches = getTargetedDataStrategyMatches(\n mapRouteProperties2,\n manifest,\n fetchRequest,\n f.path,\n fetcherMatches,\n fetcherMatch,\n lazyRoutePropertiesToSkip,\n scopedContext\n );\n }\n } else {\n let defaultShouldRevalidate;\n if (typeof callSiteDefaultShouldRevalidate === \"boolean\") {\n defaultShouldRevalidate = callSiteDefaultShouldRevalidate;\n } else if (shouldSkipRevalidation) {\n defaultShouldRevalidate = false;\n } else {\n defaultShouldRevalidate = isRevalidationRequired;\n }\n let shouldRevalidateArgs = {\n ...baseShouldRevalidateArgs,\n defaultShouldRevalidate\n };\n if (shouldRevalidateLoader(fetcherMatch, shouldRevalidateArgs)) {\n fetcherDsMatches = getTargetedDataStrategyMatches(\n mapRouteProperties2,\n manifest,\n fetchRequest,\n f.path,\n fetcherMatches,\n fetcherMatch,\n lazyRoutePropertiesToSkip,\n scopedContext,\n shouldRevalidateArgs\n );\n }\n }\n if (fetcherDsMatches) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: fetcherDsMatches,\n match: fetcherMatch,\n request: fetchRequest,\n controller: fetchController\n });\n }\n });\n return { dsMatches, revalidatingFetchers };\n}\nfunction routeHasLoaderOrMiddleware(route) {\n return route.loader != null || route.middleware != null && route.middleware.length > 0;\n}\nfunction getRouteHydrationStatus(route, loaderData, errors) {\n if (route.lazy) {\n return { shouldLoad: true, renderFallback: true };\n }\n if (!routeHasLoaderOrMiddleware(route)) {\n return { shouldLoad: false, renderFallback: false };\n }\n let hasData = loaderData != null && route.id in loaderData;\n let hasError = errors != null && errors[route.id] !== void 0;\n if (!hasData && hasError) {\n return { shouldLoad: false, renderFallback: false };\n }\n if (typeof route.loader === \"function\" && route.loader.hydrate === true) {\n return { shouldLoad: true, renderFallback: !hasData };\n }\n let shouldLoad = !hasData && !hasError;\n return { shouldLoad, renderFallback: shouldLoad };\n}\nfunction isNewLoader(currentLoaderData, currentMatch, match) {\n let isNew = (\n // [a] -> [a, b]\n !currentMatch || // [a, b] -> [a, c]\n match.route.id !== currentMatch.route.id\n );\n let isMissingData = !currentLoaderData.hasOwnProperty(match.route.id);\n return isNew || isMissingData;\n}\nfunction isNewRouteInstance(currentMatch, match) {\n let currentPath = currentMatch.route.path;\n return (\n // param change for this match, /users/123 -> /users/456\n currentMatch.pathname !== match.pathname || // splat param changed, which is not present in match.path\n // e.g. /files/images/avatar.jpg -> files/finances.xls\n currentPath != null && currentPath.endsWith(\"*\") && currentMatch.params[\"*\"] !== match.params[\"*\"]\n );\n}\nfunction shouldRevalidateLoader(loaderMatch, arg) {\n if (loaderMatch.route.shouldRevalidate) {\n let routeChoice = loaderMatch.route.shouldRevalidate(arg);\n if (typeof routeChoice === \"boolean\") {\n return routeChoice;\n }\n }\n return arg.defaultShouldRevalidate;\n}\nfunction patchRoutesImpl(routeId, children, routesToUse, manifest, mapRouteProperties2, allowElementMutations) {\n let childrenToPatch;\n if (routeId) {\n let route = manifest[routeId];\n invariant(\n route,\n `No route found to patch children into: routeId = ${routeId}`\n );\n if (!route.children) {\n route.children = [];\n }\n childrenToPatch = route.children;\n } else {\n childrenToPatch = routesToUse;\n }\n let uniqueChildren = [];\n let existingChildren = [];\n children.forEach((newRoute) => {\n let existingRoute = childrenToPatch.find(\n (existingRoute2) => isSameRoute(newRoute, existingRoute2)\n );\n if (existingRoute) {\n existingChildren.push({ existingRoute, newRoute });\n } else {\n uniqueChildren.push(newRoute);\n }\n });\n if (uniqueChildren.length > 0) {\n let newRoutes = convertRoutesToDataRoutes(\n uniqueChildren,\n mapRouteProperties2,\n [routeId || \"_\", \"patch\", String(childrenToPatch?.length || \"0\")],\n manifest\n );\n childrenToPatch.push(...newRoutes);\n }\n if (allowElementMutations && existingChildren.length > 0) {\n for (let i = 0; i < existingChildren.length; i++) {\n let { existingRoute, newRoute } = existingChildren[i];\n let existingRouteTyped = existingRoute;\n let [newRouteTyped] = convertRoutesToDataRoutes(\n [newRoute],\n mapRouteProperties2,\n [],\n // Doesn't matter for mutated routes since they already have an id\n {},\n // Don't touch the manifest here since we're updating in place\n true\n );\n Object.assign(existingRouteTyped, {\n element: newRouteTyped.element ? newRouteTyped.element : existingRouteTyped.element,\n errorElement: newRouteTyped.errorElement ? newRouteTyped.errorElement : existingRouteTyped.errorElement,\n hydrateFallbackElement: newRouteTyped.hydrateFallbackElement ? newRouteTyped.hydrateFallbackElement : existingRouteTyped.hydrateFallbackElement\n });\n }\n }\n}\nfunction isSameRoute(newRoute, existingRoute) {\n if (\"id\" in newRoute && \"id\" in existingRoute && newRoute.id === existingRoute.id) {\n return true;\n }\n if (!(newRoute.index === existingRoute.index && newRoute.path === existingRoute.path && newRoute.caseSensitive === existingRoute.caseSensitive)) {\n return false;\n }\n if ((!newRoute.children || newRoute.children.length === 0) && (!existingRoute.children || existingRoute.children.length === 0)) {\n return true;\n }\n return newRoute.children?.every(\n (aChild, i) => existingRoute.children?.some((bChild) => isSameRoute(aChild, bChild))\n ) ?? false;\n}\nvar lazyRoutePropertyCache = /* @__PURE__ */ new WeakMap();\nvar loadLazyRouteProperty = ({\n key,\n route,\n manifest,\n mapRouteProperties: mapRouteProperties2\n}) => {\n let routeToUpdate = manifest[route.id];\n invariant(routeToUpdate, \"No route found in manifest\");\n if (!routeToUpdate.lazy || typeof routeToUpdate.lazy !== \"object\") {\n return;\n }\n let lazyFn = routeToUpdate.lazy[key];\n if (!lazyFn) {\n return;\n }\n let cache = lazyRoutePropertyCache.get(routeToUpdate);\n if (!cache) {\n cache = {};\n lazyRoutePropertyCache.set(routeToUpdate, cache);\n }\n let cachedPromise = cache[key];\n if (cachedPromise) {\n return cachedPromise;\n }\n let propertyPromise = (async () => {\n let isUnsupported = isUnsupportedLazyRouteObjectKey(key);\n let staticRouteValue = routeToUpdate[key];\n let isStaticallyDefined = staticRouteValue !== void 0 && key !== \"hasErrorBoundary\";\n if (isUnsupported) {\n warning(\n !isUnsupported,\n \"Route property \" + key + \" is not a supported lazy route property. This property will be ignored.\"\n );\n cache[key] = Promise.resolve();\n } else if (isStaticallyDefined) {\n warning(\n false,\n `Route \"${routeToUpdate.id}\" has a static property \"${key}\" defined. The lazy property will be ignored.`\n );\n } else {\n let value = await lazyFn();\n if (value != null) {\n Object.assign(routeToUpdate, { [key]: value });\n Object.assign(routeToUpdate, mapRouteProperties2(routeToUpdate));\n }\n }\n if (typeof routeToUpdate.lazy === \"object\") {\n routeToUpdate.lazy[key] = void 0;\n if (Object.values(routeToUpdate.lazy).every((value) => value === void 0)) {\n routeToUpdate.lazy = void 0;\n }\n }\n })();\n cache[key] = propertyPromise;\n return propertyPromise;\n};\nvar lazyRouteFunctionCache = /* @__PURE__ */ new WeakMap();\nfunction loadLazyRoute(route, type, manifest, mapRouteProperties2, lazyRoutePropertiesToSkip) {\n let routeToUpdate = manifest[route.id];\n invariant(routeToUpdate, \"No route found in manifest\");\n if (!route.lazy) {\n return {\n lazyRoutePromise: void 0,\n lazyHandlerPromise: void 0\n };\n }\n if (typeof route.lazy === \"function\") {\n let cachedPromise = lazyRouteFunctionCache.get(routeToUpdate);\n if (cachedPromise) {\n return {\n lazyRoutePromise: cachedPromise,\n lazyHandlerPromise: cachedPromise\n };\n }\n let lazyRoutePromise2 = (async () => {\n invariant(\n typeof route.lazy === \"function\",\n \"No lazy route function found\"\n );\n let lazyRoute = await route.lazy();\n let routeUpdates = {};\n for (let lazyRouteProperty in lazyRoute) {\n let lazyValue = lazyRoute[lazyRouteProperty];\n if (lazyValue === void 0) {\n continue;\n }\n let isUnsupported = isUnsupportedLazyRouteFunctionKey(lazyRouteProperty);\n let staticRouteValue = routeToUpdate[lazyRouteProperty];\n let isStaticallyDefined = staticRouteValue !== void 0 && // This property isn't static since it should always be updated based\n // on the route updates\n lazyRouteProperty !== \"hasErrorBoundary\";\n if (isUnsupported) {\n warning(\n !isUnsupported,\n \"Route property \" + lazyRouteProperty + \" is not a supported property to be returned from a lazy route function. This property will be ignored.\"\n );\n } else if (isStaticallyDefined) {\n warning(\n !isStaticallyDefined,\n `Route \"${routeToUpdate.id}\" has a static property \"${lazyRouteProperty}\" defined but its lazy function is also returning a value for this property. The lazy route property \"${lazyRouteProperty}\" will be ignored.`\n );\n } else {\n routeUpdates[lazyRouteProperty] = lazyValue;\n }\n }\n Object.assign(routeToUpdate, routeUpdates);\n Object.assign(routeToUpdate, {\n // To keep things framework agnostic, we use the provided `mapRouteProperties`\n // function to set the framework-aware properties (`element`/`hasErrorBoundary`)\n // since the logic will differ between frameworks.\n ...mapRouteProperties2(routeToUpdate),\n lazy: void 0\n });\n })();\n lazyRouteFunctionCache.set(routeToUpdate, lazyRoutePromise2);\n lazyRoutePromise2.catch(() => {\n });\n return {\n lazyRoutePromise: lazyRoutePromise2,\n lazyHandlerPromise: lazyRoutePromise2\n };\n }\n let lazyKeys = Object.keys(route.lazy);\n let lazyPropertyPromises = [];\n let lazyHandlerPromise = void 0;\n for (let key of lazyKeys) {\n if (lazyRoutePropertiesToSkip && lazyRoutePropertiesToSkip.includes(key)) {\n continue;\n }\n let promise = loadLazyRouteProperty({\n key,\n route,\n manifest,\n mapRouteProperties: mapRouteProperties2\n });\n if (promise) {\n lazyPropertyPromises.push(promise);\n if (key === type) {\n lazyHandlerPromise = promise;\n }\n }\n }\n let lazyRoutePromise = lazyPropertyPromises.length > 0 ? Promise.all(lazyPropertyPromises).then(() => {\n }) : void 0;\n lazyRoutePromise?.catch(() => {\n });\n lazyHandlerPromise?.catch(() => {\n });\n return {\n lazyRoutePromise,\n lazyHandlerPromise\n };\n}\nfunction isNonNullable(value) {\n return value !== void 0;\n}\nfunction loadLazyMiddlewareForMatches(matches, manifest, mapRouteProperties2) {\n let promises = matches.map(({ route }) => {\n if (typeof route.lazy !== \"object\" || !route.lazy.middleware) {\n return void 0;\n }\n return loadLazyRouteProperty({\n key: \"middleware\",\n route,\n manifest,\n mapRouteProperties: mapRouteProperties2\n });\n }).filter(isNonNullable);\n return promises.length > 0 ? Promise.all(promises) : void 0;\n}\nasync function defaultDataStrategy(args) {\n let matchesToLoad = args.matches.filter((m) => m.shouldLoad);\n let keyedResults = {};\n let results = await Promise.all(matchesToLoad.map((m) => m.resolve()));\n results.forEach((result, i) => {\n keyedResults[matchesToLoad[i].route.id] = result;\n });\n return keyedResults;\n}\nasync function defaultDataStrategyWithMiddleware(args) {\n if (!args.matches.some((m) => m.route.middleware)) {\n return defaultDataStrategy(args);\n }\n return runClientMiddlewarePipeline(args, () => defaultDataStrategy(args));\n}\nfunction runServerMiddlewarePipeline(args, handler, errorHandler) {\n return runMiddlewarePipeline(\n args,\n handler,\n processResult,\n isResponse,\n errorHandler\n );\n function processResult(result) {\n return isDataWithResponseInit(result) ? dataWithResponseInitToResponse(result) : result;\n }\n}\nfunction runClientMiddlewarePipeline(args, handler) {\n return runMiddlewarePipeline(\n args,\n handler,\n (r) => {\n if (isRedirectResponse(r)) {\n throw r;\n }\n return r;\n },\n isDataStrategyResults,\n errorHandler\n );\n function errorHandler(error, routeId, nextResult) {\n if (nextResult) {\n return Promise.resolve(\n Object.assign(nextResult.value, {\n [routeId]: { type: \"error\", result: error }\n })\n );\n } else {\n let { matches } = args;\n let maxBoundaryIdx = Math.min(\n // Throwing route\n Math.max(\n matches.findIndex((m) => m.route.id === routeId),\n 0\n ),\n // or the shallowest route that needs to load data\n Math.max(\n matches.findIndex((m) => m.shouldCallHandler()),\n 0\n )\n );\n let boundaryRouteId = findNearestBoundary(\n matches,\n matches[maxBoundaryIdx].route.id\n ).route.id;\n return Promise.resolve({\n [boundaryRouteId]: { type: \"error\", result: error }\n });\n }\n }\n}\nasync function runMiddlewarePipeline(args, handler, processResult, isResult, errorHandler) {\n let { matches, ...dataFnArgs } = args;\n let tuples = matches.flatMap(\n (m) => m.route.middleware ? m.route.middleware.map((fn) => [m.route.id, fn]) : []\n );\n let result = await callRouteMiddleware(\n dataFnArgs,\n tuples,\n handler,\n processResult,\n isResult,\n errorHandler\n );\n return result;\n}\nasync function callRouteMiddleware(args, middlewares, handler, processResult, isResult, errorHandler, idx = 0) {\n let { request } = args;\n if (request.signal.aborted) {\n throw request.signal.reason ?? new Error(`Request aborted: ${request.method} ${request.url}`);\n }\n let tuple = middlewares[idx];\n if (!tuple) {\n let result = await handler();\n return result;\n }\n let [routeId, middleware] = tuple;\n let nextResult;\n let next = async () => {\n if (nextResult) {\n throw new Error(\"You may only call `next()` once per middleware\");\n }\n try {\n let result = await callRouteMiddleware(\n args,\n middlewares,\n handler,\n processResult,\n isResult,\n errorHandler,\n idx + 1\n );\n nextResult = { value: result };\n return nextResult.value;\n } catch (error) {\n nextResult = { value: await errorHandler(error, routeId, nextResult) };\n return nextResult.value;\n }\n };\n try {\n let value = await middleware(args, next);\n let result = value != null ? processResult(value) : void 0;\n if (isResult(result)) {\n return result;\n } else if (nextResult) {\n return result ?? nextResult.value;\n } else {\n nextResult = { value: await next() };\n return nextResult.value;\n }\n } catch (error) {\n let response = await errorHandler(error, routeId, nextResult);\n return response;\n }\n}\nfunction getDataStrategyMatchLazyPromises(mapRouteProperties2, manifest, request, match, lazyRoutePropertiesToSkip) {\n let lazyMiddlewarePromise = loadLazyRouteProperty({\n key: \"middleware\",\n route: match.route,\n manifest,\n mapRouteProperties: mapRouteProperties2\n });\n let lazyRoutePromises = loadLazyRoute(\n match.route,\n isMutationMethod(request.method) ? \"action\" : \"loader\",\n manifest,\n mapRouteProperties2,\n lazyRoutePropertiesToSkip\n );\n return {\n middleware: lazyMiddlewarePromise,\n route: lazyRoutePromises.lazyRoutePromise,\n handler: lazyRoutePromises.lazyHandlerPromise\n };\n}\nfunction getDataStrategyMatch(mapRouteProperties2, manifest, request, path, unstable_pattern, match, lazyRoutePropertiesToSkip, scopedContext, shouldLoad, shouldRevalidateArgs = null, callSiteDefaultShouldRevalidate) {\n let isUsingNewApi = false;\n let _lazyPromises = getDataStrategyMatchLazyPromises(\n mapRouteProperties2,\n manifest,\n request,\n match,\n lazyRoutePropertiesToSkip\n );\n return {\n ...match,\n _lazyPromises,\n shouldLoad,\n shouldRevalidateArgs,\n shouldCallHandler(defaultShouldRevalidate) {\n isUsingNewApi = true;\n if (!shouldRevalidateArgs) {\n return shouldLoad;\n }\n if (typeof callSiteDefaultShouldRevalidate === \"boolean\") {\n return shouldRevalidateLoader(match, {\n ...shouldRevalidateArgs,\n defaultShouldRevalidate: callSiteDefaultShouldRevalidate\n });\n }\n if (typeof defaultShouldRevalidate === \"boolean\") {\n return shouldRevalidateLoader(match, {\n ...shouldRevalidateArgs,\n defaultShouldRevalidate\n });\n }\n return shouldRevalidateLoader(match, shouldRevalidateArgs);\n },\n resolve(handlerOverride) {\n let { lazy, loader, middleware } = match.route;\n let callHandler = isUsingNewApi || shouldLoad || handlerOverride && !isMutationMethod(request.method) && (lazy || loader);\n let isMiddlewareOnlyRoute = middleware && middleware.length > 0 && !loader && !lazy;\n if (callHandler && (isMutationMethod(request.method) || !isMiddlewareOnlyRoute)) {\n return callLoaderOrAction({\n request,\n path,\n unstable_pattern,\n match,\n lazyHandlerPromise: _lazyPromises?.handler,\n lazyRoutePromise: _lazyPromises?.route,\n handlerOverride,\n scopedContext\n });\n }\n return Promise.resolve({ type: \"data\" /* data */, result: void 0 });\n }\n };\n}\nfunction getTargetedDataStrategyMatches(mapRouteProperties2, manifest, request, path, matches, targetMatch, lazyRoutePropertiesToSkip, scopedContext, shouldRevalidateArgs = null) {\n return matches.map((match) => {\n if (match.route.id !== targetMatch.route.id) {\n return {\n ...match,\n shouldLoad: false,\n shouldRevalidateArgs,\n shouldCallHandler: () => false,\n _lazyPromises: getDataStrategyMatchLazyPromises(\n mapRouteProperties2,\n manifest,\n request,\n match,\n lazyRoutePropertiesToSkip\n ),\n resolve: () => Promise.resolve({ type: \"data\", result: void 0 })\n };\n }\n return getDataStrategyMatch(\n mapRouteProperties2,\n manifest,\n request,\n path,\n getRoutePattern(matches),\n match,\n lazyRoutePropertiesToSkip,\n scopedContext,\n true,\n shouldRevalidateArgs\n );\n });\n}\nasync function callDataStrategyImpl(dataStrategyImpl, request, path, matches, fetcherKey, scopedContext, isStaticHandler) {\n if (matches.some((m) => m._lazyPromises?.middleware)) {\n await Promise.all(matches.map((m) => m._lazyPromises?.middleware));\n }\n let dataStrategyArgs = {\n request,\n unstable_url: createDataFunctionUrl(request, path),\n unstable_pattern: getRoutePattern(matches),\n params: matches[0].params,\n context: scopedContext,\n matches\n };\n let runClientMiddleware = isStaticHandler ? () => {\n throw new Error(\n \"You cannot call `runClientMiddleware()` from a static handler `dataStrategy`. Middleware is run outside of `dataStrategy` during SSR in order to bubble up the Response. You can enable middleware via the `respond` API in `query`/`queryRoute`\"\n );\n } : (cb) => {\n let typedDataStrategyArgs = dataStrategyArgs;\n return runClientMiddlewarePipeline(typedDataStrategyArgs, () => {\n return cb({\n ...typedDataStrategyArgs,\n fetcherKey,\n runClientMiddleware: () => {\n throw new Error(\n \"Cannot call `runClientMiddleware()` from within an `runClientMiddleware` handler\"\n );\n }\n });\n });\n };\n let results = await dataStrategyImpl({\n ...dataStrategyArgs,\n fetcherKey,\n runClientMiddleware\n });\n try {\n await Promise.all(\n matches.flatMap((m) => [\n m._lazyPromises?.handler,\n m._lazyPromises?.route\n ])\n );\n } catch (e) {\n }\n return results;\n}\nasync function callLoaderOrAction({\n request,\n path,\n unstable_pattern,\n match,\n lazyHandlerPromise,\n lazyRoutePromise,\n handlerOverride,\n scopedContext\n}) {\n let result;\n let onReject;\n let isAction = isMutationMethod(request.method);\n let type = isAction ? \"action\" : \"loader\";\n let runHandler = (handler) => {\n let reject;\n let abortPromise = new Promise((_, r) => reject = r);\n onReject = () => reject();\n request.signal.addEventListener(\"abort\", onReject);\n let actualHandler = (ctx) => {\n if (typeof handler !== \"function\") {\n return Promise.reject(\n new Error(\n `You cannot call the handler for a route which defines a boolean \"${type}\" [routeId: ${match.route.id}]`\n )\n );\n }\n return handler(\n {\n request,\n unstable_url: createDataFunctionUrl(request, path),\n unstable_pattern,\n params: match.params,\n context: scopedContext\n },\n ...ctx !== void 0 ? [ctx] : []\n );\n };\n let handlerPromise = (async () => {\n try {\n let val = await (handlerOverride ? handlerOverride((ctx) => actualHandler(ctx)) : actualHandler());\n return { type: \"data\", result: val };\n } catch (e) {\n return { type: \"error\", result: e };\n }\n })();\n return Promise.race([handlerPromise, abortPromise]);\n };\n try {\n let handler = isAction ? match.route.action : match.route.loader;\n if (lazyHandlerPromise || lazyRoutePromise) {\n if (handler) {\n let handlerError;\n let [value] = await Promise.all([\n // If the handler throws, don't let it immediately bubble out,\n // since we need to let the lazy() execution finish so we know if this\n // route has a boundary that can handle the error\n runHandler(handler).catch((e) => {\n handlerError = e;\n }),\n // Ensure all lazy route promises are resolved before continuing\n lazyHandlerPromise,\n lazyRoutePromise\n ]);\n if (handlerError !== void 0) {\n throw handlerError;\n }\n result = value;\n } else {\n await lazyHandlerPromise;\n let handler2 = isAction ? match.route.action : match.route.loader;\n if (handler2) {\n [result] = await Promise.all([runHandler(handler2), lazyRoutePromise]);\n } else if (type === \"action\") {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(405, {\n method: request.method,\n pathname,\n routeId: match.route.id\n });\n } else {\n return { type: \"data\" /* data */, result: void 0 };\n }\n }\n } else if (!handler) {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(404, {\n pathname\n });\n } else {\n result = await runHandler(handler);\n }\n } catch (e) {\n return { type: \"error\" /* error */, result: e };\n } finally {\n if (onReject) {\n request.signal.removeEventListener(\"abort\", onReject);\n }\n }\n return result;\n}\nasync function parseResponseBody(response) {\n let contentType = response.headers.get(\"Content-Type\");\n if (contentType && /\\bapplication\\/json\\b/.test(contentType)) {\n return response.body == null ? null : response.json();\n }\n return response.text();\n}\nasync function convertDataStrategyResultToDataResult(dataStrategyResult) {\n let { result, type } = dataStrategyResult;\n if (isResponse(result)) {\n let data2;\n try {\n data2 = await parseResponseBody(result);\n } catch (e) {\n return { type: \"error\" /* error */, error: e };\n }\n if (type === \"error\" /* error */) {\n return {\n type: \"error\" /* error */,\n error: new ErrorResponseImpl(result.status, result.statusText, data2),\n statusCode: result.status,\n headers: result.headers\n };\n }\n return {\n type: \"data\" /* data */,\n data: data2,\n statusCode: result.status,\n headers: result.headers\n };\n }\n if (type === \"error\" /* error */) {\n if (isDataWithResponseInit(result)) {\n if (result.data instanceof Error) {\n return {\n type: \"error\" /* error */,\n error: result.data,\n statusCode: result.init?.status,\n headers: result.init?.headers ? new Headers(result.init.headers) : void 0\n };\n }\n return {\n type: \"error\" /* error */,\n error: dataWithResponseInitToErrorResponse(result),\n statusCode: isRouteErrorResponse(result) ? result.status : void 0,\n headers: result.init?.headers ? new Headers(result.init.headers) : void 0\n };\n }\n return {\n type: \"error\" /* error */,\n error: result,\n statusCode: isRouteErrorResponse(result) ? result.status : void 0\n };\n }\n if (isDataWithResponseInit(result)) {\n return {\n type: \"data\" /* data */,\n data: result.data,\n statusCode: result.init?.status,\n headers: result.init?.headers ? new Headers(result.init.headers) : void 0\n };\n }\n return { type: \"data\" /* data */, data: result };\n}\nfunction normalizeRelativeRoutingRedirectResponse(response, request, routeId, matches, basename) {\n let location = response.headers.get(\"Location\");\n invariant(\n location,\n \"Redirects returned/thrown from loaders/actions must have a Location header\"\n );\n if (!isAbsoluteUrl(location)) {\n let trimmedMatches = matches.slice(\n 0,\n matches.findIndex((m) => m.route.id === routeId) + 1\n );\n location = normalizeTo(\n new URL(request.url),\n trimmedMatches,\n basename,\n location\n );\n response.headers.set(\"Location\", location);\n }\n return response;\n}\nvar invalidProtocols = [\n \"about:\",\n \"blob:\",\n \"chrome:\",\n \"chrome-untrusted:\",\n \"content:\",\n \"data:\",\n \"devtools:\",\n \"file:\",\n \"filesystem:\",\n // eslint-disable-next-line no-script-url\n \"javascript:\"\n];\nfunction normalizeRedirectLocation(location, currentUrl, basename, historyInstance) {\n if (isAbsoluteUrl(location)) {\n let normalizedLocation = location;\n let url = normalizedLocation.startsWith(\"//\") ? new URL(currentUrl.protocol + normalizedLocation) : new URL(normalizedLocation);\n if (invalidProtocols.includes(url.protocol)) {\n throw new Error(\"Invalid redirect location\");\n }\n let isSameBasename = stripBasename(url.pathname, basename) != null;\n if (url.origin === currentUrl.origin && isSameBasename) {\n return removeDoubleSlashes(url.pathname) + url.search + url.hash;\n }\n }\n try {\n let url = historyInstance.createURL(location);\n if (invalidProtocols.includes(url.protocol)) {\n throw new Error(\"Invalid redirect location\");\n }\n } catch (e) {\n }\n return location;\n}\nfunction createClientSideRequest(history, location, signal, submission) {\n let url = history.createURL(stripHashFromPath(location)).toString();\n let init = { signal };\n if (submission && isMutationMethod(submission.formMethod)) {\n let { formMethod, formEncType } = submission;\n init.method = formMethod.toUpperCase();\n if (formEncType === \"application/json\") {\n init.headers = new Headers({ \"Content-Type\": formEncType });\n init.body = JSON.stringify(submission.json);\n } else if (formEncType === \"text/plain\") {\n init.body = submission.text;\n } else if (formEncType === \"application/x-www-form-urlencoded\" && submission.formData) {\n init.body = convertFormDataToSearchParams(submission.formData);\n } else {\n init.body = submission.formData;\n }\n }\n return new Request(url, init);\n}\nfunction createDataFunctionUrl(request, path) {\n let url = new URL(request.url);\n let parsed = typeof path === \"string\" ? parsePath(path) : path;\n url.pathname = parsed.pathname || \"/\";\n if (parsed.search) {\n let searchParams = new URLSearchParams(parsed.search);\n let indexValues = searchParams.getAll(\"index\");\n searchParams.delete(\"index\");\n for (let value of indexValues.filter(Boolean)) {\n searchParams.append(\"index\", value);\n }\n url.search = searchParams.size ? `?${searchParams.toString()}` : \"\";\n } else {\n url.search = \"\";\n }\n url.hash = parsed.hash || \"\";\n return url;\n}\nfunction convertFormDataToSearchParams(formData) {\n let searchParams = new URLSearchParams();\n for (let [key, value] of formData.entries()) {\n searchParams.append(key, typeof value === \"string\" ? value : value.name);\n }\n return searchParams;\n}\nfunction convertSearchParamsToFormData(searchParams) {\n let formData = new FormData();\n for (let [key, value] of searchParams.entries()) {\n formData.append(key, value);\n }\n return formData;\n}\nfunction processRouteLoaderData(matches, results, pendingActionResult, isStaticHandler = false, skipLoaderErrorBubbling = false) {\n let loaderData = {};\n let errors = null;\n let statusCode;\n let foundError = false;\n let loaderHeaders = {};\n let pendingError = pendingActionResult && isErrorResult(pendingActionResult[1]) ? pendingActionResult[1].error : void 0;\n matches.forEach((match) => {\n if (!(match.route.id in results)) {\n return;\n }\n let id = match.route.id;\n let result = results[id];\n invariant(\n !isRedirectResult(result),\n \"Cannot handle redirect results in processLoaderData\"\n );\n if (isErrorResult(result)) {\n let error = result.error;\n if (pendingError !== void 0) {\n error = pendingError;\n pendingError = void 0;\n }\n errors = errors || {};\n if (skipLoaderErrorBubbling) {\n errors[id] = error;\n } else {\n let boundaryMatch = findNearestBoundary(matches, id);\n if (errors[boundaryMatch.route.id] == null) {\n errors[boundaryMatch.route.id] = error;\n }\n }\n if (!isStaticHandler) {\n loaderData[id] = ResetLoaderDataSymbol;\n }\n if (!foundError) {\n foundError = true;\n statusCode = isRouteErrorResponse(result.error) ? result.error.status : 500;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n } else {\n loaderData[id] = result.data;\n if (result.statusCode && result.statusCode !== 200 && !foundError) {\n statusCode = result.statusCode;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n }\n });\n if (pendingError !== void 0 && pendingActionResult) {\n errors = { [pendingActionResult[0]]: pendingError };\n if (pendingActionResult[2]) {\n loaderData[pendingActionResult[2]] = void 0;\n }\n }\n return {\n loaderData,\n errors,\n statusCode: statusCode || 200,\n loaderHeaders\n };\n}\nfunction processLoaderData(state, matches, results, pendingActionResult, revalidatingFetchers, fetcherResults) {\n let { loaderData, errors } = processRouteLoaderData(\n matches,\n results,\n pendingActionResult\n );\n revalidatingFetchers.filter((f) => !f.matches || f.matches.some((m) => m.shouldLoad)).forEach((rf) => {\n let { key, match, controller } = rf;\n if (controller && controller.signal.aborted) {\n return;\n }\n let result = fetcherResults[key];\n invariant(result, \"Did not find corresponding fetcher result\");\n if (isErrorResult(result)) {\n let boundaryMatch = findNearestBoundary(state.matches, match?.route.id);\n if (!(errors && errors[boundaryMatch.route.id])) {\n errors = {\n ...errors,\n [boundaryMatch.route.id]: result.error\n };\n }\n state.fetchers.delete(key);\n } else if (isRedirectResult(result)) {\n invariant(false, \"Unhandled fetcher revalidation redirect\");\n } else {\n let doneFetcher = getDoneFetcher(result.data);\n state.fetchers.set(key, doneFetcher);\n }\n });\n return { loaderData, errors };\n}\nfunction mergeLoaderData(loaderData, newLoaderData, matches, errors) {\n let mergedLoaderData = Object.entries(newLoaderData).filter(([, v]) => v !== ResetLoaderDataSymbol).reduce((merged, [k, v]) => {\n merged[k] = v;\n return merged;\n }, {});\n for (let match of matches) {\n let id = match.route.id;\n if (!newLoaderData.hasOwnProperty(id) && loaderData.hasOwnProperty(id) && match.route.loader) {\n mergedLoaderData[id] = loaderData[id];\n }\n if (errors && errors.hasOwnProperty(id)) {\n break;\n }\n }\n return mergedLoaderData;\n}\nfunction getActionDataForCommit(pendingActionResult) {\n if (!pendingActionResult) {\n return {};\n }\n return isErrorResult(pendingActionResult[1]) ? {\n // Clear out prior actionData on errors\n actionData: {}\n } : {\n actionData: {\n [pendingActionResult[0]]: pendingActionResult[1].data\n }\n };\n}\nfunction findNearestBoundary(matches, routeId) {\n let eligibleMatches = routeId ? matches.slice(0, matches.findIndex((m) => m.route.id === routeId) + 1) : [...matches];\n return eligibleMatches.reverse().find((m) => m.route.hasErrorBoundary === true) || matches[0];\n}\nfunction getShortCircuitMatches(routes) {\n let route = routes.length === 1 ? routes[0] : routes.find((r) => r.index || !r.path || r.path === \"/\") || {\n id: `__shim-error-route__`\n };\n return {\n matches: [\n {\n params: {},\n pathname: \"\",\n pathnameBase: \"\",\n route\n }\n ],\n route\n };\n}\nfunction getInternalRouterError(status, {\n pathname,\n routeId,\n method,\n type,\n message\n} = {}) {\n let statusText = \"Unknown Server Error\";\n let errorMessage = \"Unknown @remix-run/router error\";\n if (status === 400) {\n statusText = \"Bad Request\";\n if (method && pathname && routeId) {\n errorMessage = `You made a ${method} request to \"${pathname}\" but did not provide a \\`loader\\` for route \"${routeId}\", so there is no way to handle the request.`;\n } else if (type === \"invalid-body\") {\n errorMessage = \"Unable to encode submission body\";\n }\n } else if (status === 403) {\n statusText = \"Forbidden\";\n errorMessage = `Route \"${routeId}\" does not match URL \"${pathname}\"`;\n } else if (status === 404) {\n statusText = \"Not Found\";\n errorMessage = `No route matches URL \"${pathname}\"`;\n } else if (status === 405) {\n statusText = \"Method Not Allowed\";\n if (method && pathname && routeId) {\n errorMessage = `You made a ${method.toUpperCase()} request to \"${pathname}\" but did not provide an \\`action\\` for route \"${routeId}\", so there is no way to handle the request.`;\n } else if (method) {\n errorMessage = `Invalid request method \"${method.toUpperCase()}\"`;\n }\n }\n return new ErrorResponseImpl(\n status || 500,\n statusText,\n new Error(errorMessage),\n true\n );\n}\nfunction findRedirect(results) {\n let entries = Object.entries(results);\n for (let i = entries.length - 1; i >= 0; i--) {\n let [key, result] = entries[i];\n if (isRedirectResult(result)) {\n return { key, result };\n }\n }\n}\nfunction stripHashFromPath(path) {\n let parsedPath = typeof path === \"string\" ? parsePath(path) : path;\n return createPath({ ...parsedPath, hash: \"\" });\n}\nfunction isHashChangeOnly(a, b) {\n if (a.pathname !== b.pathname || a.search !== b.search) {\n return false;\n }\n if (a.hash === \"\") {\n return b.hash !== \"\";\n } else if (a.hash === b.hash) {\n return true;\n } else if (b.hash !== \"\") {\n return true;\n }\n return false;\n}\nfunction dataWithResponseInitToResponse(data2) {\n return Response.json(data2.data, data2.init ?? void 0);\n}\nfunction dataWithResponseInitToErrorResponse(data2) {\n return new ErrorResponseImpl(\n data2.init?.status ?? 500,\n data2.init?.statusText ?? \"Internal Server Error\",\n data2.data\n );\n}\nfunction isDataStrategyResults(result) {\n return result != null && typeof result === \"object\" && Object.entries(result).every(\n ([key, value]) => typeof key === \"string\" && isDataStrategyResult(value)\n );\n}\nfunction isDataStrategyResult(result) {\n return result != null && typeof result === \"object\" && \"type\" in result && \"result\" in result && (result.type === \"data\" /* data */ || result.type === \"error\" /* error */);\n}\nfunction isRedirectDataStrategyResult(result) {\n return isResponse(result.result) && redirectStatusCodes.has(result.result.status);\n}\nfunction isErrorResult(result) {\n return result.type === \"error\" /* error */;\n}\nfunction isRedirectResult(result) {\n return (result && result.type) === \"redirect\" /* redirect */;\n}\nfunction isDataWithResponseInit(value) {\n return typeof value === \"object\" && value != null && \"type\" in value && \"data\" in value && \"init\" in value && value.type === \"DataWithResponseInit\";\n}\nfunction isResponse(value) {\n return value != null && typeof value.status === \"number\" && typeof value.statusText === \"string\" && typeof value.headers === \"object\" && typeof value.body !== \"undefined\";\n}\nfunction isRedirectStatusCode(statusCode) {\n return redirectStatusCodes.has(statusCode);\n}\nfunction isRedirectResponse(result) {\n return isResponse(result) && isRedirectStatusCode(result.status) && result.headers.has(\"Location\");\n}\nfunction isValidMethod(method) {\n return validRequestMethods.has(method.toUpperCase());\n}\nfunction isMutationMethod(method) {\n return validMutationMethods.has(method.toUpperCase());\n}\nfunction hasNakedIndexQuery(search) {\n return new URLSearchParams(search).getAll(\"index\").some((v) => v === \"\");\n}\nfunction getTargetMatch(matches, location) {\n let search = typeof location === \"string\" ? parsePath(location).search : location.search;\n if (matches[matches.length - 1].route.index && hasNakedIndexQuery(search || \"\")) {\n return matches[matches.length - 1];\n }\n let pathMatches = getPathContributingMatches(matches);\n return pathMatches[pathMatches.length - 1];\n}\nfunction getSubmissionFromNavigation(navigation) {\n let { formMethod, formAction, formEncType, text, formData, json } = navigation;\n if (!formMethod || !formAction || !formEncType) {\n return;\n }\n if (text != null) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData: void 0,\n json: void 0,\n text\n };\n } else if (formData != null) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData,\n json: void 0,\n text: void 0\n };\n } else if (json !== void 0) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData: void 0,\n json,\n text: void 0\n };\n }\n}\nfunction getLoadingNavigation(location, submission) {\n if (submission) {\n let navigation = {\n state: \"loading\",\n location,\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text\n };\n return navigation;\n } else {\n let navigation = {\n state: \"loading\",\n location,\n formMethod: void 0,\n formAction: void 0,\n formEncType: void 0,\n formData: void 0,\n json: void 0,\n text: void 0\n };\n return navigation;\n }\n}\nfunction getSubmittingNavigation(location, submission) {\n let navigation = {\n state: \"submitting\",\n location,\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text\n };\n return navigation;\n}\nfunction getLoadingFetcher(submission, data2) {\n if (submission) {\n let fetcher = {\n state: \"loading\",\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n data: data2\n };\n return fetcher;\n } else {\n let fetcher = {\n state: \"loading\",\n formMethod: void 0,\n formAction: void 0,\n formEncType: void 0,\n formData: void 0,\n json: void 0,\n text: void 0,\n data: data2\n };\n return fetcher;\n }\n}\nfunction getSubmittingFetcher(submission, existingFetcher) {\n let fetcher = {\n state: \"submitting\",\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n data: existingFetcher ? existingFetcher.data : void 0\n };\n return fetcher;\n}\nfunction getDoneFetcher(data2) {\n let fetcher = {\n state: \"idle\",\n formMethod: void 0,\n formAction: void 0,\n formEncType: void 0,\n formData: void 0,\n json: void 0,\n text: void 0,\n data: data2\n };\n return fetcher;\n}\nfunction restoreAppliedTransitions(_window, transitions) {\n try {\n let sessionPositions = _window.sessionStorage.getItem(\n TRANSITIONS_STORAGE_KEY\n );\n if (sessionPositions) {\n let json = JSON.parse(sessionPositions);\n for (let [k, v] of Object.entries(json || {})) {\n if (v && Array.isArray(v)) {\n transitions.set(k, new Set(v || []));\n }\n }\n }\n } catch (e) {\n }\n}\nfunction persistAppliedTransitions(_window, transitions) {\n if (transitions.size > 0) {\n let json = {};\n for (let [k, v] of transitions) {\n json[k] = [...v];\n }\n try {\n _window.sessionStorage.setItem(\n TRANSITIONS_STORAGE_KEY,\n JSON.stringify(json)\n );\n } catch (error) {\n warning(\n false,\n `Failed to save applied view transitions in sessionStorage (${error}).`\n );\n }\n }\n}\nfunction createDeferred() {\n let resolve;\n let reject;\n let promise = new Promise((res, rej) => {\n resolve = async (val) => {\n res(val);\n try {\n await promise;\n } catch (e) {\n }\n };\n reject = async (error) => {\n rej(error);\n try {\n await promise;\n } catch (e) {\n }\n };\n });\n return {\n promise,\n //@ts-ignore\n resolve,\n //@ts-ignore\n reject\n };\n}\n\n// lib/context.ts\nimport * as React from \"react\";\nvar DataRouterContext = React.createContext(null);\nDataRouterContext.displayName = \"DataRouter\";\nvar DataRouterStateContext = React.createContext(null);\nDataRouterStateContext.displayName = \"DataRouterState\";\nvar RSCRouterContext = React.createContext(false);\nfunction useIsRSCRouterContext() {\n return React.useContext(RSCRouterContext);\n}\nvar ViewTransitionContext = React.createContext({\n isTransitioning: false\n});\nViewTransitionContext.displayName = \"ViewTransition\";\nvar FetchersContext = React.createContext(\n /* @__PURE__ */ new Map()\n);\nFetchersContext.displayName = \"Fetchers\";\nvar AwaitContext = React.createContext(null);\nAwaitContext.displayName = \"Await\";\nvar AwaitContextProvider = (props) => React.createElement(AwaitContext.Provider, props);\nvar NavigationContext = React.createContext(\n null\n);\nNavigationContext.displayName = \"Navigation\";\nvar LocationContext = React.createContext(\n null\n);\nLocationContext.displayName = \"Location\";\nvar RouteContext = React.createContext({\n outlet: null,\n matches: [],\n isDataRoute: false\n});\nRouteContext.displayName = \"Route\";\nvar RouteErrorContext = React.createContext(null);\nRouteErrorContext.displayName = \"RouteError\";\nvar ENABLE_DEV_WARNINGS = true;\n\n// lib/hooks.tsx\nimport * as React2 from \"react\";\n\n// lib/errors.ts\nvar ERROR_DIGEST_BASE = \"REACT_ROUTER_ERROR\";\nvar ERROR_DIGEST_REDIRECT = \"REDIRECT\";\nvar ERROR_DIGEST_ROUTE_ERROR_RESPONSE = \"ROUTE_ERROR_RESPONSE\";\nfunction decodeRedirectErrorDigest(digest) {\n if (digest.startsWith(`${ERROR_DIGEST_BASE}:${ERROR_DIGEST_REDIRECT}:{`)) {\n try {\n let parsed = JSON.parse(digest.slice(28));\n if (typeof parsed === \"object\" && parsed && typeof parsed.status === \"number\" && typeof parsed.statusText === \"string\" && typeof parsed.location === \"string\" && typeof parsed.reloadDocument === \"boolean\" && typeof parsed.replace === \"boolean\") {\n return parsed;\n }\n } catch {\n }\n }\n}\nfunction decodeRouteErrorResponseDigest(digest) {\n if (digest.startsWith(\n `${ERROR_DIGEST_BASE}:${ERROR_DIGEST_ROUTE_ERROR_RESPONSE}:{`\n )) {\n try {\n let parsed = JSON.parse(digest.slice(40));\n if (typeof parsed === \"object\" && parsed && typeof parsed.status === \"number\" && typeof parsed.statusText === \"string\") {\n return new ErrorResponseImpl(\n parsed.status,\n parsed.statusText,\n parsed.data\n );\n }\n } catch {\n }\n }\n}\n\n// lib/hooks.tsx\nfunction useHref(to, { relative } = {}) {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useHref() may be used only in the context of a <Router> component.`\n );\n let { basename, navigator } = React2.useContext(NavigationContext);\n let { hash, pathname, search } = useResolvedPath(to, { relative });\n let joinedPathname = pathname;\n if (basename !== \"/\") {\n joinedPathname = pathname === \"/\" ? basename : joinPaths([basename, pathname]);\n }\n return navigator.createHref({ pathname: joinedPathname, search, hash });\n}\nfunction useInRouterContext() {\n return React2.useContext(LocationContext) != null;\n}\nfunction useLocation() {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useLocation() may be used only in the context of a <Router> component.`\n );\n return React2.useContext(LocationContext).location;\n}\nfunction useNavigationType() {\n return React2.useContext(LocationContext).navigationType;\n}\nfunction useMatch(pattern) {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useMatch() may be used only in the context of a <Router> component.`\n );\n let { pathname } = useLocation();\n return React2.useMemo(\n () => matchPath(pattern, decodePath(pathname)),\n [pathname, pattern]\n );\n}\nvar navigateEffectWarning = `You should call navigate() in a React.useEffect(), not when your component is first rendered.`;\nfunction useIsomorphicLayoutEffect(cb) {\n let isStatic = React2.useContext(NavigationContext).static;\n if (!isStatic) {\n React2.useLayoutEffect(cb);\n }\n}\nfunction useNavigate() {\n let { isDataRoute } = React2.useContext(RouteContext);\n return isDataRoute ? useNavigateStable() : useNavigateUnstable();\n}\nfunction useNavigateUnstable() {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useNavigate() may be used only in the context of a <Router> component.`\n );\n let dataRouterContext = React2.useContext(DataRouterContext);\n let { basename, navigator } = React2.useContext(NavigationContext);\n let { matches } = React2.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n let routePathnamesJson = JSON.stringify(getResolveToMatches(matches));\n let activeRef = React2.useRef(false);\n useIsomorphicLayoutEffect(() => {\n activeRef.current = true;\n });\n let navigate = React2.useCallback(\n (to, options = {}) => {\n warning(activeRef.current, navigateEffectWarning);\n if (!activeRef.current) return;\n if (typeof to === \"number\") {\n navigator.go(to);\n return;\n }\n let path = resolveTo(\n to,\n JSON.parse(routePathnamesJson),\n locationPathname,\n options.relative === \"path\"\n );\n if (dataRouterContext == null && basename !== \"/\") {\n path.pathname = path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n }\n (!!options.replace ? navigator.replace : navigator.push)(\n path,\n options.state,\n options\n );\n },\n [\n basename,\n navigator,\n routePathnamesJson,\n locationPathname,\n dataRouterContext\n ]\n );\n return navigate;\n}\nvar OutletContext = React2.createContext(null);\nfunction useOutletContext() {\n return React2.useContext(OutletContext);\n}\nfunction useOutlet(context) {\n let outlet = React2.useContext(RouteContext).outlet;\n return React2.useMemo(\n () => outlet && /* @__PURE__ */ React2.createElement(OutletContext.Provider, { value: context }, outlet),\n [outlet, context]\n );\n}\nfunction useParams() {\n let { matches } = React2.useContext(RouteContext);\n let routeMatch = matches[matches.length - 1];\n return routeMatch?.params ?? {};\n}\nfunction useResolvedPath(to, { relative } = {}) {\n let { matches } = React2.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n let routePathnamesJson = JSON.stringify(getResolveToMatches(matches));\n return React2.useMemo(\n () => resolveTo(\n to,\n JSON.parse(routePathnamesJson),\n locationPathname,\n relative === \"path\"\n ),\n [to, routePathnamesJson, locationPathname, relative]\n );\n}\nfunction useRoutes(routes, locationArg) {\n return useRoutesImpl(routes, locationArg);\n}\nfunction useRoutesImpl(routes, locationArg, dataRouterOpts) {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useRoutes() may be used only in the context of a <Router> component.`\n );\n let { navigator } = React2.useContext(NavigationContext);\n let { matches: parentMatches } = React2.useContext(RouteContext);\n let routeMatch = parentMatches[parentMatches.length - 1];\n let parentParams = routeMatch ? routeMatch.params : {};\n let parentPathname = routeMatch ? routeMatch.pathname : \"/\";\n let parentPathnameBase = routeMatch ? routeMatch.pathnameBase : \"/\";\n let parentRoute = routeMatch && routeMatch.route;\n if (ENABLE_DEV_WARNINGS) {\n let parentPath = parentRoute && parentRoute.path || \"\";\n warningOnce(\n parentPathname,\n !parentRoute || parentPath.endsWith(\"*\") || parentPath.endsWith(\"*?\"),\n `You rendered descendant <Routes> (or called \\`useRoutes()\\`) at \"${parentPathname}\" (under <Route path=\"${parentPath}\">) but the parent route path has no trailing \"*\". This means if you navigate deeper, the parent won't match anymore and therefore the child routes will never render.\n\nPlease change the parent <Route path=\"${parentPath}\"> to <Route path=\"${parentPath === \"/\" ? \"*\" : `${parentPath}/*`}\">.`\n );\n }\n let locationFromContext = useLocation();\n let location;\n if (locationArg) {\n let parsedLocationArg = typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n invariant(\n parentPathnameBase === \"/\" || parsedLocationArg.pathname?.startsWith(parentPathnameBase),\n `When overriding the location using \\`<Routes location>\\` or \\`useRoutes(routes, location)\\`, the location pathname must begin with the portion of the URL pathname that was matched by all parent routes. The current pathname base is \"${parentPathnameBase}\" but pathname \"${parsedLocationArg.pathname}\" was given in the \\`location\\` prop.`\n );\n location = parsedLocationArg;\n } else {\n location = locationFromContext;\n }\n let pathname = location.pathname || \"/\";\n let remainingPathname = pathname;\n if (parentPathnameBase !== \"/\") {\n let parentSegments = parentPathnameBase.replace(/^\\//, \"\").split(\"/\");\n let segments = pathname.replace(/^\\//, \"\").split(\"/\");\n remainingPathname = \"/\" + segments.slice(parentSegments.length).join(\"/\");\n }\n let matches = matchRoutes(routes, { pathname: remainingPathname });\n if (ENABLE_DEV_WARNINGS) {\n warning(\n parentRoute || matches != null,\n `No routes matched location \"${location.pathname}${location.search}${location.hash}\" `\n );\n warning(\n matches == null || matches[matches.length - 1].route.element !== void 0 || matches[matches.length - 1].route.Component !== void 0 || matches[matches.length - 1].route.lazy !== void 0,\n `Matched leaf route at location \"${location.pathname}${location.search}${location.hash}\" does not have an element or Component. This means it will render an <Outlet /> with a null value by default resulting in an \"empty\" page.`\n );\n }\n let renderedMatches = _renderMatches(\n matches && matches.map(\n (match) => Object.assign({}, match, {\n params: Object.assign({}, parentParams, match.params),\n pathname: joinPaths([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes.\n // Pre-encode `%`, `?` and `#` ahead of `encodeLocation` because it uses\n // `new URL()` internally and we need to prevent it from treating\n // them as separators\n navigator.encodeLocation ? navigator.encodeLocation(\n match.pathname.replace(/%/g, \"%25\").replace(/\\?/g, \"%3F\").replace(/#/g, \"%23\")\n ).pathname : match.pathname\n ]),\n pathnameBase: match.pathnameBase === \"/\" ? parentPathnameBase : joinPaths([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes\n // Pre-encode `%`, `?` and `#` ahead of `encodeLocation` because it uses\n // `new URL()` internally and we need to prevent it from treating\n // them as separators\n navigator.encodeLocation ? navigator.encodeLocation(\n match.pathnameBase.replace(/%/g, \"%25\").replace(/\\?/g, \"%3F\").replace(/#/g, \"%23\")\n ).pathname : match.pathnameBase\n ])\n })\n ),\n parentMatches,\n dataRouterOpts\n );\n if (locationArg && renderedMatches) {\n return /* @__PURE__ */ React2.createElement(\n LocationContext.Provider,\n {\n value: {\n location: {\n pathname: \"/\",\n search: \"\",\n hash: \"\",\n state: null,\n key: \"default\",\n unstable_mask: void 0,\n ...location\n },\n navigationType: \"POP\" /* Pop */\n }\n },\n renderedMatches\n );\n }\n return renderedMatches;\n}\nfunction DefaultErrorComponent() {\n let error = useRouteError();\n let message = isRouteErrorResponse(error) ? `${error.status} ${error.statusText}` : error instanceof Error ? error.message : JSON.stringify(error);\n let stack = error instanceof Error ? error.stack : null;\n let lightgrey = \"rgba(200,200,200, 0.5)\";\n let preStyles = { padding: \"0.5rem\", backgroundColor: lightgrey };\n let codeStyles = { padding: \"2px 4px\", backgroundColor: lightgrey };\n let devInfo = null;\n if (ENABLE_DEV_WARNINGS) {\n console.error(\n \"Error handled by React Router default ErrorBoundary:\",\n error\n );\n devInfo = /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement(\"p\", null, \"\\u{1F4BF} Hey developer \\u{1F44B}\"), /* @__PURE__ */ React2.createElement(\"p\", null, \"You can provide a way better UX than this when your app throws errors by providing your own \", /* @__PURE__ */ React2.createElement(\"code\", { style: codeStyles }, \"ErrorBoundary\"), \" or\", \" \", /* @__PURE__ */ React2.createElement(\"code\", { style: codeStyles }, \"errorElement\"), \" prop on your route.\"));\n }\n return /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement(\"h2\", null, \"Unexpected Application Error!\"), /* @__PURE__ */ React2.createElement(\"h3\", { style: { fontStyle: \"italic\" } }, message), stack ? /* @__PURE__ */ React2.createElement(\"pre\", { style: preStyles }, stack) : null, devInfo);\n}\nvar defaultErrorElement = /* @__PURE__ */ React2.createElement(DefaultErrorComponent, null);\nvar RenderErrorBoundary = class extends React2.Component {\n constructor(props) {\n super(props);\n this.state = {\n location: props.location,\n revalidation: props.revalidation,\n error: props.error\n };\n }\n static getDerivedStateFromError(error) {\n return { error };\n }\n static getDerivedStateFromProps(props, state) {\n if (state.location !== props.location || state.revalidation !== \"idle\" && props.revalidation === \"idle\") {\n return {\n error: props.error,\n location: props.location,\n revalidation: props.revalidation\n };\n }\n return {\n error: props.error !== void 0 ? props.error : state.error,\n location: state.location,\n revalidation: props.revalidation || state.revalidation\n };\n }\n componentDidCatch(error, errorInfo) {\n if (this.props.onError) {\n this.props.onError(error, errorInfo);\n } else {\n console.error(\n \"React Router caught the following error during render\",\n error\n );\n }\n }\n render() {\n let error = this.state.error;\n if (this.context && typeof error === \"object\" && error && \"digest\" in error && typeof error.digest === \"string\") {\n const decoded = decodeRouteErrorResponseDigest(error.digest);\n if (decoded) error = decoded;\n }\n let result = error !== void 0 ? /* @__PURE__ */ React2.createElement(RouteContext.Provider, { value: this.props.routeContext }, /* @__PURE__ */ React2.createElement(\n RouteErrorContext.Provider,\n {\n value: error,\n children: this.props.component\n }\n )) : this.props.children;\n if (this.context) {\n return /* @__PURE__ */ React2.createElement(RSCErrorHandler, { error }, result);\n }\n return result;\n }\n};\nRenderErrorBoundary.contextType = RSCRouterContext;\nvar errorRedirectHandledMap = /* @__PURE__ */ new WeakMap();\nfunction RSCErrorHandler({\n children,\n error\n}) {\n let { basename } = React2.useContext(NavigationContext);\n if (typeof error === \"object\" && error && \"digest\" in error && typeof error.digest === \"string\") {\n let redirect2 = decodeRedirectErrorDigest(error.digest);\n if (redirect2) {\n let existingRedirect = errorRedirectHandledMap.get(error);\n if (existingRedirect) throw existingRedirect;\n let parsed = parseToInfo(redirect2.location, basename);\n if (isBrowser && !errorRedirectHandledMap.get(error)) {\n if (parsed.isExternal || redirect2.reloadDocument) {\n window.location.href = parsed.absoluteURL || parsed.to;\n } else {\n const redirectPromise = Promise.resolve().then(\n () => window.__reactRouterDataRouter.navigate(parsed.to, {\n replace: redirect2.replace\n })\n );\n errorRedirectHandledMap.set(error, redirectPromise);\n throw redirectPromise;\n }\n }\n return /* @__PURE__ */ React2.createElement(\n \"meta\",\n {\n httpEquiv: \"refresh\",\n content: `0;url=${parsed.absoluteURL || parsed.to}`\n }\n );\n }\n }\n return children;\n}\nfunction RenderedRoute({ routeContext, match, children }) {\n let dataRouterContext = React2.useContext(DataRouterContext);\n if (dataRouterContext && dataRouterContext.static && dataRouterContext.staticContext && (match.route.errorElement || match.route.ErrorBoundary)) {\n dataRouterContext.staticContext._deepestRenderedBoundaryId = match.route.id;\n }\n return /* @__PURE__ */ React2.createElement(RouteContext.Provider, { value: routeContext }, children);\n}\nfunction _renderMatches(matches, parentMatches = [], dataRouterOpts) {\n let dataRouterState = dataRouterOpts?.state;\n if (matches == null) {\n if (!dataRouterState) {\n return null;\n }\n if (dataRouterState.errors) {\n matches = dataRouterState.matches;\n } else if (parentMatches.length === 0 && !dataRouterState.initialized && dataRouterState.matches.length > 0) {\n matches = dataRouterState.matches;\n } else {\n return null;\n }\n }\n let renderedMatches = matches;\n let errors = dataRouterState?.errors;\n if (errors != null) {\n let errorIndex = renderedMatches.findIndex(\n (m) => m.route.id && errors?.[m.route.id] !== void 0\n );\n invariant(\n errorIndex >= 0,\n `Could not find a matching route for errors on route IDs: ${Object.keys(\n errors\n ).join(\",\")}`\n );\n renderedMatches = renderedMatches.slice(\n 0,\n Math.min(renderedMatches.length, errorIndex + 1)\n );\n }\n let renderFallback = false;\n let fallbackIndex = -1;\n if (dataRouterOpts && dataRouterState) {\n renderFallback = dataRouterState.renderFallback;\n for (let i = 0; i < renderedMatches.length; i++) {\n let match = renderedMatches[i];\n if (match.route.HydrateFallback || match.route.hydrateFallbackElement) {\n fallbackIndex = i;\n }\n if (match.route.id) {\n let { loaderData, errors: errors2 } = dataRouterState;\n let needsToRunLoader = match.route.loader && !loaderData.hasOwnProperty(match.route.id) && (!errors2 || errors2[match.route.id] === void 0);\n if (match.route.lazy || needsToRunLoader) {\n if (dataRouterOpts.isStatic) {\n renderFallback = true;\n }\n if (fallbackIndex >= 0) {\n renderedMatches = renderedMatches.slice(0, fallbackIndex + 1);\n } else {\n renderedMatches = [renderedMatches[0]];\n }\n break;\n }\n }\n }\n }\n let onErrorHandler = dataRouterOpts?.onError;\n let onError = dataRouterState && onErrorHandler ? (error, errorInfo) => {\n onErrorHandler(error, {\n location: dataRouterState.location,\n params: dataRouterState.matches?.[0]?.params ?? {},\n unstable_pattern: getRoutePattern(dataRouterState.matches),\n errorInfo\n });\n } : void 0;\n return renderedMatches.reduceRight(\n (outlet, match, index) => {\n let error;\n let shouldRenderHydrateFallback = false;\n let errorElement = null;\n let hydrateFallbackElement = null;\n if (dataRouterState) {\n error = errors && match.route.id ? errors[match.route.id] : void 0;\n errorElement = match.route.errorElement || defaultErrorElement;\n if (renderFallback) {\n if (fallbackIndex < 0 && index === 0) {\n warningOnce(\n \"route-fallback\",\n false,\n \"No `HydrateFallback` element provided to render during initial hydration\"\n );\n shouldRenderHydrateFallback = true;\n hydrateFallbackElement = null;\n } else if (fallbackIndex === index) {\n shouldRenderHydrateFallback = true;\n hydrateFallbackElement = match.route.hydrateFallbackElement || null;\n }\n }\n }\n let matches2 = parentMatches.concat(renderedMatches.slice(0, index + 1));\n let getChildren = () => {\n let children;\n if (error) {\n children = errorElement;\n } else if (shouldRenderHydrateFallback) {\n children = hydrateFallbackElement;\n } else if (match.route.Component) {\n children = /* @__PURE__ */ React2.createElement(match.route.Component, null);\n } else if (match.route.element) {\n children = match.route.element;\n } else {\n children = outlet;\n }\n return /* @__PURE__ */ React2.createElement(\n RenderedRoute,\n {\n match,\n routeContext: {\n outlet,\n matches: matches2,\n isDataRoute: dataRouterState != null\n },\n children\n }\n );\n };\n return dataRouterState && (match.route.ErrorBoundary || match.route.errorElement || index === 0) ? /* @__PURE__ */ React2.createElement(\n RenderErrorBoundary,\n {\n location: dataRouterState.location,\n revalidation: dataRouterState.revalidation,\n component: errorElement,\n error,\n children: getChildren(),\n routeContext: { outlet: null, matches: matches2, isDataRoute: true },\n onError\n }\n ) : getChildren();\n },\n null\n );\n}\nfunction getDataRouterConsoleError(hookName) {\n return `${hookName} must be used within a data router. See https://reactrouter.com/en/main/routers/picking-a-router.`;\n}\nfunction useDataRouterContext(hookName) {\n let ctx = React2.useContext(DataRouterContext);\n invariant(ctx, getDataRouterConsoleError(hookName));\n return ctx;\n}\nfunction useDataRouterState(hookName) {\n let state = React2.useContext(DataRouterStateContext);\n invariant(state, getDataRouterConsoleError(hookName));\n return state;\n}\nfunction useRouteContext(hookName) {\n let route = React2.useContext(RouteContext);\n invariant(route, getDataRouterConsoleError(hookName));\n return route;\n}\nfunction useCurrentRouteId(hookName) {\n let route = useRouteContext(hookName);\n let thisRoute = route.matches[route.matches.length - 1];\n invariant(\n thisRoute.route.id,\n `${hookName} can only be used on routes that contain a unique \"id\"`\n );\n return thisRoute.route.id;\n}\nfunction useRouteId() {\n return useCurrentRouteId(\"useRouteId\" /* UseRouteId */);\n}\nfunction useNavigation() {\n let state = useDataRouterState(\"useNavigation\" /* UseNavigation */);\n return state.navigation;\n}\nfunction useRevalidator() {\n let dataRouterContext = useDataRouterContext(\"useRevalidator\" /* UseRevalidator */);\n let state = useDataRouterState(\"useRevalidator\" /* UseRevalidator */);\n let revalidate = React2.useCallback(async () => {\n await dataRouterContext.router.revalidate();\n }, [dataRouterContext.router]);\n return React2.useMemo(\n () => ({ revalidate, state: state.revalidation }),\n [revalidate, state.revalidation]\n );\n}\nfunction useMatches() {\n let { matches, loaderData } = useDataRouterState(\n \"useMatches\" /* UseMatches */\n );\n return React2.useMemo(\n () => matches.map((m) => convertRouteMatchToUiMatch(m, loaderData)),\n [matches, loaderData]\n );\n}\nfunction useLoaderData() {\n let state = useDataRouterState(\"useLoaderData\" /* UseLoaderData */);\n let routeId = useCurrentRouteId(\"useLoaderData\" /* UseLoaderData */);\n return state.loaderData[routeId];\n}\nfunction useRouteLoaderData(routeId) {\n let state = useDataRouterState(\"useRouteLoaderData\" /* UseRouteLoaderData */);\n return state.loaderData[routeId];\n}\nfunction useActionData() {\n let state = useDataRouterState(\"useActionData\" /* UseActionData */);\n let routeId = useCurrentRouteId(\"useLoaderData\" /* UseLoaderData */);\n return state.actionData ? state.actionData[routeId] : void 0;\n}\nfunction useRouteError() {\n let error = React2.useContext(RouteErrorContext);\n let state = useDataRouterState(\"useRouteError\" /* UseRouteError */);\n let routeId = useCurrentRouteId(\"useRouteError\" /* UseRouteError */);\n if (error !== void 0) {\n return error;\n }\n return state.errors?.[routeId];\n}\nfunction useAsyncValue() {\n let value = React2.useContext(AwaitContext);\n return value?._data;\n}\nfunction useAsyncError() {\n let value = React2.useContext(AwaitContext);\n return value?._error;\n}\nvar blockerId = 0;\nfunction useBlocker(shouldBlock) {\n let { router, basename } = useDataRouterContext(\"useBlocker\" /* UseBlocker */);\n let state = useDataRouterState(\"useBlocker\" /* UseBlocker */);\n let [blockerKey, setBlockerKey] = React2.useState(\"\");\n let blockerFunction = React2.useCallback(\n (arg) => {\n if (typeof shouldBlock !== \"function\") {\n return !!shouldBlock;\n }\n if (basename === \"/\") {\n return shouldBlock(arg);\n }\n let { currentLocation, nextLocation, historyAction } = arg;\n return shouldBlock({\n currentLocation: {\n ...currentLocation,\n pathname: stripBasename(currentLocation.pathname, basename) || currentLocation.pathname\n },\n nextLocation: {\n ...nextLocation,\n pathname: stripBasename(nextLocation.pathname, basename) || nextLocation.pathname\n },\n historyAction\n });\n },\n [basename, shouldBlock]\n );\n React2.useEffect(() => {\n let key = String(++blockerId);\n setBlockerKey(key);\n return () => router.deleteBlocker(key);\n }, [router]);\n React2.useEffect(() => {\n if (blockerKey !== \"\") {\n router.getBlocker(blockerKey, blockerFunction);\n }\n }, [router, blockerKey, blockerFunction]);\n return blockerKey && state.blockers.has(blockerKey) ? state.blockers.get(blockerKey) : IDLE_BLOCKER;\n}\nfunction useNavigateStable() {\n let { router } = useDataRouterContext(\"useNavigate\" /* UseNavigateStable */);\n let id = useCurrentRouteId(\"useNavigate\" /* UseNavigateStable */);\n let activeRef = React2.useRef(false);\n useIsomorphicLayoutEffect(() => {\n activeRef.current = true;\n });\n let navigate = React2.useCallback(\n async (to, options = {}) => {\n warning(activeRef.current, navigateEffectWarning);\n if (!activeRef.current) return;\n if (typeof to === \"number\") {\n await router.navigate(to);\n } else {\n await router.navigate(to, { fromRouteId: id, ...options });\n }\n },\n [router, id]\n );\n return navigate;\n}\nvar alreadyWarned = {};\nfunction warningOnce(key, cond, message) {\n if (!cond && !alreadyWarned[key]) {\n alreadyWarned[key] = true;\n warning(false, message);\n }\n}\nfunction useRoute(...args) {\n const currentRouteId = useCurrentRouteId(\n \"useRoute\" /* UseRoute */\n );\n const id = args[0] ?? currentRouteId;\n const state = useDataRouterState(\"useRoute\" /* UseRoute */);\n const route = state.matches.find(({ route: route2 }) => route2.id === id);\n if (route === void 0) return void 0;\n return {\n handle: route.route.handle,\n loaderData: state.loaderData[id],\n actionData: state.actionData?.[id]\n };\n}\n\n// lib/components.tsx\nimport * as React3 from \"react\";\n\n// lib/server-runtime/warnings.ts\nvar alreadyWarned2 = {};\nfunction warnOnce(condition, message) {\n if (!condition && !alreadyWarned2[message]) {\n alreadyWarned2[message] = true;\n console.warn(message);\n }\n}\n\n// lib/components.tsx\nvar USE_OPTIMISTIC = \"useOptimistic\";\nvar useOptimisticImpl = React3[USE_OPTIMISTIC];\nvar stableUseOptimisticSetter = () => void 0;\nfunction useOptimisticSafe(val) {\n if (useOptimisticImpl) {\n return useOptimisticImpl(val);\n } else {\n return [val, stableUseOptimisticSetter];\n }\n}\nfunction mapRouteProperties(route) {\n let updates = {\n // Note: this check also occurs in createRoutesFromChildren so update\n // there if you change this -- please and thank you!\n hasErrorBoundary: route.hasErrorBoundary || route.ErrorBoundary != null || route.errorElement != null\n };\n if (route.Component) {\n if (ENABLE_DEV_WARNINGS) {\n if (route.element) {\n warning(\n false,\n \"You should not include both `Component` and `element` on your route - `Component` will be used.\"\n );\n }\n }\n Object.assign(updates, {\n element: React3.createElement(route.Component),\n Component: void 0\n });\n }\n if (route.HydrateFallback) {\n if (ENABLE_DEV_WARNINGS) {\n if (route.hydrateFallbackElement) {\n warning(\n false,\n \"You should not include both `HydrateFallback` and `hydrateFallbackElement` on your route - `HydrateFallback` will be used.\"\n );\n }\n }\n Object.assign(updates, {\n hydrateFallbackElement: React3.createElement(route.HydrateFallback),\n HydrateFallback: void 0\n });\n }\n if (route.ErrorBoundary) {\n if (ENABLE_DEV_WARNINGS) {\n if (route.errorElement) {\n warning(\n false,\n \"You should not include both `ErrorBoundary` and `errorElement` on your route - `ErrorBoundary` will be used.\"\n );\n }\n }\n Object.assign(updates, {\n errorElement: React3.createElement(route.ErrorBoundary),\n ErrorBoundary: void 0\n });\n }\n return updates;\n}\nvar hydrationRouteProperties = [\n \"HydrateFallback\",\n \"hydrateFallbackElement\"\n];\nfunction createMemoryRouter(routes, opts) {\n return createRouter({\n basename: opts?.basename,\n getContext: opts?.getContext,\n future: opts?.future,\n history: createMemoryHistory({\n initialEntries: opts?.initialEntries,\n initialIndex: opts?.initialIndex\n }),\n hydrationData: opts?.hydrationData,\n routes,\n hydrationRouteProperties,\n mapRouteProperties,\n dataStrategy: opts?.dataStrategy,\n patchRoutesOnNavigation: opts?.patchRoutesOnNavigation,\n unstable_instrumentations: opts?.unstable_instrumentations\n }).initialize();\n}\nvar Deferred = class {\n constructor() {\n this.status = \"pending\";\n this.promise = new Promise((resolve, reject) => {\n this.resolve = (value) => {\n if (this.status === \"pending\") {\n this.status = \"resolved\";\n resolve(value);\n }\n };\n this.reject = (reason) => {\n if (this.status === \"pending\") {\n this.status = \"rejected\";\n reject(reason);\n }\n };\n });\n }\n};\nfunction RouterProvider({\n router,\n flushSync: reactDomFlushSyncImpl,\n onError,\n unstable_useTransitions\n}) {\n let unstable_rsc = useIsRSCRouterContext();\n unstable_useTransitions = unstable_rsc || unstable_useTransitions;\n let [_state, setStateImpl] = React3.useState(router.state);\n let [state, setOptimisticState] = useOptimisticSafe(_state);\n let [pendingState, setPendingState] = React3.useState();\n let [vtContext, setVtContext] = React3.useState({\n isTransitioning: false\n });\n let [renderDfd, setRenderDfd] = React3.useState();\n let [transition, setTransition] = React3.useState();\n let [interruption, setInterruption] = React3.useState();\n let fetcherData = React3.useRef(/* @__PURE__ */ new Map());\n let setState = React3.useCallback(\n (newState, { deletedFetchers, newErrors, flushSync, viewTransitionOpts }) => {\n if (newErrors && onError) {\n Object.values(newErrors).forEach(\n (error) => onError(error, {\n location: newState.location,\n params: newState.matches[0]?.params ?? {},\n unstable_pattern: getRoutePattern(newState.matches)\n })\n );\n }\n newState.fetchers.forEach((fetcher, key) => {\n if (fetcher.data !== void 0) {\n fetcherData.current.set(key, fetcher.data);\n }\n });\n deletedFetchers.forEach((key) => fetcherData.current.delete(key));\n warnOnce(\n flushSync === false || reactDomFlushSyncImpl != null,\n 'You provided the `flushSync` option to a router update, but you are not using the `<RouterProvider>` from `react-router/dom` so `ReactDOM.flushSync()` is unavailable. Please update your app to `import { RouterProvider } from \"react-router/dom\"` and ensure you have `react-dom` installed as a dependency to use the `flushSync` option.'\n );\n let isViewTransitionAvailable = router.window != null && router.window.document != null && typeof router.window.document.startViewTransition === \"function\";\n warnOnce(\n viewTransitionOpts == null || isViewTransitionAvailable,\n \"You provided the `viewTransition` option to a router update, but you do not appear to be running in a DOM environment as `window.startViewTransition` is not available.\"\n );\n if (!viewTransitionOpts || !isViewTransitionAvailable) {\n if (reactDomFlushSyncImpl && flushSync) {\n reactDomFlushSyncImpl(() => setStateImpl(newState));\n } else if (unstable_useTransitions === false) {\n setStateImpl(newState);\n } else {\n React3.startTransition(() => {\n if (unstable_useTransitions === true) {\n setOptimisticState((s) => getOptimisticRouterState(s, newState));\n }\n setStateImpl(newState);\n });\n }\n return;\n }\n if (reactDomFlushSyncImpl && flushSync) {\n reactDomFlushSyncImpl(() => {\n if (transition) {\n renderDfd?.resolve();\n transition.skipTransition();\n }\n setVtContext({\n isTransitioning: true,\n flushSync: true,\n currentLocation: viewTransitionOpts.currentLocation,\n nextLocation: viewTransitionOpts.nextLocation\n });\n });\n let t = router.window.document.startViewTransition(() => {\n reactDomFlushSyncImpl(() => setStateImpl(newState));\n });\n t.finished.finally(() => {\n reactDomFlushSyncImpl(() => {\n setRenderDfd(void 0);\n setTransition(void 0);\n setPendingState(void 0);\n setVtContext({ isTransitioning: false });\n });\n });\n reactDomFlushSyncImpl(() => setTransition(t));\n return;\n }\n if (transition) {\n renderDfd?.resolve();\n transition.skipTransition();\n setInterruption({\n state: newState,\n currentLocation: viewTransitionOpts.currentLocation,\n nextLocation: viewTransitionOpts.nextLocation\n });\n } else {\n setPendingState(newState);\n setVtContext({\n isTransitioning: true,\n flushSync: false,\n currentLocation: viewTransitionOpts.currentLocation,\n nextLocation: viewTransitionOpts.nextLocation\n });\n }\n },\n [\n router.window,\n reactDomFlushSyncImpl,\n transition,\n renderDfd,\n unstable_useTransitions,\n setOptimisticState,\n onError\n ]\n );\n React3.useLayoutEffect(() => router.subscribe(setState), [router, setState]);\n let initialized = state.initialized;\n React3.useLayoutEffect(() => {\n if (!initialized && router.state.initialized) {\n setState(router.state, {\n deletedFetchers: [],\n flushSync: false,\n newErrors: null\n });\n }\n }, [initialized, setState, router.state]);\n React3.useEffect(() => {\n if (vtContext.isTransitioning && !vtContext.flushSync) {\n setRenderDfd(new Deferred());\n }\n }, [vtContext]);\n React3.useEffect(() => {\n if (renderDfd && pendingState && router.window) {\n let newState = pendingState;\n let renderPromise = renderDfd.promise;\n let transition2 = router.window.document.startViewTransition(async () => {\n if (unstable_useTransitions === false) {\n setStateImpl(newState);\n } else {\n React3.startTransition(() => {\n if (unstable_useTransitions === true) {\n setOptimisticState((s) => getOptimisticRouterState(s, newState));\n }\n setStateImpl(newState);\n });\n }\n await renderPromise;\n });\n transition2.finished.finally(() => {\n setRenderDfd(void 0);\n setTransition(void 0);\n setPendingState(void 0);\n setVtContext({ isTransitioning: false });\n });\n setTransition(transition2);\n }\n }, [\n pendingState,\n renderDfd,\n router.window,\n unstable_useTransitions,\n setOptimisticState\n ]);\n React3.useEffect(() => {\n if (renderDfd && pendingState && state.location.key === pendingState.location.key) {\n renderDfd.resolve();\n }\n }, [renderDfd, transition, state.location, pendingState]);\n React3.useEffect(() => {\n if (!vtContext.isTransitioning && interruption) {\n setPendingState(interruption.state);\n setVtContext({\n isTransitioning: true,\n flushSync: false,\n currentLocation: interruption.currentLocation,\n nextLocation: interruption.nextLocation\n });\n setInterruption(void 0);\n }\n }, [vtContext.isTransitioning, interruption]);\n let navigator = React3.useMemo(() => {\n return {\n createHref: router.createHref,\n encodeLocation: router.encodeLocation,\n go: (n) => router.navigate(n),\n push: (to, state2, opts) => router.navigate(to, {\n state: state2,\n preventScrollReset: opts?.preventScrollReset\n }),\n replace: (to, state2, opts) => router.navigate(to, {\n replace: true,\n state: state2,\n preventScrollReset: opts?.preventScrollReset\n })\n };\n }, [router]);\n let basename = router.basename || \"/\";\n let dataRouterContext = React3.useMemo(\n () => ({\n router,\n navigator,\n static: false,\n basename,\n onError\n }),\n [router, navigator, basename, onError]\n );\n return /* @__PURE__ */ React3.createElement(React3.Fragment, null, /* @__PURE__ */ React3.createElement(DataRouterContext.Provider, { value: dataRouterContext }, /* @__PURE__ */ React3.createElement(DataRouterStateContext.Provider, { value: state }, /* @__PURE__ */ React3.createElement(FetchersContext.Provider, { value: fetcherData.current }, /* @__PURE__ */ React3.createElement(ViewTransitionContext.Provider, { value: vtContext }, /* @__PURE__ */ React3.createElement(\n Router,\n {\n basename,\n location: state.location,\n navigationType: state.historyAction,\n navigator,\n unstable_useTransitions\n },\n /* @__PURE__ */ React3.createElement(\n MemoizedDataRoutes,\n {\n routes: router.routes,\n future: router.future,\n state,\n isStatic: false,\n onError\n }\n )\n ))))), null);\n}\nfunction getOptimisticRouterState(currentState, newState) {\n return {\n // Don't surface \"current location specific\" stuff mid-navigation\n // (historyAction, location, matches, loaderData, errors, initialized,\n // restoreScroll, preventScrollReset, blockers, etc.)\n ...currentState,\n // Only surface \"pending/in-flight stuff\"\n // (navigation, revalidation, actionData, fetchers, )\n navigation: newState.navigation.state !== \"idle\" ? newState.navigation : currentState.navigation,\n revalidation: newState.revalidation !== \"idle\" ? newState.revalidation : currentState.revalidation,\n actionData: newState.navigation.state !== \"submitting\" ? newState.actionData : currentState.actionData,\n fetchers: newState.fetchers\n };\n}\nvar MemoizedDataRoutes = React3.memo(DataRoutes);\nfunction DataRoutes({\n routes,\n future,\n state,\n isStatic,\n onError\n}) {\n return useRoutesImpl(routes, void 0, { state, isStatic, onError, future });\n}\nfunction MemoryRouter({\n basename,\n children,\n initialEntries,\n initialIndex,\n unstable_useTransitions\n}) {\n let historyRef = React3.useRef();\n if (historyRef.current == null) {\n historyRef.current = createMemoryHistory({\n initialEntries,\n initialIndex,\n v5Compat: true\n });\n }\n let history = historyRef.current;\n let [state, setStateImpl] = React3.useState({\n action: history.action,\n location: history.location\n });\n let setState = React3.useCallback(\n (newState) => {\n if (unstable_useTransitions === false) {\n setStateImpl(newState);\n } else {\n React3.startTransition(() => setStateImpl(newState));\n }\n },\n [unstable_useTransitions]\n );\n React3.useLayoutEffect(() => history.listen(setState), [history, setState]);\n return /* @__PURE__ */ React3.createElement(\n Router,\n {\n basename,\n children,\n location: state.location,\n navigationType: state.action,\n navigator: history,\n unstable_useTransitions\n }\n );\n}\nfunction Navigate({\n to,\n replace: replace2,\n state,\n relative\n}) {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of\n // the router loaded. We can help them understand how to avoid that.\n `<Navigate> may be used only in the context of a <Router> component.`\n );\n let { static: isStatic } = React3.useContext(NavigationContext);\n warning(\n !isStatic,\n `<Navigate> must not be used on the initial render in a <StaticRouter>. This is a no-op, but you should modify your code so the <Navigate> is only ever rendered in response to some user interaction or state change.`\n );\n let { matches } = React3.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n let navigate = useNavigate();\n let path = resolveTo(\n to,\n getResolveToMatches(matches),\n locationPathname,\n relative === \"path\"\n );\n let jsonPath = JSON.stringify(path);\n React3.useEffect(() => {\n navigate(JSON.parse(jsonPath), { replace: replace2, state, relative });\n }, [navigate, jsonPath, relative, replace2, state]);\n return null;\n}\nfunction Outlet(props) {\n return useOutlet(props.context);\n}\nfunction Route(props) {\n invariant(\n false,\n `A <Route> is only ever to be used as the child of <Routes> element, never rendered directly. Please wrap your <Route> in a <Routes>.`\n );\n}\nfunction Router({\n basename: basenameProp = \"/\",\n children = null,\n location: locationProp,\n navigationType = \"POP\" /* Pop */,\n navigator,\n static: staticProp = false,\n unstable_useTransitions\n}) {\n invariant(\n !useInRouterContext(),\n `You cannot render a <Router> inside another <Router>. You should never have more than one in your app.`\n );\n let basename = basenameProp.replace(/^\\/*/, \"/\");\n let navigationContext = React3.useMemo(\n () => ({\n basename,\n navigator,\n static: staticProp,\n unstable_useTransitions,\n future: {}\n }),\n [basename, navigator, staticProp, unstable_useTransitions]\n );\n if (typeof locationProp === \"string\") {\n locationProp = parsePath(locationProp);\n }\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n state = null,\n key = \"default\",\n unstable_mask\n } = locationProp;\n let locationContext = React3.useMemo(() => {\n let trailingPathname = stripBasename(pathname, basename);\n if (trailingPathname == null) {\n return null;\n }\n return {\n location: {\n pathname: trailingPathname,\n search,\n hash,\n state,\n key,\n unstable_mask\n },\n navigationType\n };\n }, [\n basename,\n pathname,\n search,\n hash,\n state,\n key,\n navigationType,\n unstable_mask\n ]);\n warning(\n locationContext != null,\n `<Router basename=\"${basename}\"> is not able to match the URL \"${pathname}${search}${hash}\" because it does not start with the basename, so the <Router> won't render anything.`\n );\n if (locationContext == null) {\n return null;\n }\n return /* @__PURE__ */ React3.createElement(NavigationContext.Provider, { value: navigationContext }, /* @__PURE__ */ React3.createElement(LocationContext.Provider, { children, value: locationContext }));\n}\nfunction Routes({\n children,\n location\n}) {\n return useRoutes(createRoutesFromChildren(children), location);\n}\nfunction Await({\n children,\n errorElement,\n resolve\n}) {\n let dataRouterContext = React3.useContext(DataRouterContext);\n let dataRouterStateContext = React3.useContext(DataRouterStateContext);\n let onError = React3.useCallback(\n (error, errorInfo) => {\n if (dataRouterContext && dataRouterContext.onError && dataRouterStateContext) {\n dataRouterContext.onError(error, {\n location: dataRouterStateContext.location,\n params: dataRouterStateContext.matches[0]?.params || {},\n unstable_pattern: getRoutePattern(dataRouterStateContext.matches),\n errorInfo\n });\n }\n },\n [dataRouterContext, dataRouterStateContext]\n );\n return /* @__PURE__ */ React3.createElement(\n AwaitErrorBoundary,\n {\n resolve,\n errorElement,\n onError\n },\n /* @__PURE__ */ React3.createElement(ResolveAwait, null, children)\n );\n}\nvar AwaitErrorBoundary = class extends React3.Component {\n constructor(props) {\n super(props);\n this.state = { error: null };\n }\n static getDerivedStateFromError(error) {\n return { error };\n }\n componentDidCatch(error, errorInfo) {\n if (this.props.onError) {\n this.props.onError(error, errorInfo);\n } else {\n console.error(\n \"<Await> caught the following error during render\",\n error,\n errorInfo\n );\n }\n }\n render() {\n let { children, errorElement, resolve } = this.props;\n let promise = null;\n let status = 0 /* pending */;\n if (!(resolve instanceof Promise)) {\n status = 1 /* success */;\n promise = Promise.resolve();\n Object.defineProperty(promise, \"_tracked\", { get: () => true });\n Object.defineProperty(promise, \"_data\", { get: () => resolve });\n } else if (this.state.error) {\n status = 2 /* error */;\n let renderError = this.state.error;\n promise = Promise.reject().catch(() => {\n });\n Object.defineProperty(promise, \"_tracked\", { get: () => true });\n Object.defineProperty(promise, \"_error\", { get: () => renderError });\n } else if (resolve._tracked) {\n promise = resolve;\n status = \"_error\" in promise ? 2 /* error */ : \"_data\" in promise ? 1 /* success */ : 0 /* pending */;\n } else {\n status = 0 /* pending */;\n Object.defineProperty(resolve, \"_tracked\", { get: () => true });\n promise = resolve.then(\n (data2) => Object.defineProperty(resolve, \"_data\", { get: () => data2 }),\n (error) => {\n this.props.onError?.(error);\n Object.defineProperty(resolve, \"_error\", { get: () => error });\n }\n );\n }\n if (status === 2 /* error */ && !errorElement) {\n throw promise._error;\n }\n if (status === 2 /* error */) {\n return /* @__PURE__ */ React3.createElement(AwaitContext.Provider, { value: promise, children: errorElement });\n }\n if (status === 1 /* success */) {\n return /* @__PURE__ */ React3.createElement(AwaitContext.Provider, { value: promise, children });\n }\n throw promise;\n }\n};\nfunction ResolveAwait({\n children\n}) {\n let data2 = useAsyncValue();\n let toRender = typeof children === \"function\" ? children(data2) : children;\n return /* @__PURE__ */ React3.createElement(React3.Fragment, null, toRender);\n}\nfunction createRoutesFromChildren(children, parentPath = []) {\n let routes = [];\n React3.Children.forEach(children, (element, index) => {\n if (!React3.isValidElement(element)) {\n return;\n }\n let treePath = [...parentPath, index];\n if (element.type === React3.Fragment) {\n routes.push.apply(\n routes,\n createRoutesFromChildren(element.props.children, treePath)\n );\n return;\n }\n invariant(\n element.type === Route,\n `[${typeof element.type === \"string\" ? element.type : element.type.name}] is not a <Route> component. All component children of <Routes> must be a <Route> or <React.Fragment>`\n );\n invariant(\n !element.props.index || !element.props.children,\n \"An index route cannot have child routes.\"\n );\n let route = {\n id: element.props.id || treePath.join(\"-\"),\n caseSensitive: element.props.caseSensitive,\n element: element.props.element,\n Component: element.props.Component,\n index: element.props.index,\n path: element.props.path,\n middleware: element.props.middleware,\n loader: element.props.loader,\n action: element.props.action,\n hydrateFallbackElement: element.props.hydrateFallbackElement,\n HydrateFallback: element.props.HydrateFallback,\n errorElement: element.props.errorElement,\n ErrorBoundary: element.props.ErrorBoundary,\n hasErrorBoundary: element.props.hasErrorBoundary === true || element.props.ErrorBoundary != null || element.props.errorElement != null,\n shouldRevalidate: element.props.shouldRevalidate,\n handle: element.props.handle,\n lazy: element.props.lazy\n };\n if (element.props.children) {\n route.children = createRoutesFromChildren(\n element.props.children,\n treePath\n );\n }\n routes.push(route);\n });\n return routes;\n}\nvar createRoutesFromElements = createRoutesFromChildren;\nfunction renderMatches(matches) {\n return _renderMatches(matches);\n}\nfunction useRouteComponentProps() {\n return {\n params: useParams(),\n loaderData: useLoaderData(),\n actionData: useActionData(),\n matches: useMatches()\n };\n}\nfunction WithComponentProps({\n children\n}) {\n const props = useRouteComponentProps();\n return React3.cloneElement(children, props);\n}\nfunction withComponentProps(Component4) {\n return function WithComponentProps2() {\n const props = useRouteComponentProps();\n return React3.createElement(Component4, props);\n };\n}\nfunction useHydrateFallbackProps() {\n return {\n params: useParams(),\n loaderData: useLoaderData(),\n actionData: useActionData()\n };\n}\nfunction WithHydrateFallbackProps({\n children\n}) {\n const props = useHydrateFallbackProps();\n return React3.cloneElement(children, props);\n}\nfunction withHydrateFallbackProps(HydrateFallback) {\n return function WithHydrateFallbackProps2() {\n const props = useHydrateFallbackProps();\n return React3.createElement(HydrateFallback, props);\n };\n}\nfunction useErrorBoundaryProps() {\n return {\n params: useParams(),\n loaderData: useLoaderData(),\n actionData: useActionData(),\n error: useRouteError()\n };\n}\nfunction WithErrorBoundaryProps({\n children\n}) {\n const props = useErrorBoundaryProps();\n return React3.cloneElement(children, props);\n}\nfunction withErrorBoundaryProps(ErrorBoundary) {\n return function WithErrorBoundaryProps2() {\n const props = useErrorBoundaryProps();\n return React3.createElement(ErrorBoundary, props);\n };\n}\n\n// lib/dom/dom.ts\nvar defaultMethod = \"get\";\nvar defaultEncType = \"application/x-www-form-urlencoded\";\nfunction isHtmlElement(object) {\n return typeof HTMLElement !== \"undefined\" && object instanceof HTMLElement;\n}\nfunction isButtonElement(object) {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"button\";\n}\nfunction isFormElement(object) {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"form\";\n}\nfunction isInputElement(object) {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"input\";\n}\nfunction isModifiedEvent(event) {\n return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\nfunction shouldProcessLinkClick(event, target) {\n return event.button === 0 && // Ignore everything but left clicks\n (!target || target === \"_self\") && // Let browser handle \"target=_blank\" etc.\n !isModifiedEvent(event);\n}\nfunction createSearchParams(init = \"\") {\n return new URLSearchParams(\n typeof init === \"string\" || Array.isArray(init) || init instanceof URLSearchParams ? init : Object.keys(init).reduce((memo2, key) => {\n let value = init[key];\n return memo2.concat(\n Array.isArray(value) ? value.map((v) => [key, v]) : [[key, value]]\n );\n }, [])\n );\n}\nfunction getSearchParamsForLocation(locationSearch, defaultSearchParams) {\n let searchParams = createSearchParams(locationSearch);\n if (defaultSearchParams) {\n defaultSearchParams.forEach((_, key) => {\n if (!searchParams.has(key)) {\n defaultSearchParams.getAll(key).forEach((value) => {\n searchParams.append(key, value);\n });\n }\n });\n }\n return searchParams;\n}\nvar _formDataSupportsSubmitter = null;\nfunction isFormDataSubmitterSupported() {\n if (_formDataSupportsSubmitter === null) {\n try {\n new FormData(\n document.createElement(\"form\"),\n // @ts-expect-error if FormData supports the submitter parameter, this will throw\n 0\n );\n _formDataSupportsSubmitter = false;\n } catch (e) {\n _formDataSupportsSubmitter = true;\n }\n }\n return _formDataSupportsSubmitter;\n}\nvar supportedFormEncTypes = /* @__PURE__ */ new Set([\n \"application/x-www-form-urlencoded\",\n \"multipart/form-data\",\n \"text/plain\"\n]);\nfunction getFormEncType(encType) {\n if (encType != null && !supportedFormEncTypes.has(encType)) {\n warning(\n false,\n `\"${encType}\" is not a valid \\`encType\\` for \\`<Form>\\`/\\`<fetcher.Form>\\` and will default to \"${defaultEncType}\"`\n );\n return null;\n }\n return encType;\n}\nfunction getFormSubmissionInfo(target, basename) {\n let method;\n let action;\n let encType;\n let formData;\n let body;\n if (isFormElement(target)) {\n let attr = target.getAttribute(\"action\");\n action = attr ? stripBasename(attr, basename) : null;\n method = target.getAttribute(\"method\") || defaultMethod;\n encType = getFormEncType(target.getAttribute(\"enctype\")) || defaultEncType;\n formData = new FormData(target);\n } else if (isButtonElement(target) || isInputElement(target) && (target.type === \"submit\" || target.type === \"image\")) {\n let form = target.form;\n if (form == null) {\n throw new Error(\n `Cannot submit a <button> or <input type=\"submit\"> without a <form>`\n );\n }\n let attr = target.getAttribute(\"formaction\") || form.getAttribute(\"action\");\n action = attr ? stripBasename(attr, basename) : null;\n method = target.getAttribute(\"formmethod\") || form.getAttribute(\"method\") || defaultMethod;\n encType = getFormEncType(target.getAttribute(\"formenctype\")) || getFormEncType(form.getAttribute(\"enctype\")) || defaultEncType;\n formData = new FormData(form, target);\n if (!isFormDataSubmitterSupported()) {\n let { name, type, value } = target;\n if (type === \"image\") {\n let prefix = name ? `${name}.` : \"\";\n formData.append(`${prefix}x`, \"0\");\n formData.append(`${prefix}y`, \"0\");\n } else if (name) {\n formData.append(name, value);\n }\n }\n } else if (isHtmlElement(target)) {\n throw new Error(\n `Cannot submit element that is not <form>, <button>, or <input type=\"submit|image\">`\n );\n } else {\n method = defaultMethod;\n action = null;\n encType = defaultEncType;\n body = target;\n }\n if (formData && encType === \"text/plain\") {\n body = formData;\n formData = void 0;\n }\n return { action, method: method.toLowerCase(), encType, formData, body };\n}\n\n// lib/dom/ssr/single-fetch.tsx\nimport * as React4 from \"react\";\n\n// vendor/turbo-stream-v2/utils.ts\nvar HOLE = -1;\nvar NAN = -2;\nvar NEGATIVE_INFINITY = -3;\nvar NEGATIVE_ZERO = -4;\nvar NULL = -5;\nvar POSITIVE_INFINITY = -6;\nvar UNDEFINED = -7;\nvar TYPE_BIGINT = \"B\";\nvar TYPE_DATE = \"D\";\nvar TYPE_ERROR = \"E\";\nvar TYPE_MAP = \"M\";\nvar TYPE_NULL_OBJECT = \"N\";\nvar TYPE_PROMISE = \"P\";\nvar TYPE_REGEXP = \"R\";\nvar TYPE_SET = \"S\";\nvar TYPE_SYMBOL = \"Y\";\nvar TYPE_URL = \"U\";\nvar TYPE_PREVIOUS_RESOLVED = \"Z\";\nvar SUPPORTED_ERROR_TYPES = [\n \"EvalError\",\n \"RangeError\",\n \"ReferenceError\",\n \"SyntaxError\",\n \"TypeError\",\n \"URIError\"\n];\nvar Deferred2 = class {\n constructor() {\n this.promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n }\n};\nfunction createLineSplittingTransform() {\n const decoder = new TextDecoder();\n let leftover = \"\";\n return new TransformStream({\n transform(chunk, controller) {\n const str = decoder.decode(chunk, { stream: true });\n const parts = (leftover + str).split(\"\\n\");\n leftover = parts.pop() || \"\";\n for (const part of parts) {\n controller.enqueue(part);\n }\n },\n flush(controller) {\n if (leftover) {\n controller.enqueue(leftover);\n }\n }\n });\n}\n\n// vendor/turbo-stream-v2/flatten.ts\nvar TIME_LIMIT_MS = 1;\nvar getNow = () => Date.now();\nvar yieldToMain = () => new Promise((resolve) => setTimeout(resolve, 0));\nasync function flatten(input) {\n const { indices } = this;\n const existing = indices.get(input);\n if (existing) return [existing];\n if (input === void 0) return UNDEFINED;\n if (input === null) return NULL;\n if (Number.isNaN(input)) return NAN;\n if (input === Number.POSITIVE_INFINITY) return POSITIVE_INFINITY;\n if (input === Number.NEGATIVE_INFINITY) return NEGATIVE_INFINITY;\n if (input === 0 && 1 / input < 0) return NEGATIVE_ZERO;\n const index = this.index++;\n indices.set(input, index);\n const stack = [[input, index]];\n await stringify.call(this, stack);\n return index;\n}\nasync function stringify(stack) {\n const { deferred, indices, plugins, postPlugins } = this;\n const str = this.stringified;\n let lastYieldTime = getNow();\n const flattenValue = (value) => {\n const existing = indices.get(value);\n if (existing) return [existing];\n if (value === void 0) return UNDEFINED;\n if (value === null) return NULL;\n if (Number.isNaN(value)) return NAN;\n if (value === Number.POSITIVE_INFINITY) return POSITIVE_INFINITY;\n if (value === Number.NEGATIVE_INFINITY) return NEGATIVE_INFINITY;\n if (value === 0 && 1 / value < 0) return NEGATIVE_ZERO;\n const index = this.index++;\n indices.set(value, index);\n stack.push([value, index]);\n return index;\n };\n let i = 0;\n while (stack.length > 0) {\n const now = getNow();\n if (++i % 6e3 === 0 && now - lastYieldTime >= TIME_LIMIT_MS) {\n await yieldToMain();\n lastYieldTime = getNow();\n }\n const [input, index] = stack.pop();\n const partsForObj = (obj) => Object.keys(obj).map((k) => `\"_${flattenValue(k)}\":${flattenValue(obj[k])}`).join(\",\");\n let error = null;\n switch (typeof input) {\n case \"boolean\":\n case \"number\":\n case \"string\":\n str[index] = JSON.stringify(input);\n break;\n case \"bigint\":\n str[index] = `[\"${TYPE_BIGINT}\",\"${input}\"]`;\n break;\n case \"symbol\": {\n const keyFor = Symbol.keyFor(input);\n if (!keyFor) {\n error = new Error(\n \"Cannot encode symbol unless created with Symbol.for()\"\n );\n } else {\n str[index] = `[\"${TYPE_SYMBOL}\",${JSON.stringify(keyFor)}]`;\n }\n break;\n }\n case \"object\": {\n if (!input) {\n str[index] = `${NULL}`;\n break;\n }\n const isArray = Array.isArray(input);\n let pluginHandled = false;\n if (!isArray && plugins) {\n for (const plugin of plugins) {\n const pluginResult = plugin(input);\n if (Array.isArray(pluginResult)) {\n pluginHandled = true;\n const [pluginIdentifier, ...rest] = pluginResult;\n str[index] = `[${JSON.stringify(pluginIdentifier)}`;\n if (rest.length > 0) {\n str[index] += `,${rest.map((v) => flattenValue(v)).join(\",\")}`;\n }\n str[index] += \"]\";\n break;\n }\n }\n }\n if (!pluginHandled) {\n let result = isArray ? \"[\" : \"{\";\n if (isArray) {\n for (let i2 = 0; i2 < input.length; i2++)\n result += (i2 ? \",\" : \"\") + (i2 in input ? flattenValue(input[i2]) : HOLE);\n str[index] = `${result}]`;\n } else if (input instanceof Date) {\n const dateTime = input.getTime();\n str[index] = `[\"${TYPE_DATE}\",${Number.isNaN(dateTime) ? JSON.stringify(\"invalid\") : dateTime}]`;\n } else if (input instanceof URL) {\n str[index] = `[\"${TYPE_URL}\",${JSON.stringify(input.href)}]`;\n } else if (input instanceof RegExp) {\n str[index] = `[\"${TYPE_REGEXP}\",${JSON.stringify(\n input.source\n )},${JSON.stringify(input.flags)}]`;\n } else if (input instanceof Set) {\n if (input.size > 0) {\n str[index] = `[\"${TYPE_SET}\",${[...input].map((val) => flattenValue(val)).join(\",\")}]`;\n } else {\n str[index] = `[\"${TYPE_SET}\"]`;\n }\n } else if (input instanceof Map) {\n if (input.size > 0) {\n str[index] = `[\"${TYPE_MAP}\",${[...input].flatMap(([k, v]) => [flattenValue(k), flattenValue(v)]).join(\",\")}]`;\n } else {\n str[index] = `[\"${TYPE_MAP}\"]`;\n }\n } else if (input instanceof Promise) {\n str[index] = `[\"${TYPE_PROMISE}\",${index}]`;\n deferred[index] = input;\n } else if (input instanceof Error) {\n str[index] = `[\"${TYPE_ERROR}\",${JSON.stringify(input.message)}`;\n if (input.name !== \"Error\") {\n str[index] += `,${JSON.stringify(input.name)}`;\n }\n str[index] += \"]\";\n } else if (Object.getPrototypeOf(input) === null) {\n str[index] = `[\"${TYPE_NULL_OBJECT}\",{${partsForObj(input)}}]`;\n } else if (isPlainObject2(input)) {\n str[index] = `{${partsForObj(input)}}`;\n } else {\n error = new Error(\"Cannot encode object with prototype\");\n }\n }\n break;\n }\n default: {\n const isArray = Array.isArray(input);\n let pluginHandled = false;\n if (!isArray && plugins) {\n for (const plugin of plugins) {\n const pluginResult = plugin(input);\n if (Array.isArray(pluginResult)) {\n pluginHandled = true;\n const [pluginIdentifier, ...rest] = pluginResult;\n str[index] = `[${JSON.stringify(pluginIdentifier)}`;\n if (rest.length > 0) {\n str[index] += `,${rest.map((v) => flattenValue(v)).join(\",\")}`;\n }\n str[index] += \"]\";\n break;\n }\n }\n }\n if (!pluginHandled) {\n error = new Error(\"Cannot encode function or unexpected type\");\n }\n }\n }\n if (error) {\n let pluginHandled = false;\n if (postPlugins) {\n for (const plugin of postPlugins) {\n const pluginResult = plugin(input);\n if (Array.isArray(pluginResult)) {\n pluginHandled = true;\n const [pluginIdentifier, ...rest] = pluginResult;\n str[index] = `[${JSON.stringify(pluginIdentifier)}`;\n if (rest.length > 0) {\n str[index] += `,${rest.map((v) => flattenValue(v)).join(\",\")}`;\n }\n str[index] += \"]\";\n break;\n }\n }\n }\n if (!pluginHandled) {\n throw error;\n }\n }\n }\n}\nvar objectProtoNames2 = Object.getOwnPropertyNames(Object.prototype).sort().join(\"\\0\");\nfunction isPlainObject2(thing) {\n const proto = Object.getPrototypeOf(thing);\n return proto === Object.prototype || proto === null || Object.getOwnPropertyNames(proto).sort().join(\"\\0\") === objectProtoNames2;\n}\n\n// vendor/turbo-stream-v2/unflatten.ts\nvar globalObj = typeof window !== \"undefined\" ? window : typeof globalThis !== \"undefined\" ? globalThis : void 0;\nfunction unflatten(parsed) {\n const { hydrated, values } = this;\n if (typeof parsed === \"number\") return hydrate.call(this, parsed);\n if (!Array.isArray(parsed) || !parsed.length) throw new SyntaxError();\n const startIndex = values.length;\n for (const value of parsed) {\n values.push(value);\n }\n hydrated.length = values.length;\n return hydrate.call(this, startIndex);\n}\nfunction hydrate(index) {\n const { hydrated, values, deferred, plugins } = this;\n let result;\n const stack = [\n [\n index,\n (v) => {\n result = v;\n }\n ]\n ];\n let postRun = [];\n while (stack.length > 0) {\n const [index2, set] = stack.pop();\n switch (index2) {\n case UNDEFINED:\n set(void 0);\n continue;\n case NULL:\n set(null);\n continue;\n case NAN:\n set(NaN);\n continue;\n case POSITIVE_INFINITY:\n set(Infinity);\n continue;\n case NEGATIVE_INFINITY:\n set(-Infinity);\n continue;\n case NEGATIVE_ZERO:\n set(-0);\n continue;\n }\n if (hydrated[index2]) {\n set(hydrated[index2]);\n continue;\n }\n const value = values[index2];\n if (!value || typeof value !== \"object\") {\n hydrated[index2] = value;\n set(value);\n continue;\n }\n if (Array.isArray(value)) {\n if (typeof value[0] === \"string\") {\n const [type, b, c] = value;\n switch (type) {\n case TYPE_DATE:\n set(hydrated[index2] = new Date(b));\n continue;\n case TYPE_URL:\n set(hydrated[index2] = new URL(b));\n continue;\n case TYPE_BIGINT:\n set(hydrated[index2] = BigInt(b));\n continue;\n case TYPE_REGEXP:\n set(hydrated[index2] = new RegExp(b, c));\n continue;\n case TYPE_SYMBOL:\n set(hydrated[index2] = Symbol.for(b));\n continue;\n case TYPE_SET:\n const newSet = /* @__PURE__ */ new Set();\n hydrated[index2] = newSet;\n for (let i = value.length - 1; i > 0; i--)\n stack.push([\n value[i],\n (v) => {\n newSet.add(v);\n }\n ]);\n set(newSet);\n continue;\n case TYPE_MAP:\n const map = /* @__PURE__ */ new Map();\n hydrated[index2] = map;\n for (let i = value.length - 2; i > 0; i -= 2) {\n const r = [];\n stack.push([\n value[i + 1],\n (v) => {\n r[1] = v;\n }\n ]);\n stack.push([\n value[i],\n (k) => {\n r[0] = k;\n }\n ]);\n postRun.push(() => {\n map.set(r[0], r[1]);\n });\n }\n set(map);\n continue;\n case TYPE_NULL_OBJECT:\n const obj = /* @__PURE__ */ Object.create(null);\n hydrated[index2] = obj;\n for (const key of Object.keys(b).reverse()) {\n const r = [];\n stack.push([\n b[key],\n (v) => {\n r[1] = v;\n }\n ]);\n stack.push([\n Number(key.slice(1)),\n (k) => {\n r[0] = k;\n }\n ]);\n postRun.push(() => {\n obj[r[0]] = r[1];\n });\n }\n set(obj);\n continue;\n case TYPE_PROMISE:\n if (hydrated[b]) {\n set(hydrated[index2] = hydrated[b]);\n } else {\n const d = new Deferred2();\n deferred[b] = d;\n set(hydrated[index2] = d.promise);\n }\n continue;\n case TYPE_ERROR:\n const [, message, errorType] = value;\n let error = errorType && globalObj && SUPPORTED_ERROR_TYPES.includes(errorType) && errorType in globalObj && typeof globalObj[errorType] === \"function\" ? new globalObj[errorType](message) : new Error(message);\n hydrated[index2] = error;\n set(error);\n continue;\n case TYPE_PREVIOUS_RESOLVED:\n set(hydrated[index2] = hydrated[b]);\n continue;\n default:\n if (Array.isArray(plugins)) {\n const r = [];\n const vals = value.slice(1);\n for (let i = 0; i < vals.length; i++) {\n const v = vals[i];\n stack.push([\n v,\n (v2) => {\n r[i] = v2;\n }\n ]);\n }\n postRun.push(() => {\n for (const plugin of plugins) {\n const result2 = plugin(value[0], ...r);\n if (result2) {\n set(hydrated[index2] = result2.value);\n return;\n }\n }\n throw new SyntaxError();\n });\n continue;\n }\n throw new SyntaxError();\n }\n } else {\n const array = [];\n hydrated[index2] = array;\n for (let i = 0; i < value.length; i++) {\n const n = value[i];\n if (n !== HOLE) {\n stack.push([\n n,\n (v) => {\n array[i] = v;\n }\n ]);\n }\n }\n set(array);\n continue;\n }\n } else {\n const object = {};\n hydrated[index2] = object;\n for (const key of Object.keys(value).reverse()) {\n const r = [];\n stack.push([\n value[key],\n (v) => {\n r[1] = v;\n }\n ]);\n stack.push([\n Number(key.slice(1)),\n (k) => {\n r[0] = k;\n }\n ]);\n postRun.push(() => {\n object[r[0]] = r[1];\n });\n }\n set(object);\n continue;\n }\n }\n while (postRun.length > 0) {\n postRun.pop()();\n }\n return result;\n}\n\n// vendor/turbo-stream-v2/turbo-stream.ts\nasync function decode(readable, options) {\n const { plugins } = options ?? {};\n const done = new Deferred2();\n const reader = readable.pipeThrough(createLineSplittingTransform()).getReader();\n const decoder = {\n values: [],\n hydrated: [],\n deferred: {},\n plugins\n };\n const decoded = await decodeInitial.call(decoder, reader);\n let donePromise = done.promise;\n if (decoded.done) {\n done.resolve();\n } else {\n donePromise = decodeDeferred.call(decoder, reader).then(done.resolve).catch((reason) => {\n for (const deferred of Object.values(decoder.deferred)) {\n deferred.reject(reason);\n }\n done.reject(reason);\n });\n }\n return {\n done: donePromise.then(() => reader.closed),\n value: decoded.value\n };\n}\nasync function decodeInitial(reader) {\n const read = await reader.read();\n if (!read.value) {\n throw new SyntaxError();\n }\n let line;\n try {\n line = JSON.parse(read.value);\n } catch (reason) {\n throw new SyntaxError();\n }\n return {\n done: read.done,\n value: unflatten.call(this, line)\n };\n}\nasync function decodeDeferred(reader) {\n let read = await reader.read();\n while (!read.done) {\n if (!read.value) continue;\n const line = read.value;\n switch (line[0]) {\n case TYPE_PROMISE: {\n const colonIndex = line.indexOf(\":\");\n const deferredId = Number(line.slice(1, colonIndex));\n const deferred = this.deferred[deferredId];\n if (!deferred) {\n throw new Error(`Deferred ID ${deferredId} not found in stream`);\n }\n const lineData = line.slice(colonIndex + 1);\n let jsonLine;\n try {\n jsonLine = JSON.parse(lineData);\n } catch (reason) {\n throw new SyntaxError();\n }\n const value = unflatten.call(this, jsonLine);\n deferred.resolve(value);\n break;\n }\n case TYPE_ERROR: {\n const colonIndex = line.indexOf(\":\");\n const deferredId = Number(line.slice(1, colonIndex));\n const deferred = this.deferred[deferredId];\n if (!deferred) {\n throw new Error(`Deferred ID ${deferredId} not found in stream`);\n }\n const lineData = line.slice(colonIndex + 1);\n let jsonLine;\n try {\n jsonLine = JSON.parse(lineData);\n } catch (reason) {\n throw new SyntaxError();\n }\n const value = unflatten.call(this, jsonLine);\n deferred.reject(value);\n break;\n }\n default:\n throw new SyntaxError();\n }\n read = await reader.read();\n }\n}\nfunction encode(input, options) {\n const { onComplete, plugins, postPlugins, signal } = options ?? {};\n const encoder = {\n deferred: {},\n index: 0,\n indices: /* @__PURE__ */ new Map(),\n stringified: [],\n plugins,\n postPlugins,\n signal\n };\n const textEncoder = new TextEncoder();\n let lastSentIndex = 0;\n const readable = new ReadableStream({\n async start(controller) {\n const id = await flatten.call(encoder, input);\n if (Array.isArray(id)) {\n throw new Error(\"This should never happen\");\n }\n if (id < 0) {\n controller.enqueue(textEncoder.encode(`${id}\n`));\n } else {\n controller.enqueue(\n textEncoder.encode(`[${encoder.stringified.join(\",\")}]\n`)\n );\n lastSentIndex = encoder.stringified.length - 1;\n }\n const seenPromises = /* @__PURE__ */ new WeakSet();\n let processingChain = Promise.resolve();\n if (Object.keys(encoder.deferred).length) {\n let raceDone;\n const racePromise = new Promise((resolve, reject) => {\n raceDone = resolve;\n if (signal) {\n const rejectPromise = () => reject(signal.reason || new Error(\"Signal was aborted.\"));\n if (signal.aborted) {\n rejectPromise();\n } else {\n signal.addEventListener(\"abort\", (event) => {\n rejectPromise();\n });\n }\n }\n });\n while (Object.keys(encoder.deferred).length > 0) {\n for (const [deferredId, deferred] of Object.entries(\n encoder.deferred\n )) {\n if (seenPromises.has(deferred)) continue;\n seenPromises.add(\n // biome-ignore lint/suspicious/noAssignInExpressions: <explanation>\n encoder.deferred[Number(deferredId)] = Promise.race([\n racePromise,\n deferred\n ]).then(\n (resolved) => {\n processingChain = processingChain.then(async () => {\n const id2 = await flatten.call(encoder, resolved);\n if (Array.isArray(id2)) {\n controller.enqueue(\n textEncoder.encode(\n `${TYPE_PROMISE}${deferredId}:[[\"${TYPE_PREVIOUS_RESOLVED}\",${id2[0]}]]\n`\n )\n );\n encoder.index++;\n lastSentIndex++;\n } else if (id2 < 0) {\n controller.enqueue(\n textEncoder.encode(\n `${TYPE_PROMISE}${deferredId}:${id2}\n`\n )\n );\n } else {\n const values = encoder.stringified.slice(lastSentIndex + 1).join(\",\");\n controller.enqueue(\n textEncoder.encode(\n `${TYPE_PROMISE}${deferredId}:[${values}]\n`\n )\n );\n lastSentIndex = encoder.stringified.length - 1;\n }\n });\n return processingChain;\n },\n (reason) => {\n processingChain = processingChain.then(async () => {\n if (!reason || typeof reason !== \"object\" || !(reason instanceof Error)) {\n reason = new Error(\"An unknown error occurred\");\n }\n const id2 = await flatten.call(encoder, reason);\n if (Array.isArray(id2)) {\n controller.enqueue(\n textEncoder.encode(\n `${TYPE_ERROR}${deferredId}:[[\"${TYPE_PREVIOUS_RESOLVED}\",${id2[0]}]]\n`\n )\n );\n encoder.index++;\n lastSentIndex++;\n } else if (id2 < 0) {\n controller.enqueue(\n textEncoder.encode(\n `${TYPE_ERROR}${deferredId}:${id2}\n`\n )\n );\n } else {\n const values = encoder.stringified.slice(lastSentIndex + 1).join(\",\");\n controller.enqueue(\n textEncoder.encode(\n `${TYPE_ERROR}${deferredId}:[${values}]\n`\n )\n );\n lastSentIndex = encoder.stringified.length - 1;\n }\n });\n return processingChain;\n }\n ).finally(() => {\n delete encoder.deferred[Number(deferredId)];\n })\n );\n }\n await Promise.race(Object.values(encoder.deferred));\n }\n raceDone();\n }\n await Promise.all(Object.values(encoder.deferred));\n await processingChain;\n controller.close();\n onComplete?.();\n }\n });\n return readable;\n}\n\n// lib/dom/ssr/data.ts\nasync function createRequestInit(request) {\n let init = { signal: request.signal };\n if (request.method !== \"GET\") {\n init.method = request.method;\n let contentType = request.headers.get(\"Content-Type\");\n if (contentType && /\\bapplication\\/json\\b/.test(contentType)) {\n init.headers = { \"Content-Type\": contentType };\n init.body = JSON.stringify(await request.json());\n } else if (contentType && /\\btext\\/plain\\b/.test(contentType)) {\n init.headers = { \"Content-Type\": contentType };\n init.body = await request.text();\n } else if (contentType && /\\bapplication\\/x-www-form-urlencoded\\b/.test(contentType)) {\n init.body = new URLSearchParams(await request.text());\n } else {\n init.body = await request.formData();\n }\n }\n return init;\n}\n\n// lib/dom/ssr/markup.ts\nvar ESCAPE_LOOKUP = {\n \"&\": \"\\\\u0026\",\n \">\": \"\\\\u003e\",\n \"<\": \"\\\\u003c\",\n \"\\u2028\": \"\\\\u2028\",\n \"\\u2029\": \"\\\\u2029\"\n};\nvar ESCAPE_REGEX = /[&><\\u2028\\u2029]/g;\nfunction escapeHtml(html) {\n return html.replace(ESCAPE_REGEX, (match) => ESCAPE_LOOKUP[match]);\n}\n\n// lib/dom/ssr/invariant.ts\nfunction invariant2(value, message) {\n if (value === false || value === null || typeof value === \"undefined\") {\n throw new Error(message);\n }\n}\n\n// lib/dom/ssr/single-fetch.tsx\nvar SingleFetchRedirectSymbol = Symbol(\"SingleFetchRedirect\");\nvar SingleFetchNoResultError = class extends Error {\n};\nvar SINGLE_FETCH_REDIRECT_STATUS = 202;\nvar NO_BODY_STATUS_CODES = /* @__PURE__ */ new Set([100, 101, 204, 205]);\nfunction StreamTransfer({\n context,\n identifier,\n reader,\n textDecoder,\n nonce\n}) {\n if (!context.renderMeta || !context.renderMeta.didRenderScripts) {\n return null;\n }\n if (!context.renderMeta.streamCache) {\n context.renderMeta.streamCache = {};\n }\n let { streamCache } = context.renderMeta;\n let promise = streamCache[identifier];\n if (!promise) {\n promise = streamCache[identifier] = reader.read().then((result) => {\n streamCache[identifier].result = {\n done: result.done,\n value: textDecoder.decode(result.value, { stream: true })\n };\n }).catch((e) => {\n streamCache[identifier].error = e;\n });\n }\n if (promise.error) {\n throw promise.error;\n }\n if (promise.result === void 0) {\n throw promise;\n }\n let { done, value } = promise.result;\n let scriptTag = value ? /* @__PURE__ */ React4.createElement(\n \"script\",\n {\n nonce,\n dangerouslySetInnerHTML: {\n __html: `window.__reactRouterContext.streamController.enqueue(${escapeHtml(\n JSON.stringify(value)\n )});`\n }\n }\n ) : null;\n if (done) {\n return /* @__PURE__ */ React4.createElement(React4.Fragment, null, scriptTag, /* @__PURE__ */ React4.createElement(\n \"script\",\n {\n nonce,\n dangerouslySetInnerHTML: {\n __html: `window.__reactRouterContext.streamController.close();`\n }\n }\n ));\n } else {\n return /* @__PURE__ */ React4.createElement(React4.Fragment, null, scriptTag, /* @__PURE__ */ React4.createElement(React4.Suspense, null, /* @__PURE__ */ React4.createElement(\n StreamTransfer,\n {\n context,\n identifier: identifier + 1,\n reader,\n textDecoder,\n nonce\n }\n )));\n }\n}\nfunction getTurboStreamSingleFetchDataStrategy(getRouter, manifest, routeModules, ssr, basename, trailingSlashAware) {\n let dataStrategy = getSingleFetchDataStrategyImpl(\n getRouter,\n (match) => {\n let manifestRoute = manifest.routes[match.route.id];\n invariant2(manifestRoute, \"Route not found in manifest\");\n let routeModule = routeModules[match.route.id];\n return {\n hasLoader: manifestRoute.hasLoader,\n hasClientLoader: manifestRoute.hasClientLoader,\n hasShouldRevalidate: Boolean(routeModule?.shouldRevalidate)\n };\n },\n fetchAndDecodeViaTurboStream,\n ssr,\n basename,\n trailingSlashAware\n );\n return async (args) => args.runClientMiddleware(dataStrategy);\n}\nfunction getSingleFetchDataStrategyImpl(getRouter, getRouteInfo, fetchAndDecode, ssr, basename, trailingSlashAware, shouldAllowOptOut = () => true) {\n return async (args) => {\n let { request, matches, fetcherKey } = args;\n let router = getRouter();\n if (request.method !== \"GET\") {\n return singleFetchActionStrategy(\n args,\n fetchAndDecode,\n basename,\n trailingSlashAware\n );\n }\n let foundRevalidatingServerLoader = matches.some((m) => {\n let { hasLoader, hasClientLoader } = getRouteInfo(m);\n return m.shouldCallHandler() && hasLoader && !hasClientLoader;\n });\n if (!ssr && !foundRevalidatingServerLoader) {\n return nonSsrStrategy(\n args,\n getRouteInfo,\n fetchAndDecode,\n basename,\n trailingSlashAware\n );\n }\n if (fetcherKey) {\n return singleFetchLoaderFetcherStrategy(\n args,\n fetchAndDecode,\n basename,\n trailingSlashAware\n );\n }\n return singleFetchLoaderNavigationStrategy(\n args,\n router,\n getRouteInfo,\n fetchAndDecode,\n ssr,\n basename,\n trailingSlashAware,\n shouldAllowOptOut\n );\n };\n}\nasync function singleFetchActionStrategy(args, fetchAndDecode, basename, trailingSlashAware) {\n let actionMatch = args.matches.find((m) => m.shouldCallHandler());\n invariant2(actionMatch, \"No action match found\");\n let actionStatus = void 0;\n let result = await actionMatch.resolve(async (handler) => {\n let result2 = await handler(async () => {\n let { data: data2, status } = await fetchAndDecode(\n args,\n basename,\n trailingSlashAware,\n [actionMatch.route.id]\n );\n actionStatus = status;\n return unwrapSingleFetchResult(data2, actionMatch.route.id);\n });\n return result2;\n });\n if (isResponse(result.result) || isRouteErrorResponse(result.result) || isDataWithResponseInit(result.result)) {\n return { [actionMatch.route.id]: result };\n }\n return {\n [actionMatch.route.id]: {\n type: result.type,\n result: data(result.result, actionStatus)\n }\n };\n}\nasync function nonSsrStrategy(args, getRouteInfo, fetchAndDecode, basename, trailingSlashAware) {\n let matchesToLoad = args.matches.filter((m) => m.shouldCallHandler());\n let results = {};\n await Promise.all(\n matchesToLoad.map(\n (m) => m.resolve(async (handler) => {\n try {\n let { hasClientLoader } = getRouteInfo(m);\n let routeId = m.route.id;\n let result = hasClientLoader ? await handler(async () => {\n let { data: data2 } = await fetchAndDecode(\n args,\n basename,\n trailingSlashAware,\n [routeId]\n );\n return unwrapSingleFetchResult(data2, routeId);\n }) : await handler();\n results[m.route.id] = { type: \"data\", result };\n } catch (e) {\n results[m.route.id] = { type: \"error\", result: e };\n }\n })\n )\n );\n return results;\n}\nasync function singleFetchLoaderNavigationStrategy(args, router, getRouteInfo, fetchAndDecode, ssr, basename, trailingSlashAware, shouldAllowOptOut = () => true) {\n let routesParams = /* @__PURE__ */ new Set();\n let foundOptOutRoute = false;\n let routeDfds = args.matches.map(() => createDeferred2());\n let singleFetchDfd = createDeferred2();\n let results = {};\n let resolvePromise = Promise.all(\n args.matches.map(\n async (m, i) => m.resolve(async (handler) => {\n routeDfds[i].resolve();\n let routeId = m.route.id;\n let { hasLoader, hasClientLoader, hasShouldRevalidate } = getRouteInfo(m);\n let defaultShouldRevalidate = !m.shouldRevalidateArgs || m.shouldRevalidateArgs.actionStatus == null || m.shouldRevalidateArgs.actionStatus < 400;\n let shouldCall = m.shouldCallHandler(defaultShouldRevalidate);\n if (!shouldCall) {\n foundOptOutRoute || (foundOptOutRoute = m.shouldRevalidateArgs != null && // This is a revalidation,\n hasLoader && // for a route with a server loader,\n hasShouldRevalidate === true);\n return;\n }\n if (shouldAllowOptOut(m) && hasClientLoader) {\n if (hasLoader) {\n foundOptOutRoute = true;\n }\n try {\n let result = await handler(async () => {\n let { data: data2 } = await fetchAndDecode(\n args,\n basename,\n trailingSlashAware,\n [routeId]\n );\n return unwrapSingleFetchResult(data2, routeId);\n });\n results[routeId] = { type: \"data\", result };\n } catch (e) {\n results[routeId] = { type: \"error\", result: e };\n }\n return;\n }\n if (hasLoader) {\n routesParams.add(routeId);\n }\n try {\n let result = await handler(async () => {\n let data2 = await singleFetchDfd.promise;\n return unwrapSingleFetchResult(data2, routeId);\n });\n results[routeId] = { type: \"data\", result };\n } catch (e) {\n results[routeId] = { type: \"error\", result: e };\n }\n })\n )\n );\n await Promise.all(routeDfds.map((d) => d.promise));\n let isInitialLoad = !router.state.initialized && router.state.navigation.state === \"idle\";\n if ((isInitialLoad || routesParams.size === 0) && !window.__reactRouterHdrActive) {\n singleFetchDfd.resolve({ routes: {} });\n } else {\n let targetRoutes = ssr && foundOptOutRoute && routesParams.size > 0 ? [...routesParams.keys()] : void 0;\n try {\n let data2 = await fetchAndDecode(\n args,\n basename,\n trailingSlashAware,\n targetRoutes\n );\n singleFetchDfd.resolve(data2.data);\n } catch (e) {\n singleFetchDfd.reject(e);\n }\n }\n await resolvePromise;\n await bubbleMiddlewareErrors(\n singleFetchDfd.promise,\n args.matches,\n routesParams,\n results\n );\n return results;\n}\nasync function bubbleMiddlewareErrors(singleFetchPromise, matches, routesParams, results) {\n try {\n let middlewareError;\n let fetchedData = await singleFetchPromise;\n if (\"routes\" in fetchedData) {\n for (let match of matches) {\n if (match.route.id in fetchedData.routes) {\n let routeResult = fetchedData.routes[match.route.id];\n if (\"error\" in routeResult) {\n middlewareError = routeResult.error;\n if (results[match.route.id]?.result == null) {\n results[match.route.id] = {\n type: \"error\",\n result: middlewareError\n };\n }\n break;\n }\n }\n }\n }\n if (middlewareError !== void 0) {\n Array.from(routesParams.values()).forEach((routeId) => {\n if (results[routeId].result instanceof SingleFetchNoResultError) {\n results[routeId].result = middlewareError;\n }\n });\n }\n } catch (e) {\n }\n}\nasync function singleFetchLoaderFetcherStrategy(args, fetchAndDecode, basename, trailingSlashAware) {\n let fetcherMatch = args.matches.find((m) => m.shouldCallHandler());\n invariant2(fetcherMatch, \"No fetcher match found\");\n let routeId = fetcherMatch.route.id;\n let result = await fetcherMatch.resolve(\n async (handler) => handler(async () => {\n let { data: data2 } = await fetchAndDecode(args, basename, trailingSlashAware, [\n routeId\n ]);\n return unwrapSingleFetchResult(data2, routeId);\n })\n );\n return { [fetcherMatch.route.id]: result };\n}\nfunction stripIndexParam(url) {\n let indexValues = url.searchParams.getAll(\"index\");\n url.searchParams.delete(\"index\");\n let indexValuesToKeep = [];\n for (let indexValue of indexValues) {\n if (indexValue) {\n indexValuesToKeep.push(indexValue);\n }\n }\n for (let toKeep of indexValuesToKeep) {\n url.searchParams.append(\"index\", toKeep);\n }\n return url;\n}\nfunction singleFetchUrl(reqUrl, basename, trailingSlashAware, extension) {\n let url = typeof reqUrl === \"string\" ? new URL(\n reqUrl,\n // This can be called during the SSR flow via PrefetchPageLinksImpl so\n // don't assume window is available\n typeof window === \"undefined\" ? \"server://singlefetch/\" : window.location.origin\n ) : reqUrl;\n if (trailingSlashAware) {\n if (url.pathname.endsWith(\"/\")) {\n url.pathname = `${url.pathname}_.${extension}`;\n } else {\n url.pathname = `${url.pathname}.${extension}`;\n }\n } else {\n if (url.pathname === \"/\") {\n url.pathname = `_root.${extension}`;\n } else if (basename && stripBasename(url.pathname, basename) === \"/\") {\n url.pathname = `${removeTrailingSlash(basename)}/_root.${extension}`;\n } else {\n url.pathname = `${removeTrailingSlash(url.pathname)}.${extension}`;\n }\n }\n return url;\n}\nasync function fetchAndDecodeViaTurboStream(args, basename, trailingSlashAware, targetRoutes) {\n let { request } = args;\n let url = singleFetchUrl(request.url, basename, trailingSlashAware, \"data\");\n if (request.method === \"GET\") {\n url = stripIndexParam(url);\n if (targetRoutes) {\n url.searchParams.set(\"_routes\", targetRoutes.join(\",\"));\n }\n }\n let res = await fetch(url, await createRequestInit(request));\n if (res.status >= 400 && !res.headers.has(\"X-Remix-Response\")) {\n throw new ErrorResponseImpl(res.status, res.statusText, await res.text());\n }\n if (res.status === 204 && res.headers.has(\"X-Remix-Redirect\")) {\n return {\n status: SINGLE_FETCH_REDIRECT_STATUS,\n data: {\n redirect: {\n redirect: res.headers.get(\"X-Remix-Redirect\"),\n status: Number(res.headers.get(\"X-Remix-Status\") || \"302\"),\n revalidate: res.headers.get(\"X-Remix-Revalidate\") === \"true\",\n reload: res.headers.get(\"X-Remix-Reload-Document\") === \"true\",\n replace: res.headers.get(\"X-Remix-Replace\") === \"true\"\n }\n }\n };\n }\n if (NO_BODY_STATUS_CODES.has(res.status)) {\n let routes = {};\n if (targetRoutes && request.method !== \"GET\") {\n routes[targetRoutes[0]] = { data: void 0 };\n }\n return {\n status: res.status,\n data: { routes }\n };\n }\n invariant2(res.body, \"No response body to decode\");\n try {\n let decoded = await decodeViaTurboStream(res.body, window);\n let data2;\n if (request.method === \"GET\") {\n let typed = decoded.value;\n if (SingleFetchRedirectSymbol in typed) {\n data2 = { redirect: typed[SingleFetchRedirectSymbol] };\n } else {\n data2 = { routes: typed };\n }\n } else {\n let typed = decoded.value;\n let routeId = targetRoutes?.[0];\n invariant2(routeId, \"No routeId found for single fetch call decoding\");\n if (\"redirect\" in typed) {\n data2 = { redirect: typed };\n } else {\n data2 = { routes: { [routeId]: typed } };\n }\n }\n return { status: res.status, data: data2 };\n } catch (e) {\n throw new Error(\"Unable to decode turbo-stream response\");\n }\n}\nfunction decodeViaTurboStream(body, global) {\n return decode(body, {\n plugins: [\n (type, ...rest) => {\n if (type === \"SanitizedError\") {\n let [name, message, stack] = rest;\n let Constructor = Error;\n if (name && SUPPORTED_ERROR_TYPES.includes(name) && name in global && // @ts-expect-error\n typeof global[name] === \"function\") {\n Constructor = global[name];\n }\n let error = new Constructor(message);\n error.stack = stack;\n return { value: error };\n }\n if (type === \"ErrorResponse\") {\n let [data2, status, statusText] = rest;\n return {\n value: new ErrorResponseImpl(status, statusText, data2)\n };\n }\n if (type === \"SingleFetchRedirect\") {\n return { value: { [SingleFetchRedirectSymbol]: rest[0] } };\n }\n if (type === \"SingleFetchClassInstance\") {\n return { value: rest[0] };\n }\n if (type === \"SingleFetchFallback\") {\n return { value: void 0 };\n }\n }\n ]\n });\n}\nfunction unwrapSingleFetchResult(result, routeId) {\n if (\"redirect\" in result) {\n let {\n redirect: location,\n revalidate,\n reload,\n replace: replace2,\n status\n } = result.redirect;\n throw redirect(location, {\n status,\n headers: {\n // Three R's of redirecting (lol Veep)\n ...revalidate ? { \"X-Remix-Revalidate\": \"yes\" } : null,\n ...reload ? { \"X-Remix-Reload-Document\": \"yes\" } : null,\n ...replace2 ? { \"X-Remix-Replace\": \"yes\" } : null\n }\n });\n }\n let routeResult = result.routes[routeId];\n if (routeResult == null) {\n throw new SingleFetchNoResultError(\n `No result found for routeId \"${routeId}\"`\n );\n } else if (\"error\" in routeResult) {\n throw routeResult.error;\n } else if (\"data\" in routeResult) {\n return routeResult.data;\n } else {\n throw new Error(`Invalid response found for routeId \"${routeId}\"`);\n }\n}\nfunction createDeferred2() {\n let resolve;\n let reject;\n let promise = new Promise((res, rej) => {\n resolve = async (val) => {\n res(val);\n try {\n await promise;\n } catch (e) {\n }\n };\n reject = async (error) => {\n rej(error);\n try {\n await promise;\n } catch (e) {\n }\n };\n });\n return {\n promise,\n //@ts-ignore\n resolve,\n //@ts-ignore\n reject\n };\n}\n\n// lib/dom/ssr/errorBoundaries.tsx\nimport * as React9 from \"react\";\n\n// lib/dom/ssr/components.tsx\nimport * as React8 from \"react\";\n\n// lib/dom/ssr/routeModules.ts\nasync function loadRouteModule(route, routeModulesCache) {\n if (route.id in routeModulesCache) {\n return routeModulesCache[route.id];\n }\n try {\n let routeModule = await import(\n /* @vite-ignore */\n /* webpackIgnore: true */\n route.module\n );\n routeModulesCache[route.id] = routeModule;\n return routeModule;\n } catch (error) {\n console.error(\n `Error loading route module \\`${route.module}\\`, reloading page...`\n );\n console.error(error);\n if (window.__reactRouterContext && window.__reactRouterContext.isSpaMode && // @ts-expect-error\n import.meta.hot) {\n throw error;\n }\n window.location.reload();\n return new Promise(() => {\n });\n }\n}\n\n// lib/dom/ssr/links.ts\nfunction getKeyedLinksForMatches(matches, routeModules, manifest) {\n let descriptors = matches.map((match) => {\n let module = routeModules[match.route.id];\n let route = manifest.routes[match.route.id];\n return [\n route && route.css ? route.css.map((href) => ({ rel: \"stylesheet\", href })) : [],\n module?.links?.() || []\n ];\n }).flat(2);\n let preloads = getModuleLinkHrefs(matches, manifest);\n return dedupeLinkDescriptors(descriptors, preloads);\n}\nfunction getRouteCssDescriptors(route) {\n if (!route.css) return [];\n return route.css.map((href) => ({ rel: \"stylesheet\", href }));\n}\nasync function prefetchRouteCss(route) {\n if (!route.css) return;\n let descriptors = getRouteCssDescriptors(route);\n await Promise.all(descriptors.map(prefetchStyleLink));\n}\nasync function prefetchStyleLinks(route, routeModule) {\n if (!route.css && !routeModule.links || !isPreloadSupported()) return;\n let descriptors = [];\n if (route.css) {\n descriptors.push(...getRouteCssDescriptors(route));\n }\n if (routeModule.links) {\n descriptors.push(...routeModule.links());\n }\n if (descriptors.length === 0) return;\n let styleLinks = [];\n for (let descriptor of descriptors) {\n if (!isPageLinkDescriptor(descriptor) && descriptor.rel === \"stylesheet\") {\n styleLinks.push({\n ...descriptor,\n rel: \"preload\",\n as: \"style\"\n });\n }\n }\n await Promise.all(styleLinks.map(prefetchStyleLink));\n}\nasync function prefetchStyleLink(descriptor) {\n return new Promise((resolve) => {\n if (descriptor.media && !window.matchMedia(descriptor.media).matches || document.querySelector(\n `link[rel=\"stylesheet\"][href=\"${descriptor.href}\"]`\n )) {\n return resolve();\n }\n let link = document.createElement(\"link\");\n Object.assign(link, descriptor);\n function removeLink() {\n if (document.head.contains(link)) {\n document.head.removeChild(link);\n }\n }\n link.onload = () => {\n removeLink();\n resolve();\n };\n link.onerror = () => {\n removeLink();\n resolve();\n };\n document.head.appendChild(link);\n });\n}\nfunction isPageLinkDescriptor(object) {\n return object != null && typeof object.page === \"string\";\n}\nfunction isHtmlLinkDescriptor(object) {\n if (object == null) {\n return false;\n }\n if (object.href == null) {\n return object.rel === \"preload\" && typeof object.imageSrcSet === \"string\" && typeof object.imageSizes === \"string\";\n }\n return typeof object.rel === \"string\" && typeof object.href === \"string\";\n}\nasync function getKeyedPrefetchLinks(matches, manifest, routeModules) {\n let links = await Promise.all(\n matches.map(async (match) => {\n let route = manifest.routes[match.route.id];\n if (route) {\n let mod = await loadRouteModule(route, routeModules);\n return mod.links ? mod.links() : [];\n }\n return [];\n })\n );\n return dedupeLinkDescriptors(\n links.flat(1).filter(isHtmlLinkDescriptor).filter((link) => link.rel === \"stylesheet\" || link.rel === \"preload\").map(\n (link) => link.rel === \"stylesheet\" ? { ...link, rel: \"prefetch\", as: \"style\" } : { ...link, rel: \"prefetch\" }\n )\n );\n}\nfunction getNewMatchesForLinks(page, nextMatches, currentMatches, manifest, location, mode) {\n let isNew = (match, index) => {\n if (!currentMatches[index]) return true;\n return match.route.id !== currentMatches[index].route.id;\n };\n let matchPathChanged = (match, index) => {\n return (\n // param change, /users/123 -> /users/456\n currentMatches[index].pathname !== match.pathname || // splat param changed, which is not present in match.path\n // e.g. /files/images/avatar.jpg -> files/finances.xls\n currentMatches[index].route.path?.endsWith(\"*\") && currentMatches[index].params[\"*\"] !== match.params[\"*\"]\n );\n };\n if (mode === \"assets\") {\n return nextMatches.filter(\n (match, index) => isNew(match, index) || matchPathChanged(match, index)\n );\n }\n if (mode === \"data\") {\n return nextMatches.filter((match, index) => {\n let manifestRoute = manifest.routes[match.route.id];\n if (!manifestRoute || !manifestRoute.hasLoader) {\n return false;\n }\n if (isNew(match, index) || matchPathChanged(match, index)) {\n return true;\n }\n if (match.route.shouldRevalidate) {\n let routeChoice = match.route.shouldRevalidate({\n currentUrl: new URL(\n location.pathname + location.search + location.hash,\n window.origin\n ),\n currentParams: currentMatches[0]?.params || {},\n nextUrl: new URL(page, window.origin),\n nextParams: match.params,\n defaultShouldRevalidate: true\n });\n if (typeof routeChoice === \"boolean\") {\n return routeChoice;\n }\n }\n return true;\n });\n }\n return [];\n}\nfunction getModuleLinkHrefs(matches, manifest, { includeHydrateFallback } = {}) {\n return dedupeHrefs(\n matches.map((match) => {\n let route = manifest.routes[match.route.id];\n if (!route) return [];\n let hrefs = [route.module];\n if (route.clientActionModule) {\n hrefs = hrefs.concat(route.clientActionModule);\n }\n if (route.clientLoaderModule) {\n hrefs = hrefs.concat(route.clientLoaderModule);\n }\n if (includeHydrateFallback && route.hydrateFallbackModule) {\n hrefs = hrefs.concat(route.hydrateFallbackModule);\n }\n if (route.imports) {\n hrefs = hrefs.concat(route.imports);\n }\n return hrefs;\n }).flat(1)\n );\n}\nfunction dedupeHrefs(hrefs) {\n return [...new Set(hrefs)];\n}\nfunction sortKeys(obj) {\n let sorted = {};\n let keys = Object.keys(obj).sort();\n for (let key of keys) {\n sorted[key] = obj[key];\n }\n return sorted;\n}\nfunction dedupeLinkDescriptors(descriptors, preloads) {\n let set = /* @__PURE__ */ new Set();\n let preloadsSet = new Set(preloads);\n return descriptors.reduce((deduped, descriptor) => {\n let alreadyModulePreload = preloads && !isPageLinkDescriptor(descriptor) && descriptor.as === \"script\" && descriptor.href && preloadsSet.has(descriptor.href);\n if (alreadyModulePreload) {\n return deduped;\n }\n let key = JSON.stringify(sortKeys(descriptor));\n if (!set.has(key)) {\n set.add(key);\n deduped.push({ key, link: descriptor });\n }\n return deduped;\n }, []);\n}\nvar _isPreloadSupported;\nfunction isPreloadSupported() {\n if (_isPreloadSupported !== void 0) {\n return _isPreloadSupported;\n }\n let el = document.createElement(\"link\");\n _isPreloadSupported = el.relList.supports(\"preload\");\n el = null;\n return _isPreloadSupported;\n}\n\n// lib/dom/ssr/fog-of-war.ts\nimport * as React7 from \"react\";\n\n// lib/dom/ssr/routes.tsx\nimport * as React6 from \"react\";\n\n// lib/dom/ssr/fallback.tsx\nimport * as React5 from \"react\";\nfunction RemixRootDefaultHydrateFallback() {\n return /* @__PURE__ */ React5.createElement(BoundaryShell, { title: \"Loading...\", renderScripts: true }, ENABLE_DEV_WARNINGS ? /* @__PURE__ */ React5.createElement(\n \"script\",\n {\n dangerouslySetInnerHTML: {\n __html: `\n console.log(\n \"\\u{1F4BF} Hey developer \\u{1F44B}. You can provide a way better UX than this \" +\n \"when your app is loading JS modules and/or running \\`clientLoader\\` \" +\n \"functions. Check out https://reactrouter.com/start/framework/route-module#hydratefallback \" +\n \"for more information.\"\n );\n `\n }\n }\n ) : null);\n}\n\n// lib/dom/ssr/routes.tsx\nfunction groupRoutesByParentId(manifest) {\n let routes = {};\n Object.values(manifest).forEach((route) => {\n if (route) {\n let parentId = route.parentId || \"\";\n if (!routes[parentId]) {\n routes[parentId] = [];\n }\n routes[parentId].push(route);\n }\n });\n return routes;\n}\nfunction getRouteComponents(route, routeModule, isSpaMode) {\n let Component4 = getRouteModuleComponent(routeModule);\n let HydrateFallback = routeModule.HydrateFallback && (!isSpaMode || route.id === \"root\") ? routeModule.HydrateFallback : route.id === \"root\" ? RemixRootDefaultHydrateFallback : void 0;\n let ErrorBoundary = routeModule.ErrorBoundary ? routeModule.ErrorBoundary : route.id === \"root\" ? () => /* @__PURE__ */ React6.createElement(RemixRootDefaultErrorBoundary, { error: useRouteError() }) : void 0;\n if (route.id === \"root\" && routeModule.Layout) {\n return {\n ...Component4 ? {\n element: /* @__PURE__ */ React6.createElement(routeModule.Layout, null, /* @__PURE__ */ React6.createElement(Component4, null))\n } : { Component: Component4 },\n ...ErrorBoundary ? {\n errorElement: /* @__PURE__ */ React6.createElement(routeModule.Layout, null, /* @__PURE__ */ React6.createElement(ErrorBoundary, null))\n } : { ErrorBoundary },\n ...HydrateFallback ? {\n hydrateFallbackElement: /* @__PURE__ */ React6.createElement(routeModule.Layout, null, /* @__PURE__ */ React6.createElement(HydrateFallback, null))\n } : { HydrateFallback }\n };\n }\n return { Component: Component4, ErrorBoundary, HydrateFallback };\n}\nfunction createServerRoutes(manifest, routeModules, future, isSpaMode, parentId = \"\", routesByParentId = groupRoutesByParentId(manifest), spaModeLazyPromise = Promise.resolve({ Component: () => null })) {\n return (routesByParentId[parentId] || []).map((route) => {\n let routeModule = routeModules[route.id];\n invariant2(\n routeModule,\n \"No `routeModule` available to create server routes\"\n );\n let dataRoute = {\n ...getRouteComponents(route, routeModule, isSpaMode),\n caseSensitive: route.caseSensitive,\n id: route.id,\n index: route.index,\n path: route.path,\n handle: routeModule.handle,\n // For SPA Mode, all routes are lazy except root. However we tell the\n // router root is also lazy here too since we don't need a full\n // implementation - we just need a `lazy` prop to tell the RR rendering\n // where to stop which is always at the root route in SPA mode\n lazy: isSpaMode ? () => spaModeLazyPromise : void 0,\n // For partial hydration rendering, we need to indicate when the route\n // has a loader/clientLoader, but it won't ever be called during the static\n // render, so just give it a no-op function so we can render down to the\n // proper fallback\n loader: route.hasLoader || route.hasClientLoader ? () => null : void 0\n // We don't need middleware/action/shouldRevalidate on these routes since\n // they're for a static render\n };\n let children = createServerRoutes(\n manifest,\n routeModules,\n future,\n isSpaMode,\n route.id,\n routesByParentId,\n spaModeLazyPromise\n );\n if (children.length > 0) dataRoute.children = children;\n return dataRoute;\n });\n}\nfunction createClientRoutesWithHMRRevalidationOptOut(needsRevalidation, manifest, routeModulesCache, initialState, ssr, isSpaMode) {\n return createClientRoutes(\n manifest,\n routeModulesCache,\n initialState,\n ssr,\n isSpaMode,\n \"\",\n groupRoutesByParentId(manifest),\n needsRevalidation\n );\n}\nfunction preventInvalidServerHandlerCall(type, route) {\n if (type === \"loader\" && !route.hasLoader || type === \"action\" && !route.hasAction) {\n let fn = type === \"action\" ? \"serverAction()\" : \"serverLoader()\";\n let msg = `You are trying to call ${fn} on a route that does not have a server ${type} (routeId: \"${route.id}\")`;\n console.error(msg);\n throw new ErrorResponseImpl(400, \"Bad Request\", new Error(msg), true);\n }\n}\nfunction noActionDefinedError(type, routeId) {\n let article = type === \"clientAction\" ? \"a\" : \"an\";\n let msg = `Route \"${routeId}\" does not have ${article} ${type}, but you are trying to submit to it. To fix this, please add ${article} \\`${type}\\` function to the route`;\n console.error(msg);\n throw new ErrorResponseImpl(405, \"Method Not Allowed\", new Error(msg), true);\n}\nfunction createClientRoutes(manifest, routeModulesCache, initialState, ssr, isSpaMode, parentId = \"\", routesByParentId = groupRoutesByParentId(manifest), needsRevalidation) {\n return (routesByParentId[parentId] || []).map((route) => {\n let routeModule = routeModulesCache[route.id];\n function fetchServerHandler(singleFetch) {\n invariant2(\n typeof singleFetch === \"function\",\n \"No single fetch function available for route handler\"\n );\n return singleFetch();\n }\n function fetchServerLoader(singleFetch) {\n if (!route.hasLoader) return Promise.resolve(null);\n return fetchServerHandler(singleFetch);\n }\n function fetchServerAction(singleFetch) {\n if (!route.hasAction) {\n throw noActionDefinedError(\"action\", route.id);\n }\n return fetchServerHandler(singleFetch);\n }\n function prefetchModule(modulePath) {\n import(\n /* @vite-ignore */\n /* webpackIgnore: true */\n modulePath\n );\n }\n function prefetchRouteModuleChunks(route2) {\n if (route2.clientActionModule) {\n prefetchModule(route2.clientActionModule);\n }\n if (route2.clientLoaderModule) {\n prefetchModule(route2.clientLoaderModule);\n }\n }\n async function prefetchStylesAndCallHandler(handler) {\n let cachedModule = routeModulesCache[route.id];\n let linkPrefetchPromise = cachedModule ? prefetchStyleLinks(route, cachedModule) : Promise.resolve();\n try {\n return handler();\n } finally {\n await linkPrefetchPromise;\n }\n }\n let dataRoute = {\n id: route.id,\n index: route.index,\n path: route.path\n };\n if (routeModule) {\n Object.assign(dataRoute, {\n ...dataRoute,\n ...getRouteComponents(route, routeModule, isSpaMode),\n middleware: routeModule.clientMiddleware,\n handle: routeModule.handle,\n shouldRevalidate: getShouldRevalidateFunction(\n dataRoute.path,\n routeModule,\n route,\n ssr,\n needsRevalidation\n )\n });\n let hasInitialData = initialState && initialState.loaderData && route.id in initialState.loaderData;\n let initialData = hasInitialData ? initialState?.loaderData?.[route.id] : void 0;\n let hasInitialError = initialState && initialState.errors && route.id in initialState.errors;\n let initialError = hasInitialError ? initialState?.errors?.[route.id] : void 0;\n let isHydrationRequest = needsRevalidation == null && (routeModule.clientLoader?.hydrate === true || !route.hasLoader);\n dataRoute.loader = async ({\n request,\n params,\n context,\n unstable_pattern,\n unstable_url\n }, singleFetch) => {\n try {\n let result = await prefetchStylesAndCallHandler(async () => {\n invariant2(\n routeModule,\n \"No `routeModule` available for critical-route loader\"\n );\n if (!routeModule.clientLoader) {\n return fetchServerLoader(singleFetch);\n }\n return routeModule.clientLoader({\n request,\n params,\n context,\n unstable_pattern,\n unstable_url,\n async serverLoader() {\n preventInvalidServerHandlerCall(\"loader\", route);\n if (isHydrationRequest) {\n if (hasInitialData) {\n return initialData;\n }\n if (hasInitialError) {\n throw initialError;\n }\n }\n return fetchServerLoader(singleFetch);\n }\n });\n });\n return result;\n } finally {\n isHydrationRequest = false;\n }\n };\n dataRoute.loader.hydrate = shouldHydrateRouteLoader(\n route.id,\n routeModule.clientLoader,\n route.hasLoader,\n isSpaMode\n );\n dataRoute.action = ({\n request,\n params,\n context,\n unstable_pattern,\n unstable_url\n }, singleFetch) => {\n return prefetchStylesAndCallHandler(async () => {\n invariant2(\n routeModule,\n \"No `routeModule` available for critical-route action\"\n );\n if (!routeModule.clientAction) {\n if (isSpaMode) {\n throw noActionDefinedError(\"clientAction\", route.id);\n }\n return fetchServerAction(singleFetch);\n }\n return routeModule.clientAction({\n request,\n params,\n context,\n unstable_pattern,\n unstable_url,\n async serverAction() {\n preventInvalidServerHandlerCall(\"action\", route);\n return fetchServerAction(singleFetch);\n }\n });\n });\n };\n } else {\n if (!route.hasClientLoader) {\n dataRoute.loader = (_, singleFetch) => prefetchStylesAndCallHandler(() => {\n return fetchServerLoader(singleFetch);\n });\n }\n if (!route.hasClientAction) {\n dataRoute.action = (_, singleFetch) => prefetchStylesAndCallHandler(() => {\n if (isSpaMode) {\n throw noActionDefinedError(\"clientAction\", route.id);\n }\n return fetchServerAction(singleFetch);\n });\n }\n let lazyRoutePromise;\n async function getLazyRoute() {\n if (lazyRoutePromise) {\n return await lazyRoutePromise;\n }\n lazyRoutePromise = (async () => {\n if (route.clientLoaderModule || route.clientActionModule) {\n await new Promise((resolve) => setTimeout(resolve, 0));\n }\n let routeModulePromise = loadRouteModuleWithBlockingLinks(\n route,\n routeModulesCache\n );\n prefetchRouteModuleChunks(route);\n return await routeModulePromise;\n })();\n return await lazyRoutePromise;\n }\n dataRoute.lazy = {\n loader: route.hasClientLoader ? async () => {\n let { clientLoader } = route.clientLoaderModule ? await import(\n /* @vite-ignore */\n /* webpackIgnore: true */\n route.clientLoaderModule\n ) : await getLazyRoute();\n invariant2(clientLoader, \"No `clientLoader` export found\");\n return (args, singleFetch) => clientLoader({\n ...args,\n async serverLoader() {\n preventInvalidServerHandlerCall(\"loader\", route);\n return fetchServerLoader(singleFetch);\n }\n });\n } : void 0,\n action: route.hasClientAction ? async () => {\n let clientActionPromise = route.clientActionModule ? import(\n /* @vite-ignore */\n /* webpackIgnore: true */\n route.clientActionModule\n ) : getLazyRoute();\n prefetchRouteModuleChunks(route);\n let { clientAction } = await clientActionPromise;\n invariant2(clientAction, \"No `clientAction` export found\");\n return (args, singleFetch) => clientAction({\n ...args,\n async serverAction() {\n preventInvalidServerHandlerCall(\"action\", route);\n return fetchServerAction(singleFetch);\n }\n });\n } : void 0,\n middleware: route.hasClientMiddleware ? async () => {\n let { clientMiddleware } = route.clientMiddlewareModule ? await import(\n /* @vite-ignore */\n /* webpackIgnore: true */\n route.clientMiddlewareModule\n ) : await getLazyRoute();\n invariant2(clientMiddleware, \"No `clientMiddleware` export found\");\n return clientMiddleware;\n } : void 0,\n shouldRevalidate: async () => {\n let lazyRoute = await getLazyRoute();\n return getShouldRevalidateFunction(\n dataRoute.path,\n lazyRoute,\n route,\n ssr,\n needsRevalidation\n );\n },\n handle: async () => (await getLazyRoute()).handle,\n // No need to wrap these in layout since the root route is never\n // loaded via route.lazy()\n Component: async () => (await getLazyRoute()).Component,\n ErrorBoundary: route.hasErrorBoundary ? async () => (await getLazyRoute()).ErrorBoundary : void 0\n };\n }\n let children = createClientRoutes(\n manifest,\n routeModulesCache,\n initialState,\n ssr,\n isSpaMode,\n route.id,\n routesByParentId,\n needsRevalidation\n );\n if (children.length > 0) dataRoute.children = children;\n return dataRoute;\n });\n}\nfunction getShouldRevalidateFunction(path, route, manifestRoute, ssr, needsRevalidation) {\n if (needsRevalidation) {\n return wrapShouldRevalidateForHdr(\n manifestRoute.id,\n route.shouldRevalidate,\n needsRevalidation\n );\n }\n if (!ssr && manifestRoute.hasLoader && !manifestRoute.hasClientLoader) {\n let myParams = path ? compilePath(path)[1].map((p) => p.paramName) : [];\n const didParamsChange = (opts) => myParams.some((p) => opts.currentParams[p] !== opts.nextParams[p]);\n if (route.shouldRevalidate) {\n let fn = route.shouldRevalidate;\n return (opts) => fn({\n ...opts,\n defaultShouldRevalidate: didParamsChange(opts)\n });\n } else {\n return (opts) => didParamsChange(opts);\n }\n }\n return route.shouldRevalidate;\n}\nfunction wrapShouldRevalidateForHdr(routeId, routeShouldRevalidate, needsRevalidation) {\n let handledRevalidation = false;\n return (arg) => {\n if (!handledRevalidation) {\n handledRevalidation = true;\n return needsRevalidation.has(routeId);\n }\n return routeShouldRevalidate ? routeShouldRevalidate(arg) : arg.defaultShouldRevalidate;\n };\n}\nasync function loadRouteModuleWithBlockingLinks(route, routeModules) {\n let routeModulePromise = loadRouteModule(route, routeModules);\n let prefetchRouteCssPromise = prefetchRouteCss(route);\n let routeModule = await routeModulePromise;\n await Promise.all([\n prefetchRouteCssPromise,\n prefetchStyleLinks(route, routeModule)\n ]);\n return {\n Component: getRouteModuleComponent(routeModule),\n ErrorBoundary: routeModule.ErrorBoundary,\n clientMiddleware: routeModule.clientMiddleware,\n clientAction: routeModule.clientAction,\n clientLoader: routeModule.clientLoader,\n handle: routeModule.handle,\n links: routeModule.links,\n meta: routeModule.meta,\n shouldRevalidate: routeModule.shouldRevalidate\n };\n}\nfunction getRouteModuleComponent(routeModule) {\n if (routeModule.default == null) return void 0;\n let isEmptyObject = typeof routeModule.default === \"object\" && Object.keys(routeModule.default).length === 0;\n if (!isEmptyObject) {\n return routeModule.default;\n }\n}\nfunction shouldHydrateRouteLoader(routeId, clientLoader, hasLoader, isSpaMode) {\n return isSpaMode && routeId !== \"root\" || clientLoader != null && (clientLoader.hydrate === true || hasLoader !== true);\n}\n\n// lib/dom/ssr/fog-of-war.ts\nvar nextPaths = /* @__PURE__ */ new Set();\nvar discoveredPathsMaxSize = 1e3;\nvar discoveredPaths = /* @__PURE__ */ new Set();\nvar URL_LIMIT = 7680;\nfunction isFogOfWarEnabled(routeDiscovery, ssr) {\n return routeDiscovery.mode === \"lazy\" && ssr === true;\n}\nfunction getPartialManifest({ sri, ...manifest }, router) {\n let routeIds = new Set(router.state.matches.map((m) => m.route.id));\n let segments = router.state.location.pathname.split(\"/\").filter(Boolean);\n let paths = [\"/\"];\n segments.pop();\n while (segments.length > 0) {\n paths.push(`/${segments.join(\"/\")}`);\n segments.pop();\n }\n paths.forEach((path) => {\n let matches = matchRoutes(router.routes, path, router.basename);\n if (matches) {\n matches.forEach((m) => routeIds.add(m.route.id));\n }\n });\n let initialRoutes = [...routeIds].reduce(\n (acc, id) => Object.assign(acc, { [id]: manifest.routes[id] }),\n {}\n );\n return {\n ...manifest,\n routes: initialRoutes,\n sri: sri ? true : void 0\n };\n}\nfunction getPatchRoutesOnNavigationFunction(getRouter, manifest, routeModules, ssr, routeDiscovery, isSpaMode, basename) {\n if (!isFogOfWarEnabled(routeDiscovery, ssr)) {\n return void 0;\n }\n return async ({ path, patch, signal, fetcherKey }) => {\n if (discoveredPaths.has(path)) {\n return;\n }\n let { state } = getRouter();\n await fetchAndApplyManifestPatches(\n [path],\n // If we're patching for a fetcher call, reload the current location\n // Otherwise prefer any ongoing navigation location\n fetcherKey ? window.location.href : createPath(state.navigation.location || state.location),\n manifest,\n routeModules,\n ssr,\n isSpaMode,\n basename,\n routeDiscovery.manifestPath,\n patch,\n signal\n );\n };\n}\nfunction useFogOFWarDiscovery(router, manifest, routeModules, ssr, routeDiscovery, isSpaMode) {\n React7.useEffect(() => {\n if (!isFogOfWarEnabled(routeDiscovery, ssr) || // @ts-expect-error - TS doesn't know about this yet\n window.navigator?.connection?.saveData === true) {\n return;\n }\n function registerElement(el) {\n let path = el.tagName === \"FORM\" ? el.getAttribute(\"action\") : el.getAttribute(\"href\");\n if (!path) {\n return;\n }\n let pathname = el.tagName === \"A\" ? el.pathname : new URL(path, window.location.origin).pathname;\n if (!discoveredPaths.has(pathname)) {\n nextPaths.add(pathname);\n }\n }\n async function fetchPatches() {\n document.querySelectorAll(\"a[data-discover], form[data-discover]\").forEach(registerElement);\n let lazyPaths = Array.from(nextPaths.keys()).filter((path) => {\n if (discoveredPaths.has(path)) {\n nextPaths.delete(path);\n return false;\n }\n return true;\n });\n if (lazyPaths.length === 0) {\n return;\n }\n try {\n await fetchAndApplyManifestPatches(\n lazyPaths,\n null,\n manifest,\n routeModules,\n ssr,\n isSpaMode,\n router.basename,\n routeDiscovery.manifestPath,\n router.patchRoutes\n );\n } catch (e) {\n console.error(\"Failed to fetch manifest patches\", e);\n }\n }\n let debouncedFetchPatches = debounce(fetchPatches, 100);\n fetchPatches();\n let observer = new MutationObserver(() => debouncedFetchPatches());\n observer.observe(document.documentElement, {\n subtree: true,\n childList: true,\n attributes: true,\n attributeFilter: [\"data-discover\", \"href\", \"action\"]\n });\n return () => observer.disconnect();\n }, [ssr, isSpaMode, manifest, routeModules, router, routeDiscovery]);\n}\nfunction getManifestPath(_manifestPath, basename) {\n let manifestPath = _manifestPath || \"/__manifest\";\n return basename == null ? manifestPath : joinPaths([basename, manifestPath]);\n}\nvar MANIFEST_VERSION_STORAGE_KEY = \"react-router-manifest-version\";\nasync function fetchAndApplyManifestPatches(paths, errorReloadPath, manifest, routeModules, ssr, isSpaMode, basename, manifestPath, patchRoutes, signal) {\n const searchParams = new URLSearchParams();\n searchParams.set(\"paths\", paths.sort().join(\",\"));\n searchParams.set(\"version\", manifest.version);\n let url = new URL(\n getManifestPath(manifestPath, basename),\n window.location.origin\n );\n url.search = searchParams.toString();\n if (url.toString().length > URL_LIMIT) {\n nextPaths.clear();\n return;\n }\n let serverPatches;\n try {\n let res = await fetch(url, { signal });\n if (!res.ok) {\n throw new Error(`${res.status} ${res.statusText}`);\n } else if (res.status === 204 && res.headers.has(\"X-Remix-Reload-Document\")) {\n if (!errorReloadPath) {\n console.warn(\n \"Detected a manifest version mismatch during eager route discovery. The next navigation/fetch to an undiscovered route will result in a new document navigation to sync up with the latest manifest.\"\n );\n return;\n }\n try {\n if (sessionStorage.getItem(MANIFEST_VERSION_STORAGE_KEY) === manifest.version) {\n console.error(\n \"Unable to discover routes due to manifest version mismatch.\"\n );\n return;\n }\n sessionStorage.setItem(MANIFEST_VERSION_STORAGE_KEY, manifest.version);\n } catch {\n }\n window.location.href = errorReloadPath;\n console.warn(\"Detected manifest version mismatch, reloading...\");\n await new Promise(() => {\n });\n } else if (res.status >= 400) {\n throw new Error(await res.text());\n }\n try {\n sessionStorage.removeItem(MANIFEST_VERSION_STORAGE_KEY);\n } catch {\n }\n serverPatches = await res.json();\n } catch (e) {\n if (signal?.aborted) return;\n throw e;\n }\n let knownRoutes = new Set(Object.keys(manifest.routes));\n let patches = Object.values(serverPatches).reduce((acc, route) => {\n if (route && !knownRoutes.has(route.id)) {\n acc[route.id] = route;\n }\n return acc;\n }, {});\n Object.assign(manifest.routes, patches);\n paths.forEach((p) => addToFifoQueue(p, discoveredPaths));\n let parentIds = /* @__PURE__ */ new Set();\n Object.values(patches).forEach((patch) => {\n if (patch && (!patch.parentId || !patches[patch.parentId])) {\n parentIds.add(patch.parentId);\n }\n });\n parentIds.forEach(\n (parentId) => patchRoutes(\n parentId || null,\n createClientRoutes(patches, routeModules, null, ssr, isSpaMode, parentId)\n )\n );\n}\nfunction addToFifoQueue(path, queue) {\n if (queue.size >= discoveredPathsMaxSize) {\n let first = queue.values().next().value;\n queue.delete(first);\n }\n queue.add(path);\n}\nfunction debounce(callback, wait) {\n let timeoutId;\n return (...args) => {\n window.clearTimeout(timeoutId);\n timeoutId = window.setTimeout(() => callback(...args), wait);\n };\n}\n\n// lib/dom/ssr/components.tsx\nfunction useDataRouterContext2() {\n let context = React8.useContext(DataRouterContext);\n invariant2(\n context,\n \"You must render this element inside a <DataRouterContext.Provider> element\"\n );\n return context;\n}\nfunction useDataRouterStateContext() {\n let context = React8.useContext(DataRouterStateContext);\n invariant2(\n context,\n \"You must render this element inside a <DataRouterStateContext.Provider> element\"\n );\n return context;\n}\nvar FrameworkContext = React8.createContext(void 0);\nFrameworkContext.displayName = \"FrameworkContext\";\nfunction useFrameworkContext() {\n let context = React8.useContext(FrameworkContext);\n invariant2(\n context,\n \"You must render this element inside a <HydratedRouter> element\"\n );\n return context;\n}\nfunction usePrefetchBehavior(prefetch, theirElementProps) {\n let frameworkContext = React8.useContext(FrameworkContext);\n let [maybePrefetch, setMaybePrefetch] = React8.useState(false);\n let [shouldPrefetch, setShouldPrefetch] = React8.useState(false);\n let { onFocus, onBlur, onMouseEnter, onMouseLeave, onTouchStart } = theirElementProps;\n let ref = React8.useRef(null);\n React8.useEffect(() => {\n if (prefetch === \"render\") {\n setShouldPrefetch(true);\n }\n if (prefetch === \"viewport\") {\n let callback = (entries) => {\n entries.forEach((entry) => {\n setShouldPrefetch(entry.isIntersecting);\n });\n };\n let observer = new IntersectionObserver(callback, { threshold: 0.5 });\n if (ref.current) observer.observe(ref.current);\n return () => {\n observer.disconnect();\n };\n }\n }, [prefetch]);\n React8.useEffect(() => {\n if (maybePrefetch) {\n let id = setTimeout(() => {\n setShouldPrefetch(true);\n }, 100);\n return () => {\n clearTimeout(id);\n };\n }\n }, [maybePrefetch]);\n let setIntent = () => {\n setMaybePrefetch(true);\n };\n let cancelIntent = () => {\n setMaybePrefetch(false);\n setShouldPrefetch(false);\n };\n if (!frameworkContext) {\n return [false, ref, {}];\n }\n if (prefetch !== \"intent\") {\n return [shouldPrefetch, ref, {}];\n }\n return [\n shouldPrefetch,\n ref,\n {\n onFocus: composeEventHandlers(onFocus, setIntent),\n onBlur: composeEventHandlers(onBlur, cancelIntent),\n onMouseEnter: composeEventHandlers(onMouseEnter, setIntent),\n onMouseLeave: composeEventHandlers(onMouseLeave, cancelIntent),\n onTouchStart: composeEventHandlers(onTouchStart, setIntent)\n }\n ];\n}\nfunction composeEventHandlers(theirHandler, ourHandler) {\n return (event) => {\n theirHandler && theirHandler(event);\n if (!event.defaultPrevented) {\n ourHandler(event);\n }\n };\n}\nfunction getActiveMatches(matches, errors, isSpaMode) {\n if (isSpaMode && !isHydrated) {\n return [matches[0]];\n }\n if (errors) {\n let errorIdx = matches.findIndex((m) => errors[m.route.id] !== void 0);\n return matches.slice(0, errorIdx + 1);\n }\n return matches;\n}\nvar CRITICAL_CSS_DATA_ATTRIBUTE = \"data-react-router-critical-css\";\nfunction Links({ nonce, crossOrigin }) {\n let { isSpaMode, manifest, routeModules, criticalCss } = useFrameworkContext();\n let { errors, matches: routerMatches } = useDataRouterStateContext();\n let matches = getActiveMatches(routerMatches, errors, isSpaMode);\n let keyedLinks = React8.useMemo(\n () => getKeyedLinksForMatches(matches, routeModules, manifest),\n [matches, routeModules, manifest]\n );\n return /* @__PURE__ */ React8.createElement(React8.Fragment, null, typeof criticalCss === \"string\" ? /* @__PURE__ */ React8.createElement(\n \"style\",\n {\n ...{ [CRITICAL_CSS_DATA_ATTRIBUTE]: \"\" },\n nonce,\n dangerouslySetInnerHTML: { __html: criticalCss }\n }\n ) : null, typeof criticalCss === \"object\" ? /* @__PURE__ */ React8.createElement(\n \"link\",\n {\n ...{ [CRITICAL_CSS_DATA_ATTRIBUTE]: \"\" },\n rel: \"stylesheet\",\n href: criticalCss.href,\n nonce,\n crossOrigin\n }\n ) : null, keyedLinks.map(\n ({ key, link }) => isPageLinkDescriptor(link) ? /* @__PURE__ */ React8.createElement(\n PrefetchPageLinks,\n {\n key,\n nonce,\n ...link,\n crossOrigin: link.crossOrigin ?? crossOrigin\n }\n ) : /* @__PURE__ */ React8.createElement(\n \"link\",\n {\n key,\n nonce,\n ...link,\n crossOrigin: link.crossOrigin ?? crossOrigin\n }\n )\n ));\n}\nfunction PrefetchPageLinks({ page, ...linkProps }) {\n let rsc = useIsRSCRouterContext();\n let { router } = useDataRouterContext2();\n let matches = React8.useMemo(\n () => matchRoutes(router.routes, page, router.basename),\n [router.routes, page, router.basename]\n );\n if (!matches) {\n return null;\n }\n if (rsc) {\n return /* @__PURE__ */ React8.createElement(RSCPrefetchPageLinksImpl, { page, matches, ...linkProps });\n }\n return /* @__PURE__ */ React8.createElement(PrefetchPageLinksImpl, { page, matches, ...linkProps });\n}\nfunction useKeyedPrefetchLinks(matches) {\n let { manifest, routeModules } = useFrameworkContext();\n let [keyedPrefetchLinks, setKeyedPrefetchLinks] = React8.useState([]);\n React8.useEffect(() => {\n let interrupted = false;\n void getKeyedPrefetchLinks(matches, manifest, routeModules).then(\n (links) => {\n if (!interrupted) {\n setKeyedPrefetchLinks(links);\n }\n }\n );\n return () => {\n interrupted = true;\n };\n }, [matches, manifest, routeModules]);\n return keyedPrefetchLinks;\n}\nfunction RSCPrefetchPageLinksImpl({\n page,\n matches: nextMatches,\n ...linkProps\n}) {\n let location = useLocation();\n let { future } = useFrameworkContext();\n let { basename } = useDataRouterContext2();\n let dataHrefs = React8.useMemo(() => {\n if (page === location.pathname + location.search + location.hash) {\n return [];\n }\n let url = singleFetchUrl(\n page,\n basename,\n future.unstable_trailingSlashAwareDataRequests,\n \"rsc\"\n );\n let hasSomeRoutesWithShouldRevalidate = false;\n let targetRoutes = [];\n for (let match of nextMatches) {\n if (typeof match.route.shouldRevalidate === \"function\") {\n hasSomeRoutesWithShouldRevalidate = true;\n } else {\n targetRoutes.push(match.route.id);\n }\n }\n if (hasSomeRoutesWithShouldRevalidate && targetRoutes.length > 0) {\n url.searchParams.set(\"_routes\", targetRoutes.join(\",\"));\n }\n return [url.pathname + url.search];\n }, [\n basename,\n future.unstable_trailingSlashAwareDataRequests,\n page,\n location,\n nextMatches\n ]);\n return /* @__PURE__ */ React8.createElement(React8.Fragment, null, dataHrefs.map((href) => /* @__PURE__ */ React8.createElement(\"link\", { key: href, rel: \"prefetch\", as: \"fetch\", href, ...linkProps })));\n}\nfunction PrefetchPageLinksImpl({\n page,\n matches: nextMatches,\n ...linkProps\n}) {\n let location = useLocation();\n let { future, manifest, routeModules } = useFrameworkContext();\n let { basename } = useDataRouterContext2();\n let { loaderData, matches } = useDataRouterStateContext();\n let newMatchesForData = React8.useMemo(\n () => getNewMatchesForLinks(\n page,\n nextMatches,\n matches,\n manifest,\n location,\n \"data\"\n ),\n [page, nextMatches, matches, manifest, location]\n );\n let newMatchesForAssets = React8.useMemo(\n () => getNewMatchesForLinks(\n page,\n nextMatches,\n matches,\n manifest,\n location,\n \"assets\"\n ),\n [page, nextMatches, matches, manifest, location]\n );\n let dataHrefs = React8.useMemo(() => {\n if (page === location.pathname + location.search + location.hash) {\n return [];\n }\n let routesParams = /* @__PURE__ */ new Set();\n let foundOptOutRoute = false;\n nextMatches.forEach((m) => {\n let manifestRoute = manifest.routes[m.route.id];\n if (!manifestRoute || !manifestRoute.hasLoader) {\n return;\n }\n if (!newMatchesForData.some((m2) => m2.route.id === m.route.id) && m.route.id in loaderData && routeModules[m.route.id]?.shouldRevalidate) {\n foundOptOutRoute = true;\n } else if (manifestRoute.hasClientLoader) {\n foundOptOutRoute = true;\n } else {\n routesParams.add(m.route.id);\n }\n });\n if (routesParams.size === 0) {\n return [];\n }\n let url = singleFetchUrl(\n page,\n basename,\n future.unstable_trailingSlashAwareDataRequests,\n \"data\"\n );\n if (foundOptOutRoute && routesParams.size > 0) {\n url.searchParams.set(\n \"_routes\",\n nextMatches.filter((m) => routesParams.has(m.route.id)).map((m) => m.route.id).join(\",\")\n );\n }\n return [url.pathname + url.search];\n }, [\n basename,\n future.unstable_trailingSlashAwareDataRequests,\n loaderData,\n location,\n manifest,\n newMatchesForData,\n nextMatches,\n page,\n routeModules\n ]);\n let moduleHrefs = React8.useMemo(\n () => getModuleLinkHrefs(newMatchesForAssets, manifest),\n [newMatchesForAssets, manifest]\n );\n let keyedPrefetchLinks = useKeyedPrefetchLinks(newMatchesForAssets);\n return /* @__PURE__ */ React8.createElement(React8.Fragment, null, dataHrefs.map((href) => /* @__PURE__ */ React8.createElement(\"link\", { key: href, rel: \"prefetch\", as: \"fetch\", href, ...linkProps })), moduleHrefs.map((href) => /* @__PURE__ */ React8.createElement(\"link\", { key: href, rel: \"modulepreload\", href, ...linkProps })), keyedPrefetchLinks.map(({ key, link }) => (\n // these don't spread `linkProps` because they are full link descriptors\n // already with their own props\n /* @__PURE__ */ React8.createElement(\n \"link\",\n {\n key,\n nonce: linkProps.nonce,\n ...link,\n crossOrigin: link.crossOrigin ?? linkProps.crossOrigin\n }\n )\n )));\n}\nfunction Meta() {\n let { isSpaMode, routeModules } = useFrameworkContext();\n let {\n errors,\n matches: routerMatches,\n loaderData\n } = useDataRouterStateContext();\n let location = useLocation();\n let _matches = getActiveMatches(routerMatches, errors, isSpaMode);\n let error = null;\n if (errors) {\n error = errors[_matches[_matches.length - 1].route.id];\n }\n let meta = [];\n let leafMeta = null;\n let matches = [];\n for (let i = 0; i < _matches.length; i++) {\n let _match = _matches[i];\n let routeId = _match.route.id;\n let data2 = loaderData[routeId];\n let params = _match.params;\n let routeModule = routeModules[routeId];\n let routeMeta = [];\n let match = {\n id: routeId,\n data: data2,\n loaderData: data2,\n meta: [],\n params: _match.params,\n pathname: _match.pathname,\n handle: _match.route.handle,\n error\n };\n matches[i] = match;\n if (routeModule?.meta) {\n routeMeta = typeof routeModule.meta === \"function\" ? routeModule.meta({\n data: data2,\n loaderData: data2,\n params,\n location,\n matches,\n error\n }) : Array.isArray(routeModule.meta) ? [...routeModule.meta] : routeModule.meta;\n } else if (leafMeta) {\n routeMeta = [...leafMeta];\n }\n routeMeta = routeMeta || [];\n if (!Array.isArray(routeMeta)) {\n throw new Error(\n \"The route at \" + _match.route.path + \" returns an invalid value. All route meta functions must return an array of meta objects.\\n\\nTo reference the meta function API, see https://reactrouter.com/start/framework/route-module#meta\"\n );\n }\n match.meta = routeMeta;\n matches[i] = match;\n meta = [...routeMeta];\n leafMeta = meta;\n }\n return /* @__PURE__ */ React8.createElement(React8.Fragment, null, meta.flat().map((metaProps) => {\n if (!metaProps) {\n return null;\n }\n if (\"tagName\" in metaProps) {\n let { tagName, ...rest } = metaProps;\n if (!isValidMetaTag(tagName)) {\n console.warn(\n `A meta object uses an invalid tagName: ${tagName}. Expected either 'link' or 'meta'`\n );\n return null;\n }\n let Comp = tagName;\n return /* @__PURE__ */ React8.createElement(Comp, { key: JSON.stringify(rest), ...rest });\n }\n if (\"title\" in metaProps) {\n return /* @__PURE__ */ React8.createElement(\"title\", { key: \"title\" }, String(metaProps.title));\n }\n if (\"charset\" in metaProps) {\n metaProps.charSet ?? (metaProps.charSet = metaProps.charset);\n delete metaProps.charset;\n }\n if (\"charSet\" in metaProps && metaProps.charSet != null) {\n return typeof metaProps.charSet === \"string\" ? /* @__PURE__ */ React8.createElement(\"meta\", { key: \"charSet\", charSet: metaProps.charSet }) : null;\n }\n if (\"script:ld+json\" in metaProps) {\n try {\n let json = JSON.stringify(metaProps[\"script:ld+json\"]);\n return /* @__PURE__ */ React8.createElement(\n \"script\",\n {\n key: `script:ld+json:${json}`,\n type: \"application/ld+json\",\n dangerouslySetInnerHTML: { __html: escapeHtml(json) }\n }\n );\n } catch (err) {\n return null;\n }\n }\n return /* @__PURE__ */ React8.createElement(\"meta\", { key: JSON.stringify(metaProps), ...metaProps });\n }));\n}\nfunction isValidMetaTag(tagName) {\n return typeof tagName === \"string\" && /^(meta|link)$/.test(tagName);\n}\nvar isHydrated = false;\nfunction setIsHydrated() {\n isHydrated = true;\n}\nfunction Scripts(scriptProps) {\n let {\n manifest,\n serverHandoffString,\n isSpaMode,\n renderMeta,\n routeDiscovery,\n ssr\n } = useFrameworkContext();\n let { router, static: isStatic, staticContext } = useDataRouterContext2();\n let { matches: routerMatches } = useDataRouterStateContext();\n let isRSCRouterContext = useIsRSCRouterContext();\n let enableFogOfWar = isFogOfWarEnabled(routeDiscovery, ssr);\n if (renderMeta) {\n renderMeta.didRenderScripts = true;\n }\n let matches = getActiveMatches(routerMatches, null, isSpaMode);\n React8.useEffect(() => {\n setIsHydrated();\n }, []);\n let initialScripts = React8.useMemo(() => {\n if (isRSCRouterContext) {\n return null;\n }\n let streamScript = \"window.__reactRouterContext.stream = new ReadableStream({start(controller){window.__reactRouterContext.streamController = controller;}}).pipeThrough(new TextEncoderStream());\";\n let contextScript = staticContext ? `window.__reactRouterContext = ${serverHandoffString};${streamScript}` : \" \";\n let routeModulesScript = !isStatic ? \" \" : `${manifest.hmr?.runtime ? `import ${JSON.stringify(manifest.hmr.runtime)};` : \"\"}${!enableFogOfWar ? `import ${JSON.stringify(manifest.url)}` : \"\"};\n${matches.map((match, routeIndex) => {\n let routeVarName = `route${routeIndex}`;\n let manifestEntry = manifest.routes[match.route.id];\n invariant2(manifestEntry, `Route ${match.route.id} not found in manifest`);\n let {\n clientActionModule,\n clientLoaderModule,\n clientMiddlewareModule,\n hydrateFallbackModule,\n module\n } = manifestEntry;\n let chunks = [\n ...clientActionModule ? [\n {\n module: clientActionModule,\n varName: `${routeVarName}_clientAction`\n }\n ] : [],\n ...clientLoaderModule ? [\n {\n module: clientLoaderModule,\n varName: `${routeVarName}_clientLoader`\n }\n ] : [],\n ...clientMiddlewareModule ? [\n {\n module: clientMiddlewareModule,\n varName: `${routeVarName}_clientMiddleware`\n }\n ] : [],\n ...hydrateFallbackModule ? [\n {\n module: hydrateFallbackModule,\n varName: `${routeVarName}_HydrateFallback`\n }\n ] : [],\n { module, varName: `${routeVarName}_main` }\n ];\n if (chunks.length === 1) {\n return `import * as ${routeVarName} from ${JSON.stringify(module)};`;\n }\n let chunkImportsSnippet = chunks.map((chunk) => `import * as ${chunk.varName} from \"${chunk.module}\";`).join(\"\\n\");\n let mergedChunksSnippet = `const ${routeVarName} = {${chunks.map((chunk) => `...${chunk.varName}`).join(\",\")}};`;\n return [chunkImportsSnippet, mergedChunksSnippet].join(\"\\n\");\n }).join(\"\\n\")}\n ${enableFogOfWar ? (\n // Inline a minimal manifest with the SSR matches\n `window.__reactRouterManifest = ${JSON.stringify(\n getPartialManifest(manifest, router),\n null,\n 2\n )};`\n ) : \"\"}\n window.__reactRouterRouteModules = {${matches.map((match, index) => `${JSON.stringify(match.route.id)}:route${index}`).join(\",\")}};\n\nimport(${JSON.stringify(manifest.entry.module)});`;\n return /* @__PURE__ */ React8.createElement(React8.Fragment, null, /* @__PURE__ */ React8.createElement(\n \"script\",\n {\n ...scriptProps,\n suppressHydrationWarning: true,\n dangerouslySetInnerHTML: { __html: contextScript },\n type: void 0\n }\n ), /* @__PURE__ */ React8.createElement(\n \"script\",\n {\n ...scriptProps,\n suppressHydrationWarning: true,\n dangerouslySetInnerHTML: { __html: routeModulesScript },\n type: \"module\",\n async: true\n }\n ));\n }, []);\n let preloads = isHydrated || isRSCRouterContext ? [] : dedupe(\n manifest.entry.imports.concat(\n getModuleLinkHrefs(matches, manifest, {\n includeHydrateFallback: true\n })\n )\n );\n let sri = typeof manifest.sri === \"object\" ? manifest.sri : {};\n warnOnce(\n !isRSCRouterContext,\n \"The <Scripts /> element is a no-op when using RSC and can be safely removed.\"\n );\n return isHydrated || isRSCRouterContext ? null : /* @__PURE__ */ React8.createElement(React8.Fragment, null, typeof manifest.sri === \"object\" ? /* @__PURE__ */ React8.createElement(\n \"script\",\n {\n ...scriptProps,\n \"rr-importmap\": \"\",\n type: \"importmap\",\n suppressHydrationWarning: true,\n dangerouslySetInnerHTML: {\n __html: JSON.stringify({\n integrity: sri\n })\n }\n }\n ) : null, !enableFogOfWar ? /* @__PURE__ */ React8.createElement(\n \"link\",\n {\n rel: \"modulepreload\",\n href: manifest.url,\n crossOrigin: scriptProps.crossOrigin,\n integrity: sri[manifest.url],\n suppressHydrationWarning: true\n }\n ) : null, /* @__PURE__ */ React8.createElement(\n \"link\",\n {\n rel: \"modulepreload\",\n href: manifest.entry.module,\n crossOrigin: scriptProps.crossOrigin,\n integrity: sri[manifest.entry.module],\n suppressHydrationWarning: true\n }\n ), preloads.map((path) => /* @__PURE__ */ React8.createElement(\n \"link\",\n {\n key: path,\n rel: \"modulepreload\",\n href: path,\n crossOrigin: scriptProps.crossOrigin,\n integrity: sri[path],\n suppressHydrationWarning: true\n }\n )), initialScripts);\n}\nfunction dedupe(array) {\n return [...new Set(array)];\n}\nfunction mergeRefs(...refs) {\n return (value) => {\n refs.forEach((ref) => {\n if (typeof ref === \"function\") {\n ref(value);\n } else if (ref != null) {\n ref.current = value;\n }\n });\n };\n}\n\n// lib/dom/ssr/errorBoundaries.tsx\nvar RemixErrorBoundary = class extends React9.Component {\n constructor(props) {\n super(props);\n this.state = { error: props.error || null, location: props.location };\n }\n static getDerivedStateFromError(error) {\n return { error };\n }\n static getDerivedStateFromProps(props, state) {\n if (state.location !== props.location) {\n return { error: props.error || null, location: props.location };\n }\n return { error: props.error || state.error, location: state.location };\n }\n render() {\n if (this.state.error) {\n return /* @__PURE__ */ React9.createElement(\n RemixRootDefaultErrorBoundary,\n {\n error: this.state.error,\n isOutsideRemixApp: true\n }\n );\n } else {\n return this.props.children;\n }\n }\n};\nfunction RemixRootDefaultErrorBoundary({\n error,\n isOutsideRemixApp\n}) {\n console.error(error);\n let heyDeveloper = /* @__PURE__ */ React9.createElement(\n \"script\",\n {\n dangerouslySetInnerHTML: {\n __html: `\n console.log(\n \"\\u{1F4BF} Hey developer \\u{1F44B}. You can provide a way better UX than this when your app throws errors. Check out https://reactrouter.com/how-to/error-boundary for more information.\"\n );\n `\n }\n }\n );\n if (isRouteErrorResponse(error)) {\n return /* @__PURE__ */ React9.createElement(BoundaryShell, { title: \"Unhandled Thrown Response!\" }, /* @__PURE__ */ React9.createElement(\"h1\", { style: { fontSize: \"24px\" } }, error.status, \" \", error.statusText), ENABLE_DEV_WARNINGS ? heyDeveloper : null);\n }\n let errorInstance;\n if (error instanceof Error) {\n errorInstance = error;\n } else {\n let errorString = error == null ? \"Unknown Error\" : typeof error === \"object\" && \"toString\" in error ? error.toString() : JSON.stringify(error);\n errorInstance = new Error(errorString);\n }\n return /* @__PURE__ */ React9.createElement(\n BoundaryShell,\n {\n title: \"Application Error!\",\n isOutsideRemixApp\n },\n /* @__PURE__ */ React9.createElement(\"h1\", { style: { fontSize: \"24px\" } }, \"Application Error\"),\n /* @__PURE__ */ React9.createElement(\n \"pre\",\n {\n style: {\n padding: \"2rem\",\n background: \"hsla(10, 50%, 50%, 0.1)\",\n color: \"red\",\n overflow: \"auto\"\n }\n },\n errorInstance.stack\n ),\n heyDeveloper\n );\n}\nfunction BoundaryShell({\n title,\n renderScripts,\n isOutsideRemixApp,\n children\n}) {\n let { routeModules } = useFrameworkContext();\n if (routeModules.root?.Layout && !isOutsideRemixApp) {\n return children;\n }\n return /* @__PURE__ */ React9.createElement(\"html\", { lang: \"en\" }, /* @__PURE__ */ React9.createElement(\"head\", null, /* @__PURE__ */ React9.createElement(\"meta\", { charSet: \"utf-8\" }), /* @__PURE__ */ React9.createElement(\n \"meta\",\n {\n name: \"viewport\",\n content: \"width=device-width,initial-scale=1,viewport-fit=cover\"\n }\n ), /* @__PURE__ */ React9.createElement(\"title\", null, title)), /* @__PURE__ */ React9.createElement(\"body\", null, /* @__PURE__ */ React9.createElement(\"main\", { style: { fontFamily: \"system-ui, sans-serif\", padding: \"2rem\" } }, children, renderScripts ? /* @__PURE__ */ React9.createElement(Scripts, null) : null)));\n}\n\n// lib/dom/lib.tsx\nimport * as React10 from \"react\";\nvar isBrowser2 = typeof window !== \"undefined\" && typeof window.document !== \"undefined\" && typeof window.document.createElement !== \"undefined\";\ntry {\n if (isBrowser2) {\n window.__reactRouterVersion = // @ts-expect-error\n \"7.14.2\";\n }\n} catch (e) {\n}\nfunction createBrowserRouter(routes, opts) {\n return createRouter({\n basename: opts?.basename,\n getContext: opts?.getContext,\n future: opts?.future,\n history: createBrowserHistory({ window: opts?.window }),\n hydrationData: opts?.hydrationData || parseHydrationData(),\n routes,\n mapRouteProperties,\n hydrationRouteProperties,\n dataStrategy: opts?.dataStrategy,\n patchRoutesOnNavigation: opts?.patchRoutesOnNavigation,\n window: opts?.window,\n unstable_instrumentations: opts?.unstable_instrumentations\n }).initialize();\n}\nfunction createHashRouter(routes, opts) {\n return createRouter({\n basename: opts?.basename,\n getContext: opts?.getContext,\n future: opts?.future,\n history: createHashHistory({ window: opts?.window }),\n hydrationData: opts?.hydrationData || parseHydrationData(),\n routes,\n mapRouteProperties,\n hydrationRouteProperties,\n dataStrategy: opts?.dataStrategy,\n patchRoutesOnNavigation: opts?.patchRoutesOnNavigation,\n window: opts?.window,\n unstable_instrumentations: opts?.unstable_instrumentations\n }).initialize();\n}\nfunction parseHydrationData() {\n let state = window?.__staticRouterHydrationData;\n if (state && state.errors) {\n state = {\n ...state,\n errors: deserializeErrors(state.errors)\n };\n }\n return state;\n}\nfunction deserializeErrors(errors) {\n if (!errors) return null;\n let entries = Object.entries(errors);\n let serialized = {};\n for (let [key, val] of entries) {\n if (val && val.__type === \"RouteErrorResponse\") {\n serialized[key] = new ErrorResponseImpl(\n val.status,\n val.statusText,\n val.data,\n val.internal === true\n );\n } else if (val && val.__type === \"Error\") {\n if (val.__subType) {\n let ErrorConstructor = window[val.__subType];\n if (typeof ErrorConstructor === \"function\") {\n try {\n let error = new ErrorConstructor(val.message);\n error.stack = \"\";\n serialized[key] = error;\n } catch (e) {\n }\n }\n }\n if (serialized[key] == null) {\n let error = new Error(val.message);\n error.stack = \"\";\n serialized[key] = error;\n }\n } else {\n serialized[key] = val;\n }\n }\n return serialized;\n}\nfunction BrowserRouter({\n basename,\n children,\n unstable_useTransitions,\n window: window2\n}) {\n let historyRef = React10.useRef();\n if (historyRef.current == null) {\n historyRef.current = createBrowserHistory({ window: window2, v5Compat: true });\n }\n let history = historyRef.current;\n let [state, setStateImpl] = React10.useState({\n action: history.action,\n location: history.location\n });\n let setState = React10.useCallback(\n (newState) => {\n if (unstable_useTransitions === false) {\n setStateImpl(newState);\n } else {\n React10.startTransition(() => setStateImpl(newState));\n }\n },\n [unstable_useTransitions]\n );\n React10.useLayoutEffect(() => history.listen(setState), [history, setState]);\n return /* @__PURE__ */ React10.createElement(\n Router,\n {\n basename,\n children,\n location: state.location,\n navigationType: state.action,\n navigator: history,\n unstable_useTransitions\n }\n );\n}\nfunction HashRouter({\n basename,\n children,\n unstable_useTransitions,\n window: window2\n}) {\n let historyRef = React10.useRef();\n if (historyRef.current == null) {\n historyRef.current = createHashHistory({ window: window2, v5Compat: true });\n }\n let history = historyRef.current;\n let [state, setStateImpl] = React10.useState({\n action: history.action,\n location: history.location\n });\n let setState = React10.useCallback(\n (newState) => {\n if (unstable_useTransitions === false) {\n setStateImpl(newState);\n } else {\n React10.startTransition(() => setStateImpl(newState));\n }\n },\n [unstable_useTransitions]\n );\n React10.useLayoutEffect(() => history.listen(setState), [history, setState]);\n return /* @__PURE__ */ React10.createElement(\n Router,\n {\n basename,\n children,\n location: state.location,\n navigationType: state.action,\n navigator: history,\n unstable_useTransitions\n }\n );\n}\nfunction HistoryRouter({\n basename,\n children,\n history,\n unstable_useTransitions\n}) {\n let [state, setStateImpl] = React10.useState({\n action: history.action,\n location: history.location\n });\n let setState = React10.useCallback(\n (newState) => {\n if (unstable_useTransitions === false) {\n setStateImpl(newState);\n } else {\n React10.startTransition(() => setStateImpl(newState));\n }\n },\n [unstable_useTransitions]\n );\n React10.useLayoutEffect(() => history.listen(setState), [history, setState]);\n return /* @__PURE__ */ React10.createElement(\n Router,\n {\n basename,\n children,\n location: state.location,\n navigationType: state.action,\n navigator: history,\n unstable_useTransitions\n }\n );\n}\nHistoryRouter.displayName = \"unstable_HistoryRouter\";\nvar ABSOLUTE_URL_REGEX2 = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\nvar Link = React10.forwardRef(\n function LinkWithRef({\n onClick,\n discover = \"render\",\n prefetch = \"none\",\n relative,\n reloadDocument,\n replace: replace2,\n unstable_mask,\n state,\n target,\n to,\n preventScrollReset,\n viewTransition,\n unstable_defaultShouldRevalidate,\n ...rest\n }, forwardedRef) {\n let { basename, navigator, unstable_useTransitions } = React10.useContext(NavigationContext);\n let isAbsolute = typeof to === \"string\" && ABSOLUTE_URL_REGEX2.test(to);\n let parsed = parseToInfo(to, basename);\n to = parsed.to;\n let href = useHref(to, { relative });\n let location = useLocation();\n let maskedHref = null;\n if (unstable_mask) {\n let resolved = resolveTo(\n unstable_mask,\n [],\n location.unstable_mask ? location.unstable_mask.pathname : \"/\",\n true\n );\n if (basename !== \"/\") {\n resolved.pathname = resolved.pathname === \"/\" ? basename : joinPaths([basename, resolved.pathname]);\n }\n maskedHref = navigator.createHref(resolved);\n }\n let [shouldPrefetch, prefetchRef, prefetchHandlers] = usePrefetchBehavior(\n prefetch,\n rest\n );\n let internalOnClick = useLinkClickHandler(to, {\n replace: replace2,\n unstable_mask,\n state,\n target,\n preventScrollReset,\n relative,\n viewTransition,\n unstable_defaultShouldRevalidate,\n unstable_useTransitions\n });\n function handleClick(event) {\n if (onClick) onClick(event);\n if (!event.defaultPrevented) {\n internalOnClick(event);\n }\n }\n let isSpaLink = !(parsed.isExternal || reloadDocument);\n let link = (\n // eslint-disable-next-line jsx-a11y/anchor-has-content\n /* @__PURE__ */ React10.createElement(\n \"a\",\n {\n ...rest,\n ...prefetchHandlers,\n href: (isSpaLink ? maskedHref : void 0) || parsed.absoluteURL || href,\n onClick: isSpaLink ? handleClick : onClick,\n ref: mergeRefs(forwardedRef, prefetchRef),\n target,\n \"data-discover\": !isAbsolute && discover === \"render\" ? \"true\" : void 0\n }\n )\n );\n return shouldPrefetch && !isAbsolute ? /* @__PURE__ */ React10.createElement(React10.Fragment, null, link, /* @__PURE__ */ React10.createElement(PrefetchPageLinks, { page: href })) : link;\n }\n);\nLink.displayName = \"Link\";\nvar NavLink = React10.forwardRef(\n function NavLinkWithRef({\n \"aria-current\": ariaCurrentProp = \"page\",\n caseSensitive = false,\n className: classNameProp = \"\",\n end = false,\n style: styleProp,\n to,\n viewTransition,\n children,\n ...rest\n }, ref) {\n let path = useResolvedPath(to, { relative: rest.relative });\n let location = useLocation();\n let routerState = React10.useContext(DataRouterStateContext);\n let { navigator, basename } = React10.useContext(NavigationContext);\n let isTransitioning = routerState != null && // Conditional usage is OK here because the usage of a data router is static\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useViewTransitionState(path) && viewTransition === true;\n let toPathname = navigator.encodeLocation ? navigator.encodeLocation(path).pathname : path.pathname;\n let locationPathname = location.pathname;\n let nextLocationPathname = routerState && routerState.navigation && routerState.navigation.location ? routerState.navigation.location.pathname : null;\n if (!caseSensitive) {\n locationPathname = locationPathname.toLowerCase();\n nextLocationPathname = nextLocationPathname ? nextLocationPathname.toLowerCase() : null;\n toPathname = toPathname.toLowerCase();\n }\n if (nextLocationPathname && basename) {\n nextLocationPathname = stripBasename(nextLocationPathname, basename) || nextLocationPathname;\n }\n const endSlashPosition = toPathname !== \"/\" && toPathname.endsWith(\"/\") ? toPathname.length - 1 : toPathname.length;\n let isActive = locationPathname === toPathname || !end && locationPathname.startsWith(toPathname) && locationPathname.charAt(endSlashPosition) === \"/\";\n let isPending = nextLocationPathname != null && (nextLocationPathname === toPathname || !end && nextLocationPathname.startsWith(toPathname) && nextLocationPathname.charAt(toPathname.length) === \"/\");\n let renderProps = {\n isActive,\n isPending,\n isTransitioning\n };\n let ariaCurrent = isActive ? ariaCurrentProp : void 0;\n let className;\n if (typeof classNameProp === \"function\") {\n className = classNameProp(renderProps);\n } else {\n className = [\n classNameProp,\n isActive ? \"active\" : null,\n isPending ? \"pending\" : null,\n isTransitioning ? \"transitioning\" : null\n ].filter(Boolean).join(\" \");\n }\n let style = typeof styleProp === \"function\" ? styleProp(renderProps) : styleProp;\n return /* @__PURE__ */ React10.createElement(\n Link,\n {\n ...rest,\n \"aria-current\": ariaCurrent,\n className,\n ref,\n style,\n to,\n viewTransition\n },\n typeof children === \"function\" ? children(renderProps) : children\n );\n }\n);\nNavLink.displayName = \"NavLink\";\nvar Form = React10.forwardRef(\n ({\n discover = \"render\",\n fetcherKey,\n navigate,\n reloadDocument,\n replace: replace2,\n state,\n method = defaultMethod,\n action,\n onSubmit,\n relative,\n preventScrollReset,\n viewTransition,\n unstable_defaultShouldRevalidate,\n ...props\n }, forwardedRef) => {\n let { unstable_useTransitions } = React10.useContext(NavigationContext);\n let submit = useSubmit();\n let formAction = useFormAction(action, { relative });\n let formMethod = method.toLowerCase() === \"get\" ? \"get\" : \"post\";\n let isAbsolute = typeof action === \"string\" && ABSOLUTE_URL_REGEX2.test(action);\n let submitHandler = (event) => {\n onSubmit && onSubmit(event);\n if (event.defaultPrevented) return;\n event.preventDefault();\n let submitter = event.nativeEvent.submitter;\n let submitMethod = submitter?.getAttribute(\"formmethod\") || method;\n let doSubmit = () => submit(submitter || event.currentTarget, {\n fetcherKey,\n method: submitMethod,\n navigate,\n replace: replace2,\n state,\n relative,\n preventScrollReset,\n viewTransition,\n unstable_defaultShouldRevalidate\n });\n if (unstable_useTransitions && navigate !== false) {\n React10.startTransition(() => doSubmit());\n } else {\n doSubmit();\n }\n };\n return /* @__PURE__ */ React10.createElement(\n \"form\",\n {\n ref: forwardedRef,\n method: formMethod,\n action: formAction,\n onSubmit: reloadDocument ? onSubmit : submitHandler,\n ...props,\n \"data-discover\": !isAbsolute && discover === \"render\" ? \"true\" : void 0\n }\n );\n }\n);\nForm.displayName = \"Form\";\nfunction ScrollRestoration({\n getKey,\n storageKey,\n ...props\n}) {\n let remixContext = React10.useContext(FrameworkContext);\n let { basename } = React10.useContext(NavigationContext);\n let location = useLocation();\n let matches = useMatches();\n useScrollRestoration({ getKey, storageKey });\n let ssrKey = React10.useMemo(\n () => {\n if (!remixContext || !getKey) return null;\n let userKey = getScrollRestorationKey(\n location,\n matches,\n basename,\n getKey\n );\n return userKey !== location.key ? userKey : null;\n },\n // Nah, we only need this the first time for the SSR render\n // eslint-disable-next-line react-hooks/exhaustive-deps\n []\n );\n if (!remixContext || remixContext.isSpaMode) {\n return null;\n }\n let restoreScroll = ((storageKey2, restoreKey) => {\n if (!window.history.state || !window.history.state.key) {\n let key = Math.random().toString(32).slice(2);\n window.history.replaceState({ key }, \"\");\n }\n try {\n let positions = JSON.parse(sessionStorage.getItem(storageKey2) || \"{}\");\n let storedY = positions[restoreKey || window.history.state.key];\n if (typeof storedY === \"number\") {\n window.scrollTo(0, storedY);\n }\n } catch (error) {\n console.error(error);\n sessionStorage.removeItem(storageKey2);\n }\n }).toString();\n return /* @__PURE__ */ React10.createElement(\n \"script\",\n {\n ...props,\n suppressHydrationWarning: true,\n dangerouslySetInnerHTML: {\n __html: `(${restoreScroll})(${escapeHtml(\n JSON.stringify(storageKey || SCROLL_RESTORATION_STORAGE_KEY)\n )}, ${escapeHtml(JSON.stringify(ssrKey))})`\n }\n }\n );\n}\nScrollRestoration.displayName = \"ScrollRestoration\";\nfunction getDataRouterConsoleError2(hookName) {\n return `${hookName} must be used within a data router. See https://reactrouter.com/en/main/routers/picking-a-router.`;\n}\nfunction useDataRouterContext3(hookName) {\n let ctx = React10.useContext(DataRouterContext);\n invariant(ctx, getDataRouterConsoleError2(hookName));\n return ctx;\n}\nfunction useDataRouterState2(hookName) {\n let state = React10.useContext(DataRouterStateContext);\n invariant(state, getDataRouterConsoleError2(hookName));\n return state;\n}\nfunction useLinkClickHandler(to, {\n target,\n replace: replaceProp,\n unstable_mask,\n state,\n preventScrollReset,\n relative,\n viewTransition,\n unstable_defaultShouldRevalidate,\n unstable_useTransitions\n} = {}) {\n let navigate = useNavigate();\n let location = useLocation();\n let path = useResolvedPath(to, { relative });\n return React10.useCallback(\n (event) => {\n if (shouldProcessLinkClick(event, target)) {\n event.preventDefault();\n let replace2 = replaceProp !== void 0 ? replaceProp : createPath(location) === createPath(path);\n let doNavigate = () => navigate(to, {\n replace: replace2,\n unstable_mask,\n state,\n preventScrollReset,\n relative,\n viewTransition,\n unstable_defaultShouldRevalidate\n });\n if (unstable_useTransitions) {\n React10.startTransition(() => doNavigate());\n } else {\n doNavigate();\n }\n }\n },\n [\n location,\n navigate,\n path,\n replaceProp,\n unstable_mask,\n state,\n target,\n to,\n preventScrollReset,\n relative,\n viewTransition,\n unstable_defaultShouldRevalidate,\n unstable_useTransitions\n ]\n );\n}\nfunction useSearchParams(defaultInit) {\n warning(\n typeof URLSearchParams !== \"undefined\",\n `You cannot use the \\`useSearchParams\\` hook in a browser that does not support the URLSearchParams API. If you need to support Internet Explorer 11, we recommend you load a polyfill such as https://github.com/ungap/url-search-params.`\n );\n let defaultSearchParamsRef = React10.useRef(createSearchParams(defaultInit));\n let hasSetSearchParamsRef = React10.useRef(false);\n let location = useLocation();\n let searchParams = React10.useMemo(\n () => (\n // Only merge in the defaults if we haven't yet called setSearchParams.\n // Once we call that we want those to take precedence, otherwise you can't\n // remove a param with setSearchParams({}) if it has an initial value\n getSearchParamsForLocation(\n location.search,\n hasSetSearchParamsRef.current ? null : defaultSearchParamsRef.current\n )\n ),\n [location.search]\n );\n let navigate = useNavigate();\n let setSearchParams = React10.useCallback(\n (nextInit, navigateOptions) => {\n const newSearchParams = createSearchParams(\n typeof nextInit === \"function\" ? nextInit(new URLSearchParams(searchParams)) : nextInit\n );\n hasSetSearchParamsRef.current = true;\n navigate(\"?\" + newSearchParams, navigateOptions);\n },\n [navigate, searchParams]\n );\n return [searchParams, setSearchParams];\n}\nvar fetcherId = 0;\nvar getUniqueFetcherId = () => `__${String(++fetcherId)}__`;\nfunction useSubmit() {\n let { router } = useDataRouterContext3(\"useSubmit\" /* UseSubmit */);\n let { basename } = React10.useContext(NavigationContext);\n let currentRouteId = useRouteId();\n let routerFetch = router.fetch;\n let routerNavigate = router.navigate;\n return React10.useCallback(\n async (target, options = {}) => {\n let { action, method, encType, formData, body } = getFormSubmissionInfo(\n target,\n basename\n );\n if (options.navigate === false) {\n let key = options.fetcherKey || getUniqueFetcherId();\n await routerFetch(key, currentRouteId, options.action || action, {\n unstable_defaultShouldRevalidate: options.unstable_defaultShouldRevalidate,\n preventScrollReset: options.preventScrollReset,\n formData,\n body,\n formMethod: options.method || method,\n formEncType: options.encType || encType,\n flushSync: options.flushSync\n });\n } else {\n await routerNavigate(options.action || action, {\n unstable_defaultShouldRevalidate: options.unstable_defaultShouldRevalidate,\n preventScrollReset: options.preventScrollReset,\n formData,\n body,\n formMethod: options.method || method,\n formEncType: options.encType || encType,\n replace: options.replace,\n state: options.state,\n fromRouteId: currentRouteId,\n flushSync: options.flushSync,\n viewTransition: options.viewTransition\n });\n }\n },\n [routerFetch, routerNavigate, basename, currentRouteId]\n );\n}\nfunction useFormAction(action, { relative } = {}) {\n let { basename } = React10.useContext(NavigationContext);\n let routeContext = React10.useContext(RouteContext);\n invariant(routeContext, \"useFormAction must be used inside a RouteContext\");\n let [match] = routeContext.matches.slice(-1);\n let path = { ...useResolvedPath(action ? action : \".\", { relative }) };\n let location = useLocation();\n if (action == null) {\n path.search = location.search;\n let params = new URLSearchParams(path.search);\n let indexValues = params.getAll(\"index\");\n let hasNakedIndexParam = indexValues.some((v) => v === \"\");\n if (hasNakedIndexParam) {\n params.delete(\"index\");\n indexValues.filter((v) => v).forEach((v) => params.append(\"index\", v));\n let qs = params.toString();\n path.search = qs ? `?${qs}` : \"\";\n }\n }\n if ((!action || action === \".\") && match.route.index) {\n path.search = path.search ? path.search.replace(/^\\?/, \"?index&\") : \"?index\";\n }\n if (basename !== \"/\") {\n path.pathname = path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n }\n return createPath(path);\n}\nfunction useFetcher({\n key\n} = {}) {\n let { router } = useDataRouterContext3(\"useFetcher\" /* UseFetcher */);\n let state = useDataRouterState2(\"useFetcher\" /* UseFetcher */);\n let fetcherData = React10.useContext(FetchersContext);\n let route = React10.useContext(RouteContext);\n let routeId = route.matches[route.matches.length - 1]?.route.id;\n invariant(fetcherData, `useFetcher must be used inside a FetchersContext`);\n invariant(route, `useFetcher must be used inside a RouteContext`);\n invariant(\n routeId != null,\n `useFetcher can only be used on routes that contain a unique \"id\"`\n );\n let defaultKey = React10.useId();\n let [fetcherKey, setFetcherKey] = React10.useState(key || defaultKey);\n if (key && key !== fetcherKey) {\n setFetcherKey(key);\n }\n let { deleteFetcher, getFetcher, resetFetcher, fetch: routerFetch } = router;\n React10.useEffect(() => {\n getFetcher(fetcherKey);\n return () => deleteFetcher(fetcherKey);\n }, [deleteFetcher, getFetcher, fetcherKey]);\n let load = React10.useCallback(\n async (href, opts) => {\n invariant(routeId, \"No routeId available for fetcher.load()\");\n await routerFetch(fetcherKey, routeId, href, opts);\n },\n [fetcherKey, routeId, routerFetch]\n );\n let submitImpl = useSubmit();\n let submit = React10.useCallback(\n async (target, opts) => {\n await submitImpl(target, {\n ...opts,\n navigate: false,\n fetcherKey\n });\n },\n [fetcherKey, submitImpl]\n );\n let reset = React10.useCallback(\n (opts) => resetFetcher(fetcherKey, opts),\n [resetFetcher, fetcherKey]\n );\n let FetcherForm = React10.useMemo(() => {\n let FetcherForm2 = React10.forwardRef(\n (props, ref) => {\n return /* @__PURE__ */ React10.createElement(Form, { ...props, navigate: false, fetcherKey, ref });\n }\n );\n FetcherForm2.displayName = \"fetcher.Form\";\n return FetcherForm2;\n }, [fetcherKey]);\n let fetcher = state.fetchers.get(fetcherKey) || IDLE_FETCHER;\n let data2 = fetcherData.get(fetcherKey);\n let fetcherWithComponents = React10.useMemo(\n () => ({\n Form: FetcherForm,\n submit,\n load,\n reset,\n ...fetcher,\n data: data2\n }),\n [FetcherForm, submit, load, reset, fetcher, data2]\n );\n return fetcherWithComponents;\n}\nfunction useFetchers() {\n let state = useDataRouterState2(\"useFetchers\" /* UseFetchers */);\n return Array.from(state.fetchers.entries()).map(([key, fetcher]) => ({\n ...fetcher,\n key\n }));\n}\nvar SCROLL_RESTORATION_STORAGE_KEY = \"react-router-scroll-positions\";\nvar savedScrollPositions = {};\nfunction getScrollRestorationKey(location, matches, basename, getKey) {\n let key = null;\n if (getKey) {\n if (basename !== \"/\") {\n key = getKey(\n {\n ...location,\n pathname: stripBasename(location.pathname, basename) || location.pathname\n },\n matches\n );\n } else {\n key = getKey(location, matches);\n }\n }\n if (key == null) {\n key = location.key;\n }\n return key;\n}\nfunction useScrollRestoration({\n getKey,\n storageKey\n} = {}) {\n let { router } = useDataRouterContext3(\"useScrollRestoration\" /* UseScrollRestoration */);\n let { restoreScrollPosition, preventScrollReset } = useDataRouterState2(\n \"useScrollRestoration\" /* UseScrollRestoration */\n );\n let { basename } = React10.useContext(NavigationContext);\n let location = useLocation();\n let matches = useMatches();\n let navigation = useNavigation();\n React10.useEffect(() => {\n window.history.scrollRestoration = \"manual\";\n return () => {\n window.history.scrollRestoration = \"auto\";\n };\n }, []);\n usePageHide(\n React10.useCallback(() => {\n if (navigation.state === \"idle\") {\n let key = getScrollRestorationKey(location, matches, basename, getKey);\n savedScrollPositions[key] = window.scrollY;\n }\n try {\n sessionStorage.setItem(\n storageKey || SCROLL_RESTORATION_STORAGE_KEY,\n JSON.stringify(savedScrollPositions)\n );\n } catch (error) {\n warning(\n false,\n `Failed to save scroll positions in sessionStorage, <ScrollRestoration /> will not work properly (${error}).`\n );\n }\n window.history.scrollRestoration = \"auto\";\n }, [navigation.state, getKey, basename, location, matches, storageKey])\n );\n if (typeof document !== \"undefined\") {\n React10.useLayoutEffect(() => {\n try {\n let sessionPositions = sessionStorage.getItem(\n storageKey || SCROLL_RESTORATION_STORAGE_KEY\n );\n if (sessionPositions) {\n savedScrollPositions = JSON.parse(sessionPositions);\n }\n } catch (e) {\n }\n }, [storageKey]);\n React10.useLayoutEffect(() => {\n let disableScrollRestoration = router?.enableScrollRestoration(\n savedScrollPositions,\n () => window.scrollY,\n getKey ? (location2, matches2) => getScrollRestorationKey(location2, matches2, basename, getKey) : void 0\n );\n return () => disableScrollRestoration && disableScrollRestoration();\n }, [router, basename, getKey]);\n React10.useLayoutEffect(() => {\n if (restoreScrollPosition === false) {\n return;\n }\n if (typeof restoreScrollPosition === \"number\") {\n window.scrollTo(0, restoreScrollPosition);\n return;\n }\n try {\n if (location.hash) {\n let el = document.getElementById(\n decodeURIComponent(location.hash.slice(1))\n );\n if (el) {\n el.scrollIntoView();\n return;\n }\n }\n } catch {\n warning(\n false,\n `\"${location.hash.slice(\n 1\n )}\" is not a decodable element ID. The view will not scroll to it.`\n );\n }\n if (preventScrollReset === true) {\n return;\n }\n window.scrollTo(0, 0);\n }, [location, restoreScrollPosition, preventScrollReset]);\n }\n}\nfunction useBeforeUnload(callback, options) {\n let { capture } = options || {};\n React10.useEffect(() => {\n let opts = capture != null ? { capture } : void 0;\n window.addEventListener(\"beforeunload\", callback, opts);\n return () => {\n window.removeEventListener(\"beforeunload\", callback, opts);\n };\n }, [callback, capture]);\n}\nfunction usePageHide(callback, options) {\n let { capture } = options || {};\n React10.useEffect(() => {\n let opts = capture != null ? { capture } : void 0;\n window.addEventListener(\"pagehide\", callback, opts);\n return () => {\n window.removeEventListener(\"pagehide\", callback, opts);\n };\n }, [callback, capture]);\n}\nfunction usePrompt({\n when,\n message\n}) {\n let blocker = useBlocker(when);\n React10.useEffect(() => {\n if (blocker.state === \"blocked\") {\n let proceed = window.confirm(message);\n if (proceed) {\n setTimeout(blocker.proceed, 0);\n } else {\n blocker.reset();\n }\n }\n }, [blocker, message]);\n React10.useEffect(() => {\n if (blocker.state === \"blocked\" && !when) {\n blocker.reset();\n }\n }, [blocker, when]);\n}\nfunction useViewTransitionState(to, { relative } = {}) {\n let vtContext = React10.useContext(ViewTransitionContext);\n invariant(\n vtContext != null,\n \"`useViewTransitionState` must be used within `react-router-dom`'s `RouterProvider`. Did you accidentally import `RouterProvider` from `react-router`?\"\n );\n let { basename } = useDataRouterContext3(\n \"useViewTransitionState\" /* useViewTransitionState */\n );\n let path = useResolvedPath(to, { relative });\n if (!vtContext.isTransitioning) {\n return false;\n }\n let currentPath = stripBasename(vtContext.currentLocation.pathname, basename) || vtContext.currentLocation.pathname;\n let nextPath = stripBasename(vtContext.nextLocation.pathname, basename) || vtContext.nextLocation.pathname;\n return matchPath(path.pathname, nextPath) != null || matchPath(path.pathname, currentPath) != null;\n}\n\n// lib/dom/server.tsx\nimport * as React11 from \"react\";\nfunction StaticRouter({\n basename,\n children,\n location: locationProp = \"/\"\n}) {\n if (typeof locationProp === \"string\") {\n locationProp = parsePath(locationProp);\n }\n let action = \"POP\" /* Pop */;\n let location = {\n pathname: locationProp.pathname || \"/\",\n search: locationProp.search || \"\",\n hash: locationProp.hash || \"\",\n state: locationProp.state != null ? locationProp.state : null,\n key: locationProp.key || \"default\",\n unstable_mask: void 0\n };\n let staticNavigator = getStatelessNavigator();\n return /* @__PURE__ */ React11.createElement(\n Router,\n {\n basename,\n children,\n location,\n navigationType: action,\n navigator: staticNavigator,\n static: true,\n unstable_useTransitions: false\n }\n );\n}\nfunction StaticRouterProvider({\n context,\n router,\n hydrate: hydrate2 = true,\n nonce\n}) {\n invariant(\n router && context,\n \"You must provide `router` and `context` to <StaticRouterProvider>\"\n );\n let dataRouterContext = {\n router,\n navigator: getStatelessNavigator(),\n static: true,\n staticContext: context,\n basename: context.basename || \"/\"\n };\n let fetchersContext = /* @__PURE__ */ new Map();\n let hydrateScript = \"\";\n if (hydrate2 !== false) {\n let data2 = {\n loaderData: context.loaderData,\n actionData: context.actionData,\n errors: serializeErrors(context.errors)\n };\n let json = escapeHtml(JSON.stringify(JSON.stringify(data2)));\n hydrateScript = `window.__staticRouterHydrationData = JSON.parse(${json});`;\n }\n let { state } = dataRouterContext.router;\n return /* @__PURE__ */ React11.createElement(React11.Fragment, null, /* @__PURE__ */ React11.createElement(DataRouterContext.Provider, { value: dataRouterContext }, /* @__PURE__ */ React11.createElement(DataRouterStateContext.Provider, { value: state }, /* @__PURE__ */ React11.createElement(FetchersContext.Provider, { value: fetchersContext }, /* @__PURE__ */ React11.createElement(ViewTransitionContext.Provider, { value: { isTransitioning: false } }, /* @__PURE__ */ React11.createElement(\n Router,\n {\n basename: dataRouterContext.basename,\n location: state.location,\n navigationType: state.historyAction,\n navigator: dataRouterContext.navigator,\n static: dataRouterContext.static,\n unstable_useTransitions: false\n },\n /* @__PURE__ */ React11.createElement(\n DataRoutes,\n {\n routes: router.routes,\n future: router.future,\n state,\n isStatic: true\n }\n )\n ))))), hydrateScript ? /* @__PURE__ */ React11.createElement(\n \"script\",\n {\n suppressHydrationWarning: true,\n nonce,\n dangerouslySetInnerHTML: { __html: hydrateScript }\n }\n ) : null);\n}\nfunction serializeErrors(errors) {\n if (!errors) return null;\n let entries = Object.entries(errors);\n let serialized = {};\n for (let [key, val] of entries) {\n if (isRouteErrorResponse(val)) {\n serialized[key] = { ...val, __type: \"RouteErrorResponse\" };\n } else if (val instanceof Error) {\n serialized[key] = {\n message: val.message,\n __type: \"Error\",\n // If this is a subclass (i.e., ReferenceError), send up the type so we\n // can re-create the same type during hydration.\n ...val.name !== \"Error\" ? {\n __subType: val.name\n } : {}\n };\n } else {\n serialized[key] = val;\n }\n }\n return serialized;\n}\nfunction getStatelessNavigator() {\n return {\n createHref,\n encodeLocation,\n push(to) {\n throw new Error(\n `You cannot use navigator.push() on the server because it is a stateless environment. This error was probably triggered when you did a \\`navigate(${JSON.stringify(to)})\\` somewhere in your app.`\n );\n },\n replace(to) {\n throw new Error(\n `You cannot use navigator.replace() on the server because it is a stateless environment. This error was probably triggered when you did a \\`navigate(${JSON.stringify(to)}, { replace: true })\\` somewhere in your app.`\n );\n },\n go(delta) {\n throw new Error(\n `You cannot use navigator.go() on the server because it is a stateless environment. This error was probably triggered when you did a \\`navigate(${delta})\\` somewhere in your app.`\n );\n },\n back() {\n throw new Error(\n `You cannot use navigator.back() on the server because it is a stateless environment.`\n );\n },\n forward() {\n throw new Error(\n `You cannot use navigator.forward() on the server because it is a stateless environment.`\n );\n }\n };\n}\nfunction createStaticHandler2(routes, opts) {\n return createStaticHandler(routes, {\n ...opts,\n mapRouteProperties\n });\n}\nfunction createStaticRouter(routes, context, opts = {}) {\n let manifest = {};\n let dataRoutes = convertRoutesToDataRoutes(\n routes,\n mapRouteProperties,\n void 0,\n manifest\n );\n let matches = context.matches.map((match) => {\n let route = manifest[match.route.id] || match.route;\n return {\n ...match,\n route\n };\n });\n let msg = (method) => `You cannot use router.${method}() on the server because it is a stateless environment`;\n return {\n get basename() {\n return context.basename;\n },\n get future() {\n return {\n v8_middleware: false,\n unstable_passThroughRequests: false,\n ...opts?.future\n };\n },\n get state() {\n return {\n historyAction: \"POP\" /* Pop */,\n location: context.location,\n matches,\n loaderData: context.loaderData,\n actionData: context.actionData,\n errors: context.errors,\n initialized: true,\n renderFallback: false,\n navigation: IDLE_NAVIGATION,\n restoreScrollPosition: null,\n preventScrollReset: false,\n revalidation: \"idle\",\n fetchers: /* @__PURE__ */ new Map(),\n blockers: /* @__PURE__ */ new Map()\n };\n },\n get routes() {\n return dataRoutes;\n },\n get window() {\n return void 0;\n },\n initialize() {\n throw msg(\"initialize\");\n },\n subscribe() {\n throw msg(\"subscribe\");\n },\n enableScrollRestoration() {\n throw msg(\"enableScrollRestoration\");\n },\n navigate() {\n throw msg(\"navigate\");\n },\n fetch() {\n throw msg(\"fetch\");\n },\n revalidate() {\n throw msg(\"revalidate\");\n },\n createHref,\n encodeLocation,\n getFetcher() {\n return IDLE_FETCHER;\n },\n deleteFetcher() {\n throw msg(\"deleteFetcher\");\n },\n resetFetcher() {\n throw msg(\"resetFetcher\");\n },\n dispose() {\n throw msg(\"dispose\");\n },\n getBlocker() {\n return IDLE_BLOCKER;\n },\n deleteBlocker() {\n throw msg(\"deleteBlocker\");\n },\n patchRoutes() {\n throw msg(\"patchRoutes\");\n },\n _internalFetchControllers: /* @__PURE__ */ new Map(),\n _internalSetRoutes() {\n throw msg(\"_internalSetRoutes\");\n },\n _internalSetStateDoNotUseOrYouWillBreakYourApp() {\n throw msg(\"_internalSetStateDoNotUseOrYouWillBreakYourApp\");\n }\n };\n}\nfunction createHref(to) {\n return typeof to === \"string\" ? to : createPath(to);\n}\nfunction encodeLocation(to) {\n let href = typeof to === \"string\" ? to : createPath(to);\n href = href.replace(/ $/, \"%20\");\n let encoded = ABSOLUTE_URL_REGEX3.test(href) ? new URL(href) : new URL(href, \"http://localhost\");\n return {\n pathname: encoded.pathname,\n search: encoded.search,\n hash: encoded.hash\n };\n}\nvar ABSOLUTE_URL_REGEX3 = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\n\nexport {\n Action,\n createMemoryHistory,\n createBrowserHistory,\n createHashHistory,\n invariant,\n createPath,\n parsePath,\n createContext,\n RouterContextProvider,\n convertRoutesToDataRoutes,\n matchRoutes,\n generatePath,\n matchPath,\n stripBasename,\n resolvePath,\n data,\n redirect,\n redirectDocument,\n replace,\n ErrorResponseImpl,\n isRouteErrorResponse,\n instrumentHandler,\n IDLE_NAVIGATION,\n IDLE_FETCHER,\n IDLE_BLOCKER,\n createRouter,\n createStaticHandler,\n getStaticContextFromError,\n invalidProtocols,\n isDataWithResponseInit,\n isResponse,\n isRedirectStatusCode,\n isRedirectResponse,\n isMutationMethod,\n DataRouterContext,\n DataRouterStateContext,\n RSCRouterContext,\n ViewTransitionContext,\n FetchersContext,\n AwaitContextProvider,\n NavigationContext,\n LocationContext,\n RouteContext,\n ENABLE_DEV_WARNINGS,\n decodeRedirectErrorDigest,\n decodeRouteErrorResponseDigest,\n useHref,\n useInRouterContext,\n useLocation,\n useNavigationType,\n useMatch,\n useNavigate,\n useOutletContext,\n useOutlet,\n useParams,\n useResolvedPath,\n useRoutes,\n useNavigation,\n useRevalidator,\n useMatches,\n useLoaderData,\n useRouteLoaderData,\n useActionData,\n useRouteError,\n useAsyncValue,\n useAsyncError,\n useBlocker,\n useRoute,\n warnOnce,\n mapRouteProperties,\n hydrationRouteProperties,\n createMemoryRouter,\n RouterProvider,\n MemoryRouter,\n Navigate,\n Outlet,\n Route,\n Router,\n Routes,\n Await,\n createRoutesFromChildren,\n createRoutesFromElements,\n renderMatches,\n WithComponentProps,\n withComponentProps,\n WithHydrateFallbackProps,\n withHydrateFallbackProps,\n WithErrorBoundaryProps,\n withErrorBoundaryProps,\n createSearchParams,\n escapeHtml,\n encode,\n createRequestInit,\n SingleFetchRedirectSymbol,\n SINGLE_FETCH_REDIRECT_STATUS,\n NO_BODY_STATUS_CODES,\n StreamTransfer,\n getTurboStreamSingleFetchDataStrategy,\n getSingleFetchDataStrategyImpl,\n stripIndexParam,\n singleFetchUrl,\n decodeViaTurboStream,\n RemixErrorBoundary,\n createServerRoutes,\n createClientRoutesWithHMRRevalidationOptOut,\n noActionDefinedError,\n createClientRoutes,\n shouldHydrateRouteLoader,\n getPatchRoutesOnNavigationFunction,\n useFogOFWarDiscovery,\n getManifestPath,\n FrameworkContext,\n CRITICAL_CSS_DATA_ATTRIBUTE,\n Links,\n PrefetchPageLinks,\n Meta,\n setIsHydrated,\n Scripts,\n createBrowserRouter,\n createHashRouter,\n BrowserRouter,\n HashRouter,\n HistoryRouter,\n Link,\n NavLink,\n Form,\n ScrollRestoration,\n useLinkClickHandler,\n useSearchParams,\n useSubmit,\n useFormAction,\n useFetcher,\n useFetchers,\n useScrollRestoration,\n useBeforeUnload,\n usePrompt,\n useViewTransitionState,\n StaticRouter,\n StaticRouterProvider,\n createStaticHandler2,\n createStaticRouter\n};\n","import { Link } from \"react-router-dom\";\nimport { 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 <Link className={containerClassname} style={containerStyle} to={link}>\n <span>{text}</span>\n </Link>\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","// 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 {\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 <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 <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 {\n Popover as UiPopover,\n PopoverContent,\n PopoverTrigger,\n} 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 setOpen(!open);\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 }, [open, setOpen, target, toggle, updateRect]);\n\n return (\n <UiPopover open={open} onOpenChange={setOpen}>\n <PopoverTrigger asChild>\n <span\n className={css.anchor}\n style={rect ? { left: rect.left, top: rect.top, width: rect.width, height: rect.height } : undefined}\n />\n </PopoverTrigger>\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","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","i","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","invariant","message","warning","cond","createPath","pathname","search","hash","parsePath","parsedPath","hashIndex","searchIndex","matchRoutes","routes","locationArg","basename","matchRoutesImpl","allowPartial","location","stripBasename","branches","flattenRoutes","rankRouteBranches","matches","decoded","decodePath","matchRouteBranch","parentsMeta","parentPath","_hasParentOptionalSegments","flattenRoute","route","hasParentOptionalSegments","relativePath","meta","joinPaths","routesMeta","computeScore","exploded","explodeOptionalSegments","segments","first","isOptional","required","restExploded","subpath","a","b","compareIndexes","paramRe","dynamicSegmentValue","indexRouteValue","emptySegmentValue","staticSegmentValue","splatPenalty","isSplat","s","initialScore","score","segment","branch","matchedParams","matchedPathname","end","remainingPathname","match","matchPath","normalizePathname","pattern","matcher","compiledParams","compilePath","pathnameBase","captureGroups","memo2","paramName","splatValue","caseSensitive","params","regexpSource","str","nextChar","v","error","ABSOLUTE_URL_REGEX","resolvePath","to","fromPathname","toPathname","removeDoubleSlashes","resolvePathname","normalizeSearch","normalizeHash","removeTrailingSlash","getInvalidPathError","char","field","dest","getPathContributingMatches","getResolveToMatches","pathMatches","idx","resolveTo","toArg","routePathnames","locationPathname","isPathRelative","isEmptyPath","from","routePathnameIndex","toSegments","hasExplicitTrailingSlash","hasCurrentTrailingSlash","paths","ErrorResponseImpl","status","statusText","data2","internal","isRouteErrorResponse","getRoutePattern","m","isBrowser","parseToInfo","_to","absoluteURL","currentUrl","targetUrl","validMutationMethodsArr","validRequestMethodsArr","DataRouterContext","DataRouterStateContext","RSCRouterContext","useIsRSCRouterContext","ViewTransitionContext","FetchersContext","AwaitContext","NavigationContext","LocationContext","RouteContext","RouteErrorContext","ERROR_DIGEST_BASE","ERROR_DIGEST_REDIRECT","ERROR_DIGEST_ROUTE_ERROR_RESPONSE","decodeRedirectErrorDigest","digest","parsed","decodeRouteErrorResponseDigest","useHref","relative","useInRouterContext","navigator","React2","useResolvedPath","joinedPathname","useLocation","navigateEffectWarning","useIsomorphicLayoutEffect","cb","useNavigate","isDataRoute","useNavigateStable","useNavigateUnstable","dataRouterContext","routePathnamesJson","activeRef","options","useRoutesImpl","dataRouterOpts","parentMatches","routeMatch","parentParams","parentPathname","parentPathnameBase","parentRoute","warningOnce","locationFromContext","parentSegments","_renderMatches","DefaultErrorComponent","useRouteError","stack","lightgrey","preStyles","codeStyles","devInfo","defaultErrorElement","RenderErrorBoundary","state","errorInfo","RSCErrorHandler","errorRedirectHandledMap","redirect2","existingRedirect","redirectPromise","RenderedRoute","routeContext","dataRouterState","renderedMatches","errors","errorIndex","renderFallback","fallbackIndex","loaderData","errors2","needsToRunLoader","onErrorHandler","onError","outlet","shouldRenderHydrateFallback","errorElement","hydrateFallbackElement","matches2","getChildren","getDataRouterConsoleError","hookName","useDataRouterContext","ctx","useDataRouterState","useRouteContext","useCurrentRouteId","thisRoute","useRouteId","routeId","router","alreadyWarned","React3","DataRoutes","future","isStatic","defaultMethod","defaultEncType","isHtmlElement","object","isButtonElement","isFormElement","isInputElement","isModifiedEvent","event","shouldProcessLinkClick","target","_formDataSupportsSubmitter","isFormDataSubmitterSupported","supportedFormEncTypes","getFormEncType","encType","getFormSubmissionInfo","method","action","formData","body","attr","form","name","invariant2","singleFetchUrl","reqUrl","trailingSlashAware","extension","url","loadRouteModule","routeModulesCache","routeModule","isHtmlLinkDescriptor","getKeyedPrefetchLinks","manifest","routeModules","links","dedupeLinkDescriptors","link","getNewMatchesForLinks","page","nextMatches","currentMatches","mode","isNew","matchPathChanged","manifestRoute","routeChoice","getModuleLinkHrefs","includeHydrateFallback","dedupeHrefs","hrefs","sortKeys","obj","sorted","keys","descriptors","preloads","set","deduped","descriptor","useDataRouterContext2","context","React8","useDataRouterStateContext","FrameworkContext","useFrameworkContext","usePrefetchBehavior","prefetch","theirElementProps","frameworkContext","maybePrefetch","setMaybePrefetch","shouldPrefetch","setShouldPrefetch","onFocus","onBlur","onMouseEnter","onMouseLeave","onTouchStart","callback","observer","setIntent","cancelIntent","composeEventHandlers","theirHandler","ourHandler","PrefetchPageLinks","linkProps","rsc","RSCPrefetchPageLinksImpl","PrefetchPageLinksImpl","useKeyedPrefetchLinks","keyedPrefetchLinks","setKeyedPrefetchLinks","interrupted","dataHrefs","hasSomeRoutesWithShouldRevalidate","targetRoutes","href","newMatchesForData","newMatchesForAssets","routesParams","foundOptOutRoute","m2","moduleHrefs","mergeRefs","isBrowser2","ABSOLUTE_URL_REGEX2","Link","React10","onClick","discover","reloadDocument","replace2","unstable_mask","preventScrollReset","viewTransition","unstable_defaultShouldRevalidate","unstable_useTransitions","isAbsolute","maskedHref","resolved","prefetchRef","prefetchHandlers","internalOnClick","useLinkClickHandler","handleClick","isSpaLink","NavLink","ariaCurrentProp","classNameProp","styleProp","routerState","isTransitioning","useViewTransitionState","nextLocationPathname","endSlashPosition","isActive","isPending","renderProps","ariaCurrent","Form","fetcherKey","navigate","onSubmit","submit","useSubmit","formAction","useFormAction","formMethod","submitHandler","submitter","submitMethod","doSubmit","getDataRouterConsoleError2","useDataRouterContext3","replaceProp","doNavigate","fetcherId","getUniqueFetcherId","currentRouteId","routerFetch","routerNavigate","indexValues","qs","vtContext","currentPath","nextPath","Card","memo","text","backgroundColor","imageUrl","textColor","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","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","e","onDocClick","useLayoutEffect","container","arrowDirection","overlay","createPortal","Fragment","CopyTextTrigger","copied","tooltipText","ariaLabel","showIcon","CopyIcon","originalEventHandler","ourEventHandler","checkForDefaultPrevented","createContext2","rootComponentName","defaultContext","Context","Provider","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","ReactDOM","useCallbackRef","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","focusOutside","useFocusOutside","dispatchUpdate","handleUpdate","BRANCH_NAME","DismissableLayerBranch","handlePointerDownOutside","isPointerInsideReactTreeRef","handleClickRef","handlePointerDown","handleAndDispatchPointerDownOutsideEvent2","handleAndDispatchCustomEvent","eventDetail","timerId","handleFocusOutside","isFocusInsideReactTreeRef","handleFocus","handler","detail","discrete","useLayoutEffect2","useReactId","count","useId","deterministicId","setId","reactId","sides","min","max","round","floor","createCoords","oppositeSideMap","clamp","start","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","_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","_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","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","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","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","last","getTabbableEdges","candidates","select","candidate","findVisible","nodes","walker","isHiddenInput","isHidden","upTo","isSelectableInput","createFocusScopesStack","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","alreadyHidden","counterValue","markerValue","hideOthers","activeParentNode","__assign","__rest","t","__spreadArray","pack","l","ar","zeroRightClassName","fullWidthClassName","noScrollbarsClassName","removedBarSizeVariable","assignRef","initialValue","currentValues","useMergeRefs","defaultValue","newValue","oldValue","prevRefs_1","nextRefs_1","current_1","ItoI","innerCreateMedium","defaults","buffer","assigned","medium","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","_devMessageSet3","_len2","messages","_key2","_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","isPrevActive","isNextActive","TableDropdown","columns","total","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","setSearch","debouncedSearch","setDebouncedSearch","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","ancestorsToExpand","inferredChildren","fullPath","parentKey","existing","merged","ensureChildrenLoaded","toggleExpand","handleSelectNode","handleConfirm","isExpanded","nodeValue","clientFilter","renderNode","level","isNodeExpanded","isNodeLoading","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","trimmed","o","ApprovalRoute","levels","editable","eyebrow","loadApprovers","onAddLevel","onRemoveLevel","onAddStage","onRemoveStage","onAddApprover","onRemoveApprover","addLevelOpen","setAddLevelOpen","addStageFor","setAddStageFor","railClass","stage","person","WarnIcon"],"mappings":";;;;;AACK,MAACA,KAAU,CAACC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,KAAyB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,qCAAqC,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,qCAAqC,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,0BAA0B,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,CAAC,GCAzpBC,KAAW,CAACF,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,UAAU,WAAW,UAAU,WAAW,GAAG,m8BAAm8B,MAAM,eAAc,CAAE,CAAC,GCApuCE,KAAgB,CAACH,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,KAAK,EAAE,UAAU,yBAAwB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,qEAAqE,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oCAAoC,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,+CAA+C,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oDAAoD,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,+MAA+M,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,gNAAgN,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,CAAC,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,MAAsB,gBAAAA,EAAM,cAAc,YAAY,EAAE,IAAI,mBAAkB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAO,CAAE,CAAC,CAAC,CAAC,GCAx4DG,KAAgB,CAACJ,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,KAAK,EAAE,UAAU,yBAAwB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oKAAoK,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,SAAS,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,wEAAwE,QAAQ,gBAAgB,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,mCAAmC,QAAQ,gBAAgB,gBAAgB,QAAO,CAAE,CAAC,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,MAAsB,gBAAAA,EAAM,cAAc,YAAY,EAAE,IAAI,mBAAkB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAO,CAAE,CAAC,CAAC,CAAC,GCA/iCI,KAAc,CAACL,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,KAAyB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,yKAAyK,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,2KAA2K,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,2OAA2O,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,mDAAmD,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,mFAAmF,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oDAAoD,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,4BAA4B,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,CAAC,GCA95DK,KAAU,CAACN,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,mCAAmC,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,SAAS,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,6CAA6C,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,SAAS,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,2CAA2C,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,qDAAqD,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,SAAS,CAAC,GCAx6BM,KAAW,CAACP,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,KAAK,EAAE,UAAU,yBAAwB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,UAAU,WAAW,UAAU,WAAW,GAAG,oWAAoW,QAAQ,eAAc,CAAE,CAAC,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,MAAsB,gBAAAA,EAAM,cAAc,YAAY,EAAE,IAAI,mBAAkB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAO,CAAE,CAAC,CAAC,CAAC,GCAh7BO,KAAU,CAACR,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,KAAK,EAAE,UAAU,yBAAwB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,4iCAA4iC,MAAM,eAAc,CAAE,GAAmB,gBAAAA,EAAM,cAAc,UAAU,EAAE,IAAI,SAAS,IAAI,SAAS,GAAG,UAAU,MAAM,eAAc,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,iLAAiL,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,QAAO,CAAE,CAAC,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,MAAsB,gBAAAA,EAAM,cAAc,YAAY,EAAE,IAAI,mBAAkB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAO,CAAE,CAAC,CAAC,CAAC,GCAz+DQ,KAAU,CAACT,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAQ,QAAQ,gBAAgB,aAAa,GAAG,eAAe,SAAS,gBAAgB,SAAS,OAAO;AAAA,EACtQ,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,MAAM,QAAQ,GAAG,oNAAoN,CAAC,GCF7RS,KAAY,CAACV,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,gNAAgN,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,+CAA+C,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,SAAS,CAAC,GCA3rBU,KAAW,CAACX,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,KAAK,EAAE,UAAU,yBAAwB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,mhBAAmhB,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,QAAO,CAAE,CAAC,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,MAAsB,gBAAAA,EAAM,cAAc,YAAY,EAAE,IAAI,mBAAkB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAO,CAAE,CAAC,CAAC,CAAC,GCAtmCW,KAAa,CAACZ,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,KAAK,EAAE,UAAU,yBAAwB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,unBAAunB,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,CAAC,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,MAAsB,gBAAAA,EAAM,cAAc,YAAY,EAAE,IAAI,mBAAkB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAO,CAAE,CAAC,CAAC,CAAC,GCA1sCY,KAAmB,CAACb,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,KAAK,EAAE,UAAU,yBAAwB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,8jBAA8jB,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,SAAS,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,mNAAmN,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oCAAoC,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,SAAS,CAAC,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,MAAsB,gBAAAA,EAAM,cAAc,YAAY,EAAE,IAAI,sBAAsC,gBAAAA,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAO,CAAE,CAAC,CAAC,CAAC,GCA5pDa,KAAa,CAACd,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,KAAK,EAAE,UAAU,4BAA4C,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oCAAoC,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,mEAAmE,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,4CAA4C,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,4CAA4C,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,2CAA2C,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,4CAA4C,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,SAAS,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,2BAA2B,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,QAAO,CAAE,CAAC,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,MAAsB,gBAAAA,EAAM,cAAc,YAAY,EAAE,IAAI,mBAAkB,GAAoB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAO,CAAE,CAAC,CAAC,CAAC,GCAloDc,KAAY,CAACf,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,KAAyB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,8QAA8Q,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,SAAS,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,2WAA2W,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,yKAAyK,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,wBAAwB,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,sBAAsB,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,SAAS,CAAC,GCArpDe,KAAe,CAAChB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,eAAe,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EAC5L,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,kMAAiM,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,6MAA6M,CAAC,GCF/fgB,KAAc,CAACjB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EACzL,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,0hBAA0hB,CAAC,GCFrlBiB,KAAW,CAAClB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,iBAAiB,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EAC1L,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,0VAA0V,CAAC,GCFrZkB,KAAc,CAACnB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EACzL,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,mnBAAmnB,CAAC,GCF9qBmB,KAAc,CAACpB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,iBAAiB,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EAC7L,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,oSAAoS,CAAC,GCF/VoB,KAAe,CAACrB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EAC1L,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,2hBAA2hB,CAAC,GCFtlBqB,KAAgB,CAACtB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAQ,QAAQ,gBAAgB,aAAa,KAAK,eAAe,SAAS,gBAAgB,SAAS,OAAO;AAAA,EAC9Q,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,MAAM,QAAQ,GAAG,oQAAoQ,CAAC,GCF7UsB,KAAc,CAACvB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,iBAAiB,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EAC7L,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,g+BAAg+B,CAAC,GCF3hCuB,KAAU,CAACxB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,iBAAiB,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EACzL,SAAS;AACX,GAAG,GAAGD,KAAyB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,mKAAmK,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,4qBAA2qB,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oFAAoF,CAAC,GCFvkCwB,KAAY,CAACzB,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,0KAA0K,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,SAAS,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oCAAoC,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,SAAS,CAAC,GCAtnByB,KAAgB,CAAC1B,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,mDAAmD,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,QAAO,CAAE,CAAC,GCAlW0B,KAAe,CAAC3B,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,oUAAoU,MAAM,eAAc,CAAE,CAAC,GCA/jB2B,KAAmB,CAAC5B,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,oUAAoU,MAAM,yBAAwB,CAAE,CAAC,GCA7kB4B,KAAW,CAAC7B,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,oCAAoC,QAAQ,gBAAgB,eAAe,SAAS,gBAAgB,QAAO,CAAE,CAAC,GCA9U6B,KAAc,CAAC9B,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,IAAI,IAAI,MAAM,WAAW,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,wCAAwC,QAAQ,WAAW,aAAa,KAAK,eAAe,SAAS,CAAC,GCA1a8B,KAAgB,CAAC/B,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,IAAI,IAAI,MAAM,UAAS,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,sVAAsV,MAAM,WAAW,CAAC,GCA9qB+B,KAAiB,CAAChC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,OAAO,IAAI,QAAQ,IAAI,IAAI,IAAI,MAAM,WAAW,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,UAAU,WAAW,UAAU,WAAW,GAAG,i9BAAi9B,MAAM,WAAW,CAAC,GCAp1CgC,KAAU,CAACjC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,qNAAqN,MAAM,WAAW,QAAQ,WAAW,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,8BAA8B,QAAQ,SAAS,aAAa,KAAK,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,CAAC,GCApsBiC,KAAY,CAAClC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,qHAAqH,MAAM,WAAW,QAAQ,WAAW,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oCAAoC,QAAQ,SAAS,aAAa,KAAK,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oCAAoC,QAAQ,SAAS,aAAa,KAAK,eAAe,SAAS,gBAAgB,QAAO,CAAE,CAAC,GCAlwBkC,KAAU,CAACnC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,iLAAiL,MAAM,WAAW,QAAQ,WAAW,aAAa,KAAK,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,qqBAAqqB,MAAM,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,UAAU,EAAE,IAAI,SAAS,IAAI,SAAS,GAAG,GAAG,MAAM,SAAS,QAAQ,SAAS,aAAa,SAAQ,CAAE,CAAC,GCAx2CmC,KAAa,CAACpC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,oBAAoB,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,SAAS,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,uBAAuB,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,SAAS,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,oCAAoC,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,8BAA8B,QAAQ,gBAAgB,kBAAkB,IAAI,eAAe,SAAS,gBAAgB,SAAS,CAAC,GCAx2BoC,KAAa,CAACrC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,gQAAgQ,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,GAAmB,gBAAAA,EAAM,cAAc,UAAU,EAAE,IAAI,SAAS,IAAI,SAAS,GAAG,MAAM,MAAM,eAAc,CAAE,GAAmB,gBAAAA,EAAM,cAAc,UAAU,EAAE,IAAI,OAAO,IAAI,SAAS,GAAG,MAAM,MAAM,eAAc,CAAE,GAAmB,gBAAAA,EAAM,cAAc,UAAU,EAAE,IAAI,SAAS,IAAI,SAAS,GAAG,MAAM,MAAM,gBAAgB,CAAC,GCA52BqC,KAAW,CAACtC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,IAAI,QAAQ,IAAI,SAAS,aAAa,MAAM,QAAQ,OAAO,8BAA8B,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,ovBAAovB,QAAQ,gBAAgB,kBAAkB,IAAI,gBAAgB,QAAO,CAAE,CAAC,GCA5hCsC,KAAY,CAACvC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EACvL,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,8MAA6M,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,uEAAuE,CAAC,GCFrYuC,KAAU,CAACxC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,WAAW,OAAO;AAAA,EAChL,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,yKAAyK,CAAC,GCFpOwC,KAAU,CAACzC,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAQ,QAAQ,gBAAgB,aAAa,GAAG,eAAe,SAAS,gBAAgB,SAAS,OAAO;AAAA,EACtQ,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,MAAM,QAAQ,GAAG,+DAA+D,CAAC,GCFxIyC,KAAY,CAAC1C,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EACvL,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,4KAA4K,CAAC,GCFvO0C,KAAU,CAAC3C,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,iBAAiB,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EACzL,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,gZAAgZ,CAAC,GCF3c2C,KAAY,CAAC5C,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EACvL,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,mbAAmb,CAAC,GCF9e4C,KAAiB,CAAC7C,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,iBAAiB,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EAChM,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,8PAA8P,CAAC,GCFzT6C,KAAW,CAAC9C,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAQ,QAAQ,gBAAgB,aAAa,GAAG,eAAe,SAAS,gBAAgB,SAAS,OAAO;AAAA,EACvQ,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,MAAM,QAAQ,GAAG,0IAAyI,CAAE,GAAmB,gBAAAA,EAAM,cAAc,UAAU,EAAE,IAAI,QAAQ,IAAI,QAAQ,GAAG,MAAK,CAAE,GAAmB,gBAAAA,EAAM,cAAc,QAAQ,EAAE,GAAG,mBAAkB,CAAE,CAAC,GCFjX8C,KAAc,CAAC/C,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAQ,QAAQ,gBAAgB,aAAa,GAAG,eAAe,SAAS,gBAAgB,SAAS,OAAO;AAAA,EAC1Q,SAAS;AACX,GAAG,GAAGD,KAAyB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,+CAA+C,GAAmB,gBAAAA,EAAM,cAAc,UAAU,EAAE,IAAI,IAAI,IAAI,GAAG,GAAG,GAAG,WAAW,kBAAiB,CAAE,GAAmB,gBAAAA,EAAM,cAAc,UAAU,EAAE,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,WAAW,mBAAkB,CAAE,GAAmB,gBAAAA,EAAM,cAAc,UAAU,EAAE,IAAI,GAAG,IAAI,GAAG,GAAG,GAAG,WAAW,kBAAkB,CAAC,GCF5Z+C,KAAY,CAAChD,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,WAAW,OAAO;AAAA,EAClL,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,smBAAsmB,CAAC,GCFjqBgD,KAAY,CAACjD,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,iBAAiB,OAAO,IAAI,QAAQ,IAAI,MAAM,gBAAgB,OAAO;AAAA,EAC3L,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,GAAG,4/BAA4/B,CAAC,GCFvjCiD,KAAc,CAAClD,MAA0B,gBAAAC,EAAM,cAAc,OAAO,EAAE,OAAO,8BAA8B,SAAS,aAAa,OAAO,IAAI,QAAQ,IAAI,MAAM,QAAQ,QAAQ,gBAAgB,aAAa,GAAG,eAAe,SAAS,gBAAgB,SAAS,OAAO;AAAA,EAC1Q,SAAS;AACX,GAAG,GAAGD,EAAK,GAAoB,gBAAAC,EAAM,cAAc,QAAQ,EAAE,MAAM,QAAQ,GAAG,mGAAmG,CAAC;ACH3K,IAAKkD,uBAAAA,OACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WAEVA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WAEVA,EAAA,WAAW,WACXA,EAAA,WAAW,WAEXA,EAAA,WAAW,WACXA,EAAA,WAAW,WAEXA,EAAA,YAAY,WACZA,EAAA,YAAY,WAEZA,EAAA,SAAS,WACTA,EAAA,SAAS,WAETA,EAAA,YAAY,WACZA,EAAA,YAAY,WA5BFA,IAAAA,MAAA,CAAA,CAAA;;;;;;;;ACOZ,KAAC,WAAY;AAGZ,UAAIC,IAAS,CAAA,EAAG;AAEhB,eAASC,IAAc;AAGtB,iBAFIC,IAAU,IAEL,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAC1C,cAAIC,IAAM,UAAU,CAAC;AACrB,UAAIA,MACHD,IAAUE,EAAYF,GAASG,EAAWF,CAAG,CAAC;AAAA,QAElD;AAEE,eAAOD;AAAA,MACT;AAEC,eAASG,EAAYF,GAAK;AACzB,YAAI,OAAOA,KAAQ,YAAY,OAAOA,KAAQ;AAC7C,iBAAOA;AAGR,YAAI,OAAOA,KAAQ;AAClB,iBAAO;AAGR,YAAI,MAAM,QAAQA,CAAG;AACpB,iBAAOF,EAAW,MAAM,MAAME,CAAG;AAGlC,YAAIA,EAAI,aAAa,OAAO,UAAU,YAAY,CAACA,EAAI,SAAS,SAAQ,EAAG,SAAS,eAAe;AAClG,iBAAOA,EAAI,SAAQ;AAGpB,YAAID,IAAU;AAEd,iBAASI,KAAOH;AACf,UAAIH,EAAO,KAAKG,GAAKG,CAAG,KAAKH,EAAIG,CAAG,MACnCJ,IAAUE,EAAYF,GAASI,CAAG;AAIpC,eAAOJ;AAAA,MACT;AAEC,eAASE,EAAaG,GAAOC,GAAU;AACtC,eAAKA,IAIDD,IACIA,IAAQ,MAAMC,IAGfD,IAAQC,IAPPD;AAAA,MAQV;AAEC,MAAqCE,EAAO,WAC3CR,EAAW,UAAUA,GACrBQ,YAAiBR,KAOjB,OAAO,aAAaA;AAAA,IAEtB;;;;;;;;GChEaS,KAAgC,CAAC,EAAE,IAAAC,GAAI,OAAAC,GAAO,UAAAC,GAAU,UAAAC,GAAU,WAAAC,EAAA,MAC7E,gBAAAC,EAAC,SAAI,WAAWC,EAAGC,GAAI,OAAOH,CAAS,GAAG,IAAAJ,GACvC,UAAA;AAAA,EAAAC,KAAS,OAAOA,KAAU,WAAW,gBAAAO,EAAC,SAAI,WAAWD,GAAI,OAAQ,UAAAN,EAAA,CAAM,IAASA;AAAA,EAChFC,KAAY,gBAAAM,EAAC,OAAA,EAAI,WAAWD,GAAI,UAAW,UAAAL,GAAS;AAAA,EACpDC;AAAA,EAAA,CACH;ACfF,SAASM,GAAOC,GAAKd,GAAO;AAC1B,MAAI,OAAOc,KAAQ;AACjB,WAAOA,EAAId,CAAK;AACX,EAAIc,KAAQ,SACjBA,EAAI,UAAUd;AAElB;AACA,SAASe,MAAeC,GAAM;AAC5B,SAAO,CAACC,MAAS;AACf,QAAIC,IAAa;AACjB,UAAMC,IAAWH,EAAK,IAAI,CAACF,MAAQ;AACjC,YAAMM,IAAUP,GAAOC,GAAKG,CAAI;AAChC,aAAI,CAACC,KAAc,OAAOE,KAAW,eACnCF,IAAa,KAERE;AAAA,IACT,CAAC;AACD,QAAIF;AACF,aAAO,MAAM;AACX,iBAASG,IAAI,GAAGA,IAAIF,EAAS,QAAQE,KAAK;AACxC,gBAAMD,IAAUD,EAASE,CAAC;AAC1B,UAAI,OAAOD,KAAW,aACpBA,EAAO,IAEPP,GAAOG,EAAKK,CAAC,GAAG,IAAI;AAAA,QAExB;AAAA,MACF;AAAA,EAEJ;AACF;AACA,SAASC,MAAmBN,GAAM;AAChC,SAAO1E,EAAM,YAAYyE,GAAY,GAAGC,CAAI,GAAGA,CAAI;AACrD;AC/BA,IAAIO,KAAkB,uBAAO,IAAI,YAAY,GACzCC,KAAMlF,EAAM,QAAQ,KAAI,EAAG,SAAQ,CAAE;AACzC,SAASmF,GAAczB,GAAO;AAC5B,SAAO,OAAOA,KAAU,YAAYA,MAAU,QAAQ,UAAUA;AAClE;AACA,SAAS0B,GAAgBC,GAAS;AAChC,SAAOA,KAAW,QAAQ,OAAOA,KAAY,YAAY,cAAcA,KAAWA,EAAQ,aAAaJ,MAAmB,cAAcI,KAAWF,GAAcE,EAAQ,QAAQ;AACnL;AAAA;AAEA,SAASC,GAAWC,GAAW;AAC7B,QAAMC,IAA4BC,gBAAAA,GAAgBF,CAAS,GACrDG,IAAQ1F,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACtD,QAAI,EAAE,UAAA1B,GAAU,GAAG2B,EAAS,IAAK7F;AACjC,IAAIqF,GAAgBnB,CAAQ,KAAK,OAAOiB,MAAQ,eAC9CjB,IAAWiB,GAAIjB,EAAS,QAAQ;AAElC,UAAM4B,IAAgB7F,EAAM,SAAS,QAAQiE,CAAQ,GAC/C6B,IAAYD,EAAc,KAAKE,EAAW;AAChD,QAAID,GAAW;AACb,YAAME,IAAaF,EAAU,MAAM,UAC7BG,IAAcJ,EAAc,IAAI,CAACK,MACjCA,MAAUJ,IACR9F,EAAM,SAAS,MAAMgG,CAAU,IAAI,IAAUhG,EAAM,SAAS,KAAK,IAAI,IAClEA,EAAM,eAAegG,CAAU,IAAIA,EAAW,MAAM,WAAW,OAE/DE,CAEV;AACD,aAAuB,gBAAA5B,EAAIkB,GAAW,EAAE,GAAGI,GAAW,KAAKD,GAAc,UAAU3F,EAAM,eAAegG,CAAU,IAAIhG,EAAM,aAAagG,GAAY,QAAQC,CAAW,IAAI,MAAM;AAAA,IACpL;AACA,WAAuB,gBAAA3B,EAAIkB,GAAW,EAAE,GAAGI,GAAW,KAAKD,GAAc,UAAA1B,GAAU;AAAA,EACrF,CAAC;AACD,SAAAyB,EAAM,cAAc,GAAGH,CAAS,SACzBG;AACT;AACA,IAAIS,KAAuBb,gBAAAA,GAAW,MAAM;AAAA;AAE5C,SAASG,GAAgBF,GAAW;AAClC,QAAMC,IAAYxF,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AAC1D,QAAI,EAAE,UAAA1B,GAAU,GAAG2B,EAAS,IAAK7F;AAIjC,QAHIqF,GAAgBnB,CAAQ,KAAK,OAAOiB,MAAQ,eAC9CjB,IAAWiB,GAAIjB,EAAS,QAAQ,IAE9BjE,EAAM,eAAeiE,CAAQ,GAAG;AAClC,YAAMmC,IAAcC,GAAcpC,CAAQ,GACpCqC,IAASC,GAAWX,GAAW3B,EAAS,KAAK;AACnD,aAAIA,EAAS,SAASjE,EAAM,aAC1BsG,EAAO,MAAMX,IAAelB,GAAYkB,GAAcS,CAAW,IAAIA,IAEhEpG,EAAM,aAAaiE,GAAUqC,CAAM;AAAA,IAC5C;AACA,WAAOtG,EAAM,SAAS,MAAMiE,CAAQ,IAAI,IAAIjE,EAAM,SAAS,KAAK,IAAI,IAAI;AAAA,EAC1E,CAAC;AACD,SAAAwF,EAAU,cAAc,GAAGD,CAAS,cAC7BC;AACT;AACA,IAAIgB,KAAuB,uBAAO,iBAAiB;AAWnD,SAAST,GAAYG,GAAO;AAC1B,SAAOlG,EAAM,eAAekG,CAAK,KAAK,OAAOA,EAAM,QAAS,cAAc,eAAeA,EAAM,QAAQA,EAAM,KAAK,cAAcM;AAClI;AACA,SAASD,GAAWX,GAAWa,GAAY;AACzC,QAAMC,IAAgB,EAAE,GAAGD,EAAU;AACrC,aAAWE,KAAYF,GAAY;AACjC,UAAMG,IAAgBhB,EAAUe,CAAQ,GAClCE,IAAiBJ,EAAWE,CAAQ;AAE1C,IADkB,WAAW,KAAKA,CAAQ,IAEpCC,KAAiBC,IACnBH,EAAcC,CAAQ,IAAI,IAAIG,MAAS;AACrC,YAAMC,IAASF,EAAe,GAAGC,CAAI;AACrC,aAAAF,EAAc,GAAGE,CAAI,GACdC;AAAA,IACT,IACSH,MACTF,EAAcC,CAAQ,IAAIC,KAEnBD,MAAa,UACtBD,EAAcC,CAAQ,IAAI,EAAE,GAAGC,GAAe,GAAGC,EAAc,IACtDF,MAAa,gBACtBD,EAAcC,CAAQ,IAAI,CAACC,GAAeC,CAAc,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAAA,EAEtF;AACA,SAAO,EAAE,GAAGjB,GAAW,GAAGc,EAAa;AACzC;AACA,SAASL,GAAchB,GAAS;AAC9B,MAAI2B,IAAS,OAAO,yBAAyB3B,EAAQ,OAAO,KAAK,GAAG,KAChE4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO;AAC7D,SAAIC,IACK5B,EAAQ,OAEjB2B,IAAS,OAAO,yBAAyB3B,GAAS,KAAK,GAAG,KAC1D4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO,gBACrDC,IACK5B,EAAQ,MAAM,MAEhBA,EAAQ,MAAM,OAAOA,EAAQ;AACtC;AC9GA,SAAS6B,GAAE,GAAE;AAAC,MAAI,GAAEC,GAAEC,IAAE;AAAG,MAAa,OAAO,KAAjB,YAA8B,OAAO,KAAjB,SAAmB,CAAAA,KAAG;AAAA,WAAoB,OAAO,KAAjB,SAAmB,KAAG,MAAM,QAAQ,CAAC,GAAE;AAAC,QAAI,IAAE,EAAE;AAAO,SAAI,IAAE,GAAE,IAAE,GAAE,IAAI,GAAE,CAAC,MAAID,IAAED,GAAE,EAAE,CAAC,CAAC,OAAKE,MAAIA,KAAG,MAAKA,KAAGD;AAAA,EAAE,MAAM,MAAIA,KAAK,EAAE,GAAEA,CAAC,MAAIC,MAAIA,KAAG,MAAKA,KAAGD;AAAG,SAAOC;AAAC;AAAQ,SAASC,KAAM;AAAC,WAAQ,GAAE,GAAEF,IAAE,GAAEC,IAAE,IAAG,IAAE,UAAU,QAAOD,IAAE,GAAEA,IAAI,EAAC,IAAE,UAAUA,CAAC,OAAK,IAAED,GAAE,CAAC,OAAKE,MAAIA,KAAG,MAAKA,KAAG;AAAG,SAAOA;AAAC;ACe/W,MAAME,KAAgB,CAAC5D,MAAQ,OAAOA,KAAU,YAAY,GAAGA,CAAK,KAAKA,MAAU,IAAI,MAAMA,GAChF6D,KAAKF,IACLG,KAAM,CAACC,GAAMC,MAAS,CAAC3H,MAAQ;AACpC,MAAI4H;AACJ,MAAqDD,GAAO,YAAa,KAAM,QAAOH,GAAGE,GAAoD1H,GAAM,OAAqDA,GAAM,SAAS;AACvN,QAAM,EAAE,UAAA6H,GAAU,iBAAAC,EAAe,IAAKH,GAChCI,IAAuB,OAAO,KAAKF,CAAQ,EAAE,IAAI,CAACG,MAAU;AAC9D,UAAMC,IAA4DjI,IAAMgI,CAAO,GACzEE,IAAuFJ,IAAgBE,CAAO;AACpH,QAAIC,MAAgB,KAAM,QAAO;AACjC,UAAME,IAAaZ,GAAcU,CAAW,KAAKV,GAAcW,CAAkB;AACjF,WAAOL,EAASG,CAAO,EAAEG,CAAU;AAAA,EACvC,CAAC,GACKC,IAAwBpI,KAAS,OAAO,QAAQA,CAAK,EAAE,OAAO,CAACqI,GAAKC,MAAQ;AAC9E,QAAI,CAAC5E,GAAKC,CAAK,IAAI2E;AACnB,WAAI3E,MAAU,WAGd0E,EAAI3E,CAAG,IAAIC,IACJ0E;AAAA,EACX,GAAG,CAAA,CAAE,GACCE,IAA+BZ,KAAW,SAAsCC,IAA2BD,EAAO,sBAAsB,QAAQC,MAA6B,SAAvG,SAAyHA,EAAyB,OAAO,CAACS,GAAKC,MAAQ;AAC/O,QAAI,EAAE,OAAOE,GAAS,WAAWC,GAAa,GAAGC,EAAsB,IAAKJ;AAC5E,WAAO,OAAO,QAAQI,CAAsB,EAAE,MAAM,CAACJ,MAAQ;AACzD,UAAI,CAAC5E,GAAKC,CAAK,IAAI2E;AACnB,aAAO,MAAM,QAAQ3E,CAAK,IAAIA,EAAM,SAAS;AAAA,QACzC,GAAGmE;AAAA,QACH,GAAGM;AAAA,MACvB,EAAkB1E,CAAG,CAAC,IAAK;AAAA,QACP,GAAGoE;AAAA,QACH,GAAGM;AAAA,MACvB,EAAmB1E,CAAG,MAAMC;AAAA,IAChB,CAAC,IAAI;AAAA,MACD,GAAG0E;AAAA,MACHG;AAAA,MACAC;AAAA,IAChB,IAAgBJ;AAAA,EACR,GAAG,CAAA,CAAE;AACL,SAAOb,GAAGE,GAAMK,GAAsBQ,GAA4EvI,GAAM,OAAqDA,GAAM,SAAS;AAChM,GCnDE2I,KAAe,CAACC,GAAQC,MAAW;AAEvC,QAAMC,IAAgB,IAAI,MAAMF,EAAO,SAASC,EAAO,MAAM;AAC7D,WAAS7D,IAAI,GAAGA,IAAI4D,EAAO,QAAQ5D;AACjC,IAAA8D,EAAc9D,CAAC,IAAI4D,EAAO5D,CAAC;AAE7B,WAASA,IAAI,GAAGA,IAAI6D,EAAO,QAAQ7D;AACjC,IAAA8D,EAAcF,EAAO,SAAS5D,CAAC,IAAI6D,EAAO7D,CAAC;AAE7C,SAAO8D;AACT,GAGMC,KAA6B,CAACC,GAAcC,OAAe;AAAA,EAC/D,cAAAD;AAAA,EACA,WAAAC;AACF,IAEMC,KAAwB,CAACC,IAAW,oBAAI,IAAG,GAAIC,IAAa,MAAMJ,OAAkB;AAAA,EACxF,UAAAG;AAAA,EACA,YAAAC;AAAA,EACA,cAAAJ;AACF,IACMK,KAAuB,KACvBC,KAAkB,CAAA,GAElBC,KAA4B,eAC5BC,KAAwB,CAAA7B,MAAU;AACtC,QAAM8B,IAAWC,GAAe/B,CAAM,GAChC;AAAA,IACJ,wBAAAgC;AAAA,IACA,gCAAAC;AAAA,EACJ,IAAMjC;AA2BJ,SAAO;AAAA,IACL,iBA3BsB,CAAAxD,MAAa;AACnC,UAAIA,EAAU,WAAW,GAAG,KAAKA,EAAU,SAAS,GAAG;AACrD,eAAO0F,GAA+B1F,CAAS;AAEjD,YAAM2F,IAAa3F,EAAU,MAAMkF,EAAoB,GAEjDU,IAAaD,EAAW,CAAC,MAAM,MAAMA,EAAW,SAAS,IAAI,IAAI;AACvE,aAAOE,GAAkBF,GAAYC,GAAYN,CAAQ;AAAA,IAC3D;AAAA,IAoBE,6BAnBkC,CAACT,GAAciB,MAAuB;AACxE,UAAIA,GAAoB;AACtB,cAAMC,IAAoBN,EAA+BZ,CAAY,GAC/DmB,IAAgBR,EAAuBX,CAAY;AACzD,eAAIkB,IACEC,IAEKxB,GAAawB,GAAeD,CAAiB,IAG/CA,IAGFC,KAAiBb;AAAA,MAC1B;AACA,aAAOK,EAAuBX,CAAY,KAAKM;AAAA,IACjD;AAAA,EAIF;AACA,GACMU,KAAoB,CAACF,GAAYC,GAAYK,MAAoB;AAErE,MADyBN,EAAW,SAASC,MACpB;AACvB,WAAOK,EAAgB;AAEzB,QAAMC,IAAmBP,EAAWC,CAAU,GACxCO,IAAsBF,EAAgB,SAAS,IAAIC,CAAgB;AACzE,MAAIC,GAAqB;AACvB,UAAMtD,IAASgD,GAAkBF,GAAYC,IAAa,GAAGO,CAAmB;AAChF,QAAItD,EAAQ,QAAOA;AAAA,EACrB;AACA,QAAMoC,IAAagB,EAAgB;AACnC,MAAIhB,MAAe;AACjB;AAGF,QAAMmB,IAAYR,MAAe,IAAID,EAAW,KAAKT,EAAoB,IAAIS,EAAW,MAAMC,CAAU,EAAE,KAAKV,EAAoB,GAC7HmB,IAAmBpB,EAAW;AACpC,WAASpE,IAAI,GAAGA,IAAIwF,GAAkBxF,KAAK;AACzC,UAAMyF,IAAerB,EAAWpE,CAAC;AACjC,QAAIyF,EAAa,UAAUF,CAAS;AAClC,aAAOE,EAAa;AAAA,EAExB;AAEF,GAMMZ,KAAiC,CAAA1F,MAAaA,EAAU,MAAM,GAAG,EAAE,EAAE,QAAQ,GAAG,MAAM,KAAK,UAAa,MAAM;AAClH,QAAMuG,IAAUvG,EAAU,MAAM,GAAG,EAAE,GAC/BwG,IAAaD,EAAQ,QAAQ,GAAG,GAChCE,IAAWF,EAAQ,MAAM,GAAGC,CAAU;AAC5C,SAAOC,IAAWrB,KAA4BqB,IAAW;AAC3D,GAAC,GAIKlB,KAAiB,CAAA/B,MAAU;AAC/B,QAAM;AAAA,IACJ,OAAAkD;AAAA,IACA,aAAAC;AAAA,EACJ,IAAMnD;AACJ,SAAOoD,GAAmBD,GAAaD,CAAK;AAC9C,GAEME,KAAqB,CAACD,GAAaD,MAAU;AACjD,QAAMpB,IAAWP,GAAqB;AACtC,aAAWF,KAAgB8B,GAAa;AACtC,UAAME,IAAQF,EAAY9B,CAAY;AACtC,IAAAiC,GAA0BD,GAAOvB,GAAUT,GAAc6B,CAAK;AAAA,EAChE;AACA,SAAOpB;AACT,GACMwB,KAA4B,CAACC,GAAYd,GAAiBpB,GAAc6B,MAAU;AACtF,QAAMM,IAAMD,EAAW;AACvB,WAASlG,IAAI,GAAGA,IAAImG,GAAKnG,KAAK;AAC5B,UAAMoG,IAAkBF,EAAWlG,CAAC;AACpC,IAAAqG,GAAuBD,GAAiBhB,GAAiBpB,GAAc6B,CAAK;AAAA,EAC9E;AACF,GAEMQ,KAAyB,CAACD,GAAiBhB,GAAiBpB,GAAc6B,MAAU;AACxF,MAAI,OAAOO,KAAoB,UAAU;AACvC,IAAAE,GAAwBF,GAAiBhB,GAAiBpB,CAAY;AACtE;AAAA,EACF;AACA,MAAI,OAAOoC,KAAoB,YAAY;AACzC,IAAAG,GAA0BH,GAAiBhB,GAAiBpB,GAAc6B,CAAK;AAC/E;AAAA,EACF;AACA,EAAAW,GAAwBJ,GAAiBhB,GAAiBpB,GAAc6B,CAAK;AAC/E,GACMS,KAA0B,CAACF,GAAiBhB,GAAiBpB,MAAiB;AAClF,QAAMyC,IAAwBL,MAAoB,KAAKhB,IAAkBsB,GAAQtB,GAAiBgB,CAAe;AACjH,EAAAK,EAAsB,eAAezC;AACvC,GACMuC,KAA4B,CAACH,GAAiBhB,GAAiBpB,GAAc6B,MAAU;AAC3F,MAAIc,GAAcP,CAAe,GAAG;AAClC,IAAAH,GAA0BG,EAAgBP,CAAK,GAAGT,GAAiBpB,GAAc6B,CAAK;AACtF;AAAA,EACF;AACA,EAAIT,EAAgB,eAAe,SACjCA,EAAgB,aAAa,CAAA,IAE/BA,EAAgB,WAAW,KAAKrB,GAA2BC,GAAcoC,CAAe,CAAC;AAC3F,GACMI,KAA0B,CAACJ,GAAiBhB,GAAiBpB,GAAc6B,MAAU;AACzF,QAAMe,IAAU,OAAO,QAAQR,CAAe,GACxCD,IAAMS,EAAQ;AACpB,WAAS,IAAI,GAAG,IAAIT,GAAK,KAAK;AAC5B,UAAM,CAACzH,GAAKC,CAAK,IAAIiI,EAAQ,CAAC;AAC9B,IAAAX,GAA0BtH,GAAO+H,GAAQtB,GAAiB1G,CAAG,GAAGsF,GAAc6B,CAAK;AAAA,EACrF;AACF,GACMa,KAAU,CAACtB,GAAiByB,MAAS;AACzC,MAAIC,IAAU1B;AACd,QAAM2B,IAAQF,EAAK,MAAMxC,EAAoB,GACvC8B,IAAMY,EAAM;AAClB,WAAS/G,IAAI,GAAGA,IAAImG,GAAKnG,KAAK;AAC5B,UAAMgH,IAAOD,EAAM/G,CAAC;AACpB,QAAIiH,IAAOH,EAAQ,SAAS,IAAIE,CAAI;AACpC,IAAKC,MACHA,IAAO/C,GAAqB,GAC5B4C,EAAQ,SAAS,IAAIE,GAAMC,CAAI,IAEjCH,IAAUG;AAAA,EACZ;AACA,SAAOH;AACT,GAEMH,KAAgB,CAAAO,MAAQ,mBAAmBA,KAAQA,EAAK,kBAAkB,IAG1EC,KAAiB,CAAAC,MAAgB;AACrC,MAAIA,IAAe;AACjB,WAAO;AAAA,MACL,KAAK,MAAA;AAAA;AAAA,MACL,KAAK,MAAM;AAAA,MAAC;AAAA,IAClB;AAEE,MAAIC,IAAY,GACZC,IAAQ,uBAAO,OAAO,IAAI,GAC1BC,IAAgB,uBAAO,OAAO,IAAI;AACtC,QAAMC,IAAS,CAAC9I,GAAKC,MAAU;AAC7B,IAAA2I,EAAM5I,CAAG,IAAIC,GACb0I,KACIA,IAAYD,MACdC,IAAY,GACZE,IAAgBD,GAChBA,IAAQ,uBAAO,OAAO,IAAI;AAAA,EAE9B;AACA,SAAO;AAAA,IACL,IAAI5I,GAAK;AACP,UAAIC,IAAQ2I,EAAM5I,CAAG;AACrB,UAAIC,MAAU;AACZ,eAAOA;AAET,WAAKA,IAAQ4I,EAAc7I,CAAG,OAAO;AACnC,eAAA8I,EAAO9I,GAAKC,CAAK,GACVA;AAAA,IAEX;AAAA,IACA,IAAID,GAAKC,GAAO;AACd,MAAID,KAAO4I,IACTA,EAAM5I,CAAG,IAAIC,IAEb6I,EAAO9I,GAAKC,CAAK;AAAA,IAErB;AAAA,EACJ;AACA,GACM8I,KAAqB,KACrBC,KAAqB,KACrBC,KAAkB,CAAA,GAElBC,KAAqB,CAACC,GAAWC,GAAsBC,GAAeC,GAA8BC,OAAgB;AAAA,EACxH,WAAAJ;AAAA,EACA,sBAAAC;AAAA,EACA,eAAAC;AAAA,EACA,8BAAAC;AAAA,EACA,YAAAC;AACF,IACMC,KAAuB,CAAAvF,MAAU;AACrC,QAAM;AAAA,IACJ,QAAAwF;AAAA,IACA,4BAAAC;AAAA,EACJ,IAAMzF;AAOJ,MAAI0F,IAAiB,CAAAlJ,MAAa;AAEhC,UAAM0I,IAAY,CAAA;AAClB,QAAIS,IAAe,GACfC,IAAa,GACbC,IAAgB,GAChBC;AACJ,UAAMtC,IAAMhH,EAAU;AACtB,aAASuJ,IAAQ,GAAGA,IAAQvC,GAAKuC,KAAS;AACxC,YAAMC,IAAmBxJ,EAAUuJ,CAAK;AACxC,UAAIJ,MAAiB,KAAKC,MAAe,GAAG;AAC1C,YAAII,MAAqBjB,IAAoB;AAC3C,UAAAG,EAAU,KAAK1I,EAAU,MAAMqJ,GAAeE,CAAK,CAAC,GACpDF,IAAgBE,IAAQ;AACxB;AAAA,QACF;AACA,YAAIC,MAAqB,KAAK;AAC5B,UAAAF,IAA0BC;AAC1B;AAAA,QACF;AAAA,MACF;AACA,MAAIC,MAAqB,MAAKL,MAAwBK,MAAqB,MAAKL,MAAwBK,MAAqB,MAAKJ,MAAsBI,MAAqB,OAAKJ;AAAA,IACpL;AACA,UAAMK,IAAqCf,EAAU,WAAW,IAAI1I,IAAYA,EAAU,MAAMqJ,CAAa;AAE7G,QAAIT,IAAgBa,GAChBd,IAAuB;AAC3B,IAAIc,EAAmC,SAASnB,EAAkB,KAChEM,IAAgBa,EAAmC,MAAM,GAAG,EAAE,GAC9Dd,IAAuB;AAAA;AAAA;AAAA;AAAA;AAAA,MAMzBc,EAAmC,WAAWnB,EAAkB,MAC9DM,IAAgBa,EAAmC,MAAM,CAAC,GAC1Dd,IAAuB;AAAA;AAEzB,UAAME,IAA+BS,KAA2BA,IAA0BD,IAAgBC,IAA0BD,IAAgB;AACpJ,WAAOZ,GAAmBC,GAAWC,GAAsBC,GAAeC,CAA4B;AAAA,EACxG;AACA,MAAIG,GAAQ;AACV,UAAMU,IAAaV,IAAST,IACtBoB,IAAyBT;AAC/B,IAAAA,IAAiB,CAAAlJ,MAAaA,EAAU,WAAW0J,CAAU,IAAIC,EAAuB3J,EAAU,MAAM0J,EAAW,MAAM,CAAC,IAAIjB,GAAmBD,IAAiB,IAAOxI,GAAW,QAAW,EAAI;AAAA,EACrM;AACA,MAAIiJ,GAA4B;AAC9B,UAAMU,IAAyBT;AAC/B,IAAAA,IAAiB,CAAAlJ,MAAaiJ,EAA2B;AAAA,MACvD,WAAAjJ;AAAA,MACA,gBAAgB2J;AAAA,IACtB,CAAK;AAAA,EACH;AACA,SAAOT;AACT,GAOMU,KAAsB,CAAApG,MAAU;AAEpC,QAAMqG,IAAkB,oBAAI,IAAG;AAE/B,SAAArG,EAAO,wBAAwB,QAAQ,CAACsG,GAAKP,MAAU;AACrD,IAAAM,EAAgB,IAAIC,GAAK,MAAUP,CAAK;AAAA,EAC1C,CAAC,GACM,CAAAb,MAAa;AAClB,UAAM7F,IAAS,CAAA;AACf,QAAIkH,IAAiB,CAAA;AAErB,aAASlJ,IAAI,GAAGA,IAAI6H,EAAU,QAAQ7H,KAAK;AACzC,YAAMmJ,IAAWtB,EAAU7H,CAAC,GAEtBoJ,IAAcD,EAAS,CAAC,MAAM,KAC9BE,IAAmBL,EAAgB,IAAIG,CAAQ;AACrD,MAAIC,KAAeC,KAEbH,EAAe,SAAS,MAC1BA,EAAe,KAAI,GACnBlH,EAAO,KAAK,GAAGkH,CAAc,GAC7BA,IAAiB,CAAA,IAEnBlH,EAAO,KAAKmH,CAAQ,KAGpBD,EAAe,KAAKC,CAAQ;AAAA,IAEhC;AAEA,WAAID,EAAe,SAAS,MAC1BA,EAAe,KAAI,GACnBlH,EAAO,KAAK,GAAGkH,CAAc,IAExBlH;AAAA,EACT;AACF,GACMsH,KAAoB,CAAA3G,OAAW;AAAA,EACnC,OAAOwE,GAAexE,EAAO,SAAS;AAAA,EACtC,gBAAgBuF,GAAqBvF,CAAM;AAAA,EAC3C,eAAeoG,GAAoBpG,CAAM;AAAA,EACzC,GAAG6B,GAAsB7B,CAAM;AACjC,IACM4G,KAAsB,OACtBC,KAAiB,CAACC,GAAWC,MAAgB;AACjD,QAAM;AAAA,IACJ,gBAAArB;AAAA,IACA,iBAAAsB;AAAA,IACA,6BAAAC;AAAA,IACA,eAAAC;AAAA,EACJ,IAAMH,GAQEI,IAAwB,CAAA,GACxBzL,IAAaoL,EAAU,KAAI,EAAG,MAAMF,EAAmB;AAC7D,MAAIvH,IAAS;AACb,WAAS0G,IAAQrK,EAAW,SAAS,GAAGqK,KAAS,GAAGA,KAAS,GAAG;AAC9D,UAAMqB,IAAoB1L,EAAWqK,CAAK,GACpC;AAAA,MACJ,YAAAT;AAAA,MACA,WAAAJ;AAAA,MACA,sBAAAC;AAAA,MACA,eAAAC;AAAA,MACA,8BAAAC;AAAA,IACN,IAAQK,EAAe0B,CAAiB;AACpC,QAAI9B,GAAY;AACd,MAAAjG,IAAS+H,KAAqB/H,EAAO,SAAS,IAAI,MAAMA,IAASA;AACjE;AAAA,IACF;AACA,QAAIiD,IAAqB,CAAC,CAAC+C,GACvBhE,IAAe2F,EAAgB1E,IAAqB8C,EAAc,UAAU,GAAGC,CAA4B,IAAID,CAAa;AAChI,QAAI,CAAC/D,GAAc;AACjB,UAAI,CAACiB,GAAoB;AAEvB,QAAAjD,IAAS+H,KAAqB/H,EAAO,SAAS,IAAI,MAAMA,IAASA;AACjE;AAAA,MACF;AAEA,UADAgC,IAAe2F,EAAgB5B,CAAa,GACxC,CAAC/D,GAAc;AAEjB,QAAAhC,IAAS+H,KAAqB/H,EAAO,SAAS,IAAI,MAAMA,IAASA;AACjE;AAAA,MACF;AACA,MAAAiD,IAAqB;AAAA,IACvB;AAEA,UAAM+E,IAAkBnC,EAAU,WAAW,IAAI,KAAKA,EAAU,WAAW,IAAIA,EAAU,CAAC,IAAIgC,EAAchC,CAAS,EAAE,KAAK,GAAG,GACzHoC,IAAanC,IAAuBkC,IAAkBvC,KAAqBuC,GAC3EE,IAAUD,IAAajG;AAC7B,QAAI8F,EAAsB,QAAQI,CAAO,IAAI;AAE3C;AAEF,IAAAJ,EAAsB,KAAKI,CAAO;AAClC,UAAMC,IAAiBP,EAA4B5F,GAAciB,CAAkB;AACnF,aAASjF,IAAI,GAAGA,IAAImK,EAAe,QAAQ,EAAEnK,GAAG;AAC9C,YAAMgG,IAAQmE,EAAenK,CAAC;AAC9B,MAAA8J,EAAsB,KAAKG,IAAajE,CAAK;AAAA,IAC/C;AAEA,IAAAhE,IAAS+H,KAAqB/H,EAAO,SAAS,IAAI,MAAMA,IAASA;AAAA,EACnE;AACA,SAAOA;AACT,GAWMoI,KAAS,IAAIC,MAAe;AAChC,MAAI3B,IAAQ,GACR4B,GACAC,GACAC,IAAS;AACb,SAAO9B,IAAQ2B,EAAW;AACxB,KAAIC,IAAWD,EAAW3B,GAAO,OAC3B6B,IAAgBE,GAAQH,CAAQ,OAClCE,MAAWA,KAAU,MACrBA,KAAUD;AAIhB,SAAOC;AACT,GACMC,KAAU,CAAAC,MAAO;AAErB,MAAI,OAAOA,KAAQ;AACjB,WAAOA;AAET,MAAIH,GACAC,IAAS;AACb,WAASG,IAAI,GAAGA,IAAID,EAAI,QAAQC;AAC9B,IAAID,EAAIC,CAAC,MACHJ,IAAgBE,GAAQC,EAAIC,CAAC,CAAC,OAChCH,MAAWA,KAAU,MACrBA,KAAUD;AAIhB,SAAOC;AACT,GACMI,KAAsB,CAACC,MAAsBC,MAAqB;AACtE,MAAIpB,GACAqB,GACAC,GACAC;AACJ,QAAMC,IAAoB,CAAAzB,MAAa;AACrC,UAAM9G,IAASmI,EAAiB,OAAO,CAACK,GAAgBC,MAAwBA,EAAoBD,CAAc,GAAGN,GAAmB;AACxI,WAAAnB,IAAcJ,GAAkB3G,CAAM,GACtCoI,IAAWrB,EAAY,MAAM,KAC7BsB,IAAWtB,EAAY,MAAM,KAC7BuB,IAAiBI,GACVA,EAAc5B,CAAS;AAAA,EAChC,GACM4B,IAAgB,CAAA5B,MAAa;AACjC,UAAM6B,IAAeP,EAAStB,CAAS;AACvC,QAAI6B;AACF,aAAOA;AAET,UAAMtJ,IAASwH,GAAeC,GAAWC,CAAW;AACpD,WAAAsB,EAASvB,GAAWzH,CAAM,GACnBA;AAAA,EACT;AACA,SAAAiJ,IAAiBC,GACV,IAAInJ,MAASkJ,EAAeb,GAAO,GAAGrI,CAAI,CAAC;AACpD,GACMwJ,KAAmB,CAAA,GACnBC,KAAY,CAAA9M,MAAO;AACvB,QAAM+M,IAAc,CAAA5F,MAASA,EAAMnH,CAAG,KAAK6M;AAC3C,SAAAE,EAAY,gBAAgB,IACrBA;AACT,GACMC,KAAsB,+BACtBC,KAAyB,+BACzBC,KAAgB,kCAChBC,KAAkB,oCAClBC,KAAkB,6HAClBC,KAAqB,sDAErBC,KAAc,mEACdC,KAAa,gGACbC,KAAa,CAAAvN,MAASiN,GAAc,KAAKjN,CAAK,GAC9CwN,IAAW,CAAAxN,MAAS,CAAC,CAACA,KAAS,CAAC,OAAO,MAAM,OAAOA,CAAK,CAAC,GAC1DyN,KAAY,CAAAzN,MAAS,CAAC,CAACA,KAAS,OAAO,UAAU,OAAOA,CAAK,CAAC,GAC9D0N,KAAY,CAAA1N,MAASA,EAAM,SAAS,GAAG,KAAKwN,EAASxN,EAAM,MAAM,GAAG,EAAE,CAAC,GACvE2N,KAAe,CAAA3N,MAASkN,GAAgB,KAAKlN,CAAK,GAClD4N,KAAQ,MAAM,IACdC,KAAe,CAAA7N;AAAA;AAAA;AAAA;AAAA,EAIrBmN,GAAgB,KAAKnN,CAAK,KAAK,CAACoN,GAAmB,KAAKpN,CAAK;AAAA,GACvD8N,KAAU,MAAM,IAChBC,KAAW,CAAA/N,MAASqN,GAAY,KAAKrN,CAAK,GAC1CgO,KAAU,CAAAhO,MAASsN,GAAW,KAAKtN,CAAK,GACxCiO,KAAoB,CAAAjO,MAAS,CAACkO,EAAiBlO,CAAK,KAAK,CAACmO,EAAoBnO,CAAK,GACnFoO,KAAkB,CAAApO,MAASqO,GAAoBrO,GAAOsO,IAAaR,EAAO,GAC1EI,IAAmB,CAAAlO,MAAS+M,GAAoB,KAAK/M,CAAK,GAC1DuO,KAAoB,CAAAvO,MAASqO,GAAoBrO,GAAOwO,IAAeX,EAAY,GACnFY,KAAoB,CAAAzO,MAASqO,GAAoBrO,GAAO0O,IAAelB,CAAQ,GAC/EmB,KAAoB,CAAA3O,MAASqO,GAAoBrO,GAAO4O,IAAehB,EAAK,GAC5EiB,KAAwB,CAAA7O,MAASqO,GAAoBrO,GAAO8O,IAAmBhB,EAAO,GACtFiB,KAAsB,CAAA/O,MAASqO,GAAoBrO,GAAOgP,IAAiBlB,EAAO,GAClFmB,KAAmB,CAAAjP,MAASqO,GAAoBrO,GAAOkP,IAAclB,EAAO,GAC5EmB,KAAoB,CAAAnP,MAASqO,GAAoBrO,GAAOoP,IAAerB,EAAQ,GAC/EI,IAAsB,CAAAnO,MAASgN,GAAuB,KAAKhN,CAAK,GAChEqP,KAA4B,CAAArP,MAASsP,GAAuBtP,GAAOwO,EAAa,GAChFe,KAAgC,CAAAvP,MAASsP,GAAuBtP,GAAO8O,EAAiB,GACxFU,KAA8B,CAAAxP,MAASsP,GAAuBtP,GAAOgP,EAAe,GACpFS,KAA0B,CAAAzP,MAASsP,GAAuBtP,GAAOsO,EAAW,GAC5EoB,KAA2B,CAAA1P,MAASsP,GAAuBtP,GAAOkP,EAAY,GAC9ES,KAA4B,CAAA3P,MAASsP,GAAuBtP,GAAOoP,IAAe,EAAI,GACtFQ,KAA4B,CAAA5P,MAASsP,GAAuBtP,GAAO4O,IAAe,EAAI,GAEtFP,KAAsB,CAACrO,GAAO6P,GAAWC,MAAc;AAC3D,QAAMzM,IAAS0J,GAAoB,KAAK/M,CAAK;AAC7C,SAAIqD,IACEA,EAAO,CAAC,IACHwM,EAAUxM,EAAO,CAAC,CAAC,IAErByM,EAAUzM,EAAO,CAAC,CAAC,IAErB;AACT,GACMiM,KAAyB,CAACtP,GAAO6P,GAAWE,IAAqB,OAAU;AAC/E,QAAM1M,IAAS2J,GAAuB,KAAKhN,CAAK;AAChD,SAAIqD,IACEA,EAAO,CAAC,IACHwM,EAAUxM,EAAO,CAAC,CAAC,IAErB0M,IAEF;AACT,GAEMf,KAAkB,CAAAgB,MAASA,MAAU,cAAcA,MAAU,cAC7Dd,KAAe,CAAAc,MAASA,MAAU,WAAWA,MAAU,OACvD1B,KAAc,CAAA0B,MAASA,MAAU,YAAYA,MAAU,UAAUA,MAAU,WAC3ExB,KAAgB,CAAAwB,MAASA,MAAU,UACnCtB,KAAgB,CAAAsB,MAASA,MAAU,UACnClB,KAAoB,CAAAkB,MAASA,MAAU,eACvCpB,KAAgB,CAAAoB,MAASA,MAAU,YAAYA,MAAU,UACzDZ,KAAgB,CAAAY,MAASA,MAAU,UA8BnCC,KAAmB,MAAM;AAM7B,QAAMC,IAAarD,GAAU,OAAO,GAC9BsD,IAAYtD,GAAU,MAAM,GAC5BuD,IAAYvD,GAAU,MAAM,GAC5BwD,IAAkBxD,GAAU,aAAa,GACzCyD,IAAgBzD,GAAU,UAAU,GACpC0D,IAAe1D,GAAU,SAAS,GAClC2D,IAAkB3D,GAAU,YAAY,GACxC4D,IAAiB5D,GAAU,WAAW,GACtC6D,IAAe7D,GAAU,SAAS,GAClC8D,IAAc9D,GAAU,QAAQ,GAChC+D,IAAc/D,GAAU,QAAQ,GAChCgE,IAAmBhE,GAAU,cAAc,GAC3CiE,IAAkBjE,GAAU,aAAa,GACzCkE,IAAkBlE,GAAU,aAAa,GACzCmE,IAAYnE,GAAU,MAAM,GAC5BoE,IAAmBpE,GAAU,aAAa,GAC1CqE,IAAcrE,GAAU,QAAQ,GAChCsE,IAAYtE,GAAU,MAAM,GAC5BuE,IAAevE,GAAU,SAAS,GAQlCwE,IAAa,MAAM,CAAC,QAAQ,SAAS,OAAO,cAAc,QAAQ,QAAQ,SAAS,QAAQ,GAC3FC,IAAgB,MAAM;AAAA,IAAC;AAAA,IAAU;AAAA,IAAO;AAAA,IAAU;AAAA,IAAQ;AAAA,IAAS;AAAA;AAAA,IAEzE;AAAA,IAAY;AAAA;AAAA,IAEZ;AAAA,IAAa;AAAA;AAAA,IAEb;AAAA,IAAgB;AAAA;AAAA,IAEhB;AAAA,EAAa,GACPC,IAA6B,MAAM,CAAC,GAAGD,EAAa,GAAInD,GAAqBD,CAAgB,GAC7FsD,IAAgB,MAAM,CAAC,QAAQ,UAAU,QAAQ,WAAW,QAAQ,GACpEC,IAAkB,MAAM,CAAC,QAAQ,WAAW,MAAM,GAClDC,IAA0B,MAAM,CAACvD,GAAqBD,GAAkBwC,CAAY,GACpFiB,IAAa,MAAM,CAACpE,IAAY,QAAQ,QAAQ,GAAGmE,GAAyB,GAC5EE,IAA4B,MAAM,CAACnE,IAAW,QAAQ,WAAWU,GAAqBD,CAAgB,GACtG2D,IAA6B,MAAM,CAAC,QAAQ;AAAA,IAChD,MAAM,CAAC,QAAQpE,IAAWU,GAAqBD,CAAgB;AAAA,EACnE,GAAKT,IAAWU,GAAqBD,CAAgB,GAC7C4D,IAA4B,MAAM,CAACrE,IAAW,QAAQU,GAAqBD,CAAgB,GAC3F6D,IAAwB,MAAM,CAAC,QAAQ,OAAO,OAAO,MAAM5D,GAAqBD,CAAgB,GAChG8D,IAAwB,MAAM,CAAC,SAAS,OAAO,UAAU,WAAW,UAAU,UAAU,WAAW,YAAY,eAAe,UAAU,GACxIC,IAA0B,MAAM,CAAC,SAAS,OAAO,UAAU,WAAW,eAAe,UAAU,GAC/FC,IAAc,MAAM,CAAC,QAAQ,GAAGR,EAAuB,CAAE,GACzDS,IAAc,MAAM,CAAC5E,IAAY,QAAQ,QAAQ,OAAO,OAAO,OAAO,OAAO,OAAO,OAAO,OAAO,OAAO,OAAO,GAAGmE,GAAyB,GAC5IU,IAAoB,MAAM,CAAC7E,IAAY,UAAU,QAAQ,OAAO,OAAO,OAAO,OAAO,OAAO,OAAO,GAAGmE,EAAuB,CAAE,GAC/HW,IAAmB,MAAM,CAAC9E,IAAY,UAAU,QAAQ,MAAM,OAAO,OAAO,OAAO,OAAO,OAAO,OAAO,GAAGmE,EAAuB,CAAE,GACpIY,IAAa,MAAM,CAACpC,GAAY/B,GAAqBD,CAAgB,GACrEqE,KAAkB,MAAM,CAAC,GAAGjB,EAAa,GAAI9B,IAA6BT,IAAqB;AAAA,IACnG,UAAU,CAACZ,GAAqBD,CAAgB;AAAA,EACpD,CAAG,GACKsE,KAAgB,MAAM,CAAC,aAAa;AAAA,IACxC,QAAQ,CAAC,IAAI,KAAK,KAAK,SAAS,OAAO;AAAA,EAC3C,CAAG,GACKC,KAAc,MAAM,CAAC,QAAQ,SAAS,WAAWhD,IAAyBrB,IAAiB;AAAA,IAC/F,MAAM,CAACD,GAAqBD,CAAgB;AAAA,EAChD,CAAG,GACKwE,KAA4B,MAAM,CAAChF,IAAW2B,IAA2Bd,EAAiB,GAC1FoE,IAAc,MAAM;AAAA;AAAA,IAE1B;AAAA,IAAI;AAAA,IAAQ;AAAA,IAAQhC;AAAA,IAAaxC;AAAA,IAAqBD;AAAA,EAAgB,GAChE0E,KAAmB,MAAM,CAAC,IAAIpF,GAAU6B,IAA2Bd,EAAiB,GACpFsE,KAAiB,MAAM,CAAC,SAAS,UAAU,UAAU,QAAQ,GAC7DC,IAAiB,MAAM,CAAC,UAAU,YAAY,UAAU,WAAW,UAAU,WAAW,eAAe,cAAc,cAAc,cAAc,cAAc,aAAa,OAAO,cAAc,SAAS,YAAY,GACtNC,IAAyB,MAAM,CAACvF,GAAUE,IAAW8B,IAA6BT,EAAmB,GACrGiE,KAAY,MAAM;AAAA;AAAA,IAExB;AAAA,IAAI;AAAA,IAAQhC;AAAA,IAAW7C;AAAA,IAAqBD;AAAA,EAAgB,GACtD+E,KAAc,MAAM,CAAC,QAAQzF,GAAUW,GAAqBD,CAAgB,GAC5EgF,KAAa,MAAM,CAAC,QAAQ1F,GAAUW,GAAqBD,CAAgB,GAC3EiF,IAAY,MAAM,CAAC3F,GAAUW,GAAqBD,CAAgB,GAClEkF,KAAiB,MAAM,CAAC7F,IAAY,QAAQ,GAAGmE,EAAuB,CAAE;AAC9E,SAAO;AAAA,IACL,WAAW;AAAA,IACX,OAAO;AAAA,MACL,SAAS,CAAC,QAAQ,QAAQ,SAAS,QAAQ;AAAA,MAC3C,QAAQ,CAAC,OAAO;AAAA,MAChB,MAAM,CAAC/D,EAAY;AAAA,MACnB,YAAY,CAACA,EAAY;AAAA,MACzB,OAAO,CAACC,EAAK;AAAA,MACb,WAAW,CAACD,EAAY;AAAA,MACxB,eAAe,CAACA,EAAY;AAAA,MAC5B,MAAM,CAAC,MAAM,OAAO,QAAQ;AAAA,MAC5B,MAAM,CAACM,EAAiB;AAAA,MACxB,eAAe,CAAC,QAAQ,cAAc,SAAS,UAAU,UAAU,YAAY,QAAQ,aAAa,OAAO;AAAA,MAC3G,gBAAgB,CAACN,EAAY;AAAA,MAC7B,SAAS,CAAC,QAAQ,SAAS,QAAQ,UAAU,WAAW,OAAO;AAAA,MAC/D,aAAa,CAAC,YAAY,QAAQ,UAAU,YAAY,WAAW,MAAM;AAAA,MACzE,QAAQ,CAACA,EAAY;AAAA,MACrB,QAAQ,CAACA,EAAY;AAAA,MACrB,SAAS,CAAC,MAAMH,CAAQ;AAAA,MACxB,MAAM,CAACG,EAAY;AAAA,MACnB,eAAe,CAACA,EAAY;AAAA,MAC5B,UAAU,CAAC,WAAW,SAAS,UAAU,QAAQ,SAAS,QAAQ;AAAA,IACxE;AAAA,IACI,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQX,QAAQ,CAAC;AAAA,QACP,QAAQ,CAAC,QAAQ,UAAUJ,IAAYW,GAAkBC,GAAqB+C,CAAW;AAAA,MACjG,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAMD,WAAW,CAAC,WAAW;AAAA;AAAA;AAAA;AAAA;AAAA,MAKvB,SAAS,CAAC;AAAA,QACR,SAAS,CAAC1D,GAAUU,GAAkBC,GAAqBsC,CAAc;AAAA,MACjF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,eAAeY,EAAU;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,gBAAgBA,EAAU;AAAA,MAClC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,gBAAgB,CAAC,QAAQ,SAAS,cAAc,cAAc;AAAA,MACtE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,kBAAkB,CAAC,SAAS,OAAO;AAAA,MAC3C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,KAAK,CAAC;AAAA,QACJ,KAAK,CAAC,UAAU,SAAS;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC,SAAS,gBAAgB,UAAU,QAAQ,eAAe,SAAS,gBAAgB,iBAAiB,cAAc,gBAAgB,sBAAsB,sBAAsB,sBAAsB,mBAAmB,aAAa,aAAa,QAAQ,eAAe,YAAY,aAAa,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,MAKnT,IAAI,CAAC,WAAW,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,MAK7B,OAAO,CAAC;AAAA,QACN,OAAO,CAAC,SAAS,QAAQ,QAAQ,SAAS,KAAK;AAAA,MACvD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,OAAO,CAAC;AAAA,QACN,OAAO,CAAC,QAAQ,SAAS,QAAQ,QAAQ,SAAS,KAAK;AAAA,MAC/D,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC,WAAW,gBAAgB;AAAA;AAAA;AAAA;AAAA;AAAA,MAKvC,cAAc,CAAC;AAAA,QACb,QAAQ,CAAC,WAAW,SAAS,QAAQ,QAAQ,YAAY;AAAA,MACjE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,QAAQE,EAA0B;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,UAAU,CAAC;AAAA,QACT,UAAUC,EAAa;AAAA,MAC/B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAa;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAa;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYC,EAAe;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,gBAAgBA,EAAe;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,gBAAgBA,EAAe;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,UAAU,CAAC,UAAU,SAAS,YAAY,YAAY,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,MAK9D,OAAO,CAAC;AAAA,QACN,OAAOE,EAAU;AAAA,MACzB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAWA,EAAU;AAAA,MAC7B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAWA,EAAU;AAAA,MAC7B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAMD,OAAO,CAAC;AAAA,QACN,WAAWA,EAAU;AAAA;AAAA;AAAA;AAAA;AAAA,QAKrB,OAAOA,EAAU;AAAA,MACzB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAMD,KAAK,CAAC;AAAA,QACJ,WAAWA,EAAU;AAAA;AAAA;AAAA;AAAA;AAAA,QAKrB,KAAKA,EAAU;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,KAAK,CAAC;AAAA,QACJ,KAAKA,EAAU;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,OAAO,CAAC;AAAA,QACN,OAAOA,EAAU;AAAA,MACzB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,QAAQ,CAAC;AAAA,QACP,QAAQA,EAAU;AAAA,MAC1B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,MAAM,CAAC;AAAA,QACL,MAAMA,EAAU;AAAA,MACxB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC,WAAW,aAAa,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA,MAK/C,GAAG,CAAC;AAAA,QACF,GAAG,CAAClE,IAAW,QAAQU,GAAqBD,CAAgB;AAAA,MACpE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,OAAO,CAAC;AAAA,QACN,OAAO,CAACX,IAAY,QAAQ,QAAQkD,GAAgB,GAAGiB,EAAuB,CAAE;AAAA,MACxF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,MAAM,CAAC,OAAO,eAAe,OAAO,aAAa;AAAA,MACzD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,MAAM,CAAC,UAAU,QAAQ,cAAc;AAAA,MAC/C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,MAAM,CAAC;AAAA,QACL,MAAM,CAAClE,GAAUD,IAAY,QAAQ,WAAW,QAAQW,CAAgB;AAAA,MAChF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,MAAM,CAAC;AAAA,QACL,MAAM,CAAC,IAAIV,GAAUW,GAAqBD,CAAgB;AAAA,MAClE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,QAAQ,CAAC;AAAA,QACP,QAAQ,CAAC,IAAIV,GAAUW,GAAqBD,CAAgB;AAAA,MACpE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,OAAO,CAAC;AAAA,QACN,OAAO,CAACT,IAAW,SAAS,QAAQ,QAAQU,GAAqBD,CAAgB;AAAA,MACzF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAa0D,EAAyB;AAAA,MAC9C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,KAAKC,EAA0B;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaC,EAAyB;AAAA,MAC9C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAWA,EAAyB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaF,EAAyB;AAAA,MAC9C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,KAAKC,EAA0B;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaC,EAAyB;AAAA,MAC9C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAWA,EAAyB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAa,CAAC,OAAO,OAAO,SAAS,aAAa,WAAW;AAAA,MACrE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaC,EAAqB;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAqB;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,KAAK,CAAC;AAAA,QACJ,KAAKL,EAAuB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAASA,EAAuB;AAAA,MACxC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAASA,EAAuB;AAAA,MACxC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,SAAS,CAAC,GAAGM,EAAqB,GAAI,QAAQ;AAAA,MACtD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,iBAAiB,CAAC,GAAGC,EAAuB,GAAI,QAAQ;AAAA,MAChE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,gBAAgB,CAAC,QAAQ,GAAGA,EAAuB,CAAE;AAAA,MAC7D,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,SAAS,CAAC,UAAU,GAAGD,EAAqB,CAAE;AAAA,MACtD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,OAAO,CAAC,GAAGC,KAA2B;AAAA,UACpC,UAAU,CAAC,IAAI,MAAM;AAAA,QAC/B,CAAS;AAAA,MACT,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,MAAM,CAAC,QAAQ,GAAGA,KAA2B;AAAA,UAC3C,UAAU,CAAC,IAAI,MAAM;AAAA,QAC/B,CAAS;AAAA,MACT,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,iBAAiBD,EAAqB;AAAA,MAC9C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,eAAe,CAAC,GAAGC,EAAuB,GAAI,UAAU;AAAA,MAChE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAc,CAAC,QAAQ,GAAGA,EAAuB,CAAE;AAAA,MAC3D,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAMD,GAAG,CAAC;AAAA,QACF,GAAGP,EAAuB;AAAA,MAClC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAuB;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAuB;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAuB;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAuB;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,KAAK,CAAC;AAAA,QACJ,KAAKA,EAAuB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,KAAK,CAAC;AAAA,QACJ,KAAKA,EAAuB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAuB;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAuB;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAuB;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAuB;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,GAAG,CAAC;AAAA,QACF,GAAGQ,EAAW;AAAA,MACtB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAW;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAW;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAW;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAW;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,KAAK,CAAC;AAAA,QACJ,KAAKA,EAAW;AAAA,MACxB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,KAAK,CAAC;AAAA,QACJ,KAAKA,EAAW;AAAA,MACxB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAW;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAW;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAW;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,IAAI,CAAC;AAAA,QACH,IAAIA,EAAW;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAWR,EAAuB;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC,iBAAiB;AAAA;AAAA;AAAA;AAAA;AAAA,MAKrC,WAAW,CAAC;AAAA,QACV,WAAWA,EAAuB;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC,iBAAiB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQrC,MAAM,CAAC;AAAA,QACL,MAAMS,EAAW;AAAA,MACzB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,QAAQ,CAAC,QAAQ,GAAGC,EAAiB,CAAE;AAAA,MAC/C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,cAAc,CAAC,QAAQ,GAAGA,EAAiB,CAAE;AAAA,MACrD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,cAAc,CAAC,QAAQ,GAAGA,EAAiB,CAAE;AAAA,MACrD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,OAAO,CAAC,QAAQ,GAAGC,EAAgB,CAAE;AAAA,MAC7C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,aAAa,CAAC,QAAQ,GAAGA,EAAgB,CAAE;AAAA,MACnD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,aAAa,CAAC,QAAQ,GAAGA,EAAgB,CAAE;AAAA,MACnD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,GAAG,CAAC;AAAA,QACF,GAAG,CAAC5B,GAAgB,UAAU,GAAG0B,EAAW,CAAE;AAAA,MACtD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS;AAAA,UAAC1B;AAAA,UAAgB;AAAA;AAAA,UAC1B;AAAA,UAAQ,GAAG0B,EAAW;AAAA,QAAE;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS;AAAA,UAAC1B;AAAA,UAAgB;AAAA,UAAU;AAAA;AAAA,UACpC;AAAA;AAAA,UACA;AAAA,YACE,QAAQ,CAACD,CAAe;AAAA,UAClC;AAAA,UAAW,GAAG2B,EAAW;AAAA,QAAE;AAAA,MAC3B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,GAAG,CAAC;AAAA,QACF,GAAG,CAAC,UAAU,MAAM,GAAGA,EAAW,CAAE;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS,CAAC,UAAU,MAAM,QAAQ,GAAGA,EAAW,CAAE;AAAA,MAC1D,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS,CAAC,UAAU,MAAM,GAAGA,EAAW,CAAE;AAAA,MAClD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,aAAa,CAAC;AAAA,QACZ,MAAM,CAAC,QAAQ/B,GAAWf,IAA2Bd,EAAiB;AAAA,MAC9E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC,eAAe,sBAAsB;AAAA;AAAA;AAAA;AAAA;AAAA,MAKxD,cAAc,CAAC,UAAU,YAAY;AAAA;AAAA;AAAA;AAAA;AAAA,MAKrC,eAAe,CAAC;AAAA,QACd,MAAM,CAAC8B,GAAiBT,IAA2BjB,EAAiB;AAAA,MAC5E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,gBAAgB,CAAC,mBAAmB,mBAAmB,aAAa,kBAAkB,UAAU,iBAAiB,YAAY,kBAAkB,kBAAkBjB,IAAWQ,CAAgB;AAAA,MACpM,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,MAAM,CAACqB,IAA+BV,IAAuBsB,CAAS;AAAA,MAC9E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,iBAAiB,CAACjC,CAAgB;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,MAK5B,eAAe,CAAC,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA,MAKzB,oBAAoB,CAAC,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA,MAKnC,cAAc,CAAC,eAAe,eAAe;AAAA;AAAA;AAAA;AAAA;AAAA,MAK7C,eAAe,CAAC,qBAAqB,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA,MAKnD,gBAAgB,CAAC,sBAAsB,mBAAmB;AAAA;AAAA;AAAA;AAAA;AAAA,MAK1D,UAAU,CAAC;AAAA,QACT,UAAU,CAACoC,GAAenC,GAAqBD,CAAgB;AAAA,MACvE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAc,CAACV,GAAU,QAAQW,GAAqBM,EAAiB;AAAA,MAC/E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS;AAAA;AAAA,UACT8B;AAAA,UAAc,GAAGmB,EAAuB;AAAA,QAAE;AAAA,MAClD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAc,CAAC,QAAQvD,GAAqBD,CAAgB;AAAA,MACpE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,uBAAuB,CAAC;AAAA,QACtB,MAAM,CAAC,UAAU,SAAS;AAAA,MAClC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,MAAM,CAAC,QAAQ,WAAW,QAAQC,GAAqBD,CAAgB;AAAA,MAC/E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,MAAM,CAAC,QAAQ,UAAU,SAAS,WAAW,SAAS,KAAK;AAAA,MACnE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAMD,qBAAqB,CAAC;AAAA,QACpB,aAAaoE,EAAU;AAAA,MAC/B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,MAAMA,EAAU;AAAA,MACxB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC,aAAa,YAAY,gBAAgB,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA,MAK3E,yBAAyB,CAAC;AAAA,QACxB,YAAY,CAAC,GAAGO,GAAc,GAAI,MAAM;AAAA,MAChD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,6BAA6B,CAAC;AAAA,QAC5B,YAAY,CAACrF,GAAU,aAAa,QAAQW,GAAqBI,EAAiB;AAAA,MAC1F,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,yBAAyB,CAAC;AAAA,QACxB,YAAY+D,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,oBAAoB,CAAC;AAAA,QACnB,oBAAoB,CAAC9E,GAAU,QAAQW,GAAqBD,CAAgB;AAAA,MACpF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC,aAAa,aAAa,cAAc,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,MAKxE,iBAAiB,CAAC,YAAY,iBAAiB,WAAW;AAAA;AAAA;AAAA;AAAA;AAAA,MAK1D,aAAa,CAAC;AAAA,QACZ,MAAM,CAAC,QAAQ,UAAU,WAAW,QAAQ;AAAA,MACpD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,QAAQ,CAAC;AAAA,QACP,QAAQwD,EAAuB;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,OAAO,CAAC,YAAY,OAAO,UAAU,UAAU,YAAY,eAAe,OAAO,SAASvD,GAAqBD,CAAgB;AAAA,MACvI,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAY,CAAC,UAAU,UAAU,OAAO,YAAY,YAAY,cAAc;AAAA,MACtF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,OAAO,CAAC;AAAA,QACN,OAAO,CAAC,UAAU,SAAS,OAAO,MAAM;AAAA,MAChD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,MAAM,CAAC;AAAA,QACL,MAAM,CAAC,cAAc,YAAY,QAAQ;AAAA,MACjD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS,CAAC,QAAQ,UAAU,MAAM;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS,CAAC,QAAQC,GAAqBD,CAAgB;AAAA,MAC/D,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,iBAAiB,CAAC;AAAA,QAChB,IAAI,CAAC,SAAS,SAAS,QAAQ;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAW,CAAC,UAAU,WAAW,WAAW,MAAM;AAAA,MAC1D,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAa,CAAC,UAAU,WAAW,SAAS;AAAA,MACpD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,IAAIqE,GAAe;AAAA,MAC3B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,IAAIC,GAAa;AAAA,MACzB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,IAAIC,GAAW;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,IAAI,CAAC,QAAQ;AAAA,UACX,QAAQ,CAAC;AAAA,YACP,IAAI,CAAC,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,IAAI;AAAA,UAC3D,GAAahF,IAAWU,GAAqBD,CAAgB;AAAA,UACnD,QAAQ,CAAC,IAAIC,GAAqBD,CAAgB;AAAA,UAClD,OAAO,CAACT,IAAWU,GAAqBD,CAAgB;AAAA,QAClE,GAAWwB,IAA0BT,EAAgB;AAAA,MACrD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,IAAIqD,EAAU;AAAA,MACtB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,qBAAqB,CAAC;AAAA,QACpB,MAAMI,GAAyB;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,oBAAoB,CAAC;AAAA,QACnB,KAAKA,GAAyB;AAAA,MACtC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,IAAIA,GAAyB;AAAA,MACrC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,MAAMJ,EAAU;AAAA,MACxB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,KAAKA,EAAU;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,IAAIA,EAAU;AAAA,MACtB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,SAAS,CAAC;AAAA,QACR,SAASK,EAAW;AAAA,MAC5B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAW;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAW;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAW;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAW;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAW;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAW;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAW;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAW;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAW;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAW;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAW;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAW;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAW;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAW;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,QAAQC,GAAgB;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,aAAaA,GAAgB;AAAA,MACrC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,aAAaA,GAAgB;AAAA,MACrC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,oBAAoB,CAAC,kBAAkB;AAAA;AAAA;AAAA;AAAA;AAAA,MAKvC,YAAY,CAAC;AAAA,QACX,YAAYA,GAAgB;AAAA,MACpC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,oBAAoB,CAAC,kBAAkB;AAAA;AAAA;AAAA;AAAA;AAAA,MAKvC,gBAAgB,CAAC;AAAA,QACf,QAAQ,CAAC,GAAGC,GAAc,GAAI,UAAU,MAAM;AAAA,MACtD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,QAAQ,CAAC,GAAGA,GAAc,GAAI,UAAU,MAAM;AAAA,MACtD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,QAAQP,EAAU;AAAA,MAC1B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,aAAaA,EAAU;AAAA,MAC/B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,aAAaA,EAAU;AAAA,MAC/B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,YAAYA,EAAU;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,QAAQA,EAAU;AAAA,MAC1B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,SAAS,CAAC,GAAGO,GAAc,GAAI,QAAQ,QAAQ;AAAA,MACvD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,kBAAkB,CAACrF,GAAUW,GAAqBD,CAAgB;AAAA,MAC1E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,SAAS,CAAC,IAAIV,GAAU6B,IAA2Bd,EAAiB;AAAA,MAC5E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,SAAS+D,EAAU;AAAA,MAC3B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,QAAQ,CAAC;AAAA,QACP,QAAQ;AAAA;AAAA,UAER;AAAA,UAAI;AAAA,UAAQ1B;AAAA,UAAajB;AAAA,UAA2BR;AAAA,QAAiB;AAAA,MAC7E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,QAAQmD,EAAU;AAAA,MAC1B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,gBAAgB,CAAC,QAAQzB,GAAkBlB,IAA2BR,EAAiB;AAAA,MAC/F,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,sBAAsB,CAAC;AAAA,QACrB,gBAAgBmD,EAAU;AAAA,MAClC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,UAAU,CAAC;AAAA,QACT,MAAMM,GAAgB;AAAA,MAC9B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOD,gBAAgB,CAAC,YAAY;AAAA;AAAA;AAAA;AAAA;AAAA,MAK7B,cAAc,CAAC;AAAA,QACb,MAAMN,EAAU;AAAA,MACxB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOD,iBAAiB,CAAC;AAAA,QAChB,eAAe,CAAC9E,GAAUe,EAAiB;AAAA,MACnD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOD,qBAAqB,CAAC;AAAA,QACpB,eAAe+D,EAAU;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,cAAcM,GAAgB;AAAA,MACtC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,oBAAoB,CAAC;AAAA,QACnB,cAAcN,EAAU;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,eAAe,CAAC,QAAQxB,GAAiBnB,IAA2BR,EAAiB;AAAA,MAC7F,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,qBAAqB,CAAC;AAAA,QACpB,eAAemD,EAAU;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS,CAAC9E,GAAUW,GAAqBD,CAAgB;AAAA,MACjE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAa,CAAC,GAAG4E,EAAc,GAAI,eAAe,cAAc;AAAA,MACxE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYA,EAAc;AAAA,MAClC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAa,CAAC,UAAU,WAAW,WAAW,QAAQ,UAAU,MAAM;AAAA,MAC9E,GAAS,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA,MAKjB,kBAAkB,CAAC;AAAA,QACjB,MAAM,CAAC,OAAO,YAAY,aAAa,SAAS;AAAA,MACxD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,yBAAyB,CAAC;AAAA,QACxB,eAAe,CAACtF,CAAQ;AAAA,MAChC,CAAO;AAAA,MACD,8BAA8B,CAAC;AAAA,QAC7B,oBAAoBuF,EAAsB;AAAA,MAClD,CAAO;AAAA,MACD,4BAA4B,CAAC;AAAA,QAC3B,kBAAkBA,EAAsB;AAAA,MAChD,CAAO;AAAA,MACD,gCAAgC,CAAC;AAAA,QAC/B,oBAAoBT,EAAU;AAAA,MACtC,CAAO;AAAA,MACD,8BAA8B,CAAC;AAAA,QAC7B,kBAAkBA,EAAU;AAAA,MACpC,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,eAAeS,EAAsB;AAAA,MAC7C,CAAO;AAAA,MACD,uBAAuB,CAAC;AAAA,QACtB,aAAaA,EAAsB;AAAA,MAC3C,CAAO;AAAA,MACD,2BAA2B,CAAC;AAAA,QAC1B,eAAeT,EAAU;AAAA,MACjC,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,aAAaA,EAAU;AAAA,MAC/B,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,eAAeS,EAAsB;AAAA,MAC7C,CAAO;AAAA,MACD,uBAAuB,CAAC;AAAA,QACtB,aAAaA,EAAsB;AAAA,MAC3C,CAAO;AAAA,MACD,2BAA2B,CAAC;AAAA,QAC1B,eAAeT,EAAU;AAAA,MACjC,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,aAAaA,EAAU;AAAA,MAC/B,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,eAAeS,EAAsB;AAAA,MAC7C,CAAO;AAAA,MACD,uBAAuB,CAAC;AAAA,QACtB,aAAaA,EAAsB;AAAA,MAC3C,CAAO;AAAA,MACD,2BAA2B,CAAC;AAAA,QAC1B,eAAeT,EAAU;AAAA,MACjC,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,aAAaA,EAAU;AAAA,MAC/B,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,eAAeS,EAAsB;AAAA,MAC7C,CAAO;AAAA,MACD,uBAAuB,CAAC;AAAA,QACtB,aAAaA,EAAsB;AAAA,MAC3C,CAAO;AAAA,MACD,2BAA2B,CAAC;AAAA,QAC1B,eAAeT,EAAU;AAAA,MACjC,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,aAAaA,EAAU;AAAA,MAC/B,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,eAAeS,EAAsB;AAAA,MAC7C,CAAO;AAAA,MACD,uBAAuB,CAAC;AAAA,QACtB,aAAaA,EAAsB;AAAA,MAC3C,CAAO;AAAA,MACD,2BAA2B,CAAC;AAAA,QAC1B,eAAeT,EAAU;AAAA,MACjC,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,aAAaA,EAAU;AAAA,MAC/B,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,eAAeS,EAAsB;AAAA,MAC7C,CAAO;AAAA,MACD,uBAAuB,CAAC;AAAA,QACtB,aAAaA,EAAsB;AAAA,MAC3C,CAAO;AAAA,MACD,2BAA2B,CAAC;AAAA,QAC1B,eAAeT,EAAU;AAAA,MACjC,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,aAAaA,EAAU;AAAA,MAC/B,CAAO;AAAA,MACD,qBAAqB,CAAC;AAAA,QACpB,eAAe,CAACnE,GAAqBD,CAAgB;AAAA,MAC7D,CAAO;AAAA,MACD,8BAA8B,CAAC;AAAA,QAC7B,oBAAoB6E,EAAsB;AAAA,MAClD,CAAO;AAAA,MACD,4BAA4B,CAAC;AAAA,QAC3B,kBAAkBA,EAAsB;AAAA,MAChD,CAAO;AAAA,MACD,gCAAgC,CAAC;AAAA,QAC/B,oBAAoBT,EAAU;AAAA,MACtC,CAAO;AAAA,MACD,8BAA8B,CAAC;AAAA,QAC7B,kBAAkBA,EAAU;AAAA,MACpC,CAAO;AAAA,MACD,2BAA2B,CAAC;AAAA,QAC1B,eAAe,CAAC,UAAU,SAAS;AAAA,MAC3C,CAAO;AAAA,MACD,0BAA0B,CAAC;AAAA,QACzB,eAAe,CAAC;AAAA,UACd,SAAS,CAAC,QAAQ,QAAQ;AAAA,UAC1B,UAAU,CAAC,QAAQ,QAAQ;AAAA,QACrC,CAAS;AAAA,MACT,CAAO;AAAA,MACD,yBAAyB,CAAC;AAAA,QACxB,kBAAkBhB,EAAa;AAAA,MACvC,CAAO;AAAA,MACD,wBAAwB,CAAC;AAAA,QACvB,cAAc,CAAC9D,CAAQ;AAAA,MAC/B,CAAO;AAAA,MACD,6BAA6B,CAAC;AAAA,QAC5B,mBAAmBuF,EAAsB;AAAA,MACjD,CAAO;AAAA,MACD,2BAA2B,CAAC;AAAA,QAC1B,iBAAiBA,EAAsB;AAAA,MAC/C,CAAO;AAAA,MACD,+BAA+B,CAAC;AAAA,QAC9B,mBAAmBT,EAAU;AAAA,MACrC,CAAO;AAAA,MACD,6BAA6B,CAAC;AAAA,QAC5B,iBAAiBA,EAAU;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,MAAM,CAAC,SAAS,aAAa,OAAO;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,eAAe,CAAC,UAAU,WAAW,WAAW,QAAQ,UAAU,MAAM;AAAA,MAChF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,MAAMC,GAAe;AAAA,MAC7B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,MAAMC,GAAa;AAAA,MAC3B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,MAAMC,GAAW;AAAA,MACzB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAa,CAAC,SAAS,WAAW;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,MAAM,CAAC,QAAQtE,GAAqBD,CAAgB;AAAA,MAC5D,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,QAAQ,CAAC;AAAA,QACP,QAAQ;AAAA;AAAA,UAER;AAAA,UAAI;AAAA,UAAQC;AAAA,UAAqBD;AAAA,QAAgB;AAAA,MACzD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,MAAM,CAAC;AAAA,QACL,MAAM8E,GAAS;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAY,CAACxF,GAAUW,GAAqBD,CAAgB;AAAA,MACpE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,UAAU,CAAC;AAAA,QACT,UAAU,CAACV,GAAUW,GAAqBD,CAAgB;AAAA,MAClE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,eAAe;AAAA;AAAA,UAEf;AAAA,UAAI;AAAA,UAAQ6C;AAAA,UAAiBpB;AAAA,UAA2BR;AAAA,QAAiB;AAAA,MACjF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,qBAAqB,CAAC;AAAA,QACpB,eAAemD,EAAU;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAW,CAAC,IAAI9E,GAAUW,GAAqBD,CAAgB;AAAA,MACvE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAc,CAACV,GAAUW,GAAqBD,CAAgB;AAAA,MACtE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,QAAQ,CAAC;AAAA,QACP,QAAQ,CAAC,IAAIV,GAAUW,GAAqBD,CAAgB;AAAA,MACpE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,UAAU,CAAC;AAAA,QACT,UAAU,CAACV,GAAUW,GAAqBD,CAAgB;AAAA,MAClE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,OAAO,CAAC;AAAA,QACN,OAAO,CAAC,IAAIV,GAAUW,GAAqBD,CAAgB;AAAA,MACnE,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,mBAAmB;AAAA;AAAA,UAEnB;AAAA,UAAI;AAAA,UAAQC;AAAA,UAAqBD;AAAA,QAAgB;AAAA,MACzD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,iBAAiB,CAAC;AAAA,QAChB,iBAAiB8E,GAAS;AAAA,MAClC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,uBAAuB,CAAC;AAAA,QACtB,uBAAuB,CAACxF,GAAUW,GAAqBD,CAAgB;AAAA,MAC/E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,qBAAqB,CAAC;AAAA,QACpB,qBAAqB,CAACV,GAAUW,GAAqBD,CAAgB;AAAA,MAC7E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,sBAAsB,CAAC;AAAA,QACrB,sBAAsB,CAAC,IAAIV,GAAUW,GAAqBD,CAAgB;AAAA,MAClF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,uBAAuB,CAAC;AAAA,QACtB,uBAAuB,CAACV,GAAUW,GAAqBD,CAAgB;AAAA,MAC/E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,mBAAmB,CAAC,IAAIV,GAAUW,GAAqBD,CAAgB;AAAA,MAC/E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,oBAAoB,CAAC;AAAA,QACnB,oBAAoB,CAACV,GAAUW,GAAqBD,CAAgB;AAAA,MAC5E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,qBAAqB,CAAC;AAAA,QACpB,qBAAqB,CAACV,GAAUW,GAAqBD,CAAgB;AAAA,MAC7E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,kBAAkB,CAAC,IAAIV,GAAUW,GAAqBD,CAAgB;AAAA,MAC9E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,mBAAmB,CAAC;AAAA,QAClB,QAAQ,CAAC,YAAY,UAAU;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,kBAAkBwD,EAAuB;AAAA,MACjD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,oBAAoB,CAAC;AAAA,QACnB,oBAAoBA,EAAuB;AAAA,MACnD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,oBAAoB,CAAC;AAAA,QACnB,oBAAoBA,EAAuB;AAAA,MACnD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,OAAO,CAAC,QAAQ,OAAO;AAAA,MAC/B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS,CAAC,OAAO,QAAQ;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,YAAY,CAAC;AAAA,QACX,YAAY,CAAC,IAAI,OAAO,UAAU,WAAW,UAAU,aAAa,QAAQvD,GAAqBD,CAAgB;AAAA,MACzH,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,uBAAuB,CAAC;AAAA,QACtB,YAAY,CAAC,UAAU,UAAU;AAAA,MACzC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,UAAU,CAAC;AAAA,QACT,UAAU,CAACV,GAAU,WAAWW,GAAqBD,CAAgB;AAAA,MAC7E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,MAAM,CAAC;AAAA,QACL,MAAM,CAAC,UAAU,WAAWiD,GAAWhD,GAAqBD,CAAgB;AAAA,MACpF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,OAAO,CAAC;AAAA,QACN,OAAO,CAACV,GAAUW,GAAqBD,CAAgB;AAAA,MAC/D,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,SAAS,CAAC;AAAA,QACR,SAAS,CAAC,QAAQkD,GAAcjD,GAAqBD,CAAgB;AAAA,MAC7E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,UAAU,CAAC;AAAA,QACT,UAAU,CAAC,UAAU,SAAS;AAAA,MACtC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAa,CAAC+C,GAAkB9C,GAAqBD,CAAgB;AAAA,MAC7E,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,sBAAsB,CAAC;AAAA,QACrB,sBAAsBqD,EAA0B;AAAA,MACxD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,QAAQ,CAAC;AAAA,QACP,QAAQ0B,GAAW;AAAA,MAC3B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYA,GAAW;AAAA,MAC/B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYA,GAAW;AAAA,MAC/B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYA,GAAW;AAAA,MAC/B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,OAAO,CAAC;AAAA,QACN,OAAOC,GAAU;AAAA,MACzB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAWA,GAAU;AAAA,MAC7B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAWA,GAAU;AAAA,MAC7B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAWA,GAAU;AAAA,MAC7B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA,MAKvB,MAAM,CAAC;AAAA,QACL,MAAMC,EAAS;AAAA,MACvB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,UAAU,CAAC;AAAA,QACT,UAAUA,EAAS;AAAA,MAC3B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,UAAU,CAAC;AAAA,QACT,UAAUA,EAAS;AAAA,MAC3B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAW,CAAChF,GAAqBD,GAAkB,IAAI,QAAQ,OAAO,KAAK;AAAA,MACnF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,oBAAoB,CAAC;AAAA,QACnB,QAAQqD,EAA0B;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,WAAW,CAAC,MAAM,MAAM;AAAA,MAChC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,WAAW6B,GAAc;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,eAAeA,GAAc;AAAA,MACrC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,eAAeA,GAAc;AAAA,MACrC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,eAAeA,GAAc;AAAA,MACrC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC,gBAAgB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQnC,QAAQ,CAAC;AAAA,QACP,QAAQd,EAAU;AAAA,MAC1B,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAY,CAAC,QAAQ,MAAM;AAAA,MACnC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,OAAOA,EAAU;AAAA,MACzB,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,QAAQ,CAAC,UAAU,QAAQ,SAAS,cAAc,aAAa,YAAY;AAAA,MACnF,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,QAAQ,CAAC;AAAA,QACP,QAAQ,CAAC,QAAQ,WAAW,WAAW,QAAQ,QAAQ,QAAQ,QAAQ,eAAe,QAAQ,gBAAgB,YAAY,QAAQ,aAAa,iBAAiB,SAAS,QAAQ,WAAW,QAAQ,YAAY,cAAc,cAAc,cAAc,YAAY,YAAY,YAAY,YAAY,aAAa,aAAa,aAAa,aAAa,aAAa,aAAa,eAAe,eAAe,WAAW,YAAYnE,GAAqBD,CAAgB;AAAA,MAC1d,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,gBAAgB,CAAC;AAAA,QACf,gBAAgB,CAAC,SAAS,SAAS;AAAA,MAC3C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,kBAAkB,CAAC;AAAA,QACjB,kBAAkB,CAAC,QAAQ,MAAM;AAAA,MACzC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,QAAQ,CAAC;AAAA,QACP,QAAQ,CAAC,QAAQ,IAAI,KAAK,GAAG;AAAA,MACrC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,QAAQ,CAAC,QAAQ,QAAQ;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYwD,EAAuB;AAAA,MAC3C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAuB;AAAA,MAC7C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAuB;AAAA,MAC7C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,YAAYA,EAAuB;AAAA,MAC3C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAuB;AAAA,MAC7C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,cAAcA,EAAuB;AAAA,MAC7C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,aAAaA,EAAuB;AAAA,MAC5C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,cAAc,CAAC;AAAA,QACb,MAAM,CAAC,SAAS,OAAO,UAAU,YAAY;AAAA,MACrD,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,MAAM,CAAC,UAAU,QAAQ;AAAA,MACjC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,aAAa,CAAC;AAAA,QACZ,MAAM,CAAC,QAAQ,KAAK,KAAK,MAAM;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,mBAAmB,CAAC;AAAA,QAClB,MAAM,CAAC,aAAa,WAAW;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,OAAO,CAAC;AAAA,QACN,OAAO,CAAC,QAAQ,QAAQ,cAAc;AAAA,MAC9C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,aAAa,CAAC,KAAK,QAAQ,OAAO;AAAA,MAC1C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,WAAW,CAAC;AAAA,QACV,aAAa,CAAC,KAAK,MAAM,MAAM;AAAA,MACvC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC,kBAAkB;AAAA;AAAA;AAAA;AAAA;AAAA,MAK/B,QAAQ,CAAC;AAAA,QACP,QAAQ,CAAC,QAAQ,QAAQ,OAAO,MAAM;AAAA,MAC9C,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,eAAe,CAAC;AAAA,QACd,eAAe,CAAC,QAAQ,UAAU,YAAY,aAAavD,GAAqBD,CAAgB;AAAA,MACxG,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,MAAM,CAAC;AAAA,QACL,MAAM,CAAC,QAAQ,GAAGoE,EAAU,CAAE;AAAA,MACtC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,YAAY,CAAC;AAAA,QACX,QAAQ,CAAC9E,GAAU6B,IAA2Bd,IAAmBE,EAAiB;AAAA,MAC1F,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKD,QAAQ,CAAC;AAAA,QACP,QAAQ,CAAC,QAAQ,GAAG6D,EAAU,CAAE;AAAA,MACxC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQD,uBAAuB,CAAC;AAAA,QACtB,uBAAuB,CAAC,QAAQ,MAAM;AAAA,MAC9C,CAAO;AAAA,IACP;AAAA,IACI,wBAAwB;AAAA,MACtB,UAAU,CAAC,cAAc,YAAY;AAAA,MACrC,YAAY,CAAC,gBAAgB,cAAc;AAAA,MAC3C,OAAO,CAAC,WAAW,WAAW,YAAY,YAAY,SAAS,OAAO,OAAO,SAAS,UAAU,MAAM;AAAA,MACtG,WAAW,CAAC,SAAS,MAAM;AAAA,MAC3B,WAAW,CAAC,OAAO,QAAQ;AAAA,MAC3B,MAAM,CAAC,SAAS,QAAQ,QAAQ;AAAA,MAChC,KAAK,CAAC,SAAS,OAAO;AAAA,MACtB,GAAG,CAAC,MAAM,MAAM,MAAM,MAAM,OAAO,OAAO,MAAM,MAAM,MAAM,IAAI;AAAA,MAChE,IAAI,CAAC,MAAM,IAAI;AAAA,MACf,IAAI,CAAC,MAAM,IAAI;AAAA,MACf,GAAG,CAAC,MAAM,MAAM,MAAM,MAAM,OAAO,OAAO,MAAM,MAAM,MAAM,IAAI;AAAA,MAChE,IAAI,CAAC,MAAM,IAAI;AAAA,MACf,IAAI,CAAC,MAAM,IAAI;AAAA,MACf,MAAM,CAAC,KAAK,GAAG;AAAA,MACf,aAAa,CAAC,SAAS;AAAA,MACvB,cAAc,CAAC,eAAe,oBAAoB,cAAc,eAAe,cAAc;AAAA,MAC7F,eAAe,CAAC,YAAY;AAAA,MAC5B,oBAAoB,CAAC,YAAY;AAAA,MACjC,cAAc,CAAC,YAAY;AAAA,MAC3B,eAAe,CAAC,YAAY;AAAA,MAC5B,gBAAgB,CAAC,YAAY;AAAA,MAC7B,cAAc,CAAC,WAAW,UAAU;AAAA,MACpC,SAAS,CAAC,aAAa,aAAa,aAAa,aAAa,aAAa,aAAa,cAAc,cAAc,cAAc,cAAc,cAAc,cAAc,cAAc,YAAY;AAAA,MACtM,aAAa,CAAC,cAAc,YAAY;AAAA,MACxC,aAAa,CAAC,cAAc,YAAY;AAAA,MACxC,aAAa,CAAC,cAAc,YAAY;AAAA,MACxC,aAAa,CAAC,cAAc,YAAY;AAAA,MACxC,aAAa,CAAC,cAAc,YAAY;AAAA,MACxC,aAAa,CAAC,cAAc,YAAY;AAAA,MACxC,kBAAkB,CAAC,oBAAoB,kBAAkB;AAAA,MACzD,YAAY,CAAC,cAAc,cAAc,cAAc,cAAc,eAAe,eAAe,cAAc,cAAc,cAAc,YAAY;AAAA,MACzJ,cAAc,CAAC,cAAc,YAAY;AAAA,MACzC,cAAc,CAAC,cAAc,YAAY;AAAA,MACzC,gBAAgB,CAAC,kBAAkB,kBAAkB,kBAAkB,kBAAkB,mBAAmB,mBAAmB,kBAAkB,kBAAkB,kBAAkB,gBAAgB;AAAA,MACrM,kBAAkB,CAAC,kBAAkB,gBAAgB;AAAA,MACrD,kBAAkB,CAAC,kBAAkB,gBAAgB;AAAA,MACrD,WAAW,CAAC,eAAe,eAAe,gBAAgB;AAAA,MAC1D,kBAAkB,CAAC,aAAa,eAAe,eAAe,aAAa;AAAA,MAC3E,YAAY,CAAC,aAAa,aAAa,aAAa,aAAa,cAAc,cAAc,aAAa,aAAa,aAAa,WAAW;AAAA,MAC/I,aAAa,CAAC,aAAa,WAAW;AAAA,MACtC,aAAa,CAAC,aAAa,WAAW;AAAA,MACtC,YAAY,CAAC,aAAa,aAAa,aAAa,aAAa,cAAc,cAAc,aAAa,aAAa,aAAa,WAAW;AAAA,MAC/I,aAAa,CAAC,aAAa,WAAW;AAAA,MACtC,aAAa,CAAC,aAAa,WAAW;AAAA,MACtC,OAAO,CAAC,WAAW,WAAW,UAAU;AAAA,MACxC,WAAW,CAAC,OAAO;AAAA,MACnB,WAAW,CAAC,OAAO;AAAA,MACnB,YAAY,CAAC,OAAO;AAAA,IAC1B;AAAA,IACI,gCAAgC;AAAA,MAC9B,aAAa,CAAC,SAAS;AAAA,IAC7B;AAAA,IACI,yBAAyB,CAAC,KAAK,MAAM,SAAS,YAAY,UAAU,mBAAmB,QAAQ,gBAAgB,cAAc,UAAU,eAAe,WAAW;AAAA,EACrK;AACA,GAsDMe,KAAuB,gBAAApH,GAAoBgE,EAAgB;AC5sG1D,SAASvP,MAAM4S,GAAsB;AAC1C,SAAOD,GAAQ1P,GAAK2P,CAAM,CAAC;AAC7B;ACCA,MAAMC,KAAiBzP;AAAA,EACrB;AAAA,EACA;AAAA,IACE,UAAU;AAAA,MACR,SAAS;AAAA,QACP,SAAS;AAAA,QACT,aAAa;AAAA,QACb,SACE;AAAA,QACF,WAAW;AAAA,QACX,OAAO;AAAA,QACP,MAAM;AAAA,MAAA;AAAA,MAER,MAAM;AAAA,QACJ,SAAS;AAAA,QACT,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,MAAM;AAAA,MAAA;AAAA,IACR;AAAA,IAEF,iBAAiB;AAAA,MACf,SAAS;AAAA,MACT,MAAM;AAAA,IAAA;AAAA,EACR;AAEJ,GAOM0P,KAASlX,EAAM;AAAA,EACnB,CAAC,EAAE,WAAAkE,GAAW,SAAA6D,GAAS,MAAAoP,GAAM,SAAAC,IAAU,IAAO,GAAGrX,EAAA,GAASyE,MAGtD,gBAAAF,EAFW8S,IAAUjR,KAAO,UAE3B,EAAK,WAAW/B,GAAG6S,GAAe,EAAE,SAAAlP,GAAS,MAAAoP,GAAM,WAAAjT,EAAA,CAAW,CAAC,GAAG,KAAAM,GAAW,GAAGzE,EAAA,CAAO;AAG9F;AACAmX,GAAO,cAAc;;;;;;GCjCRG,KAA2B,CAAC;AAAA,EACvC,WAAAC;AAAA,EACA,cAAAC;AAAA,EACA,YAAAC;AAAA,EACA,WAAAtT;AAAA,EACA,MAAAiT,IAAO;AACT,MAAM;AACJ,QAAMM,IAA8BC;AAAA,IAClC,OAAO;AAAA,MACL,WAAAJ;AAAA,MACA,cAAAC;AAAA,MACA,YAAAC;AAAA,IAAA;AAAA,IAEF,CAACD,GAAcC,GAAYF,CAAS;AAAA,EAAA;AAGtC,2BACG,OAAA,EAAI,WAAkCpT,GAAY,OAAOuT,GACxD,UAAA,gBAAAnT;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWF,EAAGC,GAAI,sBAAsB;AAAA,QACtC,CAACA,GAAI,OAAO,GAAG8S,MAAS;AAAA,QACxB,CAAC9S,GAAI,SAAS,GAAG8S,MAAS;AAAA,QAC1B,CAAC9S,GAAI,cAAc,GAAG8S,MAAS;AAAA,MAAA,CAChC;AAAA,IAAA;AAAA,EAAA,GAEL;AAEJ;;;;;;;;;;;;;;;;;;;;GCtBMD,KAASS;AAAA,EACb,CACE;AAAA,IACE,SAAA5P,IAAU;AAAA,IACV,MAAAoP,IAAO;AAAA,IACP,WAAAjT,IAAY;AAAA,IACZ,SAAA0T,IAAU;AAAA,IACV,UAAAC,IAAW;AAAA,IACX,UAAA5T;AAAA,IACA,MAAA6T,IAAO;AAAA,IACP,GAAGC;AAAA,EAAA,GAELvT,MACG;AACH,UAAMwT,IAAgB5U;AAAAA,MACpBiB,GAAI;AAAA,MACJA,GAAI,mBAAmB0D,CAAO,EAAE;AAAA,MAChC1D,GAAI,gBAAgB8S,CAAI,EAAE;AAAA,MAC1B;AAAA,QACE,CAAC9S,GAAI,iBAAiB,CAAC,GAAGuT;AAAA,QAC1B,CAACvT,GAAI,kBAAkB,CAAC,GAAGwT;AAAA,MAAA;AAAA,MAE7B3T;AAAA,IAAA;AAGF,WACE,gBAAAC;AAAA,MAAC8T;AAAAA,MAAA;AAAA,QACC,KAAAzT;AAAA,QACA,SAAS;AAAA,QACT,MAAM;AAAA,QACN,WAAWwT;AAAA,QACX,UAAUH,KAAYD;AAAA,QACtB,MAAAE;AAAA,QACC,GAAGC;AAAA,QAEH,UAAA;AAAA,UAAA9T,KAAYA;AAAA,UAEZ2T,KACC,gBAAAtT,EAAC,QAAA,EAAK,WAAWD,GAAI,gBACnB,UAAA,gBAAAC,EAAC+S,IAAA,EAAQ,MAAK,aAAA,CAAa,EAAA,CAC7B;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAIR;AACF;AAEAH,GAAO,cAAc;AC/Dd,MAAMgB,KAAoB,CAAC7S,MAAiC;AACjE,QAAM,CAAC8S,GAAQC,CAAS,IAAIC,EAAS,CAAC,GAChC,CAACC,GAAOC,CAAQ,IAAIF,EAAS,CAAC,GAC9BG,IAASC,GAAsB,IAAI;AAEzC,SAAAC,GAAU,MAAM;AACd,QAAI,CAACrT;AACH;AAGF,UAAMsT,IAAiB,IAAI,eAAe,CAAChN,MAAY;AACrD,MAAI6M,EAAO,WACT,qBAAqBA,EAAO,OAAO,GAGrCA,EAAO,UAAU,sBAAsB,MAAM;AAC3C,mBAAWI,KAASjN;AAClB,cAAIiN,EAAM,eAAe;AACvB,kBAAMC,IAAgB,MAAM,QAAQD,EAAM,aAAa,IACnDA,EAAM,cAAc,CAAC,IACrBA,EAAM;AACV,YAAAR,EAAUS,EAAc,SAAS,GACjCN,EAASM,EAAc,UAAU;AAAA,UACnC;AACE,YAAAT,EAAUQ,EAAM,YAAY,MAAM,GAClCL,EAASK,EAAM,YAAY,KAAK;AAAA,MAGtC,CAAC;AAAA,IACH,CAAC;AAED,IAAAD,EAAe,QAAQtT,CAAO;AAE9B,UAAMyT,IAAgBzT,EAAQ,sBAAA,EAAwB;AACtD,WAAA+S,EAAUU,CAAa,GAEhB,MAAM;AACX,MAAAH,EAAe,WAAA;AAAA,IACjB;AAAA,EACF,GAAG,CAACtT,GAAS+S,CAAS,CAAC,GAERV;AAAA,IACb,OAAO;AAAA,MACL,QAAAS;AAAA,MACA,OAAAG;AAAA,IAAA;AAAA,IAEF,CAACH,GAAQG,CAAK;AAAA,EAAA;AAIlB,GCvCMS,KAAiD,EAAE,SAAS,IAAM,SAAS,GAAA,GAEpEC,KAAsB,CAAC;AAAA,EAClC,YAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,QAAAC,IAAS;AAAA,EACT,SAAAC,IAAU;AAAA,EACV,eAAAC;AACF,MAAgC;AAC9B,QAAM,CAACC,GAAUC,CAAW,IAAIlB,EAA2B,QAAQ,GAC7DG,IAASC,GAAsB,IAAI,GAEnCe,IAAoBC,EAAY,MAAM;AAC1C,QAAI,CAACR,EAAW;AACd,aAAO;AAGT,UAAMS,IAAaT,EAAW,QAAQ,sBAAA,GAChCU,IAAiB,OAAO,aAExBC,IAAaF,EAAW,MAAMP;AAGpC,WAFmBQ,IAAiBD,EAAW,SAASP,KAEtCD,IACT,WAELU,KAAcV,IACT,QAGF;AAAA,EACT,GAAG,CAACD,GAAYC,GAAgBC,CAAM,CAAC,GAEjCU,IAAiBJ,EAAY,MAAM;AACvC,IAAIjB,EAAO,WACT,qBAAqBA,EAAO,OAAO,GAGrCA,EAAO,UAAU,sBAAsB,MAAM;AAC3C,YAAMsB,IAAeN,EAAA;AACrB,MAAAD,EAAYO,CAAY,GACxBT,IAAgBS,CAAY;AAAA,IAC9B,CAAC;AAAA,EACH,GAAG,CAACN,GAAmBH,CAAa,CAAC;AAErC,SAAAX,GAAU,MAAM;AACd,QAAI,CAACU;AACH;AAGF,UAAMW,IAAUd,EAAW;AAC3B,QAAI,CAACc;AACH;AAGF,IAAAF,EAAA;AAEA,UAAMlB,IAAiB,IAAI,eAAe,MAAM;AAC9C,MAAAkB,EAAA;AAAA,IACF,CAAC;AAED,IAAAlB,EAAe,QAAQoB,CAAO;AAE9B,UAAMC,IAAmB,IAAI,iBAAiB,MAAM;AAClD,MAAAH,EAAA;AAAA,IACF,CAAC;AAED,IAAAG,EAAiB,QAAQ,SAAS,MAAM;AAAA,MACtC,WAAW;AAAA,MACX,SAAS;AAAA,MACT,YAAY;AAAA,MACZ,iBAAiB,CAAC,SAAS,OAAO;AAAA,IAAA,CACnC;AAED,UAAMC,IAAmC,CAAA;AACzC,QAAIC,IAASH,EAAQ;AAErB,WAAOG,KAAQ;AACb,YAAMC,IAAQ,OAAO,iBAAiBD,CAAM,GACtCE,IAAWD,EAAM,WAAWA,EAAM,YAAYA,EAAM;AAE1D,MAAI,gBAAgB,KAAKC,CAAQ,MAC/BH,EAAkB,KAAKC,CAAM,GAC7BA,EAAO,iBAAiB,UAAUL,CAAc,IAElDK,IAASA,EAAO;AAAA,IAClB;AAEA,kBAAO,iBAAiB,UAAUL,GAAgBd,EAAqB,GACvE,OAAO,iBAAiB,UAAUc,CAAc,GAChD,OAAO,iBAAiB,iBAAiBA,CAAc,GACvD,OAAO,iBAAiB,gBAAgBA,CAAc,GAE/C,MAAM;AACX,MAAIrB,EAAO,WACT,qBAAqBA,EAAO,OAAO,GAGrCG,EAAe,WAAA,GACfqB,EAAiB,WAAA,GAEjB,OAAO,oBAAoB,UAAUH,GAAgBd,EAAqB,GAC1E,OAAO,oBAAoB,UAAUc,CAAc,GACnD,OAAO,oBAAoB,iBAAiBA,CAAc,GAC1D,OAAO,oBAAoB,gBAAgBA,CAAc,GAEzDI,EAAkB,QAAQ,CAACI,MAAM;AAC/B,QAAAA,EAAE,oBAAoB,UAAUR,CAAc;AAAA,MAChD,CAAC;AAAA,IACH;AAAA,EACF,GAAG,CAACT,GAASH,GAAYY,CAAc,CAAC,GAEjCP;AACT;;;;GC3GagB,KAAmB,CAA4B;AAAA,EAC1D,MAAAC;AAAA,EACA,cAAAC;AAAA,EACA,qBAAAC;AAAA,EACA,UAAAC;AACF,MAAgC;AAC9B,QAAM,CAACC,GAAeC,CAAe,IAAIvC,EAASoC,KAAuBF,EAAK,CAAC,GAAG,EAAE,GAC9E,CAACM,GAAgBC,CAAiB,IAAIzC,EAAS,EAAE,WAAW,iBAAiB,OAAO,GAAG,GACvF0C,IAAatC,GAAoD,oBAAI,KAAK,GAC1EuC,IAAuBR,KAAgBG,GAEvC,EAAE,OAAOM,EAAA,IAAsB/C;AAAA,IACnC6C,EAAW,QAAQ,IAAIC,CAA8B;AAAA,EAAA,GAGjDE,IAAY,CAACC,MAAsC;AACvD,IAAIA,EAAO,OAAOH,MAGlBN,IAAWS,EAAO,EAAE,GACpBP,EAAgBO,EAAO,EAAE;AAAA,EAC3B,GAEMC,IAAc3B,EAAY,CAAC4B,GAA2BvX,MAAwB;AAClF,IAAAiX,EAAW,QAAQ,IAAIjX,GAAIuX,CAAE;AAAA,EAC/B,GAAG,CAAA,CAAE;AAEL,SAAA3C,GAAU,MAAM;AACd,UAAM4C,IAAoBf,EAAK,UAAU,CAACY,MAAWA,EAAO,OAAOH,CAAoB;AACvF,QAAIM,KAAqB,GAAG;AAE1B,YAAMT,IADsBN,EAAK,MAAM,GAAGe,CAAiB,EAChB,OAAO,CAAClT,GAAKmT,MAAW;AACjE,cAAMC,IAAgBT,EAAW,QAAQ,IAAIQ,EAAO,EAAE;AACtD,YAAIC,GAAe;AACjB,gBAAMC,IAAcD,EAAc,sBAAA,EAAwB;AAC1D,UAAApT,KAAOqT;AAAA,QACT;AAEA,eAAOrT;AAAA,MACT,GAAG,CAAC;AAEJ,MAAA0S,EAAkB,EAAE,WAAW,cAAcD,CAAc,OAAO,OAAOI,GAAmB;AAAA,IAC9F;AAAA,EACF,GAAG,CAACD,GAAsBC,GAAmBV,CAAI,CAAC,GAGhD,gBAAApW,EAAC,OAAA,EAAI,WAAWE,GAAI,WACjB,UAAA;AAAA,IAAAkW,EAAK,IAAI,CAACY,MACT,gBAAA7W,EAAC,OAAA,EAAoB,KAAK,CAAC+W,MAAOD,EAAYC,GAAIF,EAAO,EAAE,GACzD,UAAA,gBAAAhX;AAAA,MAAC+S;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,SAAS,MAAMgE,EAAUC,CAAM;AAAA,QAC/B,WAAW/W,EAAG,EAAE,CAACC,GAAI,YAAY,GAAG8W,EAAO,OAAOH,GAAsB;AAAA,QAEvE,UAAA;AAAA,UAAAG,EAAO;AAAA,UACPA,EAAO;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA,KAPFA,EAAO,EASjB,CACD;AAAA,sBACA,OAAA,EAAI,WAAW9W,GAAI,QAAQ,OAAOwW,EAAA,CAAgB;AAAA,EAAA,GACrD;AAEJ;ACmHA,SAASa,GAAUhY,GAAOiY,GAAS;AACjC,MAAIjY,MAAU,MAASA,MAAU,QAAQ,OAAOA,IAAU;AACxD,UAAM,IAAI,MAAMiY,CAAO;AAE3B;AACA,SAASC,GAAQC,GAAMF,GAAS;AAC9B,MAAI,CAACE,GAAM;AACT,IAAI,OAAO,UAAY,OAAa,QAAQ,KAAKF,CAAO;AACxD,QAAI;AACF,YAAM,IAAI,MAAMA,CAAO;AAAA,IACzB,QAAY;AAAA,IACZ;AAAA,EACF;AACF;AAgCA,SAASG,GAAW;AAAA,EAClB,UAAAC,IAAW;AAAA,EACX,QAAAC,IAAS;AAAA,EACT,MAAAC,IAAO;AACT,GAAG;AACD,SAAID,KAAUA,MAAW,QACvBD,KAAYC,EAAO,OAAO,CAAC,MAAM,MAAMA,IAAS,MAAMA,IACpDC,KAAQA,MAAS,QACnBF,KAAYE,EAAK,OAAO,CAAC,MAAM,MAAMA,IAAO,MAAMA,IAC7CF;AACT;AACA,SAASG,GAAUtQ,GAAM;AACvB,MAAIuQ,IAAa,CAAA;AACjB,MAAIvQ,GAAM;AACR,QAAIwQ,IAAYxQ,EAAK,QAAQ,GAAG;AAChC,IAAIwQ,KAAa,MACfD,EAAW,OAAOvQ,EAAK,UAAUwQ,CAAS,GAC1CxQ,IAAOA,EAAK,UAAU,GAAGwQ,CAAS;AAEpC,QAAIC,IAAczQ,EAAK,QAAQ,GAAG;AAClC,IAAIyQ,KAAe,MACjBF,EAAW,SAASvQ,EAAK,UAAUyQ,CAAW,GAC9CzQ,IAAOA,EAAK,UAAU,GAAGyQ,CAAW,IAElCzQ,MACFuQ,EAAW,WAAWvQ;AAAA,EAE1B;AACA,SAAOuQ;AACT;AAoPA,SAASG,GAAYC,GAAQC,GAAaC,IAAW,KAAK;AACxD,SAAOC,GAAgBH,GAAQC,GAAaC,GAAU,EAAK;AAC7D;AACA,SAASC,GAAgBH,GAAQC,GAAaC,GAAUE,GAAc;AACpE,MAAIC,IAAW,OAAOJ,KAAgB,WAAWN,GAAUM,CAAW,IAAIA,GACtET,IAAWc,GAAcD,EAAS,YAAY,KAAKH,CAAQ;AAC/D,MAAIV,KAAY;AACd,WAAO;AAET,MAAIe,IAAWC,GAAcR,CAAM;AACnC,EAAAS,GAAkBF,CAAQ;AAC1B,MAAIG,IAAU;AACd,WAASlY,IAAI,GAAGkY,KAAW,QAAQlY,IAAI+X,EAAS,QAAQ,EAAE/X,GAAG;AAC3D,QAAImY,IAAUC,GAAWpB,CAAQ;AACjC,IAAAkB,IAAUG;AAAA,MACRN,EAAS/X,CAAC;AAAA,MACVmY;AAAA,MACAP;AAAA,IAAA;AAAA,EAEJ;AACA,SAAOM;AACT;AAYA,SAASF,GAAcR,GAAQO,IAAW,IAAIO,IAAc,CAAA,GAAIC,IAAa,IAAIC,IAA6B,IAAO;AACnH,MAAIC,IAAe,CAACC,GAAOhQ,GAAOiQ,IAA4BH,GAA4BI,MAAiB;AACzG,QAAIC,IAAO;AAAA,MACT,cAAcD,MAAiB,SAASF,EAAM,QAAQ,KAAKE;AAAA,MAC3D,eAAeF,EAAM,kBAAkB;AAAA,MACvC,eAAehQ;AAAA,MACf,OAAAgQ;AAAA,IAAA;AAEF,QAAIG,EAAK,aAAa,WAAW,GAAG,GAAG;AACrC,UAAI,CAACA,EAAK,aAAa,WAAWN,CAAU,KAAKI;AAC/C;AAEF,MAAAhC;AAAA,QACEkC,EAAK,aAAa,WAAWN,CAAU;AAAA,QACvC,wBAAwBM,EAAK,YAAY,wBAAwBN,CAAU;AAAA,MAAA,GAE7EM,EAAK,eAAeA,EAAK,aAAa,MAAMN,EAAW,MAAM;AAAA,IAC/D;AACA,QAAI1R,IAAOiS,GAAU,CAACP,GAAYM,EAAK,YAAY,CAAC,GAChDE,IAAaT,EAAY,OAAOO,CAAI;AAgBxC,IAfIH,EAAM,YAAYA,EAAM,SAAS,SAAS,MAC5C/B;AAAA;AAAA;AAAA,MAGE+B,EAAM,UAAU;AAAA,MAChB,4FAA4F7R,CAAI;AAAA,IAAA,GAElGmR;AAAA,MACEU,EAAM;AAAA,MACNX;AAAA,MACAgB;AAAA,MACAlS;AAAA,MACA8R;AAAA,IAAA,IAGA,EAAAD,EAAM,QAAQ,QAAQ,CAACA,EAAM,UAGjCX,EAAS,KAAK;AAAA,MACZ,MAAAlR;AAAA,MACA,OAAOmS,GAAanS,GAAM6R,EAAM,KAAK;AAAA,MACrC,YAAAK;AAAA,IAAA,CACD;AAAA,EACH;AACA,SAAAvB,EAAO,QAAQ,CAACkB,GAAOhQ,MAAU;AAC/B,QAAIgQ,EAAM,SAAS,MAAM,CAACA,EAAM,MAAM,SAAS,GAAG;AAChD,MAAAD,EAAaC,GAAOhQ,CAAK;AAAA;AAEzB,eAASuQ,KAAYC,GAAwBR,EAAM,IAAI;AACrD,QAAAD,EAAaC,GAAOhQ,GAAO,IAAMuQ,CAAQ;AAAA,EAG/C,CAAC,GACMlB;AACT;AACA,SAASmB,GAAwBrS,GAAM;AACrC,MAAIsS,IAAWtS,EAAK,MAAM,GAAG;AAC7B,MAAIsS,EAAS,WAAW,EAAG,QAAO,CAAA;AAClC,MAAI,CAACC,GAAO,GAAGpG,CAAI,IAAImG,GACnBE,IAAaD,EAAM,SAAS,GAAG,GAC/BE,IAAWF,EAAM,QAAQ,OAAO,EAAE;AACtC,MAAIpG,EAAK,WAAW;AAClB,WAAOqG,IAAa,CAACC,GAAU,EAAE,IAAI,CAACA,CAAQ;AAEhD,MAAIC,IAAeL,GAAwBlG,EAAK,KAAK,GAAG,CAAC,GACrDhR,IAAS,CAAA;AACb,SAAAA,EAAO;AAAA,IACL,GAAGuX,EAAa;AAAA,MACd,CAACC,MAAYA,MAAY,KAAKF,IAAW,CAACA,GAAUE,CAAO,EAAE,KAAK,GAAG;AAAA,IAAA;AAAA,EACvE,GAEEH,KACFrX,EAAO,KAAK,GAAGuX,CAAY,GAEtBvX,EAAO;AAAA,IACZ,CAACiX,MAAapS,EAAK,WAAW,GAAG,KAAKoS,MAAa,KAAK,MAAMA;AAAA,EAAA;AAElE;AACA,SAAShB,GAAkBF,GAAU;AACnC,EAAAA,EAAS;AAAA,IACP,CAAC0B,GAAGC,MAAMD,EAAE,UAAUC,EAAE,QAAQA,EAAE,QAAQD,EAAE,QAAQE;AAAA,MAClDF,EAAE,WAAW,IAAI,CAACZ,MAASA,EAAK,aAAa;AAAA,MAC7Ca,EAAE,WAAW,IAAI,CAACb,MAASA,EAAK,aAAa;AAAA,IAAA;AAAA,EAC/C;AAEJ;AACA,IAAIe,KAAU,aACVC,KAAsB,GACtBC,KAAkB,GAClBC,KAAoB,GACpBC,KAAqB,IACrBC,KAAe,IACfC,KAAU,CAACC,MAAMA,MAAM;AAC3B,SAASnB,GAAanS,GAAM6B,GAAO;AACjC,MAAIyQ,IAAWtS,EAAK,MAAM,GAAG,GACzBuT,IAAejB,EAAS;AAC5B,SAAIA,EAAS,KAAKe,EAAO,MACvBE,KAAgBH,KAEdvR,MACF0R,KAAgBN,KAEXX,EAAS,OAAO,CAACgB,MAAM,CAACD,GAAQC,CAAC,CAAC,EAAE;AAAA,IACzC,CAACE,GAAOC,MAAYD,KAAST,GAAQ,KAAKU,CAAO,IAAIT,KAAsBS,MAAY,KAAKP,KAAoBC;AAAA,IAChHI;AAAA,EAAA;AAEJ;AACA,SAAST,GAAeF,GAAGC,GAAG;AAE5B,SADeD,EAAE,WAAWC,EAAE,UAAUD,EAAE,MAAM,GAAG,EAAE,EAAE,MAAM,CAACpX,GAAGrC,MAAMqC,MAAMqX,EAAE1Z,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,IAM/EyZ,EAAEA,EAAE,SAAS,CAAC,IAAIC,EAAEA,EAAE,SAAS,CAAC;AAAA;AAAA;AAAA;AAAA,IAIhC;AAAA;AAEJ;AACA,SAASrB,GAAiBkC,GAAQvD,GAAUY,IAAe,IAAO;AAChE,MAAI,EAAE,YAAAmB,MAAewB,GACjBC,IAAgB,CAAA,GAChBC,IAAkB,KAClBvC,IAAU,CAAA;AACd,WAASlY,IAAI,GAAGA,IAAI+Y,EAAW,QAAQ,EAAE/Y,GAAG;AAC1C,QAAI6Y,IAAOE,EAAW/Y,CAAC,GACnB0a,IAAM1a,MAAM+Y,EAAW,SAAS,GAChC4B,IAAoBF,MAAoB,MAAMzD,IAAWA,EAAS,MAAMyD,EAAgB,MAAM,KAAK,KACnGG,IAAQC;AAAA,MACV,EAAE,MAAMhC,EAAK,cAAc,eAAeA,EAAK,eAAe,KAAA6B,EAAA;AAAA,MAC9DC;AAAA,IAAA,GAEEjC,IAAQG,EAAK;AAWjB,QAVI,CAAC+B,KAASF,KAAO9C,KAAgB,CAACmB,EAAWA,EAAW,SAAS,CAAC,EAAE,MAAM,UAC5E6B,IAAQC;AAAA,MACN;AAAA,QACE,MAAMhC,EAAK;AAAA,QACX,eAAeA,EAAK;AAAA,QACpB,KAAK;AAAA,MAAA;AAAA,MAEP8B;AAAA,IAAA,IAGA,CAACC;AACH,aAAO;AAET,WAAO,OAAOJ,GAAeI,EAAM,MAAM,GACzC1C,EAAQ,KAAK;AAAA;AAAA,MAEX,QAAQsC;AAAA,MACR,UAAU1B,GAAU,CAAC2B,GAAiBG,EAAM,QAAQ,CAAC;AAAA,MACrD,cAAcE;AAAA,QACZhC,GAAU,CAAC2B,GAAiBG,EAAM,YAAY,CAAC;AAAA,MAAA;AAAA,MAEjD,OAAAlC;AAAA,IAAA,CACD,GACGkC,EAAM,iBAAiB,QACzBH,IAAkB3B,GAAU,CAAC2B,GAAiBG,EAAM,YAAY,CAAC;AAAA,EAErE;AACA,SAAO1C;AACT;AA4BA,SAAS2C,GAAUE,GAAS/D,GAAU;AACpC,EAAI,OAAO+D,KAAY,aACrBA,IAAU,EAAE,MAAMA,GAAS,eAAe,IAAO,KAAK,GAAA;AAExD,MAAI,CAACC,GAASC,CAAc,IAAIC;AAAA,IAC9BH,EAAQ;AAAA,IACRA,EAAQ;AAAA,IACRA,EAAQ;AAAA,EAAA,GAENH,IAAQ5D,EAAS,MAAMgE,CAAO;AAClC,MAAI,CAACJ,EAAO,QAAO;AACnB,MAAIH,IAAkBG,EAAM,CAAC,GACzBO,IAAeV,EAAgB,QAAQ,WAAW,IAAI,GACtDW,IAAgBR,EAAM,MAAM,CAAC;AAiBjC,SAAO;AAAA,IACL,QAjBWK,EAAe;AAAA,MAC1B,CAACI,GAAO,EAAE,WAAAC,GAAW,YAAAjC,EAAA,GAAc3Q,MAAU;AAC3C,YAAI4S,MAAc,KAAK;AACrB,cAAIC,IAAaH,EAAc1S,CAAK,KAAK;AACzC,UAAAyS,IAAeV,EAAgB,MAAM,GAAGA,EAAgB,SAASc,EAAW,MAAM,EAAE,QAAQ,WAAW,IAAI;AAAA,QAC7G;AACA,cAAM5c,IAAQyc,EAAc1S,CAAK;AACjC,eAAI2Q,KAAc,CAAC1a,IACjB0c,EAAMC,CAAS,IAAI,SAEnBD,EAAMC,CAAS,KAAK3c,KAAS,IAAI,QAAQ,QAAQ,GAAG,GAE/C0c;AAAA,MACT;AAAA,MACA,CAAA;AAAA,IAAC;AAAA,IAID,UAAUZ;AAAA,IACV,cAAAU;AAAA,IACA,SAAAJ;AAAA,EAAA;AAEJ;AACA,SAASG,GAAYrU,GAAM2U,IAAgB,IAAOd,IAAM,IAAM;AAC5D,EAAA7D;AAAA,IACEhQ,MAAS,OAAO,CAACA,EAAK,SAAS,GAAG,KAAKA,EAAK,SAAS,IAAI;AAAA,IACzD,eAAeA,CAAI,oCAAoCA,EAAK,QAAQ,OAAO,IAAI,CAAC,yIAAyIA,EAAK,QAAQ,OAAO,IAAI,CAAC;AAAA,EAAA;AAEpP,MAAI4U,IAAS,CAAA,GACTC,IAAe,MAAM7U,EAAK,QAAQ,WAAW,EAAE,EAAE,QAAQ,QAAQ,GAAG,EAAE,QAAQ,sBAAsB,MAAM,EAAE;AAAA,IAC9G;AAAA,IACA,CAAC+T,GAAOU,GAAWjC,GAAY3Q,GAAOiT,MAAQ;AAE5C,UADAF,EAAO,KAAK,EAAE,WAAAH,GAAW,YAAYjC,KAAc,MAAM,GACrDA,GAAY;AACd,YAAIuC,IAAWD,EAAI,OAAOjT,IAAQkS,EAAM,MAAM;AAC9C,eAAIgB,KAAYA,MAAa,MACpB,eAEF;AAAA,MACT;AACA,aAAO;AAAA,IACT;AAAA,EAAA,EACA,QAAQ,uBAAuB,UAAU;AAC3C,SAAI/U,EAAK,SAAS,GAAG,KACnB4U,EAAO,KAAK,EAAE,WAAW,IAAA,CAAK,GAC9BC,KAAgB7U,MAAS,OAAOA,MAAS,OAAO,UAAU,uBACjD6T,IACTgB,KAAgB,UACP7U,MAAS,MAAMA,MAAS,QACjC6U,KAAgB,kBAIX,CADO,IAAI,OAAOA,GAAcF,IAAgB,SAAS,GAAG,GAClDC,CAAM;AACzB;AACA,SAASrD,GAAWzZ,GAAO;AACzB,MAAI;AACF,WAAOA,EAAM,MAAM,GAAG,EAAE,IAAI,CAACkd,MAAM,mBAAmBA,CAAC,EAAE,QAAQ,OAAO,KAAK,CAAC,EAAE,KAAK,GAAG;AAAA,EAC1F,SAASC,GAAO;AACd,WAAAjF;AAAA,MACE;AAAA,MACA,iBAAiBlY,CAAK,iHAAiHmd,CAAK;AAAA,IAAA,GAEvInd;AAAA,EACT;AACF;AACA,SAASmZ,GAAcd,GAAUU,GAAU;AACzC,MAAIA,MAAa,IAAK,QAAOV;AAC7B,MAAI,CAACA,EAAS,YAAA,EAAc,WAAWU,EAAS,YAAA,CAAa;AAC3D,WAAO;AAET,MAAI3S,IAAa2S,EAAS,SAAS,GAAG,IAAIA,EAAS,SAAS,IAAIA,EAAS,QACrEkE,IAAW5E,EAAS,OAAOjS,CAAU;AACzC,SAAI6W,KAAYA,MAAa,MACpB,OAEF5E,EAAS,MAAMjS,CAAU,KAAK;AACvC;AAOA,IAAIgX,KAAqB;AAEzB,SAASC,GAAYC,GAAIC,IAAe,KAAK;AAC3C,MAAI;AAAA,IACF,UAAUC;AAAA,IACV,QAAAlF,IAAS;AAAA,IACT,MAAAC,IAAO;AAAA,EAAA,IACL,OAAO+E,KAAO,WAAW9E,GAAU8E,CAAE,IAAIA,GACzCjF;AACJ,SAAImF,KACFA,IAAaC,GAAoBD,CAAU,GACvCA,EAAW,WAAW,GAAG,IAC3BnF,IAAWqF,GAAgBF,EAAW,UAAU,CAAC,GAAG,GAAG,IAEvDnF,IAAWqF,GAAgBF,GAAYD,CAAY,KAGrDlF,IAAWkF,GAEN;AAAA,IACL,UAAAlF;AAAA,IACA,QAAQsF,GAAgBrF,CAAM;AAAA,IAC9B,MAAMsF,GAAcrF,CAAI;AAAA,EAAA;AAE5B;AACA,SAASmF,GAAgBzD,GAAcsD,GAAc;AACnD,MAAI/C,IAAWqD,GAAoBN,CAAY,EAAE,MAAM,GAAG;AAE1D,SADuBtD,EAAa,MAAM,GAAG,EAC5B,QAAQ,CAAC0B,MAAY;AACpC,IAAIA,MAAY,OACVnB,EAAS,SAAS,KAAGA,EAAS,IAAA,IACzBmB,MAAY,OACrBnB,EAAS,KAAKmB,CAAO;AAAA,EAEzB,CAAC,GACMnB,EAAS,SAAS,IAAIA,EAAS,KAAK,GAAG,IAAI;AACpD;AACA,SAASsD,GAAoBC,GAAMC,GAAOC,GAAM/V,GAAM;AACpD,SAAO,qBAAqB6V,CAAI,4CAA4CC,CAAK,aAAa,KAAK;AAAA,IACjG9V;AAAA,EAAA,CACD,0CAA0C+V,CAAI;AACjD;AACA,SAASC,GAA2B3E,GAAS;AAC3C,SAAOA,EAAQ;AAAA,IACb,CAAC0C,GAAOlS,MAAUA,MAAU,KAAKkS,EAAM,MAAM,QAAQA,EAAM,MAAM,KAAK,SAAS;AAAA,EAAA;AAEnF;AACA,SAASkC,GAAoB5E,GAAS;AACpC,MAAI6E,IAAcF,GAA2B3E,CAAO;AACpD,SAAO6E,EAAY;AAAA,IACjB,CAACnC,GAAOoC,MAAQA,MAAQD,EAAY,SAAS,IAAInC,EAAM,WAAWA,EAAM;AAAA,EAAA;AAE5E;AACA,SAASqC,GAAUC,GAAOC,GAAgBC,GAAkBC,IAAiB,IAAO;AAClF,MAAIpB;AACJ,EAAI,OAAOiB,KAAU,WACnBjB,IAAK9E,GAAU+F,CAAK,KAEpBjB,IAAK,EAAE,GAAGiB,EAAA,GACVvG;AAAA,IACE,CAACsF,EAAG,YAAY,CAACA,EAAG,SAAS,SAAS,GAAG;AAAA,IACzCQ,GAAoB,KAAK,YAAY,UAAUR,CAAE;AAAA,EAAA,GAEnDtF;AAAA,IACE,CAACsF,EAAG,YAAY,CAACA,EAAG,SAAS,SAAS,GAAG;AAAA,IACzCQ,GAAoB,KAAK,YAAY,QAAQR,CAAE;AAAA,EAAA,GAEjDtF;AAAA,IACE,CAACsF,EAAG,UAAU,CAACA,EAAG,OAAO,SAAS,GAAG;AAAA,IACrCQ,GAAoB,KAAK,UAAU,QAAQR,CAAE;AAAA,EAAA;AAGjD,MAAIqB,IAAcJ,MAAU,MAAMjB,EAAG,aAAa,IAC9CE,IAAamB,IAAc,MAAMrB,EAAG,UACpCsB;AACJ,MAAIpB,KAAc;AAChB,IAAAoB,IAAOH;AAAA,OACF;AACL,QAAII,IAAqBL,EAAe,SAAS;AACjD,QAAI,CAACE,KAAkBlB,EAAW,WAAW,IAAI,GAAG;AAClD,UAAIsB,IAAatB,EAAW,MAAM,GAAG;AACrC,aAAOsB,EAAW,CAAC,MAAM;AACvB,QAAAA,EAAW,MAAA,GACXD,KAAsB;AAExB,MAAAvB,EAAG,WAAWwB,EAAW,KAAK,GAAG;AAAA,IACnC;AACA,IAAAF,IAAOC,KAAsB,IAAIL,EAAeK,CAAkB,IAAI;AAAA,EACxE;AACA,MAAI3W,IAAOmV,GAAYC,GAAIsB,CAAI,GAC3BG,IAA2BvB,KAAcA,MAAe,OAAOA,EAAW,SAAS,GAAG,GACtFwB,KAA2BL,KAAenB,MAAe,QAAQiB,EAAiB,SAAS,GAAG;AAClG,SAAI,CAACvW,EAAK,SAAS,SAAS,GAAG,MAAM6W,KAA4BC,OAC/D9W,EAAK,YAAY,MAEZA;AACT;AACA,IAAIuV,KAAsB,CAACvV,MAASA,EAAK,QAAQ,UAAU,GAAG,GAC1DiS,KAAY,CAAC8E,MAAUxB,GAAoBwB,EAAM,KAAK,GAAG,CAAC,GAC1DpB,KAAsB,CAAC3V,MAASA,EAAK,QAAQ,QAAQ,EAAE,GACvDiU,KAAoB,CAAC9D,MAAawF,GAAoBxF,CAAQ,EAAE,QAAQ,QAAQ,GAAG,GACnFsF,KAAkB,CAACrF,MAAW,CAACA,KAAUA,MAAW,MAAM,KAAKA,EAAO,WAAW,GAAG,IAAIA,IAAS,MAAMA,GACvGsF,KAAgB,CAACrF,MAAS,CAACA,KAAQA,MAAS,MAAM,KAAKA,EAAK,WAAW,GAAG,IAAIA,IAAO,MAAMA,GAmC3F2G,KAAoB,MAAM;AAAA,EAC5B,YAAYC,GAAQC,GAAYC,GAAOC,IAAW,IAAO;AACvD,SAAK,SAASH,GACd,KAAK,aAAaC,KAAc,IAChC,KAAK,WAAWE,GACZD,aAAiB,SACnB,KAAK,OAAOA,EAAM,SAAA,GAClB,KAAK,QAAQA,KAEb,KAAK,OAAOA;AAAA,EAEhB;AACF;AACA,SAASE,GAAqBpC,GAAO;AACnC,SAAOA,KAAS,QAAQ,OAAOA,EAAM,UAAW,YAAY,OAAOA,EAAM,cAAe,YAAY,OAAOA,EAAM,YAAa,aAAa,UAAUA;AACvJ;AACA,SAASqC,GAAgBjG,GAAS;AAChC,MAAInR,IAAQmR,EAAQ,IAAI,CAACkG,MAAMA,EAAE,MAAM,IAAI,EAAE,OAAO,OAAO;AAC3D,SAAOtF,GAAU/R,CAAK,KAAK;AAC7B;AACA,IAAIsX,KAAY,OAAO,SAAW,OAAe,OAAO,OAAO,WAAa,OAAe,OAAO,OAAO,SAAS,gBAAkB;AACpI,SAASC,GAAYC,GAAK7G,GAAU;AAClC,MAAIuE,IAAKsC;AACT,MAAI,OAAOtC,KAAO,YAAY,CAACF,GAAmB,KAAKE,CAAE;AACvD,WAAO;AAAA,MACL,aAAa;AAAA,MACb,YAAY;AAAA,MACZ,IAAAA;AAAA,IAAA;AAGJ,MAAIuC,IAAcvC,GACdhU,IAAa;AACjB,MAAIoW;AACF,QAAI;AACF,UAAII,IAAa,IAAI,IAAI,OAAO,SAAS,IAAI,GACzCC,IAAYzC,EAAG,WAAW,IAAI,IAAI,IAAI,IAAIwC,EAAW,WAAWxC,CAAE,IAAI,IAAI,IAAIA,CAAE,GAChFpV,IAAOiR,GAAc4G,EAAU,UAAUhH,CAAQ;AACrD,MAAIgH,EAAU,WAAWD,EAAW,UAAU5X,KAAQ,OACpDoV,IAAKpV,IAAO6X,EAAU,SAASA,EAAU,OAEzCzW,IAAa;AAAA,IAEjB,QAAY;AACV,MAAA4O;AAAA,QACE;AAAA,QACA,aAAaoF,CAAE;AAAA,MAAA;AAAA,IAEnB;AAEF,SAAO;AAAA,IACL,aAAAuC;AAAA,IACA,YAAAvW;AAAA,IACA,IAAAgU;AAAA,EAAA;AAEJ;AAwQuB,OAAO,oBAAoB,OAAO,SAAS,EAAE,KAAA,EAAO,KAAK,IAAI;AAUpF,IAAI0C,KAA0B;AAAA,EAC5B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAC2B,IAAI;AAAA,EAC7BA;AACF;AACA,IAAIC,KAAyB;AAAA,EAC3B;AAAA,EACA,GAAGD;AACL;AAC0B,IAAI,IAAIC,EAAsB;AA+oIxD,IAAIC,KAAoB5jB,EAAM,cAAc,IAAI;AAChD4jB,GAAkB,cAAc;AAChC,IAAIC,KAAyB7jB,EAAM,cAAc,IAAI;AACrD6jB,GAAuB,cAAc;AACrC,IAAIC,KAAmB9jB,EAAM,cAAc,EAAK;AAChD,SAAS+jB,KAAwB;AAC/B,SAAO/jB,EAAM,WAAW8jB,EAAgB;AAC1C;AACA,IAAIE,KAAwBhkB,EAAM,cAAc;AAAA,EAC9C,iBAAiB;AACnB,CAAC;AACDgkB,GAAsB,cAAc;AACpC,IAAIC,KAAkBjkB,EAAM;AAAA,sBACN,IAAA;AACtB;AACAikB,GAAgB,cAAc;AAC9B,IAAIC,KAAelkB,EAAM,cAAc,IAAI;AAC3CkkB,GAAa,cAAc;AAE3B,IAAIC,KAAoBnkB,EAAM;AAAA,EAC5B;AACF;AACAmkB,GAAkB,cAAc;AAChC,IAAIC,KAAkBpkB,EAAM;AAAA,EAC1B;AACF;AACAokB,GAAgB,cAAc;AAC9B,IAAIC,KAAerkB,EAAM,cAAc;AAAA,EACrC,QAAQ;AAAA,EACR,SAAS,CAAA;AAAA,EACT,aAAa;AACf,CAAC;AACDqkB,GAAa,cAAc;AAC3B,IAAIC,KAAoBtkB,EAAM,cAAc,IAAI;AAChDskB,GAAkB,cAAc;AAOhC,IAAIC,KAAoB,sBACpBC,KAAwB,YACxBC,KAAoC;AACxC,SAASC,GAA0BC,GAAQ;AACzC,MAAIA,EAAO,WAAW,GAAGJ,EAAiB,IAAIC,EAAqB,IAAI;AACrE,QAAI;AACF,UAAII,IAAS,KAAK,MAAMD,EAAO,MAAM,EAAE,CAAC;AACxC,UAAI,OAAOC,KAAW,YAAYA,KAAU,OAAOA,EAAO,UAAW,YAAY,OAAOA,EAAO,cAAe,YAAY,OAAOA,EAAO,YAAa,YAAY,OAAOA,EAAO,kBAAmB,aAAa,OAAOA,EAAO,WAAY;AACvO,eAAOA;AAAA,IAEX,QAAQ;AAAA,IACR;AAEJ;AACA,SAASC,GAA+BF,GAAQ;AAC9C,MAAIA,EAAO;AAAA,IACT,GAAGJ,EAAiB,IAAIE,EAAiC;AAAA,EAAA;AAEzD,QAAI;AACF,UAAIG,IAAS,KAAK,MAAMD,EAAO,MAAM,EAAE,CAAC;AACxC,UAAI,OAAOC,KAAW,YAAYA,KAAU,OAAOA,EAAO,UAAW,YAAY,OAAOA,EAAO,cAAe;AAC5G,eAAO,IAAIhC;AAAA,UACTgC,EAAO;AAAA,UACPA,EAAO;AAAA,UACPA,EAAO;AAAA,QAAA;AAAA,IAGb,QAAQ;AAAA,IACR;AAEJ;AAGA,SAASE,GAAQ9D,GAAI,EAAE,UAAA+D,EAAA,IAAa,CAAA,GAAI;AACtC,EAAArJ;AAAA,IACEsJ,GAAA;AAAA;AAAA;AAAA,IAGA;AAAA,EAAA;AAEF,MAAI,EAAE,UAAAvI,GAAU,WAAAwI,EAAA,IAAcC,EAAO,WAAWf,EAAiB,GAC7D,EAAE,MAAAlI,GAAM,UAAAF,GAAU,QAAAC,EAAA,IAAWmJ,GAAgBnE,GAAI,EAAE,UAAA+D,GAAU,GAC7DK,IAAiBrJ;AACrB,SAAIU,MAAa,QACf2I,IAAiBrJ,MAAa,MAAMU,IAAWoB,GAAU,CAACpB,GAAUV,CAAQ,CAAC,IAExEkJ,EAAU,WAAW,EAAE,UAAUG,GAAgB,QAAApJ,GAAQ,MAAAC,GAAM;AACxE;AACA,SAAS+I,KAAqB;AAC5B,SAAOE,EAAO,WAAWd,EAAe,KAAK;AAC/C;AACA,SAASiB,KAAc;AACrB,SAAA3J;AAAA,IACEsJ,GAAA;AAAA;AAAA;AAAA,IAGA;AAAA,EAAA,GAEKE,EAAO,WAAWd,EAAe,EAAE;AAC5C;AAiBA,IAAIkB,KAAwB;AAC5B,SAASC,GAA0BC,GAAI;AAErC,EADeN,EAAO,WAAWf,EAAiB,EAAE,UAElDe,EAAO,gBAAgBM,CAAE;AAE7B;AACA,SAASC,KAAc;AACrB,MAAI,EAAE,aAAAC,EAAA,IAAgBR,EAAO,WAAWb,EAAY;AACpD,SAAOqB,IAAcC,GAAA,IAAsBC,GAAA;AAC7C;AACA,SAASA,KAAsB;AAC7B,EAAAlK;AAAA,IACEsJ,GAAA;AAAA;AAAA;AAAA,IAGA;AAAA,EAAA;AAEF,MAAIa,IAAoBX,EAAO,WAAWtB,EAAiB,GACvD,EAAE,UAAAnH,GAAU,WAAAwI,EAAA,IAAcC,EAAO,WAAWf,EAAiB,GAC7D,EAAE,SAAAlH,EAAA,IAAYiI,EAAO,WAAWb,EAAY,GAC5C,EAAE,UAAUlC,EAAA,IAAqBkD,GAAA,GACjCS,IAAqB,KAAK,UAAUjE,GAAoB5E,CAAO,CAAC,GAChE8I,IAAYb,EAAO,OAAO,EAAK;AACnCK,SAAAA,GAA0B,MAAM;AAC9B,IAAAQ,EAAU,UAAU;AAAA,EACtB,CAAC,GACcb,EAAO;AAAA,IACpB,CAAClE,GAAIgF,IAAU,OAAO;AAEpB,UADApK,GAAQmK,EAAU,SAAST,EAAqB,GAC5C,CAACS,EAAU,QAAS;AACxB,UAAI,OAAO/E,KAAO,UAAU;AAC1B,QAAAiE,EAAU,GAAGjE,CAAE;AACf;AAAA,MACF;AACA,UAAIpV,IAAOoW;AAAA,QACThB;AAAA,QACA,KAAK,MAAM8E,CAAkB;AAAA,QAC7B3D;AAAA,QACA6D,EAAQ,aAAa;AAAA,MAAA;AAEvB,MAAIH,KAAqB,QAAQpJ,MAAa,QAC5C7Q,EAAK,WAAWA,EAAK,aAAa,MAAM6Q,IAAWoB,GAAU,CAACpB,GAAU7Q,EAAK,QAAQ,CAAC,KAErFoa,EAAQ,UAAUf,EAAU,UAAUA,EAAU;AAAA,QACjDrZ;AAAA,QACAoa,EAAQ;AAAA,QACRA;AAAA,MAAA;AAAA,IAEJ;AAAA,IACA;AAAA,MACEvJ;AAAA,MACAwI;AAAA,MACAa;AAAA,MACA3D;AAAA,MACA0D;AAAA,IAAA;AAAA,EACF;AAGJ;AACoBX,EAAO,cAAc,IAAI;AAgB7C,SAASC,GAAgBnE,GAAI,EAAE,UAAA+D,EAAA,IAAa,CAAA,GAAI;AAC9C,MAAI,EAAE,SAAA9H,EAAA,IAAYiI,EAAO,WAAWb,EAAY,GAC5C,EAAE,UAAUlC,EAAA,IAAqBkD,GAAA,GACjCS,IAAqB,KAAK,UAAUjE,GAAoB5E,CAAO,CAAC;AACpE,SAAOiI,EAAO;AAAA,IACZ,MAAMlD;AAAA,MACJhB;AAAA,MACA,KAAK,MAAM8E,CAAkB;AAAA,MAC7B3D;AAAA,MACA4C,MAAa;AAAA,IAAA;AAAA,IAEf,CAAC/D,GAAI8E,GAAoB3D,GAAkB4C,CAAQ;AAAA,EAAA;AAEvD;AAIA,SAASkB,GAAc1J,GAAQC,GAAa0J,GAAgB;AAC1D,EAAAxK;AAAA,IACEsJ,GAAA;AAAA;AAAA;AAAA,IAGA;AAAA,EAAA;AAEF,MAAI,EAAE,WAAAC,EAAA,IAAcC,EAAO,WAAWf,EAAiB,GACnD,EAAE,SAASgC,EAAA,IAAkBjB,EAAO,WAAWb,EAAY,GAC3D+B,IAAaD,EAAcA,EAAc,SAAS,CAAC,GACnDE,IAAeD,IAAaA,EAAW,SAAS,CAAA,GAChDE,IAAiBF,IAAaA,EAAW,WAAW,KACpDG,IAAqBH,IAAaA,EAAW,eAAe,KAC5DI,IAAcJ,KAAcA,EAAW;AAClB;AACvB,QAAI9I,IAAakJ,KAAeA,EAAY,QAAQ;AACpD,IAAAC;AAAA,MACEH;AAAA,MACA,CAACE,KAAelJ,EAAW,SAAS,GAAG,KAAKA,EAAW,SAAS,IAAI;AAAA,MACpE,oEAAoEgJ,CAAc,yBAAyBhJ,CAAU;AAAA;AAAA,wCAEnFA,CAAU,sBAAsBA,MAAe,MAAM,MAAM,GAAGA,CAAU,IAAI;AAAA,IAAA;AAAA,EAElH;AACA,MAAIoJ,IAAsBrB,GAAA,GACtBzI;AASF,EAAAA,IAAW8J;AAEb,MAAI3K,IAAWa,EAAS,YAAY,KAChC8C,IAAoB3D;AACxB,MAAIwK,MAAuB,KAAK;AAC9B,QAAII,IAAiBJ,EAAmB,QAAQ,OAAO,EAAE,EAAE,MAAM,GAAG;AAEpE,IAAA7G,IAAoB,MADL3D,EAAS,QAAQ,OAAO,EAAE,EAAE,MAAM,GAAG,EACjB,MAAM4K,EAAe,MAAM,EAAE,KAAK,GAAG;AAAA,EAC1E;AACA,MAAI1J,IAAUX,GAAYC,GAAQ,EAAE,UAAUmD,GAAmB;AAE/D,SAAA9D;AAAA,IACE4K,KAAevJ,KAAW;AAAA,IAC1B,+BAA+BL,EAAS,QAAQ,GAAGA,EAAS,MAAM,GAAGA,EAAS,IAAI;AAAA,EAAA,GAEpFhB;AAAA,IACEqB,KAAW,QAAQA,EAAQA,EAAQ,SAAS,CAAC,EAAE,MAAM,YAAY,UAAUA,EAAQA,EAAQ,SAAS,CAAC,EAAE,MAAM,cAAc,UAAUA,EAAQA,EAAQ,SAAS,CAAC,EAAE,MAAM,SAAS;AAAA,IAChL,mCAAmCL,EAAS,QAAQ,GAAGA,EAAS,MAAM,GAAGA,EAAS,IAAI;AAAA,EAAA,GAGpEgK;AAAA,IACpB3J,KAAWA,EAAQ;AAAA,MACjB,CAAC0C,MAAU,OAAO,OAAO,CAAA,GAAIA,GAAO;AAAA,QAClC,QAAQ,OAAO,OAAO,CAAA,GAAI0G,GAAc1G,EAAM,MAAM;AAAA,QACpD,UAAU9B,GAAU;AAAA,UAClB0I;AAAA;AAAA;AAAA;AAAA;AAAA,UAKAtB,EAAU,iBAAiBA,EAAU;AAAA,YACnCtF,EAAM,SAAS,QAAQ,MAAM,KAAK,EAAE,QAAQ,OAAO,KAAK,EAAE,QAAQ,MAAM,KAAK;AAAA,UAAA,EAC7E,WAAWA,EAAM;AAAA,QAAA,CACpB;AAAA,QACD,cAAcA,EAAM,iBAAiB,MAAM4G,IAAqB1I,GAAU;AAAA,UACxE0I;AAAA;AAAA;AAAA;AAAA;AAAA,UAKAtB,EAAU,iBAAiBA,EAAU;AAAA,YACnCtF,EAAM,aAAa,QAAQ,MAAM,KAAK,EAAE,QAAQ,OAAO,KAAK,EAAE,QAAQ,MAAM,KAAK;AAAA,UAAA,EACjF,WAAWA,EAAM;AAAA,QAAA,CACpB;AAAA,MAAA,CACF;AAAA,IAAA;AAAA,IAEHwG;AAAA,IACAD;AAAA,EAAA;AAuBJ;AACA,SAASW,KAAwB;AAC/B,MAAIhG,IAAQiG,GAAA,GACRnL,IAAUsH,GAAqBpC,CAAK,IAAI,GAAGA,EAAM,MAAM,IAAIA,EAAM,UAAU,KAAKA,aAAiB,QAAQA,EAAM,UAAU,KAAK,UAAUA,CAAK,GAC7IkG,IAAQlG,aAAiB,QAAQA,EAAM,QAAQ,MAC/CmG,IAAY,0BACZC,IAAY,EAAE,SAAS,UAAU,iBAAiBD,EAAA,GAClDE,IAAa,EAAE,SAAS,WAAW,iBAAiBF,EAAA,GACpDG,IAAU;AAEZ,iBAAQ;AAAA,IACN;AAAA,IACAtG;AAAA,EAAA,GAEFsG,sBAAiC,cAAcjC,EAAO,UAAU,wBAA6B,cAAc,KAAK,MAAM,qBAAmC,GAAmBA,gBAAAA,EAAO,cAAc,KAAK,MAAM,gGAAgHA,gBAAAA,EAAO,cAAc,QAAQ,EAAE,OAAOgC,EAAA,GAAc,eAAe,GAAG,OAAO,KAAqBhC,gBAAAA,EAAO,cAAc,QAAQ,EAAE,OAAOgC,EAAA,GAAc,cAAc,GAAG,sBAAsB,CAAC,GAErehC,gBAAAA,EAAO,cAAcA,EAAO,UAAU,MAAsBA,gBAAAA,EAAO,cAAc,MAAM,MAAM,+BAA+B,GAAmBA,gBAAAA,EAAO,cAAc,MAAM,EAAE,OAAO,EAAE,WAAW,SAAA,EAAS,GAAKvJ,CAAO,GAAGoL,IAAwB7B,gBAAAA,EAAO,cAAc,OAAO,EAAE,OAAO+B,EAAA,GAAaF,CAAK,IAAI,MAAMI,CAAO;AACjV;AACA,IAAIC,KAAsClC,gBAAAA,EAAO,cAAc2B,IAAuB,IAAI,GACtFQ,KAAsB,cAAcnC,EAAO,UAAU;AAAA,EACvD,YAAYnlB,GAAO;AACjB,UAAMA,CAAK,GACX,KAAK,QAAQ;AAAA,MACX,UAAUA,EAAM;AAAA,MAChB,cAAcA,EAAM;AAAA,MACpB,OAAOA,EAAM;AAAA,IAAA;AAAA,EAEjB;AAAA,EACA,OAAO,yBAAyB8gB,GAAO;AACrC,WAAO,EAAE,OAAAA,EAAA;AAAA,EACX;AAAA,EACA,OAAO,yBAAyB9gB,GAAOunB,GAAO;AAC5C,WAAIA,EAAM,aAAavnB,EAAM,YAAYunB,EAAM,iBAAiB,UAAUvnB,EAAM,iBAAiB,SACxF;AAAA,MACL,OAAOA,EAAM;AAAA,MACb,UAAUA,EAAM;AAAA,MAChB,cAAcA,EAAM;AAAA,IAAA,IAGjB;AAAA,MACL,OAAOA,EAAM,UAAU,SAASA,EAAM,QAAQunB,EAAM;AAAA,MACpD,UAAUA,EAAM;AAAA,MAChB,cAAcvnB,EAAM,gBAAgBunB,EAAM;AAAA,IAAA;AAAA,EAE9C;AAAA,EACA,kBAAkBzG,GAAO0G,GAAW;AAClC,IAAI,KAAK,MAAM,UACb,KAAK,MAAM,QAAQ1G,GAAO0G,CAAS,IAEnC,QAAQ;AAAA,MACN;AAAA,MACA1G;AAAA,IAAA;AAAA,EAGN;AAAA,EACA,SAAS;AACP,QAAIA,IAAQ,KAAK,MAAM;AACvB,QAAI,KAAK,WAAW,OAAOA,KAAU,YAAYA,KAAS,YAAYA,KAAS,OAAOA,EAAM,UAAW,UAAU;AAC/G,YAAM3D,IAAU2H,GAA+BhE,EAAM,MAAM;AAC3D,MAAI3D,MAAS2D,IAAQ3D;AAAA,IACvB;AACA,QAAInW,IAAS8Z,MAAU,SAAyBqE,gBAAAA,EAAO,cAAcb,GAAa,UAAU,EAAE,OAAO,KAAK,MAAM,aAAA,GAAgCa,gBAAAA,EAAO;AAAA,MACrJZ,GAAkB;AAAA,MAClB;AAAA,QACE,OAAOzD;AAAA,QACP,UAAU,KAAK,MAAM;AAAA,MAAA;AAAA,IACvB,CACD,IAAI,KAAK,MAAM;AAChB,WAAI,KAAK,4BACuB,cAAc2G,IAAiB,EAAE,OAAA3G,EAAA,GAAS9Z,CAAM,IAEzEA;AAAA,EACT;AACF;AACAsgB,GAAoB,cAAcvD;AAClC,IAAI2D,yBAA8C,QAAA;AAClD,SAASD,GAAgB;AAAA,EACvB,UAAAvjB;AAAA,EACA,OAAA4c;AACF,GAAG;AACD,MAAI,EAAE,UAAApE,EAAA,IAAayI,EAAO,WAAWf,EAAiB;AACtD,MAAI,OAAOtD,KAAU,YAAYA,KAAS,YAAYA,KAAS,OAAOA,EAAM,UAAW,UAAU;AAC/F,QAAI6G,IAAYhD,GAA0B7D,EAAM,MAAM;AACtD,QAAI6G,GAAW;AACb,UAAIC,IAAmBF,GAAwB,IAAI5G,CAAK;AACxD,UAAI8G,EAAkB,OAAMA;AAC5B,UAAI/C,IAASvB,GAAYqE,EAAU,UAAUjL,CAAQ;AACrD,UAAI2G,MAAa,CAACqE,GAAwB,IAAI5G,CAAK;AACjD,YAAI+D,EAAO,cAAc8C,EAAU;AACjC,iBAAO,SAAS,OAAO9C,EAAO,eAAeA,EAAO;AAAA,aAC/C;AACL,gBAAMgD,IAAkB,QAAQ,QAAA,EAAU;AAAA,YACxC,MAAM,OAAO,wBAAwB,SAAShD,EAAO,IAAI;AAAA,cACvD,SAAS8C,EAAU;AAAA,YAAA,CACpB;AAAA,UAAA;AAEH,gBAAAD,GAAwB,IAAI5G,GAAO+G,CAAe,GAC5CA;AAAA,QACR;AAEF,aAAuB1C,gBAAAA,EAAO;AAAA,QAC5B;AAAA,QACA;AAAA,UACE,WAAW;AAAA,UACX,SAAS,SAASN,EAAO,eAAeA,EAAO,EAAE;AAAA,QAAA;AAAA,MACnD;AAAA,IAEJ;AAAA,EACF;AACA,SAAO3gB;AACT;AACA,SAAS4jB,GAAc,EAAE,cAAAC,GAAc,OAAAnI,GAAO,UAAA1b,KAAY;AACxD,MAAI4hB,IAAoBX,EAAO,WAAWtB,EAAiB;AAC3D,SAAIiC,KAAqBA,EAAkB,UAAUA,EAAkB,kBAAkBlG,EAAM,MAAM,gBAAgBA,EAAM,MAAM,mBAC/HkG,EAAkB,cAAc,6BAA6BlG,EAAM,MAAM,KAEpDuF,gBAAAA,EAAO,cAAcb,GAAa,UAAU,EAAE,OAAOyD,EAAA,GAAgB7jB,CAAQ;AACtG;AACA,SAAS2iB,GAAe3J,GAASkJ,IAAgB,CAAA,GAAID,GAAgB;AACnE,MAAI6B,IAAkB7B,GAAgB;AACtC,MAAIjJ,KAAW,MAAM;AACnB,QAAI,CAAC8K;AACH,aAAO;AAET,QAAIA,EAAgB;AAClB,MAAA9K,IAAU8K,EAAgB;AAAA,aACjB5B,EAAc,WAAW,KAAK,CAAC4B,EAAgB,eAAeA,EAAgB,QAAQ,SAAS;AACxG,MAAA9K,IAAU8K,EAAgB;AAAA;AAE1B,aAAO;AAAA,EAEX;AACA,MAAIC,IAAkB/K,GAClBgL,IAASF,GAAiB;AAC9B,MAAIE,KAAU,MAAM;AAClB,QAAIC,IAAaF,EAAgB;AAAA,MAC/B,CAAC7E,MAAMA,EAAE,MAAM,MAAM8E,IAAS9E,EAAE,MAAM,EAAE,MAAM;AAAA,IAAA;AAEhD,IAAAzH;AAAA,MACEwM,KAAc;AAAA,MACd,4DAA4D,OAAO;AAAA,QACjED;AAAA,MAAA,EACA,KAAK,GAAG,CAAC;AAAA,IAAA,GAEbD,IAAkBA,EAAgB;AAAA,MAChC;AAAA,MACA,KAAK,IAAIA,EAAgB,QAAQE,IAAa,CAAC;AAAA,IAAA;AAAA,EAEnD;AACA,MAAIC,IAAiB,IACjBC,IAAgB;AACpB,MAAIlC,KAAkB6B,GAAiB;AACrC,IAAAI,IAAiBJ,EAAgB;AACjC,aAAShjB,IAAI,GAAGA,IAAIijB,EAAgB,QAAQjjB,KAAK;AAC/C,UAAI4a,IAAQqI,EAAgBjjB,CAAC;AAI7B,WAHI4a,EAAM,MAAM,mBAAmBA,EAAM,MAAM,4BAC7CyI,IAAgBrjB,IAEd4a,EAAM,MAAM,IAAI;AAClB,YAAI,EAAE,YAAA0I,GAAY,QAAQC,EAAA,IAAYP,GAClCQ,IAAmB5I,EAAM,MAAM,UAAU,CAAC0I,EAAW,eAAe1I,EAAM,MAAM,EAAE,MAAM,CAAC2I,KAAWA,EAAQ3I,EAAM,MAAM,EAAE,MAAM;AACpI,YAAIA,EAAM,MAAM,QAAQ4I,GAAkB;AACxC,UAAIrC,EAAe,aACjBiC,IAAiB,KAEfC,KAAiB,IACnBJ,IAAkBA,EAAgB,MAAM,GAAGI,IAAgB,CAAC,IAE5DJ,IAAkB,CAACA,EAAgB,CAAC,CAAC;AAEvC;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AACA,MAAIQ,IAAiBtC,GAAgB,SACjCuC,IAAUV,KAAmBS,IAAiB,CAAC3H,GAAO0G,MAAc;AACtE,IAAAiB,EAAe3H,GAAO;AAAA,MACpB,UAAUkH,EAAgB;AAAA,MAC1B,QAAQA,EAAgB,UAAU,CAAC,GAAG,UAAU,CAAA;AAAA,MAChD,kBAAkB7E,GAAgB6E,EAAgB,OAAO;AAAA,MACzD,WAAAR;AAAA,IAAA,CACD;AAAA,EACH,IAAI;AACJ,SAAOS,EAAgB;AAAA,IACrB,CAACU,GAAQ/I,GAAOlS,MAAU;AACxB,UAAIoT,GACA8H,IAA8B,IAC9BC,IAAe,MACfC,IAAyB;AAC7B,MAAId,MACFlH,IAAQoH,KAAUtI,EAAM,MAAM,KAAKsI,EAAOtI,EAAM,MAAM,EAAE,IAAI,QAC5DiJ,IAAejJ,EAAM,MAAM,gBAAgByH,IACvCe,MACEC,IAAgB,KAAK3a,MAAU,KACjCgZ;AAAA,QACE;AAAA,QACA;AAAA,QACA;AAAA,MAAA,GAEFkC,IAA8B,IAC9BE,IAAyB,QAChBT,MAAkB3a,MAC3Bkb,IAA8B,IAC9BE,IAAyBlJ,EAAM,MAAM,0BAA0B;AAIrE,UAAImJ,IAAW3C,EAAc,OAAO6B,EAAgB,MAAM,GAAGva,IAAQ,CAAC,CAAC,GACnEsb,IAAc,MAAM;AACtB,YAAI9kB;AACJ,eAAI4c,IACF5c,IAAW2kB,IACFD,IACT1kB,IAAW4kB,IACFlJ,EAAM,MAAM,YACrB1b,IAA2BihB,gBAAAA,EAAO,cAAcvF,EAAM,MAAM,WAAW,IAAI,IAClEA,EAAM,MAAM,UACrB1b,IAAW0b,EAAM,MAAM,UAEvB1b,IAAWykB,GAEUxD,gBAAAA,EAAO;AAAA,UAC5B2C;AAAA,UACA;AAAA,YACE,OAAAlI;AAAA,YACA,cAAc;AAAA,cACZ,QAAA+I;AAAA,cACA,SAASI;AAAA,cACT,aAAaf,KAAmB;AAAA,YAAA;AAAA,YAElC,UAAA9jB;AAAA,UAAA;AAAA,QACF;AAAA,MAEJ;AACA,aAAO8jB,MAAoBpI,EAAM,MAAM,iBAAiBA,EAAM,MAAM,gBAAgBlS,MAAU,KAAqByX,gBAAAA,EAAO;AAAA,QACxHmC;AAAA,QACA;AAAA,UACE,UAAUU,EAAgB;AAAA,UAC1B,cAAcA,EAAgB;AAAA,UAC9B,WAAWa;AAAA,UACX,OAAA/H;AAAA,UACA,UAAUkI,EAAA;AAAA,UACV,cAAc,EAAE,QAAQ,MAAM,SAASD,GAAU,aAAa,GAAA;AAAA,UAC9D,SAAAL;AAAA,QAAA;AAAA,MACF,IACEM,EAAA;AAAA,IACN;AAAA,IACA;AAAA,EAAA;AAEJ;AACA,SAASC,GAA0BC,GAAU;AAC3C,SAAO,GAAGA,CAAQ;AACpB;AACA,SAASC,GAAqBD,GAAU;AACtC,MAAIE,IAAMjE,EAAO,WAAWtB,EAAiB;AAC7C,SAAAlI,GAAUyN,GAAKH,GAA0BC,CAAQ,CAAC,GAC3CE;AACT;AACA,SAASC,GAAmBH,GAAU;AACpC,MAAI3B,IAAQpC,EAAO,WAAWrB,EAAsB;AACpD,SAAAnI,GAAU4L,GAAO0B,GAA0BC,CAAQ,CAAC,GAC7C3B;AACT;AACA,SAAS+B,GAAgBJ,GAAU;AACjC,MAAIxL,IAAQyH,EAAO,WAAWb,EAAY;AAC1C,SAAA3I,GAAU+B,GAAOuL,GAA0BC,CAAQ,CAAC,GAC7CxL;AACT;AACA,SAAS6L,GAAkBL,GAAU;AACnC,MAAIxL,IAAQ4L,GAAgBJ,CAAQ,GAChCM,IAAY9L,EAAM,QAAQA,EAAM,QAAQ,SAAS,CAAC;AACtD,SAAA/B;AAAA,IACE6N,EAAU,MAAM;AAAA,IAChB,GAAGN,CAAQ;AAAA,EAAA,GAENM,EAAU,MAAM;AACzB;AACA,SAASC,KAAa;AACpB,SAAOF;AAAA,IAAkB;AAAA;AAAA,EAAA;AAC3B;AAuCA,SAASxC,KAAgB;AACvB,MAAIjG,IAAQqE,EAAO,WAAWZ,EAAiB,GAC3CgD,IAAQ8B;AAAA,IAAmB;AAAA;AAAA,EAAA,GAC3BK,IAAUH;AAAA,IAAkB;AAAA;AAAA,EAAA;AAChC,SAAIzI,MAAU,SACLA,IAEFyG,EAAM,SAASmC,CAAO;AAC/B;AAiDA,SAAS9D,KAAoB;AAC3B,MAAI,EAAE,QAAA+D,MAAWR;AAAA,IAAqB;AAAA;AAAA,EAAA,GAClCplB,IAAKwlB;AAAA,IAAkB;AAAA;AAAA,EAAA,GACvBvD,IAAYb,EAAO,OAAO,EAAK;AACnCK,SAAAA,GAA0B,MAAM;AAC9B,IAAAQ,EAAU,UAAU;AAAA,EACtB,CAAC,GACcb,EAAO;AAAA,IACpB,OAAOlE,GAAIgF,IAAU,OAAO;AAE1B,MADApK,GAAQmK,EAAU,SAAST,EAAqB,GAC3CS,EAAU,YACX,OAAO/E,KAAO,WAChB,MAAM0I,EAAO,SAAS1I,CAAE,IAExB,MAAM0I,EAAO,SAAS1I,GAAI,EAAE,aAAald,GAAI,GAAGkiB,GAAS;AAAA,IAE7D;AAAA,IACA,CAAC0D,GAAQ5lB,CAAE;AAAA,EAAA;AAGf;AACA,IAAI6lB,KAAgB,CAAA;AACpB,SAASlD,GAAYhjB,GAAKoY,GAAMF,GAAS;AACvC,EAAI,CAACE,KAAQ,CAAC8N,GAAclmB,CAAG,MAC7BkmB,GAAclmB,CAAG,IAAI,IACrBmY,GAAQ,IAAOD,CAAO;AAE1B;AAmXyBiO,EAAO,KAAKC,EAAU;AAC/C,SAASA,GAAW;AAAA,EAClB,QAAAtN;AAAA,EACA,QAAAuN;AAAA,EACA,OAAAxC;AAAA,EACA,UAAAyC;AAAA,EACA,SAAAtB;AACF,GAAG;AACD,SAAOxC,GAAc1J,GAAQ,QAAQ,EAAE,OAAA+K,GAAO,UAAAyC,GAAU,SAAAtB,EAAgB,CAAC;AAC3E;AAuXA,IAAIuB,KAAgB,OAChBC,KAAiB;AACrB,SAASC,GAAcC,GAAQ;AAC7B,SAAO,OAAO,cAAgB,OAAeA,aAAkB;AACjE;AACA,SAASC,GAAgBD,GAAQ;AAC/B,SAAOD,GAAcC,CAAM,KAAKA,EAAO,QAAQ,kBAAkB;AACnE;AACA,SAASE,GAAcF,GAAQ;AAC7B,SAAOD,GAAcC,CAAM,KAAKA,EAAO,QAAQ,kBAAkB;AACnE;AACA,SAASG,GAAeH,GAAQ;AAC9B,SAAOD,GAAcC,CAAM,KAAKA,EAAO,QAAQ,kBAAkB;AACnE;AACA,SAASI,GAAgBC,GAAO;AAC9B,SAAO,CAAC,EAAEA,EAAM,WAAWA,EAAM,UAAUA,EAAM,WAAWA,EAAM;AACpE;AACA,SAASC,GAAuBD,GAAOE,GAAQ;AAC7C,SAAOF,EAAM,WAAW;AAAA,GACvB,CAACE,KAAUA,MAAW;AAAA,EACvB,CAACH,GAAgBC,CAAK;AACxB;AAwBA,IAAIG,KAA6B;AACjC,SAASC,KAA+B;AACtC,MAAID,OAA+B;AACjC,QAAI;AACF,UAAI;AAAA,QACF,SAAS,cAAc,MAAM;AAAA;AAAA,QAE7B;AAAA,MAAA,GAEFA,KAA6B;AAAA,IAC/B,QAAY;AACV,MAAAA,KAA6B;AAAA,IAC/B;AAEF,SAAOA;AACT;AACA,IAAIE,yBAA4C,IAAI;AAAA,EAClD;AAAA,EACA;AAAA,EACA;AACF,CAAC;AACD,SAASC,GAAeC,GAAS;AAC/B,SAAIA,KAAW,QAAQ,CAACF,GAAsB,IAAIE,CAAO,KACvDnP;AAAA,IACE;AAAA,IACA,IAAImP,CAAO,uFAAuFd,EAAc;AAAA,EAAA,GAE3G,QAEFc;AACT;AACA,SAASC,GAAsBN,GAAQjO,GAAU;AAC/C,MAAIwO,GACAC,GACAH,GACAI,GACAC;AACJ,MAAIf,GAAcK,CAAM,GAAG;AACzB,QAAIW,IAAOX,EAAO,aAAa,QAAQ;AACvC,IAAAQ,IAASG,IAAOxO,GAAcwO,GAAM5O,CAAQ,IAAI,MAChDwO,IAASP,EAAO,aAAa,QAAQ,KAAKV,IAC1Ce,IAAUD,GAAeJ,EAAO,aAAa,SAAS,CAAC,KAAKT,IAC5DkB,IAAW,IAAI,SAAST,CAAM;AAAA,EAChC,WAAWN,GAAgBM,CAAM,KAAKJ,GAAeI,CAAM,MAAMA,EAAO,SAAS,YAAYA,EAAO,SAAS,UAAU;AACrH,QAAIY,IAAOZ,EAAO;AAClB,QAAIY,KAAQ;AACV,YAAM,IAAI;AAAA,QACR;AAAA,MAAA;AAGJ,QAAID,IAAOX,EAAO,aAAa,YAAY,KAAKY,EAAK,aAAa,QAAQ;AAK1E,QAJAJ,IAASG,IAAOxO,GAAcwO,GAAM5O,CAAQ,IAAI,MAChDwO,IAASP,EAAO,aAAa,YAAY,KAAKY,EAAK,aAAa,QAAQ,KAAKtB,IAC7Ee,IAAUD,GAAeJ,EAAO,aAAa,aAAa,CAAC,KAAKI,GAAeQ,EAAK,aAAa,SAAS,CAAC,KAAKrB,IAChHkB,IAAW,IAAI,SAASG,GAAMZ,CAAM,GAChC,CAACE,MAAgC;AACnC,UAAI,EAAE,MAAAW,GAAM,MAAAzT,GAAM,OAAApU,EAAA,IAAUgnB;AAC5B,UAAI5S,MAAS,SAAS;AACpB,YAAI5K,IAASqe,IAAO,GAAGA,CAAI,MAAM;AACjC,QAAAJ,EAAS,OAAO,GAAGje,CAAM,KAAK,GAAG,GACjCie,EAAS,OAAO,GAAGje,CAAM,KAAK,GAAG;AAAA,MACnC,OAAWqe,KACTJ,EAAS,OAAOI,GAAM7nB,CAAK;AAAA,IAE/B;AAAA,EACF,OAAA;AAAA,QAAWwmB,GAAcQ,CAAM;AAC7B,YAAM,IAAI;AAAA,QACR;AAAA,MAAA;AAGF,IAAAO,IAASjB,IACTkB,IAAS,MACTH,IAAUd,IACVmB,IAAOV;AAAA;AAET,SAAIS,KAAYJ,MAAY,iBAC1BK,IAAOD,GACPA,IAAW,SAEN,EAAE,QAAAD,GAAQ,QAAQD,EAAO,eAAe,SAAAF,GAAS,UAAAI,GAAU,MAAAC,EAAA;AACpE;AAkPwB,OAAO,oBAAoB,OAAO,SAAS,EAAE,KAAA,EAAO,KAAK,IAAI;AAsfrF,SAASI,GAAW9nB,GAAOiY,GAAS;AAClC,MAAIjY,MAAU,MAASA,MAAU,QAAQ,OAAOA,IAAU;AACxD,UAAM,IAAI,MAAMiY,CAAO;AAE3B;AA8UA,SAAS8P,GAAeC,GAAQjP,GAAUkP,GAAoBC,GAAW;AACvE,MAAIC,IAAM,OAAOH,KAAW,WAAW,IAAI;AAAA,IACzCA;AAAA;AAAA;AAAA,IAGA,OAAO,SAAW,MAAc,0BAA0B,OAAO,SAAS;AAAA,EAAA,IACxEA;AACJ,SAAIC,IACEE,EAAI,SAAS,SAAS,GAAG,IAC3BA,EAAI,WAAW,GAAGA,EAAI,QAAQ,KAAKD,CAAS,KAE5CC,EAAI,WAAW,GAAGA,EAAI,QAAQ,IAAID,CAAS,KAGzCC,EAAI,aAAa,MACnBA,EAAI,WAAW,SAASD,CAAS,KACxBnP,KAAYI,GAAcgP,EAAI,UAAUpP,CAAQ,MAAM,MAC/DoP,EAAI,WAAW,GAAGtK,GAAoB9E,CAAQ,CAAC,UAAUmP,CAAS,KAElEC,EAAI,WAAW,GAAGtK,GAAoBsK,EAAI,QAAQ,CAAC,IAAID,CAAS,IAG7DC;AACT;AAqKA,eAAeC,GAAgBrO,GAAOsO,GAAmB;AACvD,MAAItO,EAAM,MAAMsO;AACd,WAAOA,EAAkBtO,EAAM,EAAE;AAEnC,MAAI;AACF,QAAIuO,IAAc,MAAM;AAAA;AAAA;AAAA,MAGtBvO,EAAM;AAAA;AAER,WAAAsO,EAAkBtO,EAAM,EAAE,IAAIuO,GACvBA;AAAA,EACT,SAASnL,GAAO;AACd,mBAAQ;AAAA,MACN,gCAAgCpD,EAAM,MAAM;AAAA,IAAA,GAE9C,QAAQ,MAAMoD,CAAK,GACf,OAAO,wBAAwB,OAAO,qBAAqB,WAI/D,OAAO,SAAS,OAAA,GACT,IAAI,QAAQ,MAAM;AAAA,IACzB,CAAC;AAAA,EACH;AACF;AA0EA,SAASoL,GAAqB9B,GAAQ;AACpC,SAAIA,KAAU,OACL,KAELA,EAAO,QAAQ,OACVA,EAAO,QAAQ,aAAa,OAAOA,EAAO,eAAgB,YAAY,OAAOA,EAAO,cAAe,WAErG,OAAOA,EAAO,OAAQ,YAAY,OAAOA,EAAO,QAAS;AAClE;AACA,eAAe+B,GAAsBjP,GAASkP,GAAUC,GAAc;AACpE,MAAIC,IAAQ,MAAM,QAAQ;AAAA,IACxBpP,EAAQ,IAAI,OAAO0C,MAAU;AAC3B,UAAIlC,IAAQ0O,EAAS,OAAOxM,EAAM,MAAM,EAAE;AAC1C,UAAIlC,GAAO;AACT,YAAIzP,IAAM,MAAM8d,GAAgBrO,GAAO2O,CAAY;AACnD,eAAOpe,EAAI,QAAQA,EAAI,MAAA,IAAU,CAAA;AAAA,MACnC;AACA,aAAO,CAAA;AAAA,IACT,CAAC;AAAA,EAAA;AAEH,SAAOse;AAAA,IACLD,EAAM,KAAK,CAAC,EAAE,OAAOJ,EAAoB,EAAE,OAAO,CAACM,MAASA,EAAK,QAAQ,gBAAgBA,EAAK,QAAQ,SAAS,EAAE;AAAA,MAC/G,CAACA,MAASA,EAAK,QAAQ,eAAe,EAAE,GAAGA,GAAM,KAAK,YAAY,IAAI,QAAA,IAAY,EAAE,GAAGA,GAAM,KAAK,WAAA;AAAA,IAAW;AAAA,EAC/G;AAEJ;AACA,SAASC,GAAsBC,GAAMC,GAAaC,GAAgBR,GAAUvP,GAAUgQ,GAAM;AAC1F,MAAIC,IAAQ,CAAClN,GAAOlS,MACbkf,EAAelf,CAAK,IAClBkS,EAAM,MAAM,OAAOgN,EAAelf,CAAK,EAAE,MAAM,KADnB,IAGjCqf,IAAmB,CAACnN,GAAOlS;AAAA;AAAA,IAG3Bkf,EAAelf,CAAK,EAAE,aAAakS,EAAM;AAAA;AAAA,IAEzCgN,EAAelf,CAAK,EAAE,MAAM,MAAM,SAAS,GAAG,KAAKkf,EAAelf,CAAK,EAAE,OAAO,GAAG,MAAMkS,EAAM,OAAO,GAAG;AAAA;AAG7G,SAAIiN,MAAS,WACJF,EAAY;AAAA,IACjB,CAAC/M,GAAOlS,MAAUof,EAAMlN,GAAOlS,CAAK,KAAKqf,EAAiBnN,GAAOlS,CAAK;AAAA,EAAA,IAGtEmf,MAAS,SACJF,EAAY,OAAO,CAAC/M,GAAOlS,MAAU;AAC1C,QAAIsf,IAAgBZ,EAAS,OAAOxM,EAAM,MAAM,EAAE;AAClD,QAAI,CAACoN,KAAiB,CAACA,EAAc;AACnC,aAAO;AAET,QAAIF,EAAMlN,GAAOlS,CAAK,KAAKqf,EAAiBnN,GAAOlS,CAAK;AACtD,aAAO;AAET,QAAIkS,EAAM,MAAM,kBAAkB;AAChC,UAAIqN,IAAcrN,EAAM,MAAM,iBAAiB;AAAA,QAC7C,YAAY,IAAI;AAAA,UACd/C,EAAS,WAAWA,EAAS,SAASA,EAAS;AAAA,UAC/C,OAAO;AAAA,QAAA;AAAA,QAET,eAAe+P,EAAe,CAAC,GAAG,UAAU,CAAA;AAAA,QAC5C,SAAS,IAAI,IAAIF,GAAM,OAAO,MAAM;AAAA,QACpC,YAAY9M,EAAM;AAAA,QAClB,yBAAyB;AAAA,MAAA,CAC1B;AACD,UAAI,OAAOqN,KAAgB;AACzB,eAAOA;AAAA,IAEX;AACA,WAAO;AAAA,EACT,CAAC,IAEI,CAAA;AACT;AACA,SAASC,GAAmBhQ,GAASkP,GAAU,EAAE,wBAAAe,EAAA,IAA2B,CAAA,GAAI;AAC9E,SAAOC;AAAA,IACLlQ,EAAQ,IAAI,CAAC0C,MAAU;AACrB,UAAIlC,IAAQ0O,EAAS,OAAOxM,EAAM,MAAM,EAAE;AAC1C,UAAI,CAAClC,EAAO,QAAO,CAAA;AACnB,UAAI2P,IAAQ,CAAC3P,EAAM,MAAM;AACzB,aAAIA,EAAM,uBACR2P,IAAQA,EAAM,OAAO3P,EAAM,kBAAkB,IAE3CA,EAAM,uBACR2P,IAAQA,EAAM,OAAO3P,EAAM,kBAAkB,IAE3CyP,KAA0BzP,EAAM,0BAClC2P,IAAQA,EAAM,OAAO3P,EAAM,qBAAqB,IAE9CA,EAAM,YACR2P,IAAQA,EAAM,OAAO3P,EAAM,OAAO,IAE7B2P;AAAA,IACT,CAAC,EAAE,KAAK,CAAC;AAAA,EAAA;AAEb;AACA,SAASD,GAAYC,GAAO;AAC1B,SAAO,CAAC,GAAG,IAAI,IAAIA,CAAK,CAAC;AAC3B;AACA,SAASC,GAASC,GAAK;AACrB,MAAIC,IAAS,CAAA,GACTC,IAAO,OAAO,KAAKF,CAAG,EAAE,KAAA;AAC5B,WAAS7pB,KAAO+pB;AACd,IAAAD,EAAO9pB,CAAG,IAAI6pB,EAAI7pB,CAAG;AAEvB,SAAO8pB;AACT;AACA,SAASjB,GAAsBmB,GAAaC,GAAU;AACpD,MAAIC,wBAA0B,IAAA;AACZ,aAAI,IAAID,CAAQ,GAC3BD,EAAY,OAAO,CAACG,GAASC,MAAe;AAKjD,QAAIpqB,IAAM,KAAK,UAAU4pB,GAASQ,CAAU,CAAC;AAC7C,WAAKF,EAAI,IAAIlqB,CAAG,MACdkqB,EAAI,IAAIlqB,CAAG,GACXmqB,EAAQ,KAAK,EAAE,KAAAnqB,GAAK,MAAMoqB,GAAY,IAEjCD;AAAA,EACT,GAAG,CAAA,CAAE;AACP;AAopBA,SAASE,KAAwB;AAC/B,MAAIC,IAAUC,EAAO,WAAWpK,EAAiB;AACjD,SAAA4H;AAAA,IACEuC;AAAA,IACA;AAAA,EAAA,GAEKA;AACT;AACA,SAASE,KAA4B;AACnC,MAAIF,IAAUC,EAAO,WAAWnK,EAAsB;AACtD,SAAA2H;AAAA,IACEuC;AAAA,IACA;AAAA,EAAA,GAEKA;AACT;AACA,IAAIG,KAAmBF,EAAO,cAAc,MAAM;AAClDE,GAAiB,cAAc;AAC/B,SAASC,KAAsB;AAC7B,MAAIJ,IAAUC,EAAO,WAAWE,EAAgB;AAChD,SAAA1C;AAAA,IACEuC;AAAA,IACA;AAAA,EAAA,GAEKA;AACT;AACA,SAASK,GAAoBC,GAAUC,GAAmB;AACxD,MAAIC,IAAmBP,EAAO,WAAWE,EAAgB,GACrD,CAACM,GAAeC,CAAgB,IAAIT,EAAO,SAAS,EAAK,GACzD,CAACU,GAAgBC,CAAiB,IAAIX,EAAO,SAAS,EAAK,GAC3D,EAAE,SAAAY,GAAS,QAAAC,GAAQ,cAAAC,GAAc,cAAAC,GAAc,cAAAC,MAAiBV,GAChE9pB,IAAMwpB,EAAO,OAAO,IAAI;AAC5BA,EAAAA,EAAO,UAAU,MAAM;AAIrB,QAHIK,MAAa,YACfM,EAAkB,EAAI,GAEpBN,MAAa,YAAY;AAC3B,UAAIY,IAAW,CAACtjB,MAAY;AAC1B,QAAAA,EAAQ,QAAQ,CAACiN,MAAU;AACzB,UAAA+V,EAAkB/V,EAAM,cAAc;AAAA,QACxC,CAAC;AAAA,MACH,GACIsW,IAAW,IAAI,qBAAqBD,GAAU,EAAE,WAAW,KAAK;AACpE,aAAIzqB,EAAI,WAAS0qB,EAAS,QAAQ1qB,EAAI,OAAO,GACtC,MAAM;AACX,QAAA0qB,EAAS,WAAA;AAAA,MACX;AAAA,IACF;AAAA,EACF,GAAG,CAACb,CAAQ,CAAC,GACbL,EAAO,UAAU,MAAM;AACrB,QAAIQ,GAAe;AACjB,UAAI1qB,IAAK,WAAW,MAAM;AACxB,QAAA6qB,EAAkB,EAAI;AAAA,MACxB,GAAG,GAAG;AACN,aAAO,MAAM;AACX,qBAAa7qB,CAAE;AAAA,MACjB;AAAA,IACF;AAAA,EACF,GAAG,CAAC0qB,CAAa,CAAC;AAClB,MAAIW,IAAY,MAAM;AACpB,IAAAV,EAAiB,EAAI;AAAA,EACvB,GACIW,IAAe,MAAM;AACvB,IAAAX,EAAiB,EAAK,GACtBE,EAAkB,EAAK;AAAA,EACzB;AACA,SAAKJ,IAGDF,MAAa,WACR,CAACK,GAAgBlqB,GAAK,EAAE,IAE1B;AAAA,IACLkqB;AAAA,IACAlqB;AAAA,IACA;AAAA,MACE,SAAS6qB,GAAqBT,GAASO,CAAS;AAAA,MAChD,QAAQE,GAAqBR,GAAQO,CAAY;AAAA,MACjD,cAAcC,GAAqBP,GAAcK,CAAS;AAAA,MAC1D,cAAcE,GAAqBN,GAAcK,CAAY;AAAA,MAC7D,cAAcC,GAAqBL,GAAcG,CAAS;AAAA,IAAA;AAAA,EAC5D,IAdO,CAAC,IAAO3qB,GAAK,EAAE;AAgB1B;AACA,SAAS6qB,GAAqBC,GAAcC,GAAY;AACtD,SAAO,CAAC/E,MAAU;AAChB,IAAA8E,KAAgBA,EAAa9E,CAAK,GAC7BA,EAAM,oBACT+E,EAAW/E,CAAK;AAAA,EAEpB;AACF;AAwDA,SAASgF,GAAkB,EAAE,MAAA/C,GAAM,GAAGgD,KAAa;AACjD,MAAIC,IAAM3L,GAAA,GACN,EAAE,QAAA2F,EAAA,IAAWoE,GAAA,GACb7Q,IAAU+Q,EAAO;AAAA,IACnB,MAAM1R,GAAYoN,EAAO,QAAQ+C,GAAM/C,EAAO,QAAQ;AAAA,IACtD,CAACA,EAAO,QAAQ+C,GAAM/C,EAAO,QAAQ;AAAA,EAAA;AAEvC,SAAKzM,IAGDyS,IACqB1B,gBAAAA,EAAO,cAAc2B,IAA0B,EAAE,MAAAlD,GAAM,SAAAxP,GAAS,GAAGwS,GAAW,IAEhFzB,gBAAAA,EAAO,cAAc4B,IAAuB,EAAE,MAAAnD,GAAM,SAAAxP,GAAS,GAAGwS,GAAW,IALzF;AAMX;AACA,SAASI,GAAsB5S,GAAS;AACtC,MAAI,EAAE,UAAAkP,GAAU,cAAAC,EAAA,IAAiB+B,GAAA,GAC7B,CAAC2B,GAAoBC,CAAqB,IAAI/B,EAAO,SAAS,CAAA,CAAE;AACpEA,SAAAA,EAAO,UAAU,MAAM;AACrB,QAAIgC,IAAc;AAClB,WAAK9D,GAAsBjP,GAASkP,GAAUC,CAAY,EAAE;AAAA,MAC1D,CAACC,MAAU;AACT,QAAK2D,KACHD,EAAsB1D,CAAK;AAAA,MAE/B;AAAA,IAAA,GAEK,MAAM;AACX,MAAA2D,IAAc;AAAA,IAChB;AAAA,EACF,GAAG,CAAC/S,GAASkP,GAAUC,CAAY,CAAC,GAC7B0D;AACT;AACA,SAASH,GAAyB;AAAA,EAChC,MAAAlD;AAAA,EACA,SAASC;AAAA,EACT,GAAG+C;AACL,GAAG;AACD,MAAI7S,IAAWyI,GAAA,GACX,EAAE,QAAAyE,EAAA,IAAWqE,GAAA,GACb,EAAE,UAAA1R,EAAA,IAAaqR,GAAA,GACfmC,IAAYjC,EAAO,QAAQ,MAAM;AACnC,QAAIvB,MAAS7P,EAAS,WAAWA,EAAS,SAASA,EAAS;AAC1D,aAAO,CAAA;AAET,QAAIiP,IAAMJ;AAAA,MACRgB;AAAA,MACAhQ;AAAA,MACAqN,EAAO;AAAA,MACP;AAAA,IAAA,GAEEoG,IAAoC,IACpCC,IAAe,CAAA;AACnB,aAASxQ,KAAS+M;AAChB,MAAI,OAAO/M,EAAM,MAAM,oBAAqB,aAC1CuQ,IAAoC,KAEpCC,EAAa,KAAKxQ,EAAM,MAAM,EAAE;AAGpC,WAAIuQ,KAAqCC,EAAa,SAAS,KAC7DtE,EAAI,aAAa,IAAI,WAAWsE,EAAa,KAAK,GAAG,CAAC,GAEjD,CAACtE,EAAI,WAAWA,EAAI,MAAM;AAAA,EACnC,GAAG;AAAA,IACDpP;AAAA,IACAqN,EAAO;AAAA,IACP2C;AAAA,IACA7P;AAAA,IACA8P;AAAA,EAAA,CACD;AACD,SAAuBsB,gBAAAA,EAAO,cAAcA,EAAO,UAAU,MAAMiC,EAAU,IAAI,CAACG,MAAyBpC,gBAAAA,EAAO,cAAc,QAAQ,EAAE,KAAKoC,GAAM,KAAK,YAAY,IAAI,SAAS,MAAAA,GAAM,GAAGX,EAAA,CAAW,CAAC,CAAC;AAC3M;AACA,SAASG,GAAsB;AAAA,EAC7B,MAAAnD;AAAA,EACA,SAASC;AAAA,EACT,GAAG+C;AACL,GAAG;AACD,MAAI7S,IAAWyI,GAAA,GACX,EAAE,QAAAyE,GAAQ,UAAAqC,GAAU,cAAAC,EAAA,IAAiB+B,GAAA,GACrC,EAAE,UAAA1R,EAAA,IAAaqR,GAAA,GACf,EAAE,YAAAzF,GAAY,SAAApL,EAAA,IAAYgR,GAAA,GAC1BoC,IAAoBrC,EAAO;AAAA,IAC7B,MAAMxB;AAAA,MACJC;AAAA,MACAC;AAAA,MACAzP;AAAA,MACAkP;AAAA,MACAvP;AAAA,MACA;AAAA,IAAA;AAAA,IAEF,CAAC6P,GAAMC,GAAazP,GAASkP,GAAUvP,CAAQ;AAAA,EAAA,GAE7C0T,IAAsBtC,EAAO;AAAA,IAC/B,MAAMxB;AAAA,MACJC;AAAA,MACAC;AAAA,MACAzP;AAAA,MACAkP;AAAA,MACAvP;AAAA,MACA;AAAA,IAAA;AAAA,IAEF,CAAC6P,GAAMC,GAAazP,GAASkP,GAAUvP,CAAQ;AAAA,EAAA,GAE7CqT,IAAYjC,EAAO,QAAQ,MAAM;AACnC,QAAIvB,MAAS7P,EAAS,WAAWA,EAAS,SAASA,EAAS;AAC1D,aAAO,CAAA;AAET,QAAI2T,wBAAmC,IAAA,GACnCC,IAAmB;AAcvB,QAbA9D,EAAY,QAAQ,CAACvJ,MAAM;AACzB,UAAI4J,IAAgBZ,EAAS,OAAOhJ,EAAE,MAAM,EAAE;AAC9C,MAAI,CAAC4J,KAAiB,CAACA,EAAc,cAGjC,CAACsD,EAAkB,KAAK,CAACI,MAAOA,EAAG,MAAM,OAAOtN,EAAE,MAAM,EAAE,KAAKA,EAAE,MAAM,MAAMkF,KAAc+D,EAAajJ,EAAE,MAAM,EAAE,GAAG,oBAE9G4J,EAAc,kBADvByD,IAAmB,KAInBD,EAAa,IAAIpN,EAAE,MAAM,EAAE;AAAA,IAE/B,CAAC,GACGoN,EAAa,SAAS;AACxB,aAAO,CAAA;AAET,QAAI1E,IAAMJ;AAAA,MACRgB;AAAA,MACAhQ;AAAA,MACAqN,EAAO;AAAA,MACP;AAAA,IAAA;AAEF,WAAI0G,KAAoBD,EAAa,OAAO,KAC1C1E,EAAI,aAAa;AAAA,MACf;AAAA,MACAa,EAAY,OAAO,CAACvJ,MAAMoN,EAAa,IAAIpN,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,CAACA,MAAMA,EAAE,MAAM,EAAE,EAAE,KAAK,GAAG;AAAA,IAAA,GAGpF,CAAC0I,EAAI,WAAWA,EAAI,MAAM;AAAA,EACnC,GAAG;AAAA,IACDpP;AAAA,IACAqN,EAAO;AAAA,IACPzB;AAAA,IACAzL;AAAA,IACAuP;AAAA,IACAkE;AAAA,IACA3D;AAAA,IACAD;AAAA,IACAL;AAAA,EAAA,CACD,GACGsE,IAAc1C,EAAO;AAAA,IACvB,MAAMf,GAAmBqD,GAAqBnE,CAAQ;AAAA,IACtD,CAACmE,GAAqBnE,CAAQ;AAAA,EAAA,GAE5B2D,IAAqBD,GAAsBS,CAAmB;AAClE,SAAuBtC,gBAAAA,EAAO,cAAcA,EAAO,UAAU,MAAMiC,EAAU,IAAI,CAACG,MAAyBpC,gBAAAA,EAAO,cAAc,QAAQ,EAAE,KAAKoC,GAAM,KAAK,YAAY,IAAI,SAAS,MAAAA,GAAM,GAAGX,EAAA,CAAW,CAAC,GAAGiB,EAAY,IAAI,CAACN,MAAyBpC,gBAAAA,EAAO,cAAc,QAAQ,EAAE,KAAKoC,GAAM,KAAK,iBAAiB,MAAAA,GAAM,GAAGX,EAAA,CAAW,CAAC,GAAGK,EAAmB,IAAI,CAAC,EAAE,KAAArsB,GAAK,MAAA8oB,EAAA;AAAA;AAAA;AAAA,IAG1VyB,gBAAAA,EAAO;AAAA,MACrB;AAAA,MACA;AAAA,QACE,KAAAvqB;AAAA,QACA,OAAOgsB,EAAU;AAAA,QACjB,GAAGlD;AAAA,QACH,aAAaA,EAAK,eAAekD,EAAU;AAAA,MAAA;AAAA,IAC7C;AAAA,GAEH,CAAC;AACJ;AA4QA,SAASkB,MAAajsB,GAAM;AAC1B,SAAO,CAAChB,MAAU;AAChB,IAAAgB,EAAK,QAAQ,CAACF,MAAQ;AACpB,MAAI,OAAOA,KAAQ,aACjBA,EAAId,CAAK,IACAc,KAAO,SAChBA,EAAI,UAAUd;AAAA,IAElB,CAAC;AAAA,EACH;AACF;AAqGA,IAAIktB,KAAa,OAAO,SAAW,OAAe,OAAO,OAAO,WAAa,OAAe,OAAO,OAAO,SAAS,gBAAkB;AACrI,IAAI;AACF,EAAIA,OACF,OAAO;AAAA,EACP;AAEJ,QAAY;AACZ;AA4LA,IAAIC,KAAsB,iCACtBC,KAAOC,EAAQ;AAAA,EACjB,SAAqB;AAAA,IACnB,SAAAC;AAAA,IACA,UAAAC,IAAW;AAAA,IACX,UAAA5C,IAAW;AAAA,IACX,UAAAtJ;AAAA,IACA,gBAAAmM;AAAA,IACA,SAASC;AAAA,IACT,eAAAC;AAAA,IACA,OAAA9J;AAAA,IACA,QAAAoD;AAAA,IACA,IAAA1J;AAAA,IACA,oBAAAqQ;AAAA,IACA,gBAAAC;AAAA,IACA,kCAAAC;AAAA,IACA,GAAGxZ;AAAA,EAAA,GACFpS,GAAc;AACf,QAAI,EAAE,UAAA8W,GAAU,WAAAwI,GAAW,yBAAAuM,MAA4BT,EAAQ,WAAW5M,EAAiB,GACvFsN,IAAa,OAAOzQ,KAAO,YAAY6P,GAAoB,KAAK7P,CAAE,GAClE4D,IAASvB,GAAYrC,GAAIvE,CAAQ;AACrC,IAAAuE,IAAK4D,EAAO;AACZ,QAAIwL,IAAOtL,GAAQ9D,GAAI,EAAE,UAAA+D,GAAU,GAC/BnI,IAAWyI,GAAA,GACXqM,IAAa;AACjB,QAAIN,GAAe;AACjB,UAAIO,IAAW3P;AAAA,QACboP;AAAA,QACA,CAAA;AAAA,QACAxU,EAAS,gBAAgBA,EAAS,cAAc,WAAW;AAAA,QAC3D;AAAA,MAAA;AAEF,MAAIH,MAAa,QACfkV,EAAS,WAAWA,EAAS,aAAa,MAAMlV,IAAWoB,GAAU,CAACpB,GAAUkV,EAAS,QAAQ,CAAC,IAEpGD,IAAazM,EAAU,WAAW0M,CAAQ;AAAA,IAC5C;AACA,QAAI,CAACjD,GAAgBkD,GAAaC,CAAgB,IAAIzD;AAAA,MACpDC;AAAA,MACAtW;AAAA,IAAA,GAEE+Z,IAAkBC,GAAoB/Q,GAAI;AAAA,MAC5C,SAASmQ;AAAA,MACT,eAAAC;AAAA,MACA,OAAA9J;AAAA,MACA,QAAAoD;AAAA,MACA,oBAAA2G;AAAA,MACA,UAAAtM;AAAA,MACA,gBAAAuM;AAAA,MACA,kCAAAC;AAAA,MACA,yBAAAC;AAAA,IAAA,CACD;AACD,aAASQ,EAAYxH,GAAO;AAC1B,MAAIwG,OAAiBxG,CAAK,GACrBA,EAAM,oBACTsH,EAAgBtH,CAAK;AAAA,IAEzB;AACA,QAAIyH,IAAY,EAAErN,EAAO,cAAcsM,IACnC3E;AAAA;AAAA,MAEcwE,gBAAAA,EAAQ;AAAA,QACtB;AAAA,QACA;AAAA,UACE,GAAGhZ;AAAA,UACH,GAAG8Z;AAAA,UACH,OAAOI,IAAYP,IAAa,WAAW9M,EAAO,eAAewL;AAAA,UACjE,SAAS6B,IAAYD,IAAchB;AAAA,UACnC,KAAKL,GAAUhrB,GAAcisB,CAAW;AAAA,UACxC,QAAAlH;AAAA,UACA,iBAAiB,CAAC+G,KAAcR,MAAa,WAAW,SAAS;AAAA,QAAA;AAAA,MACnE;AAAA;AAGJ,WAAOvC,KAAkB,CAAC+C,IAA6BV,gBAAAA,EAAQ,cAAcA,EAAQ,UAAU,MAAMxE,GAAsBwE,gBAAAA,EAAQ,cAAcvB,IAAmB,EAAE,MAAMY,EAAA,CAAM,CAAC,IAAI7D;AAAA,EACzL;AACF;AACAuE,GAAK,cAAc;AACnB,IAAIoB,KAAUnB,EAAQ;AAAA,EACpB,SAAwB;AAAA,IACtB,gBAAgBoB,IAAkB;AAAA,IAClC,eAAA5R,IAAgB;AAAA,IAChB,WAAW6R,IAAgB;AAAA,IAC3B,KAAA3S,IAAM;AAAA,IACN,OAAO4S;AAAA,IACP,IAAArR;AAAA,IACA,gBAAAsQ;AAAA,IACA,UAAArtB;AAAA,IACA,GAAG8T;AAAA,EAAA,GACFvT,GAAK;AACN,QAAIoH,IAAOuZ,GAAgBnE,GAAI,EAAE,UAAUjJ,EAAK,UAAU,GACtD6E,IAAWyI,GAAA,GACXiN,IAAcvB,EAAQ,WAAWlN,EAAsB,GACvD,EAAE,WAAAoB,GAAW,UAAAxI,EAAA,IAAasU,EAAQ,WAAW5M,EAAiB,GAC9DoO,IAAkBD,KAAe;AAAA;AAAA,IAErCE,GAAuB5mB,CAAI,KAAK0lB,MAAmB,IAC/CpQ,IAAa+D,EAAU,iBAAiBA,EAAU,eAAerZ,CAAI,EAAE,WAAWA,EAAK,UACvFuW,IAAmBvF,EAAS,UAC5B6V,IAAuBH,KAAeA,EAAY,cAAcA,EAAY,WAAW,WAAWA,EAAY,WAAW,SAAS,WAAW;AACjJ,IAAK/R,MACH4B,IAAmBA,EAAiB,YAAA,GACpCsQ,IAAuBA,IAAuBA,EAAqB,YAAA,IAAgB,MACnFvR,IAAaA,EAAW,YAAA,IAEtBuR,KAAwBhW,MAC1BgW,IAAuB5V,GAAc4V,GAAsBhW,CAAQ,KAAKgW;AAE1E,UAAMC,IAAmBxR,MAAe,OAAOA,EAAW,SAAS,GAAG,IAAIA,EAAW,SAAS,IAAIA,EAAW;AAC7G,QAAIyR,IAAWxQ,MAAqBjB,KAAc,CAACzB,KAAO0C,EAAiB,WAAWjB,CAAU,KAAKiB,EAAiB,OAAOuQ,CAAgB,MAAM,KAC/IE,IAAYH,KAAwB,SAASA,MAAyBvR,KAAc,CAACzB,KAAOgT,EAAqB,WAAWvR,CAAU,KAAKuR,EAAqB,OAAOvR,EAAW,MAAM,MAAM,MAC9L2R,IAAc;AAAA,MAChB,UAAAF;AAAA,MACA,WAAAC;AAAA,MACA,iBAAAL;AAAA,IAAA,GAEEO,IAAcH,IAAWR,IAAkB,QAC3CjuB;AACJ,IAAI,OAAOkuB,KAAkB,aAC3BluB,IAAYkuB,EAAcS,CAAW,IAErC3uB,IAAY;AAAA,MACVkuB;AAAA,MACAO,IAAW,WAAW;AAAA,MACtBC,IAAY,YAAY;AAAA,MACxBL,IAAkB,kBAAkB;AAAA,IAAA,EACpC,OAAO,OAAO,EAAE,KAAK,GAAG;AAE5B,QAAIpY,IAAQ,OAAOkY,KAAc,aAAaA,EAAUQ,CAAW,IAAIR;AACvE,WAAuBtB,gBAAAA,EAAQ;AAAA,MAC7BD;AAAA,MACA;AAAA,QACE,GAAG/Y;AAAA,QACH,gBAAgB+a;AAAA,QAChB,WAAA5uB;AAAA,QACA,KAAAM;AAAA,QACA,OAAA2V;AAAA,QACA,IAAA6G;AAAA,QACA,gBAAAsQ;AAAA,MAAA;AAAA,MAEF,OAAOrtB,KAAa,aAAaA,EAAS4uB,CAAW,IAAI5uB;AAAA,IAAA;AAAA,EAE7D;AACF;AACAiuB,GAAQ,cAAc;AACtB,IAAIa,KAAOhC,EAAQ;AAAA,EACjB,CAAC;AAAA,IACC,UAAAE,IAAW;AAAA,IACX,YAAA+B;AAAA,IACA,UAAAC;AAAA,IACA,gBAAA/B;AAAA,IACA,SAASC;AAAA,IACT,OAAA7J;AAAA,IACA,QAAA2D,IAASjB;AAAA,IACT,QAAAkB;AAAA,IACA,UAAAgI;AAAA,IACA,UAAAnO;AAAA,IACA,oBAAAsM;AAAA,IACA,gBAAAC;AAAA,IACA,kCAAAC;AAAA,IACA,GAAGxxB;AAAA,EAAA,GACF4F,MAAiB;AAClB,QAAI,EAAE,yBAAA6rB,EAAA,IAA4BT,EAAQ,WAAW5M,EAAiB,GAClEgP,IAASC,GAAA,GACTC,IAAaC,GAAcpI,GAAQ,EAAE,UAAAnG,GAAU,GAC/CwO,IAAatI,EAAO,YAAA,MAAkB,QAAQ,QAAQ,QACtDwG,IAAa,OAAOvG,KAAW,YAAY2F,GAAoB,KAAK3F,CAAM,GAC1EsI,IAAgB,CAAChJ,MAAU;AAE7B,UADA0I,KAAYA,EAAS1I,CAAK,GACtBA,EAAM,iBAAkB;AAC5B,MAAAA,EAAM,eAAA;AACN,UAAIiJ,IAAYjJ,EAAM,YAAY,WAC9BkJ,IAAeD,GAAW,aAAa,YAAY,KAAKxI,GACxD0I,IAAW,MAAMR,EAAOM,KAAajJ,EAAM,eAAe;AAAA,QAC5D,YAAAwI;AAAA,QACA,QAAQU;AAAA,QACR,UAAAT;AAAA,QACA,SAAS9B;AAAA,QACT,OAAA7J;AAAA,QACA,UAAAvC;AAAA,QACA,oBAAAsM;AAAA,QACA,gBAAAC;AAAA,QACA,kCAAAC;AAAA,MAAA,CACD;AACD,MAAIC,KAA2ByB,MAAa,KAC1ClC,EAAQ,gBAAgB,MAAM4C,GAAU,IAExCA,EAAA;AAAA,IAEJ;AACA,WAAuB5C,gBAAAA,EAAQ;AAAA,MAC7B;AAAA,MACA;AAAA,QACE,KAAKprB;AAAA,QACL,QAAQ4tB;AAAA,QACR,QAAQF;AAAA,QACR,UAAUnC,IAAiBgC,IAAWM;AAAA,QACtC,GAAGzzB;AAAA,QACH,iBAAiB,CAAC0xB,KAAcR,MAAa,WAAW,SAAS;AAAA,MAAA;AAAA,IACnE;AAAA,EAEJ;AACF;AACA8B,GAAK,cAAc;AA2DnB,SAASa,GAA2B3K,GAAU;AAC5C,SAAO,GAAGA,CAAQ;AACpB;AACA,SAAS4K,GAAsB5K,GAAU;AACvC,MAAIE,IAAM4H,EAAQ,WAAWnN,EAAiB;AAC9C,SAAAlI,GAAUyN,GAAKyK,GAA2B3K,CAAQ,CAAC,GAC5CE;AACT;AAMA,SAAS4I,GAAoB/Q,GAAI;AAAA,EAC/B,QAAA0J;AAAA,EACA,SAASoJ;AAAA,EACT,eAAA1C;AAAA,EACA,OAAA9J;AAAA,EACA,oBAAA+J;AAAA,EACA,UAAAtM;AAAA,EACA,gBAAAuM;AAAA,EACA,kCAAAC;AAAA,EACA,yBAAAC;AACF,IAAI,IAAI;AACN,MAAIyB,IAAWxN,GAAA,GACX7I,IAAWyI,GAAA,GACXzZ,IAAOuZ,GAAgBnE,GAAI,EAAE,UAAA+D,GAAU;AAC3C,SAAOgM,EAAQ;AAAA,IACb,CAACvG,MAAU;AACT,UAAIC,GAAuBD,GAAOE,CAAM,GAAG;AACzC,QAAAF,EAAM,eAAA;AACN,YAAI2G,IAAW2C,MAAgB,SAASA,IAAchY,GAAWc,CAAQ,MAAMd,GAAWlQ,CAAI,GAC1FmoB,IAAa,MAAMd,EAASjS,GAAI;AAAA,UAClC,SAASmQ;AAAA,UACT,eAAAC;AAAA,UACA,OAAA9J;AAAA,UACA,oBAAA+J;AAAA,UACA,UAAAtM;AAAA,UACA,gBAAAuM;AAAA,UACA,kCAAAC;AAAA,QAAA,CACD;AACD,QAAIC,IACFT,EAAQ,gBAAgB,MAAMgD,GAAY,IAE1CA,EAAA;AAAA,MAEJ;AAAA,IACF;AAAA,IACA;AAAA,MACEnX;AAAA,MACAqW;AAAA,MACArnB;AAAA,MACAkoB;AAAA,MACA1C;AAAA,MACA9J;AAAA,MACAoD;AAAA,MACA1J;AAAA,MACAqQ;AAAA,MACAtM;AAAA,MACAuM;AAAA,MACAC;AAAA,MACAC;AAAA,IAAA;AAAA,EACF;AAEJ;AAkCA,IAAIwC,KAAY,GACZC,KAAqB,MAAM,KAAK,OAAO,EAAED,EAAS,CAAC;AACvD,SAASZ,KAAY;AACnB,MAAI,EAAE,QAAA1J,MAAWmK;AAAA,IAAsB;AAAA;AAAA,EAAA,GACnC,EAAE,UAAApX,EAAA,IAAasU,EAAQ,WAAW5M,EAAiB,GACnD+P,IAAiB1K,GAAA,GACjB2K,IAAczK,EAAO,OACrB0K,IAAiB1K,EAAO;AAC5B,SAAOqH,EAAQ;AAAA,IACb,OAAOrG,GAAQ1E,IAAU,OAAO;AAC9B,UAAI,EAAE,QAAAkF,GAAQ,QAAAD,GAAQ,SAAAF,GAAS,UAAAI,GAAU,MAAAC,MAASJ;AAAA,QAChDN;AAAA,QACAjO;AAAA,MAAA;AAEF,UAAIuJ,EAAQ,aAAa,IAAO;AAC9B,YAAIviB,IAAMuiB,EAAQ,cAAciO,GAAA;AAChC,cAAME,EAAY1wB,GAAKywB,GAAgBlO,EAAQ,UAAUkF,GAAQ;AAAA,UAC/D,kCAAkClF,EAAQ;AAAA,UAC1C,oBAAoBA,EAAQ;AAAA,UAC5B,UAAAmF;AAAA,UACA,MAAAC;AAAA,UACA,YAAYpF,EAAQ,UAAUiF;AAAA,UAC9B,aAAajF,EAAQ,WAAW+E;AAAA,UAChC,WAAW/E,EAAQ;AAAA,QAAA,CACpB;AAAA,MACH;AACE,cAAMoO,EAAepO,EAAQ,UAAUkF,GAAQ;AAAA,UAC7C,kCAAkClF,EAAQ;AAAA,UAC1C,oBAAoBA,EAAQ;AAAA,UAC5B,UAAAmF;AAAA,UACA,MAAAC;AAAA,UACA,YAAYpF,EAAQ,UAAUiF;AAAA,UAC9B,aAAajF,EAAQ,WAAW+E;AAAA,UAChC,SAAS/E,EAAQ;AAAA,UACjB,OAAOA,EAAQ;AAAA,UACf,aAAakO;AAAA,UACb,WAAWlO,EAAQ;AAAA,UACnB,gBAAgBA,EAAQ;AAAA,QAAA,CACzB;AAAA,IAEL;AAAA,IACA,CAACmO,GAAaC,GAAgB3X,GAAUyX,CAAc;AAAA,EAAA;AAE1D;AACA,SAASZ,GAAcpI,GAAQ,EAAE,UAAAnG,EAAA,IAAa,CAAA,GAAI;AAChD,MAAI,EAAE,UAAAtI,EAAA,IAAasU,EAAQ,WAAW5M,EAAiB,GACnD2D,IAAeiJ,EAAQ,WAAW1M,EAAY;AAClD,EAAA3I,GAAUoM,GAAc,kDAAkD;AAC1E,MAAI,CAACnI,CAAK,IAAImI,EAAa,QAAQ,MAAM,EAAE,GACvClc,IAAO,EAAE,GAAGuZ,GAAgB+F,KAAkB,KAAK,EAAE,UAAAnG,EAAA,CAAU,EAAA,GAC/DnI,IAAWyI,GAAA;AACf,MAAI6F,KAAU,MAAM;AAClB,IAAAtf,EAAK,SAASgR,EAAS;AACvB,QAAI4D,IAAS,IAAI,gBAAgB5U,EAAK,MAAM,GACxCyoB,IAAc7T,EAAO,OAAO,OAAO;AAEvC,QADyB6T,EAAY,KAAK,CAACzT,MAAMA,MAAM,EAAE,GACjC;AACtB,MAAAJ,EAAO,OAAO,OAAO,GACrB6T,EAAY,OAAO,CAACzT,MAAMA,CAAC,EAAE,QAAQ,CAACA,MAAMJ,EAAO,OAAO,SAASI,CAAC,CAAC;AACrE,UAAI0T,IAAK9T,EAAO,SAAA;AAChB,MAAA5U,EAAK,SAAS0oB,IAAK,IAAIA,CAAE,KAAK;AAAA,IAChC;AAAA,EACF;AACA,UAAK,CAACpJ,KAAUA,MAAW,QAAQvL,EAAM,MAAM,UAC7C/T,EAAK,SAASA,EAAK,SAASA,EAAK,OAAO,QAAQ,OAAO,SAAS,IAAI,WAElE6Q,MAAa,QACf7Q,EAAK,WAAWA,EAAK,aAAa,MAAM6Q,IAAWoB,GAAU,CAACpB,GAAU7Q,EAAK,QAAQ,CAAC,IAEjFkQ,GAAWlQ,CAAI;AACxB;AAwOA,SAAS4mB,GAAuBxR,GAAI,EAAE,UAAA+D,EAAA,IAAa,CAAA,GAAI;AACrD,MAAIwP,IAAYxD,EAAQ,WAAW/M,EAAqB;AACxD,EAAAtI;AAAA,IACE6Y,KAAa;AAAA,IACb;AAAA,EAAA;AAEF,MAAI,EAAE,UAAA9X,MAAaoX;AAAA,IACjB;AAAA;AAAA,EAAA,GAEEjoB,IAAOuZ,GAAgBnE,GAAI,EAAE,UAAA+D,GAAU;AAC3C,MAAI,CAACwP,EAAU;AACb,WAAO;AAET,MAAIC,IAAc3X,GAAc0X,EAAU,gBAAgB,UAAU9X,CAAQ,KAAK8X,EAAU,gBAAgB,UACvGE,IAAW5X,GAAc0X,EAAU,aAAa,UAAU9X,CAAQ,KAAK8X,EAAU,aAAa;AAClG,SAAO3U,GAAUhU,EAAK,UAAU6oB,CAAQ,KAAK,QAAQ7U,GAAUhU,EAAK,UAAU4oB,CAAW,KAAK;AAChG;;;;GCnmVaE,KAAsBC;AAAA,EACjC,CAAC,EAAE,MAAAC,GAAM,OAAAtc,GAAO,QAAAH,GAAQ,WAAAjU,GAAW,iBAAA2wB,GAAiB,UAAAC,GAAU,WAAAC,GAAW,MAAAxI,QAAW;AAClF,UAAMyI,IAAqB5wB,EAAGC,GAAI,MAAM,EAAE,CAACA,GAAI,IAAI,GAAGkoB,EAAA,GAAQroB,CAAS,GAEjE+wB,IAAiBvd;AAAA,MACrB,OAAO;AAAA,QACL,iBAAAmd;AAAA,QACA,GAAIE,KAAa,EAAE,OAAOA,EAAA;AAAA,QAC1B,GAAIzc,KAAS,EAAE,OAAAA,EAAA;AAAA,QACf,GAAIH,KAAU,EAAE,QAAQ,GAAGA,CAAM,KAAA;AAAA,QACjC,GAAI2c,KAAY,EAAE,iBAAiB,OAAOA,CAAQ,IAAA;AAAA,MAAI;AAAA,MAExD,CAACD,GAAiB1c,GAAQ2c,GAAUC,GAAWzc,CAAK;AAAA,IAAA;AAGtD,WAAOiU,sBACJuE,IAAA,EAAK,WAAWkE,GAAoB,OAAOC,GAAgB,IAAI1I,GAC9D,UAAA,gBAAAjoB,EAAC,QAAA,EAAM,aAAK,EAAA,CACd,IAEA,gBAAAA,EAAC,OAAA,EAAI,WAAW0wB,GAAoB,OAAOC,GACzC,UAAA,gBAAA3wB,EAAC,QAAA,EAAM,UAAAswB,EAAA,CAAK,GACd;AAAA,EAEJ;AACF;;;;;;;;;;;;;GCTMM,KAAc,CAClBn1B,MAEA,WAAWA,KACX,MAAM,QAAQA,EAAM,KAAK,KACzB,gBAAgBA,KAChB,OAAOA,EAAM,cAAe,YAExBo1B,KAAc,CAClBp1B,MAEIm1B,GAAYn1B,CAAK,IACZA,EAAM,MAAM,IAAI,CAACq1B,GAAM3nB,OAAW;AAAA,EACvC,KAAK,GAAG2nB,EAAK,EAAE,IAAI3nB,CAAK;AAAA,EACxB,SAAS1N,EAAM,WAAWq1B,CAAI;AAAA,EAC9B,SAASA,EAAK;AAAA,EACd,IAGGC,GAAS,QAAQt1B,EAAM,QAAQ,EAAE,IAAI,CAACmG,GAAOuH,OAAW;AAAA,EAC7D,KACE6nB,GAAepvB,CAAK,KAAKA,EAAM,QAAQ,QAAQA,EAAM,QAAQ,UAAaA,EAAM,QAAQ,MACpF,OAAOA,EAAM,GAAG,IAChB,SAASuH,CAAK;AAAA,EACpB,SAASvH;AAAA,EACT,GAGEqvB,KAA0B,CAC9Bx1B,MACwB;AACxB,QAAMy1B,IAAS,EAAE,GAAGz1B,EAAA;AACpB,gBAAOy1B,EAAO,OACd,OAAOA,EAAO,YACd,OAAOA,EAAO,UACPA;AACT,GAEaC,KAAW,CACtB11B,MACG;AACH,QAAM21B,IAASP,GAAYp1B,CAAK,GAC1B41B,IAAaD,EAAO,QACpBE,IAAsBL,GAAwBx1B,CAAK,GACnD;AAAA,IACJ,WAAAmE;AAAA,IACA,MAAM2xB;AAAA,IACN,aAAaC;AAAA,IACb,MAAMC;AAAA,IACN,UAAUC;AAAA,IACV,UAAAC,IAAW;AAAA,IACX,OAAOC;AAAA,IACP,MAAMC;AAAA,IACN,OAAOC;AAAA,IACP,GAAGC;AAAA,EAAA,IACDT,GAEE,CAACU,GAAaC,CAAc,IAAIle,EAAS,CAAC,GAE1CrM,IAAO,MAAM;AACjB,IAAAuqB,EAAe,CAACC,MAAUA,MAASb,IAAa,IAAI,IAAIa,IAAO,CAAE;AAAA,EACnE,GAEMC,IAAW,MAAM;AACrB,IAAAF,EAAe,CAACC,MAAUA,MAAS,IAAIb,IAAa,IAAIa,IAAO,CAAE;AAAA,EACnE,GAEME,IAAY,CAACC,MAAqB;AACtC,IAAAJ,EAAeI,CAAQ;AAAA,EACzB,GAEMC,IAASjB,IAAa,GACtBkB,IAAiBnf,GAAQ,MAAMge,EAAO,IAAI,CAACoB,OAAW,EAAE,KAAKA,EAAM,IAAA,EAAM,GAAG,CAACpB,CAAM,CAAC,GAEpFqB,IAAgB,CAACvM,MAAyC;AAG9D,IAFA6L,EAAS,YAAY7L,CAAK,GAEtB,EAAAA,EAAM,oBAAoB,CAACyL,KAAY,CAACW,OAIxCpM,EAAM,QAAQ,eAChBiM,EAAA,GAGEjM,EAAM,QAAQ,gBAChBxe,EAAA;AAAA,EAEJ;AAEA,SAAK2pB,IAIAiB,IAKH,gBAAAtyB,EAAC,OAAA,EAAI,WAAWmT,GAAO,iBACrB,UAAA,gBAAAtT;AAAA,IAAC;AAAA,IAAA;AAAA,MACE,GAAGkyB;AAAA,MACJ,WAAW,CAAC5e,GAAO,UAAUvT,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAAA,MAChE,WAAW6yB;AAAA,MACX,MAAK;AAAA,MACL,wBAAqB;AAAA,MAErB,UAAA;AAAA,QAAA,gBAAAzyB,EAAC,OAAA,EAAI,WAAWmT,GAAO,UACpB,YAAO,IAAI,CAACqf,GAAOrpB,MAClB,gBAAAnJ;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,WAAW,CAACmT,GAAO,OAAOhK,MAAU6oB,IAAc7e,GAAO,cAAc,EAAE,EACtE,OAAO,OAAO,EACd,KAAK,GAAG;AAAA,YACX,eAAahK,MAAU6oB;AAAA,YAEvB,4BAAC,OAAA,EAAI,WAAW7e,GAAO,aAAc,YAAM,QAAA,CAAQ;AAAA,UAAA;AAAA,UAN9Cqf,EAAM;AAAA,QAAA,CAQd,GACH;AAAA,QAEA,gBAAA3yB,EAAC,OAAA,EAAI,WAAWsT,GAAO,UACrB,UAAA;AAAA,UAAA,gBAAAnT;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAWmT,GAAO;AAAA,cAClB,MAAK;AAAA,cACL,SAASgf;AAAA,cACT,cAAW;AAAA,cAEX,4BAAC,QAAA,EAAK,WAAWhf,GAAO,UAAU,eAAY,OAAA,CAAO;AAAA,YAAA;AAAA,UAAA;AAAA,UAGvD,gBAAAnT,EAAC,SAAI,WAAWmT,GAAO,YACpB,UAAAof,EAAe,IAAI,CAACzB,GAAM3nB,MACzB,gBAAAnJ;AAAA,YAAC;AAAA,YAAA;AAAA,cAEC,WAAWmJ,MAAU6oB,IAAc7e,GAAO,kBAAkB;AAAA,cAC5D,MAAK;AAAA,cACL,SAAS,MAAMif,EAAUjpB,CAAK;AAAA,cAC9B,cAAY,eAAeA,IAAQ,CAAC;AAAA,cACpC,gBAAcA,MAAU6oB;AAAA,YAAA;AAAA,YALnBlB,EAAK;AAAA,UAAA,CAOb,GACH;AAAA,UAEA,gBAAA9wB;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAWmT,GAAO;AAAA,cAClB,MAAK;AAAA,cACL,SAASzL;AAAA,cACT,cAAW;AAAA,cAEX,4BAAC,QAAA,EAAK,WAAWyL,GAAO,UAAU,eAAY,OAAA,CAAO;AAAA,YAAA;AAAA,UAAA;AAAA,QACvD,EAAA,CACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA,GAEJ,IA3DO,gBAAAnT,EAAC,SAAI,WAAWmT,GAAO,iBAAkB,UAAAie,EAAO,CAAC,EAAE,QAAA,CAAQ,IAJ3D;AAiEX,GC5LMsB,KAAS;AAgBR,SAASC,GACdC,GACAC,IAA8B,OACoB;AAClD,QAAM,EAAE,MAAAC,GAAM,OAAAC,GAAO,KAAAC,GAAK,QAAAC,GAAQ,OAAAjf,GAAO,QAAAH,MAAW+e,GAC9CM,IAAUJ,IAAO9e,IAAQ,GACzBmf,IAAUH,IAAMnf,IAAS;AAE/B,UAAQgf,GAAA;AAAA,IACN,KAAK;AACH,aAAO,EAAE,MAAMK,GAAS,KAAKF,IAAMN,IAAQ,WAAW,yBAAA;AAAA,IACxD,KAAK;AACH,aAAO,EAAE,MAAAI,GAAM,KAAKE,IAAMN,IAAQ,WAAW,oBAAA;AAAA,IAC/C,KAAK;AACH,aAAO,EAAE,MAAMK,GAAO,KAAKC,IAAMN,IAAQ,WAAW,0BAAA;AAAA,IACtD,KAAK;AACH,aAAO,EAAE,MAAMQ,GAAS,KAAKD,IAASP,IAAQ,WAAW,qBAAA;AAAA,IAC3D,KAAK;AACH,aAAO,EAAE,MAAAI,GAAM,KAAKG,IAASP,IAAQ,WAAW,gBAAA;AAAA,IAClD,KAAK;AACH,aAAO,EAAE,MAAMK,GAAO,KAAKE,IAASP,IAAQ,WAAW,sBAAA;AAAA,IACzD,KAAK;AACH,aAAO,EAAE,MAAMI,IAAOJ,IAAQ,KAAKS,GAAS,WAAW,yBAAA;AAAA,IACzD,KAAK;AACH,aAAO,EAAE,MAAML,IAAOJ,IAAQ,KAAAM,GAAK,WAAW,sBAAA;AAAA,IAChD,KAAK;AACH,aAAO,EAAE,MAAMF,IAAOJ,IAAQ,KAAKO,GAAQ,WAAW,0BAAA;AAAA,IACxD,KAAK;AACH,aAAO,EAAE,MAAMF,IAAQL,IAAQ,KAAKS,GAAS,WAAW,qBAAA;AAAA,IAC1D,KAAK;AACH,aAAO,EAAE,MAAMJ,IAAQL,IAAQ,KAAAM,GAAK,WAAW,kBAAA;AAAA,IACjD,KAAK;AACH,aAAO,EAAE,MAAMD,IAAQL,IAAQ,KAAKO,GAAQ,WAAW,sBAAA;AAAA,IACzD;AACE,aAAO,EAAE,MAAMC,GAAS,KAAKF,IAAMN,IAAQ,WAAW,yBAAA;AAAA,EAAyB;AAErF;;;;;;;;;;AClCA,SAASU,GAAkBP,GAAkE;AAC3F,SAAIA,EAAU,WAAW,KAAK,IACrB,WAELA,EAAU,WAAW,QAAQ,IACxB,QAELA,EAAU,WAAW,MAAM,IACtB,UAELA,EAAU,WAAW,OAAO,IACvB,SAEF;AACT;AAiBO,MAAMQ,KAAchD;AAAA,EACzB,CAAC;AAAA,IACC,OAAA5wB;AAAA,IACA,MAAM6zB;AAAA,IACN,aAAAC,IAAc;AAAA,IACd,SAAA9d,IAAU;AAAA,IACV,iBAAA+d,IAAkB;AAAA,IAClB,iBAAAC,IAAkB;AAAA,IAClB,cAAAC;AAAA,IACA,WAAAb,IAAY;AAAA,IACZ,OAAAc,IAAQ;AAAA,IACR,UAAAh0B;AAAA,IACA,kBAAAi0B;AAAA,IACA,mBAAAC,IAAoB,MAAM,SAAS;AAAA,EAAA,MACjB;AAClB,UAAMC,IAAeR,MAAa,QAC5B,CAACS,GAAcC,CAAe,IAAIjgB,EAASwf,CAAW,GACtDU,IAAOH,IAAeR,IAAWS,GAEjCG,IAAU/e;AAAA,MACd,CAAC/V,MAAmB;AAClB,QAAK00B,KACHE,EAAgB50B,CAAK,GAEvBs0B,IAAet0B,CAAK;AAAA,MACtB;AAAA,MACA,CAAC00B,GAAcJ,CAAY;AAAA,IAAA,GAGvB/e,IAAaR,GAAwB,IAAI,GACzC,CAAC0B,GAAOse,CAAQ,IAAIpgB,EAIhB,IAAI,GACRqgB,IAAgBjgB,GAA6C,IAAI,GACjEkgB,IAAgBlgB,GAA6C,IAAI,GAEjEmgB,IAAW,MAAM,QAAQ7e,CAAO,IAAIA,IAAU,CAACA,CAAO,GACtD8e,IAAWD,EAAS,SAAS,OAAO,GACpCE,IAAWF,EAAS,SAAS,OAAO,GAEpCG,IAAkBtf,EAAY,MAAM;AACxC,MAAIif,EAAc,YAChB,aAAaA,EAAc,OAAO,GAClCA,EAAc,UAAU;AAAA,IAE5B,GAAG,CAAA,CAAE,GAECM,IAAkBvf,EAAY,MAAM;AACxC,MAAIkf,EAAc,YAChB,aAAaA,EAAc,OAAO,GAClCA,EAAc,UAAU;AAAA,IAE5B,GAAG,CAAA,CAAE,GAECM,IAAmBxf,EAAY,MAAM;AACzC,MAAKof,MAGLG,EAAA,GACAN,EAAc,UAAU,WAAW,MAAMF,EAAQ,EAAI,GAAGV,CAAe;AAAA,IACzE,GAAG,CAACe,GAAUf,GAAiBU,GAASQ,CAAe,CAAC,GAElDE,IAAmBzf,EAAY,MAAM;AACzC,MAAKof,MAGLE,EAAA,GACAJ,EAAc,UAAU,WAAW,MAAMH,EAAQ,EAAK,GAAGT,CAAe;AAAA,IAC1E,GAAG,CAACc,GAAUd,GAAiBS,GAASO,CAAe,CAAC,GAElD/G,IAAcvY;AAAA,MAClB,CAAC0f,MAAwB;AACvB,QAAKL,MAGLK,EAAE,eAAA,GACFX,EAAQ,CAACD,CAAI;AAAA,MACf;AAAA,MACA,CAACO,GAAUP,GAAMC,CAAO;AAAA,IAAA;AAG1B,IAAA9f,GAAU,MAAM;AACd,UAAI,CAACogB,KAAY,CAACP,KAAQH;AACxB;AAEF,YAAMgB,IAAa,CAACD,MAAkB;AACpC,cAAM9d,IAAKpC,EAAW;AACtB,QAAIoC,KAAM,CAACA,EAAG,SAAS8d,EAAE,MAAc,KACrCX,EAAQ,EAAK;AAAA,MAEjB;AACA,sBAAS,iBAAiB,aAAaY,CAAU,GAC1C,MAAM,SAAS,oBAAoB,aAAaA,CAAU;AAAA,IACnE,GAAG,CAACN,GAAUP,GAAMH,GAAcI,CAAO,CAAC,GAE1Ca,GAAgB,MAAM;AACpB,UAAI,CAACd,KAAQ,CAACtf,EAAW,SAAS;AAChC,QAAAwf,EAAS,IAAI;AACb;AAAA,MACF;AACA,YAAMvB,IAAOje,EAAW,QAAQ,sBAAA;AAChC,MAAAwf,EAASxB,GAAmBC,GAAMC,CAAS,CAAC;AAAA,IAC9C,GAAG,CAACoB,GAAMpB,CAAS,CAAC,GAEpBze;AAAA,MACE,MAAM,MAAM;AACV,QAAAqgB,EAAA,GACAC,EAAA;AAAA,MACF;AAAA,MACA,CAACD,GAAiBC,CAAe;AAAA,IAAA;AAGnC,UAAMM,IAAY,OAAO,WAAa,MAAcnB,MAAsB,MACpEoB,IAAiB7B,GAAkBP,CAAS,GAE5CqC,IACJjB;AAAA,IAEAx0B,KAAS,QACTA,MAAU,MACVoW,KACAmf,KACAG;AAAA,MACE,gBAAAt1B;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAWC,EAAGC,GAAI,SAAS6zB,CAAgB;AAAA,UAC3C,OAAO;AAAA,YACL,MAAM/d,EAAM;AAAA,YACZ,KAAKA,EAAM;AAAA,YACX,WAAWA,EAAM;AAAA,UAAA;AAAA,UAEnB,MAAK;AAAA,UAEJ,UAAA;AAAA,YAAApW;AAAA,YACAk0B,KAAS,gBAAA3zB,EAAC,QAAA,EAAK,WAAWF,EAAGC,GAAI,OAAOA,GAAIk1B,CAAc,CAAC,EAAA,CAAG;AAAA,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,MAEjED;AAAA,IAAA;AAYJ,WACE,gBAAAn1B,EAAAu1B,IAAA,EACE,UAAA;AAAA,MAAA,gBAAAp1B,EAAC,QAAA,EAAK,KAAK2U,GAAa,GAV1B,CAACmf,MAAiBS,KAAYC,KAC1B;AAAA,QACE,cAAcG;AAAA,QACd,cAAcC;AAAA,QACd,SAASJ,IAAW9G,IAAc;AAAA,MAAA,IAEpC,CAAA,GAKC,UAAA/tB,GACH;AAAA,MACCu1B;AAAA,IAAA,GACH;AAAA,EAEJ;AACF;AAEA7B,GAAY,cAAc;;;;;GChMbgC,KAAkBhF;AAAA,EAC7B,CAAC;AAAA,IACC,UAAA1wB;AAAA,IACA,SAAA+sB;AAAA,IACA,QAAA4I;AAAA,IACA,aAAAC,IAAc;AAAA,IACd,WAAAC;AAAA,IACA,UAAAC,IAAW;AAAA,IACX,WAAA71B;AAAA,EAAA,MAC0B;AAC1B,UAAM8tB,IAAcvY,EAAY,MAAM;AACpC,MAAAuX,EAAA;AAAA,IACF,GAAG,CAACA,CAAO,CAAC;AAEZ,WACE,gBAAA1sB,EAAC,QAAA,EAAK,WAAWD,GAAI,SACnB,UAAA,gBAAAC,EAACqzB,IAAA,EAAY,MAAMiC,GAAQ,OAAOC,GAAa,WAAU,OACvD,UAAA,gBAAA11B;AAAA,MAAC8T;AAAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,SAAS;AAAA,QACT,MAAM;AAAA,QACN,WAAW7T,EAAGC,GAAI,SAASH,CAAS;AAAA,QACpC,SAAS8tB;AAAA,QACT,cAAY8H;AAAA,QACZ,aAAU;AAAA,QAET,UAAA;AAAA,UAAA71B;AAAA,UACA81B,KAAY,gBAAAz1B,EAAC01B,IAAA,EAAS,WAAW31B,GAAI,MAAM,eAAW,GAAA,CAAC;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA,GAE5D,EAAA,CACF;AAAA,EAEJ;AACF;AAEAs1B,GAAgB,cAAc;AClD9B,SAAStK,GAAqB4K,GAAsBC,GAAiB,EAAE,0BAAAC,IAA2B,GAAI,IAAK,IAAI;AAC7G,SAAO,SAAqB3P,GAAO;AAEjC,QADAyP,IAAuBzP,CAAK,GACxB2P,MAA6B,MAAS,CAAC3P,EAAM;AAC/C,aAAO0P,IAAkB1P,CAAK;AAAA,EAElC;AACF;ACNA,SAAS4P,GAAeC,GAAmBC,GAAgB;AACzD,QAAMC,IAAUv6B,EAAM,cAAcs6B,CAAc,GAC5CE,IAAW,CAACz6B,MAAU;AAC1B,UAAM,EAAE,UAAAkE,GAAU,GAAG8pB,EAAO,IAAKhuB,GAC3B2D,IAAQ1D,EAAM,QAAQ,MAAM+tB,GAAS,OAAO,OAAOA,CAAO,CAAC;AACjE,WAAuB,gBAAAzpB,EAAIi2B,EAAQ,UAAU,EAAE,OAAA72B,GAAO,UAAAO,EAAQ,CAAE;AAAA,EAClE;AACA,EAAAu2B,EAAS,cAAcH,IAAoB;AAC3C,WAASI,EAAYC,GAAc;AACjC,UAAM3M,IAAU/tB,EAAM,WAAWu6B,CAAO;AACxC,QAAIxM,EAAS,QAAOA;AACpB,QAAIuM,MAAmB,OAAQ,QAAOA;AACtC,UAAM,IAAI,MAAM,KAAKI,CAAY,4BAA4BL,CAAiB,IAAI;AAAA,EACpF;AACA,SAAO,CAACG,GAAUC,CAAW;AAC/B;AACA,SAASE,GAAmBC,GAAWC,IAAyB,IAAI;AAClE,MAAIC,IAAkB,CAAA;AACtB,WAASC,EAAeV,GAAmBC,GAAgB;AACzD,UAAMU,IAAch7B,EAAM,cAAcs6B,CAAc,GAChD7sB,IAAQqtB,EAAgB;AAC9B,IAAAA,IAAkB,CAAC,GAAGA,GAAiBR,CAAc;AACrD,UAAME,IAAW,CAACz6B,MAAU;AAC1B,YAAM,EAAE,OAAAk7B,GAAO,UAAAh3B,GAAU,GAAG8pB,EAAO,IAAKhuB,GAClCw6B,IAAUU,IAAQL,CAAS,IAAIntB,CAAK,KAAKutB,GACzCt3B,IAAQ1D,EAAM,QAAQ,MAAM+tB,GAAS,OAAO,OAAOA,CAAO,CAAC;AACjE,aAAuB,gBAAAzpB,EAAIi2B,EAAQ,UAAU,EAAE,OAAA72B,GAAO,UAAAO,EAAQ,CAAE;AAAA,IAClE;AACA,IAAAu2B,EAAS,cAAcH,IAAoB;AAC3C,aAASI,EAAYC,GAAcO,GAAO;AACxC,YAAMV,IAAUU,IAAQL,CAAS,IAAIntB,CAAK,KAAKutB,GACzCjN,IAAU/tB,EAAM,WAAWu6B,CAAO;AACxC,UAAIxM,EAAS,QAAOA;AACpB,UAAIuM,MAAmB,OAAQ,QAAOA;AACtC,YAAM,IAAI,MAAM,KAAKI,CAAY,4BAA4BL,CAAiB,IAAI;AAAA,IACpF;AACA,WAAO,CAACG,GAAUC,CAAW;AAAA,EAC/B;AACA,QAAMS,IAAc,MAAM;AACxB,UAAMC,IAAgBL,EAAgB,IAAI,CAACR,MAClCt6B,EAAM,cAAcs6B,CAAc,CAC1C;AACD,WAAO,SAAkBW,GAAO;AAC9B,YAAMG,IAAWH,IAAQL,CAAS,KAAKO;AACvC,aAAOn7B,EAAM;AAAA,QACX,OAAO,EAAE,CAAC,UAAU46B,CAAS,EAAE,GAAG,EAAE,GAAGK,GAAO,CAACL,CAAS,GAAGQ,EAAQ;QACnE,CAACH,GAAOG,CAAQ;AAAA,MACxB;AAAA,IACI;AAAA,EACF;AACA,SAAAF,EAAY,YAAYN,GACjB,CAACG,GAAgBM,GAAqBH,GAAa,GAAGL,CAAsB,CAAC;AACtF;AACA,SAASQ,MAAwBC,GAAQ;AACvC,QAAMC,IAAYD,EAAO,CAAC;AAC1B,MAAIA,EAAO,WAAW,EAAG,QAAOC;AAChC,QAAML,IAAc,MAAM;AACxB,UAAMM,IAAaF,EAAO,IAAI,CAACG,OAAkB;AAAA,MAC/C,UAAUA,EAAY;AAAA,MACtB,WAAWA,EAAa;AAAA,IAC9B,EAAM;AACF,WAAO,SAA2BC,GAAgB;AAChD,YAAMC,IAAaH,EAAW,OAAO,CAACI,GAAa,EAAE,UAAAC,GAAU,WAAAjB,QAAgB;AAE7E,cAAMkB,IADaD,EAASH,CAAc,EACV,UAAUd,CAAS,EAAE;AACrD,eAAO,EAAE,GAAGgB,GAAa,GAAGE,EAAY;AAAA,MAC1C,GAAG,CAAA,CAAE;AACL,aAAO97B,EAAM,QAAQ,OAAO,EAAE,CAAC,UAAUu7B,EAAU,SAAS,EAAE,GAAGI,EAAU,IAAK,CAACA,CAAU,CAAC;AAAA,IAC9F;AAAA,EACF;AACA,SAAAT,EAAY,YAAYK,EAAU,WAC3BL;AACT;AAAA;ACtEA,SAAS51B,GAAWC,GAAW;AAC7B,QAAMC,IAA4BC,gBAAAA,GAAgBF,CAAS,GACrDG,IAAQ1F,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACtD,UAAM,EAAE,UAAA1B,GAAU,GAAG2B,EAAS,IAAK7F,GAC7B8F,IAAgB7F,EAAM,SAAS,QAAQiE,CAAQ,GAC/C6B,IAAYD,EAAc,KAAKE,EAAW;AAChD,QAAID,GAAW;AACb,YAAME,IAAaF,EAAU,MAAM,UAC7BG,IAAcJ,EAAc,IAAI,CAACK,MACjCA,MAAUJ,IACR9F,EAAM,SAAS,MAAMgG,CAAU,IAAI,IAAUhG,EAAM,SAAS,KAAK,IAAI,IAClEA,EAAM,eAAegG,CAAU,IAAIA,EAAW,MAAM,WAAW,OAE/DE,CAEV;AACD,aAAuB,gBAAA5B,EAAIkB,GAAW,EAAE,GAAGI,GAAW,KAAKD,GAAc,UAAU3F,EAAM,eAAegG,CAAU,IAAIhG,EAAM,aAAagG,GAAY,QAAQC,CAAW,IAAI,MAAM;AAAA,IACpL;AACA,WAAuB,gBAAA3B,EAAIkB,GAAW,EAAE,GAAGI,GAAW,KAAKD,GAAc,UAAA1B,GAAU;AAAA,EACrF,CAAC;AACD,SAAAyB,EAAM,cAAc,GAAGH,CAAS,SACzBG;AACT;AAAA;AAGA,SAASD,GAAgBF,GAAW;AAClC,QAAMC,IAAYxF,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AAC1D,UAAM,EAAE,UAAA1B,GAAU,GAAG2B,EAAS,IAAK7F;AACnC,QAAIC,EAAM,eAAeiE,CAAQ,GAAG;AAClC,YAAMmC,IAAcC,GAAcpC,CAAQ,GACpCqC,IAASC,GAAWX,GAAW3B,EAAS,KAAK;AACnD,aAAIA,EAAS,SAASjE,EAAM,aAC1BsG,EAAO,MAAMX,IAAelB,GAAYkB,GAAcS,CAAW,IAAIA,IAEhEpG,EAAM,aAAaiE,GAAUqC,CAAM;AAAA,IAC5C;AACA,WAAOtG,EAAM,SAAS,MAAMiE,CAAQ,IAAI,IAAIjE,EAAM,SAAS,KAAK,IAAI,IAAI;AAAA,EAC1E,CAAC;AACD,SAAAwF,EAAU,cAAc,GAAGD,CAAS,cAC7BC;AACT;AACA,IAAIgB,KAAuB,uBAAO,iBAAiB;AAWnD,SAAST,GAAYG,GAAO;AAC1B,SAAOlG,EAAM,eAAekG,CAAK,KAAK,OAAOA,EAAM,QAAS,cAAc,eAAeA,EAAM,QAAQA,EAAM,KAAK,cAAcM;AAClI;AACA,SAASD,GAAWX,GAAWa,GAAY;AACzC,QAAMC,IAAgB,EAAE,GAAGD,EAAU;AACrC,aAAWE,KAAYF,GAAY;AACjC,UAAMG,IAAgBhB,EAAUe,CAAQ,GAClCE,IAAiBJ,EAAWE,CAAQ;AAE1C,IADkB,WAAW,KAAKA,CAAQ,IAEpCC,KAAiBC,IACnBH,EAAcC,CAAQ,IAAI,IAAIG,MAAS;AACrC,YAAMC,IAASF,EAAe,GAAGC,CAAI;AACrC,aAAAF,EAAc,GAAGE,CAAI,GACdC;AAAA,IACT,IACSH,MACTF,EAAcC,CAAQ,IAAIC,KAEnBD,MAAa,UACtBD,EAAcC,CAAQ,IAAI,EAAE,GAAGC,GAAe,GAAGC,EAAc,IACtDF,MAAa,gBACtBD,EAAcC,CAAQ,IAAI,CAACC,GAAeC,CAAc,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAAA,EAEtF;AACA,SAAO,EAAE,GAAGjB,GAAW,GAAGc,EAAa;AACzC;AACA,SAASL,GAAchB,GAAS;AAC9B,MAAI2B,IAAS,OAAO,yBAAyB3B,EAAQ,OAAO,KAAK,GAAG,KAChE4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO;AAC7D,SAAIC,IACK5B,EAAQ,OAEjB2B,IAAS,OAAO,yBAAyB3B,GAAS,KAAK,GAAG,KAC1D4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO,gBACrDC,IACK5B,EAAQ,MAAM,MAEhBA,EAAQ,MAAM,OAAOA,EAAQ;AACtC;AC3FA,IAAI02B,KAAQ;AAAA,EACV;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GACIC,KAAYD,GAAM,OAAO,CAACE,GAAWt3B,MAAS;AAChD,QAAMwB,IAAOb,gBAAAA,GAAW,aAAaX,CAAI,EAAE,GACrCu3B,IAAOl8B,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACrD,UAAM,EAAE,SAAAyR,GAAS,GAAG+kB,EAAc,IAAKp8B,GACjCq8B,IAAOhlB,IAAUjR,IAAOxB;AAC9B,WAAI,OAAO,SAAW,QACpB,OAAO,uBAAO,IAAI,UAAU,CAAC,IAAI,KAEZ,gBAAAL,EAAI83B,GAAM,EAAE,GAAGD,GAAgB,KAAKx2B,GAAc;AAAA,EAC3E,CAAC;AACD,SAAAu2B,EAAK,cAAc,aAAav3B,CAAI,IAC7B,EAAE,GAAGs3B,GAAW,CAACt3B,CAAI,GAAGu3B,EAAI;AACrC,GAAG,EAAE;AACL,SAASG,GAA4B3R,GAAQF,GAAO;AAClD,EAAIE,KAAQ4R,GAAS,UAAU,MAAM5R,EAAO,cAAcF,CAAK,CAAC;AAClE;ACrCA,SAAS+R,GAAetN,GAAU;AAChC,QAAM7T,IAAcpb,EAAM,OAAOivB,CAAQ;AACzC,SAAAjvB,EAAM,UAAU,MAAM;AACpB,IAAAob,EAAY,UAAU6T;AAAA,EACxB,CAAC,GACMjvB,EAAM,QAAQ,MAAM,IAAI8G,MAASsU,EAAY,UAAU,GAAGtU,CAAI,GAAG,EAAE;AAC5E;ACLA,SAAS01B,GAAiBC,GAAqBC,IAAgB,YAAY,UAAU;AACnF,QAAMC,IAAkBJ,GAAeE,CAAmB;AAC1D,EAAAz8B,EAAM,UAAU,MAAM;AACpB,UAAM+2B,IAAgB,CAACvM,MAAU;AAC/B,MAAIA,EAAM,QAAQ,YAChBmS,EAAgBnS,CAAK;AAAA,IAEzB;AACA,WAAAkS,EAAc,iBAAiB,WAAW3F,GAAe,EAAE,SAAS,IAAM,GACnE,MAAM2F,EAAc,oBAAoB,WAAW3F,GAAe,EAAE,SAAS,IAAM;AAAA,EAC5F,GAAG,CAAC4F,GAAiBD,CAAa,CAAC;AACrC;ACJA,IAAIE,KAAyB,oBACzBC,KAAiB,2BACjBC,KAAuB,uCACvBC,KAAgB,iCAChBC,IACAC,KAA0Bj9B,EAAM,cAAc;AAAA,EAChD,QAAwB,oBAAI,IAAG;AAAA,EAC/B,wCAAwD,oBAAI,IAAG;AAAA,EAC/D,UAA0B,oBAAI,IAAG;AACnC,CAAC,GACGk9B,KAAmBl9B,EAAM;AAAA,EAC3B,CAACD,GAAO4F,MAAiB;AACvB,UAAM;AAAA,MACJ,6BAAAw3B,IAA8B;AAAA,MAC9B,iBAAAR;AAAA,MACA,sBAAAS;AAAA,MACA,gBAAAC;AAAA,MACA,mBAAAC;AAAA,MACA,WAAAC;AAAA,MACA,GAAGC;AAAA,IACT,IAAQz9B,GACEguB,IAAU/tB,EAAM,WAAWi9B,EAAuB,GAClD,CAACt4B,GAAM84B,CAAO,IAAIz9B,EAAM,SAAS,IAAI,GACrC08B,IAAgB/3B,GAAM,iBAAiB,YAAY,UACnD,CAAA,EAAG+4B,CAAK,IAAI19B,EAAM,SAAS,CAAA,CAAE,GAC7B29B,IAAe34B,GAAgBW,GAAc,CAACi4B,MAAUH,EAAQG,CAAK,CAAC,GACtEC,IAAS,MAAM,KAAK9P,EAAQ,MAAM,GAClC,CAAC+P,CAA4C,IAAI,CAAC,GAAG/P,EAAQ,sCAAsC,EAAE,MAAM,EAAE,GAC7GgQ,IAAoDF,EAAO,QAAQC,CAA4C,GAC/GrwB,IAAQ9I,IAAOk5B,EAAO,QAAQl5B,CAAI,IAAI,IACtCq5B,IAA8BjQ,EAAQ,uCAAuC,OAAO,GACpFkQ,IAAyBxwB,KAASswB,GAClCG,IAAqBC,GAAsB,CAAC3T,MAAU;AAC1D,YAAME,IAASF,EAAM,QACf4T,IAAwB,CAAC,GAAGrQ,EAAQ,QAAQ,EAAE,KAAK,CAACzO,MAAWA,EAAO,SAASoL,CAAM,CAAC;AAC5F,MAAI,CAACuT,KAA0BG,MAC/BhB,IAAuB5S,CAAK,GAC5B8S,IAAoB9S,CAAK,GACpBA,EAAM,oBAAkB+S,IAAS;AAAA,IACxC,GAAGb,CAAa,GACV2B,IAAeC,GAAgB,CAAC9T,MAAU;AAC9C,YAAME,IAASF,EAAM;AAErB,MADwB,CAAC,GAAGuD,EAAQ,QAAQ,EAAE,KAAK,CAACzO,MAAWA,EAAO,SAASoL,CAAM,CAAC,MAEtF2S,IAAiB7S,CAAK,GACtB8S,IAAoB9S,CAAK,GACpBA,EAAM,oBAAkB+S,IAAS;AAAA,IACxC,GAAGb,CAAa;AAChB,WAAAF,GAAiB,CAAChS,MAAU;AAE1B,MADuB/c,MAAUsgB,EAAQ,OAAO,OAAO,MAEvD4O,IAAkBnS,CAAK,GACnB,CAACA,EAAM,oBAAoB+S,MAC7B/S,EAAM,eAAc,GACpB+S,EAAS;AAAA,IAEb,GAAGb,CAAa,GAChB18B,EAAM,UAAU,MAAM;AACpB,UAAK2E;AACL,eAAIw4B,MACEpP,EAAQ,uCAAuC,SAAS,MAC1DiP,KAA4BN,EAAc,KAAK,MAAM,eACrDA,EAAc,KAAK,MAAM,gBAAgB,SAE3C3O,EAAQ,uCAAuC,IAAIppB,CAAI,IAEzDopB,EAAQ,OAAO,IAAIppB,CAAI,GACvB45B,GAAc,GACP,MAAM;AACX,UAAIpB,KAA+BpP,EAAQ,uCAAuC,SAAS,MACzF2O,EAAc,KAAK,MAAM,gBAAgBM;AAAA,QAE7C;AAAA,IACF,GAAG,CAACr4B,GAAM+3B,GAAeS,GAA6BpP,CAAO,CAAC,GAC9D/tB,EAAM,UAAU,MACP,MAAM;AACX,MAAK2E,MACLopB,EAAQ,OAAO,OAAOppB,CAAI,GAC1BopB,EAAQ,uCAAuC,OAAOppB,CAAI,GAC1D45B,GAAc;AAAA,IAChB,GACC,CAAC55B,GAAMopB,CAAO,CAAC,GAClB/tB,EAAM,UAAU,MAAM;AACpB,YAAMw+B,IAAe,MAAMd,EAAM,EAAE;AACnC,sBAAS,iBAAiBb,IAAgB2B,CAAY,GAC/C,MAAM,SAAS,oBAAoB3B,IAAgB2B,CAAY;AAAA,IACxE,GAAG,CAAA,CAAE,GACkB,gBAAAl6B;AAAA,MACrB03B,GAAU;AAAA,MACV;AAAA,QACE,GAAGwB;AAAA,QACH,KAAKG;AAAA,QACL,OAAO;AAAA,UACL,eAAeK,IAA8BC,IAAyB,SAAS,SAAS;AAAA,UACxF,GAAGl+B,EAAM;AAAA,QACnB;AAAA,QACQ,gBAAgBsvB,GAAqBtvB,EAAM,gBAAgBs+B,EAAa,cAAc;AAAA,QACtF,eAAehP,GAAqBtvB,EAAM,eAAes+B,EAAa,aAAa;AAAA,QACnF,sBAAsBhP;AAAA,UACpBtvB,EAAM;AAAA,UACNm+B,EAAmB;AAAA,QAC7B;AAAA,MACA;AAAA,IACA;AAAA,EACE;AACF;AACAhB,GAAiB,cAAcN;AAC/B,IAAI6B,KAAc,0BACdC,KAAyB1+B,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACrE,QAAMooB,IAAU/tB,EAAM,WAAWi9B,EAAuB,GAClDz4B,IAAMxE,EAAM,OAAO,IAAI,GACvB29B,IAAe34B,GAAgBW,GAAcnB,CAAG;AACtD,SAAAxE,EAAM,UAAU,MAAM;AACpB,UAAM2E,IAAOH,EAAI;AACjB,QAAIG;AACF,aAAAopB,EAAQ,SAAS,IAAIppB,CAAI,GAClB,MAAM;AACX,QAAAopB,EAAQ,SAAS,OAAOppB,CAAI;AAAA,MAC9B;AAAA,EAEJ,GAAG,CAACopB,EAAQ,QAAQ,CAAC,GACE,gBAAAzpB,EAAI03B,GAAU,KAAK,EAAE,GAAGj8B,GAAO,KAAK49B,GAAc;AAC3E,CAAC;AACDe,GAAuB,cAAcD;AACrC,SAASN,GAAsBf,GAAsBV,IAAgB,YAAY,UAAU;AACzF,QAAMiC,IAA2BpC,GAAea,CAAoB,GAC9DwB,IAA8B5+B,EAAM,OAAO,EAAK,GAChD6+B,IAAiB7+B,EAAM,OAAO,MAAM;AAAA,EAC1C,CAAC;AACD,SAAAA,EAAM,UAAU,MAAM;AACpB,UAAM8+B,IAAoB,CAACtU,MAAU;AACnC,UAAIA,EAAM,UAAU,CAACoU,EAA4B,SAAS;AACxD,YAAIG,IAA4C,WAAW;AACzD,UAAAC;AAAA,YACElC;AAAA,YACA6B;AAAA,YACAM;AAAA,YACA,EAAE,UAAU,GAAI;AAAA,UAC5B;AAAA,QACQ;AAEA,cAAMA,IAAc,EAAE,eAAezU,EAAK;AAC1C,QAAIA,EAAM,gBAAgB,WACxBkS,EAAc,oBAAoB,SAASmC,EAAe,OAAO,GACjEA,EAAe,UAAUE,GACzBrC,EAAc,iBAAiB,SAASmC,EAAe,SAAS,EAAE,MAAM,IAAM,KAE9EE,EAAyC;AAAA,MAE7C;AACE,QAAArC,EAAc,oBAAoB,SAASmC,EAAe,OAAO;AAEnE,MAAAD,EAA4B,UAAU;AAAA,IACxC,GACMM,IAAU,OAAO,WAAW,MAAM;AACtC,MAAAxC,EAAc,iBAAiB,eAAeoC,CAAiB;AAAA,IACjE,GAAG,CAAC;AACJ,WAAO,MAAM;AACX,aAAO,aAAaI,CAAO,GAC3BxC,EAAc,oBAAoB,eAAeoC,CAAiB,GAClEpC,EAAc,oBAAoB,SAASmC,EAAe,OAAO;AAAA,IACnE;AAAA,EACF,GAAG,CAACnC,GAAeiC,CAAwB,CAAC,GACrC;AAAA;AAAA,IAEL,sBAAsB,MAAMC,EAA4B,UAAU;AAAA,EACtE;AACA;AACA,SAASN,GAAgBjB,GAAgBX,IAAgB,YAAY,UAAU;AAC7E,QAAMyC,IAAqB5C,GAAec,CAAc,GAClD+B,IAA4Bp/B,EAAM,OAAO,EAAK;AACpD,SAAAA,EAAM,UAAU,MAAM;AACpB,UAAMq/B,IAAc,CAAC7U,MAAU;AAC7B,MAAIA,EAAM,UAAU,CAAC4U,EAA0B,WAE7CJ,GAA6BjC,IAAeoC,GADxB,EAAE,eAAe3U,EAAK,GACmC;AAAA,QAC3E,UAAU;AAAA,MACpB,CAAS;AAAA,IAEL;AACA,WAAAkS,EAAc,iBAAiB,WAAW2C,CAAW,GAC9C,MAAM3C,EAAc,oBAAoB,WAAW2C,CAAW;AAAA,EACvE,GAAG,CAAC3C,GAAeyC,CAAkB,CAAC,GAC/B;AAAA,IACL,gBAAgB,MAAMC,EAA0B,UAAU;AAAA,IAC1D,eAAe,MAAMA,EAA0B,UAAU;AAAA,EAC7D;AACA;AACA,SAASb,KAAiB;AACxB,QAAM/T,IAAQ,IAAI,YAAYqS,EAAc;AAC5C,WAAS,cAAcrS,CAAK;AAC9B;AACA,SAASwU,GAA6BzT,GAAM+T,GAASC,GAAQ,EAAE,UAAAC,EAAQ,GAAI;AACzE,QAAM9U,IAAS6U,EAAO,cAAc,QAC9B/U,IAAQ,IAAI,YAAYe,GAAM,EAAE,SAAS,IAAO,YAAY,IAAM,QAAAgU,GAAQ;AAChF,EAAID,KAAS5U,EAAO,iBAAiBa,GAAM+T,GAAS,EAAE,MAAM,IAAM,GAC9DE,IACFnD,GAA4B3R,GAAQF,CAAK,IAEzCE,EAAO,cAAcF,CAAK;AAE9B;ACjNA,IAAIiV,KAAmB,YAAY,WAAWz/B,EAAM,kBAAkB,MAAM;AAC5E,GCAI0/B,KAAa1/B,EAAM,UAAU,KAAI,EAAG,SAAQ,CAAE,MAAM,MAAA;AAAA,IACpD2/B,KAAQ;AACZ,SAASC,GAAMC,GAAiB;AAC9B,QAAM,CAAC/7B,GAAIg8B,CAAK,IAAI9/B,EAAM,SAAS0/B,IAAY;AAC/CrG,SAAAA,GAAgB,MAAM;AACE,IAAAyG,EAAM,CAACC,MAAYA,KAAW,OAAOJ,IAAO,CAAC;AAAA,EACrE,GAAG,CAACE,CAAe,CAAC,GACbA,MAAoB/7B,IAAK,SAASA,CAAE,KAAK;AAClD;ACNA,MAAMk8B,KAAQ,CAAC,OAAO,SAAS,UAAU,MAAM,GAGzCC,KAAM,KAAK,KACXC,KAAM,KAAK,KACXC,KAAQ,KAAK,OACbC,KAAQ,KAAK,OACbC,KAAe,CAAAzf,OAAM;AAAA,EACzB,GAAGA;AAAA,EACH,GAAGA;AACL,IACM0f,KAAkB;AAAA,EACtB,MAAM;AAAA,EACN,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,KAAK;AACP;AACA,SAASC,GAAMC,GAAO98B,GAAO+b,GAAK;AAChC,SAAOygB,GAAIM,GAAOP,GAAIv8B,GAAO+b,CAAG,CAAC;AACnC;AACA,SAASghB,GAAS/8B,GAAO2E,GAAO;AAC9B,SAAO,OAAO3E,KAAU,aAAaA,EAAM2E,CAAK,IAAI3E;AACtD;AACA,SAASg9B,GAAQvJ,GAAW;AAC1B,SAAOA,EAAU,MAAM,GAAG,EAAE,CAAC;AAC/B;AACA,SAASwJ,GAAaxJ,GAAW;AAC/B,SAAOA,EAAU,MAAM,GAAG,EAAE,CAAC;AAC/B;AACA,SAASyJ,GAAgBC,GAAM;AAC7B,SAAOA,MAAS,MAAM,MAAM;AAC9B;AACA,SAASC,GAAcD,GAAM;AAC3B,SAAOA,MAAS,MAAM,WAAW;AACnC;AACA,SAASE,GAAY5J,GAAW;AAC9B,QAAM6J,IAAY7J,EAAU,CAAC;AAC7B,SAAO6J,MAAc,OAAOA,MAAc,MAAM,MAAM;AACxD;AACA,SAASC,GAAiB9J,GAAW;AACnC,SAAOyJ,GAAgBG,GAAY5J,CAAS,CAAC;AAC/C;AACA,SAAS+J,GAAkB/J,GAAWgK,GAAOC,GAAK;AAChD,EAAIA,MAAQ,WACVA,IAAM;AAER,QAAMC,IAAYV,GAAaxJ,CAAS,GAClCmK,IAAgBL,GAAiB9J,CAAS,GAC1CoK,IAAST,GAAcQ,CAAa;AAC1C,MAAIE,IAAoBF,MAAkB,MAAMD,OAAeD,IAAM,QAAQ,WAAW,UAAU,SAASC,MAAc,UAAU,WAAW;AAC9I,SAAIF,EAAM,UAAUI,CAAM,IAAIJ,EAAM,SAASI,CAAM,MACjDC,IAAoBC,GAAqBD,CAAiB,IAErD,CAACA,GAAmBC,GAAqBD,CAAiB,CAAC;AACpE;AACA,SAASE,GAAsBvK,GAAW;AACxC,QAAMwK,IAAoBF,GAAqBtK,CAAS;AACxD,SAAO,CAACyK,GAA8BzK,CAAS,GAAGwK,GAAmBC,GAA8BD,CAAiB,CAAC;AACvH;AACA,SAASC,GAA8BzK,GAAW;AAChD,SAAOA,EAAU,SAAS,OAAO,IAAIA,EAAU,QAAQ,SAAS,KAAK,IAAIA,EAAU,QAAQ,OAAO,OAAO;AAC3G;AACA,MAAM0K,KAAc,CAAC,QAAQ,OAAO,GAC9BC,KAAc,CAAC,SAAS,MAAM,GAC9BC,KAAc,CAAC,OAAO,QAAQ,GAC9BC,KAAc,CAAC,UAAU,KAAK;AACpC,SAASC,GAAYC,GAAMC,GAASf,GAAK;AACvC,UAAQc,GAAI;AAAA,IACV,KAAK;AAAA,IACL,KAAK;AACH,aAAId,IAAYe,IAAUL,KAAcD,KACjCM,IAAUN,KAAcC;AAAA,IACjC,KAAK;AAAA,IACL,KAAK;AACH,aAAOK,IAAUJ,KAAcC;AAAA,IACjC;AACE,aAAO,CAAA;AAAA,EACb;AACA;AACA,SAASI,GAA0BjL,GAAWkL,GAAeC,GAAWlB,GAAK;AAC3E,QAAMC,IAAYV,GAAaxJ,CAAS;AACxC,MAAIoL,IAAON,GAAYvB,GAAQvJ,CAAS,GAAGmL,MAAc,SAASlB,CAAG;AACrE,SAAIC,MACFkB,IAAOA,EAAK,IAAI,CAAAL,MAAQA,IAAO,MAAMb,CAAS,GAC1CgB,MACFE,IAAOA,EAAK,OAAOA,EAAK,IAAIX,EAA6B,CAAC,KAGvDW;AACT;AACA,SAASd,GAAqBtK,GAAW;AACvC,QAAM+K,IAAOxB,GAAQvJ,CAAS;AAC9B,SAAOmJ,GAAgB4B,CAAI,IAAI/K,EAAU,MAAM+K,EAAK,MAAM;AAC5D;AACA,SAASM,GAAoBC,GAAS;AACpC,SAAO;AAAA,IACL,KAAK;AAAA,IACL,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,MAAM;AAAA,IACN,GAAGA;AAAA,EACP;AACA;AACA,SAASC,GAAiBD,GAAS;AACjC,SAAO,OAAOA,KAAY,WAAWD,GAAoBC,CAAO,IAAI;AAAA,IAClE,KAAKA;AAAA,IACL,OAAOA;AAAA,IACP,QAAQA;AAAA,IACR,MAAMA;AAAA,EACV;AACA;AACA,SAASE,GAAiBzL,GAAM;AAC9B,QAAM;AAAA,IACJ,GAAA0L;AAAA,IACA,GAAAC;AAAA,IACA,OAAAvqB;AAAA,IACA,QAAAH;AAAA,EACJ,IAAM+e;AACJ,SAAO;AAAA,IACL,OAAA5e;AAAA,IACA,QAAAH;AAAA,IACA,KAAK0qB;AAAA,IACL,MAAMD;AAAA,IACN,OAAOA,IAAItqB;AAAA,IACX,QAAQuqB,IAAI1qB;AAAA,IACZ,GAAAyqB;AAAA,IACA,GAAAC;AAAA,EACJ;AACA;AClIA,SAASC,GAA2BC,GAAM5L,GAAWiK,GAAK;AACxD,MAAI;AAAA,IACF,WAAA4B;AAAA,IACA,UAAAC;AAAA,EACJ,IAAMF;AACJ,QAAMG,IAAWnC,GAAY5J,CAAS,GAChCmK,IAAgBL,GAAiB9J,CAAS,GAC1CgM,IAAcrC,GAAcQ,CAAa,GACzCY,IAAOxB,GAAQvJ,CAAS,GACxBiM,IAAaF,MAAa,KAC1BG,IAAUL,EAAU,IAAIA,EAAU,QAAQ,IAAIC,EAAS,QAAQ,GAC/DK,IAAUN,EAAU,IAAIA,EAAU,SAAS,IAAIC,EAAS,SAAS,GACjEM,IAAcP,EAAUG,CAAW,IAAI,IAAIF,EAASE,CAAW,IAAI;AACzE,MAAIK;AACJ,UAAQtB,GAAI;AAAA,IACV,KAAK;AACH,MAAAsB,IAAS;AAAA,QACP,GAAGH;AAAA,QACH,GAAGL,EAAU,IAAIC,EAAS;AAAA,MAClC;AACM;AAAA,IACF,KAAK;AACH,MAAAO,IAAS;AAAA,QACP,GAAGH;AAAA,QACH,GAAGL,EAAU,IAAIA,EAAU;AAAA,MACnC;AACM;AAAA,IACF,KAAK;AACH,MAAAQ,IAAS;AAAA,QACP,GAAGR,EAAU,IAAIA,EAAU;AAAA,QAC3B,GAAGM;AAAA,MACX;AACM;AAAA,IACF,KAAK;AACH,MAAAE,IAAS;AAAA,QACP,GAAGR,EAAU,IAAIC,EAAS;AAAA,QAC1B,GAAGK;AAAA,MACX;AACM;AAAA,IACF;AACE,MAAAE,IAAS;AAAA,QACP,GAAGR,EAAU;AAAA,QACb,GAAGA,EAAU;AAAA,MACrB;AAAA,EACA;AACE,UAAQrC,GAAaxJ,CAAS,GAAC;AAAA,IAC7B,KAAK;AACH,MAAAqM,EAAOlC,CAAa,KAAKiC,KAAenC,KAAOgC,IAAa,KAAK;AACjE;AAAA,IACF,KAAK;AACH,MAAAI,EAAOlC,CAAa,KAAKiC,KAAenC,KAAOgC,IAAa,KAAK;AACjE;AAAA,EACN;AACE,SAAOI;AACT;AAUA,eAAeC,GAAenc,GAAOtB,GAAS;AAC5C,MAAI0d;AACJ,EAAI1d,MAAY,WACdA,IAAU,CAAA;AAEZ,QAAM;AAAA,IACJ,GAAA4c;AAAA,IACA,GAAAC;AAAA,IACA,UAAAc;AAAA,IACA,OAAAxC;AAAA,IACA,UAAAyC;AAAA,IACA,UAAAC;AAAA,EACJ,IAAMvc,GACE;AAAA,IACJ,UAAAwc,IAAW;AAAA,IACX,cAAAC,IAAe;AAAA,IACf,gBAAAC,IAAiB;AAAA,IACjB,aAAAC,IAAc;AAAA,IACd,SAAAxB,IAAU;AAAA,EACd,IAAMhC,GAASza,GAASsB,CAAK,GACrB4c,IAAgBxB,GAAiBD,CAAO,GAExCp9B,IAAUu+B,EAASK,IADND,MAAmB,aAAa,cAAc,aACbA,CAAc,GAC5DG,IAAqBxB,GAAiB,MAAMgB,EAAS,gBAAgB;AAAA,IACzE,UAAWD,IAAwB,OAAOC,EAAS,aAAa,OAAO,SAASA,EAAS,UAAUt+B,CAAO,OAAO,QAAOq+B,IAAgCr+B,IAAUA,EAAQ,kBAAmB,OAAOs+B,EAAS,sBAAsB,OAAO,SAASA,EAAS,mBAAmBC,EAAS,QAAQ;AAAA,IAChS,UAAAE;AAAA,IACA,cAAAC;AAAA,IACA,UAAAF;AAAA,EACJ,CAAG,CAAC,GACI3M,IAAO8M,MAAmB,aAAa;AAAA,IAC3C,GAAApB;AAAA,IACA,GAAAC;AAAA,IACA,OAAO1B,EAAM,SAAS;AAAA,IACtB,QAAQA,EAAM,SAAS;AAAA,EAC3B,IAAMA,EAAM,WACJiD,IAAe,OAAOT,EAAS,mBAAmB,OAAO,SAASA,EAAS,gBAAgBC,EAAS,QAAQ,IAC5GS,IAAe,OAAOV,EAAS,aAAa,OAAO,SAASA,EAAS,UAAUS,CAAY,KAAO,OAAOT,EAAS,YAAY,OAAO,SAASA,EAAS,SAASS,CAAY,MAAO;AAAA,IACvL,GAAG;AAAA,IACH,GAAG;AAAA,EACP,IAAM;AAAA,IACF,GAAG;AAAA,IACH,GAAG;AAAA,EACP,GACQE,IAAoB3B,GAAiBgB,EAAS,wDAAwD,MAAMA,EAAS,sDAAsD;AAAA,IAC/K,UAAAC;AAAA,IACA,MAAA1M;AAAA,IACA,cAAAkN;AAAA,IACA,UAAAP;AAAA,EACJ,CAAG,IAAI3M,CAAI;AACT,SAAO;AAAA,IACL,MAAMiN,EAAmB,MAAMG,EAAkB,MAAMJ,EAAc,OAAOG,EAAY;AAAA,IACxF,SAASC,EAAkB,SAASH,EAAmB,SAASD,EAAc,UAAUG,EAAY;AAAA,IACpG,OAAOF,EAAmB,OAAOG,EAAkB,OAAOJ,EAAc,QAAQG,EAAY;AAAA,IAC5F,QAAQC,EAAkB,QAAQH,EAAmB,QAAQD,EAAc,SAASG,EAAY;AAAA,EACpG;AACA;AAGA,MAAME,KAAkB,IASlBC,KAAkB,OAAOxB,GAAWC,GAAUv7B,MAAW;AAC7D,QAAM;AAAA,IACJ,WAAAyvB,IAAY;AAAA,IACZ,UAAA0M,IAAW;AAAA,IACX,YAAAY,IAAa,CAAA;AAAA,IACb,UAAAd;AAAA,EACJ,IAAMj8B,GACEg9B,IAA6Bf,EAAS,iBAAiBA,IAAW;AAAA,IACtE,GAAGA;AAAA,IACH,gBAAAF;AAAA,EACJ,GACQrC,IAAM,OAAOuC,EAAS,SAAS,OAAO,SAASA,EAAS,MAAMV,CAAQ;AAC5E,MAAI9B,IAAQ,MAAMwC,EAAS,gBAAgB;AAAA,IACzC,WAAAX;AAAA,IACA,UAAAC;AAAA,IACA,UAAAY;AAAA,EACJ,CAAG,GACG;AAAA,IACF,GAAAjB;AAAA,IACA,GAAAC;AAAA,EACJ,IAAMC,GAA2B3B,GAAOhK,GAAWiK,CAAG,GAChDuD,IAAoBxN,GACpByN,IAAa;AACjB,QAAMC,IAAiB,CAAA;AACvB,WAAS9/B,IAAI,GAAGA,IAAI0/B,EAAW,QAAQ1/B,KAAK;AAC1C,UAAM+/B,IAAoBL,EAAW1/B,CAAC;AACtC,QAAI,CAAC+/B;AACH;AAEF,UAAM;AAAA,MACJ,MAAAvZ;AAAA,MACA,IAAAwZ;AAAA,IACN,IAAQD,GACE;AAAA,MACJ,GAAGE;AAAA,MACH,GAAGC;AAAA,MACH,MAAA1qB;AAAA,MACA,OAAA2qB;AAAA,IACN,IAAQ,MAAMH,EAAG;AAAA,MACX,GAAAnC;AAAA,MACA,GAAAC;AAAA,MACA,kBAAkB1L;AAAA,MAClB,WAAWwN;AAAA,MACX,UAAAd;AAAA,MACA,gBAAAgB;AAAA,MACA,OAAA1D;AAAA,MACA,UAAUuD;AAAA,MACV,UAAU;AAAA,QACR,WAAA1B;AAAA,QACA,UAAAC;AAAA,MACR;AAAA,IACA,CAAK;AACD,IAAAL,IAAIoC,KAAwBpC,GAC5BC,IAAIoC,KAAwBpC,GAC5BgC,EAAetZ,CAAI,IAAI;AAAA,MACrB,GAAGsZ,EAAetZ,CAAI;AAAA,MACtB,GAAGhR;AAAA,IACT,GACQ2qB,KAASN,IAAaL,OACxBK,KACI,OAAOM,KAAU,aACfA,EAAM,cACRP,IAAoBO,EAAM,YAExBA,EAAM,UACR/D,IAAQ+D,EAAM,UAAU,KAAO,MAAMvB,EAAS,gBAAgB;AAAA,MAC5D,WAAAX;AAAA,MACA,UAAAC;AAAA,MACA,UAAAY;AAAA,IACZ,CAAW,IAAIqB,EAAM,QAEZ;AAAA,MACC,GAAAtC;AAAA,MACA,GAAAC;AAAA,IACV,IAAYC,GAA2B3B,GAAOwD,GAAmBvD,CAAG,IAE9Dr8B,IAAI;AAAA,EAER;AACA,SAAO;AAAA,IACL,GAAA69B;AAAA,IACA,GAAAC;AAAA,IACA,WAAW8B;AAAA,IACX,UAAAd;AAAA,IACA,gBAAAgB;AAAA,EACJ;AACA,GAOM5M,KAAQ,CAAAjS,OAAY;AAAA,EACxB,MAAM;AAAA,EACN,SAAAA;AAAA,EACA,MAAM,GAAGsB,GAAO;AACd,UAAM;AAAA,MACJ,GAAAsb;AAAA,MACA,GAAAC;AAAA,MACA,WAAA1L;AAAA,MACA,OAAAgK;AAAA,MACA,UAAAwC;AAAA,MACA,UAAAC;AAAA,MACA,gBAAAiB;AAAA,IACN,IAAQvd,GAEE;AAAA,MACJ,SAAAjiB;AAAA,MACA,SAAAo9B,IAAU;AAAA,IAChB,IAAQhC,GAASza,GAASsB,CAAK,KAAK,CAAA;AAChC,QAAIjiB,KAAW;AACb,aAAO,CAAA;AAET,UAAM6+B,IAAgBxB,GAAiBD,CAAO,GACxCe,IAAS;AAAA,MACb,GAAAZ;AAAA,MACA,GAAAC;AAAA,IACN,GACUhC,IAAOI,GAAiB9J,CAAS,GACjCoK,IAAST,GAAcD,CAAI,GAC3BsE,IAAkB,MAAMxB,EAAS,cAAct+B,CAAO,GACtD+/B,IAAUvE,MAAS,KACnBwE,IAAUD,IAAU,QAAQ,QAC5BE,IAAUF,IAAU,WAAW,SAC/BG,IAAaH,IAAU,iBAAiB,eACxCI,IAAUrE,EAAM,UAAUI,CAAM,IAAIJ,EAAM,UAAUN,CAAI,IAAI2C,EAAO3C,CAAI,IAAIM,EAAM,SAASI,CAAM,GAChGkE,IAAYjC,EAAO3C,CAAI,IAAIM,EAAM,UAAUN,CAAI,GAC/C6E,IAAoB,OAAO/B,EAAS,mBAAmB,OAAO,SAASA,EAAS,gBAAgBt+B,CAAO;AAC7G,QAAIsgC,IAAaD,IAAoBA,EAAkBH,CAAU,IAAI;AAGrE,KAAI,CAACI,KAAc,CAAE,OAAOhC,EAAS,aAAa,OAAO,SAASA,EAAS,UAAU+B,CAAiB,QACpGC,IAAa/B,EAAS,SAAS2B,CAAU,KAAKpE,EAAM,SAASI,CAAM;AAErE,UAAMqE,IAAoBJ,IAAU,IAAIC,IAAY,GAI9CI,IAAyBF,IAAa,IAAIR,EAAgB5D,CAAM,IAAI,IAAI,GACxEuE,IAAa7F,GAAIiE,EAAcmB,CAAO,GAAGQ,CAAsB,GAC/DE,IAAa9F,GAAIiE,EAAcoB,CAAO,GAAGO,CAAsB,GAI/DG,IAAQF,GACR5F,IAAMyF,IAAaR,EAAgB5D,CAAM,IAAIwE,GAC7CE,IAASN,IAAa,IAAIR,EAAgB5D,CAAM,IAAI,IAAIqE,GACxDzsB,IAASonB,GAAMyF,GAAOC,GAAQ/F,CAAG,GAMjCgG,IAAkB,CAACrB,EAAe,SAASlE,GAAaxJ,CAAS,KAAK,QAAQ8O,MAAW9sB,KAAUgoB,EAAM,UAAUI,CAAM,IAAI,KAAK0E,IAASD,IAAQF,IAAaC,KAAcZ,EAAgB5D,CAAM,IAAI,IAAI,GAC5M4E,IAAkBD,IAAkBD,IAASD,IAAQC,IAASD,IAAQC,IAAS/F,IAAM;AAC3F,WAAO;AAAA,MACL,CAACW,CAAI,GAAG2C,EAAO3C,CAAI,IAAIsF;AAAA,MACvB,MAAM;AAAA,QACJ,CAACtF,CAAI,GAAG1nB;AAAA,QACR,cAAc8sB,IAAS9sB,IAASgtB;AAAA,QAChC,GAAID,KAAmB;AAAA,UACrB,iBAAAC;AAAA,QACV;AAAA,MACA;AAAA,MACM,OAAOD;AAAA,IACb;AAAA,EACE;AACF,IA+GME,KAAO,SAAUpgB,GAAS;AAC9B,SAAIA,MAAY,WACdA,IAAU,CAAA,IAEL;AAAA,IACL,MAAM;AAAA,IACN,SAAAA;AAAA,IACA,MAAM,GAAGsB,GAAO;AACd,UAAI+e,GAAuBC;AAC3B,YAAM;AAAA,QACJ,WAAAnP;AAAA,QACA,gBAAA0N;AAAA,QACA,OAAA1D;AAAA,QACA,kBAAAoF;AAAA,QACA,UAAA5C;AAAA,QACA,UAAAC;AAAA,MACR,IAAUtc,GACE;AAAA,QACJ,UAAUkf,IAAgB;AAAA,QAC1B,WAAWC,IAAiB;AAAA,QAC5B,oBAAoBC;AAAA,QACpB,kBAAAC,IAAmB;AAAA,QACnB,2BAAAC,IAA4B;AAAA,QAC5B,eAAAvE,IAAgB;AAAA,QAChB,GAAGwE;AAAA,MACX,IAAUpG,GAASza,GAASsB,CAAK;AAM3B,WAAK+e,IAAwBxB,EAAe,UAAU,QAAQwB,EAAsB;AAClF,eAAO,CAAA;AAET,YAAMnE,IAAOxB,GAAQvJ,CAAS,GACxB2P,IAAkB/F,GAAYwF,CAAgB,GAC9CQ,IAAkBrG,GAAQ6F,CAAgB,MAAMA,GAChDnF,IAAM,OAAOuC,EAAS,SAAS,OAAO,SAASA,EAAS,MAAMC,EAAS,QAAQ,IAC/EoD,IAAqBN,MAAgCK,KAAmB,CAAC1E,IAAgB,CAACZ,GAAqB8E,CAAgB,CAAC,IAAI7E,GAAsB6E,CAAgB,IAC1KU,IAA+BL,MAA8B;AACnE,MAAI,CAACF,KAA+BO,KAClCD,EAAmB,KAAK,GAAG5E,GAA0BmE,GAAkBlE,GAAeuE,GAA2BxF,CAAG,CAAC;AAEvH,YAAM8F,IAAa,CAACX,GAAkB,GAAGS,CAAkB,GACrD5sB,IAAW,MAAMupB,EAAS,eAAerc,GAAOuf,CAAqB,GACrEM,IAAY,CAAA;AAClB,UAAIC,MAAkBd,IAAuBzB,EAAe,SAAS,OAAO,SAASyB,EAAqB,cAAc,CAAA;AAIxH,UAHIE,KACFW,EAAU,KAAK/sB,EAAS8nB,CAAI,CAAC,GAE3BuE,GAAgB;AAClB,cAAMzG,IAAQkB,GAAkB/J,GAAWgK,GAAOC,CAAG;AACrD,QAAA+F,EAAU,KAAK/sB,EAAS4lB,EAAM,CAAC,CAAC,GAAG5lB,EAAS4lB,EAAM,CAAC,CAAC,CAAC;AAAA,MACvD;AAOA,UANAoH,IAAgB,CAAC,GAAGA,GAAe;AAAA,QACjC,WAAAjQ;AAAA,QACA,WAAAgQ;AAAA,MACR,CAAO,GAGG,CAACA,EAAU,MAAM,CAAAjF,MAAQA,KAAQ,CAAC,GAAG;AACvC,YAAImF,GAAuBC;AAC3B,cAAMC,OAAeF,IAAwBxC,EAAe,SAAS,OAAO,SAASwC,EAAsB,UAAU,KAAK,GACpHG,IAAgBN,EAAWK,CAAS;AAC1C,YAAIC,MAEE,EAD4Bf,MAAmB,cAAcK,MAAoB/F,GAAYyG,CAAa,IAAI;AAAA;AAAA,QAIlHJ,EAAc,MAAM,CAAAK,MAAK1G,GAAY0G,EAAE,SAAS,MAAMX,IAAkBW,EAAE,UAAU,CAAC,IAAI,IAAI,EAAI;AAE/F,iBAAO;AAAA,YACL,MAAM;AAAA,cACJ,OAAOF;AAAA,cACP,WAAWH;AAAA,YAC3B;AAAA,YACc,OAAO;AAAA,cACL,WAAWI;AAAA,YAC3B;AAAA,UACA;AAMQ,YAAIE,KAAkBJ,IAAwBF,EAAc,OAAO,CAAAK,MAAKA,EAAE,UAAU,CAAC,KAAK,CAAC,EAAE,KAAK,CAACjpB,GAAGC,MAAMD,EAAE,UAAU,CAAC,IAAIC,EAAE,UAAU,CAAC,CAAC,EAAE,CAAC,MAAM,OAAO,SAAS6oB,EAAsB;AAG1L,YAAI,CAACI;AACH,kBAAQf,GAAgB;AAAA,YACtB,KAAK,WACH;AACE,kBAAIgB;AACJ,oBAAMxQ,KAAawQ,IAAyBP,EAAc,OAAO,CAAAK,MAAK;AACpE,oBAAIR,GAA8B;AAChC,wBAAMW,IAAkB7G,GAAY0G,EAAE,SAAS;AAC/C,yBAAOG,MAAoBd;AAAA;AAAA,kBAG3Bc,MAAoB;AAAA,gBACtB;AACA,uBAAO;AAAA,cACT,CAAC,EAAE,IAAI,CAAAH,MAAK,CAACA,EAAE,WAAWA,EAAE,UAAU,OAAO,CAAArtB,MAAYA,IAAW,CAAC,EAAE,OAAO,CAAChS,GAAKgS,MAAahS,IAAMgS,GAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAACoE,GAAGC,MAAMD,EAAE,CAAC,IAAIC,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,OAAO,SAASkpB,EAAuB,CAAC;AACjM,cAAIxQ,MACFuQ,IAAiBvQ;AAEnB;AAAA,YACF;AAAA,YACF,KAAK;AACH,cAAAuQ,IAAiBnB;AACjB;AAAA,UACd;AAEQ,YAAIpP,MAAcuQ;AAChB,iBAAO;AAAA,YACL,OAAO;AAAA,cACL,WAAWA;AAAA,YACzB;AAAA,UACA;AAAA,MAEM;AACA,aAAO,CAAA;AAAA,IACT;AAAA,EACJ;AACA;AAEA,SAASG,GAAeztB,GAAU8c,GAAM;AACtC,SAAO;AAAA,IACL,KAAK9c,EAAS,MAAM8c,EAAK;AAAA,IACzB,OAAO9c,EAAS,QAAQ8c,EAAK;AAAA,IAC7B,QAAQ9c,EAAS,SAAS8c,EAAK;AAAA,IAC/B,MAAM9c,EAAS,OAAO8c,EAAK;AAAA,EAC/B;AACA;AACA,SAAS4Q,GAAsB1tB,GAAU;AACvC,SAAO4lB,GAAM,KAAK,CAAAkC,MAAQ9nB,EAAS8nB,CAAI,KAAK,CAAC;AAC/C;AAMA,MAAM6F,KAAO,SAAU/hB,GAAS;AAC9B,SAAIA,MAAY,WACdA,IAAU,CAAA,IAEL;AAAA,IACL,MAAM;AAAA,IACN,SAAAA;AAAA,IACA,MAAM,GAAGsB,GAAO;AACd,YAAM;AAAA,QACJ,OAAA6Z;AAAA,QACA,UAAAwC;AAAA,MACR,IAAUrc,GACE;AAAA,QACJ,UAAAuc,IAAW;AAAA,QACX,GAAGgD;AAAA,MACX,IAAUpG,GAASza,GAASsB,CAAK;AAC3B,cAAQuc,GAAQ;AAAA,QACd,KAAK,mBACH;AACE,gBAAMzpB,IAAW,MAAMupB,EAAS,eAAerc,GAAO;AAAA,YACpD,GAAGuf;AAAA,YACH,gBAAgB;AAAA,UAC9B,CAAa,GACKmB,IAAUH,GAAeztB,GAAU+mB,EAAM,SAAS;AACxD,iBAAO;AAAA,YACL,MAAM;AAAA,cACJ,wBAAwB6G;AAAA,cACxB,iBAAiBF,GAAsBE,CAAO;AAAA,YAC9D;AAAA,UACA;AAAA,QACU;AAAA,QACF,KAAK,WACH;AACE,gBAAM5tB,IAAW,MAAMupB,EAAS,eAAerc,GAAO;AAAA,YACpD,GAAGuf;AAAA,YACH,aAAa;AAAA,UAC3B,CAAa,GACKmB,IAAUH,GAAeztB,GAAU+mB,EAAM,QAAQ;AACvD,iBAAO;AAAA,YACL,MAAM;AAAA,cACJ,gBAAgB6G;AAAA,cAChB,SAASF,GAAsBE,CAAO;AAAA,YACtD;AAAA,UACA;AAAA,QACU;AAAA,QACF;AAEI,iBAAO,CAAA;AAAA,MAEnB;AAAA,IACI;AAAA,EACJ;AACA,GAqIMC,KAA2B,oBAAI,IAAI,CAAC,QAAQ,KAAK,CAAC;AAKxD,eAAeC,GAAqB5gB,GAAOtB,GAAS;AAClD,QAAM;AAAA,IACJ,WAAAmR;AAAA,IACA,UAAAwM;AAAA,IACA,UAAAC;AAAA,EACJ,IAAMtc,GACE8Z,IAAM,OAAOuC,EAAS,SAAS,OAAO,SAASA,EAAS,MAAMC,EAAS,QAAQ,IAC/E1B,IAAOxB,GAAQvJ,CAAS,GACxBkK,IAAYV,GAAaxJ,CAAS,GAClCiM,IAAarC,GAAY5J,CAAS,MAAM,KACxCgR,IAAgBF,GAAY,IAAI/F,CAAI,IAAI,KAAK,GAC7CkG,IAAiBhH,KAAOgC,IAAa,KAAK,GAC1CiF,IAAW5H,GAASza,GAASsB,CAAK;AAGxC,MAAI;AAAA,IACF,UAAAghB;AAAA,IACA,WAAAC;AAAA,IACA,eAAAjH;AAAA,EACJ,IAAM,OAAO+G,KAAa,WAAW;AAAA,IACjC,UAAUA;AAAA,IACV,WAAW;AAAA,IACX,eAAe;AAAA,EACnB,IAAM;AAAA,IACF,UAAUA,EAAS,YAAY;AAAA,IAC/B,WAAWA,EAAS,aAAa;AAAA,IACjC,eAAeA,EAAS;AAAA,EAC5B;AACE,SAAIhH,KAAa,OAAOC,KAAkB,aACxCiH,IAAYlH,MAAc,QAAQC,IAAgB,KAAKA,IAElD8B,IAAa;AAAA,IAClB,GAAGmF,IAAYH;AAAA,IACf,GAAGE,IAAWH;AAAA,EAClB,IAAM;AAAA,IACF,GAAGG,IAAWH;AAAA,IACd,GAAGI,IAAYH;AAAA,EACnB;AACA;AASA,MAAMjvB,KAAS,SAAU6M,GAAS;AAChC,SAAIA,MAAY,WACdA,IAAU,IAEL;AAAA,IACL,MAAM;AAAA,IACN,SAAAA;AAAA,IACA,MAAM,GAAGsB,GAAO;AACd,UAAIkhB,GAAuBnC;AAC3B,YAAM;AAAA,QACJ,GAAAzD;AAAA,QACA,GAAAC;AAAA,QACA,WAAA1L;AAAA,QACA,gBAAA0N;AAAA,MACR,IAAUvd,GACEmhB,IAAa,MAAMP,GAAqB5gB,GAAOtB,CAAO;AAI5D,aAAImR,QAAgBqR,IAAwB3D,EAAe,WAAW,OAAO,SAAS2D,EAAsB,eAAenC,IAAwBxB,EAAe,UAAU,QAAQwB,EAAsB,kBACjM,CAAA,IAEF;AAAA,QACL,GAAGzD,IAAI6F,EAAW;AAAA,QAClB,GAAG5F,IAAI4F,EAAW;AAAA,QAClB,MAAM;AAAA,UACJ,GAAGA;AAAA,UACH,WAAAtR;AAAA,QACV;AAAA,MACA;AAAA,IACI;AAAA,EACJ;AACA,GAOMuR,KAAQ,SAAU1iB,GAAS;AAC/B,SAAIA,MAAY,WACdA,IAAU,CAAA,IAEL;AAAA,IACL,MAAM;AAAA,IACN,SAAAA;AAAA,IACA,MAAM,GAAGsB,GAAO;AACd,YAAM;AAAA,QACJ,GAAAsb;AAAA,QACA,GAAAC;AAAA,QACA,WAAA1L;AAAA,QACA,UAAAwM;AAAA,MACR,IAAUrc,GACE;AAAA,QACJ,UAAUkf,IAAgB;AAAA,QAC1B,WAAWC,IAAiB;AAAA,QAC5B,SAAAkC,IAAU;AAAA,UACR,IAAI,CAAA5F,MAAQ;AACV,gBAAI;AAAA,cACF,GAAAH;AAAA,cACA;AAAA,YACd,IAAgBG;AACJ,mBAAO;AAAA,cACL,GAAAH;AAAA,cACA;AAAA,YACd;AAAA,UACU;AAAA,QACV;AAAA,QACQ,GAAGiE;AAAA,MACX,IAAUpG,GAASza,GAASsB,CAAK,GACrBkc,IAAS;AAAA,QACb,GAAAZ;AAAA,QACA,GAAAC;AAAA,MACR,GACYzoB,IAAW,MAAMupB,EAAS,eAAerc,GAAOuf,CAAqB,GACrE0B,IAAYxH,GAAYL,GAAQvJ,CAAS,CAAC,GAC1CmR,IAAW1H,GAAgB2H,CAAS;AAC1C,UAAIK,IAAgBpF,EAAO8E,CAAQ,GAC/BO,IAAiBrF,EAAO+E,CAAS;AACrC,UAAI/B,GAAe;AACjB,cAAMsC,IAAUR,MAAa,MAAM,QAAQ,QACrCS,IAAUT,MAAa,MAAM,WAAW,SACxCrI,IAAM2I,IAAgBxuB,EAAS0uB,CAAO,GACtC5I,IAAM0I,IAAgBxuB,EAAS2uB,CAAO;AAC5C,QAAAH,IAAgBrI,GAAMN,GAAK2I,GAAe1I,CAAG;AAAA,MAC/C;AACA,UAAIuG,GAAgB;AAClB,cAAMqC,IAAUP,MAAc,MAAM,QAAQ,QACtCQ,IAAUR,MAAc,MAAM,WAAW,SACzCtI,IAAM4I,IAAiBzuB,EAAS0uB,CAAO,GACvC5I,IAAM2I,IAAiBzuB,EAAS2uB,CAAO;AAC7C,QAAAF,IAAiBtI,GAAMN,GAAK4I,GAAgB3I,CAAG;AAAA,MACjD;AACA,YAAM8I,IAAgBL,EAAQ,GAAG;AAAA,QAC/B,GAAGrhB;AAAA,QACH,CAACghB,CAAQ,GAAGM;AAAA,QACZ,CAACL,CAAS,GAAGM;AAAA,MACrB,CAAO;AACD,aAAO;AAAA,QACL,GAAGG;AAAA,QACH,MAAM;AAAA,UACJ,GAAGA,EAAc,IAAIpG;AAAA,UACrB,GAAGoG,EAAc,IAAInG;AAAA,UACrB,SAAS;AAAA,YACP,CAACyF,CAAQ,GAAG9B;AAAA,YACZ,CAAC+B,CAAS,GAAG9B;AAAA,UACzB;AAAA,QACA;AAAA,MACA;AAAA,IACI;AAAA,EACJ;AACA,GAIMwC,KAAa,SAAUjjB,GAAS;AACpC,SAAIA,MAAY,WACdA,IAAU,CAAA,IAEL;AAAA,IACL,SAAAA;AAAA,IACA,GAAGsB,GAAO;AACR,YAAM;AAAA,QACJ,GAAAsb;AAAA,QACA,GAAAC;AAAA,QACA,WAAA1L;AAAA,QACA,OAAAgK;AAAA,QACA,gBAAA0D;AAAA,MACR,IAAUvd,GACE;AAAA,QACJ,QAAAnO,IAAS;AAAA,QACT,UAAUqtB,IAAgB;AAAA,QAC1B,WAAWC,IAAiB;AAAA,MACpC,IAAUhG,GAASza,GAASsB,CAAK,GACrBkc,IAAS;AAAA,QACb,GAAAZ;AAAA,QACA,GAAAC;AAAA,MACR,GACY0F,IAAYxH,GAAY5J,CAAS,GACjCmR,IAAW1H,GAAgB2H,CAAS;AAC1C,UAAIK,IAAgBpF,EAAO8E,CAAQ,GAC/BO,IAAiBrF,EAAO+E,CAAS;AACrC,YAAMW,IAAYzI,GAAStnB,GAAQmO,CAAK,GAClC6hB,IAAiB,OAAOD,KAAc,WAAW;AAAA,QACrD,UAAUA;AAAA,QACV,WAAW;AAAA,MACnB,IAAU;AAAA,QACF,UAAU;AAAA,QACV,WAAW;AAAA,QACX,GAAGA;AAAA,MACX;AACM,UAAI1C,GAAe;AACjB,cAAMt7B,IAAMo9B,MAAa,MAAM,WAAW,SACpCc,IAAWjI,EAAM,UAAUmH,CAAQ,IAAInH,EAAM,SAASj2B,CAAG,IAAIi+B,EAAe,UAC5EE,IAAWlI,EAAM,UAAUmH,CAAQ,IAAInH,EAAM,UAAUj2B,CAAG,IAAIi+B,EAAe;AACnF,QAAIP,IAAgBQ,IAClBR,IAAgBQ,IACPR,IAAgBS,MACzBT,IAAgBS;AAAA,MAEpB;AACA,UAAI5C,GAAgB;AAClB,YAAI+B,GAAuBc;AAC3B,cAAMp+B,IAAMo9B,MAAa,MAAM,UAAU,UACnCiB,IAAetB,GAAY,IAAIvH,GAAQvJ,CAAS,CAAC,GACjDiS,IAAWjI,EAAM,UAAUoH,CAAS,IAAIpH,EAAM,SAASj2B,CAAG,KAAKq+B,OAAiBf,IAAwB3D,EAAe,WAAW,OAAO,SAAS2D,EAAsBD,CAAS,MAAM,MAAUgB,IAAe,IAAIJ,EAAe,YACnOE,IAAWlI,EAAM,UAAUoH,CAAS,IAAIpH,EAAM,UAAUj2B,CAAG,KAAKq+B,IAAe,MAAMD,IAAyBzE,EAAe,WAAW,OAAO,SAASyE,EAAuBf,CAAS,MAAM,MAAMgB,IAAeJ,EAAe,YAAY;AACpP,QAAIN,IAAiBO,IACnBP,IAAiBO,IACRP,IAAiBQ,MAC1BR,IAAiBQ;AAAA,MAErB;AACA,aAAO;AAAA,QACL,CAACf,CAAQ,GAAGM;AAAA,QACZ,CAACL,CAAS,GAAGM;AAAA,MACrB;AAAA,IACI;AAAA,EACJ;AACA,GAQM1xB,KAAO,SAAU6O,GAAS;AAC9B,SAAIA,MAAY,WACdA,IAAU,CAAA,IAEL;AAAA,IACL,MAAM;AAAA,IACN,SAAAA;AAAA,IACA,MAAM,GAAGsB,GAAO;AACd,UAAIkiB,GAAuBC;AAC3B,YAAM;AAAA,QACJ,WAAAtS;AAAA,QACA,OAAAgK;AAAA,QACA,UAAAwC;AAAA,QACA,UAAAC;AAAA,MACR,IAAUtc,GACE;AAAA,QACJ,OAAAoiB,IAAQ,MAAM;AAAA,QAAC;AAAA,QACf,GAAG7C;AAAA,MACX,IAAUpG,GAASza,GAASsB,CAAK,GACrBlN,IAAW,MAAMupB,EAAS,eAAerc,GAAOuf,CAAqB,GACrE3E,IAAOxB,GAAQvJ,CAAS,GACxBkK,IAAYV,GAAaxJ,CAAS,GAClCiO,IAAUrE,GAAY5J,CAAS,MAAM,KACrC;AAAA,QACJ,OAAA7e;AAAA,QACA,QAAAH;AAAA,MACR,IAAUgpB,EAAM;AACV,UAAIwI,GACAC;AACJ,MAAI1H,MAAS,SAASA,MAAS,YAC7ByH,IAAazH,GACb0H,IAAYvI,OAAgB,OAAOsC,EAAS,SAAS,OAAO,SAASA,EAAS,MAAMC,EAAS,QAAQ,KAAM,UAAU,SAAS,SAAS,YAEvIgG,IAAY1H,GACZyH,IAAatI,MAAc,QAAQ,QAAQ;AAE7C,YAAMwI,IAAwB1xB,IAASiC,EAAS,MAAMA,EAAS,QACzD0vB,IAAuBxxB,IAAQ8B,EAAS,OAAOA,EAAS,OACxD2vB,IAA0B9J,GAAI9nB,IAASiC,EAASuvB,CAAU,GAAGE,CAAqB,GAClFG,IAAyB/J,GAAI3nB,IAAQ8B,EAASwvB,CAAS,GAAGE,CAAoB,GAC9EG,IAAU,CAAC3iB,EAAM,eAAe;AACtC,UAAI4iB,IAAkBH,GAClBI,IAAiBH;AAOrB,WANKR,IAAwBliB,EAAM,eAAe,UAAU,QAAQkiB,EAAsB,QAAQ,MAChGW,IAAiBL,KAEdL,IAAyBniB,EAAM,eAAe,UAAU,QAAQmiB,EAAuB,QAAQ,MAClGS,IAAkBL,IAEhBI,KAAW,CAAC5I,GAAW;AACzB,cAAM+I,IAAOlK,GAAI9lB,EAAS,MAAM,CAAC,GAC3BiwB,IAAOnK,GAAI9lB,EAAS,OAAO,CAAC,GAC5BkwB,IAAOpK,GAAI9lB,EAAS,KAAK,CAAC,GAC1BmwB,IAAOrK,GAAI9lB,EAAS,QAAQ,CAAC;AACnC,QAAIgrB,IACF+E,IAAiB7xB,IAAQ,KAAK8xB,MAAS,KAAKC,MAAS,IAAID,IAAOC,IAAOnK,GAAI9lB,EAAS,MAAMA,EAAS,KAAK,KAExG8vB,IAAkB/xB,IAAS,KAAKmyB,MAAS,KAAKC,MAAS,IAAID,IAAOC,IAAOrK,GAAI9lB,EAAS,KAAKA,EAAS,MAAM;AAAA,MAE9G;AACA,YAAMsvB,EAAM;AAAA,QACV,GAAGpiB;AAAA,QACH,gBAAA6iB;AAAA,QACA,iBAAAD;AAAA,MACR,CAAO;AACD,YAAMM,IAAiB,MAAM7G,EAAS,cAAcC,EAAS,QAAQ;AACrE,aAAItrB,MAAUkyB,EAAe,SAASryB,MAAWqyB,EAAe,SACvD;AAAA,QACL,OAAO;AAAA,UACL,OAAO;AAAA,QACnB;AAAA,MACA,IAEa,CAAA;AAAA,IACT;AAAA,EACJ;AACA;AC/hCA,SAASC,KAAY;AACnB,SAAO,OAAO,SAAW;AAC3B;AACA,SAASC,GAAY/lC,GAAM;AACzB,SAAIgmC,GAAOhmC,CAAI,KACLA,EAAK,YAAY,IAAI,YAAW,IAKnC;AACT;AACA,SAASimC,GAAUjmC,GAAM;AACvB,MAAIkmC;AACJ,UAAQlmC,KAAQ,SAASkmC,IAAsBlmC,EAAK,kBAAkB,OAAO,SAASkmC,EAAoB,gBAAgB;AAC5H;AACA,SAASC,GAAmBnmC,GAAM;AAChC,MAAIo+B;AACJ,UAAQA,KAAQ4H,GAAOhmC,CAAI,IAAIA,EAAK,gBAAgBA,EAAK,aAAa,OAAO,aAAa,OAAO,SAASo+B,EAAK;AACjH;AACA,SAAS4H,GAAOjnC,GAAO;AACrB,SAAK+mC,GAAS,IAGP/mC,aAAiB,QAAQA,aAAiBknC,GAAUlnC,CAAK,EAAE,OAFzD;AAGX;AACA,SAASqnC,GAAUrnC,GAAO;AACxB,SAAK+mC,GAAS,IAGP/mC,aAAiB,WAAWA,aAAiBknC,GAAUlnC,CAAK,EAAE,UAF5D;AAGX;AACA,SAASsnC,GAActnC,GAAO;AAC5B,SAAK+mC,GAAS,IAGP/mC,aAAiB,eAAeA,aAAiBknC,GAAUlnC,CAAK,EAAE,cAFhE;AAGX;AACA,SAASunC,GAAavnC,GAAO;AAC3B,SAAI,CAAC+mC,GAAS,KAAM,OAAO,aAAe,MACjC,KAEF/mC,aAAiB,cAAcA,aAAiBknC,GAAUlnC,CAAK,EAAE;AAC1E;AACA,SAASwnC,GAAkB7lC,GAAS;AAClC,QAAM;AAAA,IACJ,UAAA+U;AAAA,IACA,WAAA+wB;AAAA,IACA,WAAAC;AAAA,IACA,SAAAC;AAAA,EACJ,IAAMC,GAAiBjmC,CAAO;AAC5B,SAAO,kCAAkC,KAAK+U,IAAWgxB,IAAYD,CAAS,KAAKE,MAAY,YAAYA,MAAY;AACzH;AACA,SAASE,GAAelmC,GAAS;AAC/B,SAAO,kBAAkB,KAAKqlC,GAAYrlC,CAAO,CAAC;AACpD;AACA,SAASmmC,GAAWnmC,GAAS;AAC3B,MAAI;AACF,QAAIA,EAAQ,QAAQ,eAAe;AACjC,aAAO;AAAA,EAEX,QAAa;AAAA,EAEb;AACA,MAAI;AACF,WAAOA,EAAQ,QAAQ,QAAQ;AAAA,EACjC,QAAa;AACX,WAAO;AAAA,EACT;AACF;AACA,MAAMomC,KAAe,uDACfC,KAAY,+BACZC,KAAY,CAAAjoC,MAAS,CAAC,CAACA,KAASA,MAAU;AAChD,IAAIkoC;AACJ,SAASC,GAAkBC,GAAc;AACvC,QAAMznC,IAAM0mC,GAAUe,CAAY,IAAIR,GAAiBQ,CAAY,IAAIA;AAIvE,SAAOH,GAAUtnC,EAAI,SAAS,KAAKsnC,GAAUtnC,EAAI,SAAS,KAAKsnC,GAAUtnC,EAAI,KAAK,KAAKsnC,GAAUtnC,EAAI,MAAM,KAAKsnC,GAAUtnC,EAAI,WAAW,KAAK,CAAC0nC,GAAQ,MAAOJ,GAAUtnC,EAAI,cAAc,KAAKsnC,GAAUtnC,EAAI,MAAM,MAAMonC,GAAa,KAAKpnC,EAAI,cAAc,EAAE,KAAKqnC,GAAU,KAAKrnC,EAAI,WAAW,EAAE;AACtS;AACA,SAAS2nC,GAAmB3mC,GAAS;AACnC,MAAI4mC,IAAcC,GAAc7mC,CAAO;AACvC,SAAO2lC,GAAciB,CAAW,KAAK,CAACE,GAAsBF,CAAW,KAAG;AACxE,QAAIJ,GAAkBI,CAAW;AAC/B,aAAOA;AACF,QAAIT,GAAWS,CAAW;AAC/B,aAAO;AAET,IAAAA,IAAcC,GAAcD,CAAW;AAAA,EACzC;AACA,SAAO;AACT;AACA,SAASF,KAAW;AAClB,SAAIH,MAAiB,SACnBA,KAAgB,OAAO,MAAQ,OAAe,IAAI,YAAY,IAAI,SAAS,2BAA2B,MAAM,IAEvGA;AACT;AACA,SAASO,GAAsBxnC,GAAM;AACnC,SAAO,0BAA0B,KAAK+lC,GAAY/lC,CAAI,CAAC;AACzD;AACA,SAAS2mC,GAAiBjmC,GAAS;AACjC,SAAOulC,GAAUvlC,CAAO,EAAE,iBAAiBA,CAAO;AACpD;AACA,SAAS+mC,GAAc/mC,GAAS;AAC9B,SAAI0lC,GAAU1lC,CAAO,IACZ;AAAA,IACL,YAAYA,EAAQ;AAAA,IACpB,WAAWA,EAAQ;AAAA,EACzB,IAES;AAAA,IACL,YAAYA,EAAQ;AAAA,IACpB,WAAWA,EAAQ;AAAA,EACvB;AACA;AACA,SAAS6mC,GAAcvnC,GAAM;AAC3B,MAAI+lC,GAAY/lC,CAAI,MAAM;AACxB,WAAOA;AAET,QAAMoC;AAAA;AAAA,IAENpC,EAAK;AAAA,IAELA,EAAK;AAAA,IAELsmC,GAAatmC,CAAI,KAAKA,EAAK;AAAA,IAE3BmmC,GAAmBnmC,CAAI;AAAA;AACvB,SAAOsmC,GAAalkC,CAAM,IAAIA,EAAO,OAAOA;AAC9C;AACA,SAASslC,GAA2B1nC,GAAM;AACxC,QAAM2nC,IAAaJ,GAAcvnC,CAAI;AACrC,SAAIwnC,GAAsBG,CAAU,IAC3B3nC,EAAK,gBAAgBA,EAAK,cAAc,OAAOA,EAAK,OAEzDqmC,GAAcsB,CAAU,KAAKpB,GAAkBoB,CAAU,IACpDA,IAEFD,GAA2BC,CAAU;AAC9C;AACA,SAASC,GAAqB5nC,GAAM49B,GAAMiK,GAAiB;AACzD,MAAIC;AACJ,EAAIlK,MAAS,WACXA,IAAO,CAAA,IAELiK,MAAoB,WACtBA,IAAkB;AAEpB,QAAME,IAAqBL,GAA2B1nC,CAAI,GACpDgoC,IAASD,QAAyBD,IAAuB9nC,EAAK,kBAAkB,OAAO,SAAS8nC,EAAqB,OACrHG,IAAMhC,GAAU8B,CAAkB;AACxC,MAAIC,GAAQ;AACV,UAAME,IAAeC,GAAgBF,CAAG;AACxC,WAAOrK,EAAK,OAAOqK,GAAKA,EAAI,kBAAkB,CAAA,GAAI1B,GAAkBwB,CAAkB,IAAIA,IAAqB,CAAA,GAAIG,KAAgBL,IAAkBD,GAAqBM,CAAY,IAAI,EAAE;AAAA,EAC9L;AACE,WAAOtK,EAAK,OAAOmK,GAAoBH,GAAqBG,GAAoB,CAAA,GAAIF,CAAe,CAAC;AAExG;AACA,SAASM,GAAgBF,GAAK;AAC5B,SAAOA,EAAI,UAAU,OAAO,eAAeA,EAAI,MAAM,IAAIA,EAAI,eAAe;AAC9E;AC7JA,SAASG,GAAiB1nC,GAAS;AACjC,QAAMhB,IAAM2oC,GAAmB3nC,CAAO;AAGtC,MAAIiT,IAAQ,WAAWjU,EAAI,KAAK,KAAK,GACjC8T,IAAS,WAAW9T,EAAI,MAAM,KAAK;AACvC,QAAM4oC,IAAYjC,GAAc3lC,CAAO,GACjC6nC,IAAcD,IAAY5nC,EAAQ,cAAciT,GAChD60B,IAAeF,IAAY5nC,EAAQ,eAAe8S,GAClDi1B,IAAiBjN,GAAM7nB,CAAK,MAAM40B,KAAe/M,GAAMhoB,CAAM,MAAMg1B;AACzE,SAAIC,MACF90B,IAAQ40B,GACR/0B,IAASg1B,IAEJ;AAAA,IACL,OAAA70B;AAAA,IACA,QAAAH;AAAA,IACA,GAAGi1B;AAAA,EACP;AACA;AAEA,SAASC,GAAchoC,GAAS;AAC9B,SAAQ0lC,GAAU1lC,CAAO,IAA6BA,IAAzBA,EAAQ;AACvC;AAEA,SAASioC,GAASjoC,GAAS;AACzB,QAAMkoC,IAAaF,GAAchoC,CAAO;AACxC,MAAI,CAAC2lC,GAAcuC,CAAU;AAC3B,WAAOlN,GAAa,CAAC;AAEvB,QAAMnJ,IAAOqW,EAAW,sBAAqB,GACvC;AAAA,IACJ,OAAAj1B;AAAA,IACA,QAAAH;AAAA,IACA,GAAAq1B;AAAA,EACJ,IAAMT,GAAiBQ,CAAU;AAC/B,MAAI3K,KAAK4K,IAAIrN,GAAMjJ,EAAK,KAAK,IAAIA,EAAK,SAAS5e,GAC3CuqB,KAAK2K,IAAIrN,GAAMjJ,EAAK,MAAM,IAAIA,EAAK,UAAU/e;AAIjD,UAAI,CAACyqB,KAAK,CAAC,OAAO,SAASA,CAAC,OAC1BA,IAAI,KAEF,CAACC,KAAK,CAAC,OAAO,SAASA,CAAC,OAC1BA,IAAI,IAEC;AAAA,IACL,GAAAD;AAAA,IACA,GAAAC;AAAA,EACJ;AACA;AAEA,MAAM4K,KAAyB,gBAAApN,GAAa,CAAC;AAC7C,SAASqN,GAAiBroC,GAAS;AACjC,QAAMunC,IAAMhC,GAAUvlC,CAAO;AAC7B,SAAI,CAAC0mC,GAAQ,KAAM,CAACa,EAAI,iBACfa,KAEF;AAAA,IACL,GAAGb,EAAI,eAAe;AAAA,IACtB,GAAGA,EAAI,eAAe;AAAA,EAC1B;AACA;AACA,SAASe,GAAuBtoC,GAASuoC,GAASC,GAAsB;AAItE,SAHID,MAAY,WACdA,IAAU,KAER,CAACC,KAAwBD,KAAWC,MAAyBjD,GAAUvlC,CAAO,IACzE,KAEFuoC;AACT;AAEA,SAASE,GAAsBzoC,GAAS0oC,GAAcC,GAAiB5J,GAAc;AACnF,EAAI2J,MAAiB,WACnBA,IAAe,KAEbC,MAAoB,WACtBA,IAAkB;AAEpB,QAAMC,IAAa5oC,EAAQ,sBAAqB,GAC1CkoC,IAAaF,GAAchoC,CAAO;AACxC,MAAI6oC,IAAQ7N,GAAa,CAAC;AAC1B,EAAI0N,MACE3J,IACE2G,GAAU3G,CAAY,MACxB8J,IAAQZ,GAASlJ,CAAY,KAG/B8J,IAAQZ,GAASjoC,CAAO;AAG5B,QAAM8oC,IAAgBR,GAAuBJ,GAAYS,GAAiB5J,CAAY,IAAIsJ,GAAiBH,CAAU,IAAIlN,GAAa,CAAC;AACvI,MAAIuC,KAAKqL,EAAW,OAAOE,EAAc,KAAKD,EAAM,GAChDrL,KAAKoL,EAAW,MAAME,EAAc,KAAKD,EAAM,GAC/C51B,IAAQ21B,EAAW,QAAQC,EAAM,GACjC/1B,IAAS81B,EAAW,SAASC,EAAM;AACvC,MAAIX,GAAY;AACd,UAAMX,IAAMhC,GAAU2C,CAAU,GAC1Ba,IAAYhK,KAAgB2G,GAAU3G,CAAY,IAAIwG,GAAUxG,CAAY,IAAIA;AACtF,QAAIiK,IAAazB,GACb0B,IAAgBxB,GAAgBuB,CAAU;AAC9C,WAAOC,KAAiBlK,KAAgBgK,MAAcC,KAAY;AAChE,YAAME,IAAcjB,GAASgB,CAAa,GACpCE,IAAaF,EAAc,sBAAqB,GAChDjqC,IAAM2oC,GAAmBsB,CAAa,GACtClX,IAAOoX,EAAW,QAAQF,EAAc,aAAa,WAAWjqC,EAAI,WAAW,KAAKkqC,EAAY,GAChGjX,IAAMkX,EAAW,OAAOF,EAAc,YAAY,WAAWjqC,EAAI,UAAU,KAAKkqC,EAAY;AAClG,MAAA3L,KAAK2L,EAAY,GACjB1L,KAAK0L,EAAY,GACjBj2B,KAASi2B,EAAY,GACrBp2B,KAAUo2B,EAAY,GACtB3L,KAAKxL,GACLyL,KAAKvL,GACL+W,IAAazD,GAAU0D,CAAa,GACpCA,IAAgBxB,GAAgBuB,CAAU;AAAA,IAC5C;AAAA,EACF;AACA,SAAO1L,GAAiB;AAAA,IACtB,OAAArqB;AAAA,IACA,QAAAH;AAAA,IACA,GAAAyqB;AAAA,IACA,GAAAC;AAAA,EACJ,CAAG;AACH;AAIA,SAAS4L,GAAoBppC,GAAS6xB,GAAM;AAC1C,QAAMwX,IAAatC,GAAc/mC,CAAO,EAAE;AAC1C,SAAK6xB,IAGEA,EAAK,OAAOwX,IAFVZ,GAAsBhD,GAAmBzlC,CAAO,CAAC,EAAE,OAAOqpC;AAGrE;AAEA,SAASC,GAAcC,GAAiBC,GAAQ;AAC9C,QAAMC,IAAWF,EAAgB,sBAAqB,GAChDhM,IAAIkM,EAAS,OAAOD,EAAO,aAAaJ,GAAoBG,GAAiBE,CAAQ,GACrFjM,IAAIiM,EAAS,MAAMD,EAAO;AAChC,SAAO;AAAA,IACL,GAAAjM;AAAA,IACA,GAAAC;AAAA,EACJ;AACA;AAEA,SAASkM,GAAsDhM,GAAM;AACnE,MAAI;AAAA,IACF,UAAAa;AAAA,IACA,MAAA1M;AAAA,IACA,cAAAkN;AAAA,IACA,UAAAP;AAAA,EACJ,IAAMd;AACJ,QAAM6K,IAAU/J,MAAa,SACvB+K,IAAkB9D,GAAmB1G,CAAY,GACjD4K,IAAWpL,IAAW4H,GAAW5H,EAAS,QAAQ,IAAI;AAC5D,MAAIQ,MAAiBwK,KAAmBI,KAAYpB;AAClD,WAAO1W;AAET,MAAI2X,IAAS;AAAA,IACX,YAAY;AAAA,IACZ,WAAW;AAAA,EACf,GACMX,IAAQ7N,GAAa,CAAC;AAC1B,QAAM2H,IAAU3H,GAAa,CAAC,GACxB4O,IAA0BjE,GAAc5G,CAAY;AAC1D,OAAI6K,KAA2B,CAACA,KAA2B,CAACrB,QACtDlD,GAAYtG,CAAY,MAAM,UAAU8G,GAAkB0D,CAAe,OAC3EC,IAASzC,GAAchI,CAAY,IAEjC6K,IAAyB;AAC3B,UAAMC,IAAapB,GAAsB1J,CAAY;AACrD,IAAA8J,IAAQZ,GAASlJ,CAAY,GAC7B4D,EAAQ,IAAIkH,EAAW,IAAI9K,EAAa,YACxC4D,EAAQ,IAAIkH,EAAW,IAAI9K,EAAa;AAAA,EAC1C;AAEF,QAAM+K,IAAaP,KAAmB,CAACK,KAA2B,CAACrB,IAAUe,GAAcC,GAAiBC,CAAM,IAAIxO,GAAa,CAAC;AACpI,SAAO;AAAA,IACL,OAAOnJ,EAAK,QAAQgX,EAAM;AAAA,IAC1B,QAAQhX,EAAK,SAASgX,EAAM;AAAA,IAC5B,GAAGhX,EAAK,IAAIgX,EAAM,IAAIW,EAAO,aAAaX,EAAM,IAAIlG,EAAQ,IAAImH,EAAW;AAAA,IAC3E,GAAGjY,EAAK,IAAIgX,EAAM,IAAIW,EAAO,YAAYX,EAAM,IAAIlG,EAAQ,IAAImH,EAAW;AAAA,EAC9E;AACA;AAEA,SAASC,GAAe/pC,GAAS;AAC/B,SAAO,MAAM,KAAKA,EAAQ,eAAc,CAAE;AAC5C;AAIA,SAASgqC,GAAgBhqC,GAAS;AAChC,QAAMiqC,IAAOxE,GAAmBzlC,CAAO,GACjCwpC,IAASzC,GAAc/mC,CAAO,GAC9B+lB,IAAO/lB,EAAQ,cAAc,MAC7BiT,IAAQ4nB,GAAIoP,EAAK,aAAaA,EAAK,aAAalkB,EAAK,aAAaA,EAAK,WAAW,GAClFjT,IAAS+nB,GAAIoP,EAAK,cAAcA,EAAK,cAAclkB,EAAK,cAAcA,EAAK,YAAY;AAC7F,MAAIwX,IAAI,CAACiM,EAAO,aAAaJ,GAAoBppC,CAAO;AACxD,QAAMw9B,IAAI,CAACgM,EAAO;AAClB,SAAI7B,GAAmB5hB,CAAI,EAAE,cAAc,UACzCwX,KAAK1C,GAAIoP,EAAK,aAAalkB,EAAK,WAAW,IAAI9S,IAE1C;AAAA,IACL,OAAAA;AAAA,IACA,QAAAH;AAAA,IACA,GAAAyqB;AAAA,IACA,GAAAC;AAAA,EACJ;AACA;AAKA,MAAM0M,KAAgB;AACtB,SAASC,GAAgBnqC,GAASw+B,GAAU;AAC1C,QAAM+I,IAAMhC,GAAUvlC,CAAO,GACvBiqC,IAAOxE,GAAmBzlC,CAAO,GACjCoqC,IAAiB7C,EAAI;AAC3B,MAAIt0B,IAAQg3B,EAAK,aACbn3B,IAASm3B,EAAK,cACd1M,IAAI,GACJC,IAAI;AACR,MAAI4M,GAAgB;AAClB,IAAAn3B,IAAQm3B,EAAe,OACvBt3B,IAASs3B,EAAe;AACxB,UAAMC,IAAsB3D,GAAQ;AACpC,KAAI,CAAC2D,KAAuBA,KAAuB7L,MAAa,aAC9DjB,IAAI6M,EAAe,YACnB5M,IAAI4M,EAAe;AAAA,EAEvB;AACA,QAAME,IAAmBlB,GAAoBa,CAAI;AAIjD,MAAIK,KAAoB,GAAG;AACzB,UAAMC,IAAMN,EAAK,eACXlkB,IAAOwkB,EAAI,MACXC,IAAa,iBAAiBzkB,CAAI,GAClC0kB,IAAmBF,EAAI,eAAe,gBAAe,WAAWC,EAAW,UAAU,IAAI,WAAWA,EAAW,WAAW,KAAK,GAC/HE,IAA+B,KAAK,IAAIT,EAAK,cAAclkB,EAAK,cAAc0kB,CAAgB;AACpG,IAAIC,KAAgCR,OAClCj3B,KAASy3B;AAAA,EAEb,MAAO,CAAIJ,KAAoBJ,OAG7Bj3B,KAASq3B;AAEX,SAAO;AAAA,IACL,OAAAr3B;AAAA,IACA,QAAAH;AAAA,IACA,GAAAyqB;AAAA,IACA,GAAAC;AAAA,EACJ;AACA;AAGA,SAASmN,GAA2B3qC,GAASw+B,GAAU;AACrD,QAAMoK,IAAaH,GAAsBzoC,GAAS,IAAMw+B,MAAa,OAAO,GACtEvM,IAAM2W,EAAW,MAAM5oC,EAAQ,WAC/B+xB,IAAO6W,EAAW,OAAO5oC,EAAQ,YACjC6oC,IAAQlD,GAAc3lC,CAAO,IAAIioC,GAASjoC,CAAO,IAAIg7B,GAAa,CAAC,GACnE/nB,IAAQjT,EAAQ,cAAc6oC,EAAM,GACpC/1B,IAAS9S,EAAQ,eAAe6oC,EAAM,GACtCtL,IAAIxL,IAAO8W,EAAM,GACjBrL,IAAIvL,IAAM4W,EAAM;AACtB,SAAO;AAAA,IACL,OAAA51B;AAAA,IACA,QAAAH;AAAA,IACA,GAAAyqB;AAAA,IACA,GAAAC;AAAA,EACJ;AACA;AACA,SAASoN,GAAkC5qC,GAAS6qC,GAAkBrM,GAAU;AAC9E,MAAI3M;AACJ,MAAIgZ,MAAqB;AACvB,IAAAhZ,IAAOsY,GAAgBnqC,GAASw+B,CAAQ;AAAA,WAC/BqM,MAAqB;AAC9B,IAAAhZ,IAAOmY,GAAgBvE,GAAmBzlC,CAAO,CAAC;AAAA,WACzC0lC,GAAUmF,CAAgB;AACnC,IAAAhZ,IAAO8Y,GAA2BE,GAAkBrM,CAAQ;AAAA,OACvD;AACL,UAAMsK,IAAgBT,GAAiBroC,CAAO;AAC9C,IAAA6xB,IAAO;AAAA,MACL,GAAGgZ,EAAiB,IAAI/B,EAAc;AAAA,MACtC,GAAG+B,EAAiB,IAAI/B,EAAc;AAAA,MACtC,OAAO+B,EAAiB;AAAA,MACxB,QAAQA,EAAiB;AAAA,IAC/B;AAAA,EACE;AACA,SAAOvN,GAAiBzL,CAAI;AAC9B;AACA,SAASiZ,GAAyB9qC,GAAS+qC,GAAU;AACnD,QAAM9D,IAAaJ,GAAc7mC,CAAO;AACxC,SAAIinC,MAAe8D,KAAY,CAACrF,GAAUuB,CAAU,KAAKH,GAAsBG,CAAU,IAChF,KAEFU,GAAmBV,CAAU,EAAE,aAAa,WAAW6D,GAAyB7D,GAAY8D,CAAQ;AAC7G;AAKA,SAASC,GAA4BhrC,GAASgH,GAAO;AACnD,QAAMgE,IAAehE,EAAM,IAAIhH,CAAO;AACtC,MAAIgL;AACF,WAAOA;AAET,MAAItJ,IAASwlC,GAAqBlnC,GAAS,CAAA,GAAI,EAAK,EAAE,OAAO,CAAAgW,MAAM0vB,GAAU1vB,CAAE,KAAKqvB,GAAYrvB,CAAE,MAAM,MAAM,GAC1Gi1B,IAAsC;AAC1C,QAAMC,IAAiBvD,GAAmB3nC,CAAO,EAAE,aAAa;AAChE,MAAI4mC,IAAcsE,IAAiBrE,GAAc7mC,CAAO,IAAIA;AAG5D,SAAO0lC,GAAUkB,CAAW,KAAK,CAACE,GAAsBF,CAAW,KAAG;AACpE,UAAMuE,IAAgBxD,GAAmBf,CAAW,GAC9CwE,IAA0B5E,GAAkBI,CAAW;AAC7D,IAAI,CAACwE,KAA2BD,EAAc,aAAa,YACzDF,IAAsC,QAEVC,IAAiB,CAACE,KAA2B,CAACH,IAAsC,CAACG,KAA2BD,EAAc,aAAa,YAAY,CAAC,CAACF,MAAwCA,EAAoC,aAAa,cAAcA,EAAoC,aAAa,YAAYpF,GAAkBe,CAAW,KAAK,CAACwE,KAA2BN,GAAyB9qC,GAAS4mC,CAAW,KAGpcllC,IAASA,EAAO,OAAO,CAAA2pC,MAAYA,MAAazE,CAAW,IAG3DqE,IAAsCE,GAExCvE,IAAcC,GAAcD,CAAW;AAAA,EACzC;AACA,SAAA5/B,EAAM,IAAIhH,GAAS0B,CAAM,GAClBA;AACT;AAIA,SAAS4pC,GAAgB5N,GAAM;AAC7B,MAAI;AAAA,IACF,SAAA19B;AAAA,IACA,UAAAy+B;AAAA,IACA,cAAAC;AAAA,IACA,UAAAF;AAAA,EACJ,IAAMd;AAEJ,QAAM6N,IAAoB,CAAC,GADM9M,MAAa,sBAAsB0H,GAAWnmC,CAAO,IAAI,CAAA,IAAKgrC,GAA4BhrC,GAAS,KAAK,EAAE,IAAI,CAAA,EAAG,OAAOy+B,CAAQ,GACzGC,CAAY,GAC9D8M,IAAYZ,GAAkC5qC,GAASurC,EAAkB,CAAC,GAAG/M,CAAQ;AAC3F,MAAIvM,IAAMuZ,EAAU,KAChBxZ,IAAQwZ,EAAU,OAClBtZ,IAASsZ,EAAU,QACnBzZ,IAAOyZ,EAAU;AACrB,WAAS9rC,IAAI,GAAGA,IAAI6rC,EAAkB,QAAQ7rC,KAAK;AACjD,UAAMmyB,IAAO+Y,GAAkC5qC,GAASurC,EAAkB7rC,CAAC,GAAG8+B,CAAQ;AACtF,IAAAvM,IAAM4I,GAAIhJ,EAAK,KAAKI,CAAG,GACvBD,IAAQ4I,GAAI/I,EAAK,OAAOG,CAAK,GAC7BE,IAAS0I,GAAI/I,EAAK,QAAQK,CAAM,GAChCH,IAAO8I,GAAIhJ,EAAK,MAAME,CAAI;AAAA,EAC5B;AACA,SAAO;AAAA,IACL,OAAOC,IAAQD;AAAA,IACf,QAAQG,IAASD;AAAA,IACjB,GAAGF;AAAA,IACH,GAAGE;AAAA,EACP;AACA;AAEA,SAASwZ,GAAczrC,GAAS;AAC9B,QAAM;AAAA,IACJ,OAAAiT;AAAA,IACA,QAAAH;AAAA,EACJ,IAAM40B,GAAiB1nC,CAAO;AAC5B,SAAO;AAAA,IACL,OAAAiT;AAAA,IACA,QAAAH;AAAA,EACJ;AACA;AAEA,SAAS44B,GAA8B1rC,GAAS++B,GAAcP,GAAU;AACtE,QAAMoL,IAA0BjE,GAAc5G,CAAY,GACpDwK,IAAkB9D,GAAmB1G,CAAY,GACjDwJ,IAAU/J,MAAa,SACvB3M,IAAO4W,GAAsBzoC,GAAS,IAAMuoC,GAASxJ,CAAY;AACvE,MAAIyK,IAAS;AAAA,IACX,YAAY;AAAA,IACZ,WAAW;AAAA,EACf;AACE,QAAM7G,IAAU3H,GAAa,CAAC;AAI9B,WAAS2Q,IAA4B;AACnC,IAAAhJ,EAAQ,IAAIyG,GAAoBG,CAAe;AAAA,EACjD;AACA,MAAIK,KAA2B,CAACA,KAA2B,CAACrB;AAI1D,SAHIlD,GAAYtG,CAAY,MAAM,UAAU8G,GAAkB0D,CAAe,OAC3EC,IAASzC,GAAchI,CAAY,IAEjC6K,GAAyB;AAC3B,YAAMC,IAAapB,GAAsB1J,GAAc,IAAMwJ,GAASxJ,CAAY;AAClF,MAAA4D,EAAQ,IAAIkH,EAAW,IAAI9K,EAAa,YACxC4D,EAAQ,IAAIkH,EAAW,IAAI9K,EAAa;AAAA,IAC1C,MAAO,CAAIwK,KACToC,EAAyB;AAG7B,EAAIpD,KAAW,CAACqB,KAA2BL,KACzCoC,EAAyB;AAE3B,QAAM7B,IAAaP,KAAmB,CAACK,KAA2B,CAACrB,IAAUe,GAAcC,GAAiBC,CAAM,IAAIxO,GAAa,CAAC,GAC9HuC,IAAI1L,EAAK,OAAO2X,EAAO,aAAa7G,EAAQ,IAAImH,EAAW,GAC3DtM,IAAI3L,EAAK,MAAM2X,EAAO,YAAY7G,EAAQ,IAAImH,EAAW;AAC/D,SAAO;AAAA,IACL,GAAAvM;AAAA,IACA,GAAAC;AAAA,IACA,OAAO3L,EAAK;AAAA,IACZ,QAAQA,EAAK;AAAA,EACjB;AACA;AAEA,SAAS+Z,GAAmB5rC,GAAS;AACnC,SAAO2nC,GAAmB3nC,CAAO,EAAE,aAAa;AAClD;AAEA,SAAS6rC,GAAoB7rC,GAAS8rC,GAAU;AAC9C,MAAI,CAACnG,GAAc3lC,CAAO,KAAK2nC,GAAmB3nC,CAAO,EAAE,aAAa;AACtE,WAAO;AAET,MAAI8rC;AACF,WAAOA,EAAS9rC,CAAO;AAEzB,MAAI+rC,IAAkB/rC,EAAQ;AAM9B,SAAIylC,GAAmBzlC,CAAO,MAAM+rC,MAClCA,IAAkBA,EAAgB,cAAc,OAE3CA;AACT;AAIA,SAASC,GAAgBhsC,GAAS8rC,GAAU;AAC1C,QAAMvE,IAAMhC,GAAUvlC,CAAO;AAC7B,MAAImmC,GAAWnmC,CAAO;AACpB,WAAOunC;AAET,MAAI,CAAC5B,GAAc3lC,CAAO,GAAG;AAC3B,QAAIisC,IAAkBpF,GAAc7mC,CAAO;AAC3C,WAAOisC,KAAmB,CAACnF,GAAsBmF,CAAe,KAAG;AACjE,UAAIvG,GAAUuG,CAAe,KAAK,CAACL,GAAmBK,CAAe;AACnE,eAAOA;AAET,MAAAA,IAAkBpF,GAAcoF,CAAe;AAAA,IACjD;AACA,WAAO1E;AAAA,EACT;AACA,MAAIxI,IAAe8M,GAAoB7rC,GAAS8rC,CAAQ;AACxD,SAAO/M,KAAgBmH,GAAenH,CAAY,KAAK6M,GAAmB7M,CAAY;AACpF,IAAAA,IAAe8M,GAAoB9M,GAAc+M,CAAQ;AAE3D,SAAI/M,KAAgB+H,GAAsB/H,CAAY,KAAK6M,GAAmB7M,CAAY,KAAK,CAACyH,GAAkBzH,CAAY,IACrHwI,IAEFxI,KAAgB4H,GAAmB3mC,CAAO,KAAKunC;AACxD;AAEA,MAAM2E,KAAkB,eAAgBh3B,GAAM;AAC5C,QAAMi3B,IAAoB,KAAK,mBAAmBH,IAC5CI,IAAkB,KAAK,eACvBC,IAAqB,MAAMD,EAAgBl3B,EAAK,QAAQ;AAC9D,SAAO;AAAA,IACL,WAAWw2B,GAA8Bx2B,EAAK,WAAW,MAAMi3B,EAAkBj3B,EAAK,QAAQ,GAAGA,EAAK,QAAQ;AAAA,IAC9G,UAAU;AAAA,MACR,GAAG;AAAA,MACH,GAAG;AAAA,MACH,OAAOm3B,EAAmB;AAAA,MAC1B,QAAQA,EAAmB;AAAA,IACjC;AAAA,EACA;AACA;AAEA,SAASC,GAAMtsC,GAAS;AACtB,SAAO2nC,GAAmB3nC,CAAO,EAAE,cAAc;AACnD;AAEA,MAAMs+B,KAAW;AAAA,EACf,uDAAAoL;AAAA,EACA,oBAAAjE;AAAA,EACA,iBAAA6F;AAAA,EACA,iBAAAU;AAAA,EACA,iBAAAE;AAAA,EACA,gBAAAnC;AAAA,EACA,eAAA0B;AAAA,EACA,UAAAxD;AAAA,EACA,WAAAvC;AAAA,EACA,OAAA4G;AACF;AAEA,SAASC,GAAcpzB,GAAGC,GAAG;AAC3B,SAAOD,EAAE,MAAMC,EAAE,KAAKD,EAAE,MAAMC,EAAE,KAAKD,EAAE,UAAUC,EAAE,SAASD,EAAE,WAAWC,EAAE;AAC7E;AAGA,SAASozB,GAAYxsC,GAASysC,GAAQ;AACpC,MAAIC,IAAK,MACLC;AACJ,QAAMC,IAAOnH,GAAmBzlC,CAAO;AACvC,WAASP,IAAU;AACjB,QAAIotC;AACJ,iBAAaF,CAAS,IACrBE,IAAMH,MAAO,QAAQG,EAAI,WAAU,GACpCH,IAAK;AAAA,EACP;AACA,WAASI,EAAQC,GAAMC,GAAW;AAChC,IAAID,MAAS,WACXA,IAAO,KAELC,MAAc,WAChBA,IAAY,IAEdvtC,EAAO;AACP,UAAMwtC,IAA2BjtC,EAAQ,sBAAqB,GACxD;AAAA,MACJ,MAAA+xB;AAAA,MACA,KAAAE;AAAA,MACA,OAAAhf;AAAA,MACA,QAAAH;AAAA,IACN,IAAQm6B;AAIJ,QAHKF,KACHN,EAAM,GAEJ,CAACx5B,KAAS,CAACH;AACb;AAEF,UAAMo6B,IAAWnS,GAAM9I,CAAG,GACpBkb,IAAapS,GAAM6R,EAAK,eAAe7a,IAAO9e,EAAM,GACpDm6B,IAAcrS,GAAM6R,EAAK,gBAAgB3a,IAAMnf,EAAO,GACtDu6B,IAAYtS,GAAMhJ,CAAI,GAEtBpR,IAAU;AAAA,MACd,YAFiB,CAACusB,IAAW,QAAQ,CAACC,IAAa,QAAQ,CAACC,IAAc,QAAQ,CAACC,IAAY;AAAA,MAG/F,WAAWxS,GAAI,GAAGD,GAAI,GAAGoS,CAAS,CAAC,KAAK;AAAA,IAC9C;AACI,QAAIM,IAAgB;AACpB,aAASC,EAAcjnC,GAAS;AAC9B,YAAMknC,IAAQlnC,EAAQ,CAAC,EAAE;AACzB,UAAIknC,MAAUR,GAAW;AACvB,YAAI,CAACM;AACH,iBAAOR,EAAO;AAEhB,QAAKU,IAOHV,EAAQ,IAAOU,CAAK,IAJpBb,IAAY,WAAW,MAAM;AAC3B,UAAAG,EAAQ,IAAO,IAAI;AAAA,QACrB,GAAG,GAAI;AAAA,MAIX;AACA,MAAIU,MAAU,KAAK,CAACjB,GAAcU,GAA0BjtC,EAAQ,sBAAqB,CAAE,KAQzF8sC,EAAO,GAETQ,IAAgB;AAAA,IAClB;AAIA,QAAI;AACF,MAAAZ,IAAK,IAAI,qBAAqBa,GAAe;AAAA,QAC3C,GAAG5sB;AAAA;AAAA,QAEH,MAAMisB,EAAK;AAAA,MACnB,CAAO;AAAA,IACH,QAAa;AACX,MAAAF,IAAK,IAAI,qBAAqBa,GAAe5sB,CAAO;AAAA,IACtD;AACA,IAAA+rB,EAAG,QAAQ1sC,CAAO;AAAA,EACpB;AACA,SAAA8sC,EAAQ,EAAI,GACLrtC;AACT;AAUA,SAASguC,GAAW9P,GAAWC,GAAU12B,GAAQyZ,GAAS;AACxD,EAAIA,MAAY,WACdA,IAAU,CAAA;AAEZ,QAAM;AAAA,IACJ,gBAAA+sB,IAAiB;AAAA,IACjB,gBAAAC,IAAiB;AAAA,IACjB,eAAAC,IAAgB,OAAO,kBAAmB;AAAA,IAC1C,aAAAC,IAAc,OAAO,wBAAyB;AAAA,IAC9C,gBAAAC,IAAiB;AAAA,EACrB,IAAMntB,GACEotB,IAAc/F,GAAcrK,CAAS,GACrCqQ,IAAYN,KAAkBC,IAAiB,CAAC,GAAII,IAAc7G,GAAqB6G,CAAW,IAAI,CAAA,GAAK,GAAInQ,IAAWsJ,GAAqBtJ,CAAQ,IAAI,CAAA,CAAG,IAAI,CAAA;AACxK,EAAAoQ,EAAU,QAAQ,CAAA3C,MAAY;AAC5B,IAAAqC,KAAkBrC,EAAS,iBAAiB,UAAUnkC,GAAQ;AAAA,MAC5D,SAAS;AAAA,IACf,CAAK,GACDymC,KAAkBtC,EAAS,iBAAiB,UAAUnkC,CAAM;AAAA,EAC9D,CAAC;AACD,QAAM+mC,IAAYF,KAAeF,IAAcrB,GAAYuB,GAAa7mC,CAAM,IAAI;AAClF,MAAIgnC,IAAiB,IACjB56B,IAAiB;AACrB,EAAIs6B,MACFt6B,IAAiB,IAAI,eAAe,CAAAoqB,MAAQ;AAC1C,QAAI,CAACyQ,CAAU,IAAIzQ;AACnB,IAAIyQ,KAAcA,EAAW,WAAWJ,KAAez6B,KAAkBsqB,MAGvEtqB,EAAe,UAAUsqB,CAAQ,GACjC,qBAAqBsQ,CAAc,GACnCA,IAAiB,sBAAsB,MAAM;AAC3C,UAAIE;AACJ,OAACA,IAAkB96B,MAAmB,QAAQ86B,EAAgB,QAAQxQ,CAAQ;AAAA,IAChF,CAAC,IAEH12B,EAAM;AAAA,EACR,CAAC,GACG6mC,KAAe,CAACD,KAClBx6B,EAAe,QAAQy6B,CAAW,GAEhCnQ,KACFtqB,EAAe,QAAQsqB,CAAQ;AAGnC,MAAIyQ,GACAC,IAAcR,IAAiBrF,GAAsB9K,CAAS,IAAI;AACtE,EAAImQ,KACFS,EAAS;AAEX,WAASA,IAAY;AACnB,UAAMC,IAAc/F,GAAsB9K,CAAS;AACnD,IAAI2Q,KAAe,CAAC/B,GAAc+B,GAAaE,CAAW,KACxDtnC,EAAM,GAERonC,IAAcE,GACdH,IAAU,sBAAsBE,CAAS;AAAA,EAC3C;AACA,SAAArnC,EAAM,GACC,MAAM;AACX,QAAIunC;AACJ,IAAAT,EAAU,QAAQ,CAAA3C,MAAY;AAC5B,MAAAqC,KAAkBrC,EAAS,oBAAoB,UAAUnkC,CAAM,GAC/DymC,KAAkBtC,EAAS,oBAAoB,UAAUnkC,CAAM;AAAA,IACjE,CAAC,GACoB+mC,IAAS,IAC7BQ,IAAmBn7B,MAAmB,QAAQm7B,EAAiB,WAAU,GAC1En7B,IAAiB,MACbw6B,KACF,qBAAqBO,CAAO;AAAA,EAEhC;AACF;AAmBA,MAAMv6B,KAAS46B,IAeTrL,KAAQsL,IAQR5N,KAAO6N,IAQP98B,KAAO+8B,IAOPnM,KAAOoM,IAOPlc,KAAQmc,IAYRnL,KAAaoL,IAMb7P,KAAkB,CAACxB,GAAWC,GAAUjd,MAAY;AAIxD,QAAM3Z,IAAQ,oBAAI,IAAG,GACfioC,IAAgB;AAAA,IACpB,UAAA3Q;AAAA,IACA,GAAG3d;AAAA,EACP,GACQuuB,IAAoB;AAAA,IACxB,GAAGD,EAAc;AAAA,IACjB,IAAIjoC;AAAA,EACR;AACE,SAAOmoC,GAAkBxR,GAAWC,GAAU;AAAA,IAC5C,GAAGqR;AAAA,IACH,UAAUC;AAAA,EACd,CAAG;AACH;ACpwBA,IAAIE,KAAW,OAAO,WAAa,KAE/BC,KAAO,WAAgB;AAAC,GACxBjnC,KAAQgnC,KAAWpb,KAAkBqb;AAIzC,SAASC,GAAUn2B,GAAGC,GAAG;AACvB,MAAID,MAAMC;AACR,WAAO;AAET,MAAI,OAAOD,KAAM,OAAOC;AACtB,WAAO;AAET,MAAI,OAAOD,KAAM,cAAcA,EAAE,eAAeC,EAAE;AAChD,WAAO;AAET,MAAI8iB,GACAx8B,GACAyoB;AACJ,MAAIhP,KAAKC,KAAK,OAAOD,KAAM,UAAU;AACnC,QAAI,MAAM,QAAQA,CAAC,GAAG;AAEpB,UADA+iB,IAAS/iB,EAAE,QACP+iB,MAAW9iB,EAAE,OAAQ,QAAO;AAChC,WAAK1Z,IAAIw8B,GAAQx8B,QAAQ;AACvB,YAAI,CAAC4vC,GAAUn2B,EAAEzZ,CAAC,GAAG0Z,EAAE1Z,CAAC,CAAC;AACvB,iBAAO;AAGX,aAAO;AAAA,IACT;AAGA,QAFAyoB,IAAO,OAAO,KAAKhP,CAAC,GACpB+iB,IAAS/T,EAAK,QACV+T,MAAW,OAAO,KAAK9iB,CAAC,EAAE;AAC5B,aAAO;AAET,SAAK1Z,IAAIw8B,GAAQx8B,QAAQ;AACvB,UAAI,CAAC,CAAA,EAAG,eAAe,KAAK0Z,GAAG+O,EAAKzoB,CAAC,CAAC;AACpC,eAAO;AAGX,SAAKA,IAAIw8B,GAAQx8B,QAAQ,KAAI;AAC3B,YAAMtB,IAAM+pB,EAAKzoB,CAAC;AAClB,UAAI,EAAAtB,MAAQ,YAAY+a,EAAE,aAGtB,CAACm2B,GAAUn2B,EAAE/a,CAAG,GAAGgb,EAAEhb,CAAG,CAAC;AAC3B,eAAO;AAAA,IAEX;AACA,WAAO;AAAA,EACT;AACA,SAAO+a,MAAMA,KAAKC,MAAMA;AAC1B;AAEA,SAASm2B,GAAOvvC,GAAS;AACvB,SAAI,OAAO,SAAW,MACb,KAEGA,EAAQ,cAAc,eAAe,QACtC,oBAAoB;AACjC;AAEA,SAASwvC,GAAWxvC,GAAS3B,GAAO;AAClC,QAAMoxC,IAAMF,GAAOvvC,CAAO;AAC1B,SAAO,KAAK,MAAM3B,IAAQoxC,CAAG,IAAIA;AACnC;AAEA,SAASC,GAAarxC,GAAO;AAC3B,QAAMc,IAAMxE,EAAM,OAAO0D,CAAK;AAC9B+J,SAAAA,GAAM,MAAM;AACV,IAAAjJ,EAAI,UAAUd;AAAA,EAChB,CAAC,GACMc;AACT;AAMA,SAASwwC,GAAYhvB,GAAS;AAC5B,EAAIA,MAAY,WACdA,IAAU,CAAA;AAEZ,QAAM;AAAA,IACJ,WAAAmR,IAAY;AAAA,IACZ,UAAA0M,IAAW;AAAA,IACX,YAAAY,IAAa,CAAA;AAAA,IACb,UAAAd;AAAA,IACA,UAAU;AAAA,MACR,WAAWsR;AAAA,MACX,UAAUC;AAAA,IAChB,IAAQ,CAAA;AAAA,IACJ,WAAAC,IAAY;AAAA,IACZ,sBAAAC;AAAA,IACA,MAAA7c;AAAA,EACJ,IAAMvS,GACE,CAACzL,GAAM86B,CAAO,IAAIr1C,EAAM,SAAS;AAAA,IACrC,GAAG;AAAA,IACH,GAAG;AAAA,IACH,UAAA6jC;AAAA,IACA,WAAA1M;AAAA,IACA,gBAAgB,CAAA;AAAA,IAChB,cAAc;AAAA,EAClB,CAAG,GACK,CAACme,GAAkBC,CAAmB,IAAIv1C,EAAM,SAASykC,CAAU;AACzE,EAAKkQ,GAAUW,GAAkB7Q,CAAU,KACzC8Q,EAAoB9Q,CAAU;AAEhC,QAAM,CAAC+Q,GAAYC,CAAa,IAAIz1C,EAAM,SAAS,IAAI,GACjD,CAAC01C,GAAWC,CAAY,IAAI31C,EAAM,SAAS,IAAI,GAC/C41C,IAAe51C,EAAM,YAAY,CAAA2E,MAAQ;AAC7C,IAAIA,MAASkxC,EAAa,YACxBA,EAAa,UAAUlxC,GACvB8wC,EAAc9wC,CAAI;AAAA,EAEtB,GAAG,CAAA,CAAE,GACCmxC,IAAc91C,EAAM,YAAY,CAAA2E,MAAQ;AAC5C,IAAIA,MAASoxC,EAAY,YACvBA,EAAY,UAAUpxC,GACtBgxC,EAAahxC,CAAI;AAAA,EAErB,GAAG,CAAA,CAAE,GACCyuC,IAAc6B,KAAqBO,GACnCQ,IAAad,KAAoBQ,GACjCG,IAAe71C,EAAM,OAAO,IAAI,GAChC+1C,IAAc/1C,EAAM,OAAO,IAAI,GAC/Bi2C,IAAUj2C,EAAM,OAAOua,CAAI,GAC3B27B,IAA0Bd,KAAwB,MAClDe,IAA0BpB,GAAaK,CAAoB,GAC3DgB,IAAcrB,GAAapR,CAAQ,GACnC0S,IAAUtB,GAAaxc,CAAI,GAC3BhsB,IAASvM,EAAM,YAAY,MAAM;AACrC,QAAI,CAAC61C,EAAa,WAAW,CAACE,EAAY;AACxC;AAEF,UAAMruC,IAAS;AAAA,MACb,WAAAyvB;AAAA,MACA,UAAA0M;AAAA,MACA,YAAYyR;AAAA,IAClB;AACI,IAAIc,EAAY,YACd1uC,EAAO,WAAW0uC,EAAY,UAEhC5R,GAAgBqR,EAAa,SAASE,EAAY,SAASruC,CAAM,EAAE,KAAK,CAAA6S,MAAQ;AAC9E,YAAM+7B,IAAW;AAAA,QACf,GAAG/7B;AAAA;AAAA;AAAA;AAAA;AAAA,QAKH,cAAc87B,EAAQ,YAAY;AAAA,MAC1C;AACM,MAAIE,EAAa,WAAW,CAAC5B,GAAUsB,EAAQ,SAASK,CAAQ,MAC9DL,EAAQ,UAAUK,GAClBha,GAAS,UAAU,MAAM;AACvB,QAAA+Y,EAAQiB,CAAQ;AAAA,MAClB,CAAC;AAAA,IAEL,CAAC;AAAA,EACH,GAAG,CAAChB,GAAkBne,GAAW0M,GAAUuS,GAAaC,CAAO,CAAC;AAChE5oC,EAAAA,GAAM,MAAM;AACV,IAAI8qB,MAAS,MAAS0d,EAAQ,QAAQ,iBACpCA,EAAQ,QAAQ,eAAe,IAC/BZ,EAAQ,CAAA96B,OAAS;AAAA,MACf,GAAGA;AAAA,MACH,cAAc;AAAA,IACtB,EAAQ;AAAA,EAEN,GAAG,CAACge,CAAI,CAAC;AACT,QAAMge,IAAev2C,EAAM,OAAO,EAAK;AACvCyN,EAAAA,GAAM,OACJ8oC,EAAa,UAAU,IAChB,MAAM;AACX,IAAAA,EAAa,UAAU;AAAA,EACzB,IACC,CAAA,CAAE,GACL9oC,GAAM,MAAM;AAGV,QAFI2lC,MAAayC,EAAa,UAAUzC,IACpC4C,MAAYD,EAAY,UAAUC,IAClC5C,KAAe4C,GAAY;AAC7B,UAAIG,EAAwB;AAC1B,eAAOA,EAAwB,QAAQ/C,GAAa4C,GAAYzpC,CAAM;AAExE,MAAAA,EAAM;AAAA,IACR;AAAA,EACF,GAAG,CAAC6mC,GAAa4C,GAAYzpC,GAAQ4pC,GAAyBD,CAAuB,CAAC;AACtF,QAAMxxC,IAAO1E,EAAM,QAAQ,OAAO;AAAA,IAChC,WAAW61C;AAAA,IACX,UAAUE;AAAA,IACV,cAAAH;AAAA,IACA,aAAAE;AAAA,EACJ,IAAM,CAACF,GAAcE,CAAW,CAAC,GACzBlS,IAAW5jC,EAAM,QAAQ,OAAO;AAAA,IACpC,WAAWozC;AAAA,IACX,UAAU4C;AAAA,EACd,IAAM,CAAC5C,GAAa4C,CAAU,CAAC,GACvBQ,IAAiBx2C,EAAM,QAAQ,MAAM;AACzC,UAAMy2C,IAAgB;AAAA,MACpB,UAAU5S;AAAA,MACV,MAAM;AAAA,MACN,KAAK;AAAA,IACX;AACI,QAAI,CAACD,EAAS;AACZ,aAAO6S;AAET,UAAM7T,IAAIiS,GAAWjR,EAAS,UAAUrpB,EAAK,CAAC,GACxCsoB,IAAIgS,GAAWjR,EAAS,UAAUrpB,EAAK,CAAC;AAC9C,WAAI46B,IACK;AAAA,MACL,GAAGsB;AAAA,MACH,WAAW,eAAe7T,IAAI,SAASC,IAAI;AAAA,MAC3C,GAAI+R,GAAOhR,EAAS,QAAQ,KAAK,OAAO;AAAA,QACtC,YAAY;AAAA,MACtB;AAAA,IACA,IAEW;AAAA,MACL,UAAUC;AAAA,MACV,MAAMjB;AAAA,MACN,KAAKC;AAAA,IACX;AAAA,EACE,GAAG,CAACgB,GAAUsR,GAAWvR,EAAS,UAAUrpB,EAAK,GAAGA,EAAK,CAAC,CAAC;AAC3D,SAAOva,EAAM,QAAQ,OAAO;AAAA,IAC1B,GAAGua;AAAA,IACH,QAAAhO;AAAA,IACA,MAAA7H;AAAA,IACA,UAAAk/B;AAAA,IACA,gBAAA4S;AAAA,EACJ,IAAM,CAACj8B,GAAMhO,GAAQ7H,GAAMk/B,GAAU4S,CAAc,CAAC;AACpD;AAQA,MAAMpC,KAAU,CAAApuB,MAAW;AACzB,WAAS0wB,EAAMhzC,GAAO;AACpB,WAAO,CAAA,EAAG,eAAe,KAAKA,GAAO,SAAS;AAAA,EAChD;AACA,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAAsiB;AAAA,IACA,GAAGsB,GAAO;AACR,YAAM;AAAA,QACJ,SAAAjiB;AAAA,QACA,SAAAo9B;AAAA,MACR,IAAU,OAAOzc,KAAY,aAAaA,EAAQsB,CAAK,IAAItB;AACrD,aAAI3gB,KAAWqxC,EAAMrxC,CAAO,IACtBA,EAAQ,WAAW,OACdsxC,GAAQ;AAAA,QACb,SAAStxC,EAAQ;AAAA,QACjB,SAAAo9B;AAAA,MACZ,CAAW,EAAE,GAAGnb,CAAK,IAEN,CAAA,IAELjiB,IACKsxC,GAAQ;AAAA,QACb,SAAAtxC;AAAA,QACA,SAAAo9B;AAAA,MACV,CAAS,EAAE,GAAGnb,CAAK,IAEN,CAAA;AAAA,IACT;AAAA,EACJ;AACA,GASMnO,KAAS,CAAC6M,GAAS4wB,MAAS;AAChC,QAAM7vC,IAASgtC,GAAS/tB,CAAO;AAC/B,SAAO;AAAA,IACL,MAAMjf,EAAO;AAAA,IACb,IAAIA,EAAO;AAAA,IACX,SAAS,CAACif,GAAS4wB,CAAI;AAAA,EAC3B;AACA,GAOMlO,KAAQ,CAAC1iB,GAAS4wB,MAAS;AAC/B,QAAM7vC,IAASitC,GAAQhuB,CAAO;AAC9B,SAAO;AAAA,IACL,MAAMjf,EAAO;AAAA,IACb,IAAIA,EAAO;AAAA,IACX,SAAS,CAACif,GAAS4wB,CAAI;AAAA,EAC3B;AACA,GAKM3N,KAAa,CAACjjB,GAAS4wB,OAEpB;AAAA,EACL,IAFavC,GAAaruB,CAAO,EAEtB;AAAA,EACX,SAAS,CAACA,GAAS4wB,CAAI;AAC3B,IASMxQ,KAAO,CAACpgB,GAAS4wB,MAAS;AAC9B,QAAM7vC,IAASktC,GAAOjuB,CAAO;AAC7B,SAAO;AAAA,IACL,MAAMjf,EAAO;AAAA,IACb,IAAIA,EAAO;AAAA,IACX,SAAS,CAACif,GAAS4wB,CAAI;AAAA,EAC3B;AACA,GAQMz/B,KAAO,CAAC6O,GAAS4wB,MAAS;AAC9B,QAAM7vC,IAASmtC,GAAOluB,CAAO;AAC7B,SAAO;AAAA,IACL,MAAMjf,EAAO;AAAA,IACb,IAAIA,EAAO;AAAA,IACX,SAAS,CAACif,GAAS4wB,CAAI;AAAA,EAC3B;AACA,GAsBM7O,KAAO,CAAC/hB,GAAS4wB,MAAS;AAC9B,QAAM7vC,IAASotC,GAAOnuB,CAAO;AAC7B,SAAO;AAAA,IACL,MAAMjf,EAAO;AAAA,IACb,IAAIA,EAAO;AAAA,IACX,SAAS,CAACif,GAAS4wB,CAAI;AAAA,EAC3B;AACA,GAsBM3e,KAAQ,CAACjS,GAAS4wB,MAAS;AAC/B,QAAM7vC,IAASqtC,GAAQpuB,CAAO;AAC9B,SAAO;AAAA,IACL,MAAMjf,EAAO;AAAA,IACb,IAAIA,EAAO;AAAA,IACX,SAAS,CAACif,GAAS4wB,CAAI;AAAA,EAC3B;AACA;AC/YA,IAAIC,KAAO,SACPC,KAAQ92C,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACpD,QAAM,EAAE,UAAA1B,GAAU,OAAAqU,IAAQ,IAAI,QAAAH,IAAS,GAAG,GAAG4+B,EAAU,IAAKh3C;AAC5D,SAAuB,gBAAAuE;AAAA,IACrB03B,GAAU;AAAA,IACV;AAAA,MACE,GAAG+a;AAAA,MACH,KAAKpxC;AAAA,MACL,OAAA2S;AAAA,MACA,QAAAH;AAAA,MACA,SAAS;AAAA,MACT,qBAAqB;AAAA,MACrB,UAAUpY,EAAM,UAAUkE,IAA2B,gBAAAK,EAAI,WAAW,EAAE,QAAQ,iBAAgB,CAAE;AAAA,IACtG;AAAA,EACA;AACA,CAAC;AACDwyC,GAAM,cAAcD;AACpB,IAAIG,KAAOF;AClBX,SAASG,GAAQ5xC,GAAS;AACxB,QAAM,CAAC8R,GAAM+/B,CAAO,IAAIl3C,EAAM,SAAS,MAAM;AAC7Cq5B,SAAAA,GAAgB,MAAM;AACpB,QAAIh0B,GAAS;AACX,MAAA6xC,EAAQ,EAAE,OAAO7xC,EAAQ,aAAa,QAAQA,EAAQ,cAAc;AACpE,YAAMsT,IAAiB,IAAI,eAAe,CAAChN,MAAY;AAIrD,YAHI,CAAC,MAAM,QAAQA,CAAO,KAGtB,CAACA,EAAQ;AACX;AAEF,cAAMiN,IAAQjN,EAAQ,CAAC;AACvB,YAAI2M,GACAH;AACJ,YAAI,mBAAmBS,GAAO;AAC5B,gBAAMu+B,IAAkBv+B,EAAM,eACxBw+B,IAAa,MAAM,QAAQD,CAAe,IAAIA,EAAgB,CAAC,IAAIA;AACzE,UAAA7+B,IAAQ8+B,EAAW,YACnBj/B,IAASi/B,EAAW;AAAA,QACtB;AACE,UAAA9+B,IAAQjT,EAAQ,aAChB8S,IAAS9S,EAAQ;AAEnB,QAAA6xC,EAAQ,EAAE,OAAA5+B,GAAO,QAAAH,GAAQ;AAAA,MAC3B,CAAC;AACD,aAAAQ,EAAe,QAAQtT,GAAS,EAAE,KAAK,aAAY,CAAE,GAC9C,MAAMsT,EAAe,UAAUtT,CAAO;AAAA,IAC/C;AACE,MAAA6xC,EAAQ,MAAM;AAAA,EAElB,GAAG,CAAC7xC,CAAO,CAAC,GACL8R;AACT;ACXA,IAAIkgC,KAAc,UACd,CAACC,IAAqBC,EAAiB,IAAI5c,GAAmB0c,EAAW,GACzE,CAACG,IAAgBC,EAAgB,IAAIH,GAAoBD,EAAW,GACpEK,KAAS,CAAC33C,MAAU;AACtB,QAAM,EAAE,eAAA43C,GAAe,UAAA1zC,EAAQ,IAAKlE,GAC9B,CAAC63C,GAAQC,CAAS,IAAI73C,EAAM,SAAS,IAAI;AAC/C,SAAuB,gBAAAsE,EAAIkzC,IAAgB,EAAE,OAAOG,GAAe,QAAAC,GAAQ,gBAAgBC,GAAW,UAAA5zC,GAAU;AAClH;AACAyzC,GAAO,cAAcL;AACrB,IAAIS,KAAc,gBACdC,KAAe/3C,EAAM;AAAA,EACvB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,eAAAgyC,GAAe,YAAAK,GAAY,GAAGC,EAAW,IAAKl4C,GAChDguB,IAAU0pB,GAAiBK,IAAaH,CAAa,GACrDnzC,IAAMxE,EAAM,OAAO,IAAI,GACvB29B,IAAe34B,GAAgBW,GAAcnB,CAAG,GAChD0zC,IAAYl4C,EAAM,OAAO,IAAI;AACnC,WAAAA,EAAM,UAAU,MAAM;AACpB,YAAMm4C,IAAiBD,EAAU;AACjC,MAAAA,EAAU,UAAUF,GAAY,WAAWxzC,EAAI,SAC3C2zC,MAAmBD,EAAU,WAC/BnqB,EAAQ,eAAemqB,EAAU,OAAO;AAAA,IAE5C,CAAC,GACMF,IAAa,OAAuB,gBAAA1zC,EAAI03B,GAAU,KAAK,EAAE,GAAGic,GAAa,KAAKta,GAAc;AAAA,EACrG;AACF;AACAoa,GAAa,cAAcD;AAC3B,IAAIM,KAAe,iBACf,CAACC,IAAuBC,EAAiB,IAAIhB,GAAoBc,EAAY,GAC7EG,KAAgBv4C,EAAM;AAAA,EACxB,CAACD,GAAO4F,MAAiB;AACvB,UAAM;AAAA,MACJ,eAAAgyC;AAAA,MACA,MAAAzV,IAAO;AAAA,MACP,YAAAsW,IAAa;AAAA,MACb,OAAAC,IAAQ;AAAA,MACR,aAAAC,IAAc;AAAA,MACd,cAAAC,IAAe;AAAA,MACf,iBAAAC,IAAkB;AAAA,MAClB,mBAAAC,IAAoB,CAAA;AAAA,MACpB,kBAAkBC,IAAuB;AAAA,MACzC,QAAAC,IAAS;AAAA,MACT,kBAAAC,IAAmB;AAAA,MACnB,wBAAAC,IAAyB;AAAA,MACzB,UAAAC;AAAA,MACA,GAAGC;AAAA,IACT,IAAQp5C,GACEguB,IAAU0pB,GAAiBW,IAAcT,CAAa,GACtD,CAACltC,GAAS2uC,CAAU,IAAIp5C,EAAM,SAAS,IAAI,GAC3C29B,IAAe34B,GAAgBW,GAAc,CAAChB,OAASy0C,EAAWz0C,EAAI,CAAC,GACvE,CAACszB,GAAOohB,CAAQ,IAAIr5C,EAAM,SAAS,IAAI,GACvCs5C,IAAYrC,GAAQhf,CAAK,GACzBshB,IAAaD,GAAW,SAAS,GACjCE,IAAcF,GAAW,UAAU,GACnCG,IAAmBvX,KAAQuW,MAAU,WAAW,MAAMA,IAAQ,KAC9DiB,IAAmB,OAAOZ,KAAyB,WAAWA,IAAuB,EAAE,KAAK,GAAG,OAAO,GAAG,QAAQ,GAAG,MAAM,GAAG,GAAGA,EAAoB,GACpJhV,IAAW,MAAM,QAAQ+U,CAAiB,IAAIA,IAAoB,CAACA,CAAiB,GACpFc,IAAwB7V,EAAS,SAAS,GAC1C+C,IAAwB;AAAA,MAC5B,SAAS6S;AAAA,MACT,UAAU5V,EAAS,OAAO8V,EAAS;AAAA;AAAA,MAEnC,aAAaD;AAAA,IACnB,GACU,EAAE,MAAAj1C,GAAM,gBAAA8xC,GAAgB,WAAArf,GAAW,cAAA0iB,GAAc,gBAAAhV,EAAc,IAAKmQ,GAAY;AAAA;AAAA,MAEpF,UAAU;AAAA,MACV,WAAWyE;AAAA,MACX,sBAAsB,IAAI3yC,OACRgsC,GAAW,GAAGhsC,IAAM;AAAA,QAClC,gBAAgBmyC,MAA2B;AAAA,MACrD,CAAS;AAAA,MAGH,UAAU;AAAA,QACR,WAAWlrB,EAAQ;AAAA,MAC3B;AAAA,MACM,YAAY;AAAA,QACV5U,GAAO,EAAE,UAAUq/B,IAAagB,GAAa,eAAed,GAAa;AAAA,QACzEE,KAAmBlQ,GAAM;AAAA,UACvB,UAAU;AAAA,UACV,WAAW;AAAA,UACX,SAASqQ,MAAW,YAAY9P,GAAU,IAAK;AAAA,UAC/C,GAAGpC;AAAA,QACb,CAAS;AAAA,QACD+R,KAAmBxS,GAAK,EAAE,GAAGS,GAAuB;AAAA,QACpD1vB,GAAK;AAAA,UACH,GAAG0vB;AAAA,UACH,OAAO,CAAC,EAAE,UAAAjD,IAAU,OAAAzC,GAAO,gBAAAgJ,GAAgB,iBAAAD,GAAe,MAAO;AAC/D,kBAAM,EAAE,OAAO4P,IAAa,QAAQC,GAAY,IAAK5Y,EAAM,WACrD6Y,IAAepW,GAAS,SAAS;AACvC,YAAAoW,EAAa,YAAY,kCAAkC,GAAG7P,CAAc,IAAI,GAChF6P,EAAa,YAAY,mCAAmC,GAAG9P,EAAe,IAAI,GAClF8P,EAAa,YAAY,+BAA+B,GAAGF,EAAW,IAAI,GAC1EE,EAAa,YAAY,gCAAgC,GAAGD,EAAY,IAAI;AAAA,UAC9E;AAAA,QACV,CAAS;AAAA,QACD9hB,KAASgiB,GAAgB,EAAE,SAAShiB,GAAO,SAAS0gB,GAAc;AAAA,QAClEuB,GAAgB,EAAE,YAAAX,GAAY,aAAAC,GAAa;AAAA,QAC3CR,KAAoBjR,GAAK,EAAE,UAAU,mBAAmB,GAAGlB,EAAqB,CAAE;AAAA,MAC1F;AAAA,IACA,CAAK,GACK,CAACsT,GAAYC,CAAW,IAAIC,GAA6BljB,CAAS,GAClEmjB,KAAe/d,GAAe2c,CAAQ;AAC5C7f,IAAAA,GAAgB,MAAM;AACpB,MAAIwgB,KACFS,KAAY;AAAA,IAEhB,GAAG,CAACT,GAAcS,EAAY,CAAC;AAC/B,UAAMC,KAAS1V,EAAe,OAAO,GAC/B2V,KAAS3V,EAAe,OAAO,GAC/B4V,KAAoB5V,EAAe,OAAO,iBAAiB,GAC3D,CAAC6V,GAAeC,EAAgB,IAAI36C,EAAM,SAAQ;AACxDq5B,WAAAA,GAAgB,MAAM;AACpB,MAAI5uB,KAASkwC,GAAiB,OAAO,iBAAiBlwC,CAAO,EAAE,MAAM;AAAA,IACvE,GAAG,CAACA,CAAO,CAAC,GACW,gBAAAnG;AAAA,MACrB;AAAA,MACA;AAAA,QACE,KAAKI,EAAK;AAAA,QACV,qCAAqC;AAAA,QACrC,OAAO;AAAA,UACL,GAAG8xC;AAAA,UACH,WAAWqD,IAAerD,EAAe,YAAY;AAAA;AAAA,UAErD,UAAU;AAAA,UACV,QAAQkE;AAAA,UACP,mCAAoC;AAAA,YACnC7V,EAAe,iBAAiB;AAAA,YAChCA,EAAe,iBAAiB;AAAA,UAC5C,EAAY,KAAK,GAAG;AAAA;AAAA;AAAA;AAAA,UAIV,GAAGA,EAAe,MAAM,mBAAmB;AAAA,YACzC,YAAY;AAAA,YACZ,eAAe;AAAA,UAC3B;AAAA,QACA;AAAA,QACQ,KAAK9kC,EAAM;AAAA,QACX,UAA0B,gBAAAuE;AAAA,UACxB+zC;AAAA,UACA;AAAA,YACE,OAAOV;AAAA,YACP,YAAAwC;AAAA,YACA,eAAed;AAAA,YACf,QAAAkB;AAAA,YACA,QAAAC;AAAA,YACA,iBAAiBC;AAAA,YACjB,UAA0B,gBAAAn2C;AAAA,cACxB03B,GAAU;AAAA,cACV;AAAA,gBACE,aAAame;AAAA,gBACb,cAAcC;AAAA,gBACd,GAAGjB;AAAA,gBACH,KAAKxb;AAAA,gBACL,OAAO;AAAA,kBACL,GAAGwb,EAAa;AAAA;AAAA;AAAA,kBAGhB,WAAYU,IAAwB,SAAT;AAAA,gBAC7C;AAAA,cACA;AAAA,YACA;AAAA,UACA;AAAA,QACA;AAAA,MACA;AAAA,IACA;AAAA,EACE;AACF;AACAtB,GAAc,cAAcH;AAC5B,IAAIwC,KAAa,eACbC,KAAgB;AAAA,EAClB,KAAK;AAAA,EACL,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,MAAM;AACR,GACIC,KAAc96C,EAAM,WAAW,SAAsBD,GAAO4F,GAAc;AAC5E,QAAM,EAAE,eAAAgyC,GAAe,GAAGZ,EAAU,IAAKh3C,GACnCg7C,IAAiBzC,GAAkBsC,IAAYjD,CAAa,GAC5DqD,IAAWH,GAAcE,EAAe,UAAU;AACxD;AAAA;AAAA;AAAA;AAAA,IAIkB,gBAAAz2C;AAAA,MACd;AAAA,MACA;AAAA,QACE,KAAKy2C,EAAe;AAAA,QACpB,OAAO;AAAA,UACL,UAAU;AAAA,UACV,MAAMA,EAAe;AAAA,UACrB,KAAKA,EAAe;AAAA,UACpB,CAACC,CAAQ,GAAG;AAAA,UACZ,iBAAiB;AAAA,YACf,KAAK;AAAA,YACL,OAAO;AAAA,YACP,QAAQ;AAAA,YACR,MAAM;AAAA,UAClB,EAAYD,EAAe,UAAU;AAAA,UAC3B,WAAW;AAAA,YACT,KAAK;AAAA,YACL,OAAO;AAAA,YACP,QAAQ;AAAA,YACR,MAAM;AAAA,UAClB,EAAYA,EAAe,UAAU;AAAA,UAC3B,YAAYA,EAAe,kBAAkB,WAAW;AAAA,QAClE;AAAA,QACQ,UAA0B,gBAAAz2C;AAAA,UACxB22C;AAAAA,UACA;AAAA,YACE,GAAGlE;AAAA,YACH,KAAKpxC;AAAA,YACL,OAAO;AAAA,cACL,GAAGoxC,EAAW;AAAA;AAAA,cAEd,SAAS;AAAA,YACvB;AAAA,UACA;AAAA,QACA;AAAA,MACA;AAAA,IACA;AAAA;AAEA,CAAC;AACD+D,GAAY,cAAcF;AAC1B,SAAShB,GAAUl2C,GAAO;AACxB,SAAOA,MAAU;AACnB;AACA,IAAIw2C,KAAkB,CAACl0B,OAAa;AAAA,EAClC,MAAM;AAAA,EACN,SAAAA;AAAA,EACA,GAAGzL,GAAM;AACP,UAAM,EAAE,WAAA4c,GAAW,OAAAgK,GAAO,gBAAA0D,EAAc,IAAKtqB,GAEvC2gC,IADoBrW,EAAe,OAAO,iBAAiB,GAE3D0U,IAAa2B,IAAgB,IAAIl1B,EAAQ,YACzCwzB,IAAc0B,IAAgB,IAAIl1B,EAAQ,aAC1C,CAACm0B,GAAYC,CAAW,IAAIC,GAA6BljB,CAAS,GAClEgkB,IAAe,EAAE,OAAO,MAAM,QAAQ,OAAO,KAAK,OAAM,EAAGf,CAAW,GACtEgB,KAAgBvW,EAAe,OAAO,KAAK,KAAK0U,IAAa,GAC7D8B,KAAgBxW,EAAe,OAAO,KAAK,KAAK2U,IAAc;AACpE,QAAI5W,IAAI,IACJC,IAAI;AACR,WAAIsX,MAAe,YACjBvX,IAAIsY,IAAgBC,IAAe,GAAGC,CAAY,MAClDvY,IAAI,GAAG,CAAC2W,CAAW,QACVW,MAAe,SACxBvX,IAAIsY,IAAgBC,IAAe,GAAGC,CAAY,MAClDvY,IAAI,GAAG1B,EAAM,SAAS,SAASqY,CAAW,QACjCW,MAAe,WACxBvX,IAAI,GAAG,CAAC4W,CAAW,MACnB3W,IAAIqY,IAAgBC,IAAe,GAAGE,CAAY,QACzClB,MAAe,WACxBvX,IAAI,GAAGzB,EAAM,SAAS,QAAQqY,CAAW,MACzC3W,IAAIqY,IAAgBC,IAAe,GAAGE,CAAY,OAE7C,EAAE,MAAM,EAAE,GAAAzY,GAAG,GAAAC,EAAC,EAAE;AAAA,EACzB;AACF;AACA,SAASwX,GAA6BljB,GAAW;AAC/C,QAAM,CAAC+K,GAAMuW,IAAQ,QAAQ,IAAIthB,EAAU,MAAM,GAAG;AACpD,SAAO,CAAC+K,GAAMuW,CAAK;AACrB;AACA,IAAI6C,KAAQ5D,IACR6D,KAASxD,IACTyD,KAAUjD,IACVzB,KAAQgE,IC7RRW,KAAc,UACdC,KAAS17C,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACrD,QAAM,EAAE,WAAWg2C,GAAe,GAAGC,EAAW,IAAK77C,GAC/C,CAAC87C,GAASC,CAAU,IAAI97C,EAAM,SAAS,EAAK;AAClDq5B,EAAAA,GAAgB,MAAMyiB,EAAW,EAAI,GAAG,CAAA,CAAE;AAC1C,QAAMxiB,IAAYqiB,KAAiBE,KAAW,YAAY,UAAU;AACpE,SAAOviB,IAAYgD,GAAS,aAA6B,gBAAAh4B,EAAI03B,GAAU,KAAK,EAAE,GAAG4f,GAAa,KAAKj2C,EAAY,CAAE,GAAG2zB,CAAS,IAAI;AACnI,CAAC;AACDoiB,GAAO,cAAcD;ACPrB,SAASM,GAAgBC,GAAcC,GAAS;AAC9C,SAAOj8C,EAAM,WAAW,CAACsnB,GAAOkD,MACZyxB,EAAQ30B,CAAK,EAAEkD,CAAK,KAClBlD,GACnB00B,CAAY;AACjB;AAGA,IAAIE,KAAW,CAACn8C,MAAU;AACxB,QAAM,EAAE,SAAAo8C,GAAS,UAAAl4C,EAAQ,IAAKlE,GACxBq8C,IAAWC,GAAYF,CAAO,GAC9Bj2C,IAAQ,OAAOjC,KAAa,aAAaA,EAAS,EAAE,SAASm4C,EAAS,UAAS,CAAE,IAAIl3B,EAAO,SAAS,KAAKjhB,CAAQ,GAClHO,IAAMQ,GAAgBo3C,EAAS,KAAK/1C,GAAcH,CAAK,CAAC;AAE9D,SADmB,OAAOjC,KAAa,cAClBm4C,EAAS,YAAYl3B,EAAO,aAAahf,GAAO,EAAE,KAAA1B,EAAG,CAAE,IAAI;AAClF;AACA03C,GAAS,cAAc;AACvB,SAASG,GAAYF,GAAS;AAC5B,QAAM,CAACx3C,GAAM84B,CAAO,IAAIvY,EAAO,SAAQ,GACjCo3B,IAAYp3B,EAAO,OAAO,IAAI,GAC9Bq3B,IAAiBr3B,EAAO,OAAOi3B,CAAO,GACtCK,IAAuBt3B,EAAO,OAAO,MAAM,GAC3C82B,IAAeG,IAAU,YAAY,aACrC,CAAC70B,GAAOm1B,CAAI,IAAIV,GAAgBC,GAAc;AAAA,IAClD,SAAS;AAAA,MACP,SAAS;AAAA,MACT,eAAe;AAAA,IACrB;AAAA,IACI,kBAAkB;AAAA,MAChB,OAAO;AAAA,MACP,eAAe;AAAA,IACrB;AAAA,IACI,WAAW;AAAA,MACT,OAAO;AAAA,IACb;AAAA,EACA,CAAG;AACD92B,SAAAA,EAAO,UAAU,MAAM;AACrB,UAAMw3B,IAAuBC,GAAiBL,EAAU,OAAO;AAC/D,IAAAE,EAAqB,UAAUl1B,MAAU,YAAYo1B,IAAuB;AAAA,EAC9E,GAAG,CAACp1B,CAAK,CAAC,GACV+R,GAAgB,MAAM;AACpB,UAAM5hB,IAAS6kC,EAAU,SACnBM,IAAaL,EAAe;AAElC,QAD0BK,MAAeT,GAClB;AACrB,YAAMU,IAAoBL,EAAqB,SACzCE,IAAuBC,GAAiBllC,CAAM;AACpD,MAAI0kC,IACFM,EAAK,OAAO,IACHC,MAAyB,UAAUjlC,GAAQ,YAAY,SAChEglC,EAAK,SAAS,IAIZA,EADEG,KADgBC,MAAsBH,IAEnC,kBAEA,SAFe,GAKxBH,EAAe,UAAUJ;AAAA,IAC3B;AAAA,EACF,GAAG,CAACA,GAASM,CAAI,CAAC,GAClBpjB,GAAgB,MAAM;AACpB,QAAI10B,GAAM;AACR,UAAIqtC;AACJ,YAAM8K,IAAcn4C,EAAK,cAAc,eAAe,QAChDo4C,IAAqB,CAACvyB,MAAU;AAEpC,cAAMwyB,IADuBL,GAAiBL,EAAU,OAAO,EACf,SAAS,IAAI,OAAO9xB,EAAM,aAAa,CAAC;AACxF,YAAIA,EAAM,WAAW7lB,KAAQq4C,MAC3BP,EAAK,eAAe,GAChB,CAACF,EAAe,UAAS;AAC3B,gBAAMU,IAAkBt4C,EAAK,MAAM;AACnC,UAAAA,EAAK,MAAM,oBAAoB,YAC/BqtC,IAAY8K,EAAY,WAAW,MAAM;AACvC,YAAIn4C,EAAK,MAAM,sBAAsB,eACnCA,EAAK,MAAM,oBAAoBs4C;AAAA,UAEnC,CAAC;AAAA,QACH;AAAA,MAEJ,GACMC,IAAuB,CAAC1yB,MAAU;AACtC,QAAIA,EAAM,WAAW7lB,MACnB63C,EAAqB,UAAUG,GAAiBL,EAAU,OAAO;AAAA,MAErE;AACA,aAAA33C,EAAK,iBAAiB,kBAAkBu4C,CAAoB,GAC5Dv4C,EAAK,iBAAiB,mBAAmBo4C,CAAkB,GAC3Dp4C,EAAK,iBAAiB,gBAAgBo4C,CAAkB,GACjD,MAAM;AACX,QAAAD,EAAY,aAAa9K,CAAS,GAClCrtC,EAAK,oBAAoB,kBAAkBu4C,CAAoB,GAC/Dv4C,EAAK,oBAAoB,mBAAmBo4C,CAAkB,GAC9Dp4C,EAAK,oBAAoB,gBAAgBo4C,CAAkB;AAAA,MAC7D;AAAA,IACF;AACE,MAAAN,EAAK,eAAe;AAAA,EAExB,GAAG,CAAC93C,GAAM83C,CAAI,CAAC,GACR;AAAA,IACL,WAAW,CAAC,WAAW,kBAAkB,EAAE,SAASn1B,CAAK;AAAA,IACzD,KAAKpC,EAAO,YAAY,CAAC0Y,MAAU;AACjC,MAAA0e,EAAU,UAAU1e,IAAQ,iBAAiBA,CAAK,IAAI,MACtDH,EAAQG,CAAK;AAAA,IACf,GAAG,CAAA,CAAE;AAAA,EACT;AACA;AACA,SAAS+e,GAAiBllC,GAAQ;AAChC,SAAOA,GAAQ,iBAAiB;AAClC;AACA,SAASpR,GAAchB,GAAS;AAC9B,MAAI2B,IAAS,OAAO,yBAAyB3B,EAAQ,OAAO,KAAK,GAAG,KAChE4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO;AAC7D,SAAIC,IACK5B,EAAQ,OAEjB2B,IAAS,OAAO,yBAAyB3B,GAAS,KAAK,GAAG,KAC1D4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO,gBACrDC,IACK5B,EAAQ,MAAM,MAEhBA,EAAQ,MAAM,OAAOA,EAAQ;AACtC;ACtFA,IAAImB,KAAuB,uBAAO,iBAAiB;AAAA;AAEnD,SAAS22C,GAAgB53C,GAAW;AAClC,QAAM63C,IAAa,CAAC,EAAE,UAAAn5C,QACG,gBAAAK,EAAI+4C,IAAW,EAAE,UAAAp5C,GAAU;AAEpD,SAAAm5C,EAAW,cAAc,GAAG73C,CAAS,cACrC63C,EAAW,YAAY52C,IAChB42C;AACT;ACpDA,IAAIE,KAAqBt9C,EAAM,uBAAuB,KAAI,EAAG,SAAQ,CAAE,KAAKq5B;AAC5E,SAASkkB,GAAqB;AAAA,EAC5B,MAAAC;AAAA,EACA,aAAAC;AAAA,EACA,UAAA/iC,IAAW,MAAM;AAAA,EACjB;AAAA,EACA,QAAAgjC;AACF,GAAG;AACD,QAAM,CAACC,GAAkBC,GAAqBC,CAAW,IAAIC,GAAqB;AAAA,IAChF,aAAAL;AAAA,IACA,UAAA/iC;AAAA,EACJ,CAAG,GACK0d,IAAeolB,MAAS,QACxB95C,IAAQ00B,IAAeolB,IAAOG;AAC1B;AACR,UAAMI,IAAkB/9C,EAAM,OAAOw9C,MAAS,MAAM;AACpD,IAAAx9C,EAAM,UAAU,MAAM;AACpB,YAAMg+C,IAAgBD,EAAgB;AACtC,MAAIC,MAAkB5lB,KAGpB,QAAQ;AAAA,QACN,GAAGslB,CAAM,qBAHEM,IAAgB,eAAe,cAGR,OAFzB5lB,IAAe,eAAe,cAEI;AAAA,MACrD,GAEM2lB,EAAgB,UAAU3lB;AAAA,IAC5B,GAAG,CAACA,GAAcslB,CAAM,CAAC;AAAA,EAC3B;AACA,QAAMO,IAAWj+C,EAAM;AAAA,IACrB,CAACk+C,MAAc;AACb,UAAI9lB,GAAc;AAChB,cAAM+lB,IAASC,GAAWF,CAAS,IAAIA,EAAUV,CAAI,IAAIU;AACzD,QAAIC,MAAWX,KACbK,EAAY,UAAUM,CAAM;AAAA,MAEhC;AACE,QAAAP,EAAoBM,CAAS;AAAA,IAEjC;AAAA,IACA,CAAC9lB,GAAcolB,GAAMI,GAAqBC,CAAW;AAAA,EACzD;AACE,SAAO,CAACn6C,GAAOu6C,CAAQ;AACzB;AACA,SAASH,GAAqB;AAAA,EAC5B,aAAAL;AAAA,EACA,UAAA/iC;AACF,GAAG;AACD,QAAM,CAAChX,GAAOu6C,CAAQ,IAAIj+C,EAAM,SAASy9C,CAAW,GAC9CY,IAAer+C,EAAM,OAAO0D,CAAK,GACjCm6C,IAAc79C,EAAM,OAAO0a,CAAQ;AACzC4iC,SAAAA,GAAmB,MAAM;AACvB,IAAAO,EAAY,UAAUnjC;AAAA,EACxB,GAAG,CAACA,CAAQ,CAAC,GACb1a,EAAM,UAAU,MAAM;AACpB,IAAIq+C,EAAa,YAAY36C,MAC3Bm6C,EAAY,UAAUn6C,CAAK,GAC3B26C,EAAa,UAAU36C;AAAA,EAE3B,GAAG,CAACA,GAAO26C,CAAY,CAAC,GACjB,CAAC36C,GAAOu6C,GAAUJ,CAAW;AACtC;AACA,SAASO,GAAW16C,GAAO;AACzB,SAAO,OAAOA,KAAU;AAC1B;AC9DA,IAAI46C,KAAyB,OAAO,OAAO;AAAA;AAAA,EAEzC,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,MAAM;AAAA,EACN,YAAY;AAAA,EACZ,UAAU;AACZ,CAAC,GACGzH,KAAO,kBACP0H,KAAiBv+C,EAAM;AAAA,EACzB,CAACD,GAAO4F,MACiB,gBAAArB;AAAA,IACrB03B,GAAU;AAAA,IACV;AAAA,MACE,GAAGj8B;AAAA,MACH,KAAK4F;AAAA,MACL,OAAO,EAAE,GAAG24C,IAAwB,GAAGv+C,EAAM,MAAK;AAAA,IAC1D;AAAA,EACA;AAEA;AACAw+C,GAAe,cAAc1H;AAC7B,IAAIG,KAAOuH,ICbP,CAACC,EAAwC,IAAI7jB,GAAmB,WAAW;AAAA,EAC7E4c;AACF,CAAC,GACGkH,KAAiBlH,GAAiB,GAClCmH,KAAgB,mBAChBC,KAAyB,KACzBC,KAAe,gBACf,CAACC,IAAgCC,EAAyB,IAAIN,GAAqBE,EAAa,GAChGK,KAAkB,CAACh/C,MAAU;AAC/B,QAAM;AAAA,IACJ,gBAAAi/C;AAAA,IACA,eAAAC,IAAgBN;AAAA,IAChB,mBAAAO,IAAoB;AAAA,IACpB,yBAAAC,IAA0B;AAAA,IAC1B,UAAAl7C;AAAA,EACJ,IAAMlE,GACEq/C,IAAmBp/C,EAAM,OAAO,EAAI,GACpCq/C,IAAwBr/C,EAAM,OAAO,EAAK,GAC1Cs/C,IAAoBt/C,EAAM,OAAO,CAAC;AACxC,SAAAA,EAAM,UAAU,MAAM;AACpB,UAAMu/C,IAAiBD,EAAkB;AACzC,WAAO,MAAM,OAAO,aAAaC,CAAc;AAAA,EACjD,GAAG,CAAA,CAAE,GACkB,gBAAAj7C;AAAA,IACrBu6C;AAAA,IACA;AAAA,MACE,OAAOG;AAAA,MACP,kBAAAI;AAAA,MACA,eAAAH;AAAA,MACA,QAAQj/C,EAAM,YAAY,MAAM;AAC9B,eAAO,aAAas/C,EAAkB,OAAO,GAC7CF,EAAiB,UAAU;AAAA,MAC7B,GAAG,CAAA,CAAE;AAAA,MACL,SAASp/C,EAAM,YAAY,MAAM;AAC/B,eAAO,aAAas/C,EAAkB,OAAO,GAC7CA,EAAkB,UAAU,OAAO;AAAA,UACjC,MAAMF,EAAiB,UAAU;AAAA,UACjCF;AAAA,QACV;AAAA,MACM,GAAG,CAACA,CAAiB,CAAC;AAAA,MACtB,uBAAAG;AAAA,MACA,0BAA0Br/C,EAAM,YAAY,CAACw/C,MAAc;AACzD,QAAAH,EAAsB,UAAUG;AAAA,MAClC,GAAG,CAAA,CAAE;AAAA,MACL,yBAAAL;AAAA,MACA,UAAAl7C;AAAA,IACN;AAAA,EACA;AACA;AACA86C,GAAgB,cAAcL;AAC9B,IAAIe,KAAe,WACf,CAACC,IAAwBC,EAAiB,IAAInB,GAAqBiB,EAAY,GAC/EG,KAAU,CAAC7/C,MAAU;AACvB,QAAM;AAAA,IACJ,gBAAAi/C;AAAA,IACA,UAAA/6C;AAAA,IACA,MAAM2zB;AAAA,IACN,aAAAC;AAAA,IACA,cAAAG;AAAA,IACA,yBAAyB6nB;AAAA,IACzB,eAAeC;AAAA,EACnB,IAAM//C,GACEggD,IAAkBjB,GAA0BW,IAAc1/C,EAAM,cAAc,GAC9EigD,IAAcvB,GAAeO,CAAc,GAC3C,CAACjlC,GAASkmC,CAAU,IAAIjgD,EAAM,SAAS,IAAI,GAC3CkgD,IAAYtgB,GAAK,GACjBugB,IAAengD,EAAM,OAAO,CAAC,GAC7Bm/C,IAA0BU,KAA+BE,EAAgB,yBACzEd,IAAgBa,KAAqBC,EAAgB,eACrDK,IAAoBpgD,EAAM,OAAO,EAAK,GACtC,CAACu4B,GAAMC,CAAO,IAAI+kB,GAAqB;AAAA,IAC3C,MAAM3lB;AAAA,IACN,aAAaC,KAAe;AAAA,IAC5B,UAAU,CAACwoB,MAAU;AACnB,MAAIA,KACFN,EAAgB,OAAM,GACtB,SAAS,cAAc,IAAI,YAAYnB,EAAY,CAAC,KAEpDmB,EAAgB,QAAO,GAEzB/nB,IAAeqoB,CAAK;AAAA,IACtB;AAAA,IACA,QAAQZ;AAAA,EACZ,CAAG,GACKa,IAAiBtgD,EAAM,QAAQ,MAC5Bu4B,IAAO6nB,EAAkB,UAAU,iBAAiB,iBAAiB,UAC3E,CAAC7nB,CAAI,CAAC,GACHgoB,IAAavgD,EAAM,YAAY,MAAM;AACzC,WAAO,aAAamgD,EAAa,OAAO,GACxCA,EAAa,UAAU,GACvBC,EAAkB,UAAU,IAC5B5nB,EAAQ,EAAI;AAAA,EACd,GAAG,CAACA,CAAO,CAAC,GACNgoB,IAAcxgD,EAAM,YAAY,MAAM;AAC1C,WAAO,aAAamgD,EAAa,OAAO,GACxCA,EAAa,UAAU,GACvB3nB,EAAQ,EAAK;AAAA,EACf,GAAG,CAACA,CAAO,CAAC,GACNioB,IAAoBzgD,EAAM,YAAY,MAAM;AAChD,WAAO,aAAamgD,EAAa,OAAO,GACxCA,EAAa,UAAU,OAAO,WAAW,MAAM;AAC7C,MAAAC,EAAkB,UAAU,IAC5B5nB,EAAQ,EAAI,GACZ2nB,EAAa,UAAU;AAAA,IACzB,GAAGlB,CAAa;AAAA,EAClB,GAAG,CAACA,GAAezmB,CAAO,CAAC;AAC3B,SAAAx4B,EAAM,UAAU,MACP,MAAM;AACX,IAAImgD,EAAa,YACf,OAAO,aAAaA,EAAa,OAAO,GACxCA,EAAa,UAAU;AAAA,EAE3B,GACC,CAAA,CAAE,GACkB,gBAAA77C,EAAIo8C,IAAsB,EAAE,GAAGV,GAAa,UAA0B,gBAAA17C;AAAA,IAC3Fo7C;AAAA,IACA;AAAA,MACE,OAAOV;AAAA,MACP,WAAAkB;AAAA,MACA,MAAA3nB;AAAA,MACA,gBAAA+nB;AAAA,MACA,SAAAvmC;AAAA,MACA,iBAAiBkmC;AAAA,MACjB,gBAAgBjgD,EAAM,YAAY,MAAM;AACtC,QAAI+/C,EAAgB,iBAAiB,UAASU,EAAiB,IAC1DF,EAAU;AAAA,MACjB,GAAG,CAACR,EAAgB,kBAAkBU,GAAmBF,CAAU,CAAC;AAAA,MACpE,gBAAgBvgD,EAAM,YAAY,MAAM;AACtC,QAAIm/C,IACFqB,EAAW,KAEX,OAAO,aAAaL,EAAa,OAAO,GACxCA,EAAa,UAAU;AAAA,MAE3B,GAAG,CAACK,GAAarB,CAAuB,CAAC;AAAA,MACzC,QAAQoB;AAAA,MACR,SAASC;AAAA,MACT,yBAAArB;AAAA,MACA,UAAAl7C;AAAA,IACN;AAAA,EACA,GAAK;AACL;AACA27C,GAAQ,cAAcH;AACtB,IAAIkB,KAAe,kBACfC,KAAiB5gD,EAAM;AAAA,EACzB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,gBAAAq5C,GAAgB,GAAG6B,EAAY,IAAK9gD,GACtCguB,IAAU4xB,GAAkBgB,IAAc3B,CAAc,GACxDe,IAAkBjB,GAA0B6B,IAAc3B,CAAc,GACxEgB,IAAcvB,GAAeO,CAAc,GAC3Cx6C,IAAMxE,EAAM,OAAO,IAAI,GACvB29B,IAAe34B,GAAgBW,GAAcnB,GAAKupB,EAAQ,eAAe,GACzE+yB,IAAmB9gD,EAAM,OAAO,EAAK,GACrC+gD,IAA0B/gD,EAAM,OAAO,EAAK,GAC5CghD,IAAkBhhD,EAAM,YAAY,MAAM8gD,EAAiB,UAAU,IAAO,EAAE;AACpF,WAAA9gD,EAAM,UAAU,MACP,MAAM,SAAS,oBAAoB,aAAaghD,CAAe,GACrE,CAACA,CAAe,CAAC,GACG,gBAAA18C,EAAI28C,IAAwB,EAAE,SAAS,IAAM,GAAGjB,GAAa,UAA0B,gBAAA17C;AAAA,MAC5G03B,GAAU;AAAA,MACV;AAAA,QACE,oBAAoBjO,EAAQ,OAAOA,EAAQ,YAAY;AAAA,QACvD,cAAcA,EAAQ;AAAA,QACtB,GAAG8yB;AAAA,QACH,KAAKljB;AAAA,QACL,eAAetO,GAAqBtvB,EAAM,eAAe,CAACyqB,MAAU;AAClE,UAAIA,EAAM,gBAAgB,WACtB,CAACu2B,EAAwB,WAAW,CAAChB,EAAgB,sBAAsB,YAC7EhyB,EAAQ,eAAc,GACtBgzB,EAAwB,UAAU;AAAA,QAEtC,CAAC;AAAA,QACD,gBAAgB1xB,GAAqBtvB,EAAM,gBAAgB,MAAM;AAC/D,UAAAguB,EAAQ,eAAc,GACtBgzB,EAAwB,UAAU;AAAA,QACpC,CAAC;AAAA,QACD,eAAe1xB,GAAqBtvB,EAAM,eAAe,MAAM;AAC7D,UAAIguB,EAAQ,QACVA,EAAQ,QAAO,GAEjB+yB,EAAiB,UAAU,IAC3B,SAAS,iBAAiB,aAAaE,GAAiB,EAAE,MAAM,IAAM;AAAA,QACxE,CAAC;AAAA,QACD,SAAS3xB,GAAqBtvB,EAAM,SAAS,MAAM;AACjD,UAAK+gD,EAAiB,WAAS/yB,EAAQ,OAAM;AAAA,QAC/C,CAAC;AAAA,QACD,QAAQsB,GAAqBtvB,EAAM,QAAQguB,EAAQ,OAAO;AAAA,QAC1D,SAASsB,GAAqBtvB,EAAM,SAASguB,EAAQ,OAAO;AAAA,MACpE;AAAA,IACA,GAAO;AAAA,EACL;AACF;AACA6yB,GAAe,cAAcD;AAC7B,IAAIlF,KAAc,iBACd,CAACyF,IAAgBC,EAAgB,IAAI3C,GAAqB/C,IAAa;AAAA,EACzE,YAAY;AACd,CAAC,GACG2F,KAAgB,CAACrhD,MAAU;AAC7B,QAAM,EAAE,gBAAAi/C,GAAgB,YAAAqC,GAAY,UAAAp9C,GAAU,WAAAq1B,EAAS,IAAKv5B,GACtDguB,IAAU4xB,GAAkBlE,IAAauD,CAAc;AAC7D,SAAuB,gBAAA16C,EAAI48C,IAAgB,EAAE,OAAOlC,GAAgB,YAAAqC,GAAY,UAA0B,gBAAA/8C,EAAI43C,IAAU,EAAE,SAASmF,KAActzB,EAAQ,MAAM,UAA0B,gBAAAzpB,EAAIg9C,IAAiB,EAAE,SAAS,IAAM,WAAAhoB,GAAW,UAAAr1B,GAAU,EAAC,CAAE,EAAC,CAAE;AAC5P;AACAm9C,GAAc,cAAc3F;AAC5B,IAAIrD,KAAe,kBACfmJ,KAAiBvhD,EAAM;AAAA,EACzB,CAACD,GAAO4F,MAAiB;AACvB,UAAM67C,IAAgBL,GAAiB/I,IAAcr4C,EAAM,cAAc,GACnE,EAAE,YAAAshD,IAAaG,EAAc,YAAY,MAAAtf,IAAO,OAAO,GAAGiX,EAAY,IAAKp5C,GAC3EguB,IAAU4xB,GAAkBvH,IAAcr4C,EAAM,cAAc;AACpE,WAAuB,gBAAAuE,EAAI43C,IAAU,EAAE,SAASmF,KAActzB,EAAQ,MAAM,UAAUA,EAAQ,0BAA0C,gBAAAzpB,EAAIm9C,IAAoB,EAAE,MAAAvf,GAAM,GAAGiX,GAAc,KAAKxzC,GAAc,IAAoB,gBAAArB,EAAIo9C,IAAyB,EAAE,MAAAxf,GAAM,GAAGiX,GAAc,KAAKxzC,EAAY,CAAE,EAAC,CAAE;AAAA,EAC9S;AACF,GACI+7C,KAA0B1hD,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACtE,QAAMooB,IAAU4xB,GAAkBvH,IAAcr4C,EAAM,cAAc,GAC9DggD,IAAkBjB,GAA0B1G,IAAcr4C,EAAM,cAAc,GAC9EyE,IAAMxE,EAAM,OAAO,IAAI,GACvB29B,IAAe34B,GAAgBW,GAAcnB,CAAG,GAChD,CAACm9C,GAAkBC,CAAmB,IAAI5hD,EAAM,SAAS,IAAI,GAC7D,EAAE,SAAA+Z,GAAS,SAAA8nC,EAAO,IAAK9zB,GACvBtjB,IAAUjG,EAAI,SACd,EAAE,0BAAAs9C,EAAwB,IAAK/B,GAC/BgC,IAAwB/hD,EAAM,YAAY,MAAM;AACpD,IAAA4hD,EAAoB,IAAI,GACxBE,EAAyB,EAAK;AAAA,EAChC,GAAG,CAACA,CAAwB,CAAC,GACvBE,IAAwBhiD,EAAM;AAAA,IAClC,CAACwqB,GAAOy3B,MAAgB;AACtB,YAAMC,IAAgB13B,EAAM,eACtB23B,IAAY,EAAE,GAAG33B,EAAM,SAAS,GAAGA,EAAM,QAAO,GAChD43B,IAAWC,GAAoBF,GAAWD,EAAc,sBAAqB,CAAE,GAC/EI,IAAmBC,GAAoBJ,GAAWC,CAAQ,GAC1DI,IAAoBC,GAAkBR,EAAY,sBAAqB,CAAE,GACzES,IAAYC,GAAQ,CAAC,GAAGL,GAAkB,GAAGE,CAAiB,CAAC;AACrE,MAAAZ,EAAoBc,CAAS,GAC7BZ,EAAyB,EAAI;AAAA,IAC/B;AAAA,IACA,CAACA,CAAwB;AAAA,EAC7B;AACE,SAAA9hD,EAAM,UAAU,MACP,MAAM+hD,EAAqB,GACjC,CAACA,CAAqB,CAAC,GAC1B/hD,EAAM,UAAU,MAAM;AACpB,QAAI+Z,KAAWtP,GAAS;AACtB,YAAMm4C,IAAqB,CAACp4B,MAAUw3B,EAAsBx3B,GAAO/f,CAAO,GACpEo4C,IAAqB,CAACr4B,MAAUw3B,EAAsBx3B,GAAOzQ,CAAO;AAC1E,aAAAA,EAAQ,iBAAiB,gBAAgB6oC,CAAkB,GAC3Dn4C,EAAQ,iBAAiB,gBAAgBo4C,CAAkB,GACpD,MAAM;AACX,QAAA9oC,EAAQ,oBAAoB,gBAAgB6oC,CAAkB,GAC9Dn4C,EAAQ,oBAAoB,gBAAgBo4C,CAAkB;AAAA,MAChE;AAAA,IACF;AAAA,EACF,GAAG,CAAC9oC,GAAStP,GAASu3C,GAAuBD,CAAqB,CAAC,GACnE/hD,EAAM,UAAU,MAAM;AACpB,QAAI2hD,GAAkB;AACpB,YAAMmB,IAA0B,CAACt4B,MAAU;AACzC,cAAME,IAASF,EAAM,QACfu4B,IAAkB,EAAE,GAAGv4B,EAAM,SAAS,GAAGA,EAAM,QAAO,GACtDw4B,IAAmBjpC,GAAS,SAAS2Q,CAAM,KAAKjgB,GAAS,SAASigB,CAAM,GACxEu4B,IAA4B,CAACC,GAAiBH,GAAiBpB,CAAgB;AACrF,QAAIqB,IACFjB,EAAqB,IACZkB,MACTlB,EAAqB,GACrBF,EAAO;AAAA,MAEX;AACA,sBAAS,iBAAiB,eAAeiB,CAAuB,GACzD,MAAM,SAAS,oBAAoB,eAAeA,CAAuB;AAAA,IAClF;AAAA,EACF,GAAG,CAAC/oC,GAAStP,GAASk3C,GAAkBE,GAASE,CAAqB,CAAC,GAChD,gBAAAz9C,EAAIm9C,IAAoB,EAAE,GAAG1hD,GAAO,KAAK49B,GAAc;AAChF,CAAC,GACG,CAACwlB,IAAsCC,EAA+B,IAAI5E,GAAqBiB,IAAc,EAAE,UAAU,IAAO,GAChI4D,KAAY,gBAAAlG,GAAgB,gBAAgB,GAC5CsE,KAAqBzhD,EAAM;AAAA,EAC7B,CAACD,GAAO4F,MAAiB;AACvB,UAAM;AAAA,MACJ,gBAAAq5C;AAAA,MACA,UAAA/6C;AAAA,MACA,cAAc61B;AAAA,MACd,iBAAA6C;AAAA,MACA,sBAAAS;AAAA,MACA,GAAG+b;AAAA,IACT,IAAQp5C,GACEguB,IAAU4xB,GAAkBvH,IAAc4G,CAAc,GACxDgB,IAAcvB,GAAeO,CAAc,GAC3C,EAAE,SAAA6C,EAAO,IAAK9zB;AACpB,WAAA/tB,EAAM,UAAU,OACd,SAAS,iBAAiB4+C,IAAciD,CAAO,GACxC,MAAM,SAAS,oBAAoBjD,IAAciD,CAAO,IAC9D,CAACA,CAAO,CAAC,GACZ7hD,EAAM,UAAU,MAAM;AACpB,UAAI+tB,EAAQ,SAAS;AACnB,cAAMu1B,IAAe,CAAC94B,MAAU;AAE9B,UADeA,EAAM,QACT,SAASuD,EAAQ,OAAO,KAAG8zB,EAAO;AAAA,QAChD;AACA,sBAAO,iBAAiB,UAAUyB,GAAc,EAAE,SAAS,IAAM,GAC1D,MAAM,OAAO,oBAAoB,UAAUA,GAAc,EAAE,SAAS,IAAM;AAAA,MACnF;AAAA,IACF,GAAG,CAACv1B,EAAQ,SAAS8zB,CAAO,CAAC,GACN,gBAAAv9C;AAAA,MACrB44B;AAAA,MACA;AAAA,QACE,SAAS;AAAA,QACT,6BAA6B;AAAA,QAC7B,iBAAAP;AAAA,QACA,sBAAAS;AAAA,QACA,gBAAgB,CAAC5S,MAAUA,EAAM,eAAc;AAAA,QAC/C,WAAWq3B;AAAA,QACX,UAA0B,gBAAA19C;AAAA,UACxBo/C;AAAAA,UACA;AAAA,YACE,cAAcx1B,EAAQ;AAAA,YACtB,GAAGiyB;AAAA,YACH,GAAG7G;AAAA,YACH,KAAKxzC;AAAA,YACL,OAAO;AAAA,cACL,GAAGwzC,EAAa;AAAA,cAGd,4CAA4C;AAAA,cAC5C,2CAA2C;AAAA,cAC3C,4CAA4C;AAAA,cAC5C,iCAAiC;AAAA,cACjC,kCAAkC;AAAA,YAElD;AAAA,YACY,UAAU;AAAA,cACQ,gBAAA70C,EAAI++C,IAAW,EAAE,UAAAp/C,GAAU;AAAA,cAC3B,gBAAAK,EAAI6+C,IAAsC,EAAE,OAAOnE,GAAgB,UAAU,IAAM,UAA0B,gBAAA16C,EAAIk/C,IAA8B,EAAE,IAAIz1B,EAAQ,WAAW,MAAM,WAAW,UAAU+L,KAAa71B,EAAQ,CAAE,EAAC,CAAE;AAAA,YAC3P;AAAA,UACA;AAAA,QACA;AAAA,MACA;AAAA,IACA;AAAA,EACE;AACF;AACAs9C,GAAe,cAAcnJ;AAC7B,IAAIwC,KAAa,gBACb6I,KAAezjD,EAAM;AAAA,EACvB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,gBAAAq5C,GAAgB,GAAGjI,EAAU,IAAKh3C,GACpCigD,IAAcvB,GAAeO,CAAc;AAKjD,WAJqCoE;AAAA,MACnCxI;AAAAA,MACAoE;AAAA,IACN,EACwC,WAAW,OAAuB,gBAAA16C,EAAIo/C,IAAuB,EAAE,GAAG1D,GAAa,GAAGjJ,GAAY,KAAKpxC,EAAY,CAAE;AAAA,EACvJ;AACF;AACA89C,GAAa,cAAc7I;AAC3B,SAASyH,GAAoBsB,GAAOzsB,GAAM;AACxC,QAAMI,IAAM,KAAK,IAAIJ,EAAK,MAAMysB,EAAM,CAAC,GACjCpsB,IAAS,KAAK,IAAIL,EAAK,SAASysB,EAAM,CAAC,GACvCtsB,IAAQ,KAAK,IAAIH,EAAK,QAAQysB,EAAM,CAAC,GACrCvsB,IAAO,KAAK,IAAIF,EAAK,OAAOysB,EAAM,CAAC;AACzC,UAAQ,KAAK,IAAIrsB,GAAKC,GAAQF,GAAOD,CAAI,GAAC;AAAA,IACxC,KAAKA;AACH,aAAO;AAAA,IACT,KAAKC;AACH,aAAO;AAAA,IACT,KAAKC;AACH,aAAO;AAAA,IACT,KAAKC;AACH,aAAO;AAAA,IACT;AACE,YAAM,IAAI,MAAM,aAAa;AAAA,EACnC;AACA;AACA,SAASgrB,GAAoBJ,GAAWC,GAAU3f,IAAU,GAAG;AAC7D,QAAM6f,IAAmB,CAAA;AACzB,UAAQF,GAAQ;AAAA,IACd,KAAK;AACH,MAAAE,EAAiB;AAAA,QACf,EAAE,GAAGH,EAAU,IAAI1f,GAAS,GAAG0f,EAAU,IAAI1f,EAAO;AAAA,QACpD,EAAE,GAAG0f,EAAU,IAAI1f,GAAS,GAAG0f,EAAU,IAAI1f,EAAO;AAAA,MAC5D;AACM;AAAA,IACF,KAAK;AACH,MAAA6f,EAAiB;AAAA,QACf,EAAE,GAAGH,EAAU,IAAI1f,GAAS,GAAG0f,EAAU,IAAI1f,EAAO;AAAA,QACpD,EAAE,GAAG0f,EAAU,IAAI1f,GAAS,GAAG0f,EAAU,IAAI1f,EAAO;AAAA,MAC5D;AACM;AAAA,IACF,KAAK;AACH,MAAA6f,EAAiB;AAAA,QACf,EAAE,GAAGH,EAAU,IAAI1f,GAAS,GAAG0f,EAAU,IAAI1f,EAAO;AAAA,QACpD,EAAE,GAAG0f,EAAU,IAAI1f,GAAS,GAAG0f,EAAU,IAAI1f,EAAO;AAAA,MAC5D;AACM;AAAA,IACF,KAAK;AACH,MAAA6f,EAAiB;AAAA,QACf,EAAE,GAAGH,EAAU,IAAI1f,GAAS,GAAG0f,EAAU,IAAI1f,EAAO;AAAA,QACpD,EAAE,GAAG0f,EAAU,IAAI1f,GAAS,GAAG0f,EAAU,IAAI1f,EAAO;AAAA,MAC5D;AACM;AAAA,EACN;AACE,SAAO6f;AACT;AACA,SAASG,GAAkBvrB,GAAM;AAC/B,QAAM,EAAE,KAAAI,GAAK,OAAAD,GAAO,QAAAE,GAAQ,MAAAH,EAAI,IAAKF;AACrC,SAAO;AAAA,IACL,EAAE,GAAGE,GAAM,GAAGE,EAAG;AAAA,IACjB,EAAE,GAAGD,GAAO,GAAGC,EAAG;AAAA,IAClB,EAAE,GAAGD,GAAO,GAAGE,EAAM;AAAA,IACrB,EAAE,GAAGH,GAAM,GAAGG,EAAM;AAAA,EACxB;AACA;AACA,SAAS2rB,GAAiBS,GAAOC,GAAS;AACxC,QAAM,EAAE,GAAAhhB,GAAG,GAAAC,EAAC,IAAK8gB;AACjB,MAAIE,IAAS;AACb,WAAS9+C,IAAI,GAAG++C,IAAIF,EAAQ,SAAS,GAAG7+C,IAAI6+C,EAAQ,QAAQE,IAAI/+C,KAAK;AACnE,UAAMg/C,IAAKH,EAAQ7+C,CAAC,GACdi/C,IAAKJ,EAAQE,CAAC,GACdG,IAAKF,EAAG,GACRG,IAAKH,EAAG,GACRI,IAAKH,EAAG,GACRI,IAAKJ,EAAG;AAEd,IADkBE,IAAKrhB,KAAMuhB,IAAKvhB,KAAKD,KAAKuhB,IAAKF,MAAOphB,IAAIqhB,MAAOE,IAAKF,KAAMD,MAC/DJ,IAAS,CAACA;AAAA,EAC3B;AACA,SAAOA;AACT;AACA,SAASlB,GAAQ0B,GAAQ;AACvB,QAAMC,IAAYD,EAAO,MAAK;AAC9B,SAAAC,EAAU,KAAK,CAAC9lC,GAAGC,MACbD,EAAE,IAAIC,EAAE,IAAU,KACbD,EAAE,IAAIC,EAAE,IAAU,IAClBD,EAAE,IAAIC,EAAE,IAAU,KAClBD,EAAE,IAAIC,EAAE,IAAU,IACf,CACb,GACM8lC,GAAiBD,CAAS;AACnC;AACA,SAASC,GAAiBF,GAAQ;AAChC,MAAIA,EAAO,UAAU,EAAG,QAAOA,EAAO,MAAK;AAC3C,QAAMG,IAAY,CAAA;AAClB,WAASz/C,IAAI,GAAGA,IAAIs/C,EAAO,QAAQt/C,KAAK;AACtC,UAAMsV,IAAIgqC,EAAOt/C,CAAC;AAClB,WAAOy/C,EAAU,UAAU,KAAG;AAC5B,YAAMC,IAAID,EAAUA,EAAU,SAAS,CAAC,GAClCt9C,IAAIs9C,EAAUA,EAAU,SAAS,CAAC;AACxC,WAAKC,EAAE,IAAIv9C,EAAE,MAAMmT,EAAE,IAAInT,EAAE,OAAOu9C,EAAE,IAAIv9C,EAAE,MAAMmT,EAAE,IAAInT,EAAE,GAAI,CAAAs9C,EAAU,IAAG;AAAA,UACpE;AAAA,IACP;AACA,IAAAA,EAAU,KAAKnqC,CAAC;AAAA,EAClB;AACA,EAAAmqC,EAAU,IAAG;AACb,QAAME,IAAY,CAAA;AAClB,WAAS3/C,IAAIs/C,EAAO,SAAS,GAAGt/C,KAAK,GAAGA,KAAK;AAC3C,UAAMsV,IAAIgqC,EAAOt/C,CAAC;AAClB,WAAO2/C,EAAU,UAAU,KAAG;AAC5B,YAAMD,IAAIC,EAAUA,EAAU,SAAS,CAAC,GAClCx9C,IAAIw9C,EAAUA,EAAU,SAAS,CAAC;AACxC,WAAKD,EAAE,IAAIv9C,EAAE,MAAMmT,EAAE,IAAInT,EAAE,OAAOu9C,EAAE,IAAIv9C,EAAE,MAAMmT,EAAE,IAAInT,EAAE,GAAI,CAAAw9C,EAAU,IAAG;AAAA,UACpE;AAAA,IACP;AACA,IAAAA,EAAU,KAAKrqC,CAAC;AAAA,EAClB;AAEA,SADAqqC,EAAU,IAAG,GACTF,EAAU,WAAW,KAAKE,EAAU,WAAW,KAAKF,EAAU,CAAC,EAAE,MAAME,EAAU,CAAC,EAAE,KAAKF,EAAU,CAAC,EAAE,MAAME,EAAU,CAAC,EAAE,IACpHF,IAEAA,EAAU,OAAOE,CAAS;AAErC;AACA,IAAIlqB,KAAWukB,IACX4F,KAAQ/E,IACRgF,KAAUhE,IACVlF,KAAS0F,IACTyD,KAAWtD;ACnef,MAAMxC,KAAkB+F,IAElBlF,KAAUmF,IAEVnE,KAAiBoE,IAEjBzD,KAAiBvhD,EAAM,WAG3B,CAAC,EAAE,WAAAkE,GAAW,YAAAs0C,IAAa,GAAG,GAAGz4C,KAASyE,MAC1C,gBAAAF,EAAC2gD,IAAA,EACC,UAAA,gBAAA3gD;AAAA,EAAC4gD;AAAAA,EAAA;AAAA,IACC,KAAA1gD;AAAA,IACA,YAAAg0C;AAAA,IACA,WAAWp0C;AAAA,MACT;AAAA,MACAF;AAAA,IAAA;AAAA,IAED,GAAGnE;AAAA,EAAA;AACN,EAAA,CACF,CACD;AACDwhD,GAAe,cAAc2D,GAAyB;;;;GCLhDC,KAAmB,CAACz6B,MACpB,OAAOA,KAAW,WACb,SAAS,eAAeA,CAAM,IAGnC,aAAaA,IACRA,EAAO,UAGTA,GAGH06B,KAAe,CAACjuB,IAA8B,UAAU;AAC5D,QAAM,CAAC+K,GAAMuW,CAAK,IAAIthB,EAAU,MAAM,GAAG;AACzC,SAAO,EAAE,MAAA+K,GAAM,OAAQuW,KAAS,SAAA;AAClC,GAEM4M,KAAW,CAACC,GAAmC7hD,MACnD,OAAO6hD,KAAU,WAAWA,IAAQA,IAAQ7hD,CAAG,KAAK,GAEzC8hD,KAAsC,CAAC;AAAA,EAClD,UAAAthD;AAAA,EACA,QAAAymB;AAAA,EACA,WAAAyM,IAAY;AAAA,EACZ,iBAAAquB;AAAA,EACA,QAAAC;AAAA,EACA,QAAAC;AAAA,EACA,OAAAJ;AAAA,EACA,UAAAK,IAAW;AACb,MAAM;AACJ,QAAM,CAACttB,GAAcC,CAAe,IAAIjgB,EAAS,EAAK,GAChD,CAAC6e,GAAM0uB,CAAO,IAAIvtC,EAAyB,IAAI,GAC/CkgB,IAAOktB,KAAUptB,GACjB,EAAE,MAAA6J,GAAM,OAAAuW,EAAA,IAAU/gC,GAAQ,MAAM0tC,GAAajuB,CAAS,GAAG,CAACA,CAAS,CAAC,GAEpE0uB,IAAapsC,EAAY,MAAM;AACnC,UAAMpU,IAAU8/C,GAAiBz6B,CAAM;AACvC,IAAAk7B,EAAQvgD,GAAS,sBAAA,KAA2B,IAAI;AAAA,EAClD,GAAG,CAACqlB,CAAM,CAAC,GAEL8N,IAAU/e;AAAA,IACd,CAAC/V,MAAmB;AAClB,MAAI+hD,MAAW,UACbntB,EAAgB50B,CAAK,GAEvBgiD,IAAA;AAAA,IACF;AAAA,IACA,CAACD,GAAQC,CAAM;AAAA,EAAA;AA4CjB,SAzCAhtC,GAAU,MAAM;AACd,UAAMrT,IAAU8/C,GAAiBz6B,CAAM;AACvC,QAAI,CAACrlB;AACH;AAGF,QAAIygD,IAAkD,MAClDC,IAAkD;AACtD,UAAMC,IAAc,MAAM;AACxB,MAAIF,kBAAwBA,CAAS,GACjCC,kBAAwBA,CAAS;AAAA,IACvC,GACME,IAAO,MAAM;AACjB,MAAAD,EAAA,GACAH,EAAA,GACAC,IAAY,WAAW,MAAMttB,EAAQ,EAAI,GAAG6sB,GAASC,GAAO,MAAM,CAAC;AAAA,IACrE,GACMvd,IAAO,MAAM;AACjB,MAAK4d,MACLK,EAAA,GACAD,IAAY,WAAW,MAAMvtB,EAAQ,EAAK,GAAG6sB,GAASC,GAAO,MAAM,CAAC;AAAA,IACtE;AAEA,WAAAjgD,EAAQ,iBAAiB,cAAc4gD,CAAI,GAC3C5gD,EAAQ,iBAAiB,cAAc0iC,CAAI,GAC3C1iC,EAAQ,iBAAiB,SAAS4gD,CAAI,GACtC5gD,EAAQ,iBAAiB,QAAQ0iC,CAAI,GACrC,OAAO,iBAAiB,UAAU8d,GAAY,EAAI,GAClD,OAAO,iBAAiB,UAAUA,CAAU,GAErC,MAAM;AACX,MAAAG,EAAA,GACA3gD,EAAQ,oBAAoB,cAAc4gD,CAAI,GAC9C5gD,EAAQ,oBAAoB,cAAc0iC,CAAI,GAC9C1iC,EAAQ,oBAAoB,SAAS4gD,CAAI,GACzC5gD,EAAQ,oBAAoB,QAAQ0iC,CAAI,GACxC,OAAO,oBAAoB,UAAU8d,GAAY,EAAI,GACrD,OAAO,oBAAoB,UAAUA,CAAU;AAAA,IACjD;AAAA,EACF,GAAG,CAACF,GAAUL,GAAO9sB,GAAS9N,GAAQm7B,CAAU,CAAC,GAE5C3uB,IAKH,gBAAA5yB,EAACy6C,MAAgB,eAAe,GAC9B,4BAACa,IAAA,EAAQ,MAAArnB,GAAY,cAAcC,GACjC,UAAA;AAAA,IAAA,gBAAAl0B,EAACs8C,IAAA,EAAe,SAAO,IACrB,UAAA,gBAAAt8C;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,WAAWD,GAAI;AAAA,QACf,OAAO,EAAE,MAAM6yB,EAAK,MAAM,KAAKA,EAAK,KAAK,OAAOA,EAAK,OAAO,QAAQA,EAAK,OAAA;AAAA,MAAO;AAAA,IAAA,GAEpF;AAAA,IACA,gBAAA5yB,EAACi9C,IAAA,EAAe,MAAArf,GAAY,OAAAuW,GAAc,WAAWr0C,EAAGC,GAAI,SAASmhD,CAAe,GACjF,UAAAvhD,EAAA,CACH;AAAA,EAAA,EAAA,CACF,EAAA,CACF,IAhBO;AAkBX;AClIA,IAAI07B,KAAQ;AAKZ,SAASumB,KAAiB;AACxB,EAAAlmD,EAAM,UAAU,MAAM;AACpB,UAAMmmD,IAAa,SAAS,iBAAiB,0BAA0B;AACvE,oBAAS,KAAK,sBAAsB,cAAcA,EAAW,CAAC,KAAKC,IAAkB,GACrF,SAAS,KAAK,sBAAsB,aAAaD,EAAW,CAAC,KAAKC,IAAkB,GACpFzmB,MACO,MAAM;AACX,MAAIA,OAAU,KACZ,SAAS,iBAAiB,0BAA0B,EAAE,QAAQ,CAACh7B,MAASA,EAAK,QAAQ,GAEvFg7B;AAAAA,IACF;AAAA,EACF,GAAG,CAAA,CAAE;AACP;AACA,SAASymB,KAAmB;AAC1B,QAAM/gD,IAAU,SAAS,cAAc,MAAM;AAC7C,SAAAA,EAAQ,aAAa,0BAA0B,EAAE,GACjDA,EAAQ,WAAW,GACnBA,EAAQ,MAAM,UAAU,QACxBA,EAAQ,MAAM,UAAU,KACxBA,EAAQ,MAAM,WAAW,SACzBA,EAAQ,MAAM,gBAAgB,QACvBA;AACT;ACxBA,IAAIghD,KAAqB,+BACrBC,KAAuB,iCACvBC,KAAgB,EAAE,SAAS,IAAO,YAAY,GAAI,GAClDC,KAAmB,cACnBC,KAAazmD,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACzD,QAAM;AAAA,IACJ,MAAA+gD,IAAO;AAAA,IACP,SAAAC,IAAU;AAAA,IACV,kBAAkBC;AAAA,IAClB,oBAAoBC;AAAA,IACpB,GAAGC;AAAA,EACP,IAAM/mD,GACE,CAACu5B,GAAWytB,CAAY,IAAI/mD,EAAM,SAAS,IAAI,GAC/CgnD,IAAmBzqB,GAAeqqB,CAAoB,GACtDK,IAAqB1qB,GAAesqB,CAAsB,GAC1DK,IAAwBlnD,EAAM,OAAO,IAAI,GACzC29B,IAAe34B,GAAgBW,GAAc,CAAChB,MAASoiD,EAAapiD,CAAI,CAAC,GACzEwiD,IAAannD,EAAM,OAAO;AAAA,IAC9B,QAAQ;AAAA,IACR,QAAQ;AACN,WAAK,SAAS;AAAA,IAChB;AAAA,IACA,SAAS;AACP,WAAK,SAAS;AAAA,IAChB;AAAA,EACJ,CAAG,EAAE;AACH,EAAAA,EAAM,UAAU,MAAM;AACpB,QAAI2mD,GAAS;AACX,UAAIS,IAAiB,SAAS58B,GAAO;AACnC,YAAI28B,EAAW,UAAU,CAAC7tB,EAAW;AACrC,cAAM5O,IAASF,EAAM;AACrB,QAAI8O,EAAU,SAAS5O,CAAM,IAC3Bw8B,EAAsB,UAAUx8B,IAEhC28B,GAAMH,EAAsB,SAAS,EAAE,QAAQ,GAAI,CAAE;AAAA,MAEzD,GAAGI,IAAkB,SAAS98B,GAAO;AACnC,YAAI28B,EAAW,UAAU,CAAC7tB,EAAW;AACrC,cAAMiuB,IAAgB/8B,EAAM;AAC5B,QAAI+8B,MAAkB,SACjBjuB,EAAU,SAASiuB,CAAa,KACnCF,GAAMH,EAAsB,SAAS,EAAE,QAAQ,GAAI,CAAE;AAAA,MAEzD,GAAGM,IAAmB,SAASC,GAAW;AAExC,YADuB,SAAS,kBACT,SAAS;AAChC,qBAAWC,KAAYD;AACrB,YAAIC,EAAS,aAAa,SAAS,KAAGL,GAAM/tB,CAAS;AAAA,MAEzD;AAEA,eAAS,iBAAiB,WAAW8tB,CAAc,GACnD,SAAS,iBAAiB,YAAYE,CAAe;AACrD,YAAMttC,IAAmB,IAAI,iBAAiBwtC,CAAgB;AAC9D,aAAIluB,KAAWtf,EAAiB,QAAQsf,GAAW,EAAE,WAAW,IAAM,SAAS,IAAM,GAC9E,MAAM;AACX,iBAAS,oBAAoB,WAAW8tB,CAAc,GACtD,SAAS,oBAAoB,YAAYE,CAAe,GACxDttC,EAAiB,WAAU;AAAA,MAC7B;AAAA,IACF;AAAA,EACF,GAAG,CAAC2sC,GAASrtB,GAAW6tB,EAAW,MAAM,CAAC,GAC1CnnD,EAAM,UAAU,MAAM;AACpB,QAAIs5B,GAAW;AACb,MAAAquB,GAAiB,IAAIR,CAAU;AAC/B,YAAMS,IAA2B,SAAS;AAE1C,UAAI,CADwBtuB,EAAU,SAASsuB,CAAwB,GAC7C;AACxB,cAAMC,IAAa,IAAI,YAAYxB,IAAoBE,EAAa;AACpE,QAAAjtB,EAAU,iBAAiB+sB,IAAoBW,CAAgB,GAC/D1tB,EAAU,cAAcuuB,CAAU,GAC7BA,EAAW,qBACdC,GAAWC,GAAYC,GAAsB1uB,CAAS,CAAC,GAAG,EAAE,QAAQ,IAAM,GACtE,SAAS,kBAAkBsuB,KAC7BP,GAAM/tB,CAAS;AAAA,MAGrB;AACA,aAAO,MAAM;AACX,QAAAA,EAAU,oBAAoB+sB,IAAoBW,CAAgB,GAClE,WAAW,MAAM;AACf,gBAAMiB,IAAe,IAAI,YAAY3B,IAAsBC,EAAa;AACxE,UAAAjtB,EAAU,iBAAiBgtB,IAAsBW,CAAkB,GACnE3tB,EAAU,cAAc2uB,CAAY,GAC/BA,EAAa,oBAChBZ,GAAMO,KAA4B,SAAS,MAAM,EAAE,QAAQ,IAAM,GAEnEtuB,EAAU,oBAAoBgtB,IAAsBW,CAAkB,GACtEU,GAAiB,OAAOR,CAAU;AAAA,QACpC,GAAG,CAAC;AAAA,MACN;AAAA,IACF;AAAA,EACF,GAAG,CAAC7tB,GAAW0tB,GAAkBC,GAAoBE,CAAU,CAAC;AAChE,QAAMpwB,IAAgB/2B,EAAM;AAAA,IAC1B,CAACwqB,MAAU;AAET,UADI,CAACk8B,KAAQ,CAACC,KACVQ,EAAW,OAAQ;AACvB,YAAMe,IAAW19B,EAAM,QAAQ,SAAS,CAACA,EAAM,UAAU,CAACA,EAAM,WAAW,CAACA,EAAM,SAC5E29B,IAAiB,SAAS;AAChC,UAAID,KAAYC,GAAgB;AAC9B,cAAMC,IAAa59B,EAAM,eACnB,CAACrM,GAAOkqC,CAAI,IAAIC,GAAiBF,CAAU;AAEjD,QADkCjqC,KAASkqC,IAIrC,CAAC79B,EAAM,YAAY29B,MAAmBE,KACxC79B,EAAM,eAAc,GAChBk8B,KAAMW,GAAMlpC,GAAO,EAAE,QAAQ,GAAI,CAAE,KAC9BqM,EAAM,YAAY29B,MAAmBhqC,MAC9CqM,EAAM,eAAc,GAChBk8B,KAAMW,GAAMgB,GAAM,EAAE,QAAQ,GAAI,CAAE,KAPpCF,MAAmBC,KAAY59B,EAAM,eAAc;AAAA,MAU3D;AAAA,IACF;AAAA,IACA,CAACk8B,GAAMC,GAASQ,EAAW,MAAM;AAAA,EACrC;AACE,SAAuB,gBAAA7iD,EAAI03B,GAAU,KAAK,EAAE,UAAU,IAAI,GAAG8qB,GAAY,KAAKnpB,GAAc,WAAW5G,EAAa,CAAE;AACxH,CAAC;AACD0vB,GAAW,cAAcD;AACzB,SAASsB,GAAWS,GAAY,EAAE,QAAAC,IAAS,GAAK,IAAK,CAAA,GAAI;AACvD,QAAMZ,IAA2B,SAAS;AAC1C,aAAWa,KAAaF;AAEtB,QADAlB,GAAMoB,GAAW,EAAE,QAAAD,GAAQ,GACvB,SAAS,kBAAkBZ,EAA0B;AAE7D;AACA,SAASU,GAAiBhvB,GAAW;AACnC,QAAMivB,IAAaP,GAAsB1uB,CAAS,GAC5Cnb,IAAQuqC,GAAYH,GAAYjvB,CAAS,GACzC+uB,IAAOK,GAAYH,EAAW,QAAO,GAAIjvB,CAAS;AACxD,SAAO,CAACnb,GAAOkqC,CAAI;AACrB;AACA,SAASL,GAAsB1uB,GAAW;AACxC,QAAMqvB,IAAQ,CAAA,GACRC,IAAS,SAAS,iBAAiBtvB,GAAW,WAAW,cAAc;AAAA,IAC3E,YAAY,CAAC30B,MAAS;AACpB,YAAMkkD,IAAgBlkD,EAAK,YAAY,WAAWA,EAAK,SAAS;AAChE,aAAIA,EAAK,YAAYA,EAAK,UAAUkkD,IAAsB,WAAW,cAC9DlkD,EAAK,YAAY,IAAI,WAAW,gBAAgB,WAAW;AAAA,IACpE;AAAA,EACJ,CAAG;AACD,SAAOikD,EAAO,SAAQ,IAAI,CAAAD,EAAM,KAAKC,EAAO,WAAW;AACvD,SAAOD;AACT;AACA,SAASD,GAAY9kB,GAAUtK,GAAW;AACxC,aAAWj0B,KAAWu+B;AACpB,QAAI,CAACklB,GAASzjD,GAAS,EAAE,MAAMi0B,EAAS,CAAE,EAAG,QAAOj0B;AAExD;AACA,SAASyjD,GAASnkD,GAAM,EAAE,MAAAokD,KAAQ;AAChC,MAAI,iBAAiBpkD,CAAI,EAAE,eAAe,SAAU,QAAO;AAC3D,SAAOA,KAAM;AACX,QAAIokD,MAAS,UAAUpkD,MAASokD,EAAM,QAAO;AAC7C,QAAI,iBAAiBpkD,CAAI,EAAE,YAAY,OAAQ,QAAO;AACtD,IAAAA,IAAOA,EAAK;AAAA,EACd;AACA,SAAO;AACT;AACA,SAASqkD,GAAkB3jD,GAAS;AAClC,SAAOA,aAAmB,oBAAoB,YAAYA;AAC5D;AACA,SAASgiD,GAAMhiD,GAAS,EAAE,QAAAmjD,IAAS,GAAK,IAAK,CAAA,GAAI;AAC/C,MAAInjD,KAAWA,EAAQ,OAAO;AAC5B,UAAMuiD,IAA2B,SAAS;AAC1C,IAAAviD,EAAQ,MAAM,EAAE,eAAe,GAAI,CAAE,GACjCA,MAAYuiD,KAA4BoB,GAAkB3jD,CAAO,KAAKmjD,KACxEnjD,EAAQ,OAAM;AAAA,EAClB;AACF;AACA,IAAIsiD,KAAmBsB,GAAsB;AAC7C,SAASA,KAAyB;AAChC,MAAIliC,IAAQ,CAAA;AACZ,SAAO;AAAA,IACL,IAAIogC,GAAY;AACd,YAAM+B,IAAmBniC,EAAM,CAAC;AAChC,MAAIogC,MAAe+B,KACjBA,GAAkB,MAAK,GAEzBniC,IAAQoiC,GAAYpiC,GAAOogC,CAAU,GACrCpgC,EAAM,QAAQogC,CAAU;AAAA,IAC1B;AAAA,IACA,OAAOA,GAAY;AACjB,MAAApgC,IAAQoiC,GAAYpiC,GAAOogC,CAAU,GACrCpgC,EAAM,CAAC,GAAG,OAAM;AAAA,IAClB;AAAA,EACJ;AACA;AACA,SAASoiC,GAAYC,GAAOh0B,GAAM;AAChC,QAAMi0B,IAAe,CAAC,GAAGD,CAAK,GACxB37C,IAAQ47C,EAAa,QAAQj0B,CAAI;AACvC,SAAI3nB,MAAU,MACZ47C,EAAa,OAAO57C,GAAO,CAAC,GAEvB47C;AACT;AACA,SAAStB,GAAYuB,GAAO;AAC1B,SAAOA,EAAM,OAAO,CAACl0B,MAASA,EAAK,YAAY,GAAG;AACpD;AAAA;AC1MA,SAAS9vB,GAAWC,GAAW;AAC7B,QAAMC,IAA4BC,gBAAAA,GAAgBF,CAAS,GACrDG,IAAQ1F,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACtD,UAAM,EAAE,UAAA1B,GAAU,GAAG2B,EAAS,IAAK7F,GAC7B8F,IAAgB7F,EAAM,SAAS,QAAQiE,CAAQ,GAC/C6B,IAAYD,EAAc,KAAKE,EAAW;AAChD,QAAID,GAAW;AACb,YAAME,IAAaF,EAAU,MAAM,UAC7BG,IAAcJ,EAAc,IAAI,CAACK,MACjCA,MAAUJ,IACR9F,EAAM,SAAS,MAAMgG,CAAU,IAAI,IAAUhG,EAAM,SAAS,KAAK,IAAI,IAClEA,EAAM,eAAegG,CAAU,IAAIA,EAAW,MAAM,WAAW,OAE/DE,CAEV;AACD,aAAuB,gBAAA5B,EAAIkB,GAAW,EAAE,GAAGI,GAAW,KAAKD,GAAc,UAAU3F,EAAM,eAAegG,CAAU,IAAIhG,EAAM,aAAagG,GAAY,QAAQC,CAAW,IAAI,MAAM;AAAA,IACpL;AACA,WAAuB,gBAAA3B,EAAIkB,GAAW,EAAE,GAAGI,GAAW,KAAKD,GAAc,UAAA1B,GAAU;AAAA,EACrF,CAAC;AACD,SAAAyB,EAAM,cAAc,GAAGH,CAAS,SACzBG;AACT;AAAA;AAGA,SAASD,GAAgBF,GAAW;AAClC,QAAMC,IAAYxF,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AAC1D,UAAM,EAAE,UAAA1B,GAAU,GAAG2B,EAAS,IAAK7F;AACnC,QAAIC,EAAM,eAAeiE,CAAQ,GAAG;AAClC,YAAMmC,IAAcC,GAAcpC,CAAQ,GACpCqC,IAASC,GAAWX,GAAW3B,EAAS,KAAK;AACnD,aAAIA,EAAS,SAASjE,EAAM,aAC1BsG,EAAO,MAAMX,IAAelB,GAAYkB,GAAcS,CAAW,IAAIA,IAEhEpG,EAAM,aAAaiE,GAAUqC,CAAM;AAAA,IAC5C;AACA,WAAOtG,EAAM,SAAS,MAAMiE,CAAQ,IAAI,IAAIjE,EAAM,SAAS,KAAK,IAAI,IAAI;AAAA,EAC1E,CAAC;AACD,SAAAwF,EAAU,cAAc,GAAGD,CAAS,cAC7BC;AACT;AACA,IAAIgB,KAAuB,uBAAO,iBAAiB;AAWnD,SAAST,GAAYG,GAAO;AAC1B,SAAOlG,EAAM,eAAekG,CAAK,KAAK,OAAOA,EAAM,QAAS,cAAc,eAAeA,EAAM,QAAQA,EAAM,KAAK,cAAcM;AAClI;AACA,SAASD,GAAWX,GAAWa,GAAY;AACzC,QAAMC,IAAgB,EAAE,GAAGD,EAAU;AACrC,aAAWE,KAAYF,GAAY;AACjC,UAAMG,IAAgBhB,EAAUe,CAAQ,GAClCE,IAAiBJ,EAAWE,CAAQ;AAE1C,IADkB,WAAW,KAAKA,CAAQ,IAEpCC,KAAiBC,IACnBH,EAAcC,CAAQ,IAAI,IAAIG,MAAS;AACrC,YAAMC,IAASF,EAAe,GAAGC,CAAI;AACrC,aAAAF,EAAc,GAAGE,CAAI,GACdC;AAAA,IACT,IACSH,MACTF,EAAcC,CAAQ,IAAIC,KAEnBD,MAAa,UACtBD,EAAcC,CAAQ,IAAI,EAAE,GAAGC,GAAe,GAAGC,EAAc,IACtDF,MAAa,gBACtBD,EAAcC,CAAQ,IAAI,CAACC,GAAeC,CAAc,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAAA,EAEtF;AACA,SAAO,EAAE,GAAGjB,GAAW,GAAGc,EAAa;AACzC;AACA,SAASL,GAAchB,GAAS;AAC9B,MAAI2B,IAAS,OAAO,yBAAyB3B,EAAQ,OAAO,KAAK,GAAG,KAChE4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO;AAC7D,SAAIC,IACK5B,EAAQ,OAEjB2B,IAAS,OAAO,yBAAyB3B,GAAS,KAAK,GAAG,KAC1D4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO,gBACrDC,IACK5B,EAAQ,MAAM,MAEhBA,EAAQ,MAAM,OAAOA,EAAQ;AACtC;AChGA,IAAIkkD,KAAmB,SAAUC,GAAgB;AAC7C,MAAI,OAAO,WAAa;AACpB,WAAO;AAEX,MAAIC,IAAe,MAAM,QAAQD,CAAc,IAAIA,EAAe,CAAC,IAAIA;AACvE,SAAOC,EAAa,cAAc;AACtC,GACIC,KAAa,oBAAI,QAAO,GACxBC,KAAoB,oBAAI,QAAO,GAC/BC,KAAY,CAAA,GACZC,KAAY,GACZC,KAAa,SAAUnlD,GAAM;AAC7B,SAAOA,MAASA,EAAK,QAAQmlD,GAAWnlD,EAAK,UAAU;AAC3D,GACIolD,KAAiB,SAAU7vC,GAAQ8vC,GAAS;AAC5C,SAAOA,EACF,IAAI,SAAUt/B,GAAQ;AACvB,QAAIxQ,EAAO,SAASwQ,CAAM;AACtB,aAAOA;AAEX,QAAIu/B,IAAkBH,GAAWp/B,CAAM;AACvC,WAAIu/B,KAAmB/vC,EAAO,SAAS+vC,CAAe,IAC3CA,KAEX,QAAQ,MAAM,eAAev/B,GAAQ,2BAA2BxQ,GAAQ,iBAAiB,GAClF;AAAA,EACX,CAAC,EACI,OAAO,SAAU0oB,GAAG;AAAE,WAAO,EAAQA;AAAA,EAAI,CAAC;AACnD,GASIsnB,KAAyB,SAAUV,GAAgBld,GAAY6d,GAAYC,GAAkB;AAC7F,MAAIJ,IAAUD,GAAezd,GAAY,MAAM,QAAQkd,CAAc,IAAIA,IAAiB,CAACA,CAAc,CAAC;AAC1G,EAAKI,GAAUO,CAAU,MACrBP,GAAUO,CAAU,IAAI,oBAAI,QAAO;AAEvC,MAAIE,IAAgBT,GAAUO,CAAU,GACpCG,IAAc,CAAA,GACdC,IAAiB,oBAAI,IAAG,GACxBC,IAAiB,IAAI,IAAIR,CAAO,GAChCS,IAAO,SAAUpvC,GAAI;AACrB,IAAI,CAACA,KAAMkvC,EAAe,IAAIlvC,CAAE,MAGhCkvC,EAAe,IAAIlvC,CAAE,GACrBovC,EAAKpvC,EAAG,UAAU;AAAA,EACtB;AACA,EAAA2uC,EAAQ,QAAQS,CAAI;AACpB,MAAIC,IAAO,SAAUxwC,GAAQ;AACzB,IAAI,CAACA,KAAUswC,EAAe,IAAItwC,CAAM,KAGxC,MAAM,UAAU,QAAQ,KAAKA,EAAO,UAAU,SAAUvV,GAAM;AAC1D,UAAI4lD,EAAe,IAAI5lD,CAAI;AACvB,QAAA+lD,EAAK/lD,CAAI;AAAA;AAGT,YAAI;AACA,cAAI0mB,IAAO1mB,EAAK,aAAaylD,CAAgB,GACzCO,IAAgBt/B,MAAS,QAAQA,MAAS,SAC1Cu/B,KAAgBlB,GAAW,IAAI/kD,CAAI,KAAK,KAAK,GAC7CkmD,KAAeR,EAAc,IAAI1lD,CAAI,KAAK,KAAK;AACnD,UAAA+kD,GAAW,IAAI/kD,GAAMimD,CAAY,GACjCP,EAAc,IAAI1lD,GAAMkmD,CAAW,GACnCP,EAAY,KAAK3lD,CAAI,GACjBimD,MAAiB,KAAKD,KACtBhB,GAAkB,IAAIhlD,GAAM,EAAI,GAEhCkmD,MAAgB,KAChBlmD,EAAK,aAAawlD,GAAY,MAAM,GAEnCQ,KACDhmD,EAAK,aAAaylD,GAAkB,MAAM;AAAA,QAElD,SACOjxB,GAAG;AACN,kBAAQ,MAAM,mCAAmCx0B,GAAMw0B,CAAC;AAAA,QAC5D;AAAA,IAER,CAAC;AAAA,EACL;AACA,SAAAuxB,EAAKpe,CAAU,GACfie,EAAe,MAAK,GACpBV,MACO,WAAY;AACf,IAAAS,EAAY,QAAQ,SAAU3lD,GAAM;AAChC,UAAIimD,IAAelB,GAAW,IAAI/kD,CAAI,IAAI,GACtCkmD,IAAcR,EAAc,IAAI1lD,CAAI,IAAI;AAC5C,MAAA+kD,GAAW,IAAI/kD,GAAMimD,CAAY,GACjCP,EAAc,IAAI1lD,GAAMkmD,CAAW,GAC9BD,MACIjB,GAAkB,IAAIhlD,CAAI,KAC3BA,EAAK,gBAAgBylD,CAAgB,GAEzCT,GAAkB,OAAOhlD,CAAI,IAE5BkmD,KACDlmD,EAAK,gBAAgBwlD,CAAU;AAAA,IAEvC,CAAC,GACDN,MACKA,OAEDH,KAAa,oBAAI,QAAO,GACxBA,KAAa,oBAAI,QAAO,GACxBC,KAAoB,oBAAI,QAAO,GAC/BC,KAAY,CAAA;AAAA,EAEpB;AACJ,GAQWkB,KAAa,SAAUtB,GAAgBld,GAAY6d,GAAY;AACtE,EAAIA,MAAe,WAAUA,IAAa;AAC1C,MAAIH,IAAU,MAAM,KAAK,MAAM,QAAQR,CAAc,IAAIA,IAAiB,CAACA,CAAc,CAAC,GACtFuB,IAAiCxB,GAAiBC,CAAc;AACpE,SAAKuB,KAKLf,EAAQ,KAAK,MAAMA,GAAS,MAAM,KAAKe,EAAiB,iBAAiB,qBAAqB,CAAC,CAAC,GACzFb,GAAuBF,GAASe,GAAkBZ,GAAY,aAAa,KALvE,WAAY;AAAE,WAAO;AAAA,EAAM;AAM1C,GCvGWa,KAAW,WAAW;AAC/B,SAAAA,KAAW,OAAO,UAAU,SAAkB,GAAG;AAC7C,aAAS9rC,GAAGna,IAAI,GAAGqC,IAAI,UAAU,QAAQrC,IAAIqC,GAAGrC,KAAK;AACjD,MAAAma,IAAI,UAAUna,CAAC;AACf,eAASsV,KAAK6E,EAAG,CAAI,OAAO,UAAU,eAAe,KAAKA,GAAG7E,CAAC,MAAG,EAAEA,CAAC,IAAI6E,EAAE7E,CAAC;AAAA,IAC/E;AACA,WAAO;AAAA,EACX,GACO2wC,GAAS,MAAM,MAAM,SAAS;AACvC;AAEO,SAASC,GAAO/rC,GAAGia,GAAG;AAC3B,MAAI+xB,IAAI,CAAA;AACR,WAAS7wC,KAAK6E,EAAG,CAAI,OAAO,UAAU,eAAe,KAAKA,GAAG7E,CAAC,KAAK8e,EAAE,QAAQ9e,CAAC,IAAI,MAC9E6wC,EAAE7wC,CAAC,IAAI6E,EAAE7E,CAAC;AACd,MAAI6E,KAAK,QAAQ,OAAO,OAAO,yBAA0B;AACrD,aAASna,IAAI,GAAGsV,IAAI,OAAO,sBAAsB6E,CAAC,GAAGna,IAAIsV,EAAE,QAAQtV;AAC/D,MAAIo0B,EAAE,QAAQ9e,EAAEtV,CAAC,CAAC,IAAI,KAAK,OAAO,UAAU,qBAAqB,KAAKma,GAAG7E,EAAEtV,CAAC,CAAC,MACzEmmD,EAAE7wC,EAAEtV,CAAC,CAAC,IAAIma,EAAE7E,EAAEtV,CAAC,CAAC;AAE5B,SAAOmmD;AACT;AAiKO,SAASC,GAAcnqC,GAAIsB,GAAM8oC,GAAM;AAC5C,MAAIA,KAAQ,UAAU,WAAW,EAAG,UAASrmD,IAAI,GAAGsmD,IAAI/oC,EAAK,QAAQgpC,GAAIvmD,IAAIsmD,GAAGtmD;AAC5E,KAAIumD,KAAM,EAAEvmD,KAAKud,QACRgpC,MAAIA,IAAK,MAAM,UAAU,MAAM,KAAKhpC,GAAM,GAAGvd,CAAC,IACnDumD,EAAGvmD,CAAC,IAAIud,EAAKvd,CAAC;AAGtB,SAAOic,EAAG,OAAOsqC,KAAM,MAAM,UAAU,MAAM,KAAKhpC,CAAI,CAAC;AACzD;AC7NO,IAAIipC,KAAqB,6BACrBC,KAAqB,2BACrBC,KAAwB,2BAKxBC,KAAyB;ACM7B,SAASC,GAAUnnD,GAAKd,GAAO;AAClC,SAAI,OAAOc,KAAQ,aACfA,EAAId,CAAK,IAEJc,MACLA,EAAI,UAAUd,IAEXc;AACX;ACNO,SAAS+3B,GAAeqvB,GAAc38B,GAAU;AACnD,MAAIzqB,IAAM6T,EAAS,WAAY;AAAE,WAAQ;AAAA;AAAA,MAErC,OAAOuzC;AAAA;AAAA,MAEP,UAAU38B;AAAA;AAAA,MAEV,QAAQ;AAAA,QACJ,IAAI,UAAU;AACV,iBAAOzqB,EAAI;AAAA,QACf;AAAA,QACA,IAAI,QAAQd,GAAO;AACf,cAAI2kD,IAAO7jD,EAAI;AACf,UAAI6jD,MAAS3kD,MACTc,EAAI,QAAQd,GACZc,EAAI,SAASd,GAAO2kD,CAAI;AAAA,QAEhC;AAAA,MACZ;AAAA,IACA;AAAA,EAAQ,CAAC,EAAE,CAAC;AAER,SAAA7jD,EAAI,WAAWyqB,GACRzqB,EAAI;AACf;ACnCA,IAAI+gB,KAA4B,OAAO,SAAW,MAAcvlB,EAAM,kBAAkBA,EAAM,WAC1F6rD,KAAgB,oBAAI,QAAO;AAexB,SAASC,GAAapnD,GAAMqnD,GAAc;AAC7C,MAAI3wC,IAAcmhB,GAA+B,MAAM,SAAUyvB,GAAU;AACvE,WAAOtnD,EAAK,QAAQ,SAAUF,GAAK;AAAE,aAAOmnD,GAAUnnD,GAAKwnD,CAAQ;AAAA,IAAG,CAAC;AAAA,EAC3E,CAAC;AAED,SAAAzmC,GAA0B,WAAY;AAClC,QAAI0mC,IAAWJ,GAAc,IAAIzwC,CAAW;AAC5C,QAAI6wC,GAAU;AACV,UAAIC,IAAa,IAAI,IAAID,CAAQ,GAC7BE,IAAa,IAAI,IAAIznD,CAAI,GACzB0nD,IAAYhxC,EAAY;AAC5B,MAAA8wC,EAAW,QAAQ,SAAU1nD,GAAK;AAC9B,QAAK2nD,EAAW,IAAI3nD,CAAG,KACnBmnD,GAAUnnD,GAAK,IAAI;AAAA,MAE3B,CAAC,GACD2nD,EAAW,QAAQ,SAAU3nD,GAAK;AAC9B,QAAK0nD,EAAW,IAAI1nD,CAAG,KACnBmnD,GAAUnnD,GAAK4nD,CAAS;AAAA,MAEhC,CAAC;AAAA,IACL;AACA,IAAAP,GAAc,IAAIzwC,GAAa1W,CAAI;AAAA,EACvC,GAAG,CAACA,CAAI,CAAC,GACF0W;AACX;AC3CA,SAASixC,GAAK7tC,GAAG;AACb,SAAOA;AACX;AACA,SAAS8tC,GAAkBC,GAAU9nB,GAAY;AAC7C,EAAIA,MAAe,WAAUA,IAAa4nB;AAC1C,MAAIG,IAAS,CAAA,GACTC,IAAW,IACXC,IAAS;AAAA,IACT,MAAM,WAAY;AACd,UAAID;AACA,cAAM,IAAI,MAAM,kGAAkG;AAEtH,aAAID,EAAO,SACAA,EAAOA,EAAO,SAAS,CAAC,IAE5BD;AAAA,IACX;AAAA,IACA,WAAW,SAAUhyC,GAAM;AACvB,UAAI6a,IAAOqP,EAAWlqB,GAAMkyC,CAAQ;AACpC,aAAAD,EAAO,KAAKp3B,CAAI,GACT,WAAY;AACf,QAAAo3B,IAASA,EAAO,OAAO,SAAU5pB,GAAG;AAAE,iBAAOA,MAAMxN;AAAA,QAAM,CAAC;AAAA,MAC9D;AAAA,IACJ;AAAA,IACA,kBAAkB,SAAU5P,GAAI;AAE5B,WADAinC,IAAW,IACJD,EAAO,UAAQ;AAClB,YAAIG,IAAMH;AACV,QAAAA,IAAS,CAAA,GACTG,EAAI,QAAQnnC,CAAE;AAAA,MAClB;AACA,MAAAgnC,IAAS;AAAA,QACL,MAAM,SAAU5pB,GAAG;AAAE,iBAAOpd,EAAGod,CAAC;AAAA,QAAG;AAAA,QACnC,QAAQ,WAAY;AAAE,iBAAO4pB;AAAA,QAAQ;AAAA,MACrD;AAAA,IACQ;AAAA,IACA,cAAc,SAAUhnC,GAAI;AACxB,MAAAinC,IAAW;AACX,UAAIG,IAAe,CAAA;AACnB,UAAIJ,EAAO,QAAQ;AACf,YAAIG,IAAMH;AACV,QAAAA,IAAS,CAAA,GACTG,EAAI,QAAQnnC,CAAE,GACdonC,IAAeJ;AAAA,MACnB;AACA,UAAIK,IAAe,WAAY;AAC3B,YAAIF,IAAMC;AACV,QAAAA,IAAe,CAAA,GACfD,EAAI,QAAQnnC,CAAE;AAAA,MAClB,GACIsnC,IAAQ,WAAY;AAAE,eAAO,QAAQ,QAAO,EAAG,KAAKD,CAAY;AAAA,MAAG;AACvE,MAAAC,EAAK,GACLN,IAAS;AAAA,QACL,MAAM,SAAU5pB,GAAG;AACf,UAAAgqB,EAAa,KAAKhqB,CAAC,GACnBkqB,EAAK;AAAA,QACT;AAAA,QACA,QAAQ,SAAUC,GAAQ;AACtB,iBAAAH,IAAeA,EAAa,OAAOG,CAAM,GAClCP;AAAA,QACX;AAAA,MAChB;AAAA,IACQ;AAAA,EACR;AACI,SAAOE;AACX;AAMO,SAASM,GAAoBhnC,GAAS;AACzC,EAAIA,MAAY,WAAUA,IAAU,CAAA;AACpC,MAAI0mC,IAASJ,GAAkB,IAAI;AACnC,SAAAI,EAAO,UAAU1B,GAAS,EAAE,OAAO,IAAM,KAAK,GAAK,GAAIhlC,CAAO,GACvD0mC;AACX;AC3EA,IAAIO,KAAU,SAAUC,GAAI;AACxB,MAAIC,IAAUD,EAAG,SAASn1C,IAAOkzC,GAAOiC,GAAI,CAAC,SAAS,CAAC;AACvD,MAAI,CAACC;AACD,UAAM,IAAI,MAAM,oEAAoE;AAExF,MAAIC,IAASD,EAAQ,KAAI;AACzB,MAAI,CAACC;AACD,UAAM,IAAI,MAAM,0BAA0B;AAE9C,SAAOptD,EAAM,cAAcotD,GAAQpC,GAAS,CAAA,GAAIjzC,CAAI,CAAC;AACzD;AACAk1C,GAAQ,kBAAkB;AACnB,SAASI,GAAcX,GAAQY,GAAU;AAC5C,SAAAZ,EAAO,UAAUY,CAAQ,GAClBL;AACX;AChBO,IAAIM,KAAYP,GAAmB,GCItCQ,KAAU,WAAY;AAE1B,GAIIC,KAAeztD,EAAM,WAAW,SAAUD,GAAO2tD,GAAW;AAC5D,MAAIlpD,IAAMxE,EAAM,OAAO,IAAI,GACvBktD,IAAKltD,EAAM,SAAS;AAAA,IACpB,iBAAiBwtD;AAAA,IACjB,gBAAgBA;AAAA,IAChB,oBAAoBA;AAAA,EAC5B,CAAK,GAAGG,IAAYT,EAAG,CAAC,GAAGU,IAAeV,EAAG,CAAC,GACtCW,IAAe9tD,EAAM,cAAckE,IAAWlE,EAAM,UAAUmE,IAAYnE,EAAM,WAAW+tD,IAAkB/tD,EAAM,iBAAiBqZ,IAAUrZ,EAAM,SAASguD,IAAShuD,EAAM,QAAQotD,IAAUptD,EAAM,SAASiuD,IAAajuD,EAAM,YAAYkuD,IAAcluD,EAAM,aAAamuD,IAAQnuD,EAAM,OAAOouD,IAAiBpuD,EAAM,gBAAgBquD,IAAKruD,EAAM,IAAIsuD,IAAYD,MAAO,SAAS,QAAQA,GAAIE,IAAUvuD,EAAM,SAASgY,IAAOkzC,GAAOlrD,GAAO,CAAC,gBAAgB,YAAY,aAAa,mBAAmB,WAAW,UAAU,WAAW,cAAc,eAAe,SAAS,kBAAkB,MAAM,SAAS,CAAC,GACnlBktD,IAAUE,GACVoB,IAAezC,GAAa,CAACtnD,GAAKkpD,CAAS,CAAC,GAC5Cc,IAAiBxD,GAASA,GAAS,CAAA,GAAIjzC,CAAI,GAAG41C,CAAS;AAC3D,SAAQ3tD,EAAM;AAAA,IAAcA,EAAM;AAAA,IAAU;AAAA,IACxCoZ,KAAYpZ,EAAM,cAAcitD,GAAS,EAAE,SAASM,IAAW,iBAAiBO,GAAiB,QAAQC,GAAQ,YAAYC,GAAY,aAAaC,GAAa,OAAOC,GAAO,cAAcN,GAAc,gBAAgB,CAAC,CAACO,GAAgB,SAAS3pD,GAAK,SAAS8pD,EAAO,CAAE;AAAA,IAC/QT,IAAgB7tD,EAAM,aAAaA,EAAM,SAAS,KAAKiE,CAAQ,GAAG+mD,GAASA,GAAS,CAAA,GAAIwD,CAAc,GAAG,EAAE,KAAKD,EAAY,CAAE,CAAC,IAAMvuD,EAAM,cAAcquD,GAAWrD,GAAS,CAAA,GAAIwD,GAAgB,EAAE,WAAWtqD,GAAW,KAAKqqD,EAAY,CAAE,GAAGtqD,CAAQ;AAAA,EAAE;AACjQ,CAAC;AACDwpD,GAAa,eAAe;AAAA,EACxB,SAAS;AAAA,EACT,iBAAiB;AAAA,EACjB,OAAO;AACX;AACAA,GAAa,aAAa;AAAA,EACtB,WAAWjC;AAAA,EACX,WAAWD;AACf;AC9BO,IAAIkD,KAAW,WAAY;AAI9B,MAAI,OAAO,oBAAsB;AAC7B,WAAO;AAGf;ACXA,SAASC,KAAe;AACpB,MAAI,CAAC;AACD,WAAO;AACX,MAAIC,IAAM,SAAS,cAAc,OAAO;AACxC,EAAAA,EAAI,OAAO;AACX,MAAIC,IAAQH,GAAQ;AACpB,SAAIG,KACAD,EAAI,aAAa,SAASC,CAAK,GAE5BD;AACX;AACA,SAASE,GAAaF,GAAKtqD,GAAK;AAE5B,EAAIsqD,EAAI,aAEJA,EAAI,WAAW,UAAUtqD,IAGzBsqD,EAAI,YAAY,SAAS,eAAetqD,CAAG,CAAC;AAEpD;AACA,SAASyqD,GAAeH,GAAK;AACzB,MAAII,IAAO,SAAS,QAAQ,SAAS,qBAAqB,MAAM,EAAE,CAAC;AACnE,EAAAA,EAAK,YAAYJ,CAAG;AACxB;AACO,IAAIK,KAAsB,WAAY;AACzC,MAAIC,IAAU,GACVC,IAAa;AACjB,SAAO;AAAA,IACH,KAAK,SAAU/0C,GAAO;AAClB,MAAI80C,KAAW,MACNC,IAAaR,UACdG,GAAaK,GAAY/0C,CAAK,GAC9B20C,GAAeI,CAAU,IAGjCD;AAAA,IACJ;AAAA,IACA,QAAQ,WAAY;AAChB,MAAAA,KACI,CAACA,KAAWC,MACZA,EAAW,cAAcA,EAAW,WAAW,YAAYA,CAAU,GACrEA,IAAa;AAAA,IAErB;AAAA,EACR;AACA,GCpCWC,KAAqB,WAAY;AACxC,MAAIC,IAAQJ,GAAmB;AAC/B,SAAO,SAAUv3C,GAAQ43C,GAAW;AAChC,IAAArvD,EAAM,UAAU,WAAY;AACxB,aAAAovD,EAAM,IAAI33C,CAAM,GACT,WAAY;AACf,QAAA23C,EAAM,OAAM;AAAA,MAChB;AAAA,IACJ,GAAG,CAAC33C,KAAU43C,CAAS,CAAC;AAAA,EAC5B;AACJ,GCdWC,KAAiB,WAAY;AACpC,MAAIC,IAAWJ,GAAkB,GAC7BK,IAAQ,SAAUtC,GAAI;AACtB,QAAIz1C,IAASy1C,EAAG,QAAQuC,IAAUvC,EAAG;AACrC,WAAAqC,EAAS93C,GAAQg4C,CAAO,GACjB;AAAA,EACX;AACA,SAAOD;AACX,GCfWE,KAAU;AAAA,EACjB,MAAM;AAAA,EACN,KAAK;AAAA,EACL,OAAO;AAAA,EACP,KAAK;AACT,GACIC,KAAQ,SAAU/sB,GAAG;AAAE,SAAO,SAASA,KAAK,IAAI,EAAE,KAAK;AAAG,GAC1DgtB,KAAY,SAAUtB,GAAS;AAC/B,MAAIuB,IAAK,OAAO,iBAAiB,SAAS,IAAI,GAC1Cz4B,IAAOy4B,EAAGvB,MAAY,YAAY,gBAAgB,YAAY,GAC9Dh3B,IAAMu4B,EAAGvB,MAAY,YAAY,eAAe,WAAW,GAC3Dj3B,IAAQw4B,EAAGvB,MAAY,YAAY,iBAAiB,aAAa;AACrE,SAAO,CAACqB,GAAMv4B,CAAI,GAAGu4B,GAAMr4B,CAAG,GAAGq4B,GAAMt4B,CAAK,CAAC;AACjD,GACWy4B,KAAc,SAAUxB,GAAS;AAExC,MADIA,MAAY,WAAUA,IAAU,WAChC,OAAO,SAAW;AAClB,WAAOoB;AAEX,MAAI1nB,IAAU4nB,GAAUtB,CAAO,GAC3ByB,IAAgB,SAAS,gBAAgB,aACzCC,IAAc,OAAO;AACzB,SAAO;AAAA,IACH,MAAMhoB,EAAQ,CAAC;AAAA,IACf,KAAKA,EAAQ,CAAC;AAAA,IACd,OAAOA,EAAQ,CAAC;AAAA,IAChB,KAAK,KAAK,IAAI,GAAGgoB,IAAcD,IAAgB/nB,EAAQ,CAAC,IAAIA,EAAQ,CAAC,CAAC;AAAA,EAC9E;AACA,GCxBIioB,KAAQX,GAAc,GACfY,KAAgB,sBAIvBC,KAAY,SAAUjD,GAAIkD,GAAe9B,GAAS+B,GAAW;AAC7D,MAAIj5B,IAAO81B,EAAG,MAAM51B,IAAM41B,EAAG,KAAK71B,IAAQ61B,EAAG,OAAOoD,IAAMpD,EAAG;AAC7D,SAAIoB,MAAY,WAAUA,IAAU,WAC7B;AAAA,KAAQ,OAAO7C,IAAuB;AAAA,qBAA0B,EAAE,OAAO4E,GAAW;AAAA,mBAAuB,EAAE,OAAOC,GAAK,KAAK,EAAE,OAAOD,GAAW;AAAA;AAAA,QAAiB,EAAE,OAAOH,IAAe;AAAA,sBAA4B,EAAE,OAAOG,GAAW;AAAA;AAAA,KAA4C,EAAE,OAAO;AAAA,IACnSD,KAAiB,sBAAsB,OAAOC,GAAW,GAAG;AAAA,IAC5D/B,MAAY,YACR;AAAA,oBAAuB,OAAOl3B,GAAM;AAAA,kBAAwB,EAAE,OAAOE,GAAK;AAAA,oBAA0B,EAAE,OAAOD,GAAO;AAAA;AAAA;AAAA,mBAAgE,EAAE,OAAOi5B,GAAK,KAAK,EAAE,OAAOD,GAAW;AAAA,KAAS;AAAA,IACxO/B,MAAY,aAAa,kBAAkB,OAAOgC,GAAK,KAAK,EAAE,OAAOD,GAAW,GAAG;AAAA,EAC3F,EACS,OAAO,OAAO,EACd,KAAK,EAAE,GAAG;AAAA;AAAA;AAAA,IAAgB,EAAE,OAAO9E,IAAoB;AAAA,YAAiB,EAAE,OAAO+E,GAAK,KAAK,EAAE,OAAOD,GAAW;AAAA;AAAA;AAAA,IAAiB,EAAE,OAAO7E,IAAoB;AAAA,mBAAwB,EAAE,OAAO8E,GAAK,KAAK,EAAE,OAAOD,GAAW;AAAA;AAAA;AAAA,IAAiB,EAAE,OAAO9E,IAAoB,IAAI,EAAE,OAAOA,IAAoB;AAAA,cAAmB,EAAE,OAAO8E,GAAW;AAAA;AAAA;AAAA,IAAiB,EAAE,OAAO7E,IAAoB,IAAI,EAAE,OAAOA,IAAoB;AAAA,qBAA0B,EAAE,OAAO6E,GAAW;AAAA;AAAA;AAAA,QAAqB,EAAE,OAAOH,IAAe;AAAA,KAAW,EAAE,OAAOxE,IAAwB,IAAI,EAAE,OAAO4E,GAAK;AAAA;AAAA,CAAY;AAC/kB,GACIC,KAAuB,WAAY;AACnC,MAAItB,IAAU,SAAS,SAAS,KAAK,aAAaiB,EAAa,KAAK,KAAK,EAAE;AAC3E,SAAO,SAASjB,CAAO,IAAIA,IAAU;AACzC,GACWuB,KAAmB,WAAY;AACtC,EAAAxwD,EAAM,UAAU,WAAY;AACxB,oBAAS,KAAK,aAAakwD,KAAgBK,OAAyB,GAAG,UAAU,GAC1E,WAAY;AACf,UAAIE,IAAaF,GAAoB,IAAK;AAC1C,MAAIE,KAAc,IACd,SAAS,KAAK,gBAAgBP,EAAa,IAG3C,SAAS,KAAK,aAAaA,IAAeO,EAAW,SAAQ,CAAE;AAAA,IAEvE;AAAA,EACJ,GAAG,CAAA,CAAE;AACT,GAIWC,KAAkB,SAAUxD,GAAI;AACvC,MAAIc,IAAad,EAAG,YAAYyD,IAAczD,EAAG,aAAakB,IAAKlB,EAAG,SAASoB,IAAUF,MAAO,SAAS,WAAWA;AACpH,EAAAoC,GAAgB;AAMhB,MAAIF,IAAMtwD,EAAM,QAAQ,WAAY;AAAE,WAAO8vD,GAAYxB,CAAO;AAAA,EAAG,GAAG,CAACA,CAAO,CAAC;AAC/E,SAAOtuD,EAAM,cAAciwD,IAAO,EAAE,QAAQE,GAAUG,GAAK,CAACtC,GAAYM,GAAUqC,IAA6B,KAAf,YAAiB,EAAC,CAAE;AACxH,GCpDIC,KAAmB;AACvB,IAAI,OAAO,SAAW;AAClB,MAAI;AACA,QAAI5qC,KAAU,OAAO,eAAe,CAAA,GAAI,WAAW;AAAA,MAC/C,KAAK,WAAY;AACb,eAAA4qC,KAAmB,IACZ;AAAA,MACX;AAAA,IACZ,CAAS;AAED,WAAO,iBAAiB,QAAQ5qC,IAASA,EAAO,GAEhD,OAAO,oBAAoB,QAAQA,IAASA,EAAO;AAAA,EACvD,QACY;AACR,IAAA4qC,KAAmB;AAAA,EACvB;AAEG,IAAIC,KAAaD,KAAmB,EAAE,SAAS,GAAK,IAAK,IClB5DE,KAAuB,SAAUnsD,GAAM;AAEvC,SAAOA,EAAK,YAAY;AAC5B,GACIosD,KAAuB,SAAUpsD,GAAMyV,GAAU;AACjD,MAAI,EAAEzV,aAAgB;AAClB,WAAO;AAEX,MAAI8S,IAAS,OAAO,iBAAiB9S,CAAI;AACzC;AAAA;AAAA,IAEA8S,EAAO2C,CAAQ,MAAM;AAAA,IAEjB,EAAE3C,EAAO,cAAcA,EAAO,aAAa,CAACq5C,GAAqBnsD,CAAI,KAAK8S,EAAO2C,CAAQ,MAAM;AAAA;AACvG,GACI42C,KAA0B,SAAUrsD,GAAM;AAAE,SAAOosD,GAAqBpsD,GAAM,WAAW;AAAG,GAC5FssD,KAA0B,SAAUtsD,GAAM;AAAE,SAAOosD,GAAqBpsD,GAAM,WAAW;AAAG,GACrFusD,KAA0B,SAAUrwB,GAAMl8B,GAAM;AACvD,MAAI+3B,IAAgB/3B,EAAK,eACrBkH,IAAUlH;AACd,KAAG;AAEC,IAAI,OAAO,aAAe,OAAekH,aAAmB,eACxDA,IAAUA,EAAQ;AAEtB,QAAIslD,IAAeC,GAAuBvwB,GAAMh1B,CAAO;AACvD,QAAIslD,GAAc;AACd,UAAIjE,IAAKmE,GAAmBxwB,GAAMh1B,CAAO,GAAGylD,IAAepE,EAAG,CAAC,GAAGqE,IAAerE,EAAG,CAAC;AACrF,UAAIoE,IAAeC;AACf,eAAO;AAAA,IAEf;AACA,IAAA1lD,IAAUA,EAAQ;AAAA,EACtB,SAASA,KAAWA,MAAY6wB,EAAc;AAC9C,SAAO;AACX,GACI80B,KAAsB,SAAUtE,GAAI;AACpC,MAAIuE,IAAYvE,EAAG,WAAWoE,IAAepE,EAAG,cAAcqE,IAAerE,EAAG;AAChF,SAAO;AAAA,IACHuE;AAAA,IACAH;AAAA,IACAC;AAAA,EACR;AACA,GACIG,KAAsB,SAAUxE,GAAI;AACpC,MAAIyE,IAAazE,EAAG,YAAY0E,IAAc1E,EAAG,aAAa2E,IAAc3E,EAAG;AAC/E,SAAO;AAAA,IACHyE;AAAA,IACAC;AAAA,IACAC;AAAA,EACR;AACA,GACIT,KAAyB,SAAUvwB,GAAMl8B,GAAM;AAC/C,SAAOk8B,MAAS,MAAMmwB,GAAwBrsD,CAAI,IAAIssD,GAAwBtsD,CAAI;AACtF,GACI0sD,KAAqB,SAAUxwB,GAAMl8B,GAAM;AAC3C,SAAOk8B,MAAS,MAAM2wB,GAAoB7sD,CAAI,IAAI+sD,GAAoB/sD,CAAI;AAC9E,GACImtD,KAAqB,SAAUjxB,GAAMyB,GAAW;AAMhD,SAAOzB,MAAS,OAAOyB,MAAc,QAAQ,KAAK;AACtD,GACWghB,KAAe,SAAUziB,GAAMkxB,GAAWvnC,GAAOwnC,GAAaC,GAAc;AACnF,MAAIC,IAAkBJ,GAAmBjxB,GAAM,OAAO,iBAAiBkxB,CAAS,EAAE,SAAS,GACvFI,IAAQD,IAAkBF,GAE1BtnC,IAASF,EAAM,QACf4nC,IAAeL,EAAU,SAASrnC,CAAM,GACxC2nC,IAAqB,IACrBC,IAAkBH,IAAQ,GAC1BI,IAAkB,GAClBC,IAAqB;AACzB,KAAG;AACC,QAAI,CAAC9nC;AACD;AAEJ,QAAIwiC,IAAKmE,GAAmBxwB,GAAMnW,CAAM,GAAGpR,IAAW4zC,EAAG,CAAC,GAAGuF,IAAWvF,EAAG,CAAC,GAAGwF,IAAWxF,EAAG,CAAC,GAC1FyF,IAAgBF,IAAWC,IAAWR,IAAkB54C;AAC5D,KAAIA,KAAYq5C,MACRvB,GAAuBvwB,GAAMnW,CAAM,MACnC6nC,KAAmBI,GACnBH,KAAsBl5C;AAG9B,QAAIs5C,IAAWloC,EAAO;AAGtB,IAAAA,IAAUkoC,KAAYA,EAAS,aAAa,KAAK,yBAAyBA,EAAS,OAAOA;AAAA,EAC9F;AAAA;AAAA,IAEC,CAACR,KAAgB1nC,MAAW,SAAS;AAAA,IAEjC0nC,MAAiBL,EAAU,SAASrnC,CAAM,KAAKqnC,MAAcrnC;AAAA;AAElE,UAAI4nC,KACkB,KAAK,IAAIC,CAAe,IAAI,KAGzC,CAACD,KACY,KAAK,IAAIE,CAAkB,IAAI,OACjDH,IAAqB,KAElBA;AACX,GCrGWQ,KAAa,SAAUroC,GAAO;AACrC,SAAO,oBAAoBA,IAAQ,CAACA,EAAM,eAAe,CAAC,EAAE,SAASA,EAAM,eAAe,CAAC,EAAE,OAAO,IAAI,CAAC,GAAG,CAAC;AACjH,GACWsoC,KAAa,SAAUtoC,GAAO;AAAE,SAAO,CAACA,EAAM,QAAQA,EAAM,MAAM;AAAG,GAC5EuoC,KAAa,SAAUvuD,GAAK;AAC5B,SAAOA,KAAO,aAAaA,IAAMA,EAAI,UAAUA;AACnD,GACIwuD,KAAe,SAAUpwB,GAAGC,GAAG;AAAE,SAAOD,EAAE,CAAC,MAAMC,EAAE,CAAC,KAAKD,EAAE,CAAC,MAAMC,EAAE,CAAC;AAAG,GACxEowB,KAAgB,SAAUnvD,GAAI;AAAE,SAAO;AAAA,yBAA4B,OAAOA,GAAI;AAAA,wBAAmD,EAAE,OAAOA,GAAI;AAAA,CAA2B;AAAG,GAC5KovD,KAAY,GACZC,KAAY,CAAA;AACT,SAASC,GAAoBrzD,GAAO;AACvC,MAAIszD,IAAqBrzD,EAAM,OAAO,EAAE,GACpCszD,IAAgBtzD,EAAM,OAAO,CAAC,GAAG,CAAC,CAAC,GACnCuzD,IAAavzD,EAAM,OAAM,GACzB8D,IAAK9D,EAAM,SAASkzD,IAAW,EAAE,CAAC,GAClCjD,IAAQjwD,EAAM,SAASsvD,EAAc,EAAE,CAAC,GACxCkE,IAAYxzD,EAAM,OAAOD,CAAK;AAClC,EAAAC,EAAM,UAAU,WAAY;AACxB,IAAAwzD,EAAU,UAAUzzD;AAAA,EACxB,GAAG,CAACA,CAAK,CAAC,GACVC,EAAM,UAAU,WAAY;AACxB,QAAID,EAAM,OAAO;AACb,eAAS,KAAK,UAAU,IAAI,uBAAuB,OAAO+D,CAAE,CAAC;AAC7D,UAAI2vD,IAAUtI,GAAc,CAACprD,EAAM,QAAQ,OAAO,IAAIA,EAAM,UAAU,CAAA,GAAI,IAAIgzD,EAAU,GAAG,EAAI,EAAE,OAAO,OAAO;AAC/G,aAAAU,EAAQ,QAAQ,SAAUp4C,GAAI;AAAE,eAAOA,EAAG,UAAU,IAAI,uBAAuB,OAAOvX,CAAE,CAAC;AAAA,MAAG,CAAC,GACtF,WAAY;AACf,iBAAS,KAAK,UAAU,OAAO,uBAAuB,OAAOA,CAAE,CAAC,GAChE2vD,EAAQ,QAAQ,SAAUp4C,GAAI;AAAE,iBAAOA,EAAG,UAAU,OAAO,uBAAuB,OAAOvX,CAAE,CAAC;AAAA,QAAG,CAAC;AAAA,MACpG;AAAA,IACJ;AAAA,EAEJ,GAAG,CAAC/D,EAAM,OAAOA,EAAM,QAAQ,SAASA,EAAM,MAAM,CAAC;AACrD,MAAI2zD,IAAoB1zD,EAAM,YAAY,SAAUwqB,GAAOtQ,GAAQ;AAC/D,QAAK,aAAasQ,KAASA,EAAM,QAAQ,WAAW,KAAOA,EAAM,SAAS,WAAWA,EAAM;AACvF,aAAO,CAACgpC,EAAU,QAAQ;AAE9B,QAAIG,IAAQd,GAAWroC,CAAK,GACxBopC,IAAaN,EAAc,SAC3BO,IAAS,YAAYrpC,IAAQA,EAAM,SAASopC,EAAW,CAAC,IAAID,EAAM,CAAC,GACnEG,IAAS,YAAYtpC,IAAQA,EAAM,SAASopC,EAAW,CAAC,IAAID,EAAM,CAAC,GACnEI,GACArpC,IAASF,EAAM,QACfwpC,IAAgB,KAAK,IAAIH,CAAM,IAAI,KAAK,IAAIC,CAAM,IAAI,MAAM;AAEhE,QAAI,aAAatpC,KAASwpC,MAAkB,OAAOtpC,EAAO,SAAS;AAC/D,aAAO;AAGX,QAAIupC,IAAY,OAAO,aAAY,GAC/BC,IAAaD,KAAaA,EAAU,YACpCE,IAAsBD,IAAaA,MAAexpC,KAAUwpC,EAAW,SAASxpC,CAAM,IAAI;AAC9F,QAAIypC;AACA,aAAO;AAEX,QAAIC,IAA+BlD,GAAwB8C,GAAetpC,CAAM;AAChF,QAAI,CAAC0pC;AACD,aAAO;AAUX,QARIA,IACAL,IAAcC,KAGdD,IAAcC,MAAkB,MAAM,MAAM,KAC5CI,IAA+BlD,GAAwB8C,GAAetpC,CAAM,IAG5E,CAAC0pC;AACD,aAAO;AAKX,QAHI,CAACb,EAAW,WAAW,oBAAoB/oC,MAAUqpC,KAAUC,OAC/DP,EAAW,UAAUQ,IAErB,CAACA;AACD,aAAO;AAEX,QAAIM,IAAgBd,EAAW,WAAWQ;AAC1C,WAAOzQ,GAAa+Q,GAAen6C,GAAQsQ,GAAO6pC,MAAkB,MAAMR,IAASC,CAAY;AAAA,EACnG,GAAG,CAAA,CAAE,GACDQ,IAAgBt0D,EAAM,YAAY,SAAUu0D,GAAQ;AACpD,QAAI/pC,IAAQ+pC;AACZ,QAAI,GAACpB,GAAU,UAAUA,GAAUA,GAAU,SAAS,CAAC,MAAMlD,IAI7D;AAAA,UAAIkC,IAAQ,YAAY3nC,IAAQsoC,GAAWtoC,CAAK,IAAIqoC,GAAWroC,CAAK,GAChEgqC,IAAcnB,EAAmB,QAAQ,OAAO,SAAUl6B,GAAG;AAAE,eAAOA,EAAE,SAAS3O,EAAM,SAAS2O,EAAE,WAAW3O,EAAM,UAAUA,EAAM,WAAW2O,EAAE,iBAAiB65B,GAAa75B,EAAE,OAAOg5B,CAAK;AAAA,MAAG,CAAC,EAAE,CAAC;AAEvM,UAAIqC,KAAeA,EAAY,QAAQ;AACnC,QAAIhqC,EAAM,cACNA,EAAM,eAAc;AAExB;AAAA,MACJ;AAEA,UAAI,CAACgqC,GAAa;AACd,YAAIC,KAAcjB,EAAU,QAAQ,UAAU,CAAA,GACzC,IAAIT,EAAU,EACd,OAAO,OAAO,EACd,OAAO,SAAUpuD,GAAM;AAAE,iBAAOA,EAAK,SAAS6lB,EAAM,MAAM;AAAA,QAAG,CAAC,GAC/DkqC,IAAaD,EAAW,SAAS,IAAIf,EAAkBlpC,GAAOiqC,EAAW,CAAC,CAAC,IAAI,CAACjB,EAAU,QAAQ;AACtG,QAAIkB,KACIlqC,EAAM,cACNA,EAAM,eAAc;AAAA,MAGhC;AAAA;AAAA,EACJ,GAAG,CAAA,CAAE,GACDmqC,IAAe30D,EAAM,YAAY,SAAUurB,GAAM4mC,GAAOznC,GAAQkqC,GAAQ;AACxE,QAAIpqC,IAAQ,EAAE,MAAMe,GAAM,OAAO4mC,GAAO,QAAQznC,GAAQ,QAAQkqC,GAAQ,cAAcC,GAAyBnqC,CAAM,EAAC;AACtH,IAAA2oC,EAAmB,QAAQ,KAAK7oC,CAAK,GACrC,WAAW,WAAY;AACnB,MAAA6oC,EAAmB,UAAUA,EAAmB,QAAQ,OAAO,SAAUl6B,GAAG;AAAE,eAAOA,MAAM3O;AAAA,MAAO,CAAC;AAAA,IACvG,GAAG,CAAC;AAAA,EACR,GAAG,CAAA,CAAE,GACDsqC,IAAmB90D,EAAM,YAAY,SAAUwqB,GAAO;AACtD,IAAA8oC,EAAc,UAAUT,GAAWroC,CAAK,GACxC+oC,EAAW,UAAU;AAAA,EACzB,GAAG,CAAA,CAAE,GACDwB,IAAc/0D,EAAM,YAAY,SAAUwqB,GAAO;AACjD,IAAAmqC,EAAanqC,EAAM,MAAMsoC,GAAWtoC,CAAK,GAAGA,EAAM,QAAQkpC,EAAkBlpC,GAAOzqB,EAAM,QAAQ,OAAO,CAAC;AAAA,EAC7G,GAAG,CAAA,CAAE,GACDi1D,IAAkBh1D,EAAM,YAAY,SAAUwqB,GAAO;AACrD,IAAAmqC,EAAanqC,EAAM,MAAMqoC,GAAWroC,CAAK,GAAGA,EAAM,QAAQkpC,EAAkBlpC,GAAOzqB,EAAM,QAAQ,OAAO,CAAC;AAAA,EAC7G,GAAG,CAAA,CAAE;AACL,EAAAC,EAAM,UAAU,WAAY;AACxB,WAAAmzD,GAAU,KAAKlD,CAAK,GACpBlwD,EAAM,aAAa;AAAA,MACf,iBAAiBg1D;AAAA,MACjB,gBAAgBA;AAAA,MAChB,oBAAoBC;AAAA,IAChC,CAAS,GACD,SAAS,iBAAiB,SAASV,GAAezD,EAAU,GAC5D,SAAS,iBAAiB,aAAayD,GAAezD,EAAU,GAChE,SAAS,iBAAiB,cAAciE,GAAkBjE,EAAU,GAC7D,WAAY;AACf,MAAAsC,KAAYA,GAAU,OAAO,SAAU8B,GAAM;AAAE,eAAOA,MAAShF;AAAA,MAAO,CAAC,GACvE,SAAS,oBAAoB,SAASqE,GAAezD,EAAU,GAC/D,SAAS,oBAAoB,aAAayD,GAAezD,EAAU,GACnE,SAAS,oBAAoB,cAAciE,GAAkBjE,EAAU;AAAA,IAC3E;AAAA,EACJ,GAAG,CAAA,CAAE;AACL,MAAI/C,IAAkB/tD,EAAM,iBAAiBmuD,IAAQnuD,EAAM;AAC3D,SAAQC,EAAM;AAAA,IAAcA,EAAM;AAAA,IAAU;AAAA,IACxCkuD,IAAQluD,EAAM,cAAciwD,GAAO,EAAE,QAAQgD,GAAcnvD,CAAE,EAAC,CAAE,IAAI;AAAA,IACpEgqD,IAAkB9tD,EAAM,cAAc0wD,IAAiB,EAAE,YAAY3wD,EAAM,YAAY,SAASA,EAAM,QAAO,CAAE,IAAI;AAAA,EAAI;AAC/H;AACA,SAAS80D,GAAyBlwD,GAAM;AAEpC,WADIuwD,IAAe,MACZvwD,MAAS;AACZ,IAAIA,aAAgB,eAChBuwD,IAAevwD,EAAK,MACpBA,IAAOA,EAAK,OAEhBA,IAAOA,EAAK;AAEhB,SAAOuwD;AACX;AChKA,MAAAjI,KAAeI,GAAcE,IAAW6F,EAAmB;ACC3D,IAAI+B,KAAoBn1D,EAAM,WAAW,SAAUD,GAAOyE,GAAK;AAAE,SAAQxE,EAAM,cAAcytD,IAAczC,GAAS,IAAIjrD,GAAO,EAAE,KAAKyE,GAAK,SAASyoD,GAAO,CAAE,CAAC;AAAI,CAAC;AACnKkI,GAAkB,aAAa1H,GAAa;ACgB5C,IAAI2H,KAAe,WACf,CAACC,EAAwC,IAAI16B,GAAmBy6B,IAAc;AAAA,EAChF7d;AACF,CAAC,GACGkH,KAAiBlH,GAAiB,GAClC,CAAC+d,IAAiBC,EAAiB,IAAIF,GAAqBD,EAAY,GACxEI,KAAU,CAACz1D,MAAU;AACvB,QAAM;AAAA,IACJ,gBAAA01D;AAAA,IACA,UAAAxxD;AAAA,IACA,MAAM2zB;AAAA,IACN,aAAAC;AAAA,IACA,cAAAG;AAAA,IACA,OAAA09B,IAAQ;AAAA,EACZ,IAAM31D,GACEigD,IAAcvB,GAAegX,CAAc,GAC3Cx8C,IAAajZ,EAAM,OAAO,IAAI,GAC9B,CAAC21D,GAAiBC,CAAkB,IAAI51D,EAAM,SAAS,EAAK,GAC5D,CAACu4B,GAAMC,CAAO,IAAI+kB,GAAqB;AAAA,IAC3C,MAAM3lB;AAAA,IACN,aAAaC,KAAe;AAAA,IAC5B,UAAUG;AAAA,IACV,QAAQo9B;AAAA,EACZ,CAAG;AACD,SAAuB,gBAAA9wD,EAAIo8C,IAAsB,EAAE,GAAGV,GAAa,UAA0B,gBAAA17C;AAAA,IAC3FgxD;AAAA,IACA;AAAA,MACE,OAAOG;AAAA,MACP,WAAW71B,GAAK;AAAA,MAChB,YAAA3mB;AAAA,MACA,MAAAsf;AAAA,MACA,cAAcC;AAAA,MACd,cAAcx4B,EAAM,YAAY,MAAMw4B,EAAQ,CAACq9B,MAAa,CAACA,CAAQ,GAAG,CAACr9B,CAAO,CAAC;AAAA,MACjF,iBAAAm9B;AAAA,MACA,mBAAmB31D,EAAM,YAAY,MAAM41D,EAAmB,EAAI,GAAG,EAAE;AAAA,MACvE,sBAAsB51D,EAAM,YAAY,MAAM41D,EAAmB,EAAK,GAAG,EAAE;AAAA,MAC3E,OAAAF;AAAA,MACA,UAAAzxD;AAAA,IACN;AAAA,EACA,GAAK;AACL;AACAuxD,GAAQ,cAAcJ;AACtB,IAAItd,KAAc,iBACdge,KAAgB91D,EAAM;AAAA,EACxB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,gBAAA8vD,GAAgB,GAAGxd,EAAW,IAAKl4C,GACrCguB,IAAUwnC,GAAkBzd,IAAa2d,CAAc,GACvDzV,IAAcvB,GAAegX,CAAc,GAC3C,EAAE,mBAAAM,GAAmB,sBAAAC,EAAoB,IAAKjoC;AACpD,WAAA/tB,EAAM,UAAU,OACd+1D,EAAiB,GACV,MAAMC,EAAoB,IAChC,CAACD,GAAmBC,CAAoB,CAAC,GACrB,gBAAA1xD,EAAI28C,IAAwB,EAAE,GAAGjB,GAAa,GAAG/H,GAAa,KAAKtyC,GAAc;AAAA,EAC1G;AACF;AACAmwD,GAAc,cAAche;AAC5B,IAAI6I,KAAe,kBACfsV,KAAiBj2D,EAAM;AAAA,EACzB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,gBAAA8vD,GAAgB,GAAG5U,EAAY,IAAK9gD,GACtCguB,IAAUwnC,GAAkB5U,IAAc8U,CAAc,GACxDzV,IAAcvB,GAAegX,CAAc,GAC3CS,IAAqBlxD,GAAgBW,GAAcooB,EAAQ,UAAU,GACrEhU,IAA0B,gBAAAzV;AAAA,MAC9B03B,GAAU;AAAA,MACV;AAAA,QACE,MAAM;AAAA,QACN,iBAAiB;AAAA,QACjB,iBAAiBjO,EAAQ;AAAA,QACzB,iBAAiBA,EAAQ;AAAA,QACzB,cAAcooC,GAASpoC,EAAQ,IAAI;AAAA,QACnC,GAAG8yB;AAAA,QACH,KAAKqV;AAAA,QACL,SAAS7mC,GAAqBtvB,EAAM,SAASguB,EAAQ,YAAY;AAAA,MACzE;AAAA,IACA;AACI,WAAOA,EAAQ,kBAAkBhU,IAA0B,gBAAAzV,EAAI28C,IAAwB,EAAE,SAAS,IAAM,GAAGjB,GAAa,UAAUjmC,EAAO,CAAE;AAAA,EAC7I;AACF;AACAk8C,GAAe,cAActV;AAC7B,IAAIlF,KAAc,iBACd,CAACyF,IAAgBC,EAAgB,IAAIkU,GAAqB5Z,IAAa;AAAA,EACzE,YAAY;AACd,CAAC,GACG2a,KAAgB,CAACr2D,MAAU;AAC7B,QAAM,EAAE,gBAAA01D,GAAgB,YAAApU,GAAY,UAAAp9C,GAAU,WAAAq1B,EAAS,IAAKv5B,GACtDguB,IAAUwnC,GAAkB9Z,IAAaga,CAAc;AAC7D,SAAuB,gBAAAnxD,EAAI48C,IAAgB,EAAE,OAAOuU,GAAgB,YAAApU,GAAY,UAA0B,gBAAA/8C,EAAI43C,IAAU,EAAE,SAASmF,KAActzB,EAAQ,MAAM,UAA0B,gBAAAzpB,EAAIg9C,IAAiB,EAAE,SAAS,IAAM,WAAAhoB,GAAW,UAAAr1B,GAAU,EAAC,CAAE,EAAC,CAAE;AAC5P;AACAmyD,GAAc,cAAc3a;AAC5B,IAAIrD,KAAe,kBACfie,KAAiBr2D,EAAM;AAAA,EACzB,CAACD,GAAO4F,MAAiB;AACvB,UAAM67C,IAAgBL,GAAiB/I,IAAcr4C,EAAM,cAAc,GACnE,EAAE,YAAAshD,IAAaG,EAAc,YAAY,GAAGrI,EAAY,IAAKp5C,GAC7DguB,IAAUwnC,GAAkBnd,IAAcr4C,EAAM,cAAc;AACpE,WAAuB,gBAAAuE,EAAI43C,IAAU,EAAE,SAASmF,KAActzB,EAAQ,MAAM,UAAUA,EAAQ,QAAwB,gBAAAzpB,EAAIgyD,IAAqB,EAAE,GAAGnd,GAAc,KAAKxzC,EAAY,CAAE,IAAoB,gBAAArB,EAAIiyD,IAAwB,EAAE,GAAGpd,GAAc,KAAKxzC,EAAY,CAAE,EAAC,CAAE;AAAA,EAChR;AACF;AACA0wD,GAAe,cAAcje;AAC7B,IAAIjyC,KAAOb,gBAAAA,GAAW,6BAA6B,GAC/CgxD,KAAsBt2D,EAAM;AAAA,EAC9B,CAACD,GAAO4F,MAAiB;AACvB,UAAMooB,IAAUwnC,GAAkBnd,IAAcr4C,EAAM,cAAc,GAC9Dy2D,IAAax2D,EAAM,OAAO,IAAI,GAC9B29B,IAAe34B,GAAgBW,GAAc6wD,CAAU,GACvDC,IAAyBz2D,EAAM,OAAO,EAAK;AACjD,WAAAA,EAAM,UAAU,MAAM;AACpB,YAAMyK,IAAU+rD,EAAW;AAC3B,UAAI/rD,EAAS,QAAOqgD,GAAWrgD,CAAO;AAAA,IACxC,GAAG,CAAA,CAAE,GACkB,gBAAAnG,EAAImpD,IAAc,EAAE,IAAItnD,IAAM,gBAAgB,IAAM,UAA0B,gBAAA7B;AAAA,MACnGoyD;AAAA,MACA;AAAA,QACE,GAAG32D;AAAA,QACH,KAAK49B;AAAA,QACL,WAAW5P,EAAQ;AAAA,QACnB,6BAA6B;AAAA,QAC7B,kBAAkBsB,GAAqBtvB,EAAM,kBAAkB,CAACyqB,MAAU;AACxE,UAAAA,EAAM,eAAc,GACfisC,EAAuB,WAAS1oC,EAAQ,WAAW,SAAS,MAAK;AAAA,QACxE,CAAC;AAAA,QACD,sBAAsBsB;AAAA,UACpBtvB,EAAM;AAAA,UACN,CAACyqB,MAAU;AACT,kBAAMmsC,IAAgBnsC,EAAM,OAAO,eAC7BosC,IAAgBD,EAAc,WAAW,KAAKA,EAAc,YAAY,IACxEE,IAAeF,EAAc,WAAW,KAAKC;AACnD,YAAAH,EAAuB,UAAUI;AAAA,UACnC;AAAA,UACA,EAAE,0BAA0B,GAAK;AAAA,QAC3C;AAAA,QACQ,gBAAgBxnC;AAAA,UACdtvB,EAAM;AAAA,UACN,CAACyqB,MAAUA,EAAM,eAAc;AAAA,UAC/B,EAAE,0BAA0B,GAAK;AAAA,QAC3C;AAAA,MACA;AAAA,IACA,GAAO;AAAA,EACL;AACF,GACI+rC,KAAyBv2D,EAAM;AAAA,EACjC,CAACD,GAAO4F,MAAiB;AACvB,UAAMooB,IAAUwnC,GAAkBnd,IAAcr4C,EAAM,cAAc,GAC9D+2D,IAA0B92D,EAAM,OAAO,EAAK,GAC5C+2D,IAA2B/2D,EAAM,OAAO,EAAK;AACnD,WAAuB,gBAAAsE;AAAA,MACrBoyD;AAAA,MACA;AAAA,QACE,GAAG32D;AAAA,QACH,KAAK4F;AAAA,QACL,WAAW;AAAA,QACX,6BAA6B;AAAA,QAC7B,kBAAkB,CAAC6kB,MAAU;AAC3B,UAAAzqB,EAAM,mBAAmByqB,CAAK,GACzBA,EAAM,qBACJssC,EAAwB,WAAS/oC,EAAQ,WAAW,SAAS,MAAK,GACvEvD,EAAM,eAAc,IAEtBssC,EAAwB,UAAU,IAClCC,EAAyB,UAAU;AAAA,QACrC;AAAA,QACA,mBAAmB,CAACvsC,MAAU;AAC5B,UAAAzqB,EAAM,oBAAoByqB,CAAK,GAC1BA,EAAM,qBACTssC,EAAwB,UAAU,IAC9BtsC,EAAM,OAAO,cAAc,SAAS,kBACtCusC,EAAyB,UAAU;AAGvC,gBAAMrsC,IAASF,EAAM;AAErB,UADwBuD,EAAQ,WAAW,SAAS,SAASrD,CAAM,KAC9CF,EAAM,eAAc,GACrCA,EAAM,OAAO,cAAc,SAAS,aAAausC,EAAyB,WAC5EvsC,EAAM,eAAc;AAAA,QAExB;AAAA,MACR;AAAA,IACA;AAAA,EACE;AACF,GACIksC,KAAqB12D,EAAM;AAAA,EAC7B,CAACD,GAAO4F,MAAiB;AACvB,UAAM;AAAA,MACJ,gBAAA8vD;AAAA,MACA,WAAAuB;AAAA,MACA,iBAAAC;AAAA,MACA,kBAAAC;AAAA,MACA,6BAAA/5B;AAAA,MACA,iBAAAR;AAAA,MACA,sBAAAS;AAAA,MACA,gBAAAC;AAAA,MACA,mBAAAC;AAAA,MACA,GAAG6b;AAAA,IACT,IAAQp5C,GACEguB,IAAUwnC,GAAkBnd,IAAcqd,CAAc,GACxDzV,IAAcvB,GAAegX,CAAc;AACjD,WAAAvP,GAAc,GACS,gBAAA5hD;AAAA,MACrBmiD;AAAA,MACA;AAAA,QACE,SAAS;AAAA,QACT,MAAM;AAAA,QACN,SAASuQ;AAAA,QACT,kBAAkBC;AAAA,QAClB,oBAAoBC;AAAA,QACpB,UAA0B,gBAAA5yD;AAAA,UACxB44B;AAAA,UACA;AAAA,YACE,SAAS;AAAA,YACT,6BAAAC;AAAA,YACA,mBAAAG;AAAA,YACA,iBAAAX;AAAA,YACA,sBAAAS;AAAA,YACA,gBAAAC;AAAA,YACA,WAAW,MAAMtP,EAAQ,aAAa,EAAK;AAAA,YAC3C,UAA0B,gBAAAzpB;AAAA,cACxBi/C;AAAAA,cACA;AAAA,gBACE,cAAc4S,GAASpoC,EAAQ,IAAI;AAAA,gBACnC,MAAM;AAAA,gBACN,IAAIA,EAAQ;AAAA,gBACZ,GAAGiyB;AAAA,gBACH,GAAG7G;AAAA,gBACH,KAAKxzC;AAAA,gBACL,OAAO;AAAA,kBACL,GAAGwzC,EAAa;AAAA,kBAGd,4CAA4C;AAAA,kBAC5C,2CAA2C;AAAA,kBAC3C,4CAA4C;AAAA,kBAC5C,iCAAiC;AAAA,kBACjC,kCAAkC;AAAA,gBAEtD;AAAA,cACA;AAAA,YACA;AAAA,UACA;AAAA,QACA;AAAA,MACA;AAAA,IACA;AAAA,EACE;AACF,GACIge,KAAa,gBACbC,KAAep3D,EAAM;AAAA,EACvB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,gBAAA8vD,GAAgB,GAAG4B,EAAU,IAAKt3D,GACpCguB,IAAUwnC,GAAkB4B,IAAY1B,CAAc;AAC5D,WAAuB,gBAAAnxD;AAAA,MACrB03B,GAAU;AAAA,MACV;AAAA,QACE,MAAM;AAAA,QACN,GAAGq7B;AAAA,QACH,KAAK1xD;AAAA,QACL,SAAS0pB,GAAqBtvB,EAAM,SAAS,MAAMguB,EAAQ,aAAa,EAAK,CAAC;AAAA,MACtF;AAAA,IACA;AAAA,EACE;AACF;AACAqpC,GAAa,cAAcD;AAC3B,IAAIvc,KAAa,gBACb0c,KAAet3D,EAAM;AAAA,EACvB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,gBAAA8vD,GAAgB,GAAG1e,EAAU,IAAKh3C,GACpCigD,IAAcvB,GAAegX,CAAc;AACjD,WAAuB,gBAAAnxD,EAAIo/C,IAAuB,EAAE,GAAG1D,GAAa,GAAGjJ,GAAY,KAAKpxC,GAAc;AAAA,EACxG;AACF;AACA2xD,GAAa,cAAc1c;AAC3B,SAASub,GAAS59B,GAAM;AACtB,SAAOA,IAAO,SAAS;AACzB;AACA,IAAI+iB,KAAQka,IAER5Q,KAAUqR,IACVva,KAAS0a,IACTvR,KAAWwR;ACtSf,MAAMb,KAAU+B,IAEVtB,KAAiBuB,IAIjBnB,KAAiBr2D,EAAM,WAG3B,CAAC,EAAE,WAAAkE,GAAW,OAAAu0C,IAAQ,UAAU,YAAAD,IAAa,GAAG,GAAGz4C,EAAA,GAASyE,MAC5D,gBAAAF,EAACmzD,IAAA,EACC,UAAA,gBAAAnzD;AAAA,EAACozD;AAAAA,EAAA;AAAA,IACC,KAAAlzD;AAAA,IACA,OAAAi0C;AAAA,IACA,YAAAD;AAAA,IACA,WAAWp0C;AAAA,MACT;AAAA,MACAF;AAAA,IAAA;AAAA,IAED,GAAGnE;AAAA,EAAA;AACN,EAAA,CACF,CACD;AACDs2D,GAAe,cAAcqB,GAAyB;;;;GCPhDtS,KAAe,CAACjuB,IAA8B,aAAa;AAC/D,QAAM,CAAC+K,GAAMuW,CAAK,IAAIthB,EAAU,MAAM,GAAG;AACzC,SAAO,EAAE,MAAA+K,GAAM,OAAQuW,KAAS,SAAA;AAClC,GAEa+c,KAAU,CAAC;AAAA,EACtB,UAAAvxD;AAAA,EACA,WAAAkzB,IAAY;AAAA,EACZ,QAAAzM;AAAA,EACA,WAAAxmB;AAAA,EACA,QAAAuhD;AAAA,EACA,QAAAC;AAAA,EACA,cAAA1tB;AACF,MAAoB;AAClB,QAAM,CAACK,GAAcC,CAAe,IAAIjgB,EAAS,EAAK,GAChD,CAAC6e,GAAM0uB,CAAO,IAAIvtC,EAAyB,IAAI,GAC/CkgB,IAAOktB,KAAUptB,GACjB,EAAE,MAAA6J,GAAM,OAAAuW,EAAA,IAAU/gC,GAAQ,MAAM0tC,GAAajuB,CAAS,GAAG,CAACA,CAAS,CAAC,GAEpE0uB,IAAapsC,EAAY,MAAM;AACnC,IAAAmsC,EAAQl7B,EAAO,SAAS,sBAAA,KAA2B,IAAI;AAAA,EACzD,GAAG,CAACA,CAAM,CAAC,GAEL8N,IAAU/e;AAAA,IACd,CAAC/V,MAAmB;AAClB,MAAI+hD,MAAW,UACbntB,EAAgB50B,CAAK,GAEvBs0B,IAAet0B,CAAK;AAAA,IACtB;AAAA,IACA,CAAC+hD,GAAQztB,CAAY;AAAA,EAAA;AAGvB,SAAAtf,GAAU,MAAM;AACd,UAAMi/C,IAAgBjtC,EAAO;AAC7B,QAAI,CAACitC;AACH;AAGF,UAAM3lC,IAAc,MAAM;AACxB,MAAA6zB,EAAA,GACArtB,EAAQ,CAACD,CAAI,GACbmtB,IAAA;AAAA,IACF;AAEA,WAAAiS,EAAc,iBAAiB,SAAS3lC,CAAW,GACnD,OAAO,iBAAiB,UAAU6zB,GAAY,EAAI,GAClD,OAAO,iBAAiB,UAAUA,CAAU,GAErC,MAAM;AACX,MAAA8R,EAAc,oBAAoB,SAAS3lC,CAAW,GACtD,OAAO,oBAAoB,UAAU6zB,GAAY,EAAI,GACrD,OAAO,oBAAoB,UAAUA,CAAU;AAAA,IACjD;AAAA,EACF,GAAG,CAACttB,GAAMC,GAAS9N,GAAQg7B,GAAQG,CAAU,CAAC,GAG5C,gBAAA1hD,EAACyzD,IAAA,EAAU,MAAAr/B,GAAY,cAAcC,GACnC,UAAA;AAAA,IAAA,gBAAAl0B,EAAC2xD,IAAA,EAAe,SAAO,IACrB,UAAA,gBAAA3xD;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,WAAWD,GAAI;AAAA,QACf,OAAO6yB,IAAO,EAAE,MAAMA,EAAK,MAAM,KAAKA,EAAK,KAAK,OAAOA,EAAK,OAAO,QAAQA,EAAK,WAAW;AAAA,MAAA;AAAA,IAAA,GAE/F;AAAA,IACA,gBAAA5yB,EAAC+xD,IAAA,EAAe,MAAAn0B,GAAY,OAAAuW,GAAc,WAAWr0C,EAAGC,GAAI,SAASH,CAAS,GAC3E,UAAAD,EAAA,CACH;AAAA,EAAA,GACF;AAEJ;;;;;GC7Ea4zD,KAAgD,CAAC;AAAA,EAC5D,KAAAC,sBAAOC,IAAA,EAAU;AAAA,EACjB,OAAAh0D,IAAQ;AAAA,EACR,UAAAC;AAAA,EACA,SAAAyG;AAAA,EACA,WAAAvG;AACF,wBACG,OAAA,EAAI,WAAWE,EAAGC,GAAI,gBAAgBH,CAAS,GAC9C,UAAA;AAAA,EAAA,gBAAAI,EAAC,OAAA,EAAI,WAAWD,GAAI,YAAa,UAAAyzD,GAAI;AAAA,EACpC/zD,KAAS,gBAAAO,EAAC,QAAA,EAAK,WAAWD,GAAI,OAAQ,UAAAN,GAAM;AAAA,EAC5CC,KAAY,gBAAAM,EAAC,QAAA,EAAK,WAAWD,GAAI,UAAW,UAAAL,GAAS;AAAA,EACrDyG,KAAWA;AAAA,EAAA,CACd;;;;;;;;GCPWutD,KAA8B,CAAC;AAAA,EAC1C,QAAAC;AAAA,EACA,WAAA/zD;AAAA,EACA,SAAAuG;AAAA,EACA,UAAAytD;AAAA,EACA,QAAAzS;AAAA,EACA,aAAA5tB,IAAc;AAAA,EACd,IAAA/zB;AAAA,EACA,iBAAAq0D;AAAA,EACA,kBAAAC;AAAA,EACA,eAAAC;AACF,MAAM;AACJ,QAAM,CAACC,GAASC,CAAU,IAAIlgD,EAASwf,CAAW,GAC5C2gC,IAAY//C,GAAO,EAAK,GAExBggD,IAAe,OAAOhT,KAAW,YAAYA,IAAS6S,GACtD9zD,IAAMiU,GAAuB,IAAI,GAEjCigD,IACJ,OAAOT,KAAW,WAChB,gBAAA3zD,EAAC,OAAA,EAAI,WAAWD,GAAI,aAClB,UAAA,gBAAAC,EAAC,QAAA,EAAM,UAAA2zD,EAAA,CAAO,GAChB,IAEAA,GAGEU,IACJ,OAAOluD,KAAY,WAAW,gBAAAnG,EAAC,UAAK,WAAWD,GAAI,cAAe,UAAAoG,EAAA,CAAQ,IAAUA;AAEtF,EAAAiO,GAAU,MAAM;AACd,UAAM2C,IAAK7W,EAAI;AACf,QAAK6W,GAIL;AAAA,UAAI,CAACm9C,EAAU,SAAS;AACtB,QAAAn9C,EAAG,MAAM,SAASwc,IAAc,SAAS,OACzC2gC,EAAU,UAAU;AACpB;AAAA,MACF;AAEA,UAAIC,GAAc;AAChB,QAAAp9C,EAAG,MAAM,SAAS,GAAGA,EAAG,YAAY;AAEpC,cAAMu9C,IAAQ,MAAM;AAClB,UAAAv9C,EAAG,MAAM,SAAS;AAAA,QACpB;AAEA,QAAAA,EAAG,iBAAiB,iBAAiBu9C,GAAO,EAAE,MAAM,IAAM;AAAA,MAC5D;AACE,QAAAv9C,EAAG,MAAM,SAAS,GAAGA,EAAG,YAAY,MAEpC,sBAAsB,MAAM;AAC1B,UAAAA,EAAG,MAAM,SAAS;AAAA,QACpB,CAAC;AAAA;AAAA,EAEL,GAAG,CAACo9C,GAAc5gC,CAAW,CAAC;AAE9B,QAAMghC,IAAkCp/C;AAAA,IACtC,CAAC0f,MAAM;AACL,MAAAA,EAAE,gBAAA,GACF++B,IAAWA,MAAaK,EAAW,CAAChgC,MAAS,CAACA,CAAI;AAAA,IACpD;AAAA,IACA,CAAC2/B,CAAQ;AAAA,EAAA;AAGX,SACE,gBAAA/zD,EAAC,SAAI,WAAWC,EAAGC,GAAI,WAAWH,CAAS,GAAG,IAAAJ,GAC5C,UAAA;AAAA,IAAA,gBAAAK,EAAC,SAAI,WAAWC,EAAGC,GAAI,QAAQ8zD,CAAe,GAC3C,UAAA;AAAA,MAAAO;AAAA,MACD,gBAAAp0D,EAAC,SAAI,WAAWF,EAAGC,GAAI,aAAag0D,CAAa,GAAG,SAASQ,GAC3D,UAAA,gBAAAv0D;AAAA,QAACw0D;AAAAA,QAAA;AAAA,UACC,WAAW10D,EAAGC,GAAI,WAAWA,GAAI,gBAAgB,EAAE,CAACA,GAAI,UAAU,GAAGo0D,EAAA,CAAc;AAAA,QAAA;AAAA,MAAA,EACrF,CACF;AAAA,IAAA,GACF;AAAA,sBACC,OAAA,EAAI,WAAWr0D,EAAGC,GAAI,SAAS+zD,GAAkB,EAAE,CAAC/zD,GAAI,OAAO,GAAGo0D,EAAA,CAAc,GAAG,KAAAj0D,GACjF,UAAAm0D,EAAA,CACH;AAAA,EAAA,GACF;AAEJ;;;;;GCxFMI,KAAoC/4D,EAAM,KAAK,CAACD,MAAU;AAC9D,QAAM,EAAE,IAAA+D,GAAI,QAAAm0D,GAAQ,SAAAxtD,GAAS,WAAAvG,GAAW,oBAAA80D,GAAoB,GAAGjhD,MAAShY,GAElE,CAACk5D,GAAaC,CAAa,IAAI7gD,EAAS,EAAK,GAC7CqtC,IAAS,MAAMwT,EAAc,CAACD,CAAW;AAE/C,SACE,gBAAA30D;AAAA,IAAC0zD;AAAA,IAAA;AAAA,MACC,IAAAl0D;AAAA,MACA,WAAWM,EAAGC,GAAI,kBAAkBH,CAAS;AAAA,MAC7C,QACE80D,IACE,gBAAA70D,EAAC,OAAA,EAAI,WAAWE,GAAI,uBAClB,UAAA;AAAA,QAAA,gBAAAC,EAAC,UAAM,UAAA2zD,EAAA,CAAO;AAAA,0BACbkB,IAAA,EAAS,WAAW90D,GAAI,UAAU,IAAG,sCAAqC;AAAA,QAC3E,gBAAAC;AAAA,UAACihD;AAAA,UAAA;AAAA,YACC,UAAU;AAAA,YACV,OAAO,EAAE,MAAM,GAAG,MAAM,IAAA;AAAA,YACxB,QAAQ0T;AAAA,YACR,WAAU;AAAA,YACV,QAAO;AAAA,YACP,QAAAvT;AAAA,YAEC,UAAAsT;AAAA,UAAA;AAAA,QAAA;AAAA,MACH,EAAA,CACF,IAEAf;AAAA,MAGJ,SAAAxtD;AAAA,MACA,iBAAiBpG,GAAI;AAAA,MACpB,GAAG0T;AAAA,IAAA;AAAA,EAAA;AAGV,CAAC;ACuKD,IAAI08B,KAAW,OAAO,WAAa,KAE/BC,KAAO,WAAgB;AAAC,GACxBjnC,KAAQgnC,KAAWpb,KAAkBqb;AAGzC,MAAM0kB,KAAY;AAAA,EAChB,GAAGp5D;AACL,GASMs9C,KAAqB8b,GAAU,oBAC/BC,KAAyB/b,OAAuB,CAAAvY,MAAMA;AAC5D,SAASu0B,GAAerqC,GAAU;AAChC,QAAMzqB,IAAMxE,EAAM,OAAO,MAAM;AAC7B,QAAI,QAAQ,IAAI,aAAa;AAC3B,YAAM,IAAI,MAAM,+CAA+C;AAAA,EAEnE,CAAC;AACD,SAAAq5D,GAAuB,MAAM;AAC3B,IAAA70D,EAAI,UAAUyqB;AAAA,EAChB,CAAC,GACMjvB,EAAM,YAAY,WAAY;AACnC,aAASu5D,IAAO,UAAU,QAAQzyD,IAAO,IAAI,MAAMyyD,CAAI,GAAGC,IAAO,GAAGA,IAAOD,GAAMC;AAC/E,MAAA1yD,EAAK0yD,CAAI,IAAI,UAAUA,CAAI;AAE7B,WAAOh1D,EAAI,WAAW,OAAO,SAASA,EAAI,QAAQ,GAAGsC,CAAI;AAAA,EAC3D,GAAG,CAAA,CAAE;AACP;ACiHA,MAAMsyD,KAAY;AAAA,EAChB,GAAGp5D;AACL;AAEA,IAAIy5D,KAAwB,IACxB95B,KAAQ;AACZ,MAAM+5B,KAAQ;AAAA;AAAA;AAAA,EAEd,iBAAiB,KAAK,OAAM,EAAG,SAAS,EAAE,EAAE,MAAM,GAAG,CAAC,IAAI/5B;AAAA;AAC1D,SAASg6B,KAAgB;AACvB,QAAM,CAAC71D,GAAIg8B,CAAK,IAAI9/B,EAAM,SAAS,MAAMy5D,KAAwBC,GAAK,IAAK,MAAS;AACpFE,SAAAA,GAAsB,MAAM;AAC1B,IAAI91D,KAAM,QACRg8B,EAAM45B,GAAK,CAAE;AAAA,EAGjB,GAAG,CAAA,CAAE,GACL15D,EAAM,UAAU,MAAM;AACpB,IAAAy5D,KAAwB;AAAA,EAC1B,GAAG,CAAA,CAAE,GACE31D;AACT;AACA,MAAM47B,KAAa05B,GAAU,OAQvBx5B,KAAQF,MAAci6B;AAE5B,IAAIE;AACA,QAAQ,IAAI,aAAa,iBAC3BA,KAA6B,oBAAI,IAAG;AActC,SAASh5C,KAAQ;AAEf,WADIi5C,GACKC,IAAQ,UAAU,QAAQC,IAAW,IAAI,MAAMD,CAAK,GAAGE,IAAQ,GAAGA,IAAQF,GAAOE;AACxF,IAAAD,EAASC,CAAK,IAAI,UAAUA,CAAK;AAEnC,QAAMt+C,IAAU,kBAAkBq+C,EAAS,KAAK,GAAG;AACnD,MAAI,GAAGF,IAAkBD,OAAkB,QAAQC,EAAgB,IAAIn+C,CAAO,IAAI;AAChF,QAAIu+C;AACJ,KAACA,IAAkBL,OAAkB,QAAQK,EAAgB,IAAIv+C,CAAO,GACxE,QAAQ,MAAMA,CAAO;AAAA,EACvB;AACF;AAqHA,SAASw+C,KAAqB;AAC5B,QAAMC,IAAM,oBAAI,IAAG;AACnB,SAAO;AAAA,IACL,KAAK5vC,GAAOjQ,GAAM;AAChB,UAAI8/C;AACJ,OAACA,IAAWD,EAAI,IAAI5vC,CAAK,MAAM,QAAQ6vC,EAAS,QAAQ,CAAAC,MAAYA,EAAS//C,CAAI,CAAC;AAAA,IACpF;AAAA,IACA,GAAGiQ,GAAO8vC,GAAU;AAClB,MAAKF,EAAI,IAAI5vC,CAAK,KAChB4vC,EAAI,IAAI5vC,GAAO,oBAAI,IAAG,CAAE,GAE1B4vC,EAAI,IAAI5vC,CAAK,EAAE,IAAI8vC,CAAQ;AAAA,IAC7B;AAAA,IACA,IAAI9vC,GAAO8vC,GAAU;AACnB,UAAIC;AACJ,OAACA,IAAYH,EAAI,IAAI5vC,CAAK,MAAM,QAAQ+vC,EAAU,OAAOD,CAAQ;AAAA,IACnE;AAAA,EACJ;AACA;AAEA,MAAME,KAAmC,gBAAAx6D,EAAM,cAAc,IAAI,GAC3Dy6D,KAAmC,gBAAAz6D,EAAM,cAAc,IAAI,GAM3D06D,KAA0B,MAAM;AACpC,MAAIC;AACJ,WAASA,IAAoB36D,EAAM,WAAWw6D,EAAmB,MAAM,OAAO,SAASG,EAAkB,OAAO;AAClH,GAKMC,KAAkB,MAAM56D,EAAM,WAAWy6D,EAAmB;AAgvElE,SAASI,GAAuB70C,GAAS;AACvC,QAAM;AAAA,IACJ,MAAAuS,IAAO;AAAA,IACP,cAAcuiC;AAAA,IACd,UAAUC;AAAA,EACd,IAAM/0C,GACEg1C,IAAap7B,GAAK,GAClBqW,IAAUj2C,EAAM,OAAO,EAAE,GACzB,CAACi7D,CAAM,IAAIj7D,EAAM,SAAS,MAAMm6D,GAAkB,CAAE,GACpDe,IAASR,GAAuB,KAAM;AAC5C,MAAI,QAAQ,IAAI,aAAa,cAAc;AACzC,UAAMS,IAAqBJ,EAAa;AACxC,IAAII,KAAsB,CAACpwB,GAAUowB,CAAkB,KACrDt6C,GAAM,qEAAqE,uEAAuE,UAAU;AAAA,EAEhK;AACA,QAAM,CAACu6C,GAAmBC,CAAoB,IAAIr7D,EAAM,SAAS+6D,EAAa,SAAS,GACjF/iC,IAAeshC,GAAe,CAAC/gC,GAAM/N,GAAO8wC,MAAW;AAC3D,IAAArlB,EAAQ,QAAQ,YAAY1d,IAAO/N,IAAQ,QAC3CywC,EAAO,KAAK,cAAc;AAAA,MACxB,MAAA1iC;AAAA,MACA,OAAA/N;AAAA,MACA,QAAA8wC;AAAA,MACA,QAAAJ;AAAA,IACN,CAAK,GAC2BJ,IAAiBviC,GAAM/N,GAAO8wC,CAAM;AAAA,EAClE,CAAC,GACK52D,IAAO1E,EAAM,QAAQ,OAAO;AAAA,IAChC,sBAAAq7D;AAAA,EACJ,IAAM,CAAA,CAAE,GACAz3B,IAAW5jC,EAAM,QAAQ,OAAO;AAAA,IACpC,WAAWo7D,KAAqBL,EAAa,aAAa;AAAA,IAC1D,UAAUA,EAAa,YAAY;AAAA,IACnC,cAAcA,EAAa;AAAA,EAC/B,IAAM,CAACK,GAAmBL,EAAa,WAAWA,EAAa,QAAQ,CAAC;AACtE,SAAO/6D,EAAM,QAAQ,OAAO;AAAA,IAC1B,SAAAi2C;AAAA,IACA,MAAA1d;AAAA,IACA,cAAAP;AAAA,IACA,UAAA4L;AAAA,IACA,QAAAq3B;AAAA,IACA,YAAAD;AAAA,IACA,MAAAt2D;AAAA,EACJ,IAAM,CAAC6zB,GAAMP,GAAc4L,GAAUq3B,GAAQD,GAAYt2D,CAAI,CAAC;AAC9D;AAMA,SAASswC,GAAYhvB,GAAS;AAC5B,EAAIA,MAAY,WACdA,IAAU,CAAA;AAEZ,QAAM;AAAA,IACJ,QAAAu1C;AAAA,EACJ,IAAMv1C,GACEw1C,IAAsBX,GAAuB;AAAA,IACjD,GAAG70C;AAAA,IACH,UAAU;AAAA,MACR,WAAW;AAAA,MACX,UAAU;AAAA,MACV,GAAGA,EAAQ;AAAA,IACjB;AAAA,EACA,CAAG,GACKy1C,IAAcz1C,EAAQ,eAAew1C,GACrCE,IAAmBD,EAAY,UAC/B,CAACE,GAAeC,CAAe,IAAI57D,EAAM,SAAS,IAAI,GACtD,CAACo7D,GAAmBS,CAAqB,IAAI77D,EAAM,SAAS,IAAI,GAEhE87D,IADyDJ,GAAiB,gBACrCC,GACrCI,IAAkB/7D,EAAM,OAAO,IAAI,GACnCg8D,IAAOpB,GAAe;AAC5BhB,EAAAA,GAAsB,MAAM;AAC1B,IAAIkC,MACFC,EAAgB,UAAUD;AAAA,EAE9B,GAAG,CAACA,CAAY,CAAC;AACjB,QAAMxiD,IAAW2iD,GAAc;AAAA,IAC7B,GAAGj2C;AAAA,IACH,UAAU;AAAA,MACR,GAAG01C;AAAA,MACH,GAAIN,KAAqB;AAAA,QACvB,WAAWA;AAAA,MACnB;AAAA,IACA;AAAA,EACA,CAAG,GACKC,IAAuBr7D,EAAM,YAAY,CAAA2E,MAAQ;AACrD,UAAMu3D,IAA4BnxB,GAAUpmC,CAAI,IAAI;AAAA,MAClD,uBAAuB,MAAMA,EAAK,sBAAqB;AAAA,MACvD,gBAAgB,MAAMA,EAAK,eAAc;AAAA,MACzC,gBAAgBA;AAAA,IACtB,IAAQA;AAGJ,IAAAk3D,EAAsBK,CAAyB,GAC/C5iD,EAAS,KAAK,aAAa4iD,CAAyB;AAAA,EACtD,GAAG,CAAC5iD,EAAS,IAAI,CAAC,GACZs8B,IAAe51C,EAAM,YAAY,CAAA2E,MAAQ;AAC7C,KAAIomC,GAAUpmC,CAAI,KAAKA,MAAS,UAC9Bo3D,EAAgB,UAAUp3D,GAC1Bi3D,EAAgBj3D,CAAI,KAKlBomC,GAAUzxB,EAAS,KAAK,UAAU,OAAO,KAAKA,EAAS,KAAK,UAAU,YAAY;AAAA;AAAA;AAAA,IAItF3U,MAAS,QAAQ,CAAComC,GAAUpmC,CAAI,MAC9B2U,EAAS,KAAK,aAAa3U,CAAI;AAAA,EAEnC,GAAG,CAAC2U,EAAS,IAAI,CAAC,GACZ5U,IAAO1E,EAAM,QAAQ,OAAO;AAAA,IAChC,GAAGsZ,EAAS;AAAA,IACZ,cAAAs8B;AAAA,IACA,sBAAAylB;AAAA,IACA,cAAcU;AAAA,EAClB,IAAM,CAACziD,EAAS,MAAMs8B,GAAcylB,CAAoB,CAAC,GACjDz3B,IAAW5jC,EAAM,QAAQ,OAAO;AAAA,IACpC,GAAGsZ,EAAS;AAAA,IACZ,cAAcwiD;AAAA,EAClB,IAAM,CAACxiD,EAAS,UAAUwiD,CAAY,CAAC,GAC/B/tC,IAAU/tB,EAAM,QAAQ,OAAO;AAAA,IACnC,GAAGsZ;AAAA,IACH,GAAGmiD;AAAA,IACH,MAAA/2D;AAAA,IACA,UAAAk/B;AAAA,IACA,QAAA23B;AAAA,EACJ,IAAM,CAACjiD,GAAU5U,GAAMk/B,GAAU23B,GAAQE,CAAW,CAAC;AACnD7B,SAAAA,GAAsB,MAAM;AAC1B,IAAA6B,EAAY,QAAQ,QAAQ,kBAAkB1tC;AAC9C,UAAMppB,IAA+Bq3D,GAAK,SAAS,QAAQ,KAAK,CAAAr3D,MAAQA,EAAK,OAAO42D,CAAM;AAC1F,IAAI52D,MACFA,EAAK,UAAUopB;AAAA,EAEnB,CAAC,GACM/tB,EAAM,QAAQ,OAAO;AAAA,IAC1B,GAAGsZ;AAAA,IACH,SAAAyU;AAAA,IACA,MAAArpB;AAAA,IACA,UAAAk/B;AAAA,EACJ,IAAM,CAACtqB,GAAU5U,GAAMk/B,GAAU7V,CAAO,CAAC;AACzC;;;;GCn7FaouC,KAA+D,CAAC;AAAA,EAC3E,UAAAl4D;AAAA,EACA,aAAAm4D;AACF,MACE,gBAAA93D,EAAC,KAAA,EAAE,WAAWF,EAAGC,GAAI,cAAc,EAAE,CAACA,GAAI,SAAS,GAAG+3D,EAAA,CAAa,GAAI,UAAAn4D,EAAA,CAAS;ACRlF,IAAI83B,KAAQ;AAAA,EACV;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GACIC,KAAYD,GAAM,OAAO,CAACE,GAAWt3B,MAAS;AAChD,QAAMwB,IAAOb,gBAAAA,GAAW,aAAaX,CAAI,EAAE,GACrCu3B,IAAOl8B,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACrD,UAAM,EAAE,SAAAyR,GAAS,GAAG+kB,EAAc,IAAKp8B,GACjCq8B,IAAOhlB,IAAUjR,IAAOxB;AAC9B,WAAI,OAAO,SAAW,QACpB,OAAO,uBAAO,IAAI,UAAU,CAAC,IAAI,KAEZ,gBAAAL,EAAI83B,GAAM,EAAE,GAAGD,GAAgB,KAAKx2B,GAAc;AAAA,EAC3E,CAAC;AACD,SAAAu2B,EAAK,cAAc,aAAav3B,CAAI,IAC7B,EAAE,GAAGs3B,GAAW,CAACt3B,CAAI,GAAGu3B,EAAI;AACrC,GAAG,EAAE,GC9BD2a,KAAO,SACPwlB,KAAQr8D,EAAM,WAAW,CAACD,GAAO4F,MACZ,gBAAArB;AAAA,EACrB03B,GAAU;AAAA,EACV;AAAA,IACE,GAAGj8B;AAAA,IACH,KAAK4F;AAAA,IACL,aAAa,CAAC6kB,MAAU;AAEtB,MADeA,EAAM,OACV,QAAQ,iCAAiC,MACpDzqB,EAAM,cAAcyqB,CAAK,GACrB,CAACA,EAAM,oBAAoBA,EAAM,SAAS,KAAGA,EAAM,eAAc;AAAA,IACvE;AAAA,EACN;AACA,CACC;AACD6xC,GAAM,cAAcxlB;AACpB,IAAIG,KAAOqlB;ACfX,MAAMC,KAAgB90D;AAAA,EACpB;AACF,GAEM60D,KAAQr8D,EAAM,WAGlB,CAAC,EAAE,WAAAkE,GAAW,GAAGnE,EAAA,GAASyE,MAC1B,gBAAAF,EAACi4D,IAAA,EAAoB,KAAA/3D,GAAU,WAAWJ,GAAGk4D,GAAA,GAAiBp4D,CAAS,GAAI,GAAGnE,EAAA,CAAO,CACtF;AACDs8D,GAAM,cAAcE,GAAoB;;;;GCP3BF,KAAQ,CAAC,EAAE,SAAAG,GAAS,UAAAv4D,GAAU,WAAAC,EAAA,MACzC,gBAAAI,EAACm4D,IAAA,EAAQ,SAAAD,GAAkB,WAAWp4D,EAAGC,GAAI,OAAOH,CAAS,GAC1D,UAAA,OAAOD,KAAa,WAAW,gBAAAK,EAAC,OAAA,EAAI,WAAWD,GAAI,aAAc,UAAAJ,EAAA,CAAS,IAASA,EAAA,CACtF;;;;;GCFWy4D,KAAoC/nC,GAAK,CAAC,EAAE,WAAAzwB,GAAW,UAAAD,GAAU,SAAA+sB,GAAS,SAAA2rC,0BACpF,OAAA,EAAI,WAAWv4D,EAAGC,GAAI,SAASH,GAAWy4D,KAAWt4D,GAAI,aAAa,GACrE,UAAA;AAAA,EAAA,gBAAAC,EAAC,UAAM,UAAAL,GAAS;AAAA,EACf+sB,KACC,gBAAA1sB;AAAA,IAACs4D;AAAAA,IAAA;AAAA,MACC,WAAWx4D,EAAGC,GAAI,WAAW,EAAE,CAACA,GAAI,eAAe,GAAGs4D,GAAS;AAAA,MAC/D,SAAS,CAACxjC,MAAiC;AACzC,QAAAA,EAAE,gBAAA,GACFnI,EAAA;AAAA,MACF;AAAA,IAAA;AAAA,EAAA;AACF,GAEJ,CACD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GCZK6rC,KAAkB,GAuDlBC,KAAkB,CAAO;AAAA,EAC7B,OAAAp5D;AAAA,EACA,sBAAAq5D;AAAA,EACA,WAAAC;AAAA,EACA,UAAAC;AACF,MAIOv5D,IAIA,MAAM,QAAQA,CAAK,IAStB,gBAAAY,EAAC,OAAA,EAAI,WAAWD,EAAI,cACjB,UAAAX,EAAM;AAAA,EAAI,CAAC0xB,GAAM3nB,MAChBuvD,IACE,gBAAA14D,EAACtE,GAAM,UAAN,EAA4B,UAAAg9D,EAAU5nC,CAAI,EAAA,GAAtB3nB,CAAwB,IAE7C,gBAAAnJ;AAAA,IAACo4D;AAAA,IAAA;AAAA,MACC,SAAO;AAAA,MAEN,GAAIO,KAAY;AAAA,QACf,SAAS,MAAMA,IAAW7nC,CAAI;AAAA,MAAA;AAAA,MAG/B,UAAAA,EAAK;AAAA,IAAA;AAAA,IALD3nB;AAAA,EAAA;AAMP,GAGN,IAvBE,gBAAAnJ,EAAC,QAAA,EAAK,WAAWD,EAAI,gBAClB,cAAuB04D,EAAqBr5D,CAAK,IAAIA,EAAM,MAAA,CAC9D,IAPK,MAwCLw5D,KAAS,CAAO;AAAA,EACpB,UAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,aAAAC;AAAA,EACA,WAAAC;AAAA,EACA,aAAAC;AACF,wBACG,OAAA,EAAI,WAAWn5D,EAAGC,EAAI,QAAQ+4D,CAAe,GAC5C,UAAA;AAAA,EAAA,gBAAA94D,EAACk5D,IAAA,EAAW,WAAWn5D,EAAI,aAAA,CAAc;AAAA,EACzC,gBAAAC;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWD,EAAI;AAAA,MACf,OAAOg5D;AAAA,MACP,UAAU,CAAClkC,MAAMgkC,IAAWhkC,EAAE,OAAO,KAAK;AAAA,MAC1C,aAAAokC;AAAA,IAAA;AAAA,EAAA;AAAA,EAEDD,KAAa,gBAAAh5D,EAAC+S,IAAA,EAAQ,MAAK,cAAa,WAAWhT,EAAI,gBAAA,CAAiB;AAAA,GAC3E,GAkBIo5D,KAAW,CAAO;AAAA,EACtB,OAAA/5D;AAAA,EACA,SAAAsiB;AAAA,EACA,iBAAA03C;AAAA,EACA,cAAAC;AAAA,EACA,UAAAjjD;AAAA,EACA,UAAAyiD;AAAA,EACA,iBAAAC;AAAA,EACA,WAAAE;AAAA,EACA,aAAAD;AAAA,EACA,mBAAAO;AACF,MAAsD;AACpD,QAAMC,IAAgB,CAAC1iD,MACrB,MAAM,QAAQzX,CAAK,IACfA,EAAM,KAAK,CAAC0xB,MAASA,EAAK,UAAUja,EAAO,KAAK,IAChDzX,GAAO,UAAUyX,EAAO;AAC9B,SACE,gBAAAhX,EAAAu1B,IAAA,EACG,UAAA;AAAA,IAAAyjC,KACC,gBAAA74D;AAAA,MAAC44D;AAAA,MAAA;AAAA,QACC,UAAAC;AAAA,QACA,aAAAE;AAAA,QACA,iBAAAD;AAAA,QACA,WAAAE;AAAA,QACA,aAAaM;AAAA,MAAA;AAAA,IAAA;AAAA,IAGhB53C,KAAaA,EAAQ,SACpB,gBAAA1hB,EAAC,MAAA,EAAG,WAAWF,EAAG,EAAE,CAACC,EAAI,UAAU,GAAG84D,EAAA,CAAU,GAC7C,UAAAn3C,EAAQ,IAAI,CAAC7K,GAAQ1N,MAAU;AAC9B,YAAMklB,IAAWkrC,EAAc1iD,CAAM,GAC/B2iD,IAAe93C,EAAQvY,IAAQ,CAAC,KAAKowD,EAAc73C,EAAQvY,IAAQ,CAAC,CAAC,GACrEswD,IAAe/3C,EAAQvY,IAAQ,CAAC,KAAKowD,EAAc73C,EAAQvY,IAAQ,CAAC,CAAC;AAE3E,aACE,gBAAAnJ;AAAA,QAAC;AAAA,QAAA;AAAA,UAEC,WAAWF;AAAAA,YACTC,EAAI;AAAA,YACJ;AAAA,cACE,CAACA,EAAI,aAAa,GAAGsuB;AAAA,cACrB,CAACtuB,EAAI,yBAAyB,GAAGy5D;AAAA,cACjC,CAACz5D,EAAI,yBAAyB,GAAG05D;AAAA,YAAA;AAAA,YAEnCL;AAAA,UAAA;AAAA,UAEF,SAAS,MAAMhjD,EAASS,CAAM;AAAA,UAE7B,UAAAwiD,IAAeA,EAAaxiD,CAAM,IAAIA,EAAO;AAAA,QAAA;AAAA,QAZzC,GAAGA,EAAO,KAAK,GAAG1N,CAAK;AAAA,MAAA;AAAA,IAelC,CAAC,EAAA,CACH,IAEA,CAAC6vD,uBAAczF,IAAA,CAAA,CAAe;AAAA,EAAA,GAElC;AAEJ,GAmBMmG,KAAgB,CAAO;AAAA,EAC3B,OAAAt6D;AAAA,EACA,SAAAsiB;AAAA,EACA,UAAAtL;AAAA,EACA,UAAAuiD;AAAA,EACA,UAAAE;AAAA,EACA,iBAAAC;AAAA,EACA,WAAAE;AAAA,EACA,aAAAD;AAAA,EACA,mBAAAO;AAAA,EACA,SAAAK;AAAA,EACA,OAAAC;AAAA,EACA,MAAAtxC;AACF,MAA2D;AACzD,QAAMixC,IAAgB,CAAC1iD,MACrB,MAAM,QAAQzX,CAAK,IACfA,EAAM,KAAK,CAAC0xB,MAASA,EAAK,UAAUja,EAAO,KAAK,IAChDzX,GAAO,UAAUyX,EAAO,OAExBgjD,IAAkB,CAAChjD,GAA4BwX,MAAsB;AACzE,QAAI/F,MAAS,cAAc+F,KAAYsqC,GAAU;AAC/C,MAAAA,EAAS9hD,CAAM;AACf;AAAA,IACF;AACA,IAAAT,EAASS,CAAM;AAAA,EACjB,GAEMijD,IAAaF,KAASl4C,GAAS,UAAU,GACzCq4C,IAAcJ,KAAW,CAAA;AAE/B,SACE,gBAAA95D,EAAC,OAAA,EAAI,WAAWE,EAAI,eACjB,UAAA;AAAA,IAAA84D,KACC,gBAAA74D;AAAA,MAAC44D;AAAA,MAAA;AAAA,QACC,UAAAC;AAAA,QACA,aAAAE;AAAA,QACA,iBAAAD;AAAA,QACA,WAAAE;AAAA,QACA,aAAaM;AAAA,MAAA;AAAA,IAAA;AAAA,IAGjB,gBAAAt5D,EAAC,OAAA,EAAI,WAAWD,EAAI,gBACjB,UAAA2hB,KAAWA,EAAQ,SAClB,gBAAA7hB,EAAC,SAAA,EAAM,WAAWE,EAAI,OACpB,UAAA;AAAA,MAAA,gBAAAC,EAAC,SAAA,EACC,4BAAC,MAAA,EACC,UAAA;AAAA,QAAA,gBAAAA,EAAC,MAAA,EAAG,WAAWD,EAAI,cAAc,cAAW,IAAG;AAAA,QAC9Cg6D,EAAY,IAAI,CAACC,MAChB,gBAAAh6D,EAAC,MAAA,EAAoB,WAAWg6D,EAAO,WACpC,UAAAA,EAAO,MAAA,GADDA,EAAO,GAEhB,CACD;AAAA,MAAA,EAAA,CACH,EAAA,CACF;AAAA,wBACC,SAAA,EACE,UAAAt4C,EAAQ,IAAI,CAAC7K,GAAQ1N,MAAU;AAC9B,cAAMklB,IAAWkrC,EAAc1iD,CAAM;AACrC,eACE,gBAAAhX;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,WAAWC,EAAG,EAAE,CAACC,EAAI,SAAS,GAAGsuB,GAAU;AAAA,YAC3C,SAAS,MAAMwrC,EAAgBhjD,GAAQwX,CAAQ;AAAA,YAE/C,UAAA;AAAA,cAAA,gBAAAruB,EAAC,MAAA,EAAG,WAAWD,EAAI,cACjB,UAAA,gBAAAC;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBACC,MAAK;AAAA,kBACL,WAAWD,EAAI;AAAA,kBACf,SAASsuB;AAAA,kBACT,UAAQ;AAAA,kBACR,UAAU;AAAA,kBACV,SAAS,CAACwG,MAAMA,EAAE,gBAAA;AAAA,kBAClB,UAAU,MAAMglC,EAAgBhjD,GAAQwX,CAAQ;AAAA,gBAAA;AAAA,cAAA,GAEpD;AAAA,cACC0rC,EAAY,IAAI,CAACC,wBACf,MAAA,EAAoB,WAAWA,EAAO,WACpC,YAAO,OAAOnjD,CAAM,EAAA,GADdmjD,EAAO,GAEhB,CACD;AAAA,YAAA;AAAA,UAAA;AAAA,UAnBI,GAAG,OAAOnjD,EAAO,KAAK,CAAC,GAAG1N,CAAK;AAAA,QAAA;AAAA,MAsB1C,CAAC,EAAA,CACH;AAAA,IAAA,EAAA,CACF,IAEA,CAAC6vD,KAAa,gBAAAh5D,EAACuzD,MAAe,GAElC;AAAA,IACA,gBAAA1zD,EAAC,OAAA,EAAI,WAAWE,EAAI,aAAa,UAAA;AAAA,MAAA;AAAA,MAAO+5D;AAAA,IAAA,EAAA,CAAW;AAAA,EAAA,GACrD;AAEJ,GAEaG,KAAS,CAA+B;AAAA,EACnD,SAAAv4C;AAAA,EACA,OAAAtiB;AAAA,EACA,MAAAkpB;AAAA,EACA,aAAA2wC;AAAA,EACA,UAAA7iD;AAAA,EACA,gBAAA8jD;AAAA,EACA,cAAAb;AAAA,EACA,sBAAAZ;AAAA,EACA,cAAA0B;AAAA,EACA,WAAAzB;AAAA,EACA,mBAAA0B;AAAA,EACA,iBAAAhB;AAAA,EACA,gBAAAiB;AAAA,EACA,qBAAAC;AAAA,EACA,UAAA3B;AAAA,EACA,SAAA4B;AAAA,EACA,OAAAnrD;AAAA,EACA,UAAAypD;AAAA,EACA,iBAAAC;AAAA,EACA,mBAAAQ;AAAA,EACA,WAAAN;AAAA,EACA,UAAAzlD;AAAA,EACA,SAAAgqC;AAAA,EACA,cAAAid;AAAA,EACA,OAAAj+C;AAAA,EACA,aAAAk+C,IAAc;AAAA,EACd,UAAAC,IAAW;AAAA,EACX,SAAAf;AAAA,EACA,OAAAC;AACF,MAA+B;AAC7B,QAAM,CAACzY,GAAQwZ,CAAS,IAAI5mD,EAAS,EAAK,GACpC,CAACmgD,GAAW0G,CAAY,IAAI7mD,EAAS,EAAK,GAC1Ck2C,IAAe91C,GAAuB,IAAI,GAC1C0mD,IAAc1mD,GAAuB,IAAI,GACzC2mD,IAAW3mD,GAAuB,IAAI,GAEtC,CAAC4kD,GAAagC,EAAc,IAAIhnD,EAAS,EAAE,GAC3CinD,KACJR,MAAiBtG,KAAa,OAAO,WAAa,MAAc,SAAS,OAAO;AAElF,EAAA9/C,GAAU,MAAM;AACd,IAAAwmD,EAAa,EAAI;AAAA,EACnB,GAAG,CAAA,CAAE;AAEL,QAAMK,KAAe9lD;AAAA,IACnB,CAAC/V,MAAkB;AACjB,MAAA27D,GAAe37D,CAAK,GACpBy5D,IAAWz5D,CAAK;AAAA,IAClB;AAAA,IACA,CAACy5D,CAAQ;AAAA,EAAA;AAGX,EAAAzkD,GAAU,MAAM;AACd,QAAI,CAAC+sC;AACH;AAGF,UAAM+Z,IAAqB,CAACh1C,OAAsB;AAChD,MACE+jC,EAAa,WACb,CAACA,EAAa,QAAQ,SAAS/jC,GAAM,MAAc,MAClD,CAAC20C,EAAY,WAAW,CAACA,EAAY,QAAQ,SAAS30C,GAAM,MAAc,OAE3E+0C,GAAa,EAAE,GACfN,EAAU,EAAK,GACfpd,IAAA;AAAA,IAEJ;AAEA,oBAAS,iBAAiB,aAAa2d,GAAoB,EAAI,GAExD,MAAM;AACX,eAAS,oBAAoB,aAAaA,GAAoB,EAAI;AAAA,IACpE;AAAA,EACF,GAAG,CAACD,IAAc9Z,GAAQ5D,CAAO,CAAC;AAElC,QAAM,EAAE,MAAAn9C,IAAM,gBAAA8xC,GAAgB,QAAAjqC,GAAA,IAAWyoC,GAAY;AAAA,IACnD,UAAU;AAAA,IACV,WAAW;AAAA,IACX,MAAMyQ;AAAA,IACN,sBAAsB,CAACziB,GAAWC,IAAUppB,OAC1Ci5B,GAAW9P,GAAWC,IAAUppB,IAAgB;AAAA,MAC9C,gBAAgB;AAAA,MAChB,eAAe;AAAA,MACf,gBAAgB;AAAA,MAChB,aAAa;AAAA,IAAA,CACd;AAAA,IACH,YAAY;AAAA,MACV4lD,GAAe5C,EAAe;AAAA,MAC9Bz2B,GAAK;AAAA,QACH,oBAAoB,CAAC,aAAa,cAAc;AAAA,MAAA,CACjD;AAAA,MACDjvB,GAAK;AAAA,QACH,MAAM,EAAE,OAAAgqB,GAAO,UAAAyC,MAAY;AACzB,gBAAM87B,KAAY,GAAG,KAAK,MAAMv+B,EAAM,UAAU,KAAK,CAAC;AACtD,UAAIyC,GAAS,SAAS,MAAM,UAAU87B,OACpC97B,GAAS,SAAS,MAAM,QAAQ87B;AAAA,QAEpC;AAAA,MAAA,CACD;AAAA,IAAA;AAAA,EACH,CACD,GAEK9pB,KAAen8B;AAAA,IACnB,CAAC9U,MAAgC;AAC/B,MAAAy6D,EAAS,UAAUz6D,GACnBD,GAAK,aAAaC,CAAI;AAAA,IACxB;AAAA,IACA,CAACD,EAAI;AAAA,EAAA,GAGDoxC,IAAcr8B;AAAA,IAClB,CAAC9U,MAAgC;AAC/B,MAAAw6D,EAAY,UAAUx6D,GACtBD,GAAK,YAAYC,CAAI;AAAA,IACvB;AAAA,IACA,CAACD,EAAI;AAAA,EAAA;AAGP,EAAAgU,GAAU,MAAM;AACd,IAAK+sC,KAILl5C,GAAA;AAAA,EACF,GAAG,CAACk5C,GAAQl5C,EAAM,CAAC;AAEnB,QAAMozD,IAAelmD;AAAA,IACnB,CAACuyC,MAAiC;AAChC,MAAAtxC,IAAWsxC,CAAQ,GAEnBuT,GAAa,EAAE,GACf1d,IAAA,GAEIj1B,MAAS,YACXqyC,EAAU,EAAK;AAAA,IAEnB;AAAA,IACA,CAACM,IAAc3yC,GAAMlS,GAAUmnC,CAAO;AAAA,EAAA,GAGlC+d,KAAiBnmD,EAAY,MAAM;AACvC,UAAMomD,IACJ,gBAAAv7D;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAKwxC;AAAA,QACL,WAAW1xC,EAAGC,EAAI,UAAU,EAAE,CAACA,EAAI,gBAAgB,GAAGohD,EAAA,GAAUiZ,CAAiB;AAAA,QACjF,OAAOloB;AAAA,QACP,SAAS,CAACrd,OAAMA,GAAE,gBAAA;AAAA,QAElB,UAAA,gBAAA70B,EAAC,OAAA,EAAI,WAAWD,EAAI,iBAAiB,OAAO,EAAE,QAAQ06D,IAAc,UAAU,OAAA,GAC1E,WAAA,MAAM;AACN,gBAAMe,KACJd,MAAa,UACX,gBAAA16D;AAAA,YAAC05D;AAAA,YAAA;AAAA,cACC,OAAAt6D;AAAA,cACA,SAAAsiB;AAAA,cACA,UAAU25C;AAAA,cACV,UAAA1C;AAAA,cACC,GAAIE,KAAY,EAAE,UAAUoC,GAAA;AAAA,cAC7B,iBAAAnC;AAAA,cACA,WAAAE;AAAA,cACA,aAAAD;AAAA,cACA,mBAAAO;AAAA,cACA,SAAAK;AAAA,cACA,OAAAC;AAAA,cACA,MAAAtxC;AAAA,YAAA;AAAA,UAAA,IAGF,gBAAAtoB;AAAA,YAACm5D;AAAA,YAAA;AAAA,cACC,OAAA/5D;AAAA,cACA,SAAAsiB;AAAA,cACA,iBAAA03C;AAAA,cACA,cAAAC;AAAA,cACA,UAAUgC;AAAA,cACT,GAAIxC,KAAY,EAAE,UAAUoC,GAAA;AAAA,cAC7B,iBAAAnC;AAAA,cACA,WAAAE;AAAA,cACA,aAAAD;AAAA,cACA,mBAAAO;AAAA,YAAA;AAAA,UAAA;AAGN,iBAAOY,IAAiBA,EAAesB,EAAI,IAAIA;AAAA,QACjD,KAAG,CACL;AAAA,MAAA;AAAA,IAAA;AAIJ,WAAIR,KACKhjC,GAAS,aAAaujC,GAAiBP,EAAoB,IAG7DO;AAAA,EACT,GAAG;AAAA,IACDnB;AAAA,IACAF;AAAA,IACAO;AAAA,IACAvoB;AAAA,IACAmpB;AAAA,IACAJ;AAAA,IACAjC;AAAA,IACA7X;AAAA,IACA0X;AAAA,IACAO;AAAA,IACAC;AAAA,IACA33C;AAAA,IACAs5C;AAAA,IACAN;AAAA,IACAf;AAAA,IACAC;AAAA,IACAtxC;AAAA,IACAqwC;AAAA,IACAG;AAAA,IACAQ;AAAA,IACAP;AAAA,IACAvnB;AAAA,IACApyC;AAAA,EAAA,CACD,GAEKq8D,KAAWroD;AAAA,IACf,MAAO8gD,IAAYoH,GAAA,IAAmB;AAAA,IACtC,CAACpH,GAAWoH,EAAc;AAAA,EAAA,GAGtBI,KAAW,MAAM,QAAQt8D,CAAK,IAAI,CAAC,CAACA,EAAM,SAAS,CAAC,CAACA;AAE3D,SACE,gBAAAS,EAAC,OAAA,EAAI,WAAWE,EAAI,SACjB,UAAA;AAAA,IAAAqP,KAAS,gBAAApP,EAAC+3D,IAAA,EAAM,SAAQ,qBAAqB,UAAA3oD,GAAM;AAAA,sBACnD,OAAA,EAAI,WAAWrP,EAAI,WAAW,KAAKkqD,GAClC,UAAA;AAAA,MAAA,gBAAApqD;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,MAAK;AAAA,UACL,IAAG;AAAA,UACH,UAAU;AAAA,UACV,KAAKyxC;AAAA,UACL,WAAWxxC;AAAAA,YACTC,EAAI;AAAA,YACJ,EAAE,CAACA,EAAI,iBAAiB,GAAGuoB,MAAS,UAAU,CAACvoB,EAAI,QAAQ,GAAGwT,EAAA;AAAA,YAC9DgJ,KAASxc,EAAI;AAAA,YACbs6D;AAAA,UAAA;AAAA,UAEF,SAAS,MAAM;AACb,YAAIj7D,MACF67D,GAAa,EAAE,GACf1d,IAAA,IAEFod,EAAU,CAACv7D,MAAU,CAACA,CAAK;AAAA,UAC7B;AAAA,UAEA,UAAA;AAAA,YAAA,gBAAAY,EAAC,OAAA,EAAI,WAAWD,EAAI,yBACjB,UAAA27D,KACC,gBAAA17D;AAAA,cAACw4D;AAAA,cAAA;AAAA,gBACC,OAAAp5D;AAAA,gBACA,sBAAAq5D;AAAA,gBACA,WAAAC;AAAA,gBACA,UAAAC;AAAA,cAAA;AAAA,YAAA,IAGF,gBAAA34D,EAAC,QAAA,EAAK,WAAWD,EAAI,aAAc,aAAY,GAEnD;AAAA,YACA,gBAAAF,EAAC,OAAA,EAAI,WAAWE,EAAI,eACjB,UAAA;AAAA,cAAAw6D,KAAWmB,MACV,gBAAA77D,EAAAu1B,IAAA,EACE,UAAA;AAAA,gBAAA,gBAAAp1B;AAAA,kBAAC4S;AAAA,kBAAA;AAAA,oBACC,SAAQ;AAAA,oBACR,WAAW9S,EAAGC,EAAI,YAAYu6D,CAAmB;AAAA,oBACjD,SAAS,CAACzlC,MAAM;AACd,sBAAAA,EAAE,gBAAA,GACF0lC,EAAA;AAAA,oBACF;AAAA,oBAEA,UAAA,gBAAAv6D,EAAC,QAAA,EACC,UAAA,gBAAAA,EAACs4D,IAAA,CAAA,CAAU,EAAA,CACb;AAAA,kBAAA;AAAA,gBAAA;AAAA,kCAED,OAAA,EAAI,WAAWv4D,EAAI,SAClB,UAAA,gBAAAC,EAAC,SAAI,EAAA,CACP;AAAA,cAAA,GACF;AAAA,cAGDm6D,KACC,gBAAAn6D;AAAA,gBAAC4S;AAAA,gBAAA;AAAA,kBACC,SAAQ;AAAA,kBACR,WAAW9S,EAAGC,EAAI,WAAW;AAAA,oBAC3B,CAACA,EAAI,iBAAiB,GAAGohD;AAAA,kBAAA,CAC1B;AAAA,kBAED,4BAACqT,IAAA,CAAA,CAAc;AAAA,gBAAA;AAAA,cAAA;AAAA,YACjB,EAAA,CAEJ;AAAA,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,MAEDiH;AAAA,IAAA,GACH;AAAA,IACCl/C,KAAS,gBAAAvc,EAAC63D,IAAA,EAAc,UAAAt7C,EAAA,CAAM;AAAA,EAAA,GACjC;AAEJ;AAAA;ACxmBA,SAASvb,GAAWC,GAAW;AAC7B,QAAMC,IAA4B,gBAAAC,GAAgBF,CAAS,GACrDG,IAAQ1F,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AACtD,UAAM,EAAE,UAAA1B,GAAU,GAAG2B,EAAS,IAAK7F,GAC7B8F,IAAgB7F,EAAM,SAAS,QAAQiE,CAAQ,GAC/C6B,IAAYD,EAAc,KAAKE,EAAW;AAChD,QAAID,GAAW;AACb,YAAME,IAAaF,EAAU,MAAM,UAC7BG,IAAcJ,EAAc,IAAI,CAACK,MACjCA,MAAUJ,IACR9F,EAAM,SAAS,MAAMgG,CAAU,IAAI,IAAUhG,EAAM,SAAS,KAAK,IAAI,IAClEA,EAAM,eAAegG,CAAU,IAAIA,EAAW,MAAM,WAAW,OAE/DE,CAEV;AACD,aAAuB,gBAAA5B,EAAIkB,GAAW,EAAE,GAAGI,GAAW,KAAKD,GAAc,UAAU3F,EAAM,eAAegG,CAAU,IAAIhG,EAAM,aAAagG,GAAY,QAAQC,CAAW,IAAI,MAAM;AAAA,IACpL;AACA,WAAuB,gBAAA3B,EAAIkB,GAAW,EAAE,GAAGI,GAAW,KAAKD,GAAc,UAAA1B,GAAU;AAAA,EACrF,CAAC;AACD,SAAAyB,EAAM,cAAc,GAAGH,CAAS,SACzBG;AACT;AAAA;AAGA,SAASD,GAAgBF,GAAW;AAClC,QAAMC,IAAYxF,EAAM,WAAW,CAACD,GAAO4F,MAAiB;AAC1D,UAAM,EAAE,UAAA1B,GAAU,GAAG2B,EAAS,IAAK7F;AACnC,QAAIC,EAAM,eAAeiE,CAAQ,GAAG;AAClC,YAAMmC,IAAcC,GAAcpC,CAAQ,GACpCqC,IAASC,GAAWX,GAAW3B,EAAS,KAAK;AACnD,aAAIA,EAAS,SAASjE,EAAM,aAC1BsG,EAAO,MAAMX,IAAelB,GAAYkB,GAAcS,CAAW,IAAIA,IAEhEpG,EAAM,aAAaiE,GAAUqC,CAAM;AAAA,IAC5C;AACA,WAAOtG,EAAM,SAAS,MAAMiE,CAAQ,IAAI,IAAIjE,EAAM,SAAS,KAAK,IAAI,IAAI;AAAA,EAC1E,CAAC;AACD,SAAAwF,EAAU,cAAc,GAAGD,CAAS,cAC7BC;AACT;AACA,IAAIgB,KAAuB,uBAAO,iBAAiB;AAWnD,SAAST,GAAYG,GAAO;AAC1B,SAAOlG,EAAM,eAAekG,CAAK,KAAK,OAAOA,EAAM,QAAS,cAAc,eAAeA,EAAM,QAAQA,EAAM,KAAK,cAAcM;AAClI;AACA,SAASD,GAAWX,GAAWa,GAAY;AACzC,QAAMC,IAAgB,EAAE,GAAGD,EAAU;AACrC,aAAWE,KAAYF,GAAY;AACjC,UAAMG,IAAgBhB,EAAUe,CAAQ,GAClCE,IAAiBJ,EAAWE,CAAQ;AAE1C,IADkB,WAAW,KAAKA,CAAQ,IAEpCC,KAAiBC,IACnBH,EAAcC,CAAQ,IAAI,IAAIG,MAAS;AACrC,YAAMC,IAASF,EAAe,GAAGC,CAAI;AACrC,aAAAF,EAAc,GAAGE,CAAI,GACdC;AAAA,IACT,IACSH,MACTF,EAAcC,CAAQ,IAAIC,KAEnBD,MAAa,UACtBD,EAAcC,CAAQ,IAAI,EAAE,GAAGC,GAAe,GAAGC,EAAc,IACtDF,MAAa,gBACtBD,EAAcC,CAAQ,IAAI,CAACC,GAAeC,CAAc,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAAA,EAEtF;AACA,SAAO,EAAE,GAAGjB,GAAW,GAAGc,EAAa;AACzC;AACA,SAASL,GAAchB,GAAS;AAC9B,MAAI2B,IAAS,OAAO,yBAAyB3B,EAAQ,OAAO,KAAK,GAAG,KAChE4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO;AAC7D,SAAIC,IACK5B,EAAQ,OAEjB2B,IAAS,OAAO,yBAAyB3B,GAAS,KAAK,GAAG,KAC1D4B,IAAUD,KAAU,oBAAoBA,KAAUA,EAAO,gBACrDC,IACK5B,EAAQ,MAAM,MAEhBA,EAAQ,MAAM,OAAOA,EAAQ;AACtC;AC7EA,IAAI46D,KAAc,UACd,CAACC,EAAsC,IAAIvlC,GAAmBslC,EAAW,GACzE,CAACE,IAAgBC,EAAgB,IAAIF,GAAoBD,EAAW,GACpEI,KAAS,CAACtgE,MAAU;AACtB,QAAM;AAAA,IACJ,eAAAugE;AAAA,IACA,UAAAr8D;AAAA,IACA,MAAM2zB;AAAA,IACN,aAAAC;AAAA,IACA,cAAAG;AAAA,IACA,OAAA09B,IAAQ;AAAA,EACZ,IAAM31D,GACEkZ,IAAajZ,EAAM,OAAO,IAAI,GAC9Bw2D,IAAax2D,EAAM,OAAO,IAAI,GAC9B,CAACu4B,GAAMC,CAAO,IAAI+kB,GAAqB;AAAA,IAC3C,MAAM3lB;AAAA,IACN,aAAaC,KAAe;AAAA,IAC5B,UAAUG;AAAA,IACV,QAAQioC;AAAA,EACZ,CAAG;AACD,SAAuB,gBAAA37D;AAAA,IACrB67D;AAAA,IACA;AAAA,MACE,OAAOG;AAAA,MACP,YAAArnD;AAAA,MACA,YAAAu9C;AAAA,MACA,WAAW52B,GAAK;AAAA,MAChB,SAASA,GAAK;AAAA,MACd,eAAeA,GAAK;AAAA,MACpB,MAAArH;AAAA,MACA,cAAcC;AAAA,MACd,cAAcx4B,EAAM,YAAY,MAAMw4B,EAAQ,CAACq9B,MAAa,CAACA,CAAQ,GAAG,CAACr9B,CAAO,CAAC;AAAA,MACjF,OAAAk9B;AAAA,MACA,UAAAzxD;AAAA,IACN;AAAA,EACA;AACA;AACAo8D,GAAO,cAAcJ;AACrB,IAAItf,KAAe,iBACf4f,KAAgBvgE,EAAM;AAAA,EACxB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,eAAA26D,GAAe,GAAGzf,EAAY,IAAK9gD,GACrCguB,IAAUqyC,GAAiBzf,IAAc2f,CAAa,GACtDpK,IAAqBlxD,GAAgBW,GAAcooB,EAAQ,UAAU;AAC3E,WAAuB,gBAAAzpB;AAAA,MACrB03B,GAAU;AAAA,MACV;AAAA,QACE,MAAM;AAAA,QACN,iBAAiB;AAAA,QACjB,iBAAiBjO,EAAQ;AAAA,QACzB,iBAAiBA,EAAQ;AAAA,QACzB,cAAcooC,GAASpoC,EAAQ,IAAI;AAAA,QACnC,GAAG8yB;AAAA,QACH,KAAKqV;AAAA,QACL,SAAS7mC,GAAqBtvB,EAAM,SAASguB,EAAQ,YAAY;AAAA,MACzE;AAAA,IACA;AAAA,EACE;AACF;AACAwyC,GAAc,cAAc5f;AAC5B,IAAIlF,KAAc,gBACd,CAACyF,IAAgBC,EAAgB,IAAI+e,GAAoBzkB,IAAa;AAAA,EACxE,YAAY;AACd,CAAC,GACG+kB,KAAe,CAACzgE,MAAU;AAC5B,QAAM,EAAE,eAAAugE,GAAe,YAAAjf,GAAY,UAAAp9C,GAAU,WAAAq1B,EAAS,IAAKv5B,GACrDguB,IAAUqyC,GAAiB3kB,IAAa6kB,CAAa;AAC3D,SAAuB,gBAAAh8D,EAAI48C,IAAgB,EAAE,OAAOof,GAAe,YAAAjf,GAAY,UAAUrhD,EAAM,SAAS,IAAIiE,GAAU,CAACiC,MAA0B,gBAAA5B,EAAI43C,IAAU,EAAE,SAASmF,KAActzB,EAAQ,MAAM,UAA0B,gBAAAzpB,EAAIg9C,IAAiB,EAAE,SAAS,IAAM,WAAAhoB,GAAW,UAAUpzB,EAAK,CAAE,EAAC,CAAE,CAAC,EAAC,CAAE;AAC3S;AACAs6D,GAAa,cAAc/kB;AAC3B,IAAIglB,KAAe,iBACfC,KAAgB1gE,EAAM;AAAA,EACxB,CAACD,GAAO4F,MAAiB;AACvB,UAAM67C,IAAgBL,GAAiBsf,IAAc1gE,EAAM,aAAa,GAClE,EAAE,YAAAshD,IAAaG,EAAc,YAAY,GAAGmf,EAAY,IAAK5gE,GAC7DguB,IAAUqyC,GAAiBK,IAAc1gE,EAAM,aAAa;AAClE,WAAOguB,EAAQ,QAAwB,gBAAAzpB,EAAI43C,IAAU,EAAE,SAASmF,KAActzB,EAAQ,MAAM,UAA0B,gBAAAzpB,EAAIs8D,IAAmB,EAAE,GAAGD,GAAc,KAAKh7D,EAAY,CAAE,EAAC,CAAE,IAAI;AAAA,EAC5L;AACF;AACA+6D,GAAc,cAAcD;AAC5B,IAAIt6D,KAAO,gBAAAb,GAAW,4BAA4B,GAC9Cs7D,KAAoB5gE,EAAM;AAAA,EAC5B,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,eAAA26D,GAAe,GAAGK,EAAY,IAAK5gE,GACrCguB,IAAUqyC,GAAiBK,IAAcH,CAAa;AAC5D;AAAA;AAAA;AAAA,MAGkB,gBAAAh8D,EAAImpD,IAAc,EAAE,IAAItnD,IAAM,gBAAgB,IAAM,QAAQ,CAAC4nB,EAAQ,UAAU,GAAG,UAA0B,gBAAAzpB;AAAA,QAC1H03B,GAAU;AAAA,QACV;AAAA,UACE,cAAcm6B,GAASpoC,EAAQ,IAAI;AAAA,UACnC,GAAG4yC;AAAA,UACH,KAAKh7D;AAAA,UACL,OAAO,EAAE,eAAe,QAAQ,GAAGg7D,EAAa,MAAK;AAAA,QAC/D;AAAA,MACA,EAAO,CAAE;AAAA;AAAA,EAEP;AACF,GACIvoB,KAAe,iBACfyoB,KAAgB7gE,EAAM;AAAA,EACxB,CAACD,GAAO4F,MAAiB;AACvB,UAAM67C,IAAgBL,GAAiB/I,IAAcr4C,EAAM,aAAa,GAClE,EAAE,YAAAshD,IAAaG,EAAc,YAAY,GAAGrI,EAAY,IAAKp5C,GAC7DguB,IAAUqyC,GAAiBhoB,IAAcr4C,EAAM,aAAa;AAClE,WAAuB,gBAAAuE,EAAI43C,IAAU,EAAE,SAASmF,KAActzB,EAAQ,MAAM,UAAUA,EAAQ,QAAwB,gBAAAzpB,EAAIw8D,IAAoB,EAAE,GAAG3nB,GAAc,KAAKxzC,EAAY,CAAE,IAAoB,gBAAArB,EAAIy8D,IAAuB,EAAE,GAAG5nB,GAAc,KAAKxzC,EAAY,CAAE,EAAC,CAAE;AAAA,EAC9Q;AACF;AACAk7D,GAAc,cAAczoB;AAC5B,IAAI0oB,KAAqB9gE,EAAM;AAAA,EAC7B,CAACD,GAAO4F,MAAiB;AACvB,UAAMooB,IAAUqyC,GAAiBhoB,IAAcr4C,EAAM,aAAa,GAC5Dy2D,IAAax2D,EAAM,OAAO,IAAI,GAC9B29B,IAAe34B,GAAgBW,GAAcooB,EAAQ,YAAYyoC,CAAU;AACjF,WAAAx2D,EAAM,UAAU,MAAM;AACpB,YAAMyK,IAAU+rD,EAAW;AAC3B,UAAI/rD,EAAS,QAAOqgD,GAAWrgD,CAAO;AAAA,IACxC,GAAG,CAAA,CAAE,GACkB,gBAAAnG;AAAA,MACrB08D;AAAA,MACA;AAAA,QACE,GAAGjhE;AAAA,QACH,KAAK49B;AAAA,QACL,WAAW5P,EAAQ;AAAA,QACnB,6BAA6B;AAAA,QAC7B,kBAAkBsB,GAAqBtvB,EAAM,kBAAkB,CAACyqB,MAAU;AACxE,UAAAA,EAAM,eAAc,GACpBuD,EAAQ,WAAW,SAAS,MAAK;AAAA,QACnC,CAAC;AAAA,QACD,sBAAsBsB,GAAqBtvB,EAAM,sBAAsB,CAACyqB,MAAU;AAChF,gBAAMmsC,IAAgBnsC,EAAM,OAAO,eAC7BosC,IAAgBD,EAAc,WAAW,KAAKA,EAAc,YAAY;AAE9E,WADqBA,EAAc,WAAW,KAAKC,MACjCpsC,EAAM,eAAc;AAAA,QACxC,CAAC;AAAA,QACD,gBAAgB6E;AAAA,UACdtvB,EAAM;AAAA,UACN,CAACyqB,MAAUA,EAAM,eAAc;AAAA,QACzC;AAAA,MACA;AAAA,IACA;AAAA,EACE;AACF,GACIu2C,KAAwB/gE,EAAM;AAAA,EAChC,CAACD,GAAO4F,MAAiB;AACvB,UAAMooB,IAAUqyC,GAAiBhoB,IAAcr4C,EAAM,aAAa,GAC5D+2D,IAA0B92D,EAAM,OAAO,EAAK,GAC5C+2D,IAA2B/2D,EAAM,OAAO,EAAK;AACnD,WAAuB,gBAAAsE;AAAA,MACrB08D;AAAA,MACA;AAAA,QACE,GAAGjhE;AAAA,QACH,KAAK4F;AAAA,QACL,WAAW;AAAA,QACX,6BAA6B;AAAA,QAC7B,kBAAkB,CAAC6kB,MAAU;AAC3B,UAAAzqB,EAAM,mBAAmByqB,CAAK,GACzBA,EAAM,qBACJssC,EAAwB,WAAS/oC,EAAQ,WAAW,SAAS,MAAK,GACvEvD,EAAM,eAAc,IAEtBssC,EAAwB,UAAU,IAClCC,EAAyB,UAAU;AAAA,QACrC;AAAA,QACA,mBAAmB,CAACvsC,MAAU;AAC5B,UAAAzqB,EAAM,oBAAoByqB,CAAK,GAC1BA,EAAM,qBACTssC,EAAwB,UAAU,IAC9BtsC,EAAM,OAAO,cAAc,SAAS,kBACtCusC,EAAyB,UAAU;AAGvC,gBAAMrsC,IAASF,EAAM;AAErB,UADwBuD,EAAQ,WAAW,SAAS,SAASrD,CAAM,KAC9CF,EAAM,eAAc,GACrCA,EAAM,OAAO,cAAc,SAAS,aAAausC,EAAyB,WAC5EvsC,EAAM,eAAc;AAAA,QAExB;AAAA,MACR;AAAA,IACA;AAAA,EACE;AACF,GACIw2C,KAAoBhhE,EAAM;AAAA,EAC5B,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,eAAA26D,GAAe,WAAAtJ,GAAW,iBAAAC,GAAiB,kBAAAC,GAAkB,GAAG/d,EAAY,IAAKp5C,GACnFguB,IAAUqyC,GAAiBhoB,IAAckoB,CAAa,GACtD9J,IAAax2D,EAAM,OAAO,IAAI,GAC9B29B,IAAe34B,GAAgBW,GAAc6wD,CAAU;AAC7D,WAAAtQ,GAAc,GACS,gBAAA/hD,EAAKu1B,IAAU,EAAE,UAAU;AAAA,MAChC,gBAAAp1B;AAAA,QACdmiD;AAAA,QACA;AAAA,UACE,SAAS;AAAA,UACT,MAAM;AAAA,UACN,SAASuQ;AAAA,UACT,kBAAkBC;AAAA,UAClB,oBAAoBC;AAAA,UACpB,UAA0B,gBAAA5yD;AAAA,YACxB44B;AAAA,YACA;AAAA,cACE,MAAM;AAAA,cACN,IAAInP,EAAQ;AAAA,cACZ,oBAAoBA,EAAQ;AAAA,cAC5B,mBAAmBA,EAAQ;AAAA,cAC3B,cAAcooC,GAASpoC,EAAQ,IAAI;AAAA,cACnC,GAAGorB;AAAA,cACH,KAAKxb;AAAA,cACL,WAAW,MAAM5P,EAAQ,aAAa,EAAK;AAAA,YACzD;AAAA,UACA;AAAA,QACA;AAAA,MACA;AAAA,MACsB,gBAAA5pB,EAAKu1B,IAAU,EAAE,UAAU;AAAA,QACzB,gBAAAp1B,EAAI28D,IAAc,EAAE,SAASlzC,EAAQ,QAAO,CAAE;AAAA,QAC9C,gBAAAzpB,EAAI48D,IAAoB,EAAE,YAAA1K,GAAY,eAAezoC,EAAQ,cAAa,CAAE;AAAA,MACpG,EAAO,CAAE;AAAA,IACT,GAAO;AAAA,EACL;AACF,GACIozC,KAAa,eACbC,KAAcphE,EAAM;AAAA,EACtB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,eAAA26D,GAAe,GAAGe,EAAU,IAAKthE,GACnCguB,IAAUqyC,GAAiBe,IAAYb,CAAa;AAC1D,WAAuB,gBAAAh8D,EAAI03B,GAAU,IAAI,EAAE,IAAIjO,EAAQ,SAAS,GAAGszC,GAAY,KAAK17D,EAAY,CAAE;AAAA,EACpG;AACF;AACAy7D,GAAY,cAAcD;AAC1B,IAAIG,KAAmB,qBACnBC,KAAoBvhE,EAAM;AAAA,EAC5B,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,eAAA26D,GAAe,GAAGkB,EAAgB,IAAKzhE,GACzCguB,IAAUqyC,GAAiBkB,IAAkBhB,CAAa;AAChE,WAAuB,gBAAAh8D,EAAI03B,GAAU,GAAG,EAAE,IAAIjO,EAAQ,eAAe,GAAGyzC,GAAkB,KAAK77D,EAAY,CAAE;AAAA,EAC/G;AACF;AACA47D,GAAkB,cAAcD;AAChC,IAAInK,KAAa,eACbsK,KAAczhE,EAAM;AAAA,EACtB,CAACD,GAAO4F,MAAiB;AACvB,UAAM,EAAE,eAAA26D,GAAe,GAAGjJ,EAAU,IAAKt3D,GACnCguB,IAAUqyC,GAAiBjJ,IAAYmJ,CAAa;AAC1D,WAAuB,gBAAAh8D;AAAA,MACrB03B,GAAU;AAAA,MACV;AAAA,QACE,MAAM;AAAA,QACN,GAAGq7B;AAAA,QACH,KAAK1xD;AAAA,QACL,SAAS0pB,GAAqBtvB,EAAM,SAAS,MAAMguB,EAAQ,aAAa,EAAK,CAAC;AAAA,MACtF;AAAA,IACA;AAAA,EACE;AACF;AACA0zC,GAAY,cAActK;AAC1B,SAAShB,GAAS59B,GAAM;AACtB,SAAOA,IAAO,SAAS;AACzB;AACA,IAAImpC,KAAqB,sBACrB,CAACC,IAAiBC,EAAiB,IAAIC,GAAcH,IAAoB;AAAA,EAC3E,aAAatpB;AAAA,EACb,WAAW+oB;AAAA,EACX,UAAU;AACZ,CAAC,GACGF,KAAe,CAAC,EAAE,SAAAa,QAAc;AAClC,QAAMC,IAAsBH,GAAkBF,EAAkB,GAC1DM,IAAU,KAAKD,EAAoB,WAAW,mBAAmBA,EAAoB,SAAS;AAAA;AAAA,4BAE1EA,EAAoB,SAAS;AAAA;AAAA,4EAEmBA,EAAoB,QAAQ;AACtG,SAAA/hE,EAAM,UAAU,MAAM;AACpB,IAAI8hE,MACe,SAAS,eAAeA,CAAO,KACjC,QAAQ,MAAME,CAAO;AAAA,EAExC,GAAG,CAACA,GAASF,CAAO,CAAC,GACd;AACT,GACIG,KAA2B,4BAC3Bf,KAAqB,CAAC,EAAE,YAAA1K,GAAY,eAAA0L,QAAoB;AAE1D,QAAMF,IAAU,6EADkBJ,GAAkBK,EAAwB,EAC2C,WAAW;AAClI,SAAAjiE,EAAM,UAAU,MAAM;AACpB,UAAMmiE,IAAgB3L,EAAW,SAAS,aAAa,kBAAkB;AACzE,IAAI0L,KAAiBC,MACI,SAAS,eAAeD,CAAa,KACvC,QAAQ,KAAKF,CAAO;AAAA,EAE7C,GAAG,CAACA,GAASxL,GAAY0L,CAAa,CAAC,GAChC;AACT,GACIlrB,KAAOqpB,IAEP3kB,KAAS8kB,IACT4B,KAAU1B,IACVllB,KAAUqlB,IACVwB,KAAQjB,IACRkB,KAAcf;ACxTlB,MAAMlB,KAASkC,IAIT/B,KAAegC,IAIf9B,KAAgB1gE,EAAM,WAG1B,CAAC,EAAE,WAAAkE,GAAW,GAAGnE,EAAA,GAASyE,MAC1B,gBAAAF;AAAA,EAACm+D;AAAAA,EAAA;AAAA,IACC,KAAAj+D;AAAA,IACA,WAAWJ;AAAA,MACT;AAAA,MACAF;AAAA,IAAA;AAAA,IAED,GAAGnE;AAAA,EAAA;AACN,CACD;AACD2gE,GAAc,cAAc+B,GAAwB;AAEpD,MAAM5B,KAAgB7gE,EAAM,WAG1B,CAAC,EAAE,WAAAkE,GAAW,UAAAD,GAAU,GAAGlE,EAAA,GAASyE,MACpC,gBAAAL,EAACq8D,IAAA,EACC,UAAA;AAAA,EAAA,gBAAAl8D,EAACo8D,IAAA,EAAc;AAAA,EACf,gBAAAp8D;AAAA,IAACo+D;AAAAA,IAAA;AAAA,MACC,KAAAl+D;AAAA,MACA,WAAWJ;AAAA,QACT;AAAA,QACAF;AAAA,MAAA;AAAA,MAED,GAAGnE;AAAA,MAEH,UAAAkE;AAAA,IAAA;AAAA,EAAA;AACH,EAAA,CACF,CACD;AACD48D,GAAc,cAAc6B,GAAwB;AAEpD,MAAMC,KAAe,CAAC,EAAE,WAAAz+D,GAAW,GAAGnE,EAAA,MACpC,gBAAAuE,EAAC,OAAA,EAAI,WAAWF,GAAG,sDAAsDF,CAAS,GAAI,GAAGnE,EAAA,CAAO;AAElG4iE,GAAa,cAAc;AAE3B,MAAMC,KAAe,CAAC,EAAE,WAAA1+D,GAAW,GAAGnE,QACpC,gBAAAuE;AAAA,EAAC;AAAA,EAAA;AAAA,IACC,WAAWF,GAAG,iEAAiEF,CAAS;AAAA,IACvF,GAAGnE;AAAA,EAAA;AACN;AAEF6iE,GAAa,cAAc;AAE3B,MAAMxB,KAAcphE,EAAM,WAGxB,CAAC,EAAE,WAAAkE,GAAW,GAAGnE,EAAA,GAASyE,MAC1B,gBAAAF;AAAA,EAACu+D;AAAAA,EAAA;AAAA,IACC,KAAAr+D;AAAA,IACA,WAAWJ,GAAG,qDAAqDF,CAAS;AAAA,IAC3E,GAAGnE;AAAA,EAAA;AACN,CACD;AACDqhE,GAAY,cAAcyB,GAAsB;AAEhD,MAAMtB,KAAoBvhE,EAAM,WAG9B,CAAC,EAAE,WAAAkE,GAAW,GAAGnE,EAAA,GAASyE,MAC1B,gBAAAF;AAAA,EAACw+D;AAAAA,EAAA;AAAA,IACC,KAAAt+D;AAAA,IACA,WAAWJ,GAAG,iCAAiCF,CAAS;AAAA,IACvD,GAAGnE;AAAA,EAAA;AACN,CACD;AACDwhE,GAAkB,cAAcuB,GAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;GCnEtDC,KAAoB,GACpBC,KAAsB,KA4CfC,KAAe,CAA+B;AAAA,EACzD,OAAAv/D;AAAA,EACA,aAAA65D;AAAA,EACA,aAAA2F;AAAA,EACA,UAAAxoD;AAAA,EACA,SAAAmkD;AAAA,EACA,SAAAZ;AAAA,EACA,OAAAvqD;AAAA,EACA,OAAA3P,IAAQ;AAAA,EACR,mBAAA65D,IAAoB;AAAA,EACpB,kBAAAuF,IAAmB;AAAA,EACnB,iBAAAC,IAAkB;AAAA,EAClB,kBAAAC,IAAmB;AAAA,EACnB,aAAAC;AAAA,EACA,UAAAC,IAAWR;AAAA,EACX,YAAAS,IAAaR;AAAAA,EACb,UAAAnrD;AAAA,EACA,OAAAgJ;AAAA,EACA,WAAA3c;AAAA,EACA,gBAAAy6D;AAAA,EACA,sBAAA5B;AACF,MAA+B;AAC7B,QAAM,CAACtX,GAAQwZ,CAAS,IAAI5mD,EAAS,EAAK,GACpC,CAAC2D,GAAQynD,CAAS,IAAIprD,EAAS,EAAE,GACjC,CAACqrD,GAAiBC,CAAkB,IAAItrD,EAAS,EAAE,GACnD,CAACoU,GAAMm3C,CAAO,IAAIvrD,EAAS,CAAC,GAC5B,CAAC2N,GAAS69C,CAAU,IAAIxrD,EAA+B,CAAA,CAAE,GACzD,CAAC6lD,GAAO4F,CAAQ,IAAIzrD,EAAA,GACpB,CAAC0rD,GAAaC,CAAc,IAAI3rD,EAAS,EAAK,GAC9C,CAACilD,GAAW2G,CAAY,IAAI5rD,EAAS,EAAK,GAC1C6rD,IAAezrD,GAAO,CAAC,GAEvB0rD,KAAezsD;AAAA,IACnB,MACEumD,KAAW;AAAA,MACT;AAAA,QACE,KAAK;AAAA,QACL,OAAO;AAAA,QACP,QAAQ,CAAC9iD,MAAWA,EAAO;AAAA,MAAA;AAAA,MAE7B;AAAA,QACE,KAAK;AAAA,QACL,OAAO;AAAA,QACP,QAAQ,CAACA,MACMA,EAAO,MACP,aAAa;AAAA,MAC5B;AAAA,IACF;AAAA,IAEJ,CAAC8iD,CAAO;AAAA,EAAA,GAGJmG,KAAalG,IAAQ,KAAK,IAAI,GAAG,KAAK,KAAKA,IAAQqF,CAAQ,CAAC,IAAI,QAChEc,KAAgB53C,IAAO,GACvB63C,KAAYF,KAAa33C,IAAO23C,KAAaL;AAEnD,EAAArrD,GAAU,MAAM;AACd,UAAMs5B,IAAY,OAAO,WAAW,MAAM;AACxC,MAAA2xB,EAAmB3nD,EAAO,MAAM,GAChC4nD,EAAQ,CAAC;AAAA,IACX,GAAGJ,CAAU;AAEb,WAAO,MAAM,OAAO,aAAaxxB,CAAS;AAAA,EAC5C,GAAG,CAACwxB,GAAYxnD,CAAM,CAAC,GAEvBtD,GAAU,MAAM;AACd,QAAI,CAAC+sC;AACH;AAGF,UAAM8e,IAAYL,EAAa,UAAU;AACzC,IAAAA,EAAa,UAAUK,GACvBN,EAAa,EAAI,GAEjBf,EAAY,EAAE,QAAQQ,GAAiB,MAAAj3C,GAAM,UAAA82C,GAAU,EACpD,KAAK,CAACx8D,MAAW;AAChB,MAAIm9D,EAAa,YAAYK,MAI7BV,EAAW98D,EAAO,OAAO,GACzB+8D,EAAS/8D,EAAO,KAAK,GACrBi9D,EAAej9D,EAAO,eAAe,EAAK;AAAA,IAC5C,CAAC,EACA,QAAQ,MAAM;AACb,MAAIm9D,EAAa,YAAYK,KAC3BN,EAAa,EAAK;AAAA,IAEtB,CAAC;AAAA,EACL,GAAG,CAACP,GAAiBje,GAAQyd,GAAaz2C,GAAM82C,CAAQ,CAAC;AAEzD,QAAMiB,IAAmB/qD,EAAY,CAAC8e,MAAkB;AACtD,IAAA0mC,EAAU1mC,CAAI,GAETA,MACHkrC,EAAU,EAAE,GACZE,EAAmB,EAAE,GACrBC,EAAQ,CAAC;AAAA,EAEb,GAAG,CAAA,CAAE,GAECa,KAAehrD;AAAA,IACnB,CAAC0B,MAA+B;AAC9B,MAAAT,IAAWS,CAAM,GACjBqpD,EAAiB,EAAK;AAAA,IACxB;AAAA,IACA,CAACA,GAAkB9pD,CAAQ;AAAA,EAAA,GAGvBgqD,KAAkBhhE,IACpBq5D,IACEA,EAAqBr5D,CAAK,IAC1BA,EAAM,QACR65D;AAEJ,2BACG,OAAA,EAAI,WAAWn5D,EAAGC,GAAI,SAASH,CAAS,GACtC,UAAA;AAAA,IAAAwP,KAAS,gBAAApP,EAAC+3D,IAAA,EAAM,SAAQ,qBAAqB,UAAA3oD,GAAM;AAAA,IACpD,gBAAAvP;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,IAAG;AAAA,QACH,MAAK;AAAA,QACL,UAAU0T,IAAW,KAAK;AAAA,QAC1B,WAAWzT,EAAGC,GAAI,OAAO,EAAE,CAACA,GAAI,QAAQ,GAAGwT,GAAU,CAACxT,GAAI,KAAK,GAAGwc,EAAA,GAAS89C,CAAc;AAAA,QACzF,SAAS,MAAM,CAAC9mD,KAAY2sD,EAAiB,EAAI;AAAA,QACjD,WAAW,CAACh6C,MAAU;AACpB,UAAI,CAAC3S,MAAa2S,EAAM,QAAQ,WAAWA,EAAM,QAAQ,SACvDA,EAAM,eAAA,GACNg6C,EAAiB,EAAI;AAAA,QAEzB;AAAA,QAEA,UAAA;AAAA,UAAA,gBAAAlgE,EAAC,QAAA,EAAK,WAAWF,EAAGC,GAAI,gBAAgB,EAAE,CAACA,GAAI,WAAW,GAAG,CAACX,EAAA,CAAO,GAClE,UAAAghE,GAAA,CACH;AAAA,UACA,gBAAAvgE,EAAC,QAAA,EAAK,WAAWE,GAAI,SAClB,UAAA;AAAA,YAAAw6D,KAAWn7D,KACV,gBAAAY;AAAA,cAAC4S;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,WAAW7S,GAAI;AAAA,gBACf,cAAW;AAAA,gBACX,SAAS,CAACmmB,MAAU;AAClB,kBAAAA,EAAM,gBAAA,GACNq0C,EAAA;AAAA,gBACF;AAAA,gBAEA,4BAACjC,IAAA,CAAA,CAAU;AAAA,cAAA;AAAA,YAAA;AAAA,YAGf,gBAAAt4D;AAAA,cAAC4S;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,WAAW7S,GAAI;AAAA,gBACf,UAAAwT;AAAA,gBACA,SAAS,CAAC2S,MAAU;AAClB,kBAAAA,EAAM,gBAAA,GACNg6C,EAAiB,EAAI;AAAA,gBACvB;AAAA,gBAEC,UAAArB;AAAA,cAAA;AAAA,YAAA;AAAA,UACH,EAAA,CACF;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,IAGF,gBAAA7+D,EAAC+7D,IAAA,EAAO,MAAM5a,GAAQ,cAAc+e,GAClC,UAAA,gBAAArgE,EAAC08D,IAAA,EAAc,WAAWx8D,GAAI,eAC5B,UAAA;AAAA,MAAA,gBAAAC,EAACq+D,IAAA,EAAa,WAAWt+D,GAAI,cAC3B,UAAA,gBAAAC,EAAC88D,MAAY,WAAW/8D,GAAI,aAAc,UAAAN,EAAA,CAAM,GAClD;AAAA,MAEA,gBAAAI,EAAC,OAAA,EAAI,WAAWE,GAAI,QAClB,UAAA;AAAA,QAAA,gBAAAC,EAACk5D,IAAA,EAAW,WAAWn5D,GAAI,WAAA,CAAY;AAAA,QACvC,gBAAAC;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,WAAWD,GAAI;AAAA,YACf,OAAO2X;AAAA,YACP,UAAU,CAACwO,MAAUi5C,EAAUj5C,EAAM,OAAO,KAAK;AAAA,YACjD,aAAaozC;AAAA,YACb,WAAS;AAAA,UAAA;AAAA,QAAA;AAAA,QAEVN,KAAa,gBAAAh5D,EAAC+S,IAAA,EAAQ,MAAK,cAAa,WAAWhT,GAAI,cAAA,CAAe;AAAA,MAAA,GACzE;AAAA,MAEA,gBAAAF,EAAC,OAAA,EAAI,WAAWE,GAAI,gBAClB,UAAA;AAAA,QAAA,gBAAAF,EAAC,SAAA,EAAM,WAAWE,GAAI,OACpB,UAAA;AAAA,UAAA,gBAAAC,EAAC,WACC,UAAA,gBAAAA,EAAC,MAAA,EACE,aAAa,IAAI,CAACg6D,MACjB,gBAAAh6D,EAAC,MAAA,EAAoB,WAAWg6D,EAAO,WACpC,UAAAA,EAAO,MAAA,GADDA,EAAO,GAEhB,CACD,GACH,EAAA,CACF;AAAA,UACA,gBAAAh6D,EAAC,SAAA,EACE,UAAA0hB,EAAQ,IAAI,CAAC7K,MAAW;AACvB,kBAAMwX,IAAWjvB,GAAO,UAAUyX,EAAO;AAEzC,mBACE,gBAAA7W;AAAA,cAAC;AAAA,cAAA;AAAA,gBAEC,WAAWF,EAAG,EAAE,CAACC,GAAI,SAAS,GAAGsuB,GAAU;AAAA,gBAC3C,SAAS,MAAM8xC,GAAatpD,CAAM;AAAA,gBAEjC,UAAAgpD,GAAa,IAAI,CAAC7F,yBAChB,MAAA,EAAoB,WAAWA,GAAO,WACpC,aAAO,OAAOnjD,CAAM,EAAA,GADdmjD,GAAO,GAEhB,CACD;AAAA,cAAA;AAAA,cARI,OAAOnjD,EAAO,KAAK;AAAA,YAAA;AAAA,UAW9B,CAAC,EAAA,CACH;AAAA,QAAA,GACF;AAAA,QAEC,CAACmiD,KAAa,CAACt3C,EAAQ,UACtB,gBAAA1hB,EAAC,OAAA,EAAI,WAAWD,GAAI,YAClB,UAAA,gBAAAC;AAAA,UAACuzD;AAAA,UAAA;AAAA,YACC,OAAM;AAAA,YACN,UAAS;AAAA,UAAA;AAAA,QAAA,EACX,CACF;AAAA,MAAA,GAEJ;AAAA,MAEA,gBAAA1zD,EAACy+D,IAAA,EAAa,WAAWv+D,GAAI,cAC3B,UAAA;AAAA,QAAA,gBAAAF,EAAC,OAAA,EAAI,WAAWE,GAAI,YAClB,UAAA;AAAA,UAAA,gBAAAC;AAAA,YAAC4S;AAAA,YAAA;AAAA,cACC,SAAQ;AAAA,cACR,MAAK;AAAA,cACL,UAAU,CAACmtD,MAAiB/G;AAAA,cAC5B,SAAS,MAAMsG,EAAQ,CAACe,MAAgB,KAAK,IAAI,GAAGA,IAAc,CAAC,CAAC;AAAA,cACrE,UAAA;AAAA,YAAA;AAAA,UAAA;AAAA,UAGD,gBAAAxgE,EAAC,QAAA,EAAK,WAAWE,GAAI,UAAU,UAAA;AAAA,YAAA;AAAA,YACnBooB;AAAA,YACT23C,KAAa,OAAOA,EAAU,KAAK;AAAA,UAAA,GACtC;AAAA,UACA,gBAAA9/D;AAAA,YAAC4S;AAAA,YAAA;AAAA,cACC,SAAQ;AAAA,cACR,MAAK;AAAA,cACL,UAAU,CAACotD,MAAahH;AAAA,cACxB,SAAS,MAAMsG,EAAQ,CAACe,MAAgBA,IAAc,CAAC;AAAA,cACxD,UAAA;AAAA,YAAA;AAAA,UAAA;AAAA,QAED,GACF;AAAA,QACA,gBAAAxgE,EAAC,OAAA,EAAI,WAAWE,GAAI,eACjB,UAAA;AAAA,UAAAi/D,uBACEpsD,IAAA,EAAO,SAAQ,WAAU,SAASosD,GAChC,UAAAD,GACH;AAAA,UAEF,gBAAA/+D,EAAC4S,MAAO,SAAQ,aAAY,SAAS,MAAMstD,EAAiB,EAAK,GAC9D,UAAApB,EAAA,CACH;AAAA,QAAA,EAAA,CACF;AAAA,MAAA,EAAA,CACF;AAAA,IAAA,EAAA,CACF,EAAA,CACF;AAAA,IAECviD,KAAS,gBAAAvc,EAAC63D,IAAA,EAAc,UAAAt7C,EAAA,CAAM;AAAA,EAAA,GACjC;AAEJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GC7SMmiD,KAAsB,KACtB4B,KAAW,YA8CJC,KAAmB,CAA+B;AAAA,EAC7D,OAAAnhE;AAAA,EACA,aAAA65D;AAAA,EACA,cAAAuH;AAAA,EACA,aAAAC;AAAA,EACA,UAAArqD;AAAA,EACA,SAAAmkD;AAAA,EACA,OAAAnrD;AAAA,EACA,OAAA3P,IAAQ;AAAA,EACR,mBAAA65D,IAAoB;AAAA,EACpB,kBAAAuF,IAAmB;AAAA,EACnB,iBAAAC,IAAkB;AAAA,EAClB,mBAAA4B,IAAoB;AAAA,EACpB,YAAAxB,IAAaR;AAAA,EACb,UAAAnrD;AAAA,EACA,OAAAgJ;AAAA,EACA,WAAA3c;AAAA,EACA,gBAAAy6D;AAAA,EACA,sBAAA5B;AAAA,EACA,YAAAkI;AACF,MAAmC;AACjC,QAAM,CAACxf,GAAQwZ,CAAS,IAAI5mD,EAAS,EAAK,GACpC,CAAC2D,GAAQynD,CAAS,IAAIprD,EAAS,EAAE,GACjC,CAACqrD,GAAiBC,CAAkB,IAAItrD,EAAS,EAAE,GAEnD,CAAC6sD,GAAeC,CAAgB,IAAI9sD;AAAA,IACxC,0BAAU,IAAA;AAAA,EAAI,GAEV,CAAC+sD,GAAcC,CAAe,IAAIhtD,EAAsB,MAAM,oBAAI,KAAK,GACvE,CAACitD,GAAUC,CAAW,IAAIltD,EAAiB,MAAM,oBAAI,KAAK,GAC1D,CAACmtD,GAAgBC,CAAiB,IAAIptD,EAAiB,MAAM,oBAAI,KAAK,GACtE,CAACqtD,GAAeC,CAAgB,IAAIttD,EAAiB,MAAM,oBAAI,KAAK,GACpE,CAACutD,GAAaC,CAAc,IAAIxtD,EAAS,EAAK,GAC9C,CAACytD,IAAkBC,EAAmB,IAAI1tD,EAAgC,IAAI,GAE9E2tD,KAAmBvtD,GAAO,CAAC,GAC3BwtD,KAAqBxtD,GAAO,CAAC;AAGnC,EAAAC,GAAU,MAAM;AAEd,QADI,CAAC+sC,KACDyf,EAAc,IAAIN,EAAQ,EAAG;AAEjC,UAAML,IAAYyB,GAAiB,UAAU;AAC7C,IAAAA,GAAiB,UAAUzB,GAE3Bc,EAAgB,CAAC7uC,OAAS;AACxB,YAAMxqB,KAAO,IAAI,IAAIwqB,EAAI;AACzB,aAAAxqB,GAAK,IAAI44D,EAAQ,GACV54D;AAAA,IACT,CAAC,GAED84D,EAAa,EAAE,UAAU,MAAM,QAAQ,IAAI,EACxC,KAAK,CAAC/9D,OAAW;AAChB,MAAIi/D,GAAiB,YAAYzB,KACjCY,EAAiB,CAAC3uC,OAAS;AACzB,cAAMxqB,KAAO,IAAI,IAAIwqB,EAAI;AACzB,eAAAxqB,GAAK,IAAI44D,IAAU79D,GAAO,KAAK,GACxBiF;AAAA,MACT,CAAC;AAAA,IACH,CAAC,EACA,QAAQ,MAAM;AACb,MAAIg6D,GAAiB,YAAYzB,KACjCc,EAAgB,CAAC7uC,OAAS;AACxB,cAAMxqB,KAAO,IAAI,IAAIwqB,EAAI;AACzB,eAAAxqB,GAAK,OAAO44D,EAAQ,GACb54D;AAAA,MACT,CAAC;AAAA,IACH,CAAC;AAAA,EACL,GAAG,CAACy5C,GAAQqf,GAAcI,CAAa,CAAC,GAGxCxsD,GAAU,MAAM;AACd,UAAM5U,IAAK,OAAO,WAAW,MAAM6/D,EAAmB3nD,EAAO,MAAM,GAAGwnD,CAAU;AAChF,WAAO,MAAM,OAAO,aAAa1/D,CAAE;AAAA,EACrC,GAAG,CAACkY,GAAQwnD,CAAU,CAAC,GAGvB9qD,GAAU,MAAM;AAEd,QADI,CAAC+sC,KACD,CAACsf,EAAa;AAClB,QAAI,CAACrB,GAAiB;AACpB,MAAAiC,EAAiB,oBAAI,KAAK,GAC1BF,EAAkB,oBAAI,KAAK;AAC3B;AAAA,IACF;AAEA,UAAMlB,IAAY0B,GAAmB,UAAU;AAC/C,IAAAA,GAAmB,UAAU1B,GAC7BsB,EAAe,EAAI,GAEnBd,EAAYrB,CAAe,EACxB,KAAK,CAAC38D,OAAW;AAChB,UAAIk/D,GAAmB,YAAY1B,EAAW;AAE9C,YAAMtnD,yBAAc,IAAA,GACdipD,yBAAwB,IAAA,GAExBC,yBAAuB,IAAA;AAE7B,iBAAW/wC,MAAQruB,GAAO,SAAS;AACjC,QAAAkW,GAAQ,IAAImY,GAAK,KAAK,KAAK;AAE3B,cAAMgxC,KAAW,CAAC,GAAGhxC,GAAK,MAAMA,GAAK,IAAI;AACzC,iBAASrwB,KAAI,GAAGA,KAAIqhE,GAAS,SAAS,GAAGrhE,MAAK;AAC5C,gBAAMmV,KAASksD,GAASrhE,EAAC,GACnBmB,KAAQkgE,GAASrhE,KAAI,CAAC;AAC5B,UAAAmhE,GAAkB,IAAIhsD,GAAO,KAAK;AAElC,gBAAMmsD,KAAoBnsD,GAAO;AACjC,UAAKisD,GAAiB,IAAIE,EAAS,KACjCF,GAAiB,IAAIE,IAAW,oBAAI,IAAA,CAAK,GAE3CF,GAAiB,IAAIE,EAAS,EAAG,IAAIngE,GAAM,OAAOA,EAAK;AAAA,QACzD;AAEA,YAAIkgE,GAAS,SAAS,GAAG;AACvB,gBAAMn0B,KAAOm0B,GAAS,CAAC;AACvB,UAAKD,GAAiB,IAAIvB,EAAQ,KAChCuB,GAAiB,IAAIvB,IAAU,oBAAI,IAAA,CAAK,GAE1CuB,GAAiB,IAAIvB,EAAQ,EAAG,IAAI3yB,GAAK,OAAOA,EAAI;AAAA,QACtD;AAAA,MACF;AAEA,MAAA0zB,EAAiB1oD,EAAO,GACxBwoD,EAAkBS,EAAiB,GACnCf,EAAiB,CAAC3uC,OAAS;AACzB,cAAMxqB,KAAO,IAAI,IAAIwqB,EAAI;AACzB,eAAA2vC,GAAiB,QAAQ,CAAC/L,IAAK32D,OAAQ;AACrC,gBAAM6iE,KAAWt6D,GAAK,IAAIvI,EAAG,KAAK,CAAA,GAC5B8iE,yBAAa,IAAA;AACnB,UAAAD,GAAS,QAAQ,CAACl/D,OAAMm/D,GAAO,IAAIn/D,GAAE,OAAOA,EAAC,CAAC,GAC9CgzD,GAAI,QAAQ,CAAChzD,IAAGsI,OAAM62D,GAAO,IAAI72D,IAAGtI,EAAC,CAAC,GACtC4E,GAAK,IAAIvI,IAAK,MAAM,KAAK8iE,GAAO,OAAA,CAAQ,CAAC;AAAA,QAC3C,CAAC,GACMv6D;AAAA,MACT,CAAC;AAAA,IACH,CAAC,EACA,QAAQ,MAAM;AACb,MAAIi6D,GAAmB,YAAY1B,KAAWsB,EAAe,EAAK;AAAA,IACpE,CAAC;AAAA,EACL,GAAG,CAACnC,GAAiBje,GAAQsf,CAAW,CAAC;AAEzC,QAAMP,IAAmB/qD,EAAY,CAAC8e,MAAkB;AACtD,IAAA0mC,EAAU1mC,CAAI,GACTA,MACHkrC,EAAU,EAAE,GACZE,EAAmB,EAAE,GACrBoC,GAAoB,IAAI,GACxBJ,EAAiB,oBAAI,KAAK,GAC1BF,EAAkB,oBAAI,KAAK;AAAA,EAE/B,GAAG,CAAA,CAAE,GAECe,KAAuB/sD;AAAA,IAC3B,CAACS,MAA2B;AAC1B,YAAMzW,KAAcyW,EAAO;AAC3B,MAAIgrD,EAAc,IAAIzhE,EAAG,KACrB2hE,EAAa,IAAI3hE,EAAG,MAExB4hE,EAAgB,CAAC7uC,OAAS;AACxB,cAAMxqB,KAAO,IAAI,IAAIwqB,EAAI;AACzB,eAAAxqB,GAAK,IAAIvI,EAAG,GACLuI;AAAA,MACT,CAAC,GAED84D,EAAa,EAAE,UAAU5qD,EAAO,OAAO,QAAQ,IAAI,EAChD,KAAK,CAACnT,OAAW;AAChB,QAAAo+D,EAAiB,CAAC3uC,OAAS;AACzB,gBAAMxqB,KAAO,IAAI,IAAIwqB,EAAI,GACnB8vC,KAAWt6D,GAAK,IAAIvI,EAAG,KAAK,CAAA,GAC5B8iE,yBAAa,IAAA;AACnB,iBAAAD,GAAS,QAAQ,CAACl/D,OAAMm/D,GAAO,IAAIn/D,GAAE,OAAOA,EAAC,CAAC,GAC9CL,GAAO,MAAM,QAAQ,CAACK,OAAMm/D,GAAO,IAAIn/D,GAAE,OAAOA,EAAC,CAAC,GAClD4E,GAAK,IAAIvI,IAAK,MAAM,KAAK8iE,GAAO,OAAA,CAAQ,CAAC,GAClCv6D;AAAA,QACT,CAAC;AAAA,MACH,CAAC,EACA,QAAQ,MAAM;AACb,QAAAq5D,EAAgB,CAAC7uC,OAAS;AACxB,gBAAMxqB,KAAO,IAAI,IAAIwqB,EAAI;AACzB,iBAAAxqB,GAAK,OAAOvI,EAAG,GACRuI;AAAA,QACT,CAAC;AAAA,MACH,CAAC;AAAA,IACL;AAAA,IACA,CAACk5D,GAAeJ,GAAcM,CAAY;AAAA,EAAA,GAGtCqB,KAAehtD;AAAA,IACnB,CAAC9U,MAAyB;AACxB,MAAA4gE,EAAY,CAAC/uC,OAAS;AACpB,cAAMxqB,KAAO,IAAI,IAAIwqB,EAAI;AACzB,eAAIxqB,GAAK,IAAIrH,EAAK,KAAK,IACrBqH,GAAK,OAAOrH,EAAK,KAAK,KAEtBqH,GAAK,IAAIrH,EAAK,KAAK,GACnB6hE,GAAqB7hE,CAAI,IAEpBqH;AAAA,MACT,CAAC;AAAA,IACH;AAAA,IACA,CAACw6D,EAAoB;AAAA,EAAA,GAGjBE,IAAmBjtD,EAAY,CAAC9U,MAAyB;AAC7D,IAAAohE,GAAoBphE,CAAI;AAAA,EAC1B,GAAG,CAAA,CAAE,GAECgiE,IAAgBltD,EAAY,MAAM;AACtC,IAAIqsD,MACFprD,IAAWorD,EAAgB,GAE7BtB,EAAiB,EAAK;AAAA,EACxB,GAAG,CAACA,GAAkB9pD,GAAUorD,EAAgB,CAAC,GAE3Cc,KAAantD;AAAA,IACjB,CAACotD,MAAiBvB,EAAS,IAAIuB,CAAS,KAAKrB,EAAe,IAAIqB,CAAS;AAAA,IACzE,CAACvB,GAAUE,CAAc;AAAA,EAAA,GAIrBsB,KAAertD;AAAA,IACnB,CAACkvC,MAA8C;AAC7C,UAAI,CAAC+a,KAAmBqB,EAAa,QAAOpc;AAC5C,YAAMlE,KAAIif,EAAgB,YAAA;AAC1B,aAAO/a,EAAM,OAAO,CAACvhD,OAAMA,GAAE,MAAM,YAAA,EAAc,SAASq9C,EAAC,CAAC;AAAA,IAC9D;AAAA,IACA,CAACif,GAAiBqB,CAAW;AAAA,EAAA,GAGzBgC,KAAa,CAACpiE,GAAsBqiE,OAA6B;AACrE,UAAMvjE,KAAckB,EAAK,OACnBV,KAAWihE,EAAc,IAAIzhE,EAAG,GAChCwjE,KAAiBL,GAAWjiE,EAAK,KAAK,GACtCuiE,KAAgB9B,EAAa,IAAI3hE,EAAG,GACpCmvB,KAAYkzC,IAAkB,UAAUnhE,EAAK,OAC7CwiE,KAAYzjE,GAAO,UAAUiB,EAAK,OAClCyiE,KAAU1B,EAAc,IAAI/gE,EAAK,KAAK,GAEtC0iE,KAAeJ,MAAkBhjE,MAAYA,GAAS,SAAS,GAC/DqjE,KAAkBD,KAAeP,GAAa7iE,EAAS,IAAI,CAAA;AAEjE,WACE,gBAAAE,EAACnE,GAAM,UAAN,EACC,UAAA;AAAA,MAAA,gBAAAmE;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAWC,EAAGC,EAAI,KAAK;AAAA,YACrB,CAACA,EAAI,UAAU,GAAGuuB,MAAau0C;AAAA,YAC/B,CAAC9iE,EAAI,SAAS,GAAG+iE;AAAA,UAAA,CAClB;AAAA,UACD,OAAO,EAAE,aAAa,KAAKJ,KAAQ,GAAA;AAAA,UACnC,SAAS,MAAMN,EAAiB/hE,CAAI;AAAA,UAEnC,UAAA;AAAA,YAAAA,EAAK,cACJ,gBAAAL;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,MAAK;AAAA,gBACL,WAAWF,EAAGC,EAAI,SAAS,EAAE,CAACA,EAAI,eAAe,GAAG4iE,IAAgB;AAAA,gBACpE,SAAS,CAAC9tC,OAAM;AACd,kBAAAA,GAAE,gBAAA,GACFstC,GAAa9hE,CAAI;AAAA,gBACnB;AAAA,gBACA,cAAYsiE,KAAiB,aAAa;AAAA,gBAE1C,4BAACnO,IAAA,CAAA,CAAc;AAAA,cAAA;AAAA,YAAA,IAGjB,gBAAAx0D,EAAC,QAAA,EAAK,WAAWD,EAAI,mBAAA,CAAoB;AAAA,YAE3C,gBAAAC,EAAC,QAAA,EAAK,WAAWD,EAAI,WAAY,cAAa4gE,EAAWtgE,CAAI,IAAIA,EAAK,MAAA,CAAM;AAAA,YAC3EuiE,MAAiB,gBAAA5iE,EAAC+S,IAAA,EAAQ,MAAK,cAAa,WAAWhT,EAAI,YAAA,CAAa;AAAA,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,MAE1EgjE,MACCC,GAAgB,IAAI,CAACphE,OAAU6gE,GAAW7gE,IAAO8gE,KAAQ,CAAC,CAAC;AAAA,IAAA,EAAA,GA5B1C,OAAOriE,EAAK,KAAK,CA6BtC;AAAA,EAEJ,GAEM4iE,IAAYrC,EAAc,IAAIN,EAAQ,KAAK,CAAA,GAC3C4C,KAAeV,GAAaS,CAAS,GACrCE,KAAgBrC,EAAa,IAAIR,EAAQ,GAEzCF,KAAkBhhE,IACpBq5D,IACEA,EAAqBr5D,CAAK,IAC1BA,EAAM,QACR65D,GAEEmK,KAAY,CAACD,MAAiB,CAAC7B,KAAe4B,GAAa,WAAW,GAEtEG,KAAoBjwD;AAAA,IACxB,MAAMkuD,KAAgB6B,MAAiB,EAAQ/D;AAAA,IAC/C,CAACkC,GAAa6B,IAAe/D,CAAe;AAAA,EAAA;AAG9C,2BACG,OAAA,EAAI,WAAWt/D,EAAGC,EAAI,SAASH,CAAS,GACtC,UAAA;AAAA,IAAAwP,KAAS,gBAAApP,EAAC+3D,IAAA,EAAM,SAAQ,yBAAyB,UAAA3oD,GAAM;AAAA,IACxD,gBAAAvP;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,IAAG;AAAA,QACH,MAAK;AAAA,QACL,UAAU0T,IAAW,KAAK;AAAA,QAC1B,WAAWzT;AAAAA,UACTC,EAAI;AAAA,UACJ,EAAE,CAACA,EAAI,QAAQ,GAAGwT,GAAU,CAACxT,EAAI,KAAK,GAAGwc,EAAA;AAAA,UACzC89C;AAAA,QAAA;AAAA,QAEF,SAAS,MAAM,CAAC9mD,KAAY2sD,EAAiB,EAAI;AAAA,QACjD,WAAW,CAACh6C,MAAU;AACpB,UAAI,CAAC3S,MAAa2S,EAAM,QAAQ,WAAWA,EAAM,QAAQ,SACvDA,EAAM,eAAA,GACNg6C,EAAiB,EAAI;AAAA,QAEzB;AAAA,QAEA,UAAA;AAAA,UAAA,gBAAAlgE,EAAC,QAAA,EAAK,WAAWF,EAAGC,EAAI,gBAAgB,EAAE,CAACA,EAAI,WAAW,GAAG,CAACX,EAAA,CAAO,GAClE,UAAAghE,GAAA,CACH;AAAA,UACA,gBAAAvgE,EAAC,QAAA,EAAK,WAAWE,EAAI,SAClB,UAAA;AAAA,YAAAw6D,KAAWn7D,KACV,gBAAAY;AAAA,cAAC4S;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,WAAW7S,EAAI;AAAA,gBACf,cAAW;AAAA,gBACX,SAAS,CAACmmB,MAAU;AAClB,kBAAAA,EAAM,gBAAA,GACNq0C,EAAA;AAAA,gBACF;AAAA,gBAEA,4BAACjC,IAAA,CAAA,CAAU;AAAA,cAAA;AAAA,YAAA;AAAA,YAGf,gBAAAt4D;AAAA,cAAC4S;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,WAAW7S,EAAI;AAAA,gBACf,UAAAwT;AAAA,gBACA,SAAS,CAAC2S,MAAU;AAClB,kBAAAA,EAAM,gBAAA,GACNg6C,EAAiB,EAAI;AAAA,gBACvB;AAAA,gBAEC,UAAArB;AAAA,cAAA;AAAA,YAAA;AAAA,UACH,EAAA,CACF;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,IAGF,gBAAA7+D,EAAC+7D,IAAA,EAAO,MAAM5a,GAAQ,cAAc+e,GAClC,UAAA,gBAAArgE,EAAC08D,IAAA,EAAc,WAAWx8D,EAAI,eAC5B,UAAA;AAAA,MAAA,gBAAAC,EAACq+D,IAAA,EAAa,WAAWt+D,EAAI,cAC3B,UAAA,gBAAAC,EAAC88D,MAAY,WAAW/8D,EAAI,aAAc,UAAAN,EAAA,CAAM,GAClD;AAAA,MAEA,gBAAAI,EAAC,OAAA,EAAI,WAAWE,EAAI,QAClB,UAAA;AAAA,QAAA,gBAAAC,EAACk5D,IAAA,EAAW,WAAWn5D,EAAI,WAAA,CAAY;AAAA,QACvC,gBAAAC;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,WAAWD,EAAI;AAAA,YACf,OAAO2X;AAAA,YACP,UAAU,CAACwO,MAAUi5C,EAAUj5C,EAAM,OAAO,KAAK;AAAA,YACjD,aAAaozC;AAAA,YACb,WAAS;AAAA,UAAA;AAAA,QAAA;AAAA,QAEV+J,MACC,gBAAArjE,EAAC+S,IAAA,EAAQ,MAAK,cAAa,WAAWhT,EAAI,cAAA,CAAe;AAAA,MAAA,GAE7D;AAAA,MAEA,gBAAAC,EAAC,OAAA,EAAI,WAAWD,EAAI,eACjB,gBAAiBkjE,EAAU,WAAW,IACrC,gBAAAjjE,EAAC,OAAA,EAAI,WAAWD,EAAI,cAClB,UAAA,gBAAAC,EAAC+S,IAAA,EAAQ,MAAK,QAAA,CAAQ,EAAA,CACxB,IACEqwD,KACF,gBAAApjE,EAAC,OAAA,EAAI,WAAWD,EAAI,YAClB,UAAA,gBAAAC;AAAA,QAACuzD;AAAA,QAAA;AAAA,UACC,OAAM;AAAA,UACN,UAAS;AAAA,QAAA;AAAA,MAAA,GAEb,IAEA2P,GAAa,IAAI,CAAC7iE,MAASoiE,GAAWpiE,GAAM,CAAC,CAAC,GAElD;AAAA,MAEA,gBAAAR,EAACy+D,IAAA,EAAa,WAAWv+D,EAAI,cAC3B,UAAA;AAAA,QAAA,gBAAAC,EAAC4S,IAAA,EAAO,SAAQ,aAAY,SAAS,MAAMstD,EAAiB,EAAK,GAC9D,UAAApB,EAAA,CACH;AAAA,QACA,gBAAA9+D,EAAC4S,MAAO,SAAQ,WAAU,UAAU,CAAC4uD,IAAkB,SAASa,GAC7D,UAAA3B,EAAA,CACH;AAAA,MAAA,EAAA,CACF;AAAA,IAAA,EAAA,CACF,EAAA,CACF;AAAA,IAECnkD,KAAS,gBAAAvc,EAAC63D,IAAA,EAAc,UAAAt7C,EAAA,CAAM;AAAA,EAAA,GACjC;AAEJ;;;;;;GCxca+mD,KAA+B5nE,EAAM;AAAA,EAChD,CAAC,EAAE,WAAAkE,GAAW,OAAAolD,IAAQ,CAAA,GAAI,WAAAue,GAAW,SAAA72C,GAAS,eAAA82C,EAAA,MAC5C,gBAAAxjE,EAAC,OAAA,EAAI,WAAWF,EAAGC,GAAI,SAASH,CAAS,GACvC,UAAA,gBAAAI,EAAC,OAAA,EAAI,WAAWF,EAAGC,GAAI,MAAMyjE,CAAa,GACvC,UAAAxe,EAAM;AAAA,IACL,CAACl0B,GAAM3nB,MACL2nB,EAAK,SACH,gBAAAjxB;AAAA,MAAC;AAAA,MAAA;AAAA,QAEC,WAAWC,EAAGC,GAAI,SAAS+wB,EAAK,WAAW;AAAA,UACzC,CAAC/wB,GAAI,MAAM,GAAGwjE,MAAcp6D;AAAA,UAC5B,CAACpJ,GAAI,KAAK,GAAGoJ,MAAU;AAAA,UACvB,CAACpJ,GAAI,IAAI,GAAGoJ,MAAU67C,EAAM,SAAS;AAAA,QAAA,CACtC;AAAA,QACD,OAAO;AAAA,UACL,QACEue,MAAcp6D,IAAQ67C,EAAM,SAAS77C,MAAU,IAAI,IAAI67C,EAAM,SAAS77C;AAAA,QAAA;AAAA,QAE1E,SAAS,CAAC0rB,MAAM;AACd,UAAAA,EAAE,gBAAA,GACFnI,IAAUvjB,CAAK;AAAA,QACjB;AAAA,QAEC,UAAA;AAAA,UAAAo6D,MAAcp6D,KAASA,MAAU,uBAAM,QAAA,EAAK,WAAWpJ,GAAI,QAAQ;AAAA,UACnE+wB,EAAK;AAAA,UACLyyC,MAAcp6D,KAASA,MAAU67C,EAAM,SAAS,KAAK,gBAAAhlD,EAAC,QAAA,EAAK,WAAWD,GAAI,MAAA,CAAO;AAAA,QAAA;AAAA,MAAA;AAAA,MAjB7EoJ;AAAA,IAAA;AAAA,EAkBP,GAGR,EAAA,CACF;AAEJ;;;;;;;;;;;GC1Bas6D,KAAkC,CAAC;AAAA,EAC9C,OAAAze;AAAA,EACA,SAAAz9C;AAAA,EACA,UAAA6O;AAAA,EACA,sBAAAstD,IAAuB;AAAA,EACvB,WAAA9jE;AACF,MAAM;AACJ,QAAM+jE,IAAc,EAAQvtD;AAE5B,SACE,gBAAApW,EAAC,OAAA,EAAI,WAAWF,EAAGC,GAAI,SAASH,CAAS,GAAG,MAAK,QAC9C,UAAAolD,EAAM,IAAI,CAACl0B,GAAM3nB,MAAU;AAC1B,UAAMy6D,IAAcz6D,IAAQ5B,GACtBs7D,IAAY15D,MAAU5B,GACtB8mB,IAAWllB,KAAS5B,GACpBs8D,IAAS16D,MAAU67C,EAAM,SAAS,GAClC8e,IAAYJ,KAAwBE,GAEpCG,IAAcjzC,EAAK,YAAYgzC,IAAY,gBAAA9jE,EAACgkE,IAAA,CAAA,CAAS,IAAK76D,IAAQ,IAElE86D,IACJ,gBAAAjkE;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,WAAWF,EAAGC,GAAI,MAAM;AAAA,UACtB,CAACA,GAAI,aAAa,GAAG,CAACsuB;AAAA,UACtB,CAACtuB,GAAI,YAAY,GAAG8iE;AAAA,UACpB,CAAC9iE,GAAI,SAAS,GAAG4jE;AAAA,QAAA,CAClB;AAAA,QACD,UAAU,CAACA;AAAA,QACX,SAAS,MAAMvtD,IAAWjN,CAAK;AAAA,QAC/B,gBAAc05D,IAAY,SAAS;AAAA,QACnC,cAAY,OAAO/xC,EAAK,SAAU,WAAWA,EAAK,QAAQ,OAAO3nB,IAAQ,CAAC;AAAA,QAEzE,UAAA46D;AAAA,MAAA;AAAA,IAAA;AAIL,WACE,gBAAAlkE,EAACnE,GAAM,UAAN,EACE,UAAA;AAAA,MAAAo1B,EAAK,QACJ,gBAAAjxB,EAAC,OAAA,EAAI,WAAWE,GAAI,WAAW,MAAK,YACjC,UAAA;AAAA,QAAAkkE;AAAA,QACD,gBAAAjkE,EAAC,QAAA,EAAK,WAAWF,EAAGC,GAAI,OAAO,EAAE,CAACA,GAAI,YAAY,GAAGsuB,EAAA,CAAU,GAC5D,YAAK,MAAA,CACR;AAAA,MAAA,GACF,IAEA,gBAAAruB,EAAC,OAAA,EAAI,MAAK,YAAY,UAAAikE,GAAS;AAAA,MAEhC,CAACJ,KACA,gBAAA7jE;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAWF,EAAGC,GAAI,WAAW,EAAE,CAACA,GAAI,gBAAgB,GAAGoJ,IAAQ5B,EAAA,CAAS;AAAA,QAAA;AAAA,MAAA;AAAA,IAC1E,EAAA,GAdiB4B,CAgBrB;AAAA,EAEJ,CAAC,EAAA,CACH;AAEJ;;;;;;;;;GC5Da+6D,KAAOxoE,EAAM;AAAA,EACxB,CAAC;AAAA,IACC,OAAAspD,IAAQ,CAAA;AAAA,IACR,WAAAue;AAAA,IACA,WAAA3jE;AAAA,IACA,eAAA4jE;AAAA,IACA,cAAAW;AAAA,IACA,YAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,SAAA33C;AAAA,EAAA,MACe;AACf,UAAM43C,IAASnwD,GAAuB,IAAI,GACpCowD,IAAoBpwD,GAAsB,IAAI,GAC9C,CAACqwD,GAAMC,CAAO,IAAI1wD,EAAS,EAAE,MAAM,GAAG,OAAO,GAAG;AAEtD,WAAAK,GAAU,MAAM;AACd,YAAM/T,IAAOikE,EAAO;AAEpB,UAAI,CAACjkE;AACH;AAGF,YAAMqkE,IAAa,MAAM;AACvB,cAAMC,IAAW;AAAA,UACf,MAAMtkE,EAAK,cAAc;AAAA,UACzB,OAAOA,EAAK,eAAe;AAAA,QAAA;AAG7B,QAAAokE;AAAA,UAAQ,CAACG,MACPA,EAAS,SAASD,EAAS,QAAQC,EAAS,UAAUD,EAAS,QAC3DC,IACAD;AAAA,QAAA;AAAA,MAER,GAEME,IAAqB,MAAM;AAC/B,QAAMN,EAAkB,WACtB,qBAAqBA,EAAkB,OAAO,GAGhDA,EAAkB,UAAU,sBAAsB,MAAM;AACtD,UAAAA,EAAkB,UAAU,MAC5BG,EAAA;AAAA,QACF,CAAC;AAAA,MACH;AAEA,MAAAG,EAAA;AAEA,YAAMxwD,IAAiB,IAAI,eAAe,MAAM;AAC9C,QAAAwwD,EAAA;AAAA,MACF,CAAC;AACD,aAAAxwD,EAAe,QAAQhU,CAAI,GAEpB,MAAM;AACX,QAAAgU,EAAe,WAAA,GAEXkwD,EAAkB,YAAY,SAChC,qBAAqBA,EAAkB,OAAO,GAC9CA,EAAkB,UAAU;AAAA,MAEhC;AAAA,IACF,GAAG,CAAChB,CAAS,CAAC,qBAGX,OAAA,EAAI,WAAWzjE,EAAGC,GAAI,WAAWH,CAAS,GACzC,UAAA,gBAAAC,EAAC,OAAA,EAAI,WAAWC,EAAGC,GAAI,MAAMA,GAAI,2BAA2ByjE,CAAa,GACtE,UAAA;AAAA,MAAAxe,EAAM;AAAA,QACL,CAACl0B,GAAM3nB,MACL2nB,EAAK,SACH,gBAAAjxB;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,KAAK0jE,MAAcp6D,IAAQm7D,IAAS;AAAA,YACpC,WAAWxkE,EAAGC,GAAI,SAAS+wB,EAAK,WAAW;AAAA,cACzC,CAAC/wB,GAAI,MAAM,GAAGwjE,MAAcp6D;AAAA,YAAA,CAC7B;AAAA,YACD,SAAS,CAAC0rB,MAAM;AACd,cAAAA,EAAE,gBAAA,GACFnI,IAAUvjB,CAAK;AAAA,YACjB;AAAA,YAEC,UAAA;AAAA,cAAA2nB,EAAK,UAAU,gBAAA9wB,EAAC,OAAA,EAAI,WAAWD,GAAI,QAAS,YAAK,OAAA,CAAO;AAAA,cACxD+wB,EAAK;AAAA,cACLqzC,MAAiBh7D,KAChB,gBAAAnJ,EAAC,OAAA,EAAI,WAAWD,GAAI,qBACjB,UAAAqkE,KAAc,OACXA,IAAa,KACX,QACA,OAAOA,CAAU,IACnB,KAAA,CACN;AAAA,YAAA;AAAA,UAAA;AAAA,UAnBGj7D;AAAA,QAAA;AAAA,MAqBP;AAAA,MAGN,gBAAAnJ;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAWF,EAAGC,GAAI,MAAMskE,CAAe;AAAA,UACvC,OAAO;AAAA,YACL,MAAMG,EAAK;AAAA,YACX,OAAOA,EAAK;AAAA,UAAA;AAAA,QACd;AAAA,MAAA;AAAA,IACF,EAAA,CACF,EAAA,CACF;AAAA,EAEJ;AACF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GC/DMM,KAAW,CAAC,EAAE,WAAAllE,EAAA,wBACjB,OAAA,EAAI,SAAQ,aAAY,MAAK,QAAO,QAAO,gBAAe,aAAY,OAAM,eAAc,SAAQ,WAAAA,GAAsB,eAAY,QACnI,UAAA,gBAAAI,EAAC,QAAA,EAAK,GAAE,mBAAA,CAAmB,EAAA,CAC7B;AAGF,SAAS+kE,GAAW;AAAA,EAClB,MAAA9wC;AAAA,EACA,OAAAx0B;AAAA,EACA,aAAAw5D;AAAA,EACA,UAAArqC;AAAA,EACA,SAAA2uB;AACF,GAMG;AACD,QAAM,CAACn+C,GAAOu6C,CAAQ,IAAI5lC,EAAS,EAAE;AAErCrY,EAAAA,GAAM,UAAU,MAAM;AACpB,IAAKu4B,KAAM0lB,EAAS,EAAE;AAAA,EACxB,GAAG,CAAC1lB,CAAI,CAAC;AAET,QAAMpF,IAAS,MAAM;AACnB,UAAMm2C,IAAU5lE,EAAM,KAAA;AACtB,IAAK4lE,MACLp2C,EAASo2C,CAAO,GAChBznB,EAAA;AAAA,EACF;AAEA,SACE,gBAAAv9C,EAAC+7D,IAAA,EAAO,MAAA9nC,GAAY,cAAc,CAACgxC,MAAM,CAACA,KAAK1nB,EAAA,GAC7C,UAAA,gBAAA19C,EAAC08D,IAAA,EAAc,WAAU,kBACvB,UAAA;AAAA,IAAA,gBAAAv8D,EAACq+D,IAAA,EACC,UAAA,gBAAAr+D,EAAC88D,IAAA,EAAa,UAAAr9D,EAAA,CAAM,GACtB;AAAA,IACA,gBAAAI,EAAC,OAAA,EAAI,WAAWE,EAAI,eAClB,UAAA;AAAA,MAAA,gBAAAC;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAS;AAAA,UACT,WAAWD,EAAI;AAAA,UACf,aAAAk5D;AAAA,UACA,OAAA75D;AAAA,UACA,UAAU,CAACy1B,MAAM8kB,EAAS9kB,EAAE,OAAO,KAAK;AAAA,UACxC,WAAW,CAACA,MAAM;AAChB,YAAIA,EAAE,QAAQ,WAAShG,EAAA,GACnBgG,EAAE,QAAQ,YAAU0oB,EAAA;AAAA,UAC1B;AAAA,QAAA;AAAA,MAAA;AAAA,MAEF,gBAAA19C,EAAC,OAAA,EAAI,WAAWE,EAAI,eAClB,UAAA;AAAA,QAAA,gBAAAC,EAAC4S,IAAA,EAAO,SAAQ,aAAY,SAAS2qC,GAAS,UAAA,UAE9C;AAAA,QACA,gBAAAv9C,EAAC4S,IAAA,EAAO,SAAQ,WAAU,SAASic,GAAQ,UAAU,CAACzvB,EAAM,QAAQ,UAAA,WAAA,CAEpE;AAAA,MAAA,EAAA,CACF;AAAA,IAAA,EAAA,CACF;AAAA,EAAA,EAAA,CACF,EAAA,CACF;AAEJ;AAEO,MAAM8lE,KAA8C,CAAC;AAAA,EAC1D,QAAAC;AAAA,EACA,UAAAC,IAAW;AAAA,EACX,OAAA3lE,IAAQ;AAAA,EACR,SAAA4lE,IAAU;AAAA,EACV,WAAAzlE;AAAA,EACA,eAAA0lE;AAAA,EACA,YAAAC;AAAA,EACA,eAAAC;AAAA,EACA,YAAAC;AAAA,EACA,eAAAC;AAAA,EACA,eAAAC;AAAA,EACA,kBAAAC;AACF,MAAM;AACJ,QAAM,CAACC,GAAcC,CAAe,IAAI/xD,EAAS,EAAK,GAChD,CAACgyD,GAAaC,CAAc,IAAIjyD,EAAwB,IAAI;AAElE,2BACG,OAAA,EAAI,WAAWjU,EAAGC,EAAI,MAAMH,CAAS,GACpC,UAAA;AAAA,IAAA,gBAAAI,EAAC,OAAA,EAAI,WAAWD,EAAI,QAClB,4BAAC,OAAA,EAAI,WAAWA,EAAI,YAClB,UAAA;AAAA,MAAA,gBAAAC,EAAC,QAAA,EAAK,WAAWD,EAAI,SAAU,UAAAslE,GAAQ;AAAA,MACvC,gBAAArlE,EAAC,QAAA,EAAK,WAAWD,EAAI,OAAQ,UAAAN,EAAA,CAAM;AAAA,IAAA,EAAA,CACrC,EAAA,CACF;AAAA,IAEA,gBAAAI,EAAC,OAAA,EAAI,WAAWE,EAAI,UACjB,UAAA;AAAA,MAAAolE,EAAO,IAAI,CAACzC,GAAOv5D,MAAU;AAC5B,cAAMzB,IAAOy9D,EAAOh8D,IAAQ,CAAC,GACvB88D,IAAYnmE,EAAGC,EAAI,UAAU;AAAA,UACjC,CAACA,EAAI,kBAAkB,GAAG2iE,EAAM,WAAW,eAAeh7D,GAAM,WAAW;AAAA,UAC3E,CAAC3H,EAAI,kBAAkB,GACrB2iE,EAAM,WAAW,eAAeh7D,GAAM,WAAW;AAAA,QAAA,CACpD;AAED,eACE,gBAAA7H,EAAC,OAAA,EAAmB,WAAWE,EAAI,OACjC,UAAA;AAAA,UAAA,gBAAAF,EAAC,OAAA,EAAI,WAAWE,EAAI,MACjB,UAAA;AAAA,YAAAoJ,IAAQg8D,EAAO,SAAS,KAAK,gBAAAnlE,EAAC,QAAA,EAAK,WAAWimE,GAAW;AAAA,YAC1D,gBAAAjmE;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,WAAWF,EAAGC,EAAI,QAAQ;AAAA,kBACxB,CAACA,EAAI,gBAAgB,GAAG2iE,EAAM,WAAW;AAAA,kBACzC,CAAC3iE,EAAI,cAAc,GAAG2iE,EAAM,WAAW;AAAA,gBAAA,CACxC;AAAA,gBAEA,UAAAA,EAAM,WAAW,eAAe,gBAAA1iE,EAACgkE,IAAA,CAAA,CAAS;AAAA,cAAA;AAAA,YAAA;AAAA,UAC7C,GACF;AAAA,UAEA,gBAAAnkE,EAAC,OAAA,EAAI,WAAWE,EAAI,MAClB,UAAA;AAAA,YAAA,gBAAAF,EAAC,OAAA,EAAI,WAAWE,EAAI,aAClB,UAAA;AAAA,cAAA,gBAAAC;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBACC,WAAWF,EAAGC,EAAI,WAAW;AAAA,oBAC3B,CAACA,EAAI,iBAAiB,GAAG2iE,EAAM,WAAW;AAAA,oBAC1C,CAAC3iE,EAAI,mBAAmB,GAAG2iE,EAAM,WAAW;AAAA,kBAAA,CAC7C;AAAA,kBAEA,UAAAA,EAAM;AAAA,gBAAA;AAAA,cAAA;AAAA,cAER0C,KACC,gBAAAvlE,EAAAu1B,IAAA,EACE,UAAA;AAAA,gBAAA,gBAAAp1B;AAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,MAAK;AAAA,oBACL,WAAWD,EAAI;AAAA,oBACf,SAAS,MAAMimE,EAAetD,EAAM,EAAE;AAAA,oBACtC,cAAW;AAAA,oBACX,OAAM;AAAA,oBAEN,4BAACoC,IAAA,CAAA,CAAS;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAEZ,gBAAA9kE;AAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,MAAK;AAAA,oBACL,WAAWF,EAAGC,EAAI,YAAYA,EAAI,iBAAiB;AAAA,oBACnD,SAAS,MAAMylE,IAAgB9C,EAAM,EAAE;AAAA,oBACvC,cAAW;AAAA,oBACX,OAAM;AAAA,oBAEN,4BAACpK,IAAA,CAAA,CAAU;AAAA,kBAAA;AAAA,gBAAA;AAAA,cACb,EAAA,CACF;AAAA,YAAA,GAEJ;AAAA,YAECoK,EAAM,OAAO,SAAS,KACrB,gBAAA1iE,EAAC,OAAA,EAAI,WAAWD,EAAI,QACjB,UAAA2iE,EAAM,OAAO,IAAI,CAACwD,MACjB,gBAAArmE;AAAA,cAAC;AAAA,cAAA;AAAA,gBAEC,WAAWC,EAAGC,EAAI,OAAO;AAAA,kBACvB,CAACA,EAAI,aAAa,GAAG2iE,EAAM,WAAW;AAAA,gBAAA,CACvC;AAAA,gBAED,UAAA;AAAA,kBAAA,gBAAA7iE,EAAC,OAAA,EAAI,WAAWE,EAAI,aAClB,UAAA;AAAA,oBAAA,gBAAAC,EAAC,QAAA,EAAK,WAAWD,EAAI,WAAY,YAAM,MAAK;AAAA,sCAC3C,OAAA,EAAI,WAAWA,EAAI,cACjB,eACC,gBAAAF,EAAAu1B,IAAA,EACG,UAAA;AAAA,sBAAAkwC,IACC,gBAAAtlE;AAAA,wBAAC2+D;AAAA,wBAAA;AAAA,0BACC,OAAO;AAAA,0BACP,aAAY;AAAA,0BACZ,OAAM;AAAA,0BACN,mBAAkB;AAAA,0BAClB,aAAa2G;AAAA,0BACb,UAAU,CAACa,MACTR,IAAgBjD,EAAM,IAAIwD,EAAM,IAAIC,CAAM;AAAA,0BAE5C,WAAWpmE,EAAI;AAAA,0BACf,gBAAgBA,EAAI;AAAA,0BACpB,sBAAsB,MAAM,gBAAAC,EAAC8kE,IAAA,CAAA,CAAS;AAAA,wBAAA;AAAA,sBAAA,IAEtC;AAAA,sBACJ,gBAAA9kE;AAAA,wBAAC;AAAA,wBAAA;AAAA,0BACC,MAAK;AAAA,0BACL,WAAWF,EAAGC,EAAI,YAAYA,EAAI,iBAAiB;AAAA,0BACnD,SAAS,MAAM2lE,IAAgBhD,EAAM,IAAIwD,EAAM,EAAE;AAAA,0BACjD,cAAW;AAAA,0BACX,OAAM;AAAA,0BAEN,4BAAC5N,IAAA,CAAA,CAAU;AAAA,wBAAA;AAAA,sBAAA;AAAA,oBACb,EAAA,CACF,EAAA,CAEJ;AAAA,kBAAA,GACF;AAAA,kBAEC4N,EAAM,UAAU,WAAW,sBACzB,QAAA,EAAK,WAAWnmE,EAAI,OACnB,UAAA;AAAA,oBAAA,gBAAAC,EAAComE,IAAA,EAAS;AAAA,oBAAE;AAAA,kBAAA,EAAA,CAEd,IAEA,gBAAApmE,EAAC,OAAA,EAAI,WAAWD,EAAI,WACjB,UAAAmmE,EAAM,UAAU,IAAI,CAAChsD,MAAM;AAC1B,0BAAMqE,IAASrE,EAAE,UAAU;AAC3B,2BACE,gBAAAra,EAAC,OAAA,EAAe,WAAWE,EAAI,UAC7B,UAAA;AAAA,sBAAA,gBAAAF,EAAC,OAAA,EAAI,WAAWE,EAAI,cAClB,UAAA;AAAA,wBAAA,gBAAAC;AAAA,0BAAC;AAAA,0BAAA;AAAA,4BACC,WAAWF,EAAGC,EAAI,cAAc;AAAA,8BAC9B,CAACA,EAAI,oBAAoB,GAAGwe,MAAW;AAAA,8BACvC,CAACxe,EAAI,qBAAqB,GAAGwe,MAAW;AAAA,8BACxC,CAACxe,EAAI,qBAAqB,GAAGwe,MAAW;AAAA,4BAAA,CACzC;AAAA,4BAEA,UAAArE,EAAE;AAAA,0BAAA;AAAA,wBAAA;AAAA,wBAEJA,EAAE,WAAWqE,MAAW,aACvB,gBAAAve,EAAC,UAAK,WAAWD,EAAI,cAAe,UAAAma,EAAE,QAAA,CAAQ;AAAA,wBAE/CqE,MAAW,cAAcrE,EAAE,kCACzB,QAAA,EAAK,WAAWna,EAAI,cAAc,UAAA;AAAA,0BAAA;AAAA,0BACvBma,EAAE;AAAA,wBAAA,EAAA,CACd;AAAA,sBAAA,GAEJ;AAAA,sBACCkrD,KACC,gBAAAplE;AAAA,wBAAC;AAAA,wBAAA;AAAA,0BACC,MAAK;AAAA,0BACL,WAAWF,EAAGC,EAAI,YAAYA,EAAI,iBAAiB;AAAA,0BACnD,SAAS,MAAM6lE,IAAmBlD,EAAM,IAAIwD,EAAM,IAAIhsD,EAAE,EAAE;AAAA,0BAC1D,cAAW;AAAA,0BACX,OAAM;AAAA,0BAEN,4BAACo+C,IAAA,CAAA,CAAU;AAAA,wBAAA;AAAA,sBAAA;AAAA,oBACb,EAAA,GA7BMp+C,EAAE,EA+BZ;AAAA,kBAEJ,CAAC,EAAA,CACH;AAAA,gBAAA;AAAA,cAAA;AAAA,cAnFGgsD,EAAM;AAAA,YAAA,CAsFd,GACH;AAAA,YAGDd,KACC,gBAAAvlE;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,MAAK;AAAA,gBACL,WAAWE,EAAI;AAAA,gBACf,SAAS,MAAMimE,EAAetD,EAAM,EAAE;AAAA,gBAEtC,UAAA;AAAA,kBAAA,gBAAA1iE,EAAC8kE,IAAA,EAAS;AAAA,kBAAE;AAAA,gBAAA;AAAA,cAAA;AAAA,YAAA;AAAA,UACd,EAAA,CAEJ;AAAA,QAAA,EAAA,GAtJQpC,EAAM,EAuJhB;AAAA,MAEJ,CAAC;AAAA,MAEA0C,KACC,gBAAAvlE,EAAC,OAAA,EAAI,WAAWE,EAAI,OAClB,UAAA;AAAA,QAAA,gBAAAC,EAAC,OAAA,EAAI,WAAWD,EAAI,MAClB,UAAA,gBAAAC,EAAC,QAAA,EAAK,WAAWF,EAAGC,EAAI,MAAM,GAAG,eAAW,IAAC,GAC/C;AAAA,QACA,gBAAAC,EAAC,OAAA,EAAI,WAAWD,EAAI,MAClB,UAAA,gBAAAF;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,MAAK;AAAA,YACL,WAAWC,EAAGC,EAAI,UAAUA,EAAI,QAAQ;AAAA,YACxC,SAAS,MAAM+lE,EAAgB,EAAI;AAAA,YAEnC,UAAA;AAAA,cAAA,gBAAA9lE,EAAC8kE,IAAA,EAAS;AAAA,cAAE;AAAA,YAAA;AAAA,UAAA;AAAA,QAAA,EACd,CACF;AAAA,MAAA,EAAA,CACF;AAAA,IAAA,GAEJ;AAAA,IAEA,gBAAA9kE;AAAA,MAAC+kE;AAAA,MAAA;AAAA,QACC,MAAMc;AAAA,QACN,OAAM;AAAA,QACN,aAAY;AAAA,QACZ,SAAS,MAAMC,EAAgB,EAAK;AAAA,QACpC,UAAU,CAAC7+C,MAASs+C,IAAat+C,CAAI;AAAA,MAAA;AAAA,IAAA;AAAA,IAGvC,gBAAAjnB;AAAA,MAAC+kE;AAAA,MAAA;AAAA,QACC,MAAMgB,MAAgB;AAAA,QACtB,OAAM;AAAA,QACN,aAAY;AAAA,QACZ,SAAS,MAAMC,EAAe,IAAI;AAAA,QAClC,UAAU,CAAC/+C,MAAS8+C,KAAeN,IAAaM,GAAa9+C,CAAI;AAAA,MAAA;AAAA,IAAA;AAAA,EACnE,GACF;AAEJ;","x_google_ignoreList":[51,53,54,55,56,57,65,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]}
|