@funkit/connect 1.0.19 → 1.0.21

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 (60) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/dist/{chunk-AF763GD5.js → chunk-AKTCSKQA.js} +3 -1
  3. package/dist/{chunk-I4LVVIYS.js → chunk-W67MRJ5R.js} +3 -1
  4. package/dist/components/FunAssetAvatar/FunAssetAvatar.d.ts +3 -2
  5. package/dist/components/FunConnectOptions/FunConnectOptions.d.ts +2 -1
  6. package/dist/components/FunConnectOptions/FunFarcasterConnectingStep.d.ts +8 -0
  7. package/dist/components/FunConnectOptions/FunSignInStep.d.ts +2 -1
  8. package/dist/components/FunPoweredTagline/FunPoweredTagline.d.ts +2 -0
  9. package/dist/components/FunkitProvider/FunkitCheckoutContext.d.ts +2 -0
  10. package/dist/components/FunkitProvider/FunkitConfigContext.d.ts +7 -6
  11. package/dist/components/FunkitProvider/FunkitWeb2Provider.d.ts +27 -3
  12. package/dist/components/Icons/SocialMediaIcons.d.ts +1 -0
  13. package/dist/consts/assets.d.ts +0 -26
  14. package/dist/consts/funkit.d.ts +1 -0
  15. package/dist/consts/quote.d.ts +11 -1
  16. package/dist/farcaster-24TGVAI4.js +6 -0
  17. package/dist/hooks/useFunListeners.d.ts +1 -0
  18. package/dist/index.css +10 -10
  19. package/dist/index.d.ts +1 -1
  20. package/dist/index.js +2021 -1745
  21. package/dist/themes/baseTheme.d.ts +1 -0
  22. package/dist/themes/darkTheme.d.ts +1 -1
  23. package/dist/themes/darkTheme.js +1 -1
  24. package/dist/themes/lightTheme.d.ts +1 -1
  25. package/dist/themes/lightTheme.js +1 -1
  26. package/dist/utils/mobile.d.ts +1 -0
  27. package/dist/wallets/walletConnectors/bifrostWallet/bifrostWallet.js +2 -2
  28. package/dist/wallets/walletConnectors/bitgetWallet/bitgetWallet.js +2 -2
  29. package/dist/wallets/walletConnectors/bybitWallet/bybitWallet.js +2 -2
  30. package/dist/wallets/walletConnectors/chunk-VWZEDVW6.js +27 -0
  31. package/dist/wallets/walletConnectors/chunk-YC7XNS7C.js +98 -0
  32. package/dist/wallets/walletConnectors/clvWallet/clvWallet.js +2 -2
  33. package/dist/wallets/walletConnectors/coin98Wallet/coin98Wallet.js +2 -2
  34. package/dist/wallets/walletConnectors/coinbaseWallet/coinbaseWallet.js +2 -2
  35. package/dist/wallets/walletConnectors/coreWallet/coreWallet.js +2 -2
  36. package/dist/wallets/walletConnectors/dawnWallet/dawnWallet.js +2 -2
  37. package/dist/wallets/walletConnectors/foxWallet/foxWallet.js +2 -2
  38. package/dist/wallets/walletConnectors/frontierWallet/frontierWallet.js +2 -2
  39. package/dist/wallets/walletConnectors/gateWallet/gateWallet.js +2 -2
  40. package/dist/wallets/walletConnectors/index.js +74 -74
  41. package/dist/wallets/walletConnectors/metaMaskWallet/metaMaskWallet.js +2 -2
  42. package/dist/wallets/walletConnectors/okxWallet/okxWallet.js +2 -2
  43. package/dist/wallets/walletConnectors/rainbowWallet/rainbowWallet.js +2 -2
  44. package/dist/wallets/walletConnectors/roninWallet/roninWallet.js +2 -2
  45. package/dist/wallets/walletConnectors/safepalWallet/safepalWallet.js +2 -2
  46. package/dist/wallets/walletConnectors/subWallet/subWallet.js +2 -2
  47. package/dist/wallets/walletConnectors/tokenPocketWallet/tokenPocketWallet.js +2 -2
  48. package/dist/wallets/walletConnectors/trustWallet/trustWallet.js +2 -2
  49. package/dist/wallets/walletConnectors/zerionWallet/zerionWallet.js +2 -2
  50. package/package.json +4 -4
  51. package/dist/wallets/walletConnectors/{chunk-VSZ7PAHS.js → chunk-2PC2XXUH.js} +3 -3
  52. package/dist/wallets/walletConnectors/{chunk-2B3SPBRY.js → chunk-75A2U7T7.js} +3 -3
  53. package/dist/wallets/walletConnectors/{chunk-RCWZ4KBR.js → chunk-FDIIMYTB.js} +4 -4
  54. package/dist/wallets/walletConnectors/{chunk-HD5VYJNC.js → chunk-N3VZE65M.js} +3 -3
  55. package/dist/wallets/walletConnectors/{chunk-CRSPGVPF.js → chunk-OAEJQOAV.js} +3 -3
  56. package/dist/wallets/walletConnectors/{chunk-7KDOXASH.js → chunk-OR3PU2W4.js} +3 -3
  57. package/dist/wallets/walletConnectors/{chunk-KGTZ6E7L.js → chunk-SL4VH23R.js} +3 -3
  58. package/dist/wallets/walletConnectors/{chunk-XNNLZXHE.js → chunk-SQGFKNNZ.js} +3 -3
  59. package/dist/wallets/walletConnectors/{chunk-XRMAVTK7.js → chunk-X255T3C4.js} +4 -4
  60. package/dist/wallets/walletConnectors/{chunk-DV3SI63E.js → chunk-XSSD5ZVD.js} +3 -3
package/CHANGELOG.md CHANGED
@@ -1,5 +1,28 @@
1
1
  # @funkit/connect
2
2
 
3
+ ## 1.0.21
4
+
5
+ ### Patch Changes
6
+
7
+ - abd0295: feat: new optional checkout config disableEditing
8
+ - e3b0b4b: feat: "Powered by Fun.xyz" tag line
9
+ - ab3f917: feat: new customShadows theme configuration
10
+ - abd0295: chore: standardize localStorage keys
11
+ - f4772ec: feat: normalized quote time estimations
12
+ - abd0295: feat: theme toggle persistence
13
+ - f4772ec: feat: support more known token images
14
+ - Updated dependencies [dcd80d5]
15
+ - @funkit/core@1.0.7
16
+ - @funkit/wagmi-tools@1.0.8
17
+
18
+ ## 1.0.20
19
+
20
+ ### Patch Changes
21
+
22
+ - 093f54a: feat: more friendly quote error handling
23
+ - 00a2cac: feat: show social profile pictures (if any)
24
+ - 00a2cac: feat: sign in with farcaster (siwf)
25
+
3
26
  ## 1.0.19
4
27
 
5
28
  ### Patch Changes
@@ -18,6 +18,7 @@ var lightTheme = ({
18
18
  accentColor = defaultAccentColor.accentColor,
19
19
  accentColorForeground = defaultAccentColor.accentColorForeground,
20
20
  customColors,
21
+ customShadows,
21
22
  ...baseThemeOptions
22
23
  } = {}) => ({
23
24
  ...baseTheme(baseThemeOptions),
@@ -86,7 +87,8 @@ var lightTheme = ({
86
87
  profileDetailsAction: "0px 2px 6px rgba(37, 41, 46, 0.04)",
87
88
  selectedOption: "0px 2px 6px rgba(0, 0, 0, 0.24)",
88
89
  selectedWallet: "0px 2px 6px rgba(0, 0, 0, 0.12)",
89
- walletLogo: "0px 2px 16px rgba(0, 0, 0, 0.16)"
90
+ walletLogo: "0px 2px 16px rgba(0, 0, 0, 0.16)",
91
+ ...customShadows || {}
90
92
  },
91
93
  moonpayTheme: "light"
92
94
  });
@@ -18,6 +18,7 @@ var darkTheme = ({
18
18
  accentColor = defaultAccentColor.accentColor,
19
19
  accentColorForeground = defaultAccentColor.accentColorForeground,
20
20
  customColors,
21
+ customShadows,
21
22
  ...baseThemeOptions
22
23
  } = {}) => ({
23
24
  ...baseTheme(baseThemeOptions),
@@ -86,7 +87,8 @@ var darkTheme = ({
86
87
  profileDetailsAction: "0px 2px 6px rgba(37, 41, 46, 0.04)",
87
88
  selectedOption: "0px 2px 6px rgba(0, 0, 0, 0.24)",
88
89
  selectedWallet: "0px 2px 6px rgba(0, 0, 0, 0.24)",
89
- walletLogo: "0px 2px 16px rgba(0, 0, 0, 0.16)"
90
+ walletLogo: "0px 2px 16px rgba(0, 0, 0, 0.16)",
91
+ ...customShadows || {}
90
92
  },
91
93
  moonpayTheme: "dark"
92
94
  });
@@ -5,9 +5,10 @@ interface FunAssetAvatarProps {
5
5
  assetTicker?: string;
6
6
  assetName: string;
7
7
  assetIconSize?: BoxProps['height'] | BoxProps['width'];
8
- chainId: string | number;
8
+ chainId?: string | number;
9
9
  chainIconSize?: BoxProps['height'] | BoxProps['width'];
10
10
  prioritizeDefaults?: boolean;
11
+ hideIfUnknown?: boolean;
11
12
  }
12
- export declare function FunAssetAvatar({ assetSrc, assetTicker, assetName, assetIconSize, chainId, chainIconSize, prioritizeDefaults, }: FunAssetAvatarProps): React.JSX.Element;
13
+ export declare function FunAssetAvatar({ assetSrc, assetTicker, assetName, assetIconSize, chainId, chainIconSize, prioritizeDefaults, hideIfUnknown, }: FunAssetAvatarProps): React.JSX.Element | null;
13
14
  export {};
@@ -3,7 +3,8 @@ export declare enum ConnectStep {
3
3
  SIGNIN = 0,
4
4
  PENDING_EMAIL = 1,
5
5
  PENDING_WALLET = 2,
6
- ERROR = 3
6
+ PENDING_FARCASTER = 3,
7
+ ERROR = 4
7
8
  }
8
9
  export declare function FunConnectOptions({ onClose }: {
9
10
  onClose: () => void;
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import { ConnectStep } from './FunConnectOptions';
3
+ export declare function FunFarcasterConnectingStep({ farcasterUri, farcasterToken, changeStep, onClose, }: {
4
+ farcasterUri: string;
5
+ farcasterToken: string;
6
+ changeStep: (p: ConnectStep) => void;
7
+ onClose: () => void;
8
+ }): React.JSX.Element;
@@ -5,7 +5,7 @@ import { ConnectStep } from './FunConnectOptions';
5
5
  * Modal content for a user that is not signed-in yet
6
6
  * Shows Web2 and Web3 sign in options
7
7
  */
8
- export declare function FunSignInStep({ onClose, changeStep, setSelectedWallet, connectToWallet, setQrCodeUri, emailInput, setEmailInput, }: {
8
+ export declare function FunSignInStep({ onClose, changeStep, setSelectedWallet, connectToWallet, setQrCodeUri, emailInput, setEmailInput, onFarcasterSuccessInit, }: {
9
9
  onClose: () => void;
10
10
  changeStep: (p: ConnectStep) => void;
11
11
  setSelectedWallet: React.Dispatch<React.SetStateAction<WalletConnector | undefined>>;
@@ -13,4 +13,5 @@ export declare function FunSignInStep({ onClose, changeStep, setSelectedWallet,
13
13
  setQrCodeUri: React.Dispatch<React.SetStateAction<string>>;
14
14
  emailInput: string;
15
15
  setEmailInput: React.Dispatch<React.SetStateAction<string>>;
16
+ onFarcasterSuccessInit: (channelToken: string, connectUri: string) => void;
16
17
  }): React.JSX.Element;
@@ -0,0 +1,2 @@
1
+ import React from 'react';
2
+ export declare function FunPoweredTagline(): React.JSX.Element;
@@ -45,6 +45,8 @@ export interface FunkitCheckoutConfig {
45
45
  checkoutItemDescription?: string;
46
46
  /** The quantity of the item being checked out. If not specified (0, null, undefined), it will default to blank. **/
47
47
  checkoutItemAmount?: number;
48
+ /** Whether targetAssetAmount is editable by end users in cases where 1. checkout has empty actionsParams and 2. initial targetAssetAmount <= 0 **/
49
+ disableEditing?: boolean;
48
50
  /** *****************************
49
51
  * Miscellaneous configurations *
50
52
  ********************************/
@@ -1,7 +1,7 @@
1
1
  /// <reference types="react" />
2
2
  import { PaymentMethod } from '../../consts/payment';
3
3
  import { BoxProps } from '../Box/Box';
4
- import { FunkitOauthLoginMethod } from './FunkitWeb2Provider';
4
+ import { FunkitSocialLoginMethod } from './FunkitWeb2Provider';
5
5
  export interface FunkitTextCustomizationsConfig {
6
6
  selectPaymentMethod: string;
7
7
  brokerageOrExchange: string;
@@ -17,11 +17,12 @@ interface FunkitLoginOptionsConfig {
17
17
  web2: boolean;
18
18
  web3: boolean;
19
19
  prioritizeWeb2Logins?: boolean;
20
- /** Enables oAuth logins. Each oauth type requires configuration in your app's privy dashboard. Please ensure to do so before enabling any. **/
21
- web2OauthLogins: {
22
- [FunkitOauthLoginMethod.GOOGLE]?: boolean;
23
- [FunkitOauthLoginMethod.TWITTER]?: boolean;
24
- [FunkitOauthLoginMethod.APPLE]?: boolean;
20
+ /** Enables social logins. Each type requires configuration in your app's privy dashboard. Please ensure to do so before enabling any. **/
21
+ web2SocialLogins: {
22
+ [FunkitSocialLoginMethod.GOOGLE]?: boolean;
23
+ [FunkitSocialLoginMethod.TWITTER]?: boolean;
24
+ [FunkitSocialLoginMethod.APPLE]?: boolean;
25
+ [FunkitSocialLoginMethod.FARCASTER]?: boolean;
25
26
  };
26
27
  }
27
28
  interface FunkitAccountOptionsConfig {
@@ -9,31 +9,55 @@ export declare const ERROR_MESSAGES: {
9
9
  readonly PRIVY_NOT_INITIALIZED: "Privy not initialized";
10
10
  readonly PRIVY_PROVIDER_NOT_INITIALIZED: "Privy wallet provider not initialized";
11
11
  readonly PRIVY_USER_NOT_INITIALIZED: "Privy user not initialized";
12
+ readonly FARCASTER_NOT_INITIALIZED: "Unable to initialize Farcaster login";
12
13
  };
14
+ interface PrivyLoginParams {
15
+ firstLoginCode?: string;
16
+ secondLoginCode?: string;
17
+ alternateCodeMeta?: object | any;
18
+ inputLoginMethod: PrivyLoginMethod;
19
+ }
20
+ interface FunkitWeb2LoginParams extends Omit<PrivyLoginParams, 'inputLoginMethod'> {
21
+ chainId: number;
22
+ inputLoginMethod?: PrivyLoginMethod;
23
+ }
13
24
  interface FunkitWeb2ContextType {
14
25
  isSendingOtpEmail: boolean;
26
+ isGeneratingFcUri: boolean;
15
27
  handleSendOtpEmail: (emailAddress: string) => Promise<{
16
28
  success: boolean;
17
29
  error: string;
18
30
  }>;
19
31
  handleOauthRedirect: (provider: OAuthProviderType) => Promise<void>;
20
- handleFunkitWeb2Login: (chainId: number, firstLoginCode?: string, secondLoginCode?: string, inputLoginMethod?: PrivyLoginMethod) => Promise<boolean>;
32
+ handleFunkitWeb2Login: ({ chainId, firstLoginCode, secondLoginCode, alternateCodeMeta, inputLoginMethod, }: FunkitWeb2LoginParams) => Promise<boolean>;
21
33
  isLoggingIn: boolean;
22
34
  loginErrorMessage: string;
23
35
  clearLoginError: () => void;
24
36
  handleFunkitWeb2Logout: () => Promise<void>;
37
+ handleGenerateFcUri: () => Promise<{
38
+ success: boolean;
39
+ error: string;
40
+ channelToken: string;
41
+ connectUri: string;
42
+ }>;
43
+ getFcConnectionStatus: (channelToken: string) => Promise<{
44
+ isCompleted: boolean;
45
+ fcMeta: any;
46
+ }>;
25
47
  web2AccountInfo: FunkitUserInfo;
26
48
  }
27
49
  export declare enum PrivyLoginMethod {
28
50
  email = "email",
51
+ farcaster = "farcaster",
29
52
  google_oauth = "google_oauth",
30
53
  twitter_oauth = "twitter_oauth",
31
54
  apple_oauth = "apple_oauth"
32
55
  }
33
- export declare enum FunkitOauthLoginMethod {
56
+ export declare enum FunkitSocialLoginMethod {
34
57
  GOOGLE = "google_oauth",
35
58
  TWITTER = "twitter_oauth",
36
- APPLE = "apple_oauth"
59
+ APPLE = "apple_oauth",
60
+ FARCASTER = "farcaster"
37
61
  }
38
62
  interface FunkitWeb2ProviderProps {
39
63
  children: ReactNode;
@@ -2,3 +2,4 @@ import React from 'react';
2
2
  export declare const GoogleIcon: () => React.JSX.Element;
3
3
  export declare const TwitterIcon: () => React.JSX.Element;
4
4
  export declare const AppleIcon: () => React.JSX.Element;
5
+ export declare const FarcasterIcon: () => React.JSX.Element;
@@ -1,29 +1,3 @@
1
- export declare enum CheckoutAsset {
2
- ETH = "eth",
3
- WETH = "weth",
4
- MATIC = "matic",
5
- ARB = "arb",
6
- STETH = "steth",
7
- AAVE = "aave",
8
- WSTETH = "wsteth",
9
- MWETHWPUNKS40 = "mweth-wpunks:40",
10
- TWOXETH = "2x eth",
11
- USDC = "usdc",
12
- DAI = "dai",
13
- APOLWMATIC = "apolwmatic",
14
- AARBUSDCN = "aarbusdcn"
15
- }
16
- interface CheckoutAssetType {
17
- [key: string]: {
18
- ticker: string;
19
- name: string;
20
- icon: string;
21
- iconSVG?: () => any;
22
- decimals: number;
23
- };
24
- }
25
- export declare const CHECKOUT_ASSET: CheckoutAssetType;
26
1
  export declare const ASSET_LOGO_SRCS: {
27
2
  [x: string]: string;
28
3
  };
29
- export {};
@@ -13,6 +13,7 @@ export interface FunkitUserInfo {
13
13
  userId: string | null;
14
14
  accountLabel: string;
15
15
  accountName: string;
16
+ accountPicSrc: string;
16
17
  }
17
18
  export declare const PLACEHOLDER_FUNKIT_USER_INFO: FunkitUserInfo;
18
19
  export declare enum DepositTokenSymbol {
@@ -11,12 +11,22 @@ export declare const PENDING_QUOTE_MESSAGE_GENERATOR: {
11
11
  3: () => string;
12
12
  };
13
13
  export declare enum QuoteCustomErrorType {
14
- INSUFFICIENT_BALANCE = 0
14
+ INSUFFICIENT_BALANCE_PRE_CHECK = 0,
15
+ INSUFFICIENT_TOKEN_BALANCE_PRE_CHECK = 1,
16
+ INSUFFICIENT_BALANCE_POST_CHECK = 2
15
17
  }
16
18
  export declare const QUOTE_CUSTOM_ERROR_STRING_INFO: {
17
19
  0: {
18
20
  check: string;
19
21
  display: string;
20
22
  };
23
+ 1: {
24
+ check: string;
25
+ display: string;
26
+ };
27
+ 2: {
28
+ check: string;
29
+ display: string;
30
+ };
21
31
  };
22
32
  export declare function generateQuoteApiErrorForDisplay(errorMessage?: string): string;
@@ -0,0 +1,6 @@
1
+ "use client";
2
+ // src/components/FunConnectOptions/farcaster.svg
3
+ var farcaster_default = "";
4
+ export {
5
+ farcaster_default as default
6
+ };
@@ -8,3 +8,4 @@ export declare function useCheckoutHistoryListener(activate?: boolean, singleDep
8
8
  * Handles the starting and stopping of asset listeners based on the calling component's mount/unmount status
9
9
  */
10
10
  export declare function useWalletAssetsListener(activate?: boolean): void;
11
+ export declare function useSIWFarcasterListener(channelToken: string): void;
package/dist/index.css CHANGED
@@ -4613,6 +4613,16 @@ input[type=number] {
4613
4613
  color: inputFieldPrimary;
4614
4614
  }
4615
4615
 
4616
+ /* vanilla-extract-css-ns:src/components/FunAssetAvatar/FunAssetAvatar.css.ts.vanilla.css?source=LnV3cmRjMjAgewogIHBvc2l0aW9uOiByZWxhdGl2ZTsKfQoudXdyZGMyMiB7CiAgcG9zaXRpb246IGFic29sdXRlOwogIGJvdHRvbTogMDsKICByaWdodDogMDsKfQ== */
4617
+ [data-rk] .uwrdc20 {
4618
+ position: relative;
4619
+ }
4620
+ [data-rk] .uwrdc22 {
4621
+ position: absolute;
4622
+ bottom: 0;
4623
+ right: 0;
4624
+ }
4625
+
4616
4626
  /* vanilla-extract-css-ns:src/components/FunPayments/FunPaymentMoonpayType.css.ts.vanilla.css?source=Ll8xa21wZXlmMCBpZnJhbWUgewogIGJvcmRlcjogbm9uZTsKfQ== */
4617
4627
  [data-rk] ._1kmpeyf0 iframe {
4618
4628
  border: none;
@@ -4745,16 +4755,6 @@ input[type=number] {
4745
4755
  display: none;
4746
4756
  }
4747
4757
 
4748
- /* vanilla-extract-css-ns:src/components/FunAssetAvatar/FunAssetAvatar.css.ts.vanilla.css?source=LnV3cmRjMjAgewogIHBvc2l0aW9uOiByZWxhdGl2ZTsKfQoudXdyZGMyMiB7CiAgcG9zaXRpb246IGFic29sdXRlOwogIGJvdHRvbTogMDsKICByaWdodDogMDsKfQ== */
4749
- [data-rk] .uwrdc20 {
4750
- position: relative;
4751
- }
4752
- [data-rk] .uwrdc22 {
4753
- position: absolute;
4754
- bottom: 0;
4755
- right: 0;
4756
- }
4757
-
4758
4758
  /* vanilla-extract-css-ns:src/components/MenuButton/MenuButton.css.ts.vanilla.css?source=Ll8xMHB3NXg2MDpob3ZlciB7CiAgYmFja2dyb3VuZDogdW5zZXQ7Cn0= */
4759
4759
  [data-rk] ._10pw5x60:hover {
4760
4760
  background: unset;
package/dist/index.d.ts CHANGED
@@ -3,7 +3,7 @@ export { useFunkitCheckout } from './components/FunkitProvider/FunkitCheckoutCon
3
3
  export type { FunkitConfig } from './components/FunkitProvider/FunkitConfigContext';
4
4
  export { FunkitProvider } from './components/FunkitProvider/FunkitProvider';
5
5
  export { useActiveTheme } from './components/FunkitProvider/FunkitThemeProvider';
6
- export { FunkitOauthLoginMethod } from './components/FunkitProvider/FunkitWeb2Provider';
6
+ export { FunkitSocialLoginMethod } from './components/FunkitProvider/FunkitWeb2Provider';
7
7
  export { WalletButton } from './components/WalletButton/WalletButton';
8
8
  export { getDefaultWallets } from './wallets/getDefaultWallets';
9
9
  export { __private__ } from './__private__';