@0xsquid/ui 2.7.1-dex-beta.1 → 2.8.0

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 (107) hide show
  1. package/dist/cjs/index.js +18509 -18394
  2. package/dist/cjs/types/components/badges/ImageGroup.d.ts +1 -1
  3. package/dist/cjs/types/components/badges/PriceChange.d.ts +2 -2
  4. package/dist/cjs/types/components/badges/index.d.ts +1 -1
  5. package/dist/cjs/types/components/buttons/Button.d.ts +2 -1
  6. package/dist/cjs/types/components/buttons/IconButton.d.ts +0 -2
  7. package/dist/cjs/types/components/controls/LargeNumericInput.d.ts +2 -6
  8. package/dist/cjs/types/components/controls/NumericInput.d.ts +21 -13
  9. package/dist/cjs/types/components/feedback/AnimateNumber.d.ts +8 -0
  10. package/dist/cjs/types/components/feedback/LoadingText.d.ts +7 -0
  11. package/dist/cjs/types/components/feedback/index.d.ts +3 -0
  12. package/dist/cjs/types/components/icons/Arrow.d.ts +1 -6
  13. package/dist/cjs/types/components/icons/CrossAnimatedIcon.d.ts +7 -0
  14. package/dist/cjs/types/components/icons/Generic.d.ts +0 -29
  15. package/dist/cjs/types/components/icons/Loader.d.ts +1 -1
  16. package/dist/cjs/types/components/icons/PaymentIcons.d.ts +12 -0
  17. package/dist/cjs/types/components/icons/SwapInputs.d.ts +4 -1
  18. package/dist/cjs/types/components/icons/Wallet.d.ts +1 -1
  19. package/dist/cjs/types/components/icons/index.d.ts +2 -0
  20. package/dist/cjs/types/components/index.d.ts +1 -1
  21. package/dist/cjs/types/components/layout/AppContainer.d.ts +3 -523
  22. package/dist/cjs/types/components/layout/DropdownMenu.d.ts +0 -1
  23. package/dist/cjs/types/components/layout/NavigationBar.d.ts +2 -1
  24. package/dist/cjs/types/components/layout/SwapConfiguration.d.ts +17 -1
  25. package/dist/cjs/types/components/layout/TokenDetailsView.d.ts +1 -6
  26. package/dist/cjs/types/components/lists/HistoryItem.d.ts +2 -1
  27. package/dist/cjs/types/components/lists/TokenGroup.d.ts +1 -2
  28. package/dist/cjs/types/components/views/SwapProgressView.d.ts +2 -1
  29. package/dist/cjs/types/core/constants.d.ts +1 -1
  30. package/dist/cjs/types/core/index.d.ts +1 -1
  31. package/dist/cjs/types/core/utils.d.ts +16 -0
  32. package/dist/cjs/types/hooks/index.d.ts +3 -2
  33. package/dist/cjs/types/hooks/useMeasure.d.ts +36 -0
  34. package/dist/cjs/types/hooks/useNumericInput.d.ts +35 -0
  35. package/dist/cjs/types/services/internal/colorService.d.ts +0 -2
  36. package/dist/cjs/types/stories/badges/ImageGroup.stories.d.ts +2 -3
  37. package/dist/cjs/types/stories/buttons/Button.stories.d.ts +3 -0
  38. package/dist/cjs/types/stories/buttons/IconButon.stories.d.ts +1 -1
  39. package/dist/cjs/types/stories/controls/NumericInput.stories.d.ts +17 -0
  40. package/dist/cjs/types/stories/feedback/AnimateNumber.stories.d.ts +6 -0
  41. package/dist/{esm/types/stories/badges → cjs/types/stories/feedback}/Loader.stories.d.ts +1 -1
  42. package/dist/cjs/types/stories/{badges → feedback}/LoadingSkeleton.stories.d.ts +2 -2
  43. package/dist/cjs/types/stories/feedback/LoadingText.stories.d.ts +6 -0
  44. package/dist/cjs/types/stories/layout/NavigationBar.stories.d.ts +1 -0
  45. package/dist/cjs/types/stories/layout/SwapConfiguration.stories.d.ts +1 -1
  46. package/dist/cjs/types/stories/lists/ListItem.stories.d.ts +0 -1
  47. package/dist/cjs/types/stories/lists/TokenGroup.stories.d.ts +0 -1
  48. package/dist/cjs/types/stories/views/SwapProgressView.stories.d.ts +1 -0
  49. package/dist/esm/index.js +18858 -18740
  50. package/dist/esm/types/components/badges/ImageGroup.d.ts +1 -1
  51. package/dist/esm/types/components/badges/PriceChange.d.ts +2 -2
  52. package/dist/esm/types/components/badges/index.d.ts +1 -1
  53. package/dist/esm/types/components/buttons/Button.d.ts +2 -1
  54. package/dist/esm/types/components/buttons/IconButton.d.ts +0 -2
  55. package/dist/esm/types/components/controls/LargeNumericInput.d.ts +2 -6
  56. package/dist/esm/types/components/controls/NumericInput.d.ts +21 -13
  57. package/dist/esm/types/components/feedback/AnimateNumber.d.ts +8 -0
  58. package/dist/esm/types/components/feedback/LoadingText.d.ts +7 -0
  59. package/dist/esm/types/components/feedback/index.d.ts +3 -0
  60. package/dist/esm/types/components/icons/Arrow.d.ts +1 -6
  61. package/dist/esm/types/components/icons/CrossAnimatedIcon.d.ts +7 -0
  62. package/dist/esm/types/components/icons/Generic.d.ts +0 -29
  63. package/dist/esm/types/components/icons/Loader.d.ts +1 -1
  64. package/dist/esm/types/components/icons/PaymentIcons.d.ts +12 -0
  65. package/dist/esm/types/components/icons/SwapInputs.d.ts +4 -1
  66. package/dist/esm/types/components/icons/Wallet.d.ts +1 -1
  67. package/dist/esm/types/components/icons/index.d.ts +2 -0
  68. package/dist/esm/types/components/index.d.ts +1 -1
  69. package/dist/esm/types/components/layout/AppContainer.d.ts +3 -523
  70. package/dist/esm/types/components/layout/DropdownMenu.d.ts +0 -1
  71. package/dist/esm/types/components/layout/NavigationBar.d.ts +2 -1
  72. package/dist/esm/types/components/layout/SwapConfiguration.d.ts +17 -1
  73. package/dist/esm/types/components/layout/TokenDetailsView.d.ts +1 -6
  74. package/dist/esm/types/components/lists/HistoryItem.d.ts +2 -1
  75. package/dist/esm/types/components/lists/TokenGroup.d.ts +1 -2
  76. package/dist/esm/types/components/views/SwapProgressView.d.ts +2 -1
  77. package/dist/esm/types/core/constants.d.ts +1 -1
  78. package/dist/esm/types/core/index.d.ts +1 -1
  79. package/dist/esm/types/core/utils.d.ts +16 -0
  80. package/dist/esm/types/hooks/index.d.ts +3 -2
  81. package/dist/esm/types/hooks/useMeasure.d.ts +36 -0
  82. package/dist/esm/types/hooks/useNumericInput.d.ts +35 -0
  83. package/dist/esm/types/services/internal/colorService.d.ts +0 -2
  84. package/dist/esm/types/stories/badges/ImageGroup.stories.d.ts +2 -3
  85. package/dist/esm/types/stories/buttons/Button.stories.d.ts +3 -0
  86. package/dist/esm/types/stories/buttons/IconButon.stories.d.ts +1 -1
  87. package/dist/esm/types/stories/controls/NumericInput.stories.d.ts +17 -0
  88. package/dist/esm/types/stories/feedback/AnimateNumber.stories.d.ts +6 -0
  89. package/dist/{cjs/types/stories/badges → esm/types/stories/feedback}/Loader.stories.d.ts +1 -1
  90. package/dist/esm/types/stories/{badges → feedback}/LoadingSkeleton.stories.d.ts +2 -2
  91. package/dist/esm/types/stories/feedback/LoadingText.stories.d.ts +6 -0
  92. package/dist/esm/types/stories/layout/NavigationBar.stories.d.ts +1 -0
  93. package/dist/esm/types/stories/layout/SwapConfiguration.stories.d.ts +1 -1
  94. package/dist/esm/types/stories/lists/ListItem.stories.d.ts +0 -1
  95. package/dist/esm/types/stories/lists/TokenGroup.stories.d.ts +0 -1
  96. package/dist/esm/types/stories/views/SwapProgressView.stories.d.ts +1 -0
  97. package/dist/index.css +1 -1
  98. package/dist/index.d.ts +140 -640
  99. package/package.json +2 -1
  100. package/dist/cjs/types/components/charts/DexChart.d.ts +0 -32
  101. package/dist/cjs/types/components/charts/index.d.ts +0 -1
  102. package/dist/cjs/types/stories/charts/DexChart.stories.d.ts +0 -10
  103. package/dist/esm/types/components/charts/DexChart.d.ts +0 -32
  104. package/dist/esm/types/components/charts/index.d.ts +0 -1
  105. package/dist/esm/types/stories/charts/DexChart.stories.d.ts +0 -10
  106. /package/dist/cjs/types/components/{badges → feedback}/LoadingSkeleton.d.ts +0 -0
  107. /package/dist/esm/types/components/{badges → feedback}/LoadingSkeleton.d.ts +0 -0
@@ -18,6 +18,5 @@ export interface TokenGroupProps<T> {
18
18
  onChildClick?: (tokenProps: T) => void;
19
19
  isAdjacentToPreviousExpanded?: boolean;
20
20
  isAdjacentToNextExpanded?: boolean;
21
- action?: React.ReactNode;
22
21
  }
23
- export declare function TokenGroup<T extends TokenGroupProps<T>>({ isSelected, tokenItems, priceChange, balance, balanceUsd, extraSpacing, chainImageUrl, imageUrl, symbol, name, onClick, variant, className, onChildClick, isAdjacentToPreviousExpanded, isAdjacentToNextExpanded, action, }: TokenGroupProps<T>): import("react/jsx-runtime").JSX.Element;
22
+ export declare function TokenGroup<T extends TokenGroupProps<T>>({ isSelected, tokenItems, priceChange, balance, balanceUsd, extraSpacing, chainImageUrl, imageUrl, symbol, name, onClick, variant, className, onChildClick, isAdjacentToPreviousExpanded, isAdjacentToNextExpanded, }: TokenGroupProps<T>): import("react/jsx-runtime").JSX.Element;
@@ -10,7 +10,7 @@ interface Token {
10
10
  logoUrl: string;
11
11
  bgColor: string;
12
12
  }
13
- export declare function SwapProgressView({ steps, isOpen, handleClose, handleComplete, supportLink, fromAmount, fromChain, fromToken, toAmount, toChain, toToken, fromAddressFormatted, toAddressFormatted, swapState, estimatedTimeToComplete, footerButton, refundTokenSymbol, addGasLink, shareSwapDropdownContent, }: {
13
+ export declare function SwapProgressView({ steps, isOpen, handleClose, handleComplete, supportLink, fromAmount, fromChain, fromToken, toAmount, toChain, toToken, fromAddressFormatted, toAddressFormatted, swapState, estimatedTimeToComplete, footerButton, refundTokenSymbol, addGasLink, shareSwapDropdownContent, isSendTransaction, }: {
14
14
  steps: SwapStep[];
15
15
  handleClose?: (swapState: SwapState) => void;
16
16
  handleComplete?: () => void;
@@ -30,5 +30,6 @@ export declare function SwapProgressView({ steps, isOpen, handleClose, handleCom
30
30
  footerButton?: SwapStepsCollapsedFooterButton;
31
31
  refundTokenSymbol?: string;
32
32
  addGasLink?: string;
33
+ isSendTransaction?: boolean;
33
34
  }): import("react/jsx-runtime").JSX.Element;
34
35
  export {};
@@ -36,7 +36,7 @@ export declare const ANIMATION_TIMINGS: {
36
36
  HIDE_ROUTE: string;
37
37
  GENERIC: string;
38
38
  };
39
- type MediaQuery = "MOBILE_LG" | "MOBILE_SM_HEIGHT" | "MOBILE_XS" | "MOBILE_XS_HEIGHT" | "DESKTOP_MD";
39
+ type MediaQuery = "MOBILE_LG" | "MOBILE_SM_HEIGHT" | "MOBILE_XS" | "MOBILE_XS_HEIGHT";
40
40
  export declare const MEDIA_QUERIES: Record<MediaQuery, {
41
41
  media: string;
42
42
  key: string;
@@ -1,4 +1,4 @@
1
1
  export { MEDIA_QUERIES, CSS_VARS, ANIMATION_DURATIONS } from "./constants";
2
2
  export { darkTheme, lightTheme } from "./themes";
3
3
  export { baseTailwindConfig, spacing } from "./design-system";
4
- export { cn } from "./utils";
4
+ export { cn, pxToRem, remToPx } from "./utils";
@@ -72,4 +72,20 @@ export declare function mapToCssVariables<T extends Record<string, any>>(obj: T)
72
72
  * @returns {number} - The index within the array.
73
73
  */
74
74
  export declare function hashStringToIndex(str: string, max: number): number;
75
+ /**
76
+ * Formats a value for CSS properties by adding 'px' if no unit is present.
77
+ * @param {string | number} value - The value to format (can be a number or string)
78
+ * @returns {string} - The formatted CSS value with appropriate units
79
+ *
80
+ * @example
81
+ * // Returns "20px"
82
+ * formatCSSValue(20)
83
+ *
84
+ * @example
85
+ * // Returns "5rem"
86
+ * formatCSSValue("5rem")
87
+ */
88
+ export declare function formatCSSValue(value: string | number): string;
89
+ export declare const remToPx: (rem: string | number, baseFontSize?: number) => number;
90
+ export declare const pxToRem: (px: string | number, baseFontSize?: number) => number;
75
91
  export {};
@@ -1,7 +1,8 @@
1
+ export * from "./useCollapsibleMenu";
1
2
  export * from "./useDropdownMenu";
2
3
  export * from "./useMediaQuery";
3
- export * from "./useCollapsibleMenu";
4
+ export * from "./useNumericInput";
4
5
  export * from "./useRect";
5
- export * from "./useVersion";
6
6
  export * from "./useTimer";
7
7
  export * from "./useUserTheme";
8
+ export * from "./useVersion";
@@ -0,0 +1,36 @@
1
+ declare type ResizeObserverCallback = (entries: any[], observer: ResizeObserver) => void;
2
+ declare class ResizeObserver {
3
+ constructor(callback: ResizeObserverCallback);
4
+ observe(target: Element, options?: any): void;
5
+ unobserve(target: Element): void;
6
+ disconnect(): void;
7
+ static toString(): string;
8
+ }
9
+ export interface RectReadOnly {
10
+ readonly x: number;
11
+ readonly y: number;
12
+ readonly width: number;
13
+ readonly height: number;
14
+ readonly top: number;
15
+ readonly right: number;
16
+ readonly bottom: number;
17
+ readonly left: number;
18
+ [key: string]: number;
19
+ }
20
+ type HTMLOrSVGElement = HTMLElement | SVGElement;
21
+ type Result = [
22
+ (element: HTMLOrSVGElement | null) => void,
23
+ RectReadOnly,
24
+ () => void
25
+ ];
26
+ export interface Options {
27
+ debounce?: number | {
28
+ scroll: number;
29
+ resize: number;
30
+ };
31
+ scroll?: boolean;
32
+ polyfill?: new (cb: ResizeObserverCallback) => ResizeObserver;
33
+ offsetSize?: boolean;
34
+ }
35
+ declare function useMeasure({ debounce, scroll, polyfill, offsetSize }?: Options): Result;
36
+ export default useMeasure;
@@ -0,0 +1,35 @@
1
+ import { type ChangeEvent } from "react";
2
+ import { type Token } from "../components/controls/NumericInput";
3
+ export declare enum UserInputType {
4
+ TOKEN = 0,
5
+ USD = 1
6
+ }
7
+ interface UseNumericInputOptions {
8
+ token: Pick<Token, "decimals" | "price">;
9
+ onAmountChange: (tokenAmount: string) => void;
10
+ forcedAmount?: string;
11
+ formatIfVerySmall: {
12
+ token: string;
13
+ usd: string;
14
+ };
15
+ balance: string;
16
+ inputModeButton?: {
17
+ amountUsd?: string;
18
+ };
19
+ maxUsdDecimals?: number;
20
+ debounceInput?: boolean;
21
+ direction?: "from" | "to";
22
+ initialInputMode?: UserInputType;
23
+ }
24
+ export declare function useNumericInput({ onAmountChange, token, balance, debounceInput, forcedAmount, formatIfVerySmall, inputModeButton, maxUsdDecimals, direction, initialInputMode, }: UseNumericInputOptions): {
25
+ userInputType: UserInputType;
26
+ inputValue: string;
27
+ handleInputChange: (e: ChangeEvent<HTMLInputElement>) => void;
28
+ handleSwitchInputMode: () => void;
29
+ isTokenAmountVerySmall: boolean;
30
+ isUsdAmountVerySmall: boolean;
31
+ amountFormatted: string;
32
+ onBalanceButtonClick: () => void;
33
+ balanceFormatted: string;
34
+ };
35
+ export {};
@@ -12,8 +12,6 @@ interface RGB {
12
12
  * @param style
13
13
  */
14
14
  export declare const parseSquidTheme: (userTheme: Theme, themeType: ThemeType) => Record<string, string | undefined> | undefined;
15
- export declare const remToPx: (rem: string | number, addSuffix?: boolean) => string;
16
- export declare const pxToRem: (px: string | number, addSuffix?: boolean) => string;
17
15
  export declare function getContrastColor({ r, g, b, }: {
18
16
  r: number;
19
17
  g: number;
@@ -4,7 +4,6 @@ declare const meta: Meta<typeof ImageGroup>;
4
4
  export default meta;
5
5
  type Story = StoryObj<typeof meta>;
6
6
  export declare const Large: Story;
7
- export declare const Medium: Story;
8
7
  export declare const Small: Story;
9
- export declare const LargeWithBadge: Story;
10
- export declare const LargeWithCustomBadgeContent: Story;
8
+ export declare const Badge: Story;
9
+ export declare const CustomBadgeContent: Story;
@@ -44,6 +44,9 @@ export declare const LargeWithLabelLoading: Story;
44
44
  export declare const SmallWithLongLabelLoading: Story;
45
45
  export declare const MediumWithLongLabelLoading: Story;
46
46
  export declare const LargeWithLongLabelLoading: Story;
47
+ export declare const SmallWithLongLabelShimmer: Story;
48
+ export declare const MediumWithLongLabelShimmer: Story;
49
+ export declare const LargeWithLongLabelShimmer: Story;
47
50
  export declare const SmallWithChip: Story;
48
51
  export declare const MediumWithChip: Story;
49
52
  export declare const LargeWithChip: Story;
@@ -1,4 +1,4 @@
1
- import { type Meta, type StoryObj } from "@storybook/react";
1
+ import { Meta, StoryObj } from "@storybook/react";
2
2
  import { IconButton } from "../../components/buttons/IconButton";
3
3
  declare const meta: Meta<typeof IconButton>;
4
4
  export default meta;
@@ -0,0 +1,17 @@
1
+ import { type Meta, type StoryObj } from "@storybook/react";
2
+ import { NumericInput } from "../../components/controls/NumericInput";
3
+ declare const meta: Meta<typeof NumericInput>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof meta>;
6
+ export declare const Default: Story;
7
+ export declare const FiatOnRampStyle: Story;
8
+ export declare const FiatOnRampStyleLoading: Story;
9
+ export declare const CustomSymbol: Story;
10
+ export declare const MinimalVersion: Story;
11
+ export declare const MinimalVersionWithCustomSymbol: Story;
12
+ export declare const MinimalVersionWithBigSymbol: Story;
13
+ export declare const WithError: Story;
14
+ export declare const WithPriceImpact: Story;
15
+ export declare const WithTooltips: Story;
16
+ export declare const Loading: Story;
17
+ export declare const NonInteractive: Story;
@@ -0,0 +1,6 @@
1
+ import { type Meta, type StoryObj } from "@storybook/react";
2
+ import { AnimateNumber } from "../../components/feedback/AnimateNumber";
3
+ declare const meta: Meta<typeof AnimateNumber>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof meta>;
6
+ export declare const Default: Story;
@@ -1,4 +1,4 @@
1
- import { Meta, StoryObj } from "@storybook/react";
1
+ import { type Meta, type StoryObj } from "@storybook/react";
2
2
  import { Loader } from "../../components/icons/Loader";
3
3
  declare const meta: Meta<typeof Loader>;
4
4
  export default meta;
@@ -1,5 +1,5 @@
1
- import { Meta, StoryObj } from "@storybook/react";
2
- import { LoadingSkeleton } from "../../components/badges/LoadingSkeleton";
1
+ import { type Meta, type StoryObj } from "@storybook/react";
2
+ import { LoadingSkeleton } from "../../components/feedback/LoadingSkeleton";
3
3
  declare const meta: Meta<typeof LoadingSkeleton>;
4
4
  export default meta;
5
5
  type Story = StoryObj<typeof meta>;
@@ -0,0 +1,6 @@
1
+ import { type Meta, type StoryObj } from "@storybook/react";
2
+ import { LoadingText } from "../../components/feedback/LoadingText";
3
+ declare const meta: Meta<typeof LoadingText>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof meta>;
6
+ export declare const Default: Story;
@@ -17,3 +17,4 @@ export declare const AllProps: Story;
17
17
  export declare const Loading: Story;
18
18
  export declare const LoadingAndSubtitle: Story;
19
19
  export declare const Transparent: Story;
20
+ export declare const ActionsWithPadding: Story;
@@ -15,7 +15,7 @@ export declare const InputNotInteractiveWithAllProps: Story;
15
15
  export declare const ChainOnly: Story;
16
16
  export declare const ChainAndToken: Story;
17
17
  export declare const WithSwapAmountUsd: Story;
18
- export declare const Address: Story;
18
+ export declare const AddressAndImage: Story;
19
19
  export declare const WithBalance: Story;
20
20
  export declare const LowPriceImpact: Story;
21
21
  export declare const HighPriceImpact: Story;
@@ -23,7 +23,6 @@ export declare const SubtitleLoading: Story;
23
23
  export declare const CustomSubtitleLoading: Story;
24
24
  export declare const ImageAndBadgeLoading: Story;
25
25
  export declare const Small: Story;
26
- export declare const SmallWithImageGroup: Story;
27
26
  export declare const SmallInteractive: Story;
28
27
  export declare const SmallWithLongTitle: Story;
29
28
  export declare const SmallSelected: Story;
@@ -8,7 +8,6 @@ export declare const BalanceUsd: Story;
8
8
  export declare const PositivePriceChange: Story;
9
9
  export declare const NegativePriceChange: Story;
10
10
  export declare const NeutralPriceChange: Story;
11
- export declare const ActionButton: Story;
12
11
  export declare const LargeVariant: Story;
13
12
  export declare const SmallVariant: Story;
14
13
  export declare const CompactVariant: Story;
@@ -15,3 +15,4 @@ export declare const ConfirmationTooLong: Story;
15
15
  export declare const NeedsGas: Story;
16
16
  export declare const PartialSuccess: Story;
17
17
  export declare const Progress: Story;
18
+ export declare const SendTransaction: Story;