@dynamic-labs/sdk-react-core 4.12.0 → 4.12.2-preview.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 (29) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/package.cjs +1 -1
  3. package/package.js +1 -1
  4. package/package.json +11 -11
  5. package/src/lib/components/SignMessagePreview/SignMessagePreview.cjs +5 -1
  6. package/src/lib/components/SignMessagePreview/SignMessagePreview.js +5 -1
  7. package/src/lib/styles/index.shadow.cjs +1 -1
  8. package/src/lib/styles/index.shadow.js +1 -1
  9. package/src/lib/utils/functions/usingV3Wallets/usingV3Wallets.cjs +14 -0
  10. package/src/lib/utils/functions/usingV3Wallets/usingV3Wallets.d.ts +2 -0
  11. package/src/lib/utils/functions/usingV3Wallets/usingV3Wallets.js +10 -0
  12. package/src/lib/utils/hooks/useIsLoadingEmbeddedWallet/useIsLoadingEmbeddedWallet.cjs +110 -0
  13. package/src/lib/utils/hooks/useIsLoadingEmbeddedWallet/useIsLoadingEmbeddedWallet.d.ts +3 -0
  14. package/src/lib/utils/hooks/useIsLoadingEmbeddedWallet/useIsLoadingEmbeddedWallet.js +106 -0
  15. package/src/lib/views/EmailVerification/EmailVerification.cjs +8 -5
  16. package/src/lib/views/EmailVerification/EmailVerification.js +8 -5
  17. package/src/lib/widgets/DynamicBridgeWidget/DynamicBridgeWidget.cjs +35 -2
  18. package/src/lib/widgets/DynamicBridgeWidget/DynamicBridgeWidget.js +36 -3
  19. package/src/lib/widgets/DynamicBridgeWidget/components/DynamicBridgeWidgetEmptyCard/DynamicBridgeWidgetEmptyCard.cjs +1 -1
  20. package/src/lib/widgets/DynamicBridgeWidget/components/DynamicBridgeWidgetEmptyCard/DynamicBridgeWidgetEmptyCard.js +1 -1
  21. package/src/lib/widgets/DynamicBridgeWidget/views/WalletsView/components/SecondaryWallets/SecondaryWallets.cjs +3 -2
  22. package/src/lib/widgets/DynamicBridgeWidget/views/WalletsView/components/SecondaryWallets/SecondaryWallets.js +4 -3
  23. package/src/lib/widgets/DynamicWidget/components/ActiveWalletBalance/ActiveWalletBalance.cjs +3 -3
  24. package/src/lib/widgets/DynamicWidget/components/ActiveWalletBalance/ActiveWalletBalance.d.ts +5 -1
  25. package/src/lib/widgets/DynamicWidget/components/ActiveWalletBalance/ActiveWalletBalance.js +3 -3
  26. package/src/lib/widgets/DynamicWidget/components/ActiveWalletInformation/ActiveWalletInformation.cjs +1 -1
  27. package/src/lib/widgets/DynamicWidget/components/ActiveWalletInformation/ActiveWalletInformation.js +1 -1
  28. package/src/lib/widgets/DynamicWidget/components/DynamicWidgetHeader/DynamicWidgetWalletHeader/DynamicWidgetWalletHeader.cjs +5 -5
  29. package/src/lib/widgets/DynamicWidget/components/DynamicWidgetHeader/DynamicWidgetWalletHeader/DynamicWidgetWalletHeader.js +5 -5
@@ -188,7 +188,7 @@ const ActiveWalletInformation = ({ isLoading = false, }) => {
188
188
  }
189
189
  };
190
190
  if (isLoading) {
191
- return jsxRuntime.jsx(Skeleton.Skeleton, {});
191
+ return (jsxRuntime.jsxs("div", { className: 'active-wallet-information-container active-wallet-information-container--loading', "data-testid": 'active-wallet-information', children: [jsxRuntime.jsx("div", { className: 'active-wallet-information active-wallet-information--loading', children: jsxRuntime.jsxs("div", { className: 'active-wallet-information__header', children: [jsxRuntime.jsx("div", { className: 'active-wallet-information__avatar', children: jsxRuntime.jsx("div", { className: 'active-wallet-information__wallet-img', children: jsxRuntime.jsx(Skeleton.Skeleton, { className: 'active-wallet-information__skeleton-avatar' }) }) }), jsxRuntime.jsxs("div", { className: 'active-wallet-information__details', children: [jsxRuntime.jsxs("div", { className: 'active-wallet-information__addresses-container active-wallet-information__addresses-container--loading', children: [jsxRuntime.jsx("div", { className: 'active-wallet-information__handle-row', children: jsxRuntime.jsx(Skeleton.Skeleton, { className: 'active-wallet-information__skeleton-handle' }) }), jsxRuntime.jsx("div", { className: 'active-wallet-information__handle-row', children: jsxRuntime.jsx(Skeleton.Skeleton, { className: 'active-wallet-information__skeleton-address' }) })] }), !shouldHideNetwork && (jsxRuntime.jsx("div", { className: 'active-wallet-information__network-picker', children: jsxRuntime.jsx(Skeleton.Skeleton, { className: 'active-wallet-information__skeleton-network' }) }))] })] }) }), jsxRuntime.jsx(ActiveWalletBalance.ActiveWalletBalance, { isLoading: isLoading })] }));
192
192
  }
193
193
  return (jsxRuntime.jsxs("div", { className: 'active-wallet-information-container', "data-testid": 'active-wallet-information', children: [jsxRuntime.jsxs("div", { className: 'active-wallet-information', children: [jsxRuntime.jsxs("div", { className: 'active-wallet-information__header', children: [jsxRuntime.jsx("div", { className: 'active-wallet-information__avatar', children: (nameService === null || nameService === void 0 ? void 0 : nameService.avatar) ? (jsxRuntime.jsx("div", { className: 'active-wallet-information__avatar__name-service', children: jsxRuntime.jsx("img", { src: nameService === null || nameService === void 0 ? void 0 : nameService.avatar, alt: '' }) })) : (jsxRuntime.jsx("div", { className: 'active-wallet-information__wallet-img', children: jsxRuntime.jsx(AuthProviderIcon.AuthProviderIcon, { iconSize: ICON_SIZE }) })) }), jsxRuntime.jsxs("div", { className: 'active-wallet-information__details', children: [jsxRuntime.jsx("div", { className: classNames.classNames('active-wallet-information__addresses-container', {
194
194
  'active-wallet-information__addresses-container--centered': !(nameService === null || nameService === void 0 ? void 0 : nameService.name),
@@ -184,7 +184,7 @@ const ActiveWalletInformation = ({ isLoading = false, }) => {
184
184
  }
185
185
  };
186
186
  if (isLoading) {
187
- return jsx(Skeleton, {});
187
+ return (jsxs("div", { className: 'active-wallet-information-container active-wallet-information-container--loading', "data-testid": 'active-wallet-information', children: [jsx("div", { className: 'active-wallet-information active-wallet-information--loading', children: jsxs("div", { className: 'active-wallet-information__header', children: [jsx("div", { className: 'active-wallet-information__avatar', children: jsx("div", { className: 'active-wallet-information__wallet-img', children: jsx(Skeleton, { className: 'active-wallet-information__skeleton-avatar' }) }) }), jsxs("div", { className: 'active-wallet-information__details', children: [jsxs("div", { className: 'active-wallet-information__addresses-container active-wallet-information__addresses-container--loading', children: [jsx("div", { className: 'active-wallet-information__handle-row', children: jsx(Skeleton, { className: 'active-wallet-information__skeleton-handle' }) }), jsx("div", { className: 'active-wallet-information__handle-row', children: jsx(Skeleton, { className: 'active-wallet-information__skeleton-address' }) })] }), !shouldHideNetwork && (jsx("div", { className: 'active-wallet-information__network-picker', children: jsx(Skeleton, { className: 'active-wallet-information__skeleton-network' }) }))] })] }) }), jsx(ActiveWalletBalance, { isLoading: isLoading })] }));
188
188
  }
189
189
  return (jsxs("div", { className: 'active-wallet-information-container', "data-testid": 'active-wallet-information', children: [jsxs("div", { className: 'active-wallet-information', children: [jsxs("div", { className: 'active-wallet-information__header', children: [jsx("div", { className: 'active-wallet-information__avatar', children: (nameService === null || nameService === void 0 ? void 0 : nameService.avatar) ? (jsx("div", { className: 'active-wallet-information__avatar__name-service', children: jsx("img", { src: nameService === null || nameService === void 0 ? void 0 : nameService.avatar, alt: '' }) })) : (jsx("div", { className: 'active-wallet-information__wallet-img', children: jsx(AuthProviderIcon, { iconSize: ICON_SIZE }) })) }), jsxs("div", { className: 'active-wallet-information__details', children: [jsx("div", { className: classNames('active-wallet-information__addresses-container', {
190
190
  'active-wallet-information__addresses-container--centered': !(nameService === null || nameService === void 0 ? void 0 : nameService.name),
@@ -9,7 +9,7 @@ var reactI18next = require('react-i18next');
9
9
  var walletConnectorCore = require('@dynamic-labs/wallet-connector-core');
10
10
  require('@dynamic-labs/utils');
11
11
  require('../../../../../components/Accordion/components/AccordionItem/AccordionItem.cjs');
12
- var Alert = require('../../../../../components/Alert/Alert.cjs');
12
+ require('../../../../../components/Alert/Alert.cjs');
13
13
  require('../../../../../events/dynamicEvents.cjs');
14
14
  require('../../../../../../../_virtual/_tslib.cjs');
15
15
  require('../../../../../context/DynamicContext/DynamicContext.cjs');
@@ -51,7 +51,7 @@ require('bs58');
51
51
  require('@dynamic-labs/types');
52
52
  require('../../../../../context/SocialRedirectContext/SocialRedirectContext.cjs');
53
53
  require('../../../../../context/LoadingContext/LoadingContext.cjs');
54
- var WalletContext = require('../../../../../context/WalletContext/WalletContext.cjs');
54
+ require('../../../../../context/WalletContext/WalletContext.cjs');
55
55
  require('../../../../../utils/hooks/useEmbeddedWallet/useSecureEnclaveEmbeddedWallet/constants.cjs');
56
56
  require('yup');
57
57
  require('../../../../../context/MockContext/MockContext.cjs');
@@ -80,7 +80,6 @@ require('../../../../../utils/hooks/useSubdomainCheck/useSubdomainCheck.cjs');
80
80
  require('../../../../../store/state/sendBalances.cjs');
81
81
  require('../../../../../components/Input/Input.cjs');
82
82
  require('../../../../../components/OverlayCard/OverlayCard.cjs');
83
- var spinner = require('../../../../../components/Spinner/spinner.cjs');
84
83
  require('../../../../../views/TransactionConfirmationView/TransactionConfirmationView.cjs');
85
84
  require('../../../../../context/PasskeyContext/PasskeyContext.cjs');
86
85
  require('../../../views/ManagePasskeysWidgetView/PasskeyCard/PasskeyCard.cjs');
@@ -106,6 +105,7 @@ require('../../../../../components/Popper/PopperContext/PopperContext.cjs');
106
105
  var SecureEmbeddedWalletCard = require('../../../../../components/SecureEmbeddedWalletCard/SecureEmbeddedWalletCard.cjs');
107
106
  var SendBalanceContext = require('../../../../../context/SendBalanceContext/SendBalanceContext.cjs');
108
107
  var ActiveWalletInformation = require('../../ActiveWalletInformation/ActiveWalletInformation.cjs');
108
+ var useIsLoadingEmbeddedWallet = require('../../../../../utils/hooks/useIsLoadingEmbeddedWallet/useIsLoadingEmbeddedWallet.cjs');
109
109
 
110
110
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
111
111
 
@@ -125,7 +125,7 @@ const DynamicWidgetWalletHeader = ({ variant, }) => {
125
125
  const { primaryWallet, user } = useInternalDynamicContext.useInternalDynamicContext();
126
126
  const { open: openSendBalanceModal } = SendBalanceContext.useSendBalance();
127
127
  const { setDynamicWidgetView, setIsOpen } = DynamicWidgetContext.useWidgetContext();
128
- const { isLoadingEmbeddedWallet } = WalletContext.useWalletContext();
128
+ const { isLoadingEmbeddedWallet } = useIsLoadingEmbeddedWallet.useIsLoadingEmbeddedWallet();
129
129
  const { t } = reactI18next.useTranslation();
130
130
  const isSendBalanceEnabled = React.useMemo(() => {
131
131
  const connector = primaryWallet === null || primaryWallet === void 0 ? void 0 : primaryWallet.connector;
@@ -150,7 +150,7 @@ const DynamicWidgetWalletHeader = ({ variant, }) => {
150
150
  return (jsxRuntime.jsx("div", { className: 'dynamic-widget-wallet-header__icon-container', children: jsxRuntime.jsx(UserAvatar.UserAvatar, { user: user }) }));
151
151
  }
152
152
  };
153
- return (jsxRuntime.jsxs("div", { className: 'dynamic-widget-wallet-header', "data-testid": 'dynamic-widget-wallet-header', children: [renderWalletHeader(), isLoadingEmbeddedWallet && (jsxRuntime.jsx("div", { className: 'dynamic-widget-wallet-header__wallet-info', children: jsxRuntime.jsx("div", { className: 'dynamic-widget-wallet-header__wallet-loading', children: jsxRuntime.jsx(Alert.Alert, { variant: 'info', icon: jsxRuntime.jsx(spinner.Spinner, { className: 'button__spinner' }), children: t('dyn_creating_wallet.loading_message') }) }) })), primaryWallet ? (jsxRuntime.jsxs("div", { "data-testid": 'primaryWalletStatus', className: 'dynamic-widget-wallet-header__wallet-info', children: [jsxRuntime.jsx(SecureEmbeddedWalletCard.SecureEmbeddedWalletCard, { className: 'dynamic-widget-wallet-header__wallet-info__secure-wallet' }), jsxRuntime.jsxs("div", { className: 'dynamic-widget-wallet-header__wallet-actions', children: [jsxRuntime.jsx(TypographyButton.TypographyButton, { expanded: true, dataTestId: 'buy-crypto-button', buttonPadding: 'small', buttonVariant: 'primary', onClick: () => setDynamicWidgetView('choose-wallet-funding-method'), startSlot: jsxRuntime.jsx(Icon.Icon, { size: 'small', color: 'text-secondary', children: jsxRuntime.jsx(add.ReactComponent, {}) }), children: t('dyn_widget_header.buttons.deposit_funds') }), isSendBalanceEnabled && (jsxRuntime.jsx(TypographyButton.TypographyButton, { expanded: true, dataTestId: 'send-balance-button', buttonPadding: 'small', buttonVariant: 'primary', onClick: handleOnClickSend, startSlot: jsxRuntime.jsx(Icon.Icon, { size: 'small', color: 'text-secondary', children: jsxRuntime.jsx(send.ReactComponent, {}) }), children: t('dyn_widget_header.buttons.send_funds') })), jsxRuntime.jsx(LinkButton, { connector: primaryWallet.connector })] })] })) : (jsxRuntime.jsx(Typography.Typography, { className: 'dynamic-widget-wallet-header__email', variant: 'body_normal', weight: 'regular', children: !isLoadingEmbeddedWallet && getUserIdentifier.getUserIdentifier(user) }))] }));
153
+ return (jsxRuntime.jsxs("div", { className: 'dynamic-widget-wallet-header', "data-testid": 'dynamic-widget-wallet-header', children: [renderWalletHeader(), primaryWallet ? (jsxRuntime.jsxs("div", { "data-testid": 'primaryWalletStatus', className: 'dynamic-widget-wallet-header__wallet-info', children: [jsxRuntime.jsx(SecureEmbeddedWalletCard.SecureEmbeddedWalletCard, { className: 'dynamic-widget-wallet-header__wallet-info__secure-wallet' }), jsxRuntime.jsxs("div", { className: 'dynamic-widget-wallet-header__wallet-actions', children: [jsxRuntime.jsx(TypographyButton.TypographyButton, { expanded: true, dataTestId: 'buy-crypto-button', buttonPadding: 'small', buttonVariant: 'primary', onClick: () => setDynamicWidgetView('choose-wallet-funding-method'), startSlot: jsxRuntime.jsx(Icon.Icon, { size: 'small', color: 'text-secondary', children: jsxRuntime.jsx(add.ReactComponent, {}) }), children: t('dyn_widget_header.buttons.deposit_funds') }), isSendBalanceEnabled && (jsxRuntime.jsx(TypographyButton.TypographyButton, { expanded: true, dataTestId: 'send-balance-button', buttonPadding: 'small', buttonVariant: 'primary', onClick: handleOnClickSend, startSlot: jsxRuntime.jsx(Icon.Icon, { size: 'small', color: 'text-secondary', children: jsxRuntime.jsx(send.ReactComponent, {}) }), children: t('dyn_widget_header.buttons.send_funds') })), jsxRuntime.jsx(LinkButton, { connector: primaryWallet.connector })] })] })) : (jsxRuntime.jsx(Typography.Typography, { className: 'dynamic-widget-wallet-header__email', variant: 'body_normal', weight: 'regular', children: !isLoadingEmbeddedWallet && getUserIdentifier.getUserIdentifier(user) }))] }));
154
154
  };
155
155
  React__default["default"].memo(DynamicWidgetWalletHeader);
156
156
 
@@ -5,7 +5,7 @@ import { useTranslation } from 'react-i18next';
5
5
  import { isSendBalanceWalletConnector } from '@dynamic-labs/wallet-connector-core';
6
6
  import '@dynamic-labs/utils';
7
7
  import '../../../../../components/Accordion/components/AccordionItem/AccordionItem.js';
8
- import { Alert } from '../../../../../components/Alert/Alert.js';
8
+ import '../../../../../components/Alert/Alert.js';
9
9
  import '../../../../../events/dynamicEvents.js';
10
10
  import '../../../../../../../_virtual/_tslib.js';
11
11
  import '../../../../../context/DynamicContext/DynamicContext.js';
@@ -47,7 +47,7 @@ import 'bs58';
47
47
  import '@dynamic-labs/types';
48
48
  import '../../../../../context/SocialRedirectContext/SocialRedirectContext.js';
49
49
  import '../../../../../context/LoadingContext/LoadingContext.js';
50
- import { useWalletContext } from '../../../../../context/WalletContext/WalletContext.js';
50
+ import '../../../../../context/WalletContext/WalletContext.js';
51
51
  import '../../../../../utils/hooks/useEmbeddedWallet/useSecureEnclaveEmbeddedWallet/constants.js';
52
52
  import 'yup';
53
53
  import '../../../../../context/MockContext/MockContext.js';
@@ -76,7 +76,6 @@ import '../../../../../utils/hooks/useSubdomainCheck/useSubdomainCheck.js';
76
76
  import '../../../../../store/state/sendBalances.js';
77
77
  import '../../../../../components/Input/Input.js';
78
78
  import '../../../../../components/OverlayCard/OverlayCard.js';
79
- import { Spinner } from '../../../../../components/Spinner/spinner.js';
80
79
  import '../../../../../views/TransactionConfirmationView/TransactionConfirmationView.js';
81
80
  import '../../../../../context/PasskeyContext/PasskeyContext.js';
82
81
  import '../../../views/ManagePasskeysWidgetView/PasskeyCard/PasskeyCard.js';
@@ -102,6 +101,7 @@ import '../../../../../components/Popper/PopperContext/PopperContext.js';
102
101
  import { SecureEmbeddedWalletCard } from '../../../../../components/SecureEmbeddedWalletCard/SecureEmbeddedWalletCard.js';
103
102
  import { useSendBalance } from '../../../../../context/SendBalanceContext/SendBalanceContext.js';
104
103
  import { ActiveWalletInformation } from '../../ActiveWalletInformation/ActiveWalletInformation.js';
104
+ import { useIsLoadingEmbeddedWallet } from '../../../../../utils/hooks/useIsLoadingEmbeddedWallet/useIsLoadingEmbeddedWallet.js';
105
105
 
106
106
  const LinkButton = React__default.memo(({ connector }) => {
107
107
  const { setDynamicWidgetView } = useWidgetContext();
@@ -117,7 +117,7 @@ const DynamicWidgetWalletHeader = ({ variant, }) => {
117
117
  const { primaryWallet, user } = useInternalDynamicContext();
118
118
  const { open: openSendBalanceModal } = useSendBalance();
119
119
  const { setDynamicWidgetView, setIsOpen } = useWidgetContext();
120
- const { isLoadingEmbeddedWallet } = useWalletContext();
120
+ const { isLoadingEmbeddedWallet } = useIsLoadingEmbeddedWallet();
121
121
  const { t } = useTranslation();
122
122
  const isSendBalanceEnabled = useMemo(() => {
123
123
  const connector = primaryWallet === null || primaryWallet === void 0 ? void 0 : primaryWallet.connector;
@@ -142,7 +142,7 @@ const DynamicWidgetWalletHeader = ({ variant, }) => {
142
142
  return (jsx("div", { className: 'dynamic-widget-wallet-header__icon-container', children: jsx(UserAvatar, { user: user }) }));
143
143
  }
144
144
  };
145
- return (jsxs("div", { className: 'dynamic-widget-wallet-header', "data-testid": 'dynamic-widget-wallet-header', children: [renderWalletHeader(), isLoadingEmbeddedWallet && (jsx("div", { className: 'dynamic-widget-wallet-header__wallet-info', children: jsx("div", { className: 'dynamic-widget-wallet-header__wallet-loading', children: jsx(Alert, { variant: 'info', icon: jsx(Spinner, { className: 'button__spinner' }), children: t('dyn_creating_wallet.loading_message') }) }) })), primaryWallet ? (jsxs("div", { "data-testid": 'primaryWalletStatus', className: 'dynamic-widget-wallet-header__wallet-info', children: [jsx(SecureEmbeddedWalletCard, { className: 'dynamic-widget-wallet-header__wallet-info__secure-wallet' }), jsxs("div", { className: 'dynamic-widget-wallet-header__wallet-actions', children: [jsx(TypographyButton, { expanded: true, dataTestId: 'buy-crypto-button', buttonPadding: 'small', buttonVariant: 'primary', onClick: () => setDynamicWidgetView('choose-wallet-funding-method'), startSlot: jsx(Icon, { size: 'small', color: 'text-secondary', children: jsx(SvgAdd, {}) }), children: t('dyn_widget_header.buttons.deposit_funds') }), isSendBalanceEnabled && (jsx(TypographyButton, { expanded: true, dataTestId: 'send-balance-button', buttonPadding: 'small', buttonVariant: 'primary', onClick: handleOnClickSend, startSlot: jsx(Icon, { size: 'small', color: 'text-secondary', children: jsx(SvgSend, {}) }), children: t('dyn_widget_header.buttons.send_funds') })), jsx(LinkButton, { connector: primaryWallet.connector })] })] })) : (jsx(Typography, { className: 'dynamic-widget-wallet-header__email', variant: 'body_normal', weight: 'regular', children: !isLoadingEmbeddedWallet && getUserIdentifier(user) }))] }));
145
+ return (jsxs("div", { className: 'dynamic-widget-wallet-header', "data-testid": 'dynamic-widget-wallet-header', children: [renderWalletHeader(), primaryWallet ? (jsxs("div", { "data-testid": 'primaryWalletStatus', className: 'dynamic-widget-wallet-header__wallet-info', children: [jsx(SecureEmbeddedWalletCard, { className: 'dynamic-widget-wallet-header__wallet-info__secure-wallet' }), jsxs("div", { className: 'dynamic-widget-wallet-header__wallet-actions', children: [jsx(TypographyButton, { expanded: true, dataTestId: 'buy-crypto-button', buttonPadding: 'small', buttonVariant: 'primary', onClick: () => setDynamicWidgetView('choose-wallet-funding-method'), startSlot: jsx(Icon, { size: 'small', color: 'text-secondary', children: jsx(SvgAdd, {}) }), children: t('dyn_widget_header.buttons.deposit_funds') }), isSendBalanceEnabled && (jsx(TypographyButton, { expanded: true, dataTestId: 'send-balance-button', buttonPadding: 'small', buttonVariant: 'primary', onClick: handleOnClickSend, startSlot: jsx(Icon, { size: 'small', color: 'text-secondary', children: jsx(SvgSend, {}) }), children: t('dyn_widget_header.buttons.send_funds') })), jsx(LinkButton, { connector: primaryWallet.connector })] })] })) : (jsx(Typography, { className: 'dynamic-widget-wallet-header__email', variant: 'body_normal', weight: 'regular', children: !isLoadingEmbeddedWallet && getUserIdentifier(user) }))] }));
146
146
  };
147
147
  React__default.memo(DynamicWidgetWalletHeader);
148
148