@aori/mega-swap-widget 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/LICENSE +5 -12
- package/README.md +9 -1
- package/dist/AssetSelectionMenu-4E576X3D.cjs +2 -0
- package/dist/AssetSelectionMenu-ZFY7XFRX.js +2 -0
- package/dist/ChainSelectionMenu-SKXLHK3S.js +2 -0
- package/dist/ChainSelectionMenu-VU3SIBVL.cjs +2 -0
- package/dist/SwapFormHorizontal-GI4X7ISS.js +2 -0
- package/dist/SwapFormHorizontal-V557YBX2.cjs +2 -0
- package/dist/SwapFormSplit-52RBMJIO.js +2 -0
- package/dist/SwapFormSplit-PQCS3BPT.cjs +2 -0
- package/dist/WalletPlaceholderPanel-TTONBBI4.cjs +2 -0
- package/dist/WalletPlaceholderPanel-Z4JCFCNV.js +2 -0
- package/dist/WidgetWalletPanel-XYV3YL4I.js +2 -0
- package/dist/WidgetWalletPanel-YBMN5KZH.cjs +2 -0
- package/dist/chunk-34N36GUD.cjs +2 -0
- package/dist/chunk-46H44R7V.js +2 -0
- package/dist/chunk-4BQRVCQR.js +2 -0
- package/dist/chunk-4LJJMEOG.js +2 -0
- package/dist/chunk-726CI6GC.js +2 -0
- package/dist/chunk-73CB2I7U.js +2 -0
- package/dist/chunk-DUIRZSBV.cjs +2 -0
- package/dist/chunk-EW2OR6CJ.js +27 -0
- package/dist/chunk-FDQKBTWP.js +2 -0
- package/dist/chunk-HTWUZKYO.cjs +2 -0
- package/dist/chunk-KH57FLST.cjs +57 -0
- package/dist/chunk-LXEKOQAG.cjs +27 -0
- package/dist/chunk-MCT3UZTP.cjs +2 -0
- package/dist/chunk-OPN7WCJR.js +57 -0
- package/dist/chunk-T3I3AJXV.cjs +2 -0
- package/dist/chunk-UZWGYG2S.cjs +2 -0
- package/dist/chunk-XYF2YBR3.js +2 -0
- package/dist/chunk-XZRXVBSB.cjs +2 -0
- package/dist/index.cjs +2 -1772
- package/dist/index.css +1 -1423
- package/dist/index.js +2 -1772
- package/package.json +2 -22
- package/dist/AssetSelectionMenu-Y3EB32BT.cjs +0 -13
- package/dist/AssetSelectionMenu-Y3EB32BT.cjs.map +0 -1
- package/dist/AssetSelectionMenu-ZRG42UCZ.js +0 -13
- package/dist/AssetSelectionMenu-ZRG42UCZ.js.map +0 -1
- package/dist/ChainSelectionMenu-FBAPPFKI.cjs +0 -11
- package/dist/ChainSelectionMenu-FBAPPFKI.cjs.map +0 -1
- package/dist/ChainSelectionMenu-QO3H4TNR.js +0 -11
- package/dist/ChainSelectionMenu-QO3H4TNR.js.map +0 -1
- package/dist/SwapFormHorizontal-JDJUDFNX.js +0 -573
- package/dist/SwapFormHorizontal-JDJUDFNX.js.map +0 -1
- package/dist/SwapFormHorizontal-WG3Z3CFT.cjs +0 -573
- package/dist/SwapFormHorizontal-WG3Z3CFT.cjs.map +0 -1
- package/dist/SwapFormSplit-7CHTPLEQ.js +0 -441
- package/dist/SwapFormSplit-7CHTPLEQ.js.map +0 -1
- package/dist/SwapFormSplit-VDDIRQUQ.cjs +0 -441
- package/dist/SwapFormSplit-VDDIRQUQ.cjs.map +0 -1
- package/dist/WalletPlaceholderPanel-7YDQ4FT6.js +0 -57
- package/dist/WalletPlaceholderPanel-7YDQ4FT6.js.map +0 -1
- package/dist/WalletPlaceholderPanel-FZ6XIAMF.cjs +0 -57
- package/dist/WalletPlaceholderPanel-FZ6XIAMF.cjs.map +0 -1
- package/dist/WidgetWalletPanel-D7I5TAU3.js +0 -789
- package/dist/WidgetWalletPanel-D7I5TAU3.js.map +0 -1
- package/dist/WidgetWalletPanel-T7H6FGVN.cjs +0 -789
- package/dist/WidgetWalletPanel-T7H6FGVN.cjs.map +0 -1
- package/dist/chunk-3E6RNP2D.cjs +0 -389
- package/dist/chunk-3E6RNP2D.cjs.map +0 -1
- package/dist/chunk-5TH6MFQD.cjs +0 -122
- package/dist/chunk-5TH6MFQD.cjs.map +0 -1
- package/dist/chunk-5XSCUUOW.js +0 -101
- package/dist/chunk-5XSCUUOW.js.map +0 -1
- package/dist/chunk-6Q7MSCKS.js +0 -2199
- package/dist/chunk-6Q7MSCKS.js.map +0 -1
- package/dist/chunk-6XB5R4GF.cjs +0 -368
- package/dist/chunk-6XB5R4GF.cjs.map +0 -1
- package/dist/chunk-6YLNOZ7P.js +0 -389
- package/dist/chunk-6YLNOZ7P.js.map +0 -1
- package/dist/chunk-7AWG6OWF.js +0 -27
- package/dist/chunk-7AWG6OWF.js.map +0 -1
- package/dist/chunk-ARMW5POL.js +0 -3082
- package/dist/chunk-ARMW5POL.js.map +0 -1
- package/dist/chunk-B3ILUJ7G.cjs +0 -101
- package/dist/chunk-B3ILUJ7G.cjs.map +0 -1
- package/dist/chunk-GGM3MDFM.js +0 -32
- package/dist/chunk-GGM3MDFM.js.map +0 -1
- package/dist/chunk-GZUTUD5O.cjs +0 -2199
- package/dist/chunk-GZUTUD5O.cjs.map +0 -1
- package/dist/chunk-HXOGJSAI.cjs +0 -3082
- package/dist/chunk-HXOGJSAI.cjs.map +0 -1
- package/dist/chunk-LTA7IG3J.js +0 -122
- package/dist/chunk-LTA7IG3J.js.map +0 -1
- package/dist/chunk-NBJPKJBC.cjs +0 -32
- package/dist/chunk-NBJPKJBC.cjs.map +0 -1
- package/dist/chunk-PGYOJ5RB.cjs +0 -27
- package/dist/chunk-PGYOJ5RB.cjs.map +0 -1
- package/dist/chunk-QHW27RMH.js +0 -199
- package/dist/chunk-QHW27RMH.js.map +0 -1
- package/dist/chunk-TMC4SUEV.js +0 -368
- package/dist/chunk-TMC4SUEV.js.map +0 -1
- package/dist/chunk-XQINW7QP.cjs +0 -199
- package/dist/chunk-XQINW7QP.cjs.map +0 -1
- package/dist/index.cjs.map +0 -1
- package/dist/index.css.map +0 -1
- package/dist/index.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/flooreyes/mega-swap-widget/dist/chunk-XQINW7QP.cjs","../src/components/QuoteLoader.tsx"],"names":[],"mappings":"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","file":"/Users/flooreyes/mega-swap-widget/dist/chunk-XQINW7QP.cjs","sourcesContent":[null,"'use client';\n\nimport { ThreeDots, TokenImage } from '../internal';\nimport React, { useEffect, useState } from 'react';\nimport { useWidgetConfig } from '../context/WidgetConfigContext';\nimport { useRfq } from '../providers/RfqProvider';\nimport { useSwapFormContext } from '../providers/SwapFormProvider';\n\nfunction formatRate(rate: number): string {\n if (rate === 0) return '0';\n const abs = Math.abs(rate);\n if (abs >= 10000) return rate.toFixed(0);\n if (abs >= 1000) return rate.toFixed(1);\n if (abs >= 100) return rate.toFixed(2);\n if (abs >= 1) return rate.toFixed(4);\n if (abs >= 0.01) return rate.toFixed(6);\n return rate.toExponential(3);\n}\n\nconst QuoteLoader = React.memo(() => {\n const [isOpen, setIsOpen] = useState(false);\n const { liquidityError, routingError } = useRfq();\n const {\n baseAmount,\n baseToken: base,\n quoteAmount,\n quoteToken: quote,\n } = useSwapFormContext();\n const { quoteLoaderVariant, widgetType } = useWidgetConfig();\n const isCompact = widgetType === 'compact';\n\n // Derive inline so it resets to 0 the moment quoteAmount is cleared —\n // prevents a one-frame flash of the stale rate after clear() or cancel().\n const exchangeRate =\n baseAmount && quoteAmount && parseFloat(quoteAmount.toString())\n ? parseFloat(baseAmount.toString()) / parseFloat(quoteAmount.toString())\n : 0;\n\n const hasQuoteError = liquidityError || routingError;\n const hasValidQuote =\n base &&\n quote &&\n baseAmount &&\n parseFloat(baseAmount.toString()) &&\n quoteAmount;\n\n // Auto-open expanded panel when a valid quote arrives\n useEffect(() => {\n if (quoteLoaderVariant === 'expanded' && hasValidQuote) {\n setIsOpen(true);\n }\n }, [quoteLoaderVariant, hasValidQuote]);\n\n // ── none variant ──────────────────────────────────────────────────────────\n if (quoteLoaderVariant === 'none') return null;\n\n // ── default (rate) variant ────────────────────────────────────────────────\n if (quoteLoaderVariant === 'default') {\n return (\n <div className={`relative box-border flex flex-row pt-1 h-8 w-full items-center${isCompact ? ' justify-start overflow-x-auto' : ' justify-center'}`}>\n <div\n className={`flex h-full items-center${isCompact ? ' min-w-max' : ' w-full overflow-hidden'}`}\n style={{ color: 'var(--widget-foreground)' }}\n >\n {base && quote ? (\n baseAmount && parseFloat(baseAmount.toString()) ? (\n quoteAmount ? (\n <div className=\"translate-y-px font-mono flex flex-row items-center gap-2 whitespace-nowrap\">\n <div className=\"flex flex-row items-center gap-1\">\n <TokenImage asset={quote} size=\"3xs\" noChain className=\"mb-0.5\" />\n <span className=\"text-xs uppercase\">1 {quote?.symbol}</span>\n </div>\n <span className=\"text-xs\" style={{ color: 'var(--widget-muted-foreground)' }}>=</span>\n <div className=\"flex flex-row items-center gap-1\">\n <TokenImage asset={base} size=\"3xs\" noChain className=\"mb-0.5\" />\n <span className=\"text-xs uppercase\">{formatRate(exchangeRate)} {base?.symbol}</span>\n </div>\n <span className=\"text-xs\" style={{ color: 'var(--widget-muted-foreground)' }}>\n {base?.price ? `≈ $${(base.price * exchangeRate).toFixed(2)}` : ''}\n </span>\n </div>\n ) : hasQuoteError ? (\n <div className=\"flex h-full w-full flex-row pb-1 items-center justify-between\">\n <p className=\"text-xs\" style={{ color: 'var(--widget-destructive)' }}>\n Quote not found\n </p>\n <ThreeDots className=\"h-8 w-8\" style={{ color: 'var(--widget-destructive)' }} />\n </div>\n ) : (\n <div className=\"flex h-full w-full flex-row pb-1 items-center justify-between\">\n <p className=\"text-xs\" style={{ color: 'var(--widget-accent)' }}>\n Searching For Quote\n </p>\n <ThreeDots className=\"h-8 w-8\" style={{ color: 'var(--widget-accent)' }} />\n </div>\n )\n ) : (\n <div className=\"text-xs pb-1\" style={{ color: 'var(--widget-foreground)', opacity: 0.4 }}>\n Enter Amount\n </div>\n )\n ) : (\n <div className=\"text-xs pb-1\" style={{ color: 'var(--widget-foreground)', opacity: 0.4 }}>\n Enter Amount\n </div>\n )}\n </div>\n </div>\n );\n }\n\n // ── expanded variant ──────────────────────────────────────────────────────\n return (\n <div className=\"flex flex-col w-full\">\n {/* Rate row — same as default, but clickable to expand */}\n <div\n className={`relative box-border flex flex-row pt-1 h-8 w-full items-center cursor-pointer${isCompact ? ' overflow-x-auto' : ''}`}\n role=\"button\"\n tabIndex={0}\n onClick={() => hasValidQuote && setIsOpen((v) => !v)}\n onKeyDown={(e) => { if (e.key === 'Enter' || e.key === ' ') { e.preventDefault(); hasValidQuote && setIsOpen((v) => !v); } }}\n >\n <div\n className={`flex h-full items-center${isCompact ? ' min-w-max overflow-x-auto' : ' w-full overflow-hidden'}`}\n style={{ color: 'var(--widget-foreground)' }}\n >\n {base && quote ? (\n baseAmount && parseFloat(baseAmount.toString()) ? (\n quoteAmount ? (\n <div className=\"translate-y-px font-mono flex w-full flex-row items-center justify-between\">\n <div className=\"flex flex-row items-center gap-2 whitespace-nowrap\">\n <div className=\"flex flex-row items-center gap-1\">\n <TokenImage asset={quote} size=\"3xs\" noChain className=\"mb-0.5\" />\n <span className=\"text-xs uppercase\">1 {quote?.symbol}</span>\n </div>\n <span className=\"text-xs\" style={{ color: 'var(--widget-muted-foreground)' }}>=</span>\n <div className=\"flex flex-row items-center gap-1\">\n <TokenImage asset={base} size=\"3xs\" noChain className=\"mb-0.5\" />\n <span className=\"text-xs uppercase\">{formatRate(exchangeRate)} {base?.symbol}</span>\n </div>\n <span className=\"text-xs\" style={{ color: 'var(--widget-muted-foreground)' }}>\n {base?.price ? `≈ $${(base.price * exchangeRate).toFixed(2)}` : ''}\n </span>\n </div>\n <span\n className=\"text-xs ml-2 transition-transform duration-200 shrink-0\"\n style={{\n color: 'var(--widget-muted-foreground)',\n transform: isOpen ? 'rotate(180deg)' : 'rotate(0deg)',\n display: 'inline-block',\n }}\n >\n ▾\n </span>\n </div>\n ) : hasQuoteError ? (\n <div className=\"flex h-full w-full flex-row pb-1 items-center justify-between\">\n <p className=\"text-xs\" style={{ color: 'var(--widget-destructive)' }}>\n Quote not found\n </p>\n <ThreeDots className=\"h-8 w-8\" style={{ color: 'var(--widget-destructive)' }} />\n </div>\n ) : (\n <div className=\"flex h-full w-full flex-row pb-1 items-center justify-between\">\n <p className=\"text-xs\" style={{ color: 'var(--widget-accent)' }}>\n Searching For Quote\n </p>\n <ThreeDots className=\"h-8 w-8\" style={{ color: 'var(--widget-accent)' }} />\n </div>\n )\n ) : (\n <div className=\"text-xs pb-1\" style={{ color: 'var(--widget-foreground)', opacity: 0.4 }}>\n Enter Amount\n </div>\n )\n ) : (\n <div className=\"text-xs pb-1\" style={{ color: 'var(--widget-foreground)', opacity: 0.4 }}>\n Enter Amount\n </div>\n )}\n </div>\n </div>\n\n {/* Expanded detail rows */}\n <div\n className=\"overflow-hidden transition-all duration-200\"\n style={{\n maxHeight: isOpen && hasValidQuote ? '80px' : '0px',\n opacity: isOpen && hasValidQuote ? 1 : 0,\n }}\n >\n <div className=\"flex flex-col gap-0.5 pb-1 font-mono\">\n <div\n className=\"flex justify-between text-2xs\"\n style={{ color: 'var(--widget-muted-foreground)' }}\n >\n <span>USD Value</span>\n <span>\n $\n {base?.price && quoteAmount\n ? (\n base.price *\n exchangeRate *\n parseFloat(quoteAmount.toString())\n ).toFixed(2)\n : '—'}\n </span>\n </div>\n <div\n className=\"flex justify-between text-2xs\"\n style={{ color: 'var(--widget-muted-foreground)' }}\n >\n <span>Rate</span>\n <span className=\"uppercase\">\n {exchangeRate > 0\n ? `${formatRate(exchangeRate)} ${base?.symbol ?? ''}`\n : '—'}\n </span>\n </div>\n <div\n className=\"flex justify-between text-2xs\"\n style={{ color: 'var(--widget-muted-foreground)' }}\n >\n <span>Order Type</span>\n <span>RFQ (Exact Fill)</span>\n </div>\n </div>\n </div>\n </div>\n );\n});\n\nQuoteLoader.displayName = 'QuoteLoader';\nexport default QuoteLoader;\n"]}
|
package/dist/index.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/flooreyes/mega-swap-widget/dist/index.cjs","../src/SwapWidget.tsx","../src/components/SwapContainer.tsx","../src/components/SwapForm.tsx","../src/components/SwapFormSkeleton.tsx","../src/components/SwapHeader.tsx","../src/theme/ThemeContext.tsx","../src/theme/types.ts","../src/wallet/ConnectButton.tsx","../src/wallet/shared/transports.ts","../src/hooks/useTokenHelpers.ts"],"names":["jsxs","jsx","useCallback","useMemo"],"mappings":"AAAA,2jCAAY;AACZ;AACE;AACF,wDAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,wDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACF,wDAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B,gCAA6B;AAC7B;AACA;ACrDA,4EAA+C;ADuD/C;AACA;AExDA;AACA,gDAA2B;AF0D3B;AACA;AG3DA;AAEA;AAkNU,+CAAA;AAxLV,IAAM,SAAA,EAAoC,CAAC,EAAE,cAAA,EAAgB,gBAAgB,CAAA,EAAA,GAAM;AACjF,EAAA,MAAM;AAAA,IACJ,kBAAA;AAAA,IACA,iBAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,gBAAA;AAAA,IACA,YAAA;AAAA,IACA,qBAAA;AAAA,IACA;AAAA,EACF,EAAA,EAAI,+CAAA,CAAgB;AACpB,EAAA,MAAM,eAAA,EAAiB,aAAA,IAAiB,OAAA,GAAU,aAAA,IAAiB,OAAA;AACnE,EAAA,MAAM,cAAA,EAAgB,WAAA,IAAe,SAAA;AACrC,EAAA,MAAM,YAAA,EAAc,cAAA,EAAgB,iBAAA,EAAmB,gBAAA;AACvD,EAAA,MAAM,aAAA,EAAe,cAAA,EAAgB,iBAAA,EAAmB,gBAAA;AACxD,EAAA,MAAM;AAAA,IACJ,SAAA;AAAA,IACA,UAAA;AAAA,IACA,UAAA;AAAA,IACA,WAAA;AAAA,IACA,cAAA;AAAA,IACA,eAAA;AAAA,IACA,cAAA;AAAA,IACA,gBAAA;AAAA,IACA,WAAA;AAAA,IACA,YAAA;AAAA,IACA,aAAA;AAAA,IACA,cAAA;AAAA,IACA,UAAA;AAAA,IACA;AAAA,EACF,EAAA,EAAI,kDAAA,CAAmB;AAEvB,EAAA,MAAM;AAAA,IACJ,QAAA;AAAA,IACA,MAAA,EAAQ,SAAA;AAAA,IACR,iBAAA;AAAA,IACA,eAAA;AAAA,IACA,IAAA;AAAA,IACA,KAAA;AAAA,IACA;AAAA,EACF,EAAA,EAAI,sCAAA,CAAO;AACX,EAAA,MAAM,EAAE,OAAA,EAAS,YAAY,EAAA,EAAI,8CAAA,CAAe;AAChD,EAAA,MAAM,EAAE,gBAAA,EAAkB,gBAAgB,EAAA,EAAI,8CAAA,CAAe;AAC7D,EAAA,MAAM,EAAE,oBAAA,EAAsB,SAAS,EAAA,EACrC,oDAAA;AAAA,IACE,iCAAA,CAAY,KAAA,EAAA,GAAA,CAAW;AAAA,MACrB,oBAAA,EAAsB,KAAA,CAAM,oBAAA;AAAA,MAC5B,QAAA,EAAU,KAAA,CAAM;AAAA,IAClB,CAAA,CAAE;AAAA,EACJ,CAAA;AAEF,EAAA,MAAM,CAAC,WAAA,EAAa,cAAc,EAAA,EAAI,6BAAA,IAAqC,CAAA;AAC3E,EAAA,MAAM,CAAC,gBAAA,EAAkB,mBAAmB,EAAA,EAAI,6BAAA,IAA4B,CAAA;AAC5E,EAAA,MAAM,uBAAA,EAAyB,2BAAA,KAAY,CAAA;AAC3C,EAAA,MAAM,eAAA,EAAiB,KAAA;AAEvB,EAAA,MAAM,kBAAA,EAAoB,4BAAA,CAAQ,EAAA,GAAgC;AAChE,IAAA,GAAA,CAAI,CAAC,UAAA,GAAa,CAAC,WAAA,GAAc,OAAO,WAAA,IAAe,SAAA,GAAY,CAAC,YAAA,GAAe,CAAC,WAAA,EAAa,OAAO,IAAA;AACxG,IAAA,GAAA,CAAI,UAAA,CAAW,WAAA,CAAY,SAAS,EAAA,EAAI,UAAA,EAAY,OAAO,IAAA;AAC3D,IAAA,OAAO,EAAE,IAAA,EAAM,SAAA,EAAW,KAAA,EAAO,UAAA,EAAY,UAAA,EAAY,WAAA,EAAa,YAAY,CAAA;AAAA,EACpF,CAAA,EAAG,CAAC,SAAA,EAAW,UAAA,EAAY,UAAA,EAAY,WAAA,EAAa,WAAA,EAAa,WAAA,CAAY,SAAS,CAAC,CAAA;AAGvF,EAAA,MAAM,iBAAA,EAAmB,gCAAA,CAAa,SAAA,EAAA,GAAsB;AAC1D,IAAA,mBAAA,CAAoB,SAAS,CAAA;AAC7B,IAAA,sCAAA,CAAqB,QAAA,CAAS,CAAA,CAAE,aAAA,CAAc,SAAS,CAAA;AAAA,EACzD,CAAA,EAAG,CAAC,CAAC,CAAA;AAIL,EAAA,MAAM,oBAAA,EAAsB,gCAAA,CAAY,EAAA,GAAM;AAC5C,IAAA,sBAAA,CAAuB,QAAA,EAAU,IAAA;AACjC,IAAA,OAAA,CAAQ,CAAA;AAAA,EACV,CAAA,EAAG,CAAC,OAAO,CAAC,CAAA;AAEZ,EAAA,8BAAA,CAAU,EAAA,GAAM;AACd,IAAA,GAAA,CAAI,YAAA,IAAgB,IAAA,EAAM,MAAA;AAC1B,IAAA,GAAA,CAAI,CAAC,UAAA,GAAa,CAAC,UAAA,EAAY,MAAA;AAC/B,IAAA,GAAA,CAAI,CAAC,WAAA,GAAc,WAAA,GAAc,CAAA,EAAG;AAClC,MAAA,iBAAA,CAAkB,EAAE,MAAA,EAAQ,IAAA,EAAM,UAAA,EAAY,SAAA,EAAW,WAAA,EAAa,UAAA,EAAY,eAAA,EAAiB,eAAe,CAAC,CAAA;AACnH,MAAA,MAAA;AAAA,IACF;AACA,IAAA,GAAA,CAAI,eAAA,GAAkB,gBAAA,EAAkB;AACtC,MAAA,cAAA,CAAe,UAAU,CAAA;AACzB,MAAA,MAAA;AAAA,IACF;AACA,IAAA,iBAAA,CAAkB;AAAA,MAChB,MAAA,EAAQ,UAAA;AAAA,MACR,UAAA,EAAY,SAAA;AAAA,MACZ,WAAA,EAAa,UAAA;AAAA,MACb,eAAA,EAAiB;AAAA,IACnB,CAAC,CAAA;AAAA,EACH,CAAA,EAAG;AAAA,IACD,WAAA;AAAA,IACA,UAAA;AAAA,IACA,SAAA;AAAA,IACA,UAAA;AAAA,IACA,cAAA;AAAA,IACA,gBAAA;AAAA,IACA,iBAAA;AAAA,IACA;AAAA,EACF,CAAC,CAAA;AAED,EAAA,MAAM,0BAAA,EAA4B,gCAAA,CAAY,EAAA,GAAM;AAClD,IAAA,sCAAA,CAAqB,QAAA,CAAS,CAAA,CAAE,OAAA,CAAQ,eAAe,CAAA;AAAA,EACzD,CAAA,EAAG,CAAC,CAAC,CAAA;AAEL,EAAA,MAAM,2BAAA,EAA6B,gCAAA,CAAY,EAAA,GAAM;AACnD,IAAA,sCAAA,CAAqB,QAAA,CAAS,CAAA,CAAE,OAAA,CAAQ,gBAAgB,CAAA;AAAA,EAC1D,CAAA,EAAG,CAAC,CAAC,CAAA;AAEL,EAAA,MAAM,aAAA,EAAe,gCAAA,CAAY,EAAA,GAAM;AACrC,IAAA,UAAA,CAAW,CAAA;AACX,IAAA,cAAA,CAAe,IAAI,CAAA;AAAA,EACrB,CAAA,EAAG,CAAC,UAAA,EAAY,cAAc,CAAC,CAAA;AAE/B,EAAA,MAAM,UAAA,EAAY,gCAAA,CAAY,EAAA,GAAM;AAClC,IAAA,GAAA,CAAI,CAAC,WAAA,CAAY,UAAA,GAAa,CAAC,UAAA,GAAa,CAAC,UAAA,EAAY,MAAA;AACzD,IAAA,MAAM,OAAA,EAAS,UAAA,CAAW,WAAA,CAAY,SAAS,CAAA;AAC/C,IAAA,GAAA,CAAI,CAAC,OAAA,GAAU,OAAA,GAAU,CAAA,EAAG,MAAA;AAC5B,IAAA,MAAM,SAAA,EAAW,OAAA,EAAS,YAAA;AAC1B,IAAA,GAAA,CAAI,eAAA,GAAkB,gBAAA,EAAkB;AACtC,MAAA,aAAA,CAAc,QAAQ,CAAA;AACtB,MAAA,cAAA,CAAe,QAAQ,CAAA;AACvB,MAAA,KAAA,CAAM,CAAA;AAAA,IACR,EAAA,KAAO;AACL,MAAA,aAAA,CAAc,QAAQ,CAAA;AACtB,MAAA,cAAA,CAAe,IAAI,CAAA;AACnB,MAAA,eAAA,CAAgB;AAAA,QACd,UAAA,EAAY,SAAA;AAAA,QACZ,WAAA,EAAa,UAAA;AAAA,QACb,WAAA,EAAa,QAAA,CAAS,QAAA,CAAS,CAAA;AAAA,QAC/B,eAAA,EAAiB,CAAC,MAAA,EAAA,GAAW,cAAA,CAAe,MAAM;AAAA,MACpD,CAAC,CAAA;AAAA,IACH;AAAA,EACF,CAAA,EAAG;AAAA,IACD,WAAA,CAAY,SAAA;AAAA,IACZ,SAAA;AAAA,IACA,UAAA;AAAA,IACA,cAAA;AAAA,IACA,gBAAA;AAAA,IACA,aAAA;AAAA,IACA,cAAA;AAAA,IACA,KAAA;AAAA,IACA;AAAA,EACF,CAAC,CAAA;AAED,EAAA,MAAM,YAAA,EAAc,gCAAA,CAAY,EAAA,GAAM;AACpC,IAAA,KAAA,CAAM,CAAA;AACN,IAAA,SAAA,CAAU,CAAA;AAAA,EACZ,CAAA,EAAG,CAAC,KAAA,EAAO,SAAS,CAAC,CAAA;AAErB,EAAA,MAAM,eAAA,EAAiB,WAAA,CAAY,UAAA,EAC/B,UAAA,CAAW,WAAA,CAAY,SAAS,EAAA,EAChC,IAAA;AACJ,EAAA,MAAM,UAAA,EAAY,CAAC,CAAA,CAAE,WAAA,GAAc,WAAA,CAAA;AAEnC,EAAA,MAAM,QAAA,kBACJ,SAAA,2BAAW,QAAA,GAAS,WAAA,EAChB,CAAA,CAAA,EAAA,CAAK,SAAA,CAAU,MAAA,EAAQ,UAAA,CAAA,CAAY,OAAA,CAAQ,CAAC,CAAC,CAAA,EAAA;AAIR,EAAA;AAOzC,EAAA;AAMG,EAAA;AAKD,IAAA;AAAA;AAGI,sBAAA;AAAC,QAAA;AAAA,QAAA;AACY,UAAA;AACL,UAAA;AACC,UAAA;AACP,UAAA;AACA,UAAA;AACQ,UAAA;AAAA,QAAA;AAEZ,MAAA;AAIE,IAAA;AAAA,sBAAA;AAAC,QAAA;AAAA,QAAA;AACmC,UAAA;AACsB,UAAA;AAEvD,UAAA;AACC,YAAA;AAAA;AAEE,8BAAA;AAAC,gBAAA;AAAA,gBAAA;AACgF,kBAAA;AAE/E,kBAAA;AAAA,oCAAA;AAAC,sBAAA;AAAA,sBAAA;AACS,wBAAA;AACH,wBAAA;AACE,wBAAA;AAC2B,wBAAA;AAAA,sBAAA;AACpC,oBAAA;AAEE,oCAAA;AAAC,sBAAA;AAAA,sBAAA;AACM,wBAAA;AACe,wBAAA;AACM,wBAAA;AAC1B,wBAAA;AACA,wBAAA;AACA,wBAAA;AAAA,sBAAA;AAEJ,oBAAA;AAAA,kBAAA;AAAA,gBAAA;AACF,cAAA;AAAA,YAAA;AAAA;AAGA,8BAAA;AAAC,gBAAA;AAAA,gBAAA;AAC+E,kBAAA;AAE9E,kBAAA;AAAA,oCAAA;AAAC,sBAAA;AAAA,sBAAA;AACS,wBAAA;AACH,wBAAA;AACE,wBAAA;AAC2B,wBAAA;AAAA,sBAAA;AACpC,oBAAA;AACA,oCAAA;AAAC,sBAAA;AAAA,sBAAA;AACM,wBAAA;AACe,wBAAA;AACM,wBAAA;AAC1B,wBAAA;AACA,wBAAA;AACA,wBAAA;AAAA,sBAAA;AACF,oBAAA;AAAA,kBAAA;AAAA,gBAAA;AACF,cAAA;AAIA,YAAA;AAAA,8BAAA;AAAC,gBAAA;AAAA,gBAAA;AACS,kBAAA;AACH,kBAAA;AACE,kBAAA;AAC2B,kBAAA;AAAA,gBAAA;AACpC,cAAA;AACA,8BAAA;AAAC,gBAAA;AAAA,gBAAA;AACM,kBAAA;AACe,kBAAA;AACM,kBAAA;AAC1B,kBAAA;AACA,kBAAA;AACA,kBAAA;AAAA,gBAAA;AACF,cAAA;AACF,YAAA;AAIa,4BAAA;AACb,8BAAA;AAAC,gBAAA;AAAA,gBAAA;AACW,kBAAA;AACuC,kBAAA;AAEhD,kBAAA;AAAA,gBAAA;AACH,cAAA;AAEE,cAAA;AAAC,gBAAA;AAAA,gBAAA;AACM,kBAAA;AACI,kBAAA;AACC,kBAAA;AACA,kBAAA;AACoC,kBAAA;AAC/C,kBAAA;AAAA,gBAAA;AAED,cAAA;AAEJ,YAAA;AAAA,UAAA;AAAA,QAAA;AACF,MAAA;AAIiB,MAAA;AACZ,QAAA;AAAA,QAAA;AACM,UAAA;AACI,UAAA;AACE,UAAA;AACD,UAAA;AACwC,UAAA;AAElD,UAAA;AAA4B,4BAAA;AACA,4BAAA;AAAA,UAAA;AAAA,QAAA;AAEhC,MAAA;AAKC,sBAAA;AAEG,QAAA;AAAC,UAAA;AAAA,UAAA;AAC2E,YAAA;AAE1E,YAAA;AAAA,8BAAA;AAAC,gBAAA;AAAA,gBAAA;AACS,kBAAA;AACH,kBAAA;AACE,kBAAA;AAC2B,kBAAA;AAAA,gBAAA;AACpC,cAAA;AAEE,8BAAA;AAAC,gBAAA;AAAA,gBAAA;AACM,kBAAA;AACgB,kBAAA;AACI,kBAAA;AACzB,kBAAA;AACA,kBAAA;AACA,kBAAA;AAAA,gBAAA;AAEJ,cAAA;AAAA,YAAA;AAAA,UAAA;AAGF,QAAA;AAAC,UAAA;AAAA,UAAA;AAC+E,YAAA;AAE9E,YAAA;AAAA,8BAAA;AAAC,gBAAA;AAAA,gBAAA;AACS,kBAAA;AACH,kBAAA;AACE,kBAAA;AAC2B,kBAAA;AAAA,gBAAA;AACpC,cAAA;AACA,8BAAA;AAAC,gBAAA;AAAA,gBAAA;AACM,kBAAA;AACgB,kBAAA;AACI,kBAAA;AACzB,kBAAA;AACA,kBAAA;AACA,kBAAA;AAAA,gBAAA;AACF,cAAA;AAAA,YAAA;AAAA,UAAA;AAKF,QAAA;AAAA,0BAAA;AAAC,YAAA;AAAA,YAAA;AACS,cAAA;AACH,cAAA;AACE,cAAA;AAC2B,cAAA;AAAA,YAAA;AACpC,UAAA;AACA,0BAAA;AAAC,YAAA;AAAA,YAAA;AACM,cAAA;AACgB,cAAA;AACI,cAAA;AACzB,cAAA;AACA,cAAA;AACA,cAAA;AAAA,YAAA;AACF,UAAA;AACF,QAAA;AAIa,wBAAA;AACb,0BAAA;AAAC,YAAA;AAAA,YAAA;AACW,cAAA;AACuC,cAAA;AAEhD,cAAA;AAAA,YAAA;AACH,UAAA;AAEE,UAAA;AAAC,YAAA;AAAA,YAAA;AACM,cAAA;AACI,cAAA;AACC,cAAA;AACA,cAAA;AACoC,cAAA;AAC/C,cAAA;AAAA,YAAA;AAED,UAAA;AAEJ,QAAA;AACF,MAAA;AAGA,sBAAA;AAAC,QAAA;AAAA,QAAA;AACW,UAAA;AACH,UAAA;AAGD,YAAA;AACuC,YAAA;AACP,YAAA;AACxB,YAAA;AACd,UAAA;AAEe,UAAA;AAAA,QAAA;AACjB,MAAA;AAGA,sBAAA;AAAC,QAAA;AAAA,QAAA;AACW,UAAA;AACH,UAAA;AACM,YAAA;AACG,YAAA;AAChB,UAAA;AAEa,UAAA;AAAA,QAAA;AACf,MAAA;AACF,IAAA;AAIiE,oBAAA;AAM9D,MAAA;AAAA,MAAA;AACO,QAAA;AACN,QAAA;AACO,QAAA;AACqB,QAAA;AAC5B,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AAAA,MAAA;AAGF,IAAA;AAAC,MAAA;AAAA,MAAA;AACgC,QAAA;AACqB,QAAA;AAC7C,QAAA;AACY,UAAA;AACV,UAAA;AACO,UAAA;AAChB,QAAA;AACD,QAAA;AAAA,MAAA;AAID,IAAA;AAAC,MAAA;AAAA,MAAA;AACS,QAAA;AAC4C,QAAA;AAC7C,QAAA;AACY,UAAA;AACV,UAAA;AACO,UAAA;AAChB,QAAA;AAEmC,QAAA;AAAA,MAAA;AAGzC,IAAA;AACF,EAAA;AAEJ;AAEe;AHoBkF;AACA;AItgB7F;AAAA;AAAAA,kBAAAA;AAAC,IAAA;AAAA,IAAA;AACW,MAAA;AAC8C,MAAA;AAGxD,MAAA;AAAAC,wBAAAA;AAAC,UAAA;AAAA,UAAA;AACW,YAAA;AACmE,YAAA;AAAA,UAAA;AAC/E,QAAA;AAEAA,wBAAAA;AAAC,UAAA;AAAA,UAAA;AACW,YAAA;AACuE,YAAA;AAAU,UAAA;AAC7F,QAAA;AAEe,wBAAA;AACZ,UAAA;AAAA,UAAA;AACW,YAAA;AACuE,YAAA;AAAU,UAAA;AAE/F,QAAA;AAAA,MAAA;AAAA,IAAA;AACF,EAAA;AAIE,kBAAA;AAAC,IAAA;AAAA,IAAA;AACW,MAAA;AACH,MAAA;AACG,QAAA;AACS,QAAA;AACH,QAAA;AAChB,MAAA;AAAA,IAAA;AAEJ,EAAA;AAKE,kBAAA;AAAAA,oBAAAA;AAAC,MAAA;AAAA,MAAA;AACW,QAAA;AACmE,QAAA;AAAA,MAAA;AAC/E,IAAA;AAEAA,oBAAAA;AAAC,MAAA;AAAA,MAAA;AACW,QAAA;AACuE,QAAA;AAAU,MAAA;AAC7F,IAAA;AAEe,oBAAA;AACZ,MAAA;AAAA,MAAA;AACW,QAAA;AACuE,QAAA;AAAU,MAAA;AAE/F,IAAA;AACF,EAAA;AAGAA,kBAAAA;AAAC,IAAA;AAAA,IAAA;AACW,MAAA;AACH,MAAA;AACG,QAAA;AACG,QAAA;AACG,QAAA;AAChB,MAAA;AAAA,IAAA;AACF,EAAA;AAIEA,kBAAAA;AAAC,IAAA;AAAA,IAAA;AACW,MAAA;AACH,MAAA;AACG,QAAA;AACS,QAAA;AACH,QAAA;AACL,QAAA;AACX,MAAA;AAAA,IAAA;AAEJ,EAAA;AACF;AJmhB+F;AACA;AKpmB7D;AACT;AA6BvB;AAbyB;AAC3B,EAAA;AACA,EAAA;AAII;AAC6C,EAAA;AAC/C,IAAA;AACA,IAAA;AACF,EAAA;AAIK,EAAA;AACCA,IAAAA;AAAC,MAAA;AAAA,MAAA;AAKO,QAAA;AAGL,QAAA;AAAA,MAAA;AAPI,MAAA;AASR,IAAA;AACDA,oBAAAA;AAAC,MAAA;AAAA,MAAA;AACQ,QAAA;AAGD,UAAA;AACqB,UAAA;AAC3B,QAAA;AAEC,QAAA;AAAA,MAAA;AACH,IAAA;AACF,EAAA;AAEJ;AAE+C;AAC7C,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACI;AACmD,EAAA;AAEjD,EAAA;AACJ,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AACE,EAAA;AACqB,IAAA;AACO,MAAA;AACH,MAAA;AACD,MAAA;AACJ,MAAA;AACJ,MAAA;AACC,MAAA;AACjB,IAAA;AACJ,EAAA;AAEuF,EAAA;AAChD,EAAA;AACK,EAAA;AAEA,EAAA;AACR,EAAA;AAGpB,EAAA;AAEmE,EAAA;AAEvD,EAAA;AACI,IAAA;AACV,MAAA;AACX,QAAA;AACI,UAAA;AACJ,QAAA;AACI,UAAA;AACJ,QAAA;AACI,UAAA;AACJ,QAAA;AACI,UAAA;AACJ,QAAA;AACI,UAAA;AACT,QAAA;AACS,UAAA;AACX,MAAA;AACF,IAAA;AAMa,IAAA;AAGJ,MAAA;AACT,IAAA;AAEiD,IAAA;AAG3C,MAAA;AACN,IAAA;AAEc,IAAA;AACP,MAAA;AACI,QAAA;AACJ,MAAA;AACI,QAAA;AACJ,MAAA;AACI,QAAA;AACJ,MAAA;AACI,QAAA;AACJ,MAAA;AACI,QAAA;AACT,MAAA;AACuB,QAAA;AAC0B,UAAA;AACpC,YAAA;AACkC,UAAA;AAClC,YAAA;AAC2C,UAAA;AAC3C,YAAA;AACkC,UAAA;AAClC,YAAA;AACkC,UAAA;AAClC,YAAA;AACX,QAAA;AACgE,QAAA;AACrC,QAAA;AACE,QAAA;AACtB,QAAA;AACX,IAAA;AACF,EAAA;AAEuC,EAAA;AAMnC,EAAA;AAMyC,EAAA;AAClC,IAAA;AACC,IAAA;AACC,IAAA;AACH,IAAA;AACG,IAAA;AACb,EAAA;AAEiC,EAAA;AACQ,IAAA;AACN,IAAA;AACnC,EAAA;AAEmC,EAAA;AACR,IAAA;AAEJ,IAAA;AAGd,MAAA;AACC,QAAA;AAAC,UAAA;AAAA,UAAA;AACgB,YAAA;AAC0C,cAAA;AACpC,gBAAA;AACZ,cAAA;AAC2C,gBAAA;AAClD,cAAA;AACF,YAAA;AACW,YAAA;AACD,YAAA;AAEVD,YAAAA;AAAC,cAAA;AAAA,cAAA;AACW,gBAAA;AACF,gBAAA;AACH,gBAAA;AACC,gBAAA;AAEN,gBAAA;AAA4C,kCAAA;AACpC,kCAAA;AACgC,kCAAA;AAAkB,gBAAA;AAAA,cAAA;AAC5D,YAAA;AAAA,UAAA;AACF,QAAA;AAEuF,QAAA;AACtF,UAAA;AAAA,UAAA;AACiC,YAAA;AACrB,YAAA;AACD,YAAA;AAEVA,YAAAA;AAAC,cAAA;AAAA,cAAA;AACW,gBAAA;AACF,gBAAA;AACH,gBAAA;AACC,gBAAA;AAEN,gBAAA;AAA4C,kCAAA;AACpC,kCAAA;AACgC,kCAAA;AAAkB,gBAAA;AAAA,cAAA;AAC5D,YAAA;AAAA,UAAA;AACF,QAAA;AAEFC,wBAAAA;AAAC,UAAA;AAAA,UAAA;AAEwD,YAAA;AAEH,YAAA;AACC,YAAA;AAI/C,YAAA;AAEK,YAAA;AAMXD,YAAAA;AAAC,cAAA;AAAA,cAAA;AACW,gBAAA;AACF,gBAAA;AACH,gBAAA;AACC,gBAAA;AAEN,gBAAA;AAAAC,kCAAAA;AAAC,oBAAA;AAAA,oBAAA;AACG,sBAAA;AACG,sBAAA;AAAA,oBAAA;AACP,kBAAA;AACAA,kCAAAA;AAAC,oBAAA;AAAA,oBAAA;AACG,sBAAA;AACK,sBAAA;AACK,sBAAA;AACK,sBAAA;AACH,sBAAA;AACC,sBAAA;AAAA,oBAAA;AACjB,kBAAA;AACAA,kCAAAA;AAAC,oBAAA;AAAA,oBAAA;AACG,sBAAA;AACK,sBAAA;AACK,sBAAA;AACK,sBAAA;AACH,sBAAA;AACC,sBAAA;AAAA,oBAAA;AACjB,kBAAA;AACAA,kCAAAA;AAAC,oBAAA;AAAA,oBAAA;AACG,sBAAA;AACK,sBAAA;AACK,sBAAA;AACG,sBAAA;AAAA,oBAAA;AACjB,kBAAA;AACAD,kCAAAA;AAAC,oBAAA;AAAA,oBAAA;AACQ,sBAAA;AACuD,wBAAA;AAC3C,wBAAA;AACL,wBAAA;AACd,sBAAA;AAEA,sBAAA;AAAAC,wCAAAA;AAAC,0BAAA;AAAA,0BAAA;AACG,4BAAA;AACK,4BAAA;AACK,4BAAA;AAAA,0BAAA;AACd,wBAAA;AACAA,wCAAAA;AAAC,0BAAA;AAAA,0BAAA;AACG,4BAAA;AACK,4BAAA;AACK,4BAAA;AAAA,0BAAA;AACd,wBAAA;AAAA,sBAAA;AAAA,oBAAA;AACF,kBAAA;AAAA,gBAAA;AAAA,cAAA;AACF,YAAA;AAAA,UAAA;AACF,QAAA;AACF,MAAA;AAEJ,IAAA;AAGED,IAAAA;AAAC,MAAA;AAAA,MAAA;AAI+C,QAAA;AAEpC,QAAA;AAEV,QAAA;AAAwB,0BAAA;AACM,0BAAA;AAAA,QAAA;AAAA,MAAA;AAChC,IAAA;AAEJ,EAAA;AAE2C,EAAA;AAGF,EAAA;AAGxB,EAAA;AAEI,IAAA;AACbA,sBAAAA;AAAC,QAAA;AAAA,QAAA;AACM,UAAA;AAEkD,UAAA;AAE7C,UAAA;AACH,UAAA;AAIC,YAAA;AACR,UAAA;AAEA,UAAA;AACG,4BAAA;AAES,4BAAA;AAAA,UAAA;AAAA,QAAA;AACd,MAAA;AAEG,sBAAA;AAEHC,sBAAAA;AAAC,QAAA;AAAA,QAAA;AACM,UAAA;AAEoD,UAAA;AAE/C,UAAA;AACH,UAAA;AAIC,YAAA;AACR,UAAA;AACD,UAAA;AAAA,QAAA;AAED,MAAA;AAGa,IAAA;AACbA,sBAAAA;AAAC,QAAA;AAAA,QAAA;AACW,UAAA;AACqD,UAAA;AAE9D,UAAA;AAAA,QAAA;AACH,MAAA;AACAA,sBAAAA;AAAC,QAAA;AAAA,QAAA;AACW,UAAA;AACoD,UAAA;AAG9DA,UAAAA;AAAC,YAAA;AAAA,YAAA;AACa,cAAA;AACe,cAAA;AAAA,YAAA;AAC7B,UAAA;AAAA,QAAA;AALK,QAAA;AAMP,MAAA;AACF,IAAA;AAE2C,oBAAA;AAC/C,EAAA;AAEJ;AAEe;ALsjBkF;AACA;AE5sB7F;AAvOgE;AACA;AACA;AACV;AACsB;AACE;AAaxB;AACxD,EAAA;AACA,EAAA;AACA,EAAA;AACI;AACE,EAAA;AACJ,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AACqB,EAAA;AACoD,EAAA;AAEpB,EAAA;AACjD,EAAA;AACJ,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AACE,EAAA;AACqB,IAAA;AACE,MAAA;AACK,MAAA;AACX,MAAA;AACiD,MAAA;AAClE,IAAA;AACJ,EAAA;AAE0D,EAAA;AACD,EAAA;AACmB,EAAA;AAEhD,EAAA;AAEZ,EAAA;AACD,IAAA;AACsD,MAAA;AACF,MAAA;AACjE,IAAA;AACG,EAAA;AAEW,EAAA;AAC0B,IAAA;AACrC,EAAA;AAEW,EAAA;AACQ,IAAA;AAEqB,IAAA;AACe,MAAA;AAC9B,MAAA;AACvB,IAAA;AAEQ,IAAA;AACkB,MAAA;AACS,QAAA;AACV,QAAA;AAC5B,MAAA;AACF,IAAA;AACkB,EAAA;AAEKC,EAAAA;AACuC,IAAA;AAChC,MAAA;AACS,QAAA;AACV,QAAA;AACH,QAAA;AACxB,MAAA;AAEoD,MAAA;AACF,MAAA;AACD,QAAA;AACS,QAAA;AACnD,MAAA;AACyD,QAAA;AAChE,MAAA;AACF,IAAA;AACC,IAAA;AACH,EAAA;AAE2C,EAAA;AACZ,IAAA;AACS,MAAA;AACV,MAAA;AAC5B,IAAA;AAC4B,IAAA;AACS,MAAA;AACV,MAAA;AAC3B,IAAA;AAEoD,IAAA;AACvB,IAAA;AAEsB,IAAA;AACL,IAAA;AACU,IAAA;AACJ,IAAA;AAEV,IAAA;AAClB,MAAA;AACG,MAAA;AACrB,IAAA;AACH,EAAA;AAE2BA,EAAAA;AACC,IAAA;AACR,MAAA;AACyC,MAAA;AACE,MAAA;AACT,MAAA;AACvD,MAAA;AACsC,QAAA;AACpC,QAAA;AACF,MAAA;AACF,IAAA;AACuB,IAAA;AACzB,EAAA;AAEgD,EAAA;AACM,IAAA;AACf,IAAA;AACoB,MAAA;AACZ,IAAA;AACa,MAAA;AAC1D,IAAA;AACmB,EAAA;AAIyB,EAAA;AACvC,IAAA;AACC,IAAA;AACQ,EAAA;AAGuD,EAAA;AAE3C,EAAA;AACZ,IAAA;AACP,MAAA;AACI,QAAA;AACJ,MAAA;AACI,QAAA;AACJ,MAAA;AACI,QAAA;AACJ,MAAA;AACA,MAAA;AACI,QAAA;AACT,MAAA;AACS,QAAA;AACX,IAAA;AACF,EAAA;AAEyE,EAAA;AAGlC,EAAA;AAEK,EAAA;AAIb,EAAA;AAGG,EAAA;AAEO,EAAA;AAK9B,EAAA;AAGgD,EAAA;AAGtC,EAAA;AAEwB,EAAA;AACA,EAAA;AAEK,EAAA;AACA,EAAA;AAEG,EAAA;AACc,EAAA;AAEX,EAAA;AAEH,EAAA;AAEI,EAAA;AAES,EAAA;AAC/C,IAAA;AACO,IAAA;AACgB,IAAA;AAC5B,IAAA;AACd,EAAA;AAMa,EAAA;AAKT,EAAA;AAEC,IAAA;AAAA,IAAA;AACC,MAAA;AACiB,MAAA;AAC+B,MAAA;AACU,MAAA;AAAA,IAAA;AAK5D,EAAA;AAAC,IAAA;AAAA,IAAA;AACC,MAAA;AACiB,MAAA;AAC+B,MAAA;AACU,MAAA;AAAA,IAAA;AAIH,EAAA;AAKnC,EAAA;AAGqB,EAAA;AACiB,EAAA;AAEhD,EAAA;AACK,IAAA;AACI,IAAA;AACd,IAAA;AACwC,IAAA;AAClB,MAAA;AACe,QAAA;AAC5C,MAAA;AACD,IAAA;AACkB,IAAA;AACc,IAAA;AAClB,EAAA;AAEC,EAAA;AAIZ,IAAA;AAAAF,sBAAAA;AAAC,QAAA;AAAA,QAAA;AACM,UAAA;AACK,UAAA;AACH,UAAA;AACC,YAAA;AACI,YAAA;AACP,YAAA;AACL,UAAA;AAEA,UAAA;AAAAC,4BAAAA;AAAC,cAAA;AAAA,cAAA;AACY,gBAAA;AACE,gBAAA;AACb,gBAAA;AACA,gBAAA;AACA,gBAAA;AACiB,gBAAA;AACS,gBAAA;AACT,gBAAA;AACA,gBAAA;AAAA,cAAA;AACnB,YAAA;AAC8C,4BAAA;AAAA,UAAA;AAAA,QAAA;AAChD,MAAA;AAIEA,MAAAA;AAAC,QAAA;AAAA,QAAA;AACW,UAAA;AACH,UAAA;AACE,YAAA;AACkB,YAAA;AACtB,YAAA;AACC,YAAA;AACyC,cAAA;AAC7C,YAAA;AACF,UAAA;AAGC,UAAA;AACE,YAAA;AAAA,YAAA;AACS,cAAA;AACF,cAAA;AACM,cAAA;AACO,cAAA;AACE,cAAA;AAAA,YAAA;AAKvBA,UAAAA;AAAC,YAAA;AAAA,YAAA;AACS,cAAA;AACF,cAAA;AACS,cAAA;AAAA,YAAA;AAEnB,UAAA;AAAA,QAAA;AAEF,MAAA;AAEJ,IAAA;AAEJ,EAAA;AAGED,EAAAA;AAAC,IAAA;AAAA,IAAA;AACW,MAAA;AACH,MAAA;AACK,QAAA;AACA,QAAA;AACZ,MAAA;AAEA,MAAA;AAAAC,wBAAAA;AAAC,UAAA;AAAA,UAAA;AAC2B,YAAA;AACb,YAAA;AACb,YAAA;AACA,YAAA;AACA,YAAA;AACiB,YAAA;AACS,YAAA;AACT,YAAA;AACA,YAAA;AAAA,UAAA;AACnB,QAAA;AAGG,wBAAA;AACCA,UAAAA;AAAC,YAAA;AAAA,YAAA;AACW,cAAA;AAC4C,cAAA;AAErD,cAAA;AAAA,YAAA;AACH,UAAA;AAIAA,UAAAA;AAAC,YAAA;AAAA,YAAA;AACW,cAAA;AAC+C,cAAA;AAGtD,cAAA;AACH,YAAA;AACF,UAAA;AAIAA,UAAAA;AAAC,YAAA;AAAA,YAAA;AACW,cAAA;AAC8B,cAAA;AAGtC,cAAA;AAAC,gBAAA;AAAA,gBAAA;AACS,kBAAA;AACF,kBAAA;AACM,kBAAA;AACO,kBAAA;AACE,kBAAA;AAAA,gBAAA;AAEzB,cAAA;AAAA,YAAA;AACF,UAAA;AAIAA,UAAAA;AAAC,YAAA;AAAA,YAAA;AACW,cAAA;AAC8B,cAAA;AAGtC,cAAA;AAAC,gBAAA;AAAA,gBAAA;AACS,kBAAA;AACF,kBAAA;AACS,kBAAA;AAAA,gBAAA;AAEnB,cAAA;AAAA,YAAA;AACF,UAAA;AAEJ,QAAA;AAAA,MAAA;AAAA,IAAA;AACF,EAAA;AAEJ;AAE4D;AAC1D,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACI;AAC4C,EAAA;AACS,EAAA;AAGvDA,EAAAA;AAAC,IAAA;AAAA,IAAA;AACC,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AAGEA,MAAAA;AAAC,QAAA;AAAA,QAAA;AACC,UAAA;AACA,UAAA;AACA,UAAA;AAAA,QAAA;AAEJ,MAAA;AAAA,IAAA;AACF,EAAA;AAEJ;AFs2BiG;AACA;AMxzCvC;AN0zCuC;AACA;AOnxCnD;AAChC,EAAA;AACA,EAAA;AACN,EAAA;AACa,EAAA;AACV,EAAA;AACa,EAAA;AACb,EAAA;AACa,EAAA;AACX,EAAA;AACa,EAAA;AACjB,EAAA;AACa,EAAA;AACZ,EAAA;AACa,EAAA;AACR,EAAA;AACa,EAAA;AAClB,EAAA;AACD,EAAA;AACD,EAAA;AACE,EAAA;AACQ,EAAA;AACE,EAAA;AACC,EAAA;AACC,EAAA;AACH,EAAA;AACnB;AAE6C;AAC/B,EAAA;AACA,EAAA;AACN,EAAA;AACa,EAAA;AACV,EAAA;AACa,EAAA;AACb,EAAA;AACa,EAAA;AACX,EAAA;AACa,EAAA;AACjB,EAAA;AACa,EAAA;AACZ,EAAA;AACa,EAAA;AACR,EAAA;AACa,EAAA;AAClB,EAAA;AACD,EAAA;AACD,EAAA;AACE,EAAA;AACQ,EAAA;AACE,EAAA;AACC,EAAA;AACC,EAAA;AACH,EAAA;AACnB;AAEuE;AAChC,EAAA;AACN,IAAA;AACA,IAAA;AACN,IAAA;AAC4B,IAAA;AACzB,IAAA;AAC+B,IAAA;AAC/B,IAAA;AAC+B,IAAA;AAC7B,IAAA;AACiC,IAAA;AACrC,IAAA;AAC6B,IAAA;AAC5B,IAAA;AAC8B,IAAA;AACzB,IAAA;AACmC,IAAA;AACxC,IAAA;AACD,IAAA;AACD,IAAA;AACE,IAAA;AACyB,IAAA;AACpD,EAAA;AAEmD,EAAA;AACA,EAAA;AACM,EAAA;AACI,EAAA;AACN,EAAA;AACI,EAAA;AACI,EAAA;AACA,EAAA;AACF,EAAA;AAEA,EAAA;AACE,EAAA;AACE,EAAA;AACN,EAAA;AAEpD,EAAA;AACT;APgxCiG;AACA;AM94C7F;AATkE;AAOa;AAI/E,EAAA;AAEJ;AAEiC;AACK,EAAA;AACtC;AN+4CiG;AACA;ACt3CzF;AA5BwB;AACmD;AACC;AAC1C;AAEd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAa1B;AAC0B,iBAAA;AAEQ,EAAA;AACR,IAAA;AAC1B,EAAA;AAES,EAAA;AACkB,IAAA;AAEiC,MAAA;AACO,wBAAA;AAC3DA,wBAAAA;AAAC,UAAA;AAAA,UAAA;AACM,YAAA;AAC2C,YAAA;AACzC,YAAA;AACI,cAAA;AACC,cAAA;AACF,cAAA;AACA,cAAA;AACM,cAAA;AACF,cAAA;AACL,cAAA;AACT,YAAA;AACD,YAAA;AAAA,UAAA;AAED,QAAA;AACF,MAAA;AAEJ,IAAA;AACkB,IAAA;AACpB,EAAA;AACF;AAa8D;AACE,EAAA;AACY,EAAA;AAC7B,EAAA;AAC/C;AAE2B;AACzB,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACiB,EAAA;AACC;AAGK,EAAA;AACY,EAAA;AACA,EAAA;AAEF,EAAA;AACmB,EAAA;AACI,EAAA;AACkB,EAAA;AACV,EAAA;AACI,EAAA;AACM,EAAA;AACR,EAAA;AACA,EAAA;AACE,EAAA;AACE,EAAA;AACZ,EAAA;AACN,EAAA;AACpB,EAAA;AAOD,EAAA;AAEP,EAAA;AAIT,IAAA;AAEf,EAAA;AAEuD,EAAA;AACO,EAAA;AAG1D,EAAA;AACiD,IAAA;AACnC,IAAA;AACJ,IAAA;AACE,IAAA;AACD,IAAA;AACJ,IAAA;AACO,IAAA;AACK,IAAA;AACT,IAAA;AACM,IAAA;AACH,IAAA;AACF,IAAA;AAEX,EAAA;AACS,IAAA;AAGH,IAAA;AAMU,MAAA;AAGV,IAAA;AACI,IAAA;AACE,IAAA;AACZ,EAAA;AAEoC,EAAA;AAC3B,IAAA;AACM,IAAA;AACV,IAAA;AACO,IAAA;AAGV,IAAA;AACe,MAAA;AACA,MAAA;AACA,MAAA;AACf,IAAA;AAEF,IAAA;AACO,IAAA;AACG,IAAA;AACd,EAAA;AAEsD,EAAA;AACc,EAAA;AACE,EAAA;AACF,EAAA;AACE,EAAA;AACF,EAAA;AACE,EAAA;AACoB,EAAA;AACE,EAAA;AAChD,EAAA;AACE,EAAA;AACc,EAAA;AACA,EAAA;AAChC,EAAA;AAEFE,EAAAA;AACjB,IAAA;AACU,MAAA;AACK,MAAA;AACpB,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACF,IAAA;AACA,IAAA;AACS,MAAA;AACP,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACF,IAAA;AACF,EAAA;AAEyBA,EAAAA;AAGuC,IAAA;AAE3B,IAAA;AACrC,EAAA;AAIK,EAAA;AAEI,IAAA;AAAA,IAAA;AAC0D,MAAA;AAEvD,MAAA;AACK,QAAA;AACY,QAAA;AACA,QAAA;AACH,QAAA;AACG,QAAA;AACR,QAAA;AACJ,QAAA;AACO,QAAA;AACmB,QAAA;AAC/B,MAAA;AAGF,MAAA;AAA8D,wBAAA;AAE5DF,wBAAAA;AAAC,UAAA;AAAA,UAAA;AACC,YAAA;AACiC,YAAA;AACC,YAAA;AAClC,YAAA;AACA,YAAA;AAC6C,YAAA;AACF,YAAA;AAAA,UAAA;AAE/C,QAAA;AAAA,MAAA;AAAA,IAAA;AAIR,EAAA;AAGoB,EAAA;AAGf,IAAA;AAGP,EAAA;AAEO,EAAA;AACT;ADg1CiG;AACA;AQloD7F;AAT4B;AACc,EAAA;AACI,EAAA;AAI5C,EAAA;AAGFA,EAAAA;AAAC,IAAA;AAAA,IAAA;AACM,MAAA;AAC2B,MAAA;AACtB,MAAA;AAET,MAAA;AAAA,IAAA;AACH,EAAA;AAEJ;AR0oDiG;AACA;AS/pDlE;AAI7B;AACsD,EAAA;AACxC,EAAA;AACkB,IAAA;AACc,MAAA;AAGrC,MAAA;AAGC,MAAA;AACC,MAAA;AACL,QAAA;AAEyE,QAAA;AAE3E,MAAA;AACD,IAAA;AACH,EAAA;AACF;AAEuE;ATupD0B;AACA;AUhrDzE;AAE8B;AACa,EAAA;AAEpC,EAAA;AACqC,IAAA;AACvC,EAAA;AAE0B,EAAA;AACvD;AAEyE;AAChC,EAAA;AAElB,EAAA;AAC2B,IAAA;AACzB,IAAA;AAGC,MAAA;AACtB,IAAA;AACkC,EAAA;AACtC;AAEuE;AACnC,EAAA;AAEb,EAAA;AACc,IAAA;AACD,IAAA;AACH,EAAA;AACjC;AAEuD;AVwqD0C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"/Users/flooreyes/mega-swap-widget/dist/index.cjs","sourcesContent":[null,"'use client';\n\nimport type { Asset } from './internal';\nimport React, { type ReactNode, useMemo } from 'react';\nimport type { AoriSwapWidgetConfig } from './config/types';\nimport { SwapContainer } from './components/SwapContainer';\nimport { WidgetConfigContext } from './context/WidgetConfigContext';\nimport { useWidgetSwapUIStore } from './stores/swapUIStore';\n\nimport { WidgetThemeProvider } from './theme/ThemeContext';\nimport {\n type WidgetTheme,\n defaultDarkTheme,\n defaultLightTheme,\n themeToCSS,\n} from './theme/types';\nimport { AoriClientProvider } from './internal';\nimport { setApiKey, setRpcOverrides, setVtApiBaseUrl } from './internal/environment';\nimport { WalletModalContext } from './wallet/WalletModalContext';\n\nconst EMPTY_CHAINS: number[] = [];\nconst EMPTY_SUPPORTED_INPUT_TOKENS: Array<{ chainId: number; address: string }> = [];\nconst EMPTY_SUPPORTED_OUTPUT_TOKENS: Array<{ chainId: number; address: string }> = [];\nconst EMPTY_SUPPORTED_CHAINS: number[] = [];\n\nconst WIDGET_CRITICAL_CSS = `\n.aori-widget .text-2xs { font-size: 0.75rem; }\n.aori-widget .text-3xs { font-size: 0.68rem; }\n.aori-widget ::-webkit-scrollbar { width: 0px; height: 0px; display: none; }\n.aori-widget * { scrollbar-width: none; }\n.aori-widget input:focus, .aori-widget input:focus-visible,\n.aori-widget button:focus, .aori-widget button:focus-visible,\n.aori-widget select:focus, .aori-widget select:focus-visible { outline: none; }\n`;\n\nclass WidgetErrorBoundary extends React.Component<\n { children: ReactNode },\n { hasError: boolean }\n> {\n state = { hasError: false };\n\n static getDerivedStateFromError() {\n return { hasError: true };\n }\n\n render() {\n if (this.state.hasError) {\n return (\n <div style={{ padding: '1.5rem', textAlign: 'center', color: 'var(--widget-foreground, #888)', fontFamily: 'system-ui, sans-serif' }}>\n <p style={{ margin: '0 0 0.75rem', fontSize: '0.875rem' }}>Something went wrong.</p>\n <button\n type=\"button\"\n onClick={() => this.setState({ hasError: false })}\n style={{\n padding: '0.375rem 1rem',\n fontSize: '0.8125rem',\n cursor: 'pointer',\n border: '1px solid currentColor',\n borderRadius: '0.25rem',\n background: 'transparent',\n color: 'inherit',\n }}\n >\n Retry\n </button>\n </div>\n );\n }\n return this.props.children;\n }\n}\n\nexport interface SwapWidgetProps {\n config: AoriSwapWidgetConfig;\n className?: string;\n onSwapComplete?: (orderHash: string) => void;\n onBaseTokenChange?: (token: Asset) => void;\n onQuoteTokenChange?: (token: Asset) => void;\n onRequestConnect?: () => void;\n onRequestAccount?: () => void;\n customWalletUI?: 'builtin' | 'none' | 'provider';\n}\n\nfunction resolveTheme(cfg: AoriSwapWidgetConfig): WidgetTheme {\n const base = cfg.theme.mode === 'light' ? defaultLightTheme : defaultDarkTheme;\n const override = cfg.theme.mode === 'light' ? cfg.theme.light : cfg.theme.dark;\n return override ? { ...base, ...override } : base;\n}\n\nexport function SwapWidget({\n config,\n className,\n onSwapComplete,\n onBaseTokenChange,\n onQuoteTokenChange,\n onRequestConnect,\n onRequestAccount,\n customWalletUI = 'builtin',\n}: SwapWidgetProps) {\n // Synchronous so every fetch (including initial token/chain queries) picks up\n // the overrides before any React Query hooks fire.\n setApiKey(config.apiKey);\n setRpcOverrides(config.rpcOverrides);\n setVtApiBaseUrl(config.vtApiBaseUrl);\n\n const theme = resolveTheme(config);\n const widgetType = config.appearance?.widgetType ?? 'default';\n const tokenDisplay = config.appearance?.tokenDisplay ?? 'default';\n const tokenBadgeOrientation = config.appearance?.tokenBadgeOrientation ?? 'left';\n const assetMenuVariant = config.appearance?.assetMenuVariant ?? 'default';\n const amountInputVariant = config.appearance?.amountInputVariant ?? 'default';\n const hideAmountInputSymbol = config.appearance?.hideAmountInputSymbol ?? false;\n const swapButtonVariant = config.appearance?.swapButtonVariant ?? 'default';\n const swapHeaderVariant = config.appearance?.swapHeaderVariant ?? 'default';\n const quoteLoaderVariant = config.appearance?.quoteLoaderVariant ?? 'default';\n const walletButtonEnabled = config.appearance?.walletButtonEnabled ?? true;\n const fillContainer = config.appearance?.fillContainer ?? false;\n const hideBorder = config.appearance?.hideBorder ?? false;\n const cssVars = themeToCSS(theme);\n\n // For default/compact with split menu, the outer div becomes a transparent flex-row\n // wrapper (no card styling) and expands to hold both the form card and selection card.\n // The card styling is applied to each individual card inside SwapContainer.\n const isSplitSideBySide =\n assetMenuVariant === 'split' &&\n (widgetType === 'default' || widgetType === 'compact');\n\n const isSelectionOpen = useWidgetSwapUIStore(\n (s) =>\n s.view === 'baseSelection' ||\n s.view === 'quoteSelection' ||\n s.view === 'baseChainSelection' ||\n s.view === 'quoteChainSelection',\n );\n\n const cardWidth = widgetType === 'compact' ? '22rem' : '24rem';\n const expandedMaxWidth = widgetType === 'compact' ? '46rem' : '49rem';\n\n const widgetDimensions: React.CSSProperties = isSplitSideBySide\n ? {\n maxWidth: isSelectionOpen ? expandedMaxWidth : cardWidth,\n transition: 'max-width 0.3s ease',\n height: 'auto',\n overflow: 'visible',\n display: 'flex',\n gap: '1rem',\n alignItems: 'stretch',\n backgroundColor: 'transparent',\n border: 'none',\n borderRadius: 0,\n boxShadow: 'none',\n padding: 0,\n }\n : {\n width: '100%',\n ...(fillContainer\n ? {}\n : {\n maxWidth:\n widgetType === 'split'\n ? '48rem'\n : widgetType === 'horizontal'\n ? '48rem'\n : widgetType === 'compact'\n ? '22rem'\n : '24rem',\n }),\n height: 'auto',\n overflow: 'hidden',\n };\n\n const cardStyles: React.CSSProperties = {\n boxSizing: 'border-box',\n backgroundColor: 'var(--widget-background)',\n color: 'var(--widget-foreground)',\n borderRadius: 'var(--widget-radius)',\n ...(hideBorder\n ? { border: 'none' }\n : {\n borderWidth: '1px',\n borderStyle: 'var(--widget-border-style)' as React.CSSProperties['borderStyle'],\n borderColor: 'var(--widget-border)',\n }),\n boxShadow:\n 'var(--widget-shadow-offset-x) var(--widget-shadow-offset-y) var(--widget-shadow-blur) var(--widget-shadow-spread) color-mix(in srgb, var(--widget-shadow-color) calc(var(--widget-shadow-opacity) * 100%), transparent)',\n padding: '0.25rem 0.5rem',\n paddingTop: '0.25rem',\n };\n\n const enabledChains = config.tokens?.enabledChains ?? EMPTY_CHAINS;\n const supportedInputTokens = config.tokens?.supportedInputTokens ?? EMPTY_SUPPORTED_INPUT_TOKENS;\n const supportedOutputTokens = config.tokens?.supportedOutputTokens ?? EMPTY_SUPPORTED_OUTPUT_TOKENS;\n const supportedInputChains = config.tokens?.supportedInputChains ?? EMPTY_SUPPORTED_CHAINS;\n const supportedOutputChains = config.tokens?.supportedOutputChains ?? EMPTY_SUPPORTED_CHAINS;\n const inputSelectionSearch = config.tokens?.inputSelectionSearch ?? true;\n const outputSelectionSearch = config.tokens?.outputSelectionSearch ?? true;\n const showInputSelectionTokenBalances = config.tokens?.showInputSelectionTokenBalances ?? true;\n const showOutputSelectionTokenBalances = config.tokens?.showOutputSelectionTokenBalances ?? true;\n const lockBase = config.tokens?.lockBase ?? false;\n const lockQuote = config.tokens?.lockQuote ?? false;\n const disableInverting = config.tokens?.disableInverting ?? false;\n const defaultSlippage = config.settings?.defaultSlippage ?? 0.01;\n const hasConnectHandler = !!onRequestConnect;\n\n const widgetConfigValue = useMemo(\n () => ({\n apiKey: config.apiKey,\n web3ConnectionType: 'custom' as const,\n enabledChains,\n supportedInputTokens,\n supportedOutputTokens,\n supportedInputChains,\n supportedOutputChains,\n inputSelectionSearch,\n outputSelectionSearch,\n showInputSelectionTokenBalances,\n showOutputSelectionTokenBalances,\n lockBase,\n lockQuote,\n disableInverting,\n defaultSlippage,\n widgetType,\n tokenDisplay,\n tokenBadgeOrientation,\n assetMenuVariant,\n amountInputVariant,\n hideAmountInputSymbol,\n swapButtonVariant,\n swapHeaderVariant,\n quoteLoaderVariant,\n walletButtonEnabled,\n hasConnectHandler,\n customWalletUI,\n }),\n [\n config.apiKey,\n enabledChains,\n supportedInputTokens,\n supportedOutputTokens,\n supportedInputChains,\n supportedOutputChains,\n inputSelectionSearch,\n outputSelectionSearch,\n showInputSelectionTokenBalances,\n showOutputSelectionTokenBalances,\n lockBase,\n lockQuote,\n disableInverting,\n defaultSlippage,\n widgetType,\n tokenDisplay,\n tokenBadgeOrientation,\n assetMenuVariant,\n amountInputVariant,\n hideAmountInputSymbol,\n swapButtonVariant,\n swapHeaderVariant,\n quoteLoaderVariant,\n walletButtonEnabled,\n hasConnectHandler,\n customWalletUI,\n ],\n );\n\n const walletModalValue = useMemo(\n () =>\n onRequestConnect\n ? { openConnectModal: onRequestConnect, openAccountModal: onRequestAccount }\n : null,\n [onRequestConnect, onRequestAccount],\n );\n\n const inner = (\n <AoriClientProvider>\n <WidgetConfigContext.Provider value={widgetConfigValue}>\n <WidgetThemeProvider theme={theme}>\n <div\n className={`aori-widget${className ? ` ${className}` : ''}`}\n style={\n {\n ...cssVars,\n '--font-sans': 'var(--widget-font-sans)',\n '--font-mono': 'var(--widget-font-mono)',\n fontFamily: 'var(--widget-font-sans)',\n letterSpacing: 'var(--widget-letter-spacing)',\n width: '100%',\n ...widgetDimensions,\n position: 'relative',\n ...(isSplitSideBySide ? {} : cardStyles),\n } as React.CSSProperties\n }\n >\n <style dangerouslySetInnerHTML={{ __html: WIDGET_CRITICAL_CSS }} />\n <WidgetErrorBoundary>\n <SwapContainer\n onSwapComplete={onSwapComplete}\n defaultBaseToken={config.tokens?.defaultBase}\n defaultQuoteToken={config.tokens?.defaultQuote}\n onBaseTokenChange={onBaseTokenChange}\n onQuoteTokenChange={onQuoteTokenChange}\n cardStyles={isSplitSideBySide ? cardStyles : undefined}\n cardWidth={isSplitSideBySide ? cardWidth : undefined}\n />\n </WidgetErrorBoundary>\n </div>\n </WidgetThemeProvider>\n </WidgetConfigContext.Provider>\n </AoriClientProvider>\n );\n\n if (walletModalValue) {\n return (\n <WalletModalContext.Provider value={walletModalValue}>\n {inner}\n </WalletModalContext.Provider>\n );\n }\n\n return inner;\n}\n","'use client';\n\nimport type { SupportedChainId } from '../internal/types';\nimport { Suspense, lazy, useCallback, useEffect, useRef, useState } from 'react';\nimport { useShallow } from 'zustand/react/shallow';\nimport { useWidgetConfig } from '../context/WidgetConfigContext';\nimport { useBalanceEventSubscription } from '../hooks/useBalanceEventListener';\nimport { RfqProvider, useRfq } from '../providers/RfqProvider';\nimport {\n SwapFormProvider,\n useSwapFormContext,\n} from '../providers/SwapFormProvider';\nimport {\n type TransitionType,\n type WidgetView,\n useWidgetSwapUIStore,\n} from '../stores/swapUIStore';\nimport { useWalletState } from '../wallet/useWalletState';\nimport SwapForm from './SwapForm';\nimport { SwapFormSkeleton } from './SwapFormSkeleton';\nimport SwapHeader from './SwapHeader';\n\nconst AssetSelectionMenu = lazy(() => import('./AssetSelectionMenu'));\nconst ChainSelectionMenu = lazy(() => import('./ChainSelectionMenu'));\nconst SwapFormHorizontal = lazy(() => import('./SwapFormHorizontal'));\nconst SwapFormSplit = lazy(() => import('./SwapFormSplit'));\nconst WidgetWalletPanel = lazy(() => import('./WidgetWalletPanel').then(m => ({ default: m.WidgetWalletPanel })));\nconst WalletPlaceholderPanel = lazy(() => import('./WalletPlaceholderPanel').then(m => ({ default: m.WalletPlaceholderPanel })));\n\ninterface SwapContainerProps {\n onSwapComplete?: (orderHash: string) => void;\n defaultBaseToken?: { chainId: number; address: string };\n defaultQuoteToken?: { chainId: number; address: string };\n onBaseTokenChange?: (token: import('../internal/types').Asset) => void;\n onQuoteTokenChange?: (token: import('../internal/types').Asset) => void;\n // Passed from SwapWidget when isSplitSideBySide — each card renders its own styling\n cardStyles?: React.CSSProperties;\n cardWidth?: string;\n}\n\nconst SwapContainerInner: React.FC<SwapContainerProps> = ({\n onSwapComplete,\n cardStyles,\n cardWidth,\n}) => {\n const {\n baseToken,\n quoteToken,\n baseAmount,\n quoteAmount,\n isWrappingPair,\n isUnwrappingPair,\n isRegistryLoading,\n } = useSwapFormContext();\n const { liquidityError, routingError, sizeCapError, stop, clear } = useRfq();\n\n const view = useWidgetSwapUIStore((state) => state.view);\n const {\n isTransitioning,\n isRecipientInputOpen,\n recipient,\n selectedChainFilterChainId,\n } = useWidgetSwapUIStore(\n useShallow((state) => ({\n isTransitioning: state.isTransitioning,\n isRecipientInputOpen: state.isRecipientInputOpen,\n recipient: state.recipient,\n selectedChainFilterChainId: state.selectedChainFilter?.chainId ?? null,\n })),\n );\n\n const enterTimeoutRef = useRef<NodeJS.Timeout | null>(null);\n const exitTimeoutRef = useRef<NodeJS.Timeout | null>(null);\n const [exitingOverlay, setExitingOverlay] = useState<WidgetView | null>(null);\n\n useBalanceEventSubscription();\n\n useEffect(() => {\n return () => {\n if (enterTimeoutRef.current) clearTimeout(enterTimeoutRef.current);\n if (exitTimeoutRef.current) clearTimeout(exitTimeoutRef.current);\n };\n }, []);\n\n useEffect(() => {\n useWidgetSwapUIStore.getState().resetUI();\n }, []);\n\n useEffect(() => {\n if (!isTransitioning) return;\n\n enterTimeoutRef.current = setTimeout(() => {\n useWidgetSwapUIStore.getState().setIsTransitioning(false);\n enterTimeoutRef.current = null;\n }, 20);\n\n return () => {\n if (enterTimeoutRef.current) {\n clearTimeout(enterTimeoutRef.current);\n enterTimeoutRef.current = null;\n }\n };\n }, [isTransitioning]);\n\n const transitionToView = useCallback(\n (newView: WidgetView, type: TransitionType = 'navigation') => {\n if (exitTimeoutRef.current) {\n clearTimeout(exitTimeoutRef.current);\n exitTimeoutRef.current = null;\n setExitingOverlay(null);\n }\n\n const currentView = useWidgetSwapUIStore.getState().view;\n if (currentView !== 'swap' && newView !== 'swap') {\n useWidgetSwapUIStore.getState().setView(newView);\n useWidgetSwapUIStore.getState().setIsTransitioning(false);\n } else {\n useWidgetSwapUIStore.getState().transitionToView(newView, type);\n }\n },\n [],\n );\n\n const handleBackToSwap = useCallback(() => {\n if (enterTimeoutRef.current) {\n clearTimeout(enterTimeoutRef.current);\n enterTimeoutRef.current = null;\n }\n if (exitTimeoutRef.current) {\n clearTimeout(exitTimeoutRef.current);\n exitTimeoutRef.current = null;\n }\n\n const currentView = useWidgetSwapUIStore.getState().view;\n setExitingOverlay(currentView);\n\n useWidgetSwapUIStore.getState().setChainFilter(null);\n useWidgetSwapUIStore.getState().setView('swap');\n useWidgetSwapUIStore.getState().setIsTransitioning(false);\n useWidgetSwapUIStore.getState().resetAssetSelection();\n\n exitTimeoutRef.current = setTimeout(() => {\n setExitingOverlay(null);\n exitTimeoutRef.current = null;\n }, 200);\n }, []);\n\n const handleChainFilterSelect = useCallback(\n (chainId: SupportedChainId) => {\n const previousView = view;\n const side = previousView === 'baseChainSelection' ? 'base' : 'quote';\n useWidgetSwapUIStore.getState().setChainFilter({ chainId, side });\n useWidgetSwapUIStore.getState().pushRecentChain(chainId);\n transitionToView(\n side === 'base' ? 'baseSelection' : 'quoteSelection',\n 'chainSelection',\n );\n },\n [view, transitionToView],\n );\n\n const handleMoreChainsClick = useCallback(() => {\n const currentView = useWidgetSwapUIStore.getState().view;\n if (currentView === 'baseSelection') {\n transitionToView('baseChainSelection', 'chainSelection');\n } else if (currentView === 'quoteSelection') {\n transitionToView('quoteChainSelection', 'chainSelection');\n }\n }, [transitionToView]);\n\n // Called by ReviewActionSignAndSubmitOrderRow after a swap is submitted.\n // Stops and fully clears the RFQ so no stale quote lingers post-submission.\n const handleSwapInitiated = useCallback(() => {\n stop();\n clear();\n }, [stop, clear]);\n\n const isSameChain =\n baseToken && quoteToken ? baseToken.chainId === quoteToken.chainId : true;\n\n const getHeaderText = () => {\n switch (view) {\n case 'wallet':\n return 'Wallet';\n case 'baseSelection':\n return 'Select Input Token';\n case 'quoteSelection':\n return 'Select Output Token';\n case 'baseChainSelection':\n case 'quoteChainSelection':\n return 'Select Chain';\n default:\n return 'Swap';\n }\n };\n\n const { assetMenuVariant, widgetType, customWalletUI } = useWidgetConfig();\n\n const isTokenSelection =\n view === 'baseSelection' || view === 'quoteSelection';\n const isChainSelection =\n view === 'baseChainSelection' || view === 'quoteChainSelection';\n\n const isSideBySide =\n assetMenuVariant === 'split' &&\n (widgetType === 'default' || widgetType === 'compact');\n const isInlineMenu =\n assetMenuVariant === 'split' &&\n (widgetType === 'horizontal' || widgetType === 'split');\n\n const isPanelMode = assetMenuVariant === 'default';\n const showSwapForm =\n view === 'swap' ||\n isTokenSelection ||\n isChainSelection ||\n view === 'wallet';\n\n const isTokenSelectionExiting =\n exitingOverlay === 'baseSelection' || exitingOverlay === 'quoteSelection';\n const isChainSelectionExiting =\n exitingOverlay === 'baseChainSelection' ||\n exitingOverlay === 'quoteChainSelection';\n\n const showTokenOverlay = isTokenSelection || isTokenSelectionExiting;\n const showChainOverlay = isChainSelection || isChainSelectionExiting;\n\n const isTokenOverlayActive = isTokenSelection && !isTransitioning;\n const isChainOverlayActive = isChainSelection && !isTransitioning;\n\n const effectiveTokenView = isTokenSelection ? view : exitingOverlay;\n const menuSide = effectiveTokenView === 'baseSelection' ? 'base' : 'quote';\n const menuOtherAsset =\n effectiveTokenView === 'baseSelection' ? quoteToken : baseToken;\n\n const effectiveChainView = isChainSelection ? view : exitingOverlay;\n const chainMenuSide =\n effectiveChainView === 'baseChainSelection' ? 'base' : 'quote';\n\n const overlayStyle = (isActive: boolean): React.CSSProperties => ({\n backgroundColor: 'var(--widget-background)',\n opacity: isActive ? 1 : 0,\n transform: isActive ? 'translateY(0)' : 'translateY(6px)',\n transition: 'opacity 200ms ease-in-out, transform 200ms ease-in-out',\n });\n\n const hasActiveOverlay =\n isPanelMode &&\n (isTokenSelection ||\n isChainSelection ||\n view === 'wallet' ||\n exitingOverlay != null);\n\n const formContent = isRegistryLoading ? (\n <SwapFormSkeleton />\n ) : widgetType === 'horizontal' ? (\n <Suspense fallback={null}>\n <SwapFormHorizontal\n onSwapComplete={onSwapComplete}\n onSwapInitiated={handleSwapInitiated}\n onBackToSwap={isInlineMenu ? handleBackToSwap : undefined}\n onMoreChainsClick={isInlineMenu ? handleMoreChainsClick : undefined}\n />\n </Suspense>\n ) : widgetType === 'split' ? (\n <Suspense fallback={null}>\n <SwapFormSplit\n onSwapComplete={onSwapComplete}\n onSwapInitiated={handleSwapInitiated}\n onBackToSwap={isInlineMenu ? handleBackToSwap : undefined}\n onMoreChainsClick={isInlineMenu ? handleMoreChainsClick : undefined}\n />\n </Suspense>\n ) : (\n <SwapForm onSwapComplete={onSwapComplete} onSwapInitiated={handleSwapInitiated} />\n );\n\n // When isSideBySide, cardStyles/cardWidth are passed from SwapWidget.\n // Each card renders its own border/bg/radius; the outer widget div is transparent.\n const cs = cardStyles ?? {};\n\n // Measure the left (form) card height so the right (selection) card matches exactly.\n const leftCardRef = useRef<HTMLDivElement>(null);\n const [leftCardHeight, setLeftCardHeight] = useState<number>(420);\n\n useEffect(() => {\n if (!isSideBySide) return;\n const el = leftCardRef.current;\n if (!el) return;\n const observer = new ResizeObserver((entries) => {\n for (const entry of entries) {\n setLeftCardHeight(entry.contentRect.height);\n }\n });\n observer.observe(el);\n return () => observer.disconnect();\n }, [isSideBySide]);\n\n if (isSideBySide) {\n return (\n <>\n {/* ── Left card: the swap form ─────────────────── */}\n <div\n ref={leftCardRef}\n className=\"flex flex-col w-full overflow-hidden transition-colors duration-300\"\n style={{\n flex: '1 1 0',\n minWidth: 0,\n ...cs,\n }}\n >\n <SwapHeader\n headerText=\"Swap\"\n onBackClick={handleBackToSwap}\n isSameChain={isSameChain}\n isWrappingPair={isWrappingPair}\n isUnwrappingPair={isUnwrappingPair}\n hasLowLiquidity={liquidityError}\n hasInsufficientLiquidity={liquidityError}\n hasRoutingError={routingError}\n hasSizeCapError={sizeCapError}\n />\n <div className=\"overflow-hidden\">{formContent}</div>\n </div>\n\n {/* ── Right card: selection panel, height explicitly matched to the form card ─── */}\n {(showTokenOverlay || showChainOverlay) && (\n <div\n className=\"flex flex-col overflow-hidden shrink-0\"\n style={{\n width: cardWidth,\n height: `${leftCardHeight}px`,\n ...cs,\n ...(overlayStyle(\n (isTokenSelection || isChainSelection) && !isTransitioning,\n )),\n }}\n >\n {(isTokenSelection || isTokenSelectionExiting) ? (\n <Suspense fallback={null}>\n <AssetSelectionMenu\n toggle={handleBackToSwap}\n side={menuSide}\n otherAsset={menuOtherAsset}\n onMoreChainsClick={handleMoreChainsClick}\n selectedChainFilter={selectedChainFilterChainId}\n />\n </Suspense>\n ) : (\n <Suspense fallback={null}>\n <ChainSelectionMenu\n toggle={handleBackToSwap}\n side={chainMenuSide}\n onChainSelect={handleChainFilterSelect}\n />\n </Suspense>\n )}\n </div>\n )}\n </>\n );\n }\n\n return (\n <div\n className=\"flex flex-col w-full\"\n style={{\n overflow: 'hidden',\n position: 'relative',\n }}\n >\n <SwapHeader\n headerText={getHeaderText()}\n onBackClick={handleBackToSwap}\n isSameChain={isSameChain}\n isWrappingPair={isWrappingPair}\n isUnwrappingPair={isUnwrappingPair}\n hasLowLiquidity={liquidityError}\n hasInsufficientLiquidity={liquidityError}\n hasRoutingError={routingError}\n hasSizeCapError={sizeCapError}\n />\n\n <div className=\"relative overflow-hidden\">\n {showSwapForm && (\n <div\n className=\"overflow-hidden\"\n style={hasActiveOverlay ? { pointerEvents: 'none' } : undefined}\n >\n {formContent}\n </div>\n )}\n\n {(view === 'wallet' || exitingOverlay === 'wallet') && (\n <div\n className=\"absolute inset-0 overflow-hidden\"\n style={overlayStyle(view === 'wallet' && !isTransitioning)}\n >\n <Suspense fallback={null}>\n {customWalletUI === 'none' ? <WalletPlaceholderPanel /> : <WidgetWalletPanel />}\n </Suspense>\n </div>\n )}\n\n {isPanelMode && showTokenOverlay && (\n <div\n className=\"absolute inset-0 overflow-hidden\"\n style={overlayStyle(isTokenOverlayActive)}\n >\n <Suspense fallback={null}>\n <AssetSelectionMenu\n toggle={handleBackToSwap}\n side={menuSide}\n otherAsset={menuOtherAsset}\n onMoreChainsClick={handleMoreChainsClick}\n selectedChainFilter={selectedChainFilterChainId}\n />\n </Suspense>\n </div>\n )}\n\n {isPanelMode && showChainOverlay && (\n <div\n className=\"absolute inset-0 overflow-hidden\"\n style={overlayStyle(isChainOverlayActive)}\n >\n <Suspense fallback={null}>\n <ChainSelectionMenu\n toggle={handleBackToSwap}\n side={chainMenuSide}\n onChainSelect={handleChainFilterSelect}\n />\n </Suspense>\n </div>\n )}\n </div>\n </div>\n );\n};\n\nexport const SwapContainer: React.FC<SwapContainerProps> = ({\n onSwapComplete,\n defaultBaseToken,\n defaultQuoteToken,\n onBaseTokenChange,\n onQuoteTokenChange,\n cardStyles,\n cardWidth,\n}) => {\n const { address: userAddress } = useWalletState();\n const recipient = useWidgetSwapUIStore((s) => s.recipient);\n\n return (\n <SwapFormProvider\n defaultBaseToken={defaultBaseToken}\n defaultQuoteToken={defaultQuoteToken}\n onBaseTokenChange={onBaseTokenChange}\n onQuoteTokenChange={onQuoteTokenChange}\n >\n <RfqProvider recipient={recipient}>\n <SwapContainerInner\n onSwapComplete={onSwapComplete}\n cardStyles={cardStyles}\n cardWidth={cardWidth}\n />\n </RfqProvider>\n </SwapFormProvider>\n );\n};\n","'use client';\n\nimport { type Asset, type ReviewOrderStep } from '../internal';\nimport { useWalletModal } from '../wallet/WalletModalContext';\nimport React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { useShallow } from 'zustand/react/shallow';\nimport { useWidgetConfig } from '../context/WidgetConfigContext';\nimport { useRfq } from '../providers/RfqProvider';\nimport { useSwapFormContext } from '../providers/SwapFormProvider';\nimport { useWidgetSwapUIStore } from '../stores/swapUIStore';\nimport { useWalletState } from '../wallet/useWalletState';\nimport AssetAmountInput from './AssetAmountInput';\nimport AssetSelection from './AssetSelection';\nimport QuoteLoader from './QuoteLoader';\nimport RecipientForm from './RecipientForm';\nimport { SwapButton } from './states/SwapButton';\nimport TxStatusDisplay from './states/TxStatusDisplay';\n\ninterface ReviewActionProps {\n base: Asset;\n quote: Asset;\n baseAmount: number;\n quoteAmount: number;\n userAddress: string;\n}\n\ninterface SwapFormProps {\n onSwapComplete?: (orderHash: string) => void;\n onSwapInitiated?: () => void;\n}\n\nconst SwapForm: React.FC<SwapFormProps> = ({ onSwapComplete, onSwapInitiated }) => {\n const {\n web3ConnectionType,\n hasConnectHandler,\n lockBase,\n lockQuote,\n disableInverting,\n tokenDisplay,\n tokenBadgeOrientation,\n widgetType,\n } = useWidgetConfig();\n const isOverlayToken = tokenDisplay === 'pill' || tokenDisplay === 'ghost';\n const isCompactMode = widgetType === 'compact';\n const basePadding = isCompactMode ? 'px-4 pt-3 pb-1' : 'px-4 pt-4 pb-2';\n const quotePadding = isCompactMode ? 'px-4 pt-4 pb-1' : 'px-4 pt-6 pb-2';\n const {\n baseToken,\n quoteToken,\n baseAmount,\n quoteAmount,\n isBaseGasToken,\n isQuoteGasToken,\n isWrappingPair,\n isUnwrappingPair,\n baseBalance,\n quoteBalance,\n setBaseAmount,\n setQuoteAmount,\n swapTokens,\n clearForm,\n } = useSwapFormContext();\n\n const {\n rfqQuote,\n status: rfqStatus,\n handleInputChange,\n ensureForParams,\n stop,\n clear,\n refresh,\n } = useRfq();\n const { address: userAddress } = useWalletState();\n const { openConnectModal: openWalletModal } = useWalletModal();\n const { isRecipientInputOpen, txStatus } =\n useWidgetSwapUIStore(\n useShallow((state) => ({\n isRecipientInputOpen: state.isRecipientInputOpen,\n txStatus: state.txStatus,\n })),\n );\n\n const [reviewState, setReviewState] = useState<ReviewOrderStep | null>(null);\n const [trackedOrderHash, setTrackedOrderHash] = useState<string | null>(null);\n const isHandlingStaleRestart = useRef(false);\n const isPlacingOrder = false;\n\n const reviewActionProps = useMemo((): ReviewActionProps | null => {\n if (!baseToken || !quoteToken || typeof baseAmount !== 'number' || !quoteAmount || !userAddress) return null;\n if (parseFloat(baseBalance.formatted) < baseAmount) return null;\n return { base: baseToken, quote: quoteToken, baseAmount, quoteAmount, userAddress };\n }, [baseToken, quoteToken, baseAmount, quoteAmount, userAddress, baseBalance.formatted]);\n\n // Called by ReviewActionSignAndSubmitOrderRow on successful submission.\n const onOrderSubmitted = useCallback((orderHash: string) => {\n setTrackedOrderHash(orderHash);\n useWidgetSwapUIStore.getState().startTracking(orderHash);\n }, []);\n\n // Called by SwapButton on stale-quote restart — marks the restart so we\n // don't accidentally double-poll and calls refresh() to get a fresh quote.\n const onStaleQuoteRestart = useCallback(() => {\n isHandlingStaleRestart.current = true;\n refresh();\n }, [refresh]);\n\n useEffect(() => {\n if (reviewState !== null) return;\n if (!baseToken || !quoteToken) return;\n if (!baseAmount || baseAmount <= 0) {\n handleInputChange({ amount: null, inputToken: baseToken, outputToken: quoteToken, setOutputAmount: setQuoteAmount });\n return;\n }\n if (isWrappingPair || isUnwrappingPair) {\n setQuoteAmount(baseAmount);\n return;\n }\n handleInputChange({\n amount: baseAmount,\n inputToken: baseToken,\n outputToken: quoteToken,\n setOutputAmount: setQuoteAmount,\n });\n }, [\n reviewState,\n baseAmount,\n baseToken,\n quoteToken,\n isWrappingPair,\n isUnwrappingPair,\n handleInputChange,\n setQuoteAmount,\n ]);\n\n const handleToggleBaseSelection = useCallback(() => {\n useWidgetSwapUIStore.getState().setView('baseSelection');\n }, []);\n\n const handleToggleQuoteSelection = useCallback(() => {\n useWidgetSwapUIStore.getState().setView('quoteSelection');\n }, []);\n\n const handleInvert = useCallback(() => {\n swapTokens();\n setQuoteAmount(null);\n }, [swapTokens, setQuoteAmount]);\n\n const handleMax = useCallback(() => {\n if (!baseBalance.formatted || !baseToken || !quoteToken) return;\n const balNum = parseFloat(baseBalance.formatted);\n if (!balNum || balNum <= 0) return;\n const adjusted = balNum * 0.9999999999;\n if (isWrappingPair || isUnwrappingPair) {\n setBaseAmount(adjusted);\n setQuoteAmount(adjusted);\n clear();\n } else {\n setBaseAmount(adjusted);\n setQuoteAmount(null);\n ensureForParams({\n inputToken: baseToken,\n outputToken: quoteToken,\n inputAmount: adjusted.toString(),\n setOutputAmount: (amount) => setQuoteAmount(amount),\n });\n }\n }, [\n baseBalance.formatted,\n baseToken,\n quoteToken,\n isWrappingPair,\n isUnwrappingPair,\n setBaseAmount,\n setQuoteAmount,\n clear,\n ensureForParams,\n ]);\n\n const handleClear = useCallback(() => {\n clear();\n clearForm();\n }, [clear, clearForm]);\n\n const baseBalanceNum = baseBalance.formatted\n ? parseFloat(baseBalance.formatted)\n : null;\n const hasAmount = !!(baseAmount || quoteAmount);\n\n const baseUsd =\n baseToken?.price && baseAmount\n ? `$${(baseToken.price * baseAmount).toFixed(2)}`\n : '$0.00';\n const quoteUsd =\n quoteToken?.price && quoteAmount\n ? `$${(quoteToken.price * quoteAmount).toFixed(2)}`\n : '$0.00';\n\n const isShowingTxStatus =\n reviewState === 'trackingTx' &&\n !!trackedOrderHash &&\n !!baseToken &&\n !!quoteToken &&\n !!baseAmount &&\n !!quoteAmount;\n\n return (\n <div className=\"flex flex-col w-full\">\n {isShowingTxStatus &&\n trackedOrderHash &&\n baseToken &&\n quoteToken &&\n baseAmount &&\n quoteAmount ? (\n /* ── TX STATUS (replaces token sections during tracking) ── */\n <div className=\"overflow-hidden\">\n <TxStatusDisplay\n orderHash={trackedOrderHash}\n base={baseToken}\n quote={quoteToken}\n baseAmount={baseAmount}\n quoteAmount={quoteAmount}\n status={txStatus}\n />\n </div>\n ) : (\n <>\n {/* ── BASE TOKEN SECTION ───────────────────────────── */}\n <div\n className={`relative ${basePadding}`}\n style={{ borderBottom: '1px solid var(--widget-border)' }}\n >\n {isOverlayToken ? (\n isCompactMode ? (\n // compact + pill/ghost: side-by-side row, badge on side\n <div\n className={`flex items-center gap-2 mb-2 ${tokenBadgeOrientation === 'right' ? 'flex-row-reverse' : 'flex-row'}`}\n >\n <AssetSelection\n toggle={handleToggleBaseSelection}\n side=\"base\"\n asset={baseToken}\n isPlacingOrder={isPlacingOrder || lockBase}\n />\n <div className=\"flex-1 min-w-0\">\n <AssetAmountInput\n side=\"base\"\n asset={baseToken ?? null}\n otherAsset={quoteToken ?? null}\n isPlacingOrder={isPlacingOrder}\n isWrappingPair={isWrappingPair}\n isUnwrappingPair={isUnwrappingPair}\n />\n </div>\n </div>\n ) : (\n // default + pill/ghost: badge stacked above input, aligned to chosen side\n <div\n className={`flex flex-col ${tokenBadgeOrientation === 'right' ? 'items-end' : 'items-start'}`}\n >\n <AssetSelection\n toggle={handleToggleBaseSelection}\n side=\"base\"\n asset={baseToken}\n isPlacingOrder={isPlacingOrder || lockBase}\n />\n <AssetAmountInput\n side=\"base\"\n asset={baseToken ?? null}\n otherAsset={quoteToken ?? null}\n isPlacingOrder={isPlacingOrder}\n isWrappingPair={isWrappingPair}\n isUnwrappingPair={isUnwrappingPair}\n />\n </div>\n )\n ) : (\n <>\n <AssetSelection\n toggle={handleToggleBaseSelection}\n side=\"base\"\n asset={baseToken}\n isPlacingOrder={isPlacingOrder || lockBase}\n />\n <AssetAmountInput\n side=\"base\"\n asset={baseToken ?? null}\n otherAsset={quoteToken ?? null}\n isPlacingOrder={isPlacingOrder}\n isWrappingPair={isWrappingPair}\n isUnwrappingPair={isUnwrappingPair}\n />\n </>\n )}\n\n {/* USD value + MAX button */}\n <div className=\"mb-1 flex w-full flex-row items-center justify-between\">\n <p\n className=\"mono text-sm\"\n style={{ color: 'var(--widget-muted-foreground)' }}\n >\n {baseUsd}\n </p>\n {userAddress && baseBalanceNum !== null && baseBalanceNum > 0 && (\n <button\n type=\"button\"\n onClick={handleMax}\n disabled={isPlacingOrder}\n className=\"absolute bottom-3 right-4 flex items-center px-3 py-0.5 text-xs font-medium uppercase cursor-pointer disabled:opacity-40 disabled:cursor-not-allowed transition-colors bg-(--widget-primary) text-(--widget-primary-foreground) hover:bg-(--widget-foreground) hover:text-(--widget-card)\"\n style={{ borderRadius: 'var(--widget-radius)' }}\n >\n Max\n </button>\n )}\n </div>\n </div>\n\n {/* ── INVERT BUTTON (centered on border) ───────────── */}\n {!disableInverting && (\n <div className=\"flex justify-center -my-4 relative z-10\">\n <button\n type=\"button\"\n onClick={handleInvert}\n aria-label=\"Swap input and output tokens\"\n className=\"flex h-8 w-8 items-center justify-center rounded-full cursor-pointer transition-colors bg-(--widget-card) text-(--widget-muted-foreground) hover:bg-(--widget-secondary) hover:text-(--widget-foreground)\"\n style={{ border: '1px solid var(--widget-border)' }}\n >\n <span className=\"text-2xs\">↑</span>\n <span className=\"text-2xs\">↓</span>\n </button>\n </div>\n )}\n\n {/* ── QUOTE TOKEN SECTION ──────────────────────────── */}\n <div className={`relative ${quotePadding}`}>\n {isOverlayToken ? (\n isCompactMode ? (\n <div\n className={`flex items-center gap-2 ${tokenBadgeOrientation === 'right' ? 'flex-row-reverse' : 'flex-row'}`}\n >\n <AssetSelection\n toggle={handleToggleQuoteSelection}\n side=\"quote\"\n asset={quoteToken}\n isPlacingOrder={isPlacingOrder || lockQuote}\n />\n <div className=\"flex-1 min-w-0\">\n <AssetAmountInput\n side=\"quote\"\n asset={quoteToken ?? null}\n otherAsset={baseToken ?? null}\n isPlacingOrder={isPlacingOrder}\n isWrappingPair={isWrappingPair}\n isUnwrappingPair={isUnwrappingPair}\n />\n </div>\n </div>\n ) : (\n <div\n className={`flex flex-col ${tokenBadgeOrientation === 'right' ? 'items-end' : 'items-start'}`}\n >\n <AssetSelection\n toggle={handleToggleQuoteSelection}\n side=\"quote\"\n asset={quoteToken}\n isPlacingOrder={isPlacingOrder || lockQuote}\n />\n <AssetAmountInput\n side=\"quote\"\n asset={quoteToken ?? null}\n otherAsset={baseToken ?? null}\n isPlacingOrder={isPlacingOrder}\n isWrappingPair={isWrappingPair}\n isUnwrappingPair={isUnwrappingPair}\n />\n </div>\n )\n ) : (\n <>\n <AssetSelection\n toggle={handleToggleQuoteSelection}\n side=\"quote\"\n asset={quoteToken}\n isPlacingOrder={isPlacingOrder || lockQuote}\n />\n <AssetAmountInput\n side=\"quote\"\n asset={quoteToken ?? null}\n otherAsset={baseToken ?? null}\n isPlacingOrder={isPlacingOrder}\n isWrappingPair={isWrappingPair}\n isUnwrappingPair={isUnwrappingPair}\n />\n </>\n )}\n\n {/* USD value + CLEAR button */}\n <div className=\"flex w-full flex-row items-center justify-between\">\n <p\n className=\"mono text-sm\"\n style={{ color: 'var(--widget-muted-foreground)' }}\n >\n {quoteUsd}\n </p>\n {hasAmount && (\n <button\n type=\"button\"\n onClick={handleClear}\n disabled={isPlacingOrder}\n className=\"absolute bottom-2 right-4 flex items-center px-3 py-0.5 text-xs font-medium uppercase cursor-pointer disabled:opacity-40 disabled:cursor-not-allowed transition-colors text-(--widget-muted-foreground) hover:bg-(--widget-secondary)\"\n style={{ borderRadius: 'var(--widget-radius)' }}\n >\n Clear\n </button>\n )}\n </div>\n </div>\n\n {/* ── RECIPIENT FORM (animated maxHeight, always mounted) ── */}\n <div\n className=\"flex flex-row items-center w-full overflow-hidden\"\n style={{\n borderTop: isRecipientInputOpen\n ? '1px solid var(--widget-border)'\n : 'none',\n maxHeight: isRecipientInputOpen ? '60px' : '0px',\n opacity: isRecipientInputOpen ? 1 : 0,\n transition: 'max-height 0.3s ease, opacity 0.3s ease',\n }}\n >\n <RecipientForm />\n </div>\n\n {/* ── QUOTE LOADER with borders ── */}\n <div\n className=\"px-4\"\n style={{\n borderTop: '1px solid var(--widget-border)',\n borderBottom: '1px solid var(--widget-border)',\n }}\n >\n <QuoteLoader />\n </div>\n </>\n )}\n\n {/* ── SWAP / CONNECT BUTTON ─────────────────────────── */}\n <div className={`relative ${isShowingTxStatus ? 'px-0' : 'px-4'} ${isCompactMode ? 'py-2' : 'py-4'}`}>\n {userAddress &&\n baseToken &&\n quoteToken &&\n baseAmount &&\n baseAmount > 0 ? (\n <SwapButton\n base={baseToken}\n baseAmount={baseAmount}\n quote={quoteToken}\n quoteAmount={quoteAmount ?? 0}\n userAddress={userAddress}\n isWrappingPair={isWrappingPair}\n isUnwrappingPair={isUnwrappingPair}\n isBaseGasToken={isBaseGasToken}\n isQuoteGasToken={isQuoteGasToken}\n reviewActionProps={reviewActionProps}\n reviewState={reviewState}\n setReviewState={setReviewState}\n trackedOrderHash={trackedOrderHash}\n setTrackedOrderHash={setTrackedOrderHash}\n onSwapComplete={onSwapComplete}\n onSwapInitiated={onSwapInitiated}\n onOrderSubmitted={onOrderSubmitted}\n onStaleQuoteRestart={onStaleQuoteRestart}\n txStatus={txStatus}\n />\n ) : !userAddress && hasConnectHandler ? (\n <button\n onClick={() => openWalletModal()}\n className={`w-full ${isCompactMode ? 'py-2' : 'py-3'} text-sm font-medium cursor-pointer transition-opacity hover:opacity-80`}\n style={{\n backgroundColor: 'var(--widget-primary)',\n color: 'var(--widget-primary-foreground)',\n borderRadius: 'var(--widget-radius)',\n }}\n >\n Connect Wallet\n </button>\n ) : (\n <button\n disabled\n className={`w-full ${isCompactMode ? 'py-2' : 'py-3'} text-sm font-medium transition-colors disabled:opacity-40 cursor-not-allowed`}\n style={{\n backgroundColor: 'var(--widget-primary)',\n color: 'var(--widget-primary-foreground)',\n borderRadius: 'var(--widget-radius)',\n }}\n >\n {!userAddress ? 'Connect Wallet' : 'Enter Amount'}\n </button>\n )}\n </div>\n </div>\n );\n};\n\nexport default SwapForm;\n","'use client';\n\nimport React from 'react';\n\nexport const SwapFormSkeleton: React.FC = () => (\n <div className=\"flex flex-col w-full\">\n {/* Base section */}\n <div\n className=\"relative px-4 pt-4 pb-2\"\n style={{ borderBottom: '1px solid var(--widget-border)' }}\n >\n {/* Token selector row */}\n <div\n className=\"h-12 w-full animate-pulse\"\n style={{ backgroundColor: 'var(--widget-secondary)', borderRadius: '0.25rem' }}\n />\n {/* Amount input area */}\n <div\n className=\"mt-2 h-20 w-2/3 animate-pulse\"\n style={{ backgroundColor: 'var(--widget-secondary)', opacity: 0.5, borderRadius: '0.25rem' }}\n />\n {/* USD value row */}\n <div className=\"mt-1 mb-1 flex w-full items-center justify-between\">\n <div\n className=\"h-4 w-12 animate-pulse\"\n style={{ backgroundColor: 'var(--widget-secondary)', opacity: 0.4, borderRadius: '0.25rem' }}\n />\n </div>\n </div>\n\n {/* Invert button (centered on border) */}\n <div className=\"flex justify-center -my-4 relative z-10\">\n <div\n className=\"h-8 w-8\"\n style={{\n border: '1px solid var(--widget-border)',\n backgroundColor: 'var(--widget-card)',\n borderRadius: '9999px',\n }}\n />\n </div>\n\n {/* Quote section */}\n <div className=\"relative px-4 pt-6 pb-2\">\n {/* Token selector row */}\n <div\n className=\"h-12 w-full animate-pulse\"\n style={{ backgroundColor: 'var(--widget-secondary)', borderRadius: '0.25rem' }}\n />\n {/* Amount input area */}\n <div\n className=\"mt-2 h-20 w-2/3 animate-pulse\"\n style={{ backgroundColor: 'var(--widget-secondary)', opacity: 0.5, borderRadius: '0.25rem' }}\n />\n {/* USD value row */}\n <div className=\"mt-1 mb-1 flex w-full items-center justify-between\">\n <div\n className=\"h-4 w-12 animate-pulse\"\n style={{ backgroundColor: 'var(--widget-secondary)', opacity: 0.4, borderRadius: '0.25rem' }}\n />\n </div>\n </div>\n\n {/* Quote loader bar */}\n <div\n className=\"px-4\"\n style={{\n height: '28px',\n borderTop: '1px solid var(--widget-border)',\n borderBottom: '1px solid var(--widget-border)',\n }}\n />\n\n {/* Swap button */}\n <div className=\"relative px-4 py-4\">\n <div\n className=\"w-full animate-pulse\"\n style={{\n height: '44px',\n backgroundColor: 'var(--widget-secondary)',\n borderRadius: 'var(--widget-radius)',\n opacity: 0.6,\n }}\n />\n </div>\n </div>\n);\n","'use client';\n\nimport { useTextScramble } from '../internal/hooks/useTextScramble';\nimport { useWalletState } from '../wallet/useWalletState';\nimport { useWalletModal } from '../wallet/WalletModalContext';\nimport { useEffect, useState } from 'react';\nimport { useShallow } from 'zustand/react/shallow';\nimport { useWidgetConfig } from '../context/WidgetConfigContext';\nimport { useWidgetSwapUIStore } from '../stores/swapUIStore';\n\ninterface SwapHeaderProps {\n headerText: string;\n onBackClick?: () => void;\n isSameChain?: boolean;\n isWrappingPair?: boolean;\n isUnwrappingPair?: boolean;\n hasLowLiquidity?: boolean;\n hasInsufficientLiquidity?: boolean;\n hasRoutingError?: boolean;\n hasSizeCapError?: boolean;\n}\n\nconst TextScrambleDisplay = ({\n targetText,\n isError,\n}: {\n targetText: string;\n isError: boolean;\n}) => {\n const { displayText, suffix, characterColors } = useTextScramble(\n targetText,\n isError,\n );\n\n return (\n <>\n {displayText.split('').map((char, index) => (\n <span\n key={index}\n style={\n characterColors[index]\n ? { color: 'var(--widget-destructive)' }\n : undefined\n }\n >\n {char}\n </span>\n ))}\n <span\n style={{\n color: isError\n ? 'var(--widget-destructive)'\n : 'var(--widget-muted-foreground)',\n opacity: isError ? 0.5 : 1,\n }}\n >\n {suffix}\n </span>\n </>\n );\n};\n\nconst SwapHeader: React.FC<SwapHeaderProps> = ({\n headerText,\n onBackClick,\n isSameChain,\n isWrappingPair,\n isUnwrappingPair,\n hasLowLiquidity,\n hasInsufficientLiquidity,\n hasRoutingError,\n hasSizeCapError,\n}) => {\n const view = useWidgetSwapUIStore((state) => state.view);\n\n const {\n isRecipientInputOpen,\n hasAllowanceError,\n hoveredChainName,\n isTrackingTx,\n txStatus,\n walletTab,\n } = useWidgetSwapUIStore(\n useShallow((state) => ({\n isRecipientInputOpen: state.isRecipientInputOpen,\n hasAllowanceError: state.hasAllowanceError,\n hoveredChainName: state.hoveredChainName,\n isTrackingTx: state.isTrackingTx,\n txStatus: state.txStatus,\n walletTab: state.walletTab,\n })),\n );\n\n const { web3ConnectionType, swapHeaderVariant, customWalletUI, walletButtonEnabled } = useWidgetConfig();\n const { isConnected } = useWalletState();\n const { openAccountModal } = useWalletModal();\n\n const [mounted, setMounted] = useState(false);\n useEffect(() => setMounted(true), []);\n\n const [isRecipientButtonHovered, setIsRecipientButtonHovered] =\n useState(false);\n\n const scrambleKey = `${view}-${isRecipientButtonHovered}-${isRecipientInputOpen}-${hoveredChainName || 'none'}`;\n\n const getHeaderText = () => {\n if (isTrackingTx && txStatus) {\n switch (txStatus) {\n case 'pending':\n return 'Trade Pending';\n case 'received':\n return 'Trade Received';\n case 'completed':\n return 'Trade Filled';\n case 'failed':\n return 'Trade Failed';\n case 'cancelled':\n return 'Trade Cancelled';\n default:\n return 'Processing Trade';\n }\n }\n\n if (\n hoveredChainName &&\n (view === 'baseSelection' ||\n view === 'quoteSelection' ||\n view === 'baseChainSelection' ||\n view === 'quoteChainSelection')\n ) {\n return hoveredChainName;\n }\n\n if (view === 'swap' && isRecipientButtonHovered) {\n return isRecipientInputOpen\n ? 'Remove Custom Recipient'\n : 'Add Custom Recipient';\n }\n\n switch (view) {\n case 'wallet':\n return 'Wallet';\n case 'baseSelection':\n return 'Select Source Token';\n case 'quoteSelection':\n return 'Select Destination Token';\n case 'baseChainSelection':\n return 'Select Source Chain';\n case 'quoteChainSelection':\n return 'Select Destination Chain';\n default:\n if (view === 'swap') {\n if (hasAllowanceError && !isWrappingPair && !isUnwrappingPair)\n return 'Allowance check failed';\n if (hasSizeCapError && !isWrappingPair && !isUnwrappingPair)\n return 'Size limit exceeded';\n if (hasInsufficientLiquidity && !isWrappingPair && !isUnwrappingPair)\n return 'Insufficient Liquidity';\n if (hasRoutingError && !isWrappingPair && !isUnwrappingPair)\n return 'Route Not Found';\n if (hasLowLiquidity && !isWrappingPair && !isUnwrappingPair)\n return 'High Price Impact';\n }\n if (isSameChain && !isWrappingPair && !isUnwrappingPair) return 'Swap';\n if (isWrappingPair) return 'Wrap';\n if (isUnwrappingPair) return 'Unwrap';\n return headerText;\n }\n };\n\n const targetHeaderText = getHeaderText();\n\n const isErrorMessage =\n !isTrackingTx &&\n view === 'swap' &&\n !isRecipientButtonHovered &&\n ((hasAllowanceError && !isWrappingPair && !isUnwrappingPair) ||\n (hasSizeCapError && !isWrappingPair && !isUnwrappingPair) ||\n (hasInsufficientLiquidity && !isWrappingPair && !isUnwrappingPair) ||\n (hasRoutingError && !isWrappingPair && !isUnwrappingPair) ||\n (hasLowLiquidity && !isWrappingPair && !isUnwrappingPair));\n\n const statusVarMap: Record<string, string> = {\n pending: 'var(--widget-status-pending)',\n received: 'var(--widget-status-received)',\n completed: 'var(--widget-status-completed)',\n failed: 'var(--widget-status-failed)',\n cancelled: 'var(--widget-status-failed)',\n };\n\n const getHeaderTextColor = () => {\n if (!isTrackingTx || !txStatus) return null;\n return statusVarMap[txStatus] ?? null;\n };\n\n const renderRightComponent = () => {\n if (isTrackingTx) return null;\n\n if (view === 'swap') {\n return (\n <div className=\"flex items-center gap-2\">\n {walletButtonEnabled && mounted && web3ConnectionType === 'custom' && isConnected && (\n <button\n onClick={() => {\n if (customWalletUI === 'provider' && openAccountModal) {\n openAccountModal();\n } else {\n useWidgetSwapUIStore.getState().setView('wallet');\n }\n }}\n aria-label=\"Open wallet\"\n className=\"size-4 -translate-y-0.5 flex cursor-pointer items-center justify-center rounded-full transition-colors text-(--widget-muted-foreground) opacity-60 hover:text-(--widget-foreground) hover:opacity-100\"\n >\n <svg\n className=\"size-3.5\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <rect x=\"2\" y=\"5\" width=\"20\" height=\"15\" rx=\"2\" stroke=\"currentColor\" strokeWidth=\"1.5\" />\n <path d=\"M16 12C16 11.4477 16.4477 11 17 11H21V13H17C16.4477 13 16 12.5523 16 12Z\" fill=\"currentColor\" />\n <path d=\"M2 9H22\" stroke=\"currentColor\" strokeWidth=\"1.5\" />\n </svg>\n </button>\n )}\n {walletButtonEnabled && mounted && web3ConnectionType === 'standalone' && isConnected && openAccountModal && (\n <button\n onClick={() => openAccountModal()}\n aria-label=\"Open account\"\n className=\"size-4 -translate-y-0.5 flex cursor-pointer items-center justify-center rounded-full transition-colors text-(--widget-muted-foreground) opacity-60 hover:text-(--widget-foreground) hover:opacity-100\"\n >\n <svg\n className=\"size-3.5\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <rect x=\"2\" y=\"5\" width=\"20\" height=\"15\" rx=\"2\" stroke=\"currentColor\" strokeWidth=\"1.5\" />\n <path d=\"M16 12C16 11.4477 16.4477 11 17 11H21V13H17C16.4477 13 16 12.5523 16 12Z\" fill=\"currentColor\" />\n <path d=\"M2 9H22\" stroke=\"currentColor\" strokeWidth=\"1.5\" />\n </svg>\n </button>\n )}\n <button\n onClick={() =>\n useWidgetSwapUIStore.getState().toggleRecipientInput()\n }\n onMouseEnter={() => setIsRecipientButtonHovered(true)}\n onMouseLeave={() => setIsRecipientButtonHovered(false)}\n aria-label={\n isRecipientInputOpen\n ? 'Remove custom recipient'\n : 'Add custom recipient'\n }\n className={`size-4 -translate-y-0.5 flex cursor-pointer items-center justify-center rounded-full transition-colors hover:text-(--widget-foreground) hover:opacity-100 ${\n isRecipientInputOpen\n ? 'text-(--widget-destructive) opacity-80'\n : 'text-(--widget-muted-foreground) opacity-60'\n }`}\n >\n <svg\n className=\"size-3.5\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M2 7.75C1.58579 7.75 1.25 8.08579 1.25 8.5C1.25 8.91421 1.58579 9.25 2 9.25V7.75ZM2 8.5V9.25H13.5V8.5V7.75H2V8.5Z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M6 16.5H8\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeMiterlimit=\"10\"\n strokeLinecap=\"butt\"\n strokeLinejoin=\"miter\"\n />\n <path\n d=\"M10.5 16.5H14.5\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeMiterlimit=\"10\"\n strokeLinecap=\"butt\"\n strokeLinejoin=\"miter\"\n />\n <path\n d=\"M22 12.03V16.11C22 20.5 22 20.5 17.56 20.5H6.44C2 20.5 2 20.5 2 16.11V7.89C2 3.5 2 3.5 6.44 3.5H13.5\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinejoin=\"miter\"\n />\n <g\n style={{\n transform: `rotate(${isRecipientInputOpen ? '45deg' : '0deg'})`,\n transformOrigin: '18.75px 6.75px',\n transition: 'transform 150ms ease-out',\n }}\n >\n <path\n d=\"M15 6.75H22.5\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n />\n <path\n d=\"M18.75 10.5V3\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n />\n </g>\n </svg>\n </button>\n </div>\n );\n }\n\n return (\n <button\n onClick={() =>\n onBackClick\n ? onBackClick()\n : useWidgetSwapUIStore.getState().setView('swap')\n }\n className=\"flex cursor-pointer items-center justify-center whitespace-nowrap h-6 transition-colors text-(--widget-muted-foreground) opacity-70 hover:text-(--widget-foreground) hover:opacity-100\"\n >\n <span className=\"pr-1\">←</span>\n <span className=\"text-sm\">Back</span>\n </button>\n );\n };\n\n const headerTextColor = getHeaderTextColor();\n\n // ── none variant: render nothing ─────────────────────────────────────────\n if (swapHeaderVariant === 'none') return null;\n\n return (\n <div className=\"w-full pt-3 px-2 mono text-base flex flex-row justify-between h-6 shrink-0\">\n {view === 'wallet' ? (\n <div className=\"flex items-center gap-1 mono uppercase -translate-y-0.5 text-xs\">\n <button\n type=\"button\"\n onClick={() =>\n useWidgetSwapUIStore.getState().setWalletTab('wallet')\n }\n className=\"cursor-pointer transition-colors\"\n style={{\n color:\n walletTab === 'wallet'\n ? 'var(--widget-foreground)'\n : 'var(--widget-muted-foreground)',\n }}\n >\n <span style={{ color: 'var(--widget-muted-foreground)' }}>\n {'>> '}\n </span>\n <span>Wallet</span>\n </button>\n <span style={{ color: 'var(--widget-foreground)', opacity: 0.4 }}>\n {'>>'}\n </span>\n <button\n type=\"button\"\n onClick={() =>\n useWidgetSwapUIStore.getState().setWalletTab('activity')\n }\n className=\"cursor-pointer transition-colors\"\n style={{\n color:\n walletTab === 'activity'\n ? 'var(--widget-foreground)'\n : 'var(--widget-muted-foreground)',\n }}\n >\n Activity\n </button>\n </div>\n ) : (\n <div className=\"mono uppercase -translate-y-0.5 text-xs flex items-center\">\n <span\n className=\"mr-1.5\"\n style={{ color: 'var(--widget-muted-foreground)', opacity: 0.4 }}\n >\n {'>> '}\n </span>\n <span\n className=\"relative\"\n style={{ color: headerTextColor || 'var(--widget-foreground)' }}\n key={scrambleKey}\n >\n <TextScrambleDisplay\n targetText={targetHeaderText}\n isError={isErrorMessage ?? false}\n />\n </span>\n </div>\n )}\n <div className=\"flex flex-row items-center\">{renderRightComponent()}</div>\n </div>\n );\n};\n\nexport default SwapHeader;\n","'use client';\n\nimport { createContext, useContext, type ReactNode } from 'react';\nimport { type WidgetTheme, defaultDarkTheme } from './types';\n\nconst WidgetThemeContext = createContext<WidgetTheme>(defaultDarkTheme);\n\ninterface WidgetThemeProviderProps {\n theme: WidgetTheme;\n children: ReactNode;\n}\n\nexport function WidgetThemeProvider({ theme, children }: WidgetThemeProviderProps) {\n return (\n <WidgetThemeContext.Provider value={theme}>\n {children}\n </WidgetThemeContext.Provider>\n );\n}\n\nexport function useWidgetTheme() {\n return useContext(WidgetThemeContext);\n}\n","export interface WidgetTheme {\n background: string;\n foreground: string;\n card: string;\n 'card-foreground': string;\n popover: string;\n 'popover-foreground': string;\n primary: string;\n 'primary-foreground': string;\n secondary: string;\n 'secondary-foreground': string;\n muted: string;\n 'muted-foreground': string;\n accent: string;\n 'accent-foreground': string;\n destructive: string;\n 'destructive-foreground': string;\n border: string;\n input: string;\n ring: string;\n\n radius: string;\n 'border-style'?: string;\n\n 'font-sans'?: string;\n 'font-mono'?: string;\n\n 'shadow-color'?: string;\n 'shadow-opacity'?: string;\n 'shadow-blur'?: string;\n 'shadow-spread'?: string;\n 'shadow-offset-x'?: string;\n 'shadow-offset-y'?: string;\n\n 'letter-spacing'?: string;\n\n 'status-pending'?: string;\n 'status-received'?: string;\n 'status-completed'?: string;\n 'status-failed'?: string;\n}\n\nexport const defaultLightTheme: WidgetTheme = {\n background: '#ffffff',\n foreground: '#0a0a0a',\n card: '#ffffff',\n 'card-foreground': '#0a0a0a',\n popover: '#ffffff',\n 'popover-foreground': '#0a0a0a',\n primary: '#171717',\n 'primary-foreground': '#fafafa',\n secondary: '#f5f5f5',\n 'secondary-foreground': '#171717',\n muted: '#f5f5f5',\n 'muted-foreground': '#737373',\n accent: '#f5f5f5',\n 'accent-foreground': '#171717',\n destructive: '#e7000b',\n 'destructive-foreground': '#ffffff',\n border: '#e5e5e5',\n input: '#e5e5e5',\n ring: '#a1a1a1',\n radius: '0.625rem',\n 'border-style': 'dotted',\n 'status-pending': '#a1a1aa',\n 'status-received': '#f59e0b',\n 'status-completed': '#10b981',\n 'status-failed': '#ef4444',\n};\n\nexport const defaultDarkTheme: WidgetTheme = {\n background: '#0a0a0a',\n foreground: '#fafafa',\n card: '#171717',\n 'card-foreground': '#fafafa',\n popover: '#262626',\n 'popover-foreground': '#fafafa',\n primary: '#e5e5e5',\n 'primary-foreground': '#171717',\n secondary: '#262626',\n 'secondary-foreground': '#fafafa',\n muted: '#262626',\n 'muted-foreground': '#a1a1a1',\n accent: '#404040',\n 'accent-foreground': '#fafafa',\n destructive: '#ff6467',\n 'destructive-foreground': '#fafafa',\n border: '#282828',\n input: '#343434',\n ring: '#737373',\n radius: '0.625rem',\n 'border-style': 'dotted',\n 'status-pending': '#a1a1aa',\n 'status-received': '#fbbf24',\n 'status-completed': '#2dd4bf',\n 'status-failed': '#fb7185',\n};\n\nexport function themeToCSS(theme: WidgetTheme): Record<string, string> {\n const vars: Record<string, string> = {\n '--widget-background': theme.background,\n '--widget-foreground': theme.foreground,\n '--widget-card': theme.card,\n '--widget-card-foreground': theme['card-foreground'],\n '--widget-popover': theme.popover,\n '--widget-popover-foreground': theme['popover-foreground'],\n '--widget-primary': theme.primary,\n '--widget-primary-foreground': theme['primary-foreground'],\n '--widget-secondary': theme.secondary,\n '--widget-secondary-foreground': theme['secondary-foreground'],\n '--widget-muted': theme.muted,\n '--widget-muted-foreground': theme['muted-foreground'],\n '--widget-accent': theme.accent,\n '--widget-accent-foreground': theme['accent-foreground'],\n '--widget-destructive': theme.destructive,\n '--widget-destructive-foreground': theme['destructive-foreground'],\n '--widget-border': theme.border,\n '--widget-input': theme.input,\n '--widget-ring': theme.ring,\n '--widget-radius': theme.radius,\n '--widget-border-style': theme['border-style'] || 'dotted',\n };\n\n vars['--widget-font-sans'] = theme['font-sans'] || 'inherit';\n vars['--widget-font-mono'] = theme['font-mono'] || 'inherit';\n vars['--widget-shadow-color'] = theme['shadow-color'] || 'oklch(0 0 0)';\n vars['--widget-shadow-opacity'] = theme['shadow-opacity'] || '0.1';\n vars['--widget-shadow-blur'] = theme['shadow-blur'] || '3px';\n vars['--widget-shadow-spread'] = theme['shadow-spread'] || '0px';\n vars['--widget-shadow-offset-x'] = theme['shadow-offset-x'] || '0';\n vars['--widget-shadow-offset-y'] = theme['shadow-offset-y'] || '1px';\n vars['--widget-letter-spacing'] = theme['letter-spacing'] || 'normal';\n\n vars['--widget-status-pending'] = theme['status-pending'] || '#a1a1aa';\n vars['--widget-status-received'] = theme['status-received'] || '#fbbf24';\n vars['--widget-status-completed'] = theme['status-completed'] || '#2dd4bf';\n vars['--widget-status-failed'] = theme['status-failed'] || '#fb7185';\n\n return vars;\n}\n","'use client';\n\nimport { useWalletModal } from './WalletModalContext';\nimport { useWalletState } from './useWalletState';\n\nexport function ConnectButton() {\n const { openConnectModal } = useWalletModal();\n const { isConnected, address } = useWalletState();\n\n const label = isConnected && address\n ? `${address.slice(0, 6)}...${address.slice(-4)}`\n : 'Connect';\n\n return (\n <button\n type=\"button\"\n onClick={() => openConnectModal()}\n className=\"h-8 cursor-pointer px-3 text-xs font-bold uppercase tracking-wide transition-colors duration-150 border border-border rounded-sm bg-card text-foreground hover:bg-secondary hover:border-foreground/20\"\n >\n {label}\n </button>\n );\n}\n","import { getAllChainConfigs, staticChainsConfig, type StaticChainConfig } from '../../internal';\nimport type { Chain } from 'wagmi/chains';\nimport { http, fallback } from 'wagmi';\n\nexport function buildTransports(\n rpcOverrides?: Partial<Record<number, string | string[]>>,\n) {\n const chainEntries = Object.entries(staticChainsConfig) as [string, StaticChainConfig][];\n return Object.fromEntries(\n chainEntries.map(([id, c]) => {\n const override = rpcOverrides?.[Number(id)];\n const overrideUrls = override\n ? Array.isArray(override) ? override : [override]\n : [];\n const urls = overrideUrls.length > 0\n ? [...overrideUrls, ...c.rpcUrls]\n : c.rpcUrls;\n return [\n id,\n urls.length > 1\n ? fallback(urls.map((url) => http(url, { batch: { batchSize: 50, wait: 50 } })))\n : http(urls[0], { batch: { batchSize: 50, wait: 50 } }),\n ];\n }),\n );\n}\n\nexport const wagmiChains = getAllChainConfigs().map((c) => c.wagmiChain) as [Chain, ...Chain[]];\n","'use client';\n\nimport { useTokenData, getChainKeyToIdMapping } from '../internal';\nimport { useMemo } from 'react';\n\nexport const useTokensForChain = (chainId: number) => {\n const { tokenRegistry, isLoadingRegistry, error } = useTokenData();\n\n const tokens = useMemo(() => {\n return tokenRegistry.filter((token) => token.chainId === chainId);\n }, [tokenRegistry, chainId]);\n\n return { tokens, isLoading: isLoadingRegistry, error };\n};\n\nexport const useIsTokenSupported = (address: string, chainId: number) => {\n const { tokenRegistry } = useTokenData();\n\n return useMemo(() => {\n if (!address || !tokenRegistry.length) return false;\n return tokenRegistry.some(\n (token) =>\n token.address.toLowerCase() === address.toLowerCase() &&\n token.chainId === chainId,\n );\n }, [tokenRegistry, address, chainId]);\n};\n\nexport const useTokenByAddress = (address: string, chainId: number) => {\n const { getToken } = useTokenData();\n\n return useMemo(() => {\n if (!address || !chainId) return undefined;\n return getToken(chainId, address);\n }, [getToken, address, chainId]);\n};\n\nexport const SUPPORTED_CHAINS = getChainKeyToIdMapping();\n"]}
|
package/dist/index.css.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/widget.css"],"sourcesContent":["/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */\n@layer properties;\n@layer aori-base, aori-theme, aori-utilities;\n@layer aori-base {\n .aori-widget *, .aori-widget ::after, .aori-widget ::before, .aori-widget ::backdrop, .aori-widget ::file-selector-button {\n box-sizing: border-box;\n margin: 0;\n padding: 0;\n border: 0 solid;\n }\n .aori-widget, .aori-widget :host {\n line-height: 1.5;\n -webkit-text-size-adjust: 100%;\n tab-size: 4;\n font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji');\n font-feature-settings: var(--default-font-feature-settings, normal);\n font-variation-settings: var(--default-font-variation-settings, normal);\n -webkit-tap-highlight-color: transparent;\n }\n .aori-widget hr {\n height: 0;\n color: inherit;\n border-top-width: 1px;\n }\n .aori-widget abbr:where([title]) {\n -webkit-text-decoration: underline dotted;\n text-decoration: underline dotted;\n }\n .aori-widget h1, .aori-widget h2, .aori-widget h3, .aori-widget h4, .aori-widget h5, .aori-widget h6 {\n font-size: inherit;\n font-weight: inherit;\n }\n .aori-widget a {\n color: inherit;\n -webkit-text-decoration: inherit;\n text-decoration: inherit;\n }\n .aori-widget b, .aori-widget strong {\n font-weight: bolder;\n }\n .aori-widget code, .aori-widget kbd, .aori-widget samp, .aori-widget pre {\n font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace);\n font-feature-settings: var(--default-mono-font-feature-settings, normal);\n font-variation-settings: var(--default-mono-font-variation-settings, normal);\n font-size: 1em;\n }\n .aori-widget small {\n font-size: 80%;\n }\n .aori-widget sub, .aori-widget sup {\n font-size: 75%;\n line-height: 0;\n position: relative;\n vertical-align: baseline;\n }\n .aori-widget sub {\n bottom: -0.25em;\n }\n .aori-widget sup {\n top: -0.5em;\n }\n .aori-widget table {\n text-indent: 0;\n border-color: inherit;\n border-collapse: collapse;\n }\n .aori-widget :-moz-focusring {\n outline: auto;\n }\n .aori-widget progress {\n vertical-align: baseline;\n }\n .aori-widget summary {\n display: list-item;\n }\n .aori-widget ol, .aori-widget ul, .aori-widget menu {\n list-style: none;\n }\n .aori-widget img, .aori-widget svg, .aori-widget video, .aori-widget canvas, .aori-widget audio, .aori-widget iframe, .aori-widget embed, .aori-widget object {\n display: block;\n vertical-align: middle;\n }\n .aori-widget img, .aori-widget video {\n max-width: 100%;\n height: auto;\n }\n .aori-widget button, .aori-widget input, .aori-widget select, .aori-widget optgroup, .aori-widget textarea, .aori-widget ::file-selector-button {\n font: inherit;\n font-feature-settings: inherit;\n font-variation-settings: inherit;\n letter-spacing: inherit;\n color: inherit;\n border-radius: 0;\n background-color: transparent;\n opacity: 1;\n }\n .aori-widget :where(select:is([multiple], [size])) optgroup {\n font-weight: bolder;\n }\n .aori-widget :where(select:is([multiple], [size])) optgroup option {\n padding-inline-start: 20px;\n }\n .aori-widget ::file-selector-button {\n margin-inline-end: 4px;\n }\n .aori-widget ::placeholder {\n opacity: 1;\n }\n @supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px) {\n .aori-widget ::placeholder {\n color: currentcolor;\n @supports (color: color-mix(in lab, red, red)) {\n color: color-mix(in oklab, currentcolor 50%, transparent);\n }\n }\n }\n .aori-widget textarea {\n resize: vertical;\n }\n .aori-widget ::-webkit-search-decoration {\n -webkit-appearance: none;\n }\n .aori-widget ::-webkit-date-and-time-value {\n min-height: 1lh;\n text-align: inherit;\n }\n .aori-widget ::-webkit-datetime-edit {\n display: inline-flex;\n }\n .aori-widget ::-webkit-datetime-edit-fields-wrapper {\n padding: 0;\n }\n .aori-widget ::-webkit-datetime-edit, .aori-widget ::-webkit-datetime-edit-year-field, .aori-widget ::-webkit-datetime-edit-month-field, .aori-widget ::-webkit-datetime-edit-day-field, .aori-widget ::-webkit-datetime-edit-hour-field, .aori-widget ::-webkit-datetime-edit-minute-field, .aori-widget ::-webkit-datetime-edit-second-field, .aori-widget ::-webkit-datetime-edit-millisecond-field, .aori-widget ::-webkit-datetime-edit-meridiem-field {\n padding-block: 0;\n }\n .aori-widget ::-webkit-calendar-picker-indicator {\n line-height: 1;\n }\n .aori-widget :-moz-ui-invalid {\n box-shadow: none;\n }\n .aori-widget button, .aori-widget input:where([type='button'], [type='reset'], [type='submit']), .aori-widget ::file-selector-button {\n appearance: button;\n }\n .aori-widget ::-webkit-inner-spin-button, .aori-widget ::-webkit-outer-spin-button {\n height: auto;\n }\n .aori-widget [hidden]:where(:not([hidden='until-found'])) {\n display: none !important;\n }\n}\n@layer aori-theme {\n .aori-widget, .aori-widget :host {\n --font-sans: ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol',\n 'Noto Color Emoji';\n --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New',\n monospace;\n --color-gray-700: oklch(37.3% 0.034 259.733);\n --color-gray-800: oklch(27.8% 0.033 256.848);\n --color-black: #000;\n --color-white: #fff;\n --spacing: 0.25rem;\n --text-xs: 0.75rem;\n --text-xs--line-height: calc(1 / 0.75);\n --text-sm: 0.875rem;\n --text-sm--line-height: calc(1.25 / 0.875);\n --text-base: 1rem;\n --text-base--line-height: calc(1.5 / 1);\n --text-lg: 1.125rem;\n --text-lg--line-height: calc(1.75 / 1.125);\n --text-xl: 1.25rem;\n --text-xl--line-height: calc(1.75 / 1.25);\n --text-2xl: 1.5rem;\n --text-2xl--line-height: calc(2 / 1.5);\n --font-weight-light: 300;\n --font-weight-medium: 500;\n --font-weight-semibold: 600;\n --font-weight-bold: 700;\n --tracking-wide: 0.025em;\n --tracking-wider: 0.05em;\n --radius-sm: 0.25rem;\n --radius-lg: 0.5rem;\n --ease-out: cubic-bezier(0, 0, 0.2, 1);\n --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);\n --animate-spin: spin 1s linear infinite;\n --animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;\n --blur-sm: 8px;\n --default-transition-duration: 150ms;\n --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n --default-font-family: var(--font-sans);\n --default-mono-font-family: var(--font-mono);\n }\n}\n@layer aori-utilities {\n .aori-widget .pointer-events-none {\n pointer-events: none;\n }\n .aori-widget .invisible {\n visibility: hidden;\n }\n .aori-widget .visible {\n visibility: visible;\n }\n .aori-widget .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip-path: inset(50%);\n white-space: nowrap;\n border-width: 0;\n }\n .aori-widget .absolute {\n position: absolute;\n }\n .aori-widget .fixed {\n position: fixed;\n }\n .aori-widget .relative {\n position: relative;\n }\n .aori-widget .static {\n position: static;\n }\n .aori-widget .inset-0 {\n inset: calc(var(--spacing) * 0);\n }\n .aori-widget .top-0 {\n top: calc(var(--spacing) * 0);\n }\n .aori-widget .top-1\\.5 {\n top: calc(var(--spacing) * 1.5);\n }\n .aori-widget .top-1\\/2 {\n top: calc(1 / 2 * 100%);\n }\n .aori-widget .right-0 {\n right: calc(var(--spacing) * 0);\n }\n .aori-widget .right-2 {\n right: calc(var(--spacing) * 2);\n }\n .aori-widget .right-3 {\n right: calc(var(--spacing) * 3);\n }\n .aori-widget .right-4 {\n right: calc(var(--spacing) * 4);\n }\n .aori-widget .bottom-2 {\n bottom: calc(var(--spacing) * 2);\n }\n .aori-widget .bottom-3 {\n bottom: calc(var(--spacing) * 3);\n }\n .aori-widget .left-3 {\n left: calc(var(--spacing) * 3);\n }\n .aori-widget .left-12 {\n left: calc(var(--spacing) * 12);\n }\n .aori-widget .z-0 {\n z-index: 0;\n }\n .aori-widget .z-10 {\n z-index: 10;\n }\n .aori-widget .z-40 {\n z-index: 40;\n }\n .aori-widget .z-50 {\n z-index: 50;\n }\n .aori-widget .mx-2 {\n margin-inline: calc(var(--spacing) * 2);\n }\n .aori-widget .-my-4 {\n margin-block: calc(var(--spacing) * -4);\n }\n .aori-widget .my-0\\.5 {\n margin-block: calc(var(--spacing) * 0.5);\n }\n .aori-widget .my-1 {\n margin-block: calc(var(--spacing) * 1);\n }\n .aori-widget .my-2 {\n margin-block: calc(var(--spacing) * 2);\n }\n .aori-widget .mt-0\\.5 {\n margin-top: calc(var(--spacing) * 0.5);\n }\n .aori-widget .mt-1 {\n margin-top: calc(var(--spacing) * 1);\n }\n .aori-widget .mt-1\\.5 {\n margin-top: calc(var(--spacing) * 1.5);\n }\n .aori-widget .mt-2 {\n margin-top: calc(var(--spacing) * 2);\n }\n .aori-widget .mt-3 {\n margin-top: calc(var(--spacing) * 3);\n }\n .aori-widget .mt-auto {\n margin-top: auto;\n }\n .aori-widget .mr-1\\.5 {\n margin-right: calc(var(--spacing) * 1.5);\n }\n .aori-widget .mr-4 {\n margin-right: calc(var(--spacing) * 4);\n }\n .aori-widget .mb-0\\.5 {\n margin-bottom: calc(var(--spacing) * 0.5);\n }\n .aori-widget .mb-1 {\n margin-bottom: calc(var(--spacing) * 1);\n }\n .aori-widget .mb-2 {\n margin-bottom: calc(var(--spacing) * 2);\n }\n .aori-widget .mb-px {\n margin-bottom: 1px;\n }\n .aori-widget .ml-1 {\n margin-left: calc(var(--spacing) * 1);\n }\n .aori-widget .ml-2 {\n margin-left: calc(var(--spacing) * 2);\n }\n .aori-widget .ml-4 {\n margin-left: calc(var(--spacing) * 4);\n }\n .aori-widget .ml-auto {\n margin-left: auto;\n }\n .aori-widget .box-border {\n box-sizing: border-box;\n }\n .aori-widget .block {\n display: block;\n }\n .aori-widget .flex {\n display: flex;\n }\n .aori-widget .grid {\n display: grid;\n }\n .aori-widget .hidden {\n display: none;\n }\n .aori-widget .inline {\n display: inline;\n }\n .aori-widget .inline-block {\n display: inline-block;\n }\n .aori-widget .inline-flex {\n display: inline-flex;\n }\n .aori-widget .aspect-square {\n aspect-ratio: 1 / 1;\n }\n .aori-widget .size-3\\.5 {\n width: calc(var(--spacing) * 3.5);\n height: calc(var(--spacing) * 3.5);\n }\n .aori-widget .size-4 {\n width: calc(var(--spacing) * 4);\n height: calc(var(--spacing) * 4);\n }\n .aori-widget .size-8 {\n width: calc(var(--spacing) * 8);\n height: calc(var(--spacing) * 8);\n }\n .aori-widget .h-0 {\n height: calc(var(--spacing) * 0);\n }\n .aori-widget .h-1 {\n height: calc(var(--spacing) * 1);\n }\n .aori-widget .h-2\\.5 {\n height: calc(var(--spacing) * 2.5);\n }\n .aori-widget .h-3 {\n height: calc(var(--spacing) * 3);\n }\n .aori-widget .h-3\\.5 {\n height: calc(var(--spacing) * 3.5);\n }\n .aori-widget .h-4 {\n height: calc(var(--spacing) * 4);\n }\n .aori-widget .h-5 {\n height: calc(var(--spacing) * 5);\n }\n .aori-widget .h-6 {\n height: calc(var(--spacing) * 6);\n }\n .aori-widget .h-7 {\n height: calc(var(--spacing) * 7);\n }\n .aori-widget .h-8 {\n height: calc(var(--spacing) * 8);\n }\n .aori-widget .h-9 {\n height: calc(var(--spacing) * 9);\n }\n .aori-widget .h-10 {\n height: calc(var(--spacing) * 10);\n }\n .aori-widget .h-12 {\n height: calc(var(--spacing) * 12);\n }\n .aori-widget .h-14 {\n height: calc(var(--spacing) * 14);\n }\n .aori-widget .h-16 {\n height: calc(var(--spacing) * 16);\n }\n .aori-widget .h-20 {\n height: calc(var(--spacing) * 20);\n }\n .aori-widget .h-\\[12px\\] {\n height: 12px;\n }\n .aori-widget .h-\\[52px\\] {\n height: 52px;\n }\n .aori-widget .h-\\[140px\\] {\n height: 140px;\n }\n .aori-widget .h-\\[380px\\] {\n height: 380px;\n }\n .aori-widget .h-full {\n height: 100%;\n }\n .aori-widget .max-h-0 {\n max-height: calc(var(--spacing) * 0);\n }\n .aori-widget .max-h-\\[2000px\\] {\n max-height: 2000px;\n }\n .aori-widget .min-h-0 {\n min-height: calc(var(--spacing) * 0);\n }\n .aori-widget .w-0 {\n width: calc(var(--spacing) * 0);\n }\n .aori-widget .w-1 {\n width: calc(var(--spacing) * 1);\n }\n .aori-widget .w-1\\.5 {\n width: calc(var(--spacing) * 1.5);\n }\n .aori-widget .w-2\\.5 {\n width: calc(var(--spacing) * 2.5);\n }\n .aori-widget .w-2\\/3 {\n width: calc(2 / 3 * 100%);\n }\n .aori-widget .w-3 {\n width: calc(var(--spacing) * 3);\n }\n .aori-widget .w-4 {\n width: calc(var(--spacing) * 4);\n }\n .aori-widget .w-5 {\n width: calc(var(--spacing) * 5);\n }\n .aori-widget .w-6 {\n width: calc(var(--spacing) * 6);\n }\n .aori-widget .w-7 {\n width: calc(var(--spacing) * 7);\n }\n .aori-widget .w-8 {\n width: calc(var(--spacing) * 8);\n }\n .aori-widget .w-9 {\n width: calc(var(--spacing) * 9);\n }\n .aori-widget .w-10 {\n width: calc(var(--spacing) * 10);\n }\n .aori-widget .w-12 {\n width: calc(var(--spacing) * 12);\n }\n .aori-widget .w-14 {\n width: calc(var(--spacing) * 14);\n }\n .aori-widget .w-16 {\n width: calc(var(--spacing) * 16);\n }\n .aori-widget .w-24 {\n width: calc(var(--spacing) * 24);\n }\n .aori-widget .w-28 {\n width: calc(var(--spacing) * 28);\n }\n .aori-widget .w-48 {\n width: calc(var(--spacing) * 48);\n }\n .aori-widget .w-\\[12px\\] {\n width: 12px;\n }\n .aori-widget .w-\\[420px\\] {\n width: 420px;\n }\n .aori-widget .w-full {\n width: 100%;\n }\n .aori-widget .min-w-0 {\n min-width: calc(var(--spacing) * 0);\n }\n .aori-widget .min-w-\\[45px\\] {\n min-width: 45px;\n }\n .aori-widget .min-w-max {\n min-width: max-content;\n }\n .aori-widget .flex-1 {\n flex: 1;\n }\n .aori-widget .flex-shrink-0 {\n flex-shrink: 0;\n }\n .aori-widget .shrink-0 {\n flex-shrink: 0;\n }\n .aori-widget .translate-x-0 {\n --tw-translate-x: calc(var(--spacing) * 0);\n translate: var(--tw-translate-x) var(--tw-translate-y);\n }\n .aori-widget .translate-x-full {\n --tw-translate-x: 100%;\n translate: var(--tw-translate-x) var(--tw-translate-y);\n }\n .aori-widget .-translate-y-0\\.5 {\n --tw-translate-y: calc(var(--spacing) * -0.5);\n translate: var(--tw-translate-x) var(--tw-translate-y);\n }\n .aori-widget .-translate-y-1 {\n --tw-translate-y: calc(var(--spacing) * -1);\n translate: var(--tw-translate-x) var(--tw-translate-y);\n }\n .aori-widget .-translate-y-1\\/2 {\n --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);\n translate: var(--tw-translate-x) var(--tw-translate-y);\n }\n .aori-widget .-translate-y-px {\n --tw-translate-y: -1px;\n translate: var(--tw-translate-x) var(--tw-translate-y);\n }\n .aori-widget .translate-y-\\[-50\\%\\] {\n --tw-translate-y: -50%;\n translate: var(--tw-translate-x) var(--tw-translate-y);\n }\n .aori-widget .translate-y-px {\n --tw-translate-y: 1px;\n translate: var(--tw-translate-x) var(--tw-translate-y);\n }\n .aori-widget .rotate-180 {\n rotate: 180deg;\n }\n .aori-widget .transform {\n transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);\n }\n .aori-widget .animate-pulse {\n animation: var(--animate-pulse);\n }\n .aori-widget .animate-spin {\n animation: var(--animate-spin);\n }\n .aori-widget .cursor-default {\n cursor: default;\n }\n .aori-widget .cursor-not-allowed {\n cursor: not-allowed;\n }\n .aori-widget .cursor-pointer {\n cursor: pointer;\n }\n .aori-widget .cursor-text {\n cursor: text;\n }\n .aori-widget .grid-cols-\\[1fr_auto_1fr\\] {\n grid-template-columns: 1fr auto 1fr;\n }\n .aori-widget .flex-col {\n flex-direction: column;\n }\n .aori-widget .flex-row {\n flex-direction: row;\n }\n .aori-widget .flex-row-reverse {\n flex-direction: row-reverse;\n }\n .aori-widget .items-center {\n align-items: center;\n }\n .aori-widget .items-end {\n align-items: flex-end;\n }\n .aori-widget .items-start {\n align-items: flex-start;\n }\n .aori-widget .items-stretch {\n align-items: stretch;\n }\n .aori-widget .justify-between {\n justify-content: space-between;\n }\n .aori-widget .justify-center {\n justify-content: center;\n }\n .aori-widget .justify-start {\n justify-content: flex-start;\n }\n .aori-widget .gap-0\\.5 {\n gap: calc(var(--spacing) * 0.5);\n }\n .aori-widget .gap-1 {\n gap: calc(var(--spacing) * 1);\n }\n .aori-widget .gap-1\\.5 {\n gap: calc(var(--spacing) * 1.5);\n }\n .aori-widget .gap-2 {\n gap: calc(var(--spacing) * 2);\n }\n .aori-widget .gap-2\\.5 {\n gap: calc(var(--spacing) * 2.5);\n }\n .aori-widget .gap-3 {\n gap: calc(var(--spacing) * 3);\n }\n .aori-widget .space-y-1\\.5 {\n .aori-widget :where(& > :not(:last-child)) {\n --tw-space-y-reverse: 0;\n margin-block-start: calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));\n margin-block-end: calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)));\n }\n }\n .aori-widget .space-x-1 {\n .aori-widget :where(& > :not(:last-child)) {\n --tw-space-x-reverse: 0;\n margin-inline-start: calc(calc(var(--spacing) * 1) * var(--tw-space-x-reverse));\n margin-inline-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-x-reverse)));\n }\n }\n .aori-widget .space-x-2 {\n .aori-widget :where(& > :not(:last-child)) {\n --tw-space-x-reverse: 0;\n margin-inline-start: calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));\n margin-inline-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)));\n }\n }\n .aori-widget .space-x-3 {\n .aori-widget :where(& > :not(:last-child)) {\n --tw-space-x-reverse: 0;\n margin-inline-start: calc(calc(var(--spacing) * 3) * var(--tw-space-x-reverse));\n margin-inline-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-x-reverse)));\n }\n }\n .aori-widget .truncate {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n .aori-widget .overflow-auto {\n overflow: auto;\n }\n .aori-widget .overflow-hidden {\n overflow: hidden;\n }\n .aori-widget .overflow-x-auto {\n overflow-x: auto;\n }\n .aori-widget .overflow-y-auto {\n overflow-y: auto;\n }\n .aori-widget .rounded {\n border-radius: 0.25rem;\n }\n .aori-widget .rounded-full {\n border-radius: calc(infinity * 1px);\n }\n .aori-widget .rounded-lg {\n border-radius: var(--radius-lg);\n }\n .aori-widget .rounded-sm {\n border-radius: var(--radius-sm);\n }\n .aori-widget .border {\n border-style: var(--tw-border-style);\n border-width: 1px;\n }\n .aori-widget .border-t {\n border-top-style: var(--tw-border-style);\n border-top-width: 1px;\n }\n .aori-widget .border-none {\n --tw-border-style: none;\n border-style: none;\n }\n .aori-widget .bg-\\(--widget-card\\) {\n background-color: var(--widget-card);\n }\n .aori-widget .bg-\\(--widget-primary\\) {\n background-color: var(--widget-primary);\n }\n .aori-widget .bg-black\\/30 {\n background-color: color-mix(in srgb, #000 30%, transparent);\n @supports (color: color-mix(in lab, red, red)) {\n background-color: color-mix(in oklab, var(--color-black) 30%, transparent);\n }\n }\n .aori-widget .bg-black\\/50 {\n background-color: color-mix(in srgb, #000 50%, transparent);\n @supports (color: color-mix(in lab, red, red)) {\n background-color: color-mix(in oklab, var(--color-black) 50%, transparent);\n }\n }\n .aori-widget .bg-gray-700 {\n background-color: var(--color-gray-700);\n }\n .aori-widget .bg-gray-800 {\n background-color: var(--color-gray-800);\n }\n .aori-widget .bg-transparent {\n background-color: transparent;\n }\n .aori-widget .bg-white\\/10 {\n background-color: color-mix(in srgb, #fff 10%, transparent);\n @supports (color: color-mix(in lab, red, red)) {\n background-color: color-mix(in oklab, var(--color-white) 10%, transparent);\n }\n }\n .aori-widget .bg-gradient-to-t {\n --tw-gradient-position: to top in oklab;\n background-image: linear-gradient(var(--tw-gradient-stops));\n }\n .aori-widget .from-black\\/80 {\n --tw-gradient-from: color-mix(in srgb, #000 80%, transparent);\n @supports (color: color-mix(in lab, red, red)) {\n --tw-gradient-from: color-mix(in oklab, var(--color-black) 80%, transparent);\n }\n --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));\n }\n .aori-widget .via-black\\/40 {\n --tw-gradient-via: color-mix(in srgb, #000 40%, transparent);\n @supports (color: color-mix(in lab, red, red)) {\n --tw-gradient-via: color-mix(in oklab, var(--color-black) 40%, transparent);\n }\n --tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);\n --tw-gradient-stops: var(--tw-gradient-via-stops);\n }\n .aori-widget .to-transparent {\n --tw-gradient-to: transparent;\n --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));\n }\n .aori-widget .object-cover {\n object-fit: cover;\n }\n .aori-widget .p-0 {\n padding: calc(var(--spacing) * 0);\n }\n .aori-widget .p-2 {\n padding: calc(var(--spacing) * 2);\n }\n .aori-widget .p-2\\.5 {\n padding: calc(var(--spacing) * 2.5);\n }\n .aori-widget .p-3 {\n padding: calc(var(--spacing) * 3);\n }\n .aori-widget .p-4 {\n padding: calc(var(--spacing) * 4);\n }\n .aori-widget .p-6 {\n padding: calc(var(--spacing) * 6);\n }\n .aori-widget .p-8 {\n padding: calc(var(--spacing) * 8);\n }\n .aori-widget .px-0 {\n padding-inline: calc(var(--spacing) * 0);\n }\n .aori-widget .px-1 {\n padding-inline: calc(var(--spacing) * 1);\n }\n .aori-widget .px-2 {\n padding-inline: calc(var(--spacing) * 2);\n }\n .aori-widget .px-2\\.5 {\n padding-inline: calc(var(--spacing) * 2.5);\n }\n .aori-widget .px-3 {\n padding-inline: calc(var(--spacing) * 3);\n }\n .aori-widget .px-4 {\n padding-inline: calc(var(--spacing) * 4);\n }\n .aori-widget .px-8 {\n padding-inline: calc(var(--spacing) * 8);\n }\n .aori-widget .py-0\\.5 {\n padding-block: calc(var(--spacing) * 0.5);\n }\n .aori-widget .py-1 {\n padding-block: calc(var(--spacing) * 1);\n }\n .aori-widget .py-1\\.5 {\n padding-block: calc(var(--spacing) * 1.5);\n }\n .aori-widget .py-2 {\n padding-block: calc(var(--spacing) * 2);\n }\n .aori-widget .py-2\\.5 {\n padding-block: calc(var(--spacing) * 2.5);\n }\n .aori-widget .py-3 {\n padding-block: calc(var(--spacing) * 3);\n }\n .aori-widget .py-4 {\n padding-block: calc(var(--spacing) * 4);\n }\n .aori-widget .pt-1 {\n padding-top: calc(var(--spacing) * 1);\n }\n .aori-widget .pt-2\\.5 {\n padding-top: calc(var(--spacing) * 2.5);\n }\n .aori-widget .pt-3 {\n padding-top: calc(var(--spacing) * 3);\n }\n .aori-widget .pt-4 {\n padding-top: calc(var(--spacing) * 4);\n }\n .aori-widget .pt-5 {\n padding-top: calc(var(--spacing) * 5);\n }\n .aori-widget .pt-6 {\n padding-top: calc(var(--spacing) * 6);\n }\n .aori-widget .pr-1 {\n padding-right: calc(var(--spacing) * 1);\n }\n .aori-widget .pr-2 {\n padding-right: calc(var(--spacing) * 2);\n }\n .aori-widget .pr-7 {\n padding-right: calc(var(--spacing) * 7);\n }\n .aori-widget .pr-8 {\n padding-right: calc(var(--spacing) * 8);\n }\n .aori-widget .pb-0\\.5 {\n padding-bottom: calc(var(--spacing) * 0.5);\n }\n .aori-widget .pb-1 {\n padding-bottom: calc(var(--spacing) * 1);\n }\n .aori-widget .pb-2 {\n padding-bottom: calc(var(--spacing) * 2);\n }\n .aori-widget .pb-3 {\n padding-bottom: calc(var(--spacing) * 3);\n }\n .aori-widget .pb-4 {\n padding-bottom: calc(var(--spacing) * 4);\n }\n .aori-widget .pl-1\\.5 {\n padding-left: calc(var(--spacing) * 1.5);\n }\n .aori-widget .pl-4 {\n padding-left: calc(var(--spacing) * 4);\n }\n .aori-widget .pl-12 {\n padding-left: calc(var(--spacing) * 12);\n }\n .aori-widget .pl-px {\n padding-left: 1px;\n }\n .aori-widget .text-center {\n text-align: center;\n }\n .aori-widget .text-right {\n text-align: right;\n }\n .aori-widget .font-mono {\n font-family: var(--font-mono);\n }\n .aori-widget .font-sans {\n font-family: var(--font-sans);\n }\n .aori-widget .text-2xl {\n font-size: var(--text-2xl);\n line-height: var(--tw-leading, var(--text-2xl--line-height));\n }\n .aori-widget .text-base {\n font-size: var(--text-base);\n line-height: var(--tw-leading, var(--text-base--line-height));\n }\n .aori-widget .text-lg {\n font-size: var(--text-lg);\n line-height: var(--tw-leading, var(--text-lg--line-height));\n }\n .aori-widget .text-sm {\n font-size: var(--text-sm);\n line-height: var(--tw-leading, var(--text-sm--line-height));\n }\n .aori-widget .text-xl {\n font-size: var(--text-xl);\n line-height: var(--tw-leading, var(--text-xl--line-height));\n }\n .aori-widget .text-xs {\n font-size: var(--text-xs);\n line-height: var(--tw-leading, var(--text-xs--line-height));\n }\n .aori-widget .text-2xs {\n font-size: 0.75rem;\n }\n .aori-widget .text-3xs {\n font-size: 0.68rem;\n }\n .aori-widget .font-bold {\n --tw-font-weight: var(--font-weight-bold);\n font-weight: var(--font-weight-bold);\n }\n .aori-widget .font-light {\n --tw-font-weight: var(--font-weight-light);\n font-weight: var(--font-weight-light);\n }\n .aori-widget .font-medium {\n --tw-font-weight: var(--font-weight-medium);\n font-weight: var(--font-weight-medium);\n }\n .aori-widget .font-semibold {\n --tw-font-weight: var(--font-weight-semibold);\n font-weight: var(--font-weight-semibold);\n }\n .aori-widget .tracking-wide {\n --tw-tracking: var(--tracking-wide);\n letter-spacing: var(--tracking-wide);\n }\n .aori-widget .tracking-wider {\n --tw-tracking: var(--tracking-wider);\n letter-spacing: var(--tracking-wider);\n }\n .aori-widget .whitespace-nowrap {\n white-space: nowrap;\n }\n .aori-widget .text-\\(--widget-destructive\\) {\n color: var(--widget-destructive);\n }\n .aori-widget .text-\\(--widget-muted-foreground\\) {\n color: var(--widget-muted-foreground);\n }\n .aori-widget .text-\\(--widget-primary-foreground\\) {\n color: var(--widget-primary-foreground);\n }\n .aori-widget .capitalize {\n text-transform: capitalize;\n }\n .aori-widget .lowercase {\n text-transform: lowercase;\n }\n .aori-widget .uppercase {\n text-transform: uppercase;\n }\n .aori-widget .tabular-nums {\n --tw-numeric-spacing: tabular-nums;\n font-variant-numeric: var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,);\n }\n .aori-widget .no-underline {\n text-decoration-line: none;\n }\n .aori-widget .opacity-0 {\n opacity: 0%;\n }\n .aori-widget .opacity-20 {\n opacity: 20%;\n }\n .aori-widget .opacity-50 {\n opacity: 50%;\n }\n .aori-widget .opacity-60 {\n opacity: 60%;\n }\n .aori-widget .opacity-70 {\n opacity: 70%;\n }\n .aori-widget .opacity-80 {\n opacity: 80%;\n }\n .aori-widget .opacity-100 {\n opacity: 100%;\n }\n .aori-widget .shadow-xl {\n --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.1));\n box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);\n }\n .aori-widget .ring {\n --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);\n box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);\n }\n .aori-widget .outline {\n outline-style: var(--tw-outline-style);\n outline-width: 1px;\n }\n .aori-widget .invert {\n --tw-invert: invert(100%);\n filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);\n }\n .aori-widget .filter {\n filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);\n }\n .aori-widget .backdrop-blur-sm {\n --tw-backdrop-blur: blur(var(--blur-sm));\n -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);\n backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);\n }\n .aori-widget .transition {\n transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;\n transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));\n transition-duration: var(--tw-duration, var(--default-transition-duration));\n }\n .aori-widget .transition-all {\n transition-property: all;\n transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));\n transition-duration: var(--tw-duration, var(--default-transition-duration));\n }\n .aori-widget .transition-colors {\n transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;\n transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));\n transition-duration: var(--tw-duration, var(--default-transition-duration));\n }\n .aori-widget .transition-opacity {\n transition-property: opacity;\n transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));\n transition-duration: var(--tw-duration, var(--default-transition-duration));\n }\n .aori-widget .transition-transform {\n transition-property: transform, translate, scale, rotate;\n transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));\n transition-duration: var(--tw-duration, var(--default-transition-duration));\n }\n .aori-widget .duration-100 {\n --tw-duration: 100ms;\n transition-duration: 100ms;\n }\n .aori-widget .duration-150 {\n --tw-duration: 150ms;\n transition-duration: 150ms;\n }\n .aori-widget .duration-200 {\n --tw-duration: 200ms;\n transition-duration: 200ms;\n }\n .aori-widget .duration-300 {\n --tw-duration: 300ms;\n transition-duration: 300ms;\n }\n .aori-widget .ease-in-out {\n --tw-ease: var(--ease-in-out);\n transition-timing-function: var(--ease-in-out);\n }\n .aori-widget .ease-linear {\n --tw-ease: linear;\n transition-timing-function: linear;\n }\n .aori-widget .ease-out {\n --tw-ease: var(--ease-out);\n transition-timing-function: var(--ease-out);\n }\n .aori-widget .group-hover\\:rotate-\\[-45deg\\] {\n .aori-widget &:is(:where(.group):hover *) {\n @media (hover: hover) {\n rotate: -45deg;\n }\n }\n }\n .aori-widget .group-hover\\:opacity-100 {\n .aori-widget &:is(:where(.group):hover *) {\n @media (hover: hover) {\n opacity: 100%;\n }\n }\n }\n .aori-widget .placeholder\\:opacity-50 {\n .aori-widget &::placeholder {\n opacity: 50%;\n }\n }\n .aori-widget .hover\\:bg-\\(--widget-foreground\\) {\n .aori-widget &:hover {\n @media (hover: hover) {\n background-color: var(--widget-foreground);\n }\n }\n }\n .aori-widget .hover\\:bg-\\(--widget-secondary\\) {\n .aori-widget &:hover {\n @media (hover: hover) {\n background-color: var(--widget-secondary);\n }\n }\n }\n .aori-widget .hover\\:\\[color\\:var\\(--widget-destructive\\)\\] {\n .aori-widget &:hover {\n @media (hover: hover) {\n color: var(--widget-destructive);\n }\n }\n }\n .aori-widget .hover\\:text-\\(--widget-card\\) {\n .aori-widget &:hover {\n @media (hover: hover) {\n color: var(--widget-card);\n }\n }\n }\n .aori-widget .hover\\:text-\\(--widget-foreground\\) {\n .aori-widget &:hover {\n @media (hover: hover) {\n color: var(--widget-foreground);\n }\n }\n }\n .aori-widget .hover\\:opacity-70 {\n .aori-widget &:hover {\n @media (hover: hover) {\n opacity: 70%;\n }\n }\n }\n .aori-widget .hover\\:opacity-80 {\n .aori-widget &:hover {\n @media (hover: hover) {\n opacity: 80%;\n }\n }\n }\n .aori-widget .hover\\:opacity-100 {\n .aori-widget &:hover {\n @media (hover: hover) {\n opacity: 100%;\n }\n }\n }\n .aori-widget .disabled\\:cursor-not-allowed {\n .aori-widget &:disabled {\n cursor: not-allowed;\n }\n }\n .aori-widget .disabled\\:opacity-40 {\n .aori-widget &:disabled {\n opacity: 40%;\n }\n }\n}\n@property --tw-translate-x {\n syntax: \"*\";\n inherits: false;\n initial-value: 0;\n}\n@property --tw-translate-y {\n syntax: \"*\";\n inherits: false;\n initial-value: 0;\n}\n@property --tw-translate-z {\n syntax: \"*\";\n inherits: false;\n initial-value: 0;\n}\n@property --tw-rotate-x {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-rotate-y {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-rotate-z {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-skew-x {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-skew-y {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-space-y-reverse {\n syntax: \"*\";\n inherits: false;\n initial-value: 0;\n}\n@property --tw-space-x-reverse {\n syntax: \"*\";\n inherits: false;\n initial-value: 0;\n}\n@property --tw-border-style {\n syntax: \"*\";\n inherits: false;\n initial-value: solid;\n}\n@property --tw-gradient-position {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-gradient-from {\n syntax: \"<color>\";\n inherits: false;\n initial-value: #0000;\n}\n@property --tw-gradient-via {\n syntax: \"<color>\";\n inherits: false;\n initial-value: #0000;\n}\n@property --tw-gradient-to {\n syntax: \"<color>\";\n inherits: false;\n initial-value: #0000;\n}\n@property --tw-gradient-stops {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-gradient-via-stops {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-gradient-from-position {\n syntax: \"<length-percentage>\";\n inherits: false;\n initial-value: 0%;\n}\n@property --tw-gradient-via-position {\n syntax: \"<length-percentage>\";\n inherits: false;\n initial-value: 50%;\n}\n@property --tw-gradient-to-position {\n syntax: \"<length-percentage>\";\n inherits: false;\n initial-value: 100%;\n}\n@property --tw-font-weight {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-tracking {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-ordinal {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-slashed-zero {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-numeric-figure {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-numeric-spacing {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-numeric-fraction {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-shadow {\n syntax: \"*\";\n inherits: false;\n initial-value: 0 0 #0000;\n}\n@property --tw-shadow-color {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-shadow-alpha {\n syntax: \"<percentage>\";\n inherits: false;\n initial-value: 100%;\n}\n@property --tw-inset-shadow {\n syntax: \"*\";\n inherits: false;\n initial-value: 0 0 #0000;\n}\n@property --tw-inset-shadow-color {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-inset-shadow-alpha {\n syntax: \"<percentage>\";\n inherits: false;\n initial-value: 100%;\n}\n@property --tw-ring-color {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-ring-shadow {\n syntax: \"*\";\n inherits: false;\n initial-value: 0 0 #0000;\n}\n@property --tw-inset-ring-color {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-inset-ring-shadow {\n syntax: \"*\";\n inherits: false;\n initial-value: 0 0 #0000;\n}\n@property --tw-ring-inset {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-ring-offset-width {\n syntax: \"<length>\";\n inherits: false;\n initial-value: 0px;\n}\n@property --tw-ring-offset-color {\n syntax: \"*\";\n inherits: false;\n initial-value: #fff;\n}\n@property --tw-ring-offset-shadow {\n syntax: \"*\";\n inherits: false;\n initial-value: 0 0 #0000;\n}\n@property --tw-outline-style {\n syntax: \"*\";\n inherits: false;\n initial-value: solid;\n}\n@property --tw-blur {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-brightness {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-contrast {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-grayscale {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-hue-rotate {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-invert {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-opacity {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-saturate {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-sepia {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-drop-shadow {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-drop-shadow-color {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-drop-shadow-alpha {\n syntax: \"<percentage>\";\n inherits: false;\n initial-value: 100%;\n}\n@property --tw-drop-shadow-size {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-backdrop-blur {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-backdrop-brightness {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-backdrop-contrast {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-backdrop-grayscale {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-backdrop-hue-rotate {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-backdrop-invert {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-backdrop-opacity {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-backdrop-saturate {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-backdrop-sepia {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-duration {\n syntax: \"*\";\n inherits: false;\n}\n@property --tw-ease {\n syntax: \"*\";\n inherits: false;\n}\n@keyframes spin {\n to {\n transform: rotate(360deg);\n }\n}\n@keyframes pulse {\n 50% {\n opacity: 0.5;\n }\n}\n@layer properties {\n @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {\n .aori-widget *, .aori-widget ::before, .aori-widget ::after, .aori-widget ::backdrop {\n --tw-translate-x: 0;\n --tw-translate-y: 0;\n --tw-translate-z: 0;\n --tw-rotate-x: initial;\n --tw-rotate-y: initial;\n --tw-rotate-z: initial;\n --tw-skew-x: initial;\n --tw-skew-y: initial;\n --tw-space-y-reverse: 0;\n --tw-space-x-reverse: 0;\n --tw-border-style: solid;\n --tw-gradient-position: initial;\n --tw-gradient-from: #0000;\n --tw-gradient-via: #0000;\n --tw-gradient-to: #0000;\n --tw-gradient-stops: initial;\n --tw-gradient-via-stops: initial;\n --tw-gradient-from-position: 0%;\n --tw-gradient-via-position: 50%;\n --tw-gradient-to-position: 100%;\n --tw-font-weight: initial;\n --tw-tracking: initial;\n --tw-ordinal: initial;\n --tw-slashed-zero: initial;\n --tw-numeric-figure: initial;\n --tw-numeric-spacing: initial;\n --tw-numeric-fraction: initial;\n --tw-shadow: 0 0 #0000;\n --tw-shadow-color: initial;\n --tw-shadow-alpha: 100%;\n --tw-inset-shadow: 0 0 #0000;\n --tw-inset-shadow-color: initial;\n --tw-inset-shadow-alpha: 100%;\n --tw-ring-color: initial;\n --tw-ring-shadow: 0 0 #0000;\n --tw-inset-ring-color: initial;\n --tw-inset-ring-shadow: 0 0 #0000;\n --tw-ring-inset: initial;\n --tw-ring-offset-width: 0px;\n --tw-ring-offset-color: #fff;\n --tw-ring-offset-shadow: 0 0 #0000;\n --tw-outline-style: solid;\n --tw-blur: initial;\n --tw-brightness: initial;\n --tw-contrast: initial;\n --tw-grayscale: initial;\n --tw-hue-rotate: initial;\n --tw-invert: initial;\n --tw-opacity: initial;\n --tw-saturate: initial;\n --tw-sepia: initial;\n --tw-drop-shadow: initial;\n --tw-drop-shadow-color: initial;\n --tw-drop-shadow-alpha: 100%;\n --tw-drop-shadow-size: initial;\n --tw-backdrop-blur: initial;\n --tw-backdrop-brightness: initial;\n --tw-backdrop-contrast: initial;\n --tw-backdrop-grayscale: initial;\n --tw-backdrop-hue-rotate: initial;\n --tw-backdrop-invert: initial;\n --tw-backdrop-opacity: initial;\n --tw-backdrop-saturate: initial;\n --tw-backdrop-sepia: initial;\n --tw-duration: initial;\n --tw-ease: initial;\n }\n }\n}\n"],"mappings":"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","names":[]}
|