@dynamic-labs/sdk-react-core 4.10.1 → 4.10.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.
Files changed (86) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/package.cjs +1 -1
  3. package/package.js +1 -1
  4. package/package.json +11 -11
  5. package/src/api.d.ts +1 -0
  6. package/src/lib/components/AuthProviderIcon/AuthProviderIcon.cjs +1 -1
  7. package/src/lib/components/AuthProviderIcon/AuthProviderIcon.js +1 -1
  8. package/src/lib/components/DynamicSpinner/DynamicSpinner.d.ts +3 -0
  9. package/src/lib/components/DynamicSpinner/index.d.ts +1 -0
  10. package/src/lib/components/IconWithSpinner/IconWithSpinner.cjs +2 -5
  11. package/src/lib/components/IconWithSpinner/IconWithSpinner.d.ts +3 -3
  12. package/src/lib/components/IconWithSpinner/IconWithSpinner.js +2 -5
  13. package/src/lib/components/Popper/PopperContext/PopperContext.cjs +2 -2
  14. package/src/lib/components/Popper/PopperContext/PopperContext.d.ts +2 -1
  15. package/src/lib/components/Popper/PopperContext/PopperContext.js +2 -2
  16. package/src/lib/components/QrCodeWrapper/QrCodeWrapper.cjs +7 -7
  17. package/src/lib/components/QrCodeWrapper/QrCodeWrapper.js +7 -7
  18. package/src/lib/components/SocialSignIn/SocialSignIn.cjs +1 -1
  19. package/src/lib/components/SocialSignIn/SocialSignIn.js +1 -1
  20. package/src/lib/components/TransactionStatusLayout/TransactionStatusLayout.cjs +8 -8
  21. package/src/lib/components/TransactionStatusLayout/TransactionStatusLayout.js +8 -8
  22. package/src/lib/components/Typography/Typography.cjs +1 -0
  23. package/src/lib/components/Typography/Typography.js +1 -0
  24. package/src/lib/components/Typography/Typography.types.d.ts +1 -1
  25. package/src/lib/components/index.d.ts +8 -7
  26. package/src/lib/context/DynamicContext/hooks/useTieCallbacksToEvents/useTieCallbacksToEvents.cjs +4 -0
  27. package/src/lib/context/DynamicContext/hooks/useTieCallbacksToEvents/useTieCallbacksToEvents.js +4 -0
  28. package/src/lib/context/SocialRedirectContext/hooks/useRedirectSocialHandler/useRedirectSocialHandler.cjs +1 -1
  29. package/src/lib/context/SocialRedirectContext/hooks/useRedirectSocialHandler/useRedirectSocialHandler.js +1 -1
  30. package/src/lib/data/api/index.d.ts +1 -0
  31. package/src/lib/data/api/transactions/index.d.ts +1 -0
  32. package/src/lib/events/dynamicEvents.cjs +1 -0
  33. package/src/lib/events/dynamicEvents.d.ts +2 -2
  34. package/src/lib/events/dynamicEvents.js +1 -0
  35. package/src/lib/events/ui.d.ts +8 -0
  36. package/src/lib/main.global.cjs +1 -1
  37. package/src/lib/main.global.js +1 -1
  38. package/src/lib/modals/SignMessageConfirmationModal/SignMessageConfirmationModal.cjs +8 -8
  39. package/src/lib/modals/SignMessageConfirmationModal/SignMessageConfirmationModal.js +8 -8
  40. package/src/lib/shared/assets/index.d.ts +2 -1
  41. package/src/lib/shared/types/dynamicEventsCallbacks.d.ts +6 -1
  42. package/src/lib/shared/types/wallets.d.ts +10 -0
  43. package/src/lib/styles/index.shadow.cjs +1 -1
  44. package/src/lib/styles/index.shadow.js +1 -1
  45. package/src/lib/utils/hooks/events/useDynamicEvents/useDynamicEvents.d.ts +1 -1
  46. package/src/lib/utils/hooks/useMfa/useMfa.cjs +1 -1
  47. package/src/lib/utils/hooks/useMfa/useMfa.js +1 -1
  48. package/src/lib/utils/hooks/useRefreshUser/useRefreshUser.cjs +23 -82
  49. package/src/lib/utils/hooks/useRefreshUser/useRefreshUser.js +23 -82
  50. package/src/lib/utils/hooks/useSocialAccounts/useSocialAccounts.cjs +1 -1
  51. package/src/lib/utils/hooks/useSocialAccounts/useSocialAccounts.js +1 -1
  52. package/src/lib/utils/hooks/useSocialAuth/useSocialAuth.cjs +1 -1
  53. package/src/lib/utils/hooks/useSocialAuth/useSocialAuth.js +1 -1
  54. package/src/lib/utils/hooks/useSyncEmbeddedWalletFlow/useSyncEmbeddedWalletFlow.cjs +1 -1
  55. package/src/lib/utils/hooks/useSyncEmbeddedWalletFlow/useSyncEmbeddedWalletFlow.js +1 -1
  56. package/src/lib/utils/hooks/useSyncOnboardingFlow/useSyncOnboardingFlow.cjs +1 -1
  57. package/src/lib/utils/hooks/useSyncOnboardingFlow/useSyncOnboardingFlow.js +1 -1
  58. package/src/lib/utils/hooks/useTelegramLogin/useTelegramLogin.cjs +1 -1
  59. package/src/lib/utils/hooks/useTelegramLogin/useTelegramLogin.js +1 -1
  60. package/src/lib/utils/hooks/useVerifyWallet/useVerifyWallet.cjs +1 -1
  61. package/src/lib/utils/hooks/useVerifyWallet/useVerifyWallet.js +1 -1
  62. package/src/lib/views/LoginView/sections/EmailSignInSection/LoginEmailForm.cjs +1 -1
  63. package/src/lib/views/LoginView/sections/EmailSignInSection/LoginEmailForm.js +1 -1
  64. package/src/lib/views/MfaRecoveryView/MfaRecoveryView.cjs +1 -1
  65. package/src/lib/views/MfaRecoveryView/MfaRecoveryView.js +1 -1
  66. package/src/lib/views/Passkey/PasskeyRecovery/AddRecoveryEmail/AddRecoveryEmail.cjs +1 -1
  67. package/src/lib/views/Passkey/PasskeyRecovery/AddRecoveryEmail/AddRecoveryEmail.js +1 -1
  68. package/src/lib/views/SmsVerification/useSmsVerification/useSmsVerification.cjs +1 -1
  69. package/src/lib/views/SmsVerification/useSmsVerification/useSmsVerification.js +1 -1
  70. package/src/lib/views/TransactionConfirmationView/TransactionConfirmationView.cjs +1 -1
  71. package/src/lib/views/TransactionConfirmationView/TransactionConfirmationView.js +1 -1
  72. package/src/lib/views/WalletList/hooks/useTabState.cjs +29 -4
  73. package/src/lib/views/WalletList/hooks/useTabState.d.ts +2 -2
  74. package/src/lib/views/WalletList/hooks/useTabState.js +30 -5
  75. package/src/lib/views/WalletSignSpinnerView/WalletSignSpinnerView.cjs +1 -1
  76. package/src/lib/views/WalletSignSpinnerView/WalletSignSpinnerView.js +1 -1
  77. package/src/lib/widgets/DynamicBridgeWidget/components/DynamicBridgeUserProfile/DynamicBridgeUserProfile.cjs +1 -1
  78. package/src/lib/widgets/DynamicBridgeWidget/components/DynamicBridgeUserProfile/DynamicBridgeUserProfile.js +1 -1
  79. package/src/lib/widgets/DynamicWidget/components/Wallet/Wallet.cjs +1 -1
  80. package/src/lib/widgets/DynamicWidget/components/Wallet/Wallet.js +1 -1
  81. package/src/lib/widgets/DynamicWidget/views/AccountAndSecuritySettingsView/AccountAndSecuritySettingsView.cjs +1 -1
  82. package/src/lib/widgets/DynamicWidget/views/AccountAndSecuritySettingsView/AccountAndSecuritySettingsView.js +1 -1
  83. package/src/lib/widgets/DynamicWidget/views/GlobalWalletView/GlobalWalletView.cjs +1 -1
  84. package/src/lib/widgets/DynamicWidget/views/GlobalWalletView/GlobalWalletView.js +1 -1
  85. package/src/lib/widgets/DynamicWidget/views/SettingsView/SettingsView.cjs +2 -2
  86. package/src/lib/widgets/DynamicWidget/views/SettingsView/SettingsView.js +2 -2
@@ -4,5 +4,5 @@ type DynamicEventListener<E extends keyof DynamicEvents> = (...args: EventArgs<D
4
4
  /** Allows us to subscribe to all dynamicEvents with a hook, even the internal ones */
5
5
  export declare const useInternalDynamicEvents: <E extends keyof import("../../../../events/auth").AuthEvents | keyof import("../../../../events/ui").UIEvents | keyof import("../../../../events/otp").OTPEvents | keyof import("../../../../events/wallets").WalletEvents | keyof import("../../../../events/passkey").PasskeyEvents | "farcasterConnectCancelled" | keyof import("../../../../events/embeddedWallet").EmbeddedWalletEvents | keyof import("../../../../events/multiWallet").MultiWalletInternalEvents | "tokenBalancesChanged" | "userProfileUpdated" | "walletConnectedForFunding">(event: E, listener: DynamicEventListener<E>) => void;
6
6
  /** Allows subscribing to dynamic events directly inside components with a hook */
7
- export declare const useDynamicEvents: <E extends "authFailure" | "authInit" | "logout" | "mfaCompletionSuccess" | "mfaCompletionFailure" | "authFlowOpen" | "authFlowClose" | "authFlowCancelled" | "emailVerificationResult" | "smsVerificationResult" | "walletAdded" | "walletRemoved" | "primaryWalletChanged" | "primaryWalletNetworkChanged" | "userWalletsChanged" | "embeddedWalletCreated" | "walletConnectedForFunding">(event: E, listener: DynamicEventListener<E>) => void;
7
+ export declare const useDynamicEvents: <E extends "authFailure" | "authInit" | "logout" | "mfaCompletionSuccess" | "mfaCompletionFailure" | "authFlowOpen" | "authFlowClose" | "authFlowCancelled" | "walletTabSelected" | "emailVerificationResult" | "smsVerificationResult" | "walletAdded" | "walletRemoved" | "primaryWalletChanged" | "primaryWalletNetworkChanged" | "userWalletsChanged" | "embeddedWalletCreated" | "walletConnectedForFunding">(event: E, listener: DynamicEventListener<E>) => void;
8
8
  export {};
@@ -55,6 +55,7 @@ require('../../../store/state/walletOptions/walletOptions.cjs');
55
55
  require('react-i18next');
56
56
  require('../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
57
57
  require('../../../components/Alert/Alert.cjs');
58
+ require('../../../context/WalletContext/WalletContext.cjs');
58
59
  require('../../../components/ShadowDOM/ShadowDOM.cjs');
59
60
  require('../../../components/IconButton/IconButton.cjs');
60
61
  require('../../../components/InlineWidget/InlineWidget.cjs');
@@ -70,7 +71,6 @@ require('../../../components/Popper/Popper/Popper.cjs');
70
71
  require('../../../components/Popper/PopperContext/PopperContext.cjs');
71
72
  require('react-focus-lock');
72
73
  require('qrcode');
73
- require('../../../context/WalletContext/WalletContext.cjs');
74
74
  require('formik');
75
75
  require('../../../context/FieldsStateContext/FieldsStateContext.cjs');
76
76
  require('../useSubdomainCheck/useSubdomainCheck.cjs');
@@ -51,6 +51,7 @@ import '../../../store/state/walletOptions/walletOptions.js';
51
51
  import 'react-i18next';
52
52
  import '../../../components/Accordion/components/AccordionItem/AccordionItem.js';
53
53
  import '../../../components/Alert/Alert.js';
54
+ import '../../../context/WalletContext/WalletContext.js';
54
55
  import '../../../components/ShadowDOM/ShadowDOM.js';
55
56
  import '../../../components/IconButton/IconButton.js';
56
57
  import '../../../components/InlineWidget/InlineWidget.js';
@@ -66,7 +67,6 @@ import '../../../components/Popper/Popper/Popper.js';
66
67
  import '../../../components/Popper/PopperContext/PopperContext.js';
67
68
  import 'react-focus-lock';
68
69
  import 'qrcode';
69
- import '../../../context/WalletContext/WalletContext.js';
70
70
  import 'formik';
71
71
  import '../../../context/FieldsStateContext/FieldsStateContext.js';
72
72
  import '../useSubdomainCheck/useSubdomainCheck.js';
@@ -3,106 +3,47 @@
3
3
 
4
4
  Object.defineProperty(exports, '__esModule', { value: true });
5
5
 
6
+ var _tslib = require('../../../../../_virtual/_tslib.cjs');
6
7
  var React = require('react');
7
- require('../../../context/DynamicContext/DynamicContext.cjs');
8
+ require('@dynamic-labs/utils');
8
9
  require('@dynamic-labs/sdk-api-core');
10
+ require('../../../config/ApiEndpoint.cjs');
11
+ require('../../constants/values.cjs');
12
+ require('@dynamic-labs/multi-wallet');
9
13
  require('../../../shared/logger.cjs');
14
+ require('../../constants/colors.cjs');
15
+ require('react-international-phone');
10
16
  require('@dynamic-labs/iconic');
11
17
  require('@dynamic-labs/wallet-connector-core');
12
18
  require('react/jsx-runtime');
13
19
  require('../../../context/ViewContext/ViewContext.cjs');
14
20
  require('@dynamic-labs/wallet-book');
15
- require('@dynamic-labs/utils');
16
- require('../../constants/colors.cjs');
17
- require('../../constants/values.cjs');
18
21
  require('../../../shared/consts/index.cjs');
19
- require('../../../events/dynamicEvents.cjs');
20
- require('../../../../../_virtual/_tslib.cjs');
21
- require('../../../context/CaptchaContext/CaptchaContext.cjs');
22
- require('../../../context/ErrorContext/ErrorContext.cjs');
23
- require('@dynamic-labs/multi-wallet');
24
- require('react-international-phone');
25
22
  require('../../../store/state/nonce/nonce.cjs');
26
23
  require('../../../store/state/projectSettings/projectSettings.cjs');
27
- require('../../../config/ApiEndpoint.cjs');
24
+ var dynamicContextProps = require('../../../store/state/dynamicContextProps/dynamicContextProps.cjs');
25
+ var primaryWalletId = require('../../../store/state/primaryWalletId/primaryWalletId.cjs');
28
26
  require('../../../store/state/user/user.cjs');
29
27
  require('../../../locale/locale.cjs');
30
28
  var user = require('../../../data/api/user/user.cjs');
31
- require('../../../store/state/dynamicContextProps/dynamicContextProps.cjs');
32
- require('../../../store/state/primaryWalletId/primaryWalletId.cjs');
33
- require('../../../context/AccessDeniedContext/AccessDeniedContext.cjs');
34
- require('../../../context/AccountExistsContext/AccountExistsContext.cjs');
35
- require('../../../context/UserWalletsContext/UserWalletsContext.cjs');
36
- require('../../../store/state/connectedWalletsInfo/connectedWalletsInfo.cjs');
37
- require('../../../context/VerificationContext/VerificationContext.cjs');
38
- require('react-dom');
39
- require('../../functions/compareChains/compareChains.cjs');
40
- require('../../../context/ThemeContext/ThemeContext.cjs');
41
- require('../useUserUpdateRequest/useUpdateUser/userFieldsSchema.cjs');
42
- require('bs58');
43
- require('@dynamic-labs/types');
44
- require('../../../context/SocialRedirectContext/SocialRedirectContext.cjs');
45
- require('../../../context/LoadingContext/LoadingContext.cjs');
46
- require('../../../context/WalletContext/WalletContext.cjs');
47
- require('../useEmbeddedWallet/useSecureEnclaveEmbeddedWallet/constants.cjs');
48
- require('yup');
49
- require('../../../context/MockContext/MockContext.cjs');
50
- require('../../../views/CollectUserDataView/useFields.cjs');
51
- require('../../../context/FieldsStateContext/FieldsStateContext.cjs');
52
- require('../../../context/UserFieldEditorContext/UserFieldEditorContext.cjs');
53
- require('@dynamic-labs/rpc-providers');
54
- require('../../../store/state/loadingAndLifecycle.cjs');
55
- require('../../../store/state/walletOptions/walletOptions.cjs');
56
- require('react-i18next');
57
- require('../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
58
- require('../../../components/Alert/Alert.cjs');
59
- require('../../../components/ShadowDOM/ShadowDOM.cjs');
60
- require('../../../components/IconButton/IconButton.cjs');
61
- require('../../../components/InlineWidget/InlineWidget.cjs');
62
- require('../../../components/Input/Input.cjs');
63
- require('../../../components/IsBrowser/IsBrowser.cjs');
64
- require('../../../components/MenuList/Dropdown/Dropdown.cjs');
65
- require('../../../components/OverlayCard/OverlayCard.cjs');
66
- require('../../../components/Transition/ZoomTransition/ZoomTransition.cjs');
67
- require('../../../components/Transition/SlideInUpTransition/SlideInUpTransition.cjs');
68
- require('../../../components/Transition/OpacityTransition/OpacityTransition.cjs');
69
- require('../../../components/PasskeyCreatedSuccessBanner/PasskeyCreatedSuccessBanner.cjs');
70
- require('../../../components/Popper/Popper/Popper.cjs');
71
- require('../../../components/Popper/PopperContext/PopperContext.cjs');
72
- require('react-focus-lock');
73
- require('qrcode');
74
- require('formik');
75
- require('../useSubdomainCheck/useSubdomainCheck.cjs');
76
- require('../../../context/WalletGroupContext/WalletGroupContext.cjs');
77
- require('../../../context/IpConfigurationContext/IpConfigurationContext.cjs');
78
- require('../../../context/ConnectWithOtpContext/ConnectWithOtpContext.cjs');
79
- require('../../../context/ConnectWithOtpContext/constants.cjs');
80
- require('../../../widgets/DynamicBridgeWidget/views/WalletsView/components/SecondaryWallets/SecondaryWallets.cjs');
81
- require('@hcaptcha/react-hcaptcha');
82
- require('../../../widgets/DynamicWidget/context/DynamicWidgetContext.cjs');
83
- require('../../../context/FooterAnimationContext/index.cjs');
84
- require('../../../context/ErrorContext/hooks/useErrorText/useErrorText.cjs');
85
- require('../../../context/PasskeyContext/PasskeyContext.cjs');
86
- require('../../../store/state/sendBalances.cjs');
87
- require('../../../store/state/connectorsInitializing/connectorsInitializing.cjs');
88
- require('../../../components/OverlayCardBase/OverlayCardTarget/OverlayCardTarget.cjs');
89
- require('../../../widgets/DynamicWidget/components/DynamicWidgetHeader/DynamicWidgetHeader.cjs');
90
- require('../../../views/TransactionConfirmationView/TransactionConfirmationView.cjs');
91
- require('../../../widgets/DynamicWidget/views/ManagePasskeysWidgetView/PasskeyCard/PasskeyCard.cjs');
92
- require('../../../context/OnrampContext/OnrampContext.cjs');
93
- require('../../../widgets/DynamicWidget/views/ReceiveWalletFunds/ReceiveWalletFunds.cjs');
94
- require('../../../../index.cjs');
95
- require('../../../store/state/tokenBalances.cjs');
96
- require('../../../shared/utils/functions/getInitialUrl/getInitialUrl.cjs');
97
- var useInternalDynamicContext = require('../../../context/DynamicContext/useDynamicContext/useInternalDynamicContext.cjs');
98
29
 
99
30
  /**
100
31
  * Refresh user state
101
32
  * @returns A callback function that can be used to refresh the user state
102
33
  */
103
- const useRefreshUser = () => {
104
- const { environmentId } = useInternalDynamicContext.useInternalDynamicContext();
105
- return React.useCallback(() => user.refreshUserJwt({ environmentId }), [environmentId]);
106
- };
34
+ const useRefreshUser = () => React.useCallback(() => _tslib.__awaiter(void 0, void 0, void 0, function* () {
35
+ var _a;
36
+ const user$1 = yield user.refreshUserJwt({ environmentId: dynamicContextProps.getEnvironmentId() });
37
+ if (!(user$1 === null || user$1 === void 0 ? void 0 : user$1.verifiedCredentials))
38
+ throw new Error('useRefreshUser resulted in an invalid user: no verified credentials found');
39
+ // Check if the primary wallet is still in this user's VCs
40
+ const primaryWalletInUserVCs = user$1.verifiedCredentials.some(({ id }) => id === primaryWalletId.getPrimaryWalletId());
41
+ if (primaryWalletInUserVCs)
42
+ return user$1;
43
+ // We need to switch primary wallet to the first wallet in the user's VCs
44
+ const newPrimaryWalletId = (_a = user$1.verifiedCredentials.find(({ format }) => format === 'blockchain')) === null || _a === void 0 ? void 0 : _a.id;
45
+ primaryWalletId.setPrimaryWalletId(newPrimaryWalletId);
46
+ return user$1;
47
+ }), []);
107
48
 
108
49
  exports.useRefreshUser = useRefreshUser;
@@ -1,104 +1,45 @@
1
1
  'use client'
2
+ import { __awaiter } from '../../../../../_virtual/_tslib.js';
2
3
  import { useCallback } from 'react';
3
- import '../../../context/DynamicContext/DynamicContext.js';
4
+ import '@dynamic-labs/utils';
4
5
  import '@dynamic-labs/sdk-api-core';
6
+ import '../../../config/ApiEndpoint.js';
7
+ import '../../constants/values.js';
8
+ import '@dynamic-labs/multi-wallet';
5
9
  import '../../../shared/logger.js';
10
+ import '../../constants/colors.js';
11
+ import 'react-international-phone';
6
12
  import '@dynamic-labs/iconic';
7
13
  import '@dynamic-labs/wallet-connector-core';
8
14
  import 'react/jsx-runtime';
9
15
  import '../../../context/ViewContext/ViewContext.js';
10
16
  import '@dynamic-labs/wallet-book';
11
- import '@dynamic-labs/utils';
12
- import '../../constants/colors.js';
13
- import '../../constants/values.js';
14
17
  import '../../../shared/consts/index.js';
15
- import '../../../events/dynamicEvents.js';
16
- import '../../../../../_virtual/_tslib.js';
17
- import '../../../context/CaptchaContext/CaptchaContext.js';
18
- import '../../../context/ErrorContext/ErrorContext.js';
19
- import '@dynamic-labs/multi-wallet';
20
- import 'react-international-phone';
21
18
  import '../../../store/state/nonce/nonce.js';
22
19
  import '../../../store/state/projectSettings/projectSettings.js';
23
- import '../../../config/ApiEndpoint.js';
20
+ import { getEnvironmentId } from '../../../store/state/dynamicContextProps/dynamicContextProps.js';
21
+ import { getPrimaryWalletId, setPrimaryWalletId } from '../../../store/state/primaryWalletId/primaryWalletId.js';
24
22
  import '../../../store/state/user/user.js';
25
23
  import '../../../locale/locale.js';
26
24
  import { refreshUserJwt } from '../../../data/api/user/user.js';
27
- import '../../../store/state/dynamicContextProps/dynamicContextProps.js';
28
- import '../../../store/state/primaryWalletId/primaryWalletId.js';
29
- import '../../../context/AccessDeniedContext/AccessDeniedContext.js';
30
- import '../../../context/AccountExistsContext/AccountExistsContext.js';
31
- import '../../../context/UserWalletsContext/UserWalletsContext.js';
32
- import '../../../store/state/connectedWalletsInfo/connectedWalletsInfo.js';
33
- import '../../../context/VerificationContext/VerificationContext.js';
34
- import 'react-dom';
35
- import '../../functions/compareChains/compareChains.js';
36
- import '../../../context/ThemeContext/ThemeContext.js';
37
- import '../useUserUpdateRequest/useUpdateUser/userFieldsSchema.js';
38
- import 'bs58';
39
- import '@dynamic-labs/types';
40
- import '../../../context/SocialRedirectContext/SocialRedirectContext.js';
41
- import '../../../context/LoadingContext/LoadingContext.js';
42
- import '../../../context/WalletContext/WalletContext.js';
43
- import '../useEmbeddedWallet/useSecureEnclaveEmbeddedWallet/constants.js';
44
- import 'yup';
45
- import '../../../context/MockContext/MockContext.js';
46
- import '../../../views/CollectUserDataView/useFields.js';
47
- import '../../../context/FieldsStateContext/FieldsStateContext.js';
48
- import '../../../context/UserFieldEditorContext/UserFieldEditorContext.js';
49
- import '@dynamic-labs/rpc-providers';
50
- import '../../../store/state/loadingAndLifecycle.js';
51
- import '../../../store/state/walletOptions/walletOptions.js';
52
- import 'react-i18next';
53
- import '../../../components/Accordion/components/AccordionItem/AccordionItem.js';
54
- import '../../../components/Alert/Alert.js';
55
- import '../../../components/ShadowDOM/ShadowDOM.js';
56
- import '../../../components/IconButton/IconButton.js';
57
- import '../../../components/InlineWidget/InlineWidget.js';
58
- import '../../../components/Input/Input.js';
59
- import '../../../components/IsBrowser/IsBrowser.js';
60
- import '../../../components/MenuList/Dropdown/Dropdown.js';
61
- import '../../../components/OverlayCard/OverlayCard.js';
62
- import '../../../components/Transition/ZoomTransition/ZoomTransition.js';
63
- import '../../../components/Transition/SlideInUpTransition/SlideInUpTransition.js';
64
- import '../../../components/Transition/OpacityTransition/OpacityTransition.js';
65
- import '../../../components/PasskeyCreatedSuccessBanner/PasskeyCreatedSuccessBanner.js';
66
- import '../../../components/Popper/Popper/Popper.js';
67
- import '../../../components/Popper/PopperContext/PopperContext.js';
68
- import 'react-focus-lock';
69
- import 'qrcode';
70
- import 'formik';
71
- import '../useSubdomainCheck/useSubdomainCheck.js';
72
- import '../../../context/WalletGroupContext/WalletGroupContext.js';
73
- import '../../../context/IpConfigurationContext/IpConfigurationContext.js';
74
- import '../../../context/ConnectWithOtpContext/ConnectWithOtpContext.js';
75
- import '../../../context/ConnectWithOtpContext/constants.js';
76
- import '../../../widgets/DynamicBridgeWidget/views/WalletsView/components/SecondaryWallets/SecondaryWallets.js';
77
- import '@hcaptcha/react-hcaptcha';
78
- import '../../../widgets/DynamicWidget/context/DynamicWidgetContext.js';
79
- import '../../../context/FooterAnimationContext/index.js';
80
- import '../../../context/ErrorContext/hooks/useErrorText/useErrorText.js';
81
- import '../../../context/PasskeyContext/PasskeyContext.js';
82
- import '../../../store/state/sendBalances.js';
83
- import '../../../store/state/connectorsInitializing/connectorsInitializing.js';
84
- import '../../../components/OverlayCardBase/OverlayCardTarget/OverlayCardTarget.js';
85
- import '../../../widgets/DynamicWidget/components/DynamicWidgetHeader/DynamicWidgetHeader.js';
86
- import '../../../views/TransactionConfirmationView/TransactionConfirmationView.js';
87
- import '../../../widgets/DynamicWidget/views/ManagePasskeysWidgetView/PasskeyCard/PasskeyCard.js';
88
- import '../../../context/OnrampContext/OnrampContext.js';
89
- import '../../../widgets/DynamicWidget/views/ReceiveWalletFunds/ReceiveWalletFunds.js';
90
- import '../../../../index.js';
91
- import '../../../store/state/tokenBalances.js';
92
- import '../../../shared/utils/functions/getInitialUrl/getInitialUrl.js';
93
- import { useInternalDynamicContext } from '../../../context/DynamicContext/useDynamicContext/useInternalDynamicContext.js';
94
25
 
95
26
  /**
96
27
  * Refresh user state
97
28
  * @returns A callback function that can be used to refresh the user state
98
29
  */
99
- const useRefreshUser = () => {
100
- const { environmentId } = useInternalDynamicContext();
101
- return useCallback(() => refreshUserJwt({ environmentId }), [environmentId]);
102
- };
30
+ const useRefreshUser = () => useCallback(() => __awaiter(void 0, void 0, void 0, function* () {
31
+ var _a;
32
+ const user = yield refreshUserJwt({ environmentId: getEnvironmentId() });
33
+ if (!(user === null || user === void 0 ? void 0 : user.verifiedCredentials))
34
+ throw new Error('useRefreshUser resulted in an invalid user: no verified credentials found');
35
+ // Check if the primary wallet is still in this user's VCs
36
+ const primaryWalletInUserVCs = user.verifiedCredentials.some(({ id }) => id === getPrimaryWalletId());
37
+ if (primaryWalletInUserVCs)
38
+ return user;
39
+ // We need to switch primary wallet to the first wallet in the user's VCs
40
+ const newPrimaryWalletId = (_a = user.verifiedCredentials.find(({ format }) => format === 'blockchain')) === null || _a === void 0 ? void 0 : _a.id;
41
+ setPrimaryWalletId(newPrimaryWalletId);
42
+ return user;
43
+ }), []);
103
44
 
104
45
  export { useRefreshUser };
@@ -57,6 +57,7 @@ require('../../../store/state/walletOptions/walletOptions.cjs');
57
57
  require('react-i18next');
58
58
  require('../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
59
59
  require('../../../components/Alert/Alert.cjs');
60
+ require('../../../context/WalletContext/WalletContext.cjs');
60
61
  require('../../../components/ShadowDOM/ShadowDOM.cjs');
61
62
  require('../../../components/IconButton/IconButton.cjs');
62
63
  require('../../../components/InlineWidget/InlineWidget.cjs');
@@ -72,7 +73,6 @@ require('../../../components/Popper/Popper/Popper.cjs');
72
73
  require('../../../components/Popper/PopperContext/PopperContext.cjs');
73
74
  require('react-focus-lock');
74
75
  require('qrcode');
75
- require('../../../context/WalletContext/WalletContext.cjs');
76
76
  require('formik');
77
77
  require('../useSubdomainCheck/useSubdomainCheck.cjs');
78
78
  require('../../../context/WalletGroupContext/WalletGroupContext.cjs');
@@ -53,6 +53,7 @@ import '../../../store/state/walletOptions/walletOptions.js';
53
53
  import 'react-i18next';
54
54
  import '../../../components/Accordion/components/AccordionItem/AccordionItem.js';
55
55
  import '../../../components/Alert/Alert.js';
56
+ import '../../../context/WalletContext/WalletContext.js';
56
57
  import '../../../components/ShadowDOM/ShadowDOM.js';
57
58
  import '../../../components/IconButton/IconButton.js';
58
59
  import '../../../components/InlineWidget/InlineWidget.js';
@@ -68,7 +69,6 @@ import '../../../components/Popper/Popper/Popper.js';
68
69
  import '../../../components/Popper/PopperContext/PopperContext.js';
69
70
  import 'react-focus-lock';
70
71
  import 'qrcode';
71
- import '../../../context/WalletContext/WalletContext.js';
72
72
  import 'formik';
73
73
  import '../useSubdomainCheck/useSubdomainCheck.js';
74
74
  import '../../../context/WalletGroupContext/WalletGroupContext.js';
@@ -62,6 +62,7 @@ require('../../../store/state/walletOptions/walletOptions.cjs');
62
62
  require('react-i18next');
63
63
  require('../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
64
64
  require('../../../components/Alert/Alert.cjs');
65
+ require('../../../context/WalletContext/WalletContext.cjs');
65
66
  require('../../../components/ShadowDOM/ShadowDOM.cjs');
66
67
  require('../../../components/IconButton/IconButton.cjs');
67
68
  require('../../../components/InlineWidget/InlineWidget.cjs');
@@ -77,7 +78,6 @@ require('../../../components/Popper/Popper/Popper.cjs');
77
78
  require('../../../components/Popper/PopperContext/PopperContext.cjs');
78
79
  require('react-focus-lock');
79
80
  require('qrcode');
80
- require('../../../context/WalletContext/WalletContext.cjs');
81
81
  require('formik');
82
82
  require('../useSubdomainCheck/useSubdomainCheck.cjs');
83
83
  require('../../../context/WalletGroupContext/WalletGroupContext.cjs');
@@ -58,6 +58,7 @@ import '../../../store/state/walletOptions/walletOptions.js';
58
58
  import 'react-i18next';
59
59
  import '../../../components/Accordion/components/AccordionItem/AccordionItem.js';
60
60
  import '../../../components/Alert/Alert.js';
61
+ import '../../../context/WalletContext/WalletContext.js';
61
62
  import '../../../components/ShadowDOM/ShadowDOM.js';
62
63
  import '../../../components/IconButton/IconButton.js';
63
64
  import '../../../components/InlineWidget/InlineWidget.js';
@@ -73,7 +74,6 @@ import '../../../components/Popper/Popper/Popper.js';
73
74
  import '../../../components/Popper/PopperContext/PopperContext.js';
74
75
  import 'react-focus-lock';
75
76
  import 'qrcode';
76
- import '../../../context/WalletContext/WalletContext.js';
77
77
  import 'formik';
78
78
  import '../useSubdomainCheck/useSubdomainCheck.js';
79
79
  import '../../../context/WalletGroupContext/WalletGroupContext.js';
@@ -57,6 +57,7 @@ require('../../../store/state/walletOptions/walletOptions.cjs');
57
57
  require('react-i18next');
58
58
  require('../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
59
59
  require('../../../components/Alert/Alert.cjs');
60
+ var WalletContext = require('../../../context/WalletContext/WalletContext.cjs');
60
61
  require('../../../components/ShadowDOM/ShadowDOM.cjs');
61
62
  require('../../../components/IconButton/IconButton.cjs');
62
63
  require('../../../components/InlineWidget/InlineWidget.cjs');
@@ -72,7 +73,6 @@ require('../../../components/Popper/Popper/Popper.cjs');
72
73
  require('../../../components/Popper/PopperContext/PopperContext.cjs');
73
74
  require('react-focus-lock');
74
75
  require('qrcode');
75
- var WalletContext = require('../../../context/WalletContext/WalletContext.cjs');
76
76
  require('formik');
77
77
  require('../useSubdomainCheck/useSubdomainCheck.cjs');
78
78
  require('../../../context/WalletGroupContext/WalletGroupContext.cjs');
@@ -53,6 +53,7 @@ import '../../../store/state/walletOptions/walletOptions.js';
53
53
  import 'react-i18next';
54
54
  import '../../../components/Accordion/components/AccordionItem/AccordionItem.js';
55
55
  import '../../../components/Alert/Alert.js';
56
+ import { useWalletContext } from '../../../context/WalletContext/WalletContext.js';
56
57
  import '../../../components/ShadowDOM/ShadowDOM.js';
57
58
  import '../../../components/IconButton/IconButton.js';
58
59
  import '../../../components/InlineWidget/InlineWidget.js';
@@ -68,7 +69,6 @@ import '../../../components/Popper/Popper/Popper.js';
68
69
  import '../../../components/Popper/PopperContext/PopperContext.js';
69
70
  import 'react-focus-lock';
70
71
  import 'qrcode';
71
- import { useWalletContext } from '../../../context/WalletContext/WalletContext.js';
72
72
  import 'formik';
73
73
  import '../useSubdomainCheck/useSubdomainCheck.js';
74
74
  import '../../../context/WalletGroupContext/WalletGroupContext.js';
@@ -56,6 +56,7 @@ require('../../../store/state/walletOptions/walletOptions.cjs');
56
56
  require('react-i18next');
57
57
  require('../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
58
58
  require('../../../components/Alert/Alert.cjs');
59
+ require('../../../context/WalletContext/WalletContext.cjs');
59
60
  require('../../../components/ShadowDOM/ShadowDOM.cjs');
60
61
  require('../../../components/IconButton/IconButton.cjs');
61
62
  require('../../../components/InlineWidget/InlineWidget.cjs');
@@ -71,7 +72,6 @@ require('../../../components/Popper/Popper/Popper.cjs');
71
72
  require('../../../components/Popper/PopperContext/PopperContext.cjs');
72
73
  require('react-focus-lock');
73
74
  require('qrcode');
74
- require('../../../context/WalletContext/WalletContext.cjs');
75
75
  require('formik');
76
76
  require('../useSubdomainCheck/useSubdomainCheck.cjs');
77
77
  require('../../../context/WalletGroupContext/WalletGroupContext.cjs');
@@ -52,6 +52,7 @@ import '../../../store/state/walletOptions/walletOptions.js';
52
52
  import 'react-i18next';
53
53
  import '../../../components/Accordion/components/AccordionItem/AccordionItem.js';
54
54
  import '../../../components/Alert/Alert.js';
55
+ import '../../../context/WalletContext/WalletContext.js';
55
56
  import '../../../components/ShadowDOM/ShadowDOM.js';
56
57
  import '../../../components/IconButton/IconButton.js';
57
58
  import '../../../components/InlineWidget/InlineWidget.js';
@@ -67,7 +68,6 @@ import '../../../components/Popper/Popper/Popper.js';
67
68
  import '../../../components/Popper/PopperContext/PopperContext.js';
68
69
  import 'react-focus-lock';
69
70
  import 'qrcode';
70
- import '../../../context/WalletContext/WalletContext.js';
71
71
  import 'formik';
72
72
  import '../useSubdomainCheck/useSubdomainCheck.js';
73
73
  import '../../../context/WalletGroupContext/WalletGroupContext.js';
@@ -55,6 +55,7 @@ require('../../../store/state/walletOptions/walletOptions.cjs');
55
55
  require('react-i18next');
56
56
  require('../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
57
57
  require('../../../components/Alert/Alert.cjs');
58
+ require('../../../context/WalletContext/WalletContext.cjs');
58
59
  require('../../../components/ShadowDOM/ShadowDOM.cjs');
59
60
  require('../../../components/IconButton/IconButton.cjs');
60
61
  require('../../../components/InlineWidget/InlineWidget.cjs');
@@ -70,7 +71,6 @@ require('../../../components/Popper/Popper/Popper.cjs');
70
71
  require('../../../components/Popper/PopperContext/PopperContext.cjs');
71
72
  require('react-focus-lock');
72
73
  require('qrcode');
73
- require('../../../context/WalletContext/WalletContext.cjs');
74
74
  require('formik');
75
75
  require('../useSubdomainCheck/useSubdomainCheck.cjs');
76
76
  require('../../../context/WalletGroupContext/WalletGroupContext.cjs');
@@ -51,6 +51,7 @@ import '../../../store/state/walletOptions/walletOptions.js';
51
51
  import 'react-i18next';
52
52
  import '../../../components/Accordion/components/AccordionItem/AccordionItem.js';
53
53
  import '../../../components/Alert/Alert.js';
54
+ import '../../../context/WalletContext/WalletContext.js';
54
55
  import '../../../components/ShadowDOM/ShadowDOM.js';
55
56
  import '../../../components/IconButton/IconButton.js';
56
57
  import '../../../components/InlineWidget/InlineWidget.js';
@@ -66,7 +67,6 @@ import '../../../components/Popper/Popper/Popper.js';
66
67
  import '../../../components/Popper/PopperContext/PopperContext.js';
67
68
  import 'react-focus-lock';
68
69
  import 'qrcode';
69
- import '../../../context/WalletContext/WalletContext.js';
70
70
  import 'formik';
71
71
  import '../useSubdomainCheck/useSubdomainCheck.js';
72
72
  import '../../../context/WalletGroupContext/WalletGroupContext.js';
@@ -62,6 +62,7 @@ require('../../../store/state/walletOptions/walletOptions.cjs');
62
62
  require('react-i18next');
63
63
  require('../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
64
64
  require('../../../components/Alert/Alert.cjs');
65
+ require('../../../context/WalletContext/WalletContext.cjs');
65
66
  require('../../../components/ShadowDOM/ShadowDOM.cjs');
66
67
  require('../../../components/IconButton/IconButton.cjs');
67
68
  require('../../../components/InlineWidget/InlineWidget.cjs');
@@ -77,7 +78,6 @@ require('../../../components/Popper/Popper/Popper.cjs');
77
78
  require('../../../components/Popper/PopperContext/PopperContext.cjs');
78
79
  require('react-focus-lock');
79
80
  require('qrcode');
80
- require('../../../context/WalletContext/WalletContext.cjs');
81
81
  require('formik');
82
82
  require('../useSubdomainCheck/useSubdomainCheck.cjs');
83
83
  require('../../../context/WalletGroupContext/WalletGroupContext.cjs');
@@ -58,6 +58,7 @@ import '../../../store/state/walletOptions/walletOptions.js';
58
58
  import 'react-i18next';
59
59
  import '../../../components/Accordion/components/AccordionItem/AccordionItem.js';
60
60
  import '../../../components/Alert/Alert.js';
61
+ import '../../../context/WalletContext/WalletContext.js';
61
62
  import '../../../components/ShadowDOM/ShadowDOM.js';
62
63
  import '../../../components/IconButton/IconButton.js';
63
64
  import '../../../components/InlineWidget/InlineWidget.js';
@@ -73,7 +74,6 @@ import '../../../components/Popper/Popper/Popper.js';
73
74
  import '../../../components/Popper/PopperContext/PopperContext.js';
74
75
  import 'react-focus-lock';
75
76
  import 'qrcode';
76
- import '../../../context/WalletContext/WalletContext.js';
77
77
  import 'formik';
78
78
  import '../useSubdomainCheck/useSubdomainCheck.js';
79
79
  import '../../../context/WalletGroupContext/WalletGroupContext.js';
@@ -92,11 +92,11 @@ require('../../../../components/PasskeyCreatedSuccessBanner/PasskeyCreatedSucces
92
92
  require('../../../../store/state/connectorsInitializing/connectorsInitializing.cjs');
93
93
  require('../../../../store/state/tokenBalances.cjs');
94
94
  require('../../../../shared/utils/functions/getInitialUrl/getInitialUrl.cjs');
95
+ var EmailForm = require('../../../../components/EmailForm/EmailForm.cjs');
95
96
  require('../../../../components/InlineWidget/InlineWidget.cjs');
96
97
  require('../../../../components/IsBrowser/IsBrowser.cjs');
97
98
  require('../../../../components/Popper/Popper/Popper.cjs');
98
99
  require('../../../../components/Popper/PopperContext/PopperContext.cjs');
99
- var EmailForm = require('../../../../components/EmailForm/EmailForm.cjs');
100
100
 
101
101
  const LoginEmailForm = ({ isLoading, onSubmit, onSubmitError, currentEmail, className, style, }) => {
102
102
  var _a;
@@ -88,11 +88,11 @@ import '../../../../components/PasskeyCreatedSuccessBanner/PasskeyCreatedSuccess
88
88
  import '../../../../store/state/connectorsInitializing/connectorsInitializing.js';
89
89
  import '../../../../store/state/tokenBalances.js';
90
90
  import '../../../../shared/utils/functions/getInitialUrl/getInitialUrl.js';
91
+ import { EmailForm } from '../../../../components/EmailForm/EmailForm.js';
91
92
  import '../../../../components/InlineWidget/InlineWidget.js';
92
93
  import '../../../../components/IsBrowser/IsBrowser.js';
93
94
  import '../../../../components/Popper/Popper/Popper.js';
94
95
  import '../../../../components/Popper/PopperContext/PopperContext.js';
95
- import { EmailForm } from '../../../../components/EmailForm/EmailForm.js';
96
96
 
97
97
  const LoginEmailForm = ({ isLoading, onSubmit, onSubmitError, currentEmail, className, style, }) => {
98
98
  var _a;
@@ -96,9 +96,9 @@ require('../../components/PasskeyCreatedSuccessBanner/PasskeyCreatedSuccessBanne
96
96
  require('../../store/state/connectorsInitializing/connectorsInitializing.cjs');
97
97
  require('../../store/state/tokenBalances.cjs');
98
98
  require('../../shared/utils/functions/getInitialUrl/getInitialUrl.cjs');
99
- var MfaRecoveryIcon = require('../../components/MfaRecoveryIcon/MfaRecoveryIcon.cjs');
100
99
  require('../../components/InlineWidget/InlineWidget.cjs');
101
100
  require('../../components/IsBrowser/IsBrowser.cjs');
101
+ var MfaRecoveryIcon = require('../../components/MfaRecoveryIcon/MfaRecoveryIcon.cjs');
102
102
  require('../../components/Popper/Popper/Popper.cjs');
103
103
  require('../../components/Popper/PopperContext/PopperContext.cjs');
104
104
 
@@ -92,9 +92,9 @@ import '../../components/PasskeyCreatedSuccessBanner/PasskeyCreatedSuccessBanner
92
92
  import '../../store/state/connectorsInitializing/connectorsInitializing.js';
93
93
  import '../../store/state/tokenBalances.js';
94
94
  import '../../shared/utils/functions/getInitialUrl/getInitialUrl.js';
95
- import { MfaRecoveryScreenIcon } from '../../components/MfaRecoveryIcon/MfaRecoveryIcon.js';
96
95
  import '../../components/InlineWidget/InlineWidget.js';
97
96
  import '../../components/IsBrowser/IsBrowser.js';
97
+ import { MfaRecoveryScreenIcon } from '../../components/MfaRecoveryIcon/MfaRecoveryIcon.js';
98
98
  import '../../components/Popper/Popper/Popper.js';
99
99
  import '../../components/Popper/PopperContext/PopperContext.js';
100
100
 
@@ -99,11 +99,11 @@ require('../../../../components/PasskeyCreatedSuccessBanner/PasskeyCreatedSucces
99
99
  require('../../../../store/state/connectorsInitializing/connectorsInitializing.cjs');
100
100
  require('../../../../store/state/tokenBalances.cjs');
101
101
  require('../../../../shared/utils/functions/getInitialUrl/getInitialUrl.cjs');
102
+ var EmailForm = require('../../../../components/EmailForm/EmailForm.cjs');
102
103
  require('../../../../components/InlineWidget/InlineWidget.cjs');
103
104
  require('../../../../components/IsBrowser/IsBrowser.cjs');
104
105
  require('../../../../components/Popper/Popper/Popper.cjs');
105
106
  require('../../../../components/Popper/PopperContext/PopperContext.cjs');
106
- var EmailForm = require('../../../../components/EmailForm/EmailForm.cjs');
107
107
 
108
108
  const AddRecoveryEmail = ({ canSkipAddingEmail = true, shouldInitRecovery = false, authenticatorType, currentAction, isFromEmailVerification = false, }) => {
109
109
  const { user, setShowAuthFlow } = useInternalDynamicContext.useInternalDynamicContext();
@@ -95,11 +95,11 @@ import '../../../../components/PasskeyCreatedSuccessBanner/PasskeyCreatedSuccess
95
95
  import '../../../../store/state/connectorsInitializing/connectorsInitializing.js';
96
96
  import '../../../../store/state/tokenBalances.js';
97
97
  import '../../../../shared/utils/functions/getInitialUrl/getInitialUrl.js';
98
+ import { EmailForm } from '../../../../components/EmailForm/EmailForm.js';
98
99
  import '../../../../components/InlineWidget/InlineWidget.js';
99
100
  import '../../../../components/IsBrowser/IsBrowser.js';
100
101
  import '../../../../components/Popper/Popper/Popper.js';
101
102
  import '../../../../components/Popper/PopperContext/PopperContext.js';
102
- import { EmailForm } from '../../../../components/EmailForm/EmailForm.js';
103
103
 
104
104
  const AddRecoveryEmail = ({ canSkipAddingEmail = true, shouldInitRecovery = false, authenticatorType, currentAction, isFromEmailVerification = false, }) => {
105
105
  const { user, setShowAuthFlow } = useInternalDynamicContext();
@@ -57,6 +57,7 @@ require('../../../store/state/walletOptions/walletOptions.cjs');
57
57
  require('react-i18next');
58
58
  require('../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
59
59
  require('../../../components/Alert/Alert.cjs');
60
+ require('../../../context/WalletContext/WalletContext.cjs');
60
61
  require('../../../components/ShadowDOM/ShadowDOM.cjs');
61
62
  require('../../../components/IconButton/IconButton.cjs');
62
63
  require('../../../components/InlineWidget/InlineWidget.cjs');
@@ -72,7 +73,6 @@ require('../../../components/Popper/Popper/Popper.cjs');
72
73
  require('../../../components/Popper/PopperContext/PopperContext.cjs');
73
74
  require('react-focus-lock');
74
75
  require('qrcode');
75
- require('../../../context/WalletContext/WalletContext.cjs');
76
76
  require('formik');
77
77
  require('../../../utils/hooks/useSubdomainCheck/useSubdomainCheck.cjs');
78
78
  require('../../../context/WalletGroupContext/WalletGroupContext.cjs');