@agg-market/ui 0.0.1 → 0.0.4

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.
Files changed (174) hide show
  1. package/dist/badge.d.mts +2 -2
  2. package/dist/badge.d.ts +2 -2
  3. package/dist/badge.mjs +2 -2
  4. package/dist/button.d.mts +2 -2
  5. package/dist/button.d.ts +2 -2
  6. package/dist/button.js +1 -0
  7. package/dist/button.mjs +3 -3
  8. package/dist/card.mjs +2 -2
  9. package/dist/chart.mjs +3 -3
  10. package/dist/{chunk-YUIZZ6XE.mjs → chunk-3O4U3E5I.mjs} +1 -1
  11. package/dist/{chunk-JLLMIPIX.mjs → chunk-4VUDTWH7.mjs} +1 -1
  12. package/dist/{chunk-MG243DSX.mjs → chunk-AEMAY3MR.mjs} +1 -1
  13. package/dist/{chunk-765JPQDG.mjs → chunk-BJNHDIDW.mjs} +4 -4
  14. package/dist/{chunk-LY6474C4.mjs → chunk-BLSHXIAH.mjs} +36 -71
  15. package/dist/{chunk-DQ6XFBYJ.mjs → chunk-DYEWXEEY.mjs} +1 -1
  16. package/dist/{chunk-OUOIDPGX.mjs → chunk-EXF4SESB.mjs} +1 -1
  17. package/dist/chunk-F236MLT6.mjs +1337 -0
  18. package/dist/{chunk-PAQ542ER.mjs → chunk-GHB3GOCW.mjs} +4 -2
  19. package/dist/{chunk-GC3QIIH7.mjs → chunk-GJ4U5NCE.mjs} +23 -1
  20. package/dist/chunk-HM3CGN32.mjs +669 -0
  21. package/dist/chunk-I4YUYVJJ.mjs +472 -0
  22. package/dist/{chunk-NFYS557L.mjs → chunk-JH5VMNDL.mjs} +3 -3
  23. package/dist/{chunk-TTOR7JCT.mjs → chunk-JRS2M5GY.mjs} +1 -1
  24. package/dist/{chunk-QXFDXXDB.mjs → chunk-LWTQD345.mjs} +3 -3
  25. package/dist/{chunk-QE46DVJG.mjs → chunk-MNSHWA6M.mjs} +3 -3
  26. package/dist/{chunk-H7P6DIX4.mjs → chunk-MXBPDNMC.mjs} +7 -7
  27. package/dist/{chunk-VYNVBJK6.mjs → chunk-NDG43KGL.mjs} +1 -1
  28. package/dist/chunk-O2XH4A3G.mjs +654 -0
  29. package/dist/{chunk-KDBYDMYV.mjs → chunk-OBCHURW5.mjs} +1 -1
  30. package/dist/{chunk-FZTAHWOS.mjs → chunk-OGI343OV.mjs} +2 -2
  31. package/dist/{chunk-HJOBAMDU.mjs → chunk-P23GR7NX.mjs} +2 -2
  32. package/dist/{chunk-J6L5BLKX.mjs → chunk-PGSPYQOW.mjs} +2 -2
  33. package/dist/{chunk-J7OETCZ7.mjs → chunk-QFQHD2V6.mjs} +19 -20
  34. package/dist/chunk-RGZQHSNJ.mjs +845 -0
  35. package/dist/{chunk-7XRKA6XF.mjs → chunk-RXACBTON.mjs} +5 -5
  36. package/dist/{chunk-2PGUPOXY.mjs → chunk-USLTNDJA.mjs} +15 -11
  37. package/dist/{chunk-FACIYUNK.mjs → chunk-VC7LTPQD.mjs} +2 -2
  38. package/dist/{chunk-CKTAVEW2.mjs → chunk-VIP7HSOU.mjs} +2 -2
  39. package/dist/{chunk-5MN6ZNFA.mjs → chunk-VUDJ3PYM.mjs} +9 -9
  40. package/dist/{chunk-MRHSN2B7.mjs → chunk-W2DMBW4E.mjs} +13 -9
  41. package/dist/{chunk-7CD7GIZC.mjs → chunk-XELWY7SO.mjs} +157 -50
  42. package/dist/chunk-ZDF7QP4G.mjs +160 -0
  43. package/dist/{chunk-4NK2FNAG.mjs → chunk-ZHKMDK5M.mjs} +244 -112
  44. package/dist/{chunk-C4OI72SM.mjs → chunk-ZVBVGWSP.mjs} +1 -0
  45. package/dist/chunk-ZYREURXK.mjs +470 -0
  46. package/dist/connect-button.js +767 -292
  47. package/dist/connect-button.mjs +8 -8
  48. package/dist/deposit-modal.d.mts +34 -0
  49. package/dist/deposit-modal.d.ts +34 -0
  50. package/dist/deposit-modal.js +2787 -0
  51. package/dist/deposit-modal.mjs +15 -0
  52. package/dist/event-list-item-details.js +271 -173
  53. package/dist/event-list-item-details.mjs +13 -13
  54. package/dist/event-list-item.js +903 -426
  55. package/dist/event-list-item.mjs +11 -11
  56. package/dist/event-list.js +1104 -517
  57. package/dist/event-list.mjs +14 -14
  58. package/dist/event-market-page.d.mts +1 -1
  59. package/dist/event-market-page.d.ts +1 -1
  60. package/dist/event-market-page.js +1513 -685
  61. package/dist/event-market-page.mjs +23 -23
  62. package/dist/hello-world.mjs +3 -3
  63. package/dist/home-page.d.mts +1 -1
  64. package/dist/home-page.d.ts +1 -1
  65. package/dist/home-page.js +1120 -533
  66. package/dist/home-page.mjs +15 -15
  67. package/dist/icon.d.mts +74 -4
  68. package/dist/icon.d.ts +74 -4
  69. package/dist/icon.js +668 -123
  70. package/dist/icon.mjs +32 -4
  71. package/dist/index.d.mts +16 -8
  72. package/dist/index.d.ts +16 -8
  73. package/dist/index.js +5309 -2151
  74. package/dist/index.mjs +80 -32
  75. package/dist/loading-icon.d.mts +1 -1
  76. package/dist/loading-icon.d.ts +1 -1
  77. package/dist/loading-icon.js +1 -0
  78. package/dist/loading-icon.mjs +3 -3
  79. package/dist/market-details.d.mts +2 -2
  80. package/dist/market-details.d.ts +2 -2
  81. package/dist/market-details.js +1097 -411
  82. package/dist/market-details.mjs +16 -16
  83. package/dist/modal.mjs +3 -3
  84. package/dist/number-value.mjs +2 -2
  85. package/dist/onboarding-modal.js +1249 -672
  86. package/dist/onboarding-modal.mjs +8 -8
  87. package/dist/place-order.d.mts +1 -1
  88. package/dist/place-order.d.ts +1 -1
  89. package/dist/place-order.js +1091 -506
  90. package/dist/place-order.mjs +12 -12
  91. package/dist/profile-modal.d.mts +66 -0
  92. package/dist/profile-modal.d.ts +66 -0
  93. package/dist/profile-modal.js +2429 -0
  94. package/dist/profile-modal.mjs +14 -0
  95. package/dist/{registry-CVn79H3I.d.mts → registry-DfSCFAdC.d.mts} +72 -0
  96. package/dist/{registry-CVn79H3I.d.ts → registry-DfSCFAdC.d.ts} +72 -0
  97. package/dist/search.d.mts +5 -23
  98. package/dist/search.d.ts +5 -23
  99. package/dist/search.js +740 -265
  100. package/dist/search.mjs +6 -6
  101. package/dist/select.d.mts +2 -0
  102. package/dist/select.d.ts +2 -0
  103. package/dist/select.js +814 -187
  104. package/dist/select.mjs +5 -5
  105. package/dist/settlement.d.mts +1 -1
  106. package/dist/settlement.d.ts +1 -1
  107. package/dist/settlement.js +891 -417
  108. package/dist/settlement.mjs +9 -9
  109. package/dist/skeleton.js +1 -1
  110. package/dist/skeleton.mjs +3 -3
  111. package/dist/styles.css +1 -1
  112. package/dist/switch-button.mjs +2 -2
  113. package/dist/tabs.js +854 -227
  114. package/dist/tabs.mjs +6 -6
  115. package/dist/tailwind.css +1 -1
  116. package/dist/types-Bed6Q0EK.d.mts +3 -0
  117. package/dist/types-Bed6Q0EK.d.ts +3 -0
  118. package/dist/{types-8VUuQVZq.d.mts → types-DkGlbmXq.d.mts} +24 -24
  119. package/dist/{types-8VUuQVZq.d.ts → types-DkGlbmXq.d.ts} +24 -24
  120. package/dist/typography.mjs +2 -2
  121. package/dist/user-profile-page.d.mts +133 -0
  122. package/dist/user-profile-page.d.ts +133 -0
  123. package/dist/user-profile-page.js +3335 -0
  124. package/dist/user-profile-page.mjs +15 -0
  125. package/dist/venue-logo.d.mts +2 -2
  126. package/dist/venue-logo.d.ts +2 -2
  127. package/dist/venue-logo.js +28 -70
  128. package/dist/venue-logo.mjs +2 -2
  129. package/dist/{venue-logo.types-Bg8eXtGp.d.ts → venue-logo.types-BSAuY84j.d.ts} +1 -1
  130. package/dist/{venue-logo.types-B1iPJgiD.d.mts → venue-logo.types-DACqcTvY.d.mts} +1 -1
  131. package/dist/withdraw-modal.d.mts +36 -0
  132. package/dist/withdraw-modal.d.ts +36 -0
  133. package/dist/withdraw-modal.js +2442 -0
  134. package/dist/withdraw-modal.mjs +14 -0
  135. package/package.json +275 -101
  136. package/dist/chunk-3DV3D2LH.mjs +0 -155
  137. package/dist/chunk-44UEI6KD.mjs +0 -280
  138. package/dist/chunk-4ADCXJE6.mjs +0 -297
  139. package/dist/chunk-4GSXVVSA.mjs +0 -64
  140. package/dist/chunk-4XWCYUV3.mjs +0 -355
  141. package/dist/chunk-6RRBINER.mjs +0 -50
  142. package/dist/chunk-AOFP74IB.mjs +0 -850
  143. package/dist/chunk-CB2MLGCJ.mjs +0 -279
  144. package/dist/chunk-DA6KZWSK.mjs +0 -807
  145. package/dist/chunk-DBD5GHHD.mjs +0 -147
  146. package/dist/chunk-FUJQIYOF.mjs +0 -37
  147. package/dist/chunk-GPBLZGJ2.mjs +0 -136
  148. package/dist/chunk-H4LELROL.mjs +0 -262
  149. package/dist/chunk-H7YEBGYY.mjs +0 -42
  150. package/dist/chunk-IJG5I642.mjs +0 -462
  151. package/dist/chunk-IY2AA3OL.mjs +0 -50
  152. package/dist/chunk-KBRLFTJT.mjs +0 -741
  153. package/dist/chunk-L6E6Q4C4.mjs +0 -217
  154. package/dist/chunk-M23S2DVV.mjs +0 -581
  155. package/dist/chunk-MXWRCVRJ.mjs +0 -285
  156. package/dist/chunk-NNSY462N.mjs +0 -212
  157. package/dist/chunk-P5PFQX75.mjs +0 -31
  158. package/dist/chunk-P674XRDY.mjs +0 -481
  159. package/dist/chunk-R3DRVI4J.mjs +0 -741
  160. package/dist/chunk-V5WIYMKS.mjs +0 -25
  161. package/dist/chunk-VAZE267Q.mjs +0 -82
  162. package/dist/chunk-VLIJ7PQK.mjs +0 -792
  163. package/dist/chunk-WIWJ6DIE.mjs +0 -323
  164. package/dist/chunk-XDAEEJYR.mjs +0 -142
  165. package/dist/event-list-item-details.types-CxWr4Qn1.d.ts +0 -53
  166. package/dist/event-list-item-details.types-DRi99PZq.d.mts +0 -53
  167. package/dist/event-list-item.types-B1490EQm.d.mts +0 -46
  168. package/dist/event-list-item.types-B1490EQm.d.ts +0 -46
  169. package/dist/event-list.types-Bpp6Vn-t.d.mts +0 -13
  170. package/dist/event-list.types-Bpp6Vn-t.d.ts +0 -13
  171. package/dist/types-CayJ8tWA.d.mts +0 -3
  172. package/dist/types-CayJ8tWA.d.ts +0 -3
  173. package/dist/venue-logo.types-4hmCg3D3.d.ts +0 -17
  174. package/dist/venue-logo.types-QNDwiQ77.d.mts +0 -17
@@ -1,462 +0,0 @@
1
- import {
2
- LoadingIcon
3
- } from "./chunk-VAZE267Q.mjs";
4
- import {
5
- VenueLogo
6
- } from "./chunk-4ADCXJE6.mjs";
7
- import {
8
- Icon
9
- } from "./chunk-DA6KZWSK.mjs";
10
- import {
11
- Button
12
- } from "./chunk-GPBLZGJ2.mjs";
13
- import {
14
- AGG_ROOT_CLASS_NAME,
15
- __spreadProps,
16
- __spreadValues,
17
- cn,
18
- formatUsd,
19
- getMotionClassName,
20
- shortenAddress
21
- } from "./chunk-GC3QIIH7.mjs";
22
-
23
- // src/auth/connect-button/index.tsx
24
- import { useEffect, useMemo, useRef, useState } from "react";
25
- import * as DropdownMenu from "@radix-ui/react-dropdown-menu";
26
- import { isAddress } from "viem";
27
- import { useAccount, useConnect, useDisconnect, useSignMessage } from "wagmi";
28
- import {
29
- getWalletAddressFromUserProfile,
30
- useAggAuth,
31
- useAggBalanceState,
32
- useLabels,
33
- useSdkUiConfig
34
- } from "@agg/hooks";
35
-
36
- // src/auth/connect-button/connect-button.constants.ts
37
- var connectButtonContainerClassName = cn(
38
- "inline-flex flex-col items-start gap-2 font-agg-sans"
39
- );
40
- var connectedButtonsRowClassName = cn("inline-flex h-10 items-center gap-2");
41
- var connectedBalanceChipClassName = cn(
42
- "inline-flex h-10 items-center gap-3 rounded-agg-full border border-agg-separator bg-agg-secondary pl-3 pr-12 font-agg-sans"
43
- );
44
- var connectedProfileChipClassName = cn(
45
- "-ml-12",
46
- "inline-flex h-10 items-center gap-3 rounded-agg-full border border-agg-separator bg-agg-secondary pl-2 pr-3 font-agg-sans",
47
- "cursor-pointer hover:bg-agg-secondary-hover",
48
- "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-agg-primary-hover focus-visible:ring-offset-2 focus-visible:ring-offset-agg-secondary"
49
- );
50
- var profileMenuContentClassName = cn(
51
- "z-50 w-64 overflow-hidden rounded-agg-xl font-agg-sans",
52
- "border border-agg-separator bg-agg-secondary",
53
- "shadow-agg-popover"
54
- );
55
- var profileMenuSectionClassName = cn("flex w-full flex-col gap-5 px-5 py-5");
56
- var profileMenuSeparatorClassName = cn("h-px w-full bg-agg-separator");
57
- var profileMenuActionItemClassName = cn(
58
- "flex w-full items-center gap-3 px-5 py-4 font-agg-sans text-agg-sm leading-agg-5 text-agg-foreground",
59
- "outline-none",
60
- "hover:bg-agg-secondary-hover focus:bg-agg-secondary-hover"
61
- );
62
- var avatarRootClassName = cn(
63
- "inline-flex size-6 shrink-0 items-center justify-center rounded-agg-full bg-agg-separator"
64
- );
65
- var avatarIconClassName = cn("h-[66%] w-[66%] text-agg-muted-foreground");
66
-
67
- // src/auth/connect-button/index.tsx
68
- import { Fragment, jsx, jsxs } from "react/jsx-runtime";
69
- var venueLogoNameSet = /* @__PURE__ */ new Set([
70
- "polymarket",
71
- "kalshi",
72
- "opinion",
73
- "probable"
74
- ]);
75
- var toVenueLogoName = (value) => {
76
- if (!venueLogoNameSet.has(value))
77
- return null;
78
- return value;
79
- };
80
- function WalletAvatar({ className }) {
81
- return /* @__PURE__ */ jsx("span", { "aria-hidden": "true", className: cn(avatarRootClassName, className), children: /* @__PURE__ */ jsx(Icon, { className: avatarIconClassName, name: "wallet-avatar" }) });
82
- }
83
- var ConnectButton = ({
84
- autoSignInOnConnect = true,
85
- buttonProps,
86
- classNames,
87
- disabled,
88
- onConnect,
89
- onDepositClick,
90
- onDisconnect,
91
- onProfileClick,
92
- onViewAllBalancesClick,
93
- onWithdrawClick
94
- }) => {
95
- var _a, _b;
96
- const [isProfileMenuOpen, setIsProfileMenuOpen] = useState(false);
97
- const autoSignInAttemptRef = useRef(null);
98
- const { enableAnimations, rootClassName } = useSdkUiConfig();
99
- const labels = useLabels();
100
- const { address: walletAddress, chainId, isConnected: isWalletConnected } = useAccount();
101
- const { connect, connectors, isPending: isConnectPending } = useConnect();
102
- const { disconnect } = useDisconnect();
103
- const { signMessageAsync } = useSignMessage();
104
- const {
105
- totalBalance,
106
- balanceBreakdown,
107
- connectedVenues,
108
- isLoading: isBalanceLoading,
109
- error: balanceError
110
- } = useAggBalanceState();
111
- const preferredConnector = useMemo(() => {
112
- var _a2;
113
- return (_a2 = connectors.find((connector) => connector.name === "MetaMask")) != null ? _a2 : connectors[0];
114
- }, [connectors]);
115
- const signInStatement = labels.auth.signInStatement;
116
- const { signIn, signOut, isAuthenticated, user, isLoading, error } = useAggAuth({
117
- signMessage: (message) => signMessageAsync({ message }),
118
- address: walletAddress != null ? walletAddress : "",
119
- chainId
120
- });
121
- const resolvedWalletAddress = (_b = (_a = getWalletAddressFromUserProfile(user)) != null ? _a : walletAddress) != null ? _b : "";
122
- const resolvedAddressLabel = shortenAddress(resolvedWalletAddress);
123
- const resolvedProfileLabel = resolvedAddressLabel;
124
- const resolvedBalanceRows = useMemo(() => {
125
- const balancesByVenue = /* @__PURE__ */ new Map();
126
- for (const balanceItem of balanceBreakdown) {
127
- balancesByVenue.set(balanceItem.venue, balanceItem.balance);
128
- }
129
- for (const venue of connectedVenues) {
130
- if (!balancesByVenue.has(venue)) {
131
- balancesByVenue.set(venue, 0);
132
- }
133
- }
134
- return Array.from(balancesByVenue.entries()).map(([venue, balanceValue]) => {
135
- var _a2;
136
- return {
137
- key: venue,
138
- label: (_a2 = labels.venues[venue]) != null ? _a2 : venue,
139
- amountLabel: formatUsd(balanceValue),
140
- venue: toVenueLogoName(venue)
141
- };
142
- });
143
- }, [balanceBreakdown, connectedVenues, labels.venues]);
144
- const errorText = error ? `Error: ${error.message}` : null;
145
- const balanceErrorText = balanceError ? `Error: ${balanceError.message}` : null;
146
- const resolvedErrorText = errorText != null ? errorText : balanceErrorText;
147
- const normalizedWalletAddress = (walletAddress != null ? walletAddress : "").toLowerCase();
148
- const hasWalletAddress = isAddress(walletAddress != null ? walletAddress : "");
149
- const isConnectDisabled = disabled || isConnectPending || !preferredConnector;
150
- const dropdownMenuItemClassName = cn(
151
- "cursor-pointer",
152
- profileMenuActionItemClassName,
153
- getMotionClassName(enableAnimations, "transition-colors"),
154
- disabled ? "pointer-events-none opacity-50" : null,
155
- classNames == null ? void 0 : classNames.profileMenuActionItem
156
- );
157
- useEffect(() => {
158
- if (!autoSignInOnConnect) {
159
- autoSignInAttemptRef.current = null;
160
- return;
161
- }
162
- if (!isWalletConnected || isAuthenticated || isLoading || !hasWalletAddress) {
163
- if (!isWalletConnected || isAuthenticated) {
164
- autoSignInAttemptRef.current = null;
165
- }
166
- return;
167
- }
168
- const attemptKey = `${normalizedWalletAddress}:${chainId != null ? chainId : "unknown"}`;
169
- if (autoSignInAttemptRef.current === attemptKey)
170
- return;
171
- autoSignInAttemptRef.current = attemptKey;
172
- void signIn(signInStatement).catch(() => void 0);
173
- }, [
174
- autoSignInOnConnect,
175
- chainId,
176
- hasWalletAddress,
177
- isAuthenticated,
178
- isLoading,
179
- isWalletConnected,
180
- normalizedWalletAddress,
181
- signIn,
182
- signInStatement
183
- ]);
184
- const handleConnectClick = () => {
185
- if (isConnectDisabled || !preferredConnector)
186
- return;
187
- connect({ connector: preferredConnector });
188
- if (!onConnect)
189
- return;
190
- void Promise.resolve(onConnect());
191
- };
192
- const handleSignInClick = () => {
193
- if (disabled || isLoading || !hasWalletAddress)
194
- return;
195
- void signIn(signInStatement);
196
- };
197
- const handleDepositClick = () => {
198
- if (disabled)
199
- return;
200
- if (!onDepositClick)
201
- return;
202
- void Promise.resolve(onDepositClick());
203
- };
204
- const handleProfileItemClick = () => {
205
- if (disabled)
206
- return;
207
- if (!onProfileClick)
208
- return;
209
- void Promise.resolve(onProfileClick());
210
- };
211
- const handleWithdrawClick = () => {
212
- if (disabled)
213
- return;
214
- if (!onWithdrawClick)
215
- return;
216
- void Promise.resolve(onWithdrawClick());
217
- };
218
- const handleViewAllBalancesClick = () => {
219
- if (disabled)
220
- return;
221
- if (!onViewAllBalancesClick)
222
- return;
223
- void Promise.resolve(onViewAllBalancesClick());
224
- };
225
- const handleDisconnectClick = () => {
226
- if (disabled)
227
- return;
228
- signOut();
229
- disconnect();
230
- if (!onDisconnect)
231
- return;
232
- void Promise.resolve(onDisconnect());
233
- };
234
- const handleProfileMenuOpenChange = (open) => {
235
- if (disabled)
236
- return;
237
- setIsProfileMenuOpen(open);
238
- };
239
- if (resolvedErrorText) {
240
- console.error({ resolvedErrorText });
241
- }
242
- if (!isWalletConnected) {
243
- return /* @__PURE__ */ jsx("div", { className: cn(connectButtonContainerClassName, classNames == null ? void 0 : classNames.root), children: /* @__PURE__ */ jsx(
244
- Button,
245
- __spreadProps(__spreadValues({
246
- variant: "primary",
247
- size: "l",
248
- className: classNames == null ? void 0 : classNames.connectButton,
249
- onClick: handleConnectClick,
250
- disabled: isConnectDisabled,
251
- "aria-label": labels.auth.connect(preferredConnector == null ? void 0 : preferredConnector.name)
252
- }, buttonProps), {
253
- children: labels.auth.connect(preferredConnector == null ? void 0 : preferredConnector.name)
254
- })
255
- ) });
256
- }
257
- if (!isAuthenticated) {
258
- return /* @__PURE__ */ jsx("div", { className: cn(connectButtonContainerClassName, classNames == null ? void 0 : classNames.root), children: /* @__PURE__ */ jsx(
259
- Button,
260
- __spreadProps(__spreadValues({
261
- variant: "primary",
262
- size: "l",
263
- className: classNames == null ? void 0 : classNames.signInButton,
264
- onClick: handleSignInClick,
265
- disabled: disabled || !hasWalletAddress,
266
- isLoading,
267
- "aria-label": isLoading ? labels.auth.signingIn : labels.auth.signIn
268
- }, buttonProps), {
269
- children: isLoading ? labels.auth.signingIn : labels.auth.signIn
270
- })
271
- ) });
272
- }
273
- return /* @__PURE__ */ jsx("div", { className: cn(connectButtonContainerClassName, classNames == null ? void 0 : classNames.root), children: /* @__PURE__ */ jsxs("div", { className: cn(connectedButtonsRowClassName, classNames == null ? void 0 : classNames.connectedRow), children: [
274
- /* @__PURE__ */ jsxs("div", { className: cn(connectedBalanceChipClassName, classNames == null ? void 0 : classNames.balanceChip), children: [
275
- /* @__PURE__ */ jsx(
276
- Button,
277
- {
278
- variant: "primary",
279
- size: "xxs",
280
- className: cn("h-6 px-3 text-agg-xs leading-agg-4", classNames == null ? void 0 : classNames.depositButton),
281
- onClick: handleDepositClick,
282
- disabled,
283
- "aria-label": labels.auth.deposit,
284
- children: labels.auth.deposit
285
- }
286
- ),
287
- /* @__PURE__ */ jsx(
288
- "p",
289
- {
290
- className: cn("text-agg-sm leading-none text-agg-foreground", classNames == null ? void 0 : classNames.balanceText),
291
- children: isBalanceLoading ? /* @__PURE__ */ jsx(LoadingIcon, { size: "s" }) : formatUsd(totalBalance)
292
- }
293
- )
294
- ] }),
295
- /* @__PURE__ */ jsxs(DropdownMenu.Root, { open: isProfileMenuOpen, onOpenChange: handleProfileMenuOpenChange, children: [
296
- /* @__PURE__ */ jsx(DropdownMenu.Trigger, { asChild: true, children: /* @__PURE__ */ jsxs(
297
- "button",
298
- {
299
- type: "button",
300
- className: cn(
301
- connectedProfileChipClassName,
302
- getMotionClassName(enableAnimations, "transition-colors"),
303
- classNames == null ? void 0 : classNames.profileTrigger
304
- ),
305
- disabled,
306
- "aria-label": labels.auth.walletMenuFor(resolvedProfileLabel),
307
- children: [
308
- /* @__PURE__ */ jsx(WalletAvatar, {}),
309
- /* @__PURE__ */ jsx(
310
- "span",
311
- {
312
- className: cn(
313
- "text-agg-base font-agg-bold leading-none text-agg-foreground",
314
- classNames == null ? void 0 : classNames.profileTriggerLabel
315
- ),
316
- children: resolvedProfileLabel
317
- }
318
- ),
319
- /* @__PURE__ */ jsx(
320
- Icon,
321
- {
322
- name: isProfileMenuOpen ? "chevron-up" : "chevron-down",
323
- size: "s",
324
- className: "h-3.5 w-3.5 text-agg-foreground",
325
- "aria-hidden": "true"
326
- }
327
- )
328
- ]
329
- }
330
- ) }),
331
- /* @__PURE__ */ jsx(DropdownMenu.Portal, { children: /* @__PURE__ */ jsxs(
332
- DropdownMenu.Content,
333
- {
334
- className: cn(
335
- AGG_ROOT_CLASS_NAME,
336
- rootClassName,
337
- profileMenuContentClassName,
338
- classNames == null ? void 0 : classNames.profileMenuContent
339
- ),
340
- "data-agg-animations": enableAnimations ? "true" : "false",
341
- sideOffset: 4,
342
- align: "end",
343
- children: [
344
- /* @__PURE__ */ jsx(
345
- "div",
346
- {
347
- className: cn(
348
- profileMenuSectionClassName,
349
- "cursor-pointer",
350
- classNames == null ? void 0 : classNames.profileMenuSection
351
- ),
352
- onClick: handleProfileItemClick,
353
- children: /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-3", children: [
354
- /* @__PURE__ */ jsx(WalletAvatar, { className: "size-11" }),
355
- /* @__PURE__ */ jsxs("div", { className: "flex flex-col items-start gap-0.5", children: [
356
- /* @__PURE__ */ jsx("p", { className: "text-agg-lg font-agg-bold leading-agg-7 text-agg-foreground", children: resolvedProfileLabel }),
357
- /* @__PURE__ */ jsx("p", { className: "text-agg-sm font-agg-normal leading-agg-5 text-agg-muted-foreground", children: resolvedAddressLabel })
358
- ] })
359
- ] })
360
- }
361
- ),
362
- /* @__PURE__ */ jsx(
363
- "div",
364
- {
365
- className: cn(profileMenuSeparatorClassName, classNames == null ? void 0 : classNames.profileMenuSeparator)
366
- }
367
- ),
368
- /* @__PURE__ */ jsxs("div", { className: cn(profileMenuSectionClassName, classNames == null ? void 0 : classNames.profileMenuSection), children: [
369
- isBalanceLoading ? /* @__PURE__ */ jsxs("p", { className: "flex flex-col gap-2 items-center justify-center text-agg-sm font-agg-normal leading-agg-5 text-agg-muted-foreground", children: [
370
- /* @__PURE__ */ jsx(LoadingIcon, {}),
371
- labels.auth.loadingBalances
372
- ] }) : /* @__PURE__ */ jsx(Fragment, { children: resolvedBalanceRows.length === 0 ? /* @__PURE__ */ jsxs("p", { className: "flex flex-col gap-2 items-center justify-center text-agg-sm font-agg-normal leading-agg-5 text-agg-muted-foreground", children: [
373
- /* @__PURE__ */ jsx(Icon, { name: "warning", className: "text-agg-primary" }),
374
- labels.auth.noBalances
375
- ] }) : /* @__PURE__ */ jsxs("div", { className: "flex w-full items-center justify-between", children: [
376
- /* @__PURE__ */ jsx("p", { className: "text-agg-xs font-agg-bold uppercase leading-agg-4 tracking-agg-normal text-agg-muted-foreground", children: labels.auth.balances }),
377
- /* @__PURE__ */ jsx(
378
- Button,
379
- {
380
- variant: "tertiary",
381
- size: "xxs",
382
- className: "h-6 px-3 text-agg-xs leading-agg-4",
383
- onClick: handleViewAllBalancesClick,
384
- children: labels.auth.viewAll
385
- }
386
- )
387
- ] }) }),
388
- !isBalanceLoading ? resolvedBalanceRows.map((row) => /* @__PURE__ */ jsxs("div", { className: "flex w-full items-center justify-between", children: [
389
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1.5", children: [
390
- row.venue ? /* @__PURE__ */ jsx(VenueLogo, { venue: row.venue, size: "s" }) : null,
391
- /* @__PURE__ */ jsx("p", { className: "text-agg-sm font-agg-normal leading-agg-5 text-agg-foreground", children: row.label })
392
- ] }),
393
- /* @__PURE__ */ jsx("p", { className: "text-agg-sm font-agg-bold leading-agg-5 text-agg-foreground", children: row.amountLabel })
394
- ] }, row.key)) : null
395
- ] }),
396
- /* @__PURE__ */ jsx(
397
- "div",
398
- {
399
- className: cn(profileMenuSeparatorClassName, classNames == null ? void 0 : classNames.profileMenuSeparator)
400
- }
401
- ),
402
- /* @__PURE__ */ jsxs("div", { className: "flex w-full flex-col py-2", children: [
403
- /* @__PURE__ */ jsxs(
404
- DropdownMenu.Item,
405
- {
406
- className: dropdownMenuItemClassName,
407
- onSelect: handleProfileItemClick,
408
- disabled,
409
- children: [
410
- /* @__PURE__ */ jsx(Icon, { name: "profile", size: "s", className: "text-agg-foreground" }),
411
- /* @__PURE__ */ jsx("span", { children: labels.auth.myProfile })
412
- ]
413
- }
414
- ),
415
- /* @__PURE__ */ jsxs(
416
- DropdownMenu.Item,
417
- {
418
- className: dropdownMenuItemClassName,
419
- onSelect: handleDepositClick,
420
- disabled,
421
- children: [
422
- /* @__PURE__ */ jsx(Icon, { name: "download", size: "s", className: "text-agg-foreground" }),
423
- /* @__PURE__ */ jsx("span", { children: labels.auth.deposit })
424
- ]
425
- }
426
- ),
427
- /* @__PURE__ */ jsxs(
428
- DropdownMenu.Item,
429
- {
430
- className: dropdownMenuItemClassName,
431
- onSelect: handleWithdrawClick,
432
- disabled,
433
- children: [
434
- /* @__PURE__ */ jsx(Icon, { name: "upload", size: "s", className: "text-agg-foreground" }),
435
- /* @__PURE__ */ jsx("span", { children: labels.auth.withdraw })
436
- ]
437
- }
438
- ),
439
- /* @__PURE__ */ jsxs(
440
- DropdownMenu.Item,
441
- {
442
- className: dropdownMenuItemClassName,
443
- onSelect: handleDisconnectClick,
444
- disabled,
445
- children: [
446
- /* @__PURE__ */ jsx(Icon, { name: "disconnect", size: "s", className: "text-agg-foreground" }),
447
- /* @__PURE__ */ jsx("span", { children: labels.auth.disconnect })
448
- ]
449
- }
450
- )
451
- ] })
452
- ]
453
- }
454
- ) })
455
- ] })
456
- ] }) });
457
- };
458
- ConnectButton.displayName = "ConnectButton";
459
-
460
- export {
461
- ConnectButton
462
- };
@@ -1,50 +0,0 @@
1
- import {
2
- Icon
3
- } from "./chunk-DA6KZWSK.mjs";
4
- import {
5
- cn,
6
- getMotionClassName
7
- } from "./chunk-GC3QIIH7.mjs";
8
-
9
- // src/primitives/select/index.tsx
10
- import { useLabels, useSdkUiConfig } from "@agg-market/hooks";
11
- import { jsx, jsxs } from "react/jsx-runtime";
12
- var Select = ({
13
- items,
14
- value,
15
- onChange,
16
- ariaLabel,
17
- className,
18
- disabled = false
19
- }) => {
20
- const labels = useLabels();
21
- const { enableAnimations } = useSdkUiConfig();
22
- const hasEnabledItems = items.some((item) => !item.disabled);
23
- return /* @__PURE__ */ jsxs("label", { className: cn("relative inline-flex w-full", className), children: [
24
- /* @__PURE__ */ jsx(
25
- "select",
26
- {
27
- "aria-label": ariaLabel != null ? ariaLabel : labels.common.selectAria,
28
- className: cn(
29
- "w-full appearance-none rounded-agg-md border border-agg-separator bg-agg-secondary px-4 py-2 pr-10 font-agg-sans text-agg-sm leading-agg-5 text-agg-foreground outline-none",
30
- getMotionClassName(
31
- enableAnimations,
32
- "transition-[border-color,box-shadow] duration-200 ease-out"
33
- ),
34
- "focus:border-agg-primary focus:ring-2 focus:ring-agg-primary/15",
35
- "disabled:cursor-not-allowed disabled:opacity-60"
36
- ),
37
- disabled: disabled || !hasEnabledItems,
38
- value,
39
- onChange: (event) => onChange(event.target.value),
40
- children: items.map((item) => /* @__PURE__ */ jsx("option", { value: item.value, disabled: item.disabled, children: item.label }, item.value))
41
- }
42
- ),
43
- /* @__PURE__ */ jsx("span", { className: "pointer-events-none absolute inset-y-0 right-3 inline-flex items-center justify-center text-agg-muted-foreground", children: /* @__PURE__ */ jsx(Icon, { name: "chevron-down", size: "s", color: "currentColor" }) })
44
- ] });
45
- };
46
- Select.displayName = "Select";
47
-
48
- export {
49
- Select
50
- };