@arcblock/ux 2.13.70 → 3.0.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.
- package/lib/ActionButton/ActionButton.stories.d.ts +18 -0
- package/lib/ActionButton/index.d.ts +2 -2
- package/lib/ActionButton/index.js +43 -94
- package/lib/ActivityIndicator/ActivityIndicator.stories.d.ts +8 -0
- package/lib/ActivityIndicator/index.d.ts +2 -8
- package/lib/ActivityIndicator/index.js +41 -114
- package/lib/Address/Address.stories.d.ts +16 -0
- package/lib/Address/compact-text.d.ts +4 -14
- package/lib/Address/compact-text.js +40 -98
- package/lib/Address/did-address.d.ts +5 -4
- package/lib/Address/did-address.js +94 -151
- package/lib/Address/index.d.ts +4 -2
- package/lib/Address/index.js +13 -20
- package/lib/Address/responsive-did-address.d.ts +5 -4
- package/lib/Address/responsive-did-address.js +80 -114
- package/lib/Alert/Alert.stories.d.ts +28 -0
- package/lib/Alert/index.d.ts +2 -2
- package/lib/Alert/index.js +56 -102
- package/lib/AnimationWaiter/AnimationWaiter.stories.d.ts +21 -0
- package/lib/AnimationWaiter/{dark-animation.json → dark-animation.json.js} +27 -1
- package/lib/AnimationWaiter/{default-animation.json → default-animation.json.js} +29 -1
- package/lib/AnimationWaiter/index.d.ts +3 -25
- package/lib/AnimationWaiter/index.js +107 -198
- package/lib/Async/index.d.ts +2 -4
- package/lib/Async/index.js +15 -29
- package/lib/Avatar/Avatar.stories.d.ts +11 -0
- package/lib/Avatar/did-motif.d.ts +5 -15
- package/lib/Avatar/did-motif.js +30 -65
- package/lib/Avatar/etherscan-blockies.js +42 -75
- package/lib/Avatar/index.d.ts +3 -19
- package/lib/Avatar/index.js +114 -180
- package/lib/Badge/Badge.stories.d.ts +13 -0
- package/lib/Badge/index.d.ts +3 -3
- package/lib/Badge/index.js +43 -83
- package/lib/Blocklet/Blocklet.stories.d.ts +17 -0
- package/lib/Blocklet/blocklet.d.ts +2 -28
- package/lib/Blocklet/blocklet.js +108 -191
- package/lib/Blocklet/index.d.ts +2 -3
- package/lib/Blocklet/index.js +7 -4
- package/lib/Blocklet/utils.d.ts +1 -1
- package/lib/Blocklet/utils.js +10 -10
- package/lib/BlockletContext/index.d.ts +3 -3
- package/lib/BlockletContext/index.js +32 -57
- package/lib/BlockletNFT/BlockletNFT.stories.d.ts +17 -0
- package/lib/BlockletNFT/index.d.ts +3 -38
- package/lib/BlockletNFT/index.js +123 -245
- package/lib/BlockletV2/Blocklet.stories.d.ts +18 -0
- package/lib/BlockletV2/blocklet.d.ts +2 -2
- package/lib/BlockletV2/blocklet.js +188 -213
- package/lib/BlockletV2/components/icon-text.d.ts +2 -2
- package/lib/BlockletV2/components/icon-text.js +43 -33
- package/lib/BlockletV2/components/tooltip-icon.js +46 -36
- package/lib/BlockletV2/index.d.ts +3 -3
- package/lib/BlockletV2/index.js +9 -5
- package/lib/BlockletV2/utils.d.ts +1 -1
- package/lib/BlockletV2/utils.js +13 -25
- package/lib/Button/Button.stories.d.ts +19 -0
- package/lib/Button/index.d.ts +1 -1
- package/lib/Button/index.js +6 -8
- package/lib/Button/wrap.d.ts +3 -3
- package/lib/Button/wrap.js +48 -131
- package/lib/ButtonGroup/index.d.ts +2 -2
- package/lib/ButtonGroup/index.js +6 -16
- package/lib/CardSelector/index.js +51 -94
- package/lib/Center/Center.stories.d.ts +18 -0
- package/lib/Center/index.js +15 -18
- package/lib/ClickToCopy/ClickToCopy.stories.d.ts +16 -0
- package/lib/ClickToCopy/copy-button.d.ts +3 -2
- package/lib/ClickToCopy/copy-button.js +19 -58
- package/lib/ClickToCopy/hook.d.ts +2 -2
- package/lib/ClickToCopy/hook.js +23 -32
- package/lib/ClickToCopy/index.d.ts +3 -14
- package/lib/ClickToCopy/index.js +23 -75
- package/lib/CloseButton/index.d.ts +1 -1
- package/lib/CloseButton/index.js +34 -28
- package/lib/CodeBlock/CodeBlock.stories.d.ts +20 -0
- package/lib/CodeBlock/LightBox.d.ts +4 -4
- package/lib/CodeBlock/LightBox.js +5 -4
- package/lib/CodeBlock/index.d.ts +1 -2
- package/lib/CodeBlock/index.js +96 -127
- package/lib/Colors/Colors.stories.d.ts +34 -0
- package/lib/Colors/index.js +8 -4
- package/lib/Colors/themes/default.d.ts +1 -1
- package/lib/Colors/themes/default.js +5 -7
- package/lib/Colors/themes/did-connect.js +43 -44
- package/lib/Colors/themes/temp.js +38 -39
- package/lib/Config/Config.stories.d.ts +14 -0
- package/lib/Config/config-provider.d.ts +8 -8
- package/lib/Config/config-provider.js +50 -44
- package/lib/Config/index.js +7 -2
- package/lib/Config/theme-mode-toggle.js +12 -27
- package/lib/ContactForm/ContactForm.stories.d.ts +23 -0
- package/lib/ContactForm/index.d.ts +2 -1
- package/lib/ContactForm/index.js +137 -164
- package/lib/CookieConsent/CookieConsent.stories.d.ts +18 -0
- package/lib/CookieConsent/index.d.ts +2 -2
- package/lib/CookieConsent/index.js +44 -73
- package/lib/CountDown/CountDown.stories.d.ts +14 -0
- package/lib/CountDown/index.d.ts +2 -2
- package/lib/CountDown/index.js +52 -124
- package/lib/DID/DID.stories.d.ts +15 -0
- package/lib/DID/index.d.ts +3 -1
- package/lib/DID/index.js +262 -327
- package/lib/DIDConnect/app-icon.js +26 -31
- package/lib/DIDConnect/app-info-item.js +76 -82
- package/lib/DIDConnect/auth-apps/auth-apps-info.js +71 -63
- package/lib/DIDConnect/auth-apps/index.d.ts +2 -2
- package/lib/DIDConnect/auth-apps/index.js +184 -183
- package/lib/DIDConnect/did-connect-container.js +231 -247
- package/lib/DIDConnect/did-connect-footer.js +66 -68
- package/lib/DIDConnect/did-connect-logo.js +10 -11
- package/lib/DIDConnect/index.js +22 -10
- package/lib/DIDConnect/landing-page.d.ts +1 -1
- package/lib/DIDConnect/landing-page.js +165 -189
- package/lib/DIDConnect/powered-by.js +55 -46
- package/lib/DIDConnect/request-storage-access-api-dialog.d.ts +5 -2
- package/lib/DIDConnect/request-storage-access-api-dialog.js +230 -292
- package/lib/DIDConnect/with-container.js +200 -236
- package/lib/DIDConnect/with-ux-theme.js +15 -22
- package/lib/Datatable/CustomToolbar.d.ts +1 -15
- package/lib/Datatable/CustomToolbar.js +232 -313
- package/lib/Datatable/Datatable.stories.d.ts +32 -0
- package/lib/Datatable/DatatableContext.js +23 -35
- package/lib/Datatable/TableSearch.d.ts +5 -13
- package/lib/Datatable/TableSearch.js +81 -113
- package/lib/Datatable/index.d.ts +12 -13
- package/lib/Datatable/index.js +226 -479
- package/lib/Datatable/utils.js +55 -120
- package/lib/Dialog/Dialog.stories.d.ts +20 -0
- package/lib/Dialog/confirm.d.ts +4 -25
- package/lib/Dialog/confirm.js +99 -125
- package/lib/Dialog/dialog.d.ts +30 -23
- package/lib/Dialog/dialog.js +62 -148
- package/lib/Dialog/index.d.ts +3 -3
- package/lib/Dialog/index.js +8 -4
- package/lib/Dialog/use-confirm.d.ts +3 -3
- package/lib/Dialog/use-confirm.js +91 -171
- package/lib/DidLogo/Logo.stories.d.ts +8 -0
- package/lib/DidLogo/index.js +19 -19
- package/lib/DriftBot/index.js +23 -33
- package/lib/Earth/Earth.stories.d.ts +18 -0
- package/lib/Earth/countries.json.js +13 -0
- package/lib/Earth/index.js +234 -334
- package/lib/Earth/util.js +36 -45
- package/lib/Empty/Empty.stories.d.ts +17 -0
- package/lib/Empty/index.d.ts +3 -11
- package/lib/Empty/index.js +17 -50
- package/lib/ErrorBoundary/ErrorBoundary.stories.d.ts +12 -0
- package/lib/ErrorBoundary/fallback.js +54 -71
- package/lib/ErrorBoundary/index.js +6 -1
- package/lib/Footer/Footer.stories.d.ts +12 -0
- package/lib/Footer/index.d.ts +1 -12
- package/lib/Footer/index.js +53 -100
- package/lib/Header/Header.stories.d.ts +21 -0
- package/lib/Header/addon-button.js +24 -31
- package/lib/Header/auto-hidden.d.ts +1 -1
- package/lib/Header/auto-hidden.js +9 -16
- package/lib/Header/header-addons.d.ts +1 -1
- package/lib/Header/header-addons.js +40 -37
- package/lib/Header/header.d.ts +2 -1
- package/lib/Header/header.js +64 -109
- package/lib/Header/index.js +8 -3
- package/lib/Header/responsive-header.d.ts +1 -1
- package/lib/Header/responsive-header.js +74 -112
- package/lib/Icon/Icon.stories.d.ts +23 -0
- package/lib/Icon/image.d.ts +1 -1
- package/lib/Icon/image.js +32 -33
- package/lib/Icon/index.d.ts +4 -4
- package/lib/Icon/index.js +30 -53
- package/lib/Img/Img.stories.d.ts +13 -0
- package/lib/Img/index.d.ts +6 -32
- package/lib/Img/index.js +126 -204
- package/lib/InfoRow/InfoRow.stories.d.ts +14 -0
- package/lib/InfoRow/index.js +27 -41
- package/lib/Layout/Layout.stories.d.ts +23 -0
- package/lib/Layout/dashboard/external-link.d.ts +1 -1
- package/lib/Layout/dashboard/external-link.js +23 -44
- package/lib/Layout/dashboard/full-page.d.ts +1 -1
- package/lib/Layout/dashboard/full-page.js +31 -48
- package/lib/Layout/dashboard/index.d.ts +4 -4
- package/lib/Layout/dashboard/index.js +134 -211
- package/lib/Layout/dashboard/sidebar.js +44 -78
- package/lib/Layout/dashboard-legacy/header.d.ts +1 -1
- package/lib/Layout/dashboard-legacy/header.js +70 -87
- package/lib/Layout/dashboard-legacy/index.d.ts +2 -2
- package/lib/Layout/dashboard-legacy/index.js +82 -90
- package/lib/Layout/dashboard-legacy/sidebar.d.ts +1 -1
- package/lib/Layout/dashboard-legacy/sidebar.js +44 -76
- package/lib/Layout/index.d.ts +2 -2
- package/lib/Layout/index.js +129 -189
- package/lib/LoadingMask/index.js +91 -82
- package/lib/Locale/LocaleSelector.stories.d.ts +22 -0
- package/lib/Locale/browser-lang.js +23 -52
- package/lib/Locale/context.d.ts +3 -3
- package/lib/Locale/context.js +71 -123
- package/lib/Locale/languages.js +32 -34
- package/lib/Locale/selector.d.ts +2 -2
- package/lib/Locale/selector.js +104 -139
- package/lib/Locale/util.d.ts +1 -1
- package/lib/Locale/util.js +9 -24
- package/lib/Logo/Logo.stories.d.ts +22 -0
- package/lib/Logo/images/logo-dark-text.svg.js +5 -0
- package/lib/Logo/images/logo-dark-top.svg.js +5 -0
- package/lib/Logo/images/logo-light-text.svg.js +5 -0
- package/lib/Logo/images/logo-light-top.svg.js +5 -0
- package/lib/Logo/index.d.ts +1 -1
- package/lib/Logo/index.js +27 -107
- package/lib/Metric/Metric.stories.d.ts +14 -0
- package/lib/Metric/index.js +50 -53
- package/lib/MuiWrap/index.js +11 -19
- package/lib/NFTDisplay/NFTBroken.svg.js +108 -0
- package/lib/NFTDisplay/NFTDisplay.stories.d.ts +15 -0
- package/lib/NFTDisplay/aspect-ratio-container.js +9 -20
- package/lib/NFTDisplay/broken.js +14 -286
- package/lib/NFTDisplay/displayApi.d.ts +1 -1
- package/lib/NFTDisplay/displayApi.js +17 -44
- package/lib/NFTDisplay/index.d.ts +2 -2
- package/lib/NFTDisplay/index.js +160 -343
- package/lib/NFTDisplay/loading.js +9 -9
- package/lib/NFTDisplay/render-svg.js +15 -22
- package/lib/NFTDisplay/svg-embedder/img.js +13 -29
- package/lib/NFTDisplay/svg-embedder/inline-svg.d.ts +1 -1
- package/lib/NFTDisplay/svg-embedder/inline-svg.js +10 -20
- package/lib/NavMenu/NavMenu.stories.d.ts +17 -0
- package/lib/NavMenu/images/OCAP.svg.js +5 -0
- package/lib/NavMenu/images/abt-network.svg.js +7 -0
- package/lib/NavMenu/images/ai-kit.svg.js +7 -0
- package/lib/NavMenu/images/aigne.svg.js +7 -0
- package/lib/NavMenu/images/aistro.svg.js +5 -0
- package/lib/NavMenu/images/arcsphere.svg.js +10 -0
- package/lib/NavMenu/images/blocklet-framework.svg.js +7 -0
- package/lib/NavMenu/images/blocklet-launcher.svg.js +5 -0
- package/lib/NavMenu/images/blocklet-server.svg.js +7 -0
- package/lib/NavMenu/images/blocklet-store.svg.js +5 -0
- package/lib/NavMenu/images/creator-studio.svg.js +7 -0
- package/lib/NavMenu/images/did-connect.svg.js +5 -0
- package/lib/NavMenu/images/did-name-service.svg.js +5 -0
- package/lib/NavMenu/images/did-wallet.svg.js +7 -0
- package/lib/NavMenu/images/did.svg.js +5 -0
- package/lib/NavMenu/images/nft-studio.svg.js +5 -0
- package/lib/NavMenu/images/vc.svg.js +5 -0
- package/lib/NavMenu/images/web3-kit.svg.js +7 -0
- package/lib/NavMenu/index.js +6 -3
- package/lib/NavMenu/nav-menu-context.js +15 -18
- package/lib/NavMenu/nav-menu.d.ts +17 -7
- package/lib/NavMenu/nav-menu.js +219 -355
- package/lib/NavMenu/products.js +264 -1652
- package/lib/NavMenu/style.d.ts +5 -5
- package/lib/NavMenu/style.js +156 -172
- package/lib/NavMenu/sub-container.d.ts +1 -1
- package/lib/NavMenu/sub-container.js +63 -104
- package/lib/NavMenu/sub-item-group.js +15 -33
- package/lib/PageScroller/index.d.ts +1 -1
- package/lib/PageScroller/index.js +116 -252
- package/lib/PageScroller/story/FifthComponent.js +7 -9
- package/lib/PageScroller/story/FirstComponent.js +7 -9
- package/lib/PageScroller/story/FourthComponent.js +7 -12
- package/lib/PageScroller/story/FullPage.js +52 -45
- package/lib/PageScroller/story/PageContain.js +55 -57
- package/lib/PageScroller/story/PageScroller.stories.d.ts +13 -0
- package/lib/PageScroller/story/SecondComponent.js +7 -9
- package/lib/PageScroller/story/ThirdComponent.js +7 -9
- package/lib/PageScroller/usePrevValue.js +10 -8
- package/lib/Passport/index.d.ts +1 -1
- package/lib/Passport/index.js +4 -2
- package/lib/Passport/passport.d.ts +1 -1
- package/lib/Passport/passport.js +123 -100
- package/lib/PhoneInput/PhoneInput.stories.d.ts +12 -0
- package/lib/PhoneInput/country-select.d.ts +2 -2
- package/lib/PhoneInput/country-select.js +111 -159
- package/lib/PhoneInput/index.js +166 -218
- package/lib/PoweredByArcBlock/index.d.ts +1 -1
- package/lib/PoweredByArcBlock/index.js +16 -22
- package/lib/PricingTable/PricingPlan.js +20 -55
- package/lib/PricingTable/PricingTable.stories.d.ts +8 -0
- package/lib/PricingTable/index.d.ts +1 -1
- package/lib/PricingTable/index.js +34 -37
- package/lib/QRCode/QRCode.stories.d.ts +13 -0
- package/lib/QRCode/index.d.ts +1 -1
- package/lib/QRCode/index.js +31 -49
- package/lib/RelativeTime/RelativeTime.stories.d.ts +20 -0
- package/lib/RelativeTime/index.d.ts +3 -3
- package/lib/RelativeTime/index.js +163 -261
- package/lib/Result/Result.stories.d.ts +21 -0
- package/lib/Result/common.d.ts +2 -2
- package/lib/Result/common.js +97 -129
- package/lib/Result/index.d.ts +1 -1
- package/lib/Result/index.js +21 -22
- package/lib/Result/result.js +45 -32
- package/lib/Result/translations.d.ts +1 -1
- package/lib/Result/translations.js +28 -25
- package/lib/Screenshot/BaseScreenshot/index.d.ts +1 -1
- package/lib/Screenshot/BaseScreenshot/index.js +23 -44
- package/lib/Screenshot/BaseScreenshot/shells/Macbook.js +23 -41
- package/lib/Screenshot/BaseScreenshot/shells/Phone.js +24 -26
- package/lib/Screenshot/Screenshot.stories.d.ts +13 -0
- package/lib/Screenshot/demo/images/bg-01.jpg +0 -0
- package/lib/Screenshot/demo/images/bg-02.jpg +0 -0
- package/lib/Screenshot/demo/images/bg-03.jpg +0 -0
- package/lib/Screenshot/index.d.ts +1 -2
- package/lib/Screenshot/index.js +83 -188
- package/lib/SessionBlocklet/index.d.ts +2 -2
- package/lib/SessionBlocklet/index.js +147 -162
- package/lib/SessionManager/SessionManager.stories.d.ts +9 -0
- package/lib/SessionManager/index.d.ts +1 -1
- package/lib/SessionManager/index.js +4 -2
- package/lib/SessionPermission/index.d.ts +1 -0
- package/lib/SessionPermission/index.js +12 -20
- package/lib/SessionUser/components/did-space.js +65 -117
- package/lib/SessionUser/components/logged-in.d.ts +3 -4
- package/lib/SessionUser/components/logged-in.js +215 -292
- package/lib/SessionUser/components/quick-login-item.js +125 -120
- package/lib/SessionUser/components/session-user-item.d.ts +4 -2
- package/lib/SessionUser/components/session-user-item.js +85 -89
- package/lib/SessionUser/components/session-user-switch.d.ts +1 -1
- package/lib/SessionUser/components/session-user-switch.js +187 -187
- package/lib/SessionUser/components/un-login.js +196 -222
- package/lib/SessionUser/components/user-info.d.ts +1 -1
- package/lib/SessionUser/components/user-info.js +163 -150
- package/lib/SessionUser/images/did-spaces.svg.js +5 -0
- package/lib/SessionUser/index.d.ts +1 -1
- package/lib/SessionUser/index.js +27 -30
- package/lib/SessionUser/libs/translation.d.ts +1 -1
- package/lib/SessionUser/libs/translation.js +25 -24
- package/lib/SessionUser/libs/utils.js +33 -23
- package/lib/SharedBridge/index.d.ts +6 -5
- package/lib/SharedBridge/index.js +76 -93
- package/lib/Sparkline/Sparkline.stories.d.ts +12 -0
- package/lib/Sparkline/index.js +67 -183
- package/lib/Spinner/Spinner.stories.d.ts +18 -0
- package/lib/Spinner/index.d.ts +1 -1
- package/lib/Spinner/index.js +10 -20
- package/lib/SplitButton/SplitButton.stories.d.ts +15 -0
- package/lib/SplitButton/index.d.ts +3 -5
- package/lib/SplitButton/index.js +39 -83
- package/lib/Success/index.js +174 -160
- package/lib/Switch/Switch.stories.d.ts +13 -0
- package/lib/Switch/index.d.ts +3 -7
- package/lib/Switch/index.js +51 -87
- package/lib/Tabs/Tabs.stories.d.ts +14 -0
- package/lib/Tabs/index.d.ts +2 -2
- package/lib/Tabs/index.js +169 -186
- package/lib/Tag/Tag.stories.d.ts +13 -0
- package/lib/Tag/index.d.ts +7 -4
- package/lib/Tag/index.js +40 -88
- package/lib/TextCollapse/TextCollapse.stories.d.ts +28 -0
- package/lib/TextCollapse/index.js +34 -51
- package/lib/Theme/Theme.stories.d.ts +10 -0
- package/lib/Theme/index.d.ts +1 -2
- package/lib/Theme/index.js +25 -17
- package/lib/Theme/theme-provider.d.ts +4 -15
- package/lib/Theme/theme-provider.js +111 -232
- package/lib/Theme/theme.d.ts +1 -8
- package/lib/Theme/theme.js +118 -166
- package/lib/Toast/Toast.stories.d.ts +15 -0
- package/lib/Toast/index.d.ts +1 -1
- package/lib/Toast/index.js +46 -67
- package/lib/Typography/index.d.ts +1 -1
- package/lib/Typography/index.js +73 -109
- package/lib/UserCard/Cards/avatar-only.d.ts +1 -1
- package/lib/UserCard/Cards/avatar-only.js +28 -36
- package/lib/UserCard/Cards/basic-info.d.ts +1 -2
- package/lib/UserCard/Cards/basic-info.js +34 -42
- package/lib/UserCard/Cards/index.d.ts +1 -1
- package/lib/UserCard/Cards/index.js +13 -21
- package/lib/UserCard/Cards/name-only.js +12 -18
- package/lib/UserCard/Container/card.d.ts +2 -2
- package/lib/UserCard/Container/card.js +34 -41
- package/lib/UserCard/Container/dialog.d.ts +1 -1
- package/lib/UserCard/Container/dialog.js +27 -27
- package/lib/UserCard/Content/basic.d.ts +1 -2
- package/lib/UserCard/Content/basic.js +227 -307
- package/lib/UserCard/Content/clock.d.ts +2 -0
- package/lib/UserCard/Content/clock.js +85 -71
- package/lib/UserCard/Content/minimal.d.ts +1 -1
- package/lib/UserCard/Content/minimal.js +81 -71
- package/lib/UserCard/Content/shorten-label.js +11 -35
- package/lib/UserCard/Content/tooltip-avatar.d.ts +1 -1
- package/lib/UserCard/Content/tooltip-avatar.js +43 -51
- package/lib/UserCard/UserCard.stories.d.ts +18 -0
- package/lib/UserCard/components.d.ts +1 -1
- package/lib/UserCard/components.js +53 -66
- package/lib/UserCard/index.d.ts +1 -2
- package/lib/UserCard/index.js +59 -111
- package/lib/UserCard/types.d.ts +1 -1
- package/lib/UserCard/types.js +10 -37
- package/lib/UserCard/utils.js +70 -125
- package/lib/Util/WebWalletOpener.stories.d.ts +5 -0
- package/lib/Util/constant.js +47 -46
- package/lib/Util/deprecate.js +11 -26
- package/lib/Util/federated.d.ts +6 -6
- package/lib/Util/federated.js +77 -92
- package/lib/Util/iframe.js +14 -21
- package/lib/Util/index.d.ts +5 -5
- package/lib/Util/index.js +278 -479
- package/lib/Util/logger.d.ts +1 -1
- package/lib/Util/logger.js +17 -25
- package/lib/Util/passport.js +72 -87
- package/lib/Util/security.js +28 -40
- package/lib/Util/style.d.ts +1 -1
- package/lib/Util/style.js +4 -14
- package/lib/Util/wallet.js +16 -30
- package/lib/VerificationCode/index.d.ts +1 -1
- package/lib/VerificationCode/index.js +69 -64
- package/lib/Video/Video.stories.d.ts +6 -0
- package/lib/Video/index.d.ts +1 -9
- package/lib/Video/index.js +26 -60
- package/lib/Wallet/Action.d.ts +1 -10
- package/lib/Wallet/Action.js +37 -65
- package/lib/Wallet/Action.stories.d.ts +8 -0
- package/lib/Wallet/Download.d.ts +3 -16
- package/lib/Wallet/Download.js +41 -440
- package/lib/Wallet/Download.stories.d.ts +9 -0
- package/lib/Wallet/Open.d.ts +1 -1
- package/lib/Wallet/Open.js +27 -27
- package/lib/Wallet/OpenInWallet.stories.d.ts +5 -0
- package/lib/Wallet/images/android_download.svg.js +5 -0
- package/lib/Wallet/images/app-store.svg.js +5 -0
- package/lib/Wallet/images/google-play.svg.js +5 -0
- package/lib/WalletOSIcon/index.js +15 -73
- package/lib/WebWalletSWKeeper/index.js +39 -106
- package/lib/WechatPrompt/images/android.png +0 -0
- package/lib/WechatPrompt/images/ios.png +0 -0
- package/lib/WechatPrompt/index.js +26 -61
- package/lib/hooks/use-blocklet-logo.d.ts +2 -2
- package/lib/hooks/use-blocklet-logo.js +22 -30
- package/lib/hooks/use-clock.d.ts +1 -3
- package/lib/hooks/use-clock.js +34 -67
- package/lib/hooks/use-location-state.js +55 -79
- package/lib/hooks/use-mobile.js +8 -7
- package/lib/index.d.ts +35 -35
- package/lib/index.js +81 -38
- package/lib/ux.css +1 -0
- package/lib/withTheme/index.d.ts +1 -3
- package/lib/withTheme/index.js +28 -37
- package/lib/withTracker/error_boundary.d.ts +1 -1
- package/lib/withTracker/error_boundary.js +15 -29
- package/lib/withTracker/index.js +21 -48
- package/package.json +48 -57
- package/src/ActionButton/ActionButton.stories.jsx +61 -0
- package/src/ActionButton/index.jsx +30 -14
- package/src/ActivityIndicator/ActivityIndicator.stories.jsx +9 -0
- package/src/ActivityIndicator/index.jsx +2 -11
- package/src/Address/Address.stories.jsx +38 -0
- package/src/Address/compact-text.jsx +9 -11
- package/src/Address/did-address.tsx +8 -4
- package/src/Address/index.tsx +12 -9
- package/src/Address/responsive-did-address.tsx +94 -89
- package/src/Alert/Alert.stories.jsx +100 -0
- package/src/Alert/index.jsx +24 -12
- package/src/AnimationWaiter/AnimationWaiter.stories.jsx +35 -0
- package/src/AnimationWaiter/index.jsx +10 -23
- package/src/Async/index.tsx +2 -2
- package/src/Avatar/Avatar.stories.jsx +11 -0
- package/src/Avatar/did-motif.jsx +1 -8
- package/src/Avatar/index.jsx +36 -13
- package/src/Badge/Badge.stories.jsx +41 -0
- package/src/Badge/index.jsx +22 -18
- package/src/Blocklet/Blocklet.stories.jsx +21 -0
- package/src/Blocklet/blocklet.jsx +13 -30
- package/src/BlockletContext/index.tsx +2 -2
- package/src/BlockletNFT/BlockletNFT.stories.jsx +21 -0
- package/src/BlockletNFT/index.jsx +14 -38
- package/src/BlockletV2/Blocklet.stories.jsx +34 -0
- package/src/BlockletV2/blocklet.tsx +69 -29
- package/src/BlockletV2/components/icon-text.tsx +15 -5
- package/src/Button/Button.stories.jsx +24 -0
- package/src/Button/index.js +1 -1
- package/src/Button/wrap.jsx +20 -13
- package/src/ButtonGroup/index.js +1 -1
- package/src/Center/Center.stories.jsx +20 -0
- package/src/ClickToCopy/ClickToCopy.stories.jsx +24 -0
- package/src/ClickToCopy/copy-button.tsx +4 -4
- package/src/ClickToCopy/index.tsx +28 -12
- package/src/CodeBlock/CodeBlock.stories.jsx +22 -0
- package/src/CodeBlock/index.tsx +1 -2
- package/src/Colors/Colors.stories.jsx +211 -0
- package/src/Colors/themes/did-connect.ts +0 -2
- package/src/Config/Config.stories.jsx +16 -0
- package/src/Config/theme-mode-toggle.tsx +4 -2
- package/src/ContactForm/ContactForm.stories.jsx +32 -0
- package/src/ContactForm/index.tsx +2 -2
- package/src/CookieConsent/CookieConsent.stories.jsx +33 -0
- package/src/CookieConsent/index.tsx +1 -1
- package/src/CountDown/CountDown.stories.jsx +15 -0
- package/src/CountDown/index.tsx +11 -6
- package/src/DID/DID.stories.jsx +37 -0
- package/src/DID/index.tsx +8 -3
- package/src/DIDConnect/app-info-item.tsx +2 -2
- package/src/DIDConnect/did-connect-container.tsx +17 -18
- package/src/DIDConnect/request-storage-access-api-dialog.tsx +210 -183
- package/src/DIDConnect/with-container.tsx +17 -18
- package/src/Datatable/CustomToolbar.jsx +32 -34
- package/src/Datatable/Datatable.stories.jsx +92 -0
- package/src/Datatable/DatatableContext.jsx +2 -2
- package/src/Datatable/TableSearch.jsx +10 -12
- package/src/Datatable/index.jsx +36 -58
- package/src/Datatable/utils.js +7 -7
- package/src/Dialog/Dialog.stories.jsx +21 -0
- package/src/Dialog/confirm.jsx +11 -21
- package/src/Dialog/dialog.jsx +9 -20
- package/src/Dialog/use-confirm.jsx +4 -3
- package/src/DidLogo/Logo.stories.jsx +8 -0
- package/src/DriftBot/index.tsx +4 -6
- package/src/Earth/Earth.stories.jsx +39 -0
- package/src/Earth/index.tsx +1 -1
- package/src/Empty/Empty.stories.jsx +23 -0
- package/src/Empty/index.jsx +1 -6
- package/src/ErrorBoundary/ErrorBoundary.stories.jsx +13 -0
- package/src/ErrorBoundary/fallback.tsx +5 -1
- package/src/Footer/Footer.stories.jsx +13 -0
- package/src/Footer/index.tsx +10 -18
- package/src/Header/Header.stories.jsx +30 -0
- package/src/Header/auto-hidden.tsx +1 -1
- package/src/Header/header.tsx +21 -4
- package/src/Header/responsive-header.tsx +11 -13
- package/src/Icon/Icon.stories.jsx +45 -0
- package/src/Icon/index.tsx +12 -24
- package/src/Img/Img.stories.jsx +17 -0
- package/src/Img/index.jsx +14 -30
- package/src/InfoRow/InfoRow.stories.jsx +14 -0
- package/src/InfoRow/index.tsx +5 -5
- package/src/Layout/Layout.stories.jsx +24 -0
- package/src/Layout/dashboard/full-page.tsx +4 -4
- package/src/Layout/dashboard/index.tsx +24 -21
- package/src/Layout/dashboard/sidebar.tsx +1 -1
- package/src/Layout/dashboard-legacy/header.tsx +25 -14
- package/src/Layout/dashboard-legacy/index.tsx +7 -7
- package/src/Layout/dashboard-legacy/sidebar.tsx +1 -3
- package/src/Layout/index.tsx +8 -6
- package/src/Locale/LocaleSelector.stories.jsx +44 -0
- package/src/Locale/context.tsx +2 -2
- package/src/Locale/selector.tsx +10 -17
- package/src/Logo/Logo.stories.jsx +23 -0
- package/src/Metric/Metric.stories.jsx +29 -0
- package/src/NFTDisplay/NFTDisplay.stories.jsx +30 -0
- package/src/NFTDisplay/broken.tsx +1 -1
- package/src/NFTDisplay/displayApi.ts +1 -0
- package/src/NFTDisplay/index.tsx +0 -1
- package/src/NavMenu/NavMenu.stories.jsx +17 -0
- package/src/NavMenu/nav-menu-context.tsx +3 -3
- package/src/NavMenu/nav-menu.tsx +138 -125
- package/src/NavMenu/products.tsx +7 -1
- package/src/NavMenu/style.ts +1 -1
- package/src/PageScroller/index.tsx +2 -2
- package/src/PageScroller/story/PageScroller.stories.jsx +18 -0
- package/src/PageScroller/usePrevValue.ts +1 -1
- package/src/PhoneInput/PhoneInput.stories.jsx +12 -0
- package/src/PhoneInput/country-select.tsx +107 -103
- package/src/PhoneInput/index.tsx +12 -4
- package/src/PricingTable/PricingPlan.tsx +1 -4
- package/src/PricingTable/PricingTable.stories.jsx +38 -0
- package/src/PricingTable/index.tsx +16 -4
- package/src/QRCode/QRCode.stories.jsx +13 -0
- package/src/RelativeTime/RelativeTime.stories.jsx +20 -0
- package/src/RelativeTime/index.tsx +20 -5
- package/src/Result/Result.stories.jsx +61 -0
- package/src/Result/common.tsx +1 -2
- package/src/Result/result.tsx +22 -6
- package/src/Screenshot/Screenshot.stories.jsx +44 -0
- package/src/Screenshot/index.tsx +33 -15
- package/src/SessionManager/SessionManager.stories.jsx +9 -0
- package/src/SessionPermission/index.tsx +1 -0
- package/src/SessionUser/components/logged-in.tsx +0 -2
- package/src/SessionUser/components/quick-login-item.tsx +3 -3
- package/src/SessionUser/components/session-user-item.tsx +68 -70
- package/src/SessionUser/components/session-user-switch.tsx +9 -1
- package/src/SessionUser/components/un-login.tsx +8 -1
- package/src/SharedBridge/index.tsx +106 -111
- package/src/Sparkline/Sparkline.stories.jsx +13 -0
- package/src/Spinner/Spinner.stories.jsx +98 -0
- package/src/Spinner/index.tsx +1 -1
- package/src/SplitButton/SplitButton.stories.jsx +32 -0
- package/src/SplitButton/index.tsx +15 -9
- package/src/Switch/Switch.stories.jsx +16 -0
- package/src/Switch/index.jsx +2 -6
- package/src/Tabs/Tabs.stories.jsx +18 -0
- package/src/Tabs/index.tsx +3 -3
- package/src/Tag/Tag.stories.jsx +15 -0
- package/src/Tag/index.jsx +20 -11
- package/src/TextCollapse/TextCollapse.stories.jsx +73 -0
- package/src/TextCollapse/index.tsx +1 -1
- package/src/Theme/Theme.stories.jsx +10 -0
- package/src/Theme/theme-provider.tsx +10 -18
- package/src/Theme/theme.ts +7 -2
- package/src/Toast/Toast.stories.jsx +28 -0
- package/src/Toast/index.tsx +2 -2
- package/src/Typography/index.tsx +6 -2
- package/src/UserCard/Cards/basic-info.tsx +9 -5
- package/src/UserCard/Container/card.tsx +2 -2
- package/src/UserCard/Content/basic.tsx +43 -14
- package/src/UserCard/Content/clock.tsx +13 -6
- package/src/UserCard/Content/minimal.tsx +23 -7
- package/src/UserCard/Content/tooltip-avatar.tsx +14 -11
- package/src/UserCard/UserCard.stories.jsx +18 -0
- package/src/UserCard/components.tsx +6 -3
- package/src/UserCard/index.tsx +0 -1
- package/src/Util/WebWalletOpener.stories.jsx +5 -0
- package/src/Util/index.ts +37 -3
- package/src/VerificationCode/index.tsx +16 -14
- package/src/Video/Video.stories.jsx +6 -0
- package/src/Video/index.tsx +16 -8
- package/src/Wallet/Action.stories.jsx +8 -0
- package/src/Wallet/Action.tsx +20 -9
- package/src/Wallet/Download.stories.jsx +9 -0
- package/src/Wallet/Download.tsx +36 -14
- package/src/Wallet/Open.tsx +1 -1
- package/src/Wallet/OpenInWallet.stories.jsx +5 -0
- package/src/WechatPrompt/index.tsx +1 -2
- package/src/hooks/use-clock.tsx +2 -1
- package/src/withTheme/index.tsx +1 -4
- package/vite.config.mjs +34 -0
- package/babel.config.es.js +0 -28
- package/lib/Dialog/types.d.ts +0 -20
- package/lib/Earth/countries.json +0 -8057
- package/lib/Header/demo/images/boards.svg +0 -3
- package/lib/Header/demo/images/chatbot.svg +0 -3
- package/lib/Header/demo/images/gallery.svg +0 -3
- package/lib/Logo/images/logo-dark-text.svg +0 -3
- package/lib/Logo/images/logo-dark-top.svg +0 -6
- package/lib/Logo/images/logo-light-text.svg +0 -3
- package/lib/Logo/images/logo-light-top.svg +0 -6
- package/lib/NFTDisplay/NFTBroken.svg +0 -34
- package/lib/NFTDisplay/README.md +0 -59
- package/lib/NFTDisplay/demo/data/asset-state-bad-url.json +0 -7
- package/lib/NFTDisplay/demo/data/asset-state-did-space-svg.json +0 -7
- package/lib/NFTDisplay/demo/data/asset-state-did-space.json +0 -7
- package/lib/NFTDisplay/demo/data/asset-state-display-url.json +0 -7
- package/lib/NFTDisplay/demo/data/asset-state-gzipped-svg-1-1.json +0 -10
- package/lib/NFTDisplay/demo/data/asset-state-gzipped-svg-374-130.json +0 -10
- package/lib/NFTDisplay/demo/data/asset-state-gzipped-svg-with-foreign-object.json +0 -20
- package/lib/NFTDisplay/demo/data/asset-state-svg.json +0 -29
- package/lib/NFTDisplay/demo/data/asset-state-url.json +0 -10
- package/lib/NavMenu/images/OCAP.svg +0 -16
- package/lib/NavMenu/images/abt-network.svg +0 -18
- package/lib/NavMenu/images/ai-kit.svg +0 -46
- package/lib/NavMenu/images/aigne.svg +0 -8
- package/lib/NavMenu/images/aistro.svg +0 -14
- package/lib/NavMenu/images/arcsphere.svg +0 -13
- package/lib/NavMenu/images/blocklet-framework.svg +0 -25
- package/lib/NavMenu/images/blocklet-launcher.svg +0 -9
- package/lib/NavMenu/images/blocklet-server.svg +0 -19
- package/lib/NavMenu/images/blocklet-store.svg +0 -11
- package/lib/NavMenu/images/creator-studio.svg +0 -42
- package/lib/NavMenu/images/did-connect.svg +0 -26
- package/lib/NavMenu/images/did-name-service.svg +0 -3
- package/lib/NavMenu/images/did-wallet.svg +0 -33
- package/lib/NavMenu/images/did.svg +0 -3
- package/lib/NavMenu/images/nft-studio.svg +0 -19
- package/lib/NavMenu/images/vc.svg +0 -7
- package/lib/NavMenu/images/web3-kit.svg +0 -56
- package/lib/PageScroller/story/index.css +0 -115
- package/lib/Result/demo/fixtures/result-image-404.svg +0 -1
- package/lib/Screenshot/devices.css +0 -1366
- package/lib/SessionUser/images/did-spaces.svg +0 -17
- package/lib/Wallet/images/android_download.svg +0 -22
- package/lib/Wallet/images/app-store.svg +0 -30
- package/lib/Wallet/images/google-play.svg +0 -69
- package/lib/global.d.ts +0 -28
- package/lib/type.d.ts +0 -44
- package/lib/withTracker/README.md +0 -37
- /package/src/PageScroller/story/{FifthComponent.js → FifthComponent.jsx} +0 -0
- /package/src/PageScroller/story/{FirstComponent.js → FirstComponent.jsx} +0 -0
- /package/src/PageScroller/story/{FourthComponent.js → FourthComponent.jsx} +0 -0
- /package/src/PageScroller/story/{FullPage.js → FullPage.jsx} +0 -0
- /package/src/PageScroller/story/{PageContain.js → PageContain.jsx} +0 -0
- /package/src/PageScroller/story/{SecondComponent.js → SecondComponent.jsx} +0 -0
- /package/src/PageScroller/story/{ThirdComponent.js → ThirdComponent.jsx} +0 -0
package/src/Screenshot/index.tsx
CHANGED
@@ -1,5 +1,6 @@
|
|
1
1
|
import { createElement, Children, cloneElement, useEffect, useRef, useState } from 'react';
|
2
2
|
import { type SxProps } from '@mui/material';
|
3
|
+
import isUndefined from 'lodash/isUndefined';
|
3
4
|
|
4
5
|
import { mergeProps } from '../Util';
|
5
6
|
import { styled } from '../Theme';
|
@@ -87,7 +88,7 @@ const childProps = {
|
|
87
88
|
video: ['alt', 'title', 'muted', 'autoplay', 'loop', 'key', 'children'],
|
88
89
|
};
|
89
90
|
|
90
|
-
const createChild = (child: React.ReactElement) => [
|
91
|
+
const createChild = (child: React.ReactElement<any>) => [
|
91
92
|
createElement(
|
92
93
|
child.type,
|
93
94
|
childProps[child.type as keyof typeof childProps].reduce((acc: Record<string, any>, x: string) => {
|
@@ -97,7 +98,10 @@ const createChild = (child: React.ReactElement) => [
|
|
97
98
|
),
|
98
99
|
];
|
99
100
|
|
100
|
-
const findChildren = (
|
101
|
+
const findChildren = (
|
102
|
+
children: React.ReactElement<any>[],
|
103
|
+
returnArgWhenNotFound = true
|
104
|
+
): React.ReactElement<any>[] | null => {
|
101
105
|
for (let i = 0; i < children.length; i++) {
|
102
106
|
const child = children[i];
|
103
107
|
|
@@ -106,7 +110,7 @@ const findChildren = (children: React.ReactElement[], returnArgWhenNotFound = tr
|
|
106
110
|
}
|
107
111
|
|
108
112
|
if (child.props && child.props.children) {
|
109
|
-
const subChildren = Children.toArray(child.props.children) as React.ReactElement[];
|
113
|
+
const subChildren = Children.toArray(child.props.children) as React.ReactElement<any>[];
|
110
114
|
const result = findChildren(subChildren, false);
|
111
115
|
if (result) {
|
112
116
|
return result;
|
@@ -133,7 +137,28 @@ export interface OldScreenshotProps extends React.ComponentProps<'div'> {
|
|
133
137
|
// This component is built upon the awesome device.css lib
|
134
138
|
// By default it will find and only render img/video tags in the children
|
135
139
|
// If neither of them are found, the whole child tree is rendered
|
136
|
-
function OldScreenshot(
|
140
|
+
function OldScreenshot(rawProps: OldScreenshotProps) {
|
141
|
+
const props = Object.assign({}, rawProps);
|
142
|
+
// eslint-disable-next-line react/prop-types
|
143
|
+
if (isUndefined(props.type)) {
|
144
|
+
props.type = 'iphone-x';
|
145
|
+
}
|
146
|
+
// eslint-disable-next-line react/prop-types
|
147
|
+
if (isUndefined(props.className)) {
|
148
|
+
props.className = '';
|
149
|
+
}
|
150
|
+
// eslint-disable-next-line react/prop-types
|
151
|
+
if (isUndefined(props.style)) {
|
152
|
+
props.style = {};
|
153
|
+
}
|
154
|
+
// eslint-disable-next-line react/prop-types
|
155
|
+
if (isUndefined(props.width)) {
|
156
|
+
props.width = 0;
|
157
|
+
}
|
158
|
+
// eslint-disable-next-line react/prop-types
|
159
|
+
if (isUndefined(props.height)) {
|
160
|
+
props.height = 0;
|
161
|
+
}
|
137
162
|
const newProps = mergeProps(props, OldScreenshot, ['style', 'width', 'height']) as OldScreenshotProps;
|
138
163
|
const { type, children, style, className, width, height, ...rest } = newProps;
|
139
164
|
const { zIndex = 0, borderRadius = 0 } = (types[type!] || {}) as DeviceStyles;
|
@@ -149,9 +174,10 @@ function OldScreenshot(props: OldScreenshotProps) {
|
|
149
174
|
<div className="device-frame">
|
150
175
|
<div className="device-content">
|
151
176
|
{/* eslint-disable-next-line react/no-array-index-key */}
|
152
|
-
{findChildren(Children.toArray(children) as React.ReactElement[])?.map((item: any, index: number) =>
|
153
|
-
|
154
|
-
|
177
|
+
{findChildren(Children.toArray(children) as React.ReactElement<any>[])?.map((item: any, index: number) => {
|
178
|
+
// eslint-disable-next-line react/no-array-index-key
|
179
|
+
return cloneElement(item, { key: index });
|
180
|
+
})}
|
155
181
|
</div>
|
156
182
|
</div>
|
157
183
|
<div className="device-stripe" />
|
@@ -163,14 +189,6 @@ function OldScreenshot(props: OldScreenshotProps) {
|
|
163
189
|
);
|
164
190
|
}
|
165
191
|
|
166
|
-
OldScreenshot.defaultProps = {
|
167
|
-
type: 'iphone-x' as const,
|
168
|
-
className: '',
|
169
|
-
style: {},
|
170
|
-
width: 0,
|
171
|
-
height: 0,
|
172
|
-
};
|
173
|
-
|
174
192
|
type DivProps = {
|
175
193
|
type: keyof typeof types;
|
176
194
|
contentRadius: number;
|
@@ -0,0 +1,9 @@
|
|
1
|
+
export { default as HasLogin } from './demo/has-login';
|
2
|
+
export { default as NotLogin } from './demo/not-login';
|
3
|
+
export { default as Callback } from './demo/callback';
|
4
|
+
export { default as DarkMode } from './demo/dark-mode';
|
5
|
+
export { default as Size } from './demo/size';
|
6
|
+
|
7
|
+
export default {
|
8
|
+
title: 'DID/SessionManager',
|
9
|
+
};
|
@@ -44,7 +44,6 @@ const debug = createDebug('did-connect');
|
|
44
44
|
|
45
45
|
export interface LoggedInProps extends Omit<BoxProps, 'onClick' | 'onMouseEnter' | 'onMouseLeave'> {
|
46
46
|
session: Session;
|
47
|
-
dark?: false | true;
|
48
47
|
onBindWallet?: () => void;
|
49
48
|
isBlocklet?: true | false;
|
50
49
|
locale?: Locale;
|
@@ -54,7 +53,6 @@ export interface LoggedInProps extends Omit<BoxProps, 'onClick' | 'onMouseEnter'
|
|
54
53
|
|
55
54
|
export default function LoggedIn({
|
56
55
|
session,
|
57
|
-
dark = false,
|
58
56
|
onBindWallet = noop,
|
59
57
|
isBlocklet = true,
|
60
58
|
locale = 'en',
|
@@ -1,10 +1,10 @@
|
|
1
|
-
import DID from '@arcblock/ux/lib/DID';
|
2
|
-
import RelativeTime from '@arcblock/ux/lib/RelativeTime';
|
3
|
-
import WalletOSIcon from '@arcblock/ux/lib/WalletOSIcon';
|
4
1
|
import { Box, Chip, Typography, useMediaQuery, useTheme } from '@mui/material';
|
5
2
|
import type { Theme } from '@mui/material';
|
6
3
|
import noop from 'lodash/noop';
|
7
4
|
|
5
|
+
import RelativeTime from '../../RelativeTime';
|
6
|
+
import WalletOSIcon from '../../WalletOSIcon';
|
7
|
+
import { DID } from '../../DID';
|
8
8
|
import Avatar from '../../Avatar';
|
9
9
|
import { getSourceProvider } from '../libs/utils';
|
10
10
|
|
@@ -1,11 +1,10 @@
|
|
1
|
-
import { forwardRef } from 'react';
|
2
1
|
import { Box, type BoxProps, IconButton, Tooltip, Typography, useTheme } from '@mui/material';
|
3
2
|
import { Icon } from '@iconify/react';
|
4
3
|
import LensIcon from '@iconify-icons/material-symbols/lens';
|
5
4
|
|
6
5
|
import WalletOSIcon from '../../WalletOSIcon';
|
7
6
|
import Avatar from '../../Avatar';
|
8
|
-
import DID from '../../DID';
|
7
|
+
import { DID } from '../../DID';
|
9
8
|
import { getSourceProvider } from '../libs/utils';
|
10
9
|
import { Session } from '../../type';
|
11
10
|
|
@@ -15,81 +14,80 @@ export interface SessionUserItemProps extends BoxProps {
|
|
15
14
|
active?: false | true;
|
16
15
|
}
|
17
16
|
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
17
|
+
function SessionUserItem({
|
18
|
+
ref,
|
19
|
+
sessionItem,
|
20
|
+
statusContent = null,
|
21
|
+
active = false,
|
22
|
+
...rest
|
23
|
+
}: SessionUserItemProps & {
|
24
|
+
ref?: React.Ref<unknown>;
|
25
|
+
}) {
|
26
|
+
const { palette } = useTheme();
|
27
|
+
const isRawWalletAccount = getSourceProvider(sessionItem?.user) === 'wallet';
|
22
28
|
|
23
|
-
|
29
|
+
return (
|
30
|
+
<Box
|
31
|
+
{...rest}
|
32
|
+
ref={ref}
|
33
|
+
sx={{
|
34
|
+
display: 'flex',
|
35
|
+
alignItems: 'center',
|
36
|
+
justifyContent: 'space-between',
|
37
|
+
py: 0.75,
|
38
|
+
px: 1,
|
39
|
+
width: '100%',
|
40
|
+
...rest?.sx,
|
41
|
+
}}>
|
24
42
|
<Box
|
25
|
-
{...rest}
|
26
|
-
ref={ref}
|
27
43
|
sx={{
|
28
44
|
display: 'flex',
|
29
45
|
alignItems: 'center',
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
46
|
+
gap: 0.5,
|
47
|
+
overflow: 'hidden',
|
48
|
+
'& .did-address-avatar': {
|
49
|
+
display: 'none !important',
|
50
|
+
},
|
35
51
|
}}>
|
36
|
-
<Box
|
37
|
-
|
38
|
-
display: 'flex',
|
39
|
-
alignItems: 'center',
|
40
|
-
gap: 0.5,
|
41
|
-
overflow: 'hidden',
|
42
|
-
'& .did-address-avatar': {
|
43
|
-
display: 'none !important',
|
44
|
-
},
|
45
|
-
}}>
|
46
|
-
<Box sx={{ mr: 0.5, fontSize: 0 }}>
|
47
|
-
<Avatar did={sessionItem.userDid} size={36} />
|
48
|
-
</Box>
|
49
|
-
<WalletOSIcon
|
50
|
-
color={palette.text.secondary}
|
51
|
-
loading={sessionItem.__isDefault}
|
52
|
-
provider={sessionItem?.extra?.provider}
|
53
|
-
walletOS={sessionItem?.extra?.walletOS}
|
54
|
-
/>
|
55
|
-
{isRawWalletAccount ? (
|
56
|
-
<DID
|
57
|
-
did={sessionItem.userDid}
|
58
|
-
copyable={false}
|
59
|
-
size={14}
|
60
|
-
responsive={false}
|
61
|
-
compact
|
62
|
-
sx={{ lineHeight: 1 }}
|
63
|
-
/>
|
64
|
-
) : (
|
65
|
-
sessionItem.user.email && (
|
66
|
-
<Tooltip
|
67
|
-
title={sessionItem.user.email}
|
68
|
-
sx={{
|
69
|
-
zIndex: 1600,
|
70
|
-
}}
|
71
|
-
placement="top">
|
72
|
-
<Typography
|
73
|
-
sx={{
|
74
|
-
fontSize: 14,
|
75
|
-
overflow: 'hidden',
|
76
|
-
textOverflow: 'ellipsis',
|
77
|
-
}}>
|
78
|
-
{sessionItem.user.email}
|
79
|
-
</Typography>
|
80
|
-
</Tooltip>
|
81
|
-
)
|
82
|
-
)}
|
52
|
+
<Box sx={{ mr: 0.5, fontSize: 0 }}>
|
53
|
+
<Avatar did={sessionItem.userDid} size={36} />
|
83
54
|
</Box>
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
55
|
+
<WalletOSIcon
|
56
|
+
color={palette.text.secondary}
|
57
|
+
loading={sessionItem.__isDefault}
|
58
|
+
provider={sessionItem?.extra?.provider}
|
59
|
+
walletOS={sessionItem?.extra?.walletOS}
|
60
|
+
/>
|
61
|
+
{isRawWalletAccount ? (
|
62
|
+
<DID did={sessionItem.userDid} copyable={false} size={14} responsive={false} compact sx={{ lineHeight: 1 }} />
|
63
|
+
) : (
|
64
|
+
sessionItem.user.email && (
|
65
|
+
<Tooltip
|
66
|
+
title={sessionItem.user.email}
|
67
|
+
sx={{
|
68
|
+
zIndex: 1600,
|
69
|
+
}}
|
70
|
+
placement="top">
|
71
|
+
<Typography
|
72
|
+
sx={{
|
73
|
+
fontSize: 14,
|
74
|
+
overflow: 'hidden',
|
75
|
+
textOverflow: 'ellipsis',
|
76
|
+
}}>
|
77
|
+
{sessionItem.user.email}
|
78
|
+
</Typography>
|
79
|
+
</Tooltip>
|
80
|
+
)
|
81
|
+
)}
|
90
82
|
</Box>
|
91
|
-
|
92
|
-
|
93
|
-
|
83
|
+
{statusContent ||
|
84
|
+
(active && (
|
85
|
+
<IconButton size="small" disableRipple>
|
86
|
+
<Icon icon={LensIcon} fontSize={6} color={palette.success.main} />
|
87
|
+
</IconButton>
|
88
|
+
))}
|
89
|
+
</Box>
|
90
|
+
);
|
91
|
+
}
|
94
92
|
|
95
93
|
export default SessionUserItem;
|
@@ -106,6 +106,7 @@ export default function SessionUserSwitch({
|
|
106
106
|
return (
|
107
107
|
<SessionUserItem
|
108
108
|
sessionItem={currentSession}
|
109
|
+
// @ts-expect-error
|
109
110
|
statusContent={<Icon icon={SwapHorizRoundedIcon} color={palette.text.hint} />}
|
110
111
|
sx={{
|
111
112
|
borderRadius: 1,
|
@@ -219,7 +220,14 @@ export default function SessionUserSwitch({
|
|
219
220
|
}}
|
220
221
|
onClick={handleAddAccount}
|
221
222
|
data-cy="sessionManager-switch-trigger">
|
222
|
-
<Box
|
223
|
+
<Box
|
224
|
+
component={Icon}
|
225
|
+
icon={AddCircleOutlineRoundedIcon}
|
226
|
+
sx={{
|
227
|
+
fontSize: 20,
|
228
|
+
mr: 0.5,
|
229
|
+
}}
|
230
|
+
/>
|
223
231
|
{t('addAnotherAccount')}
|
224
232
|
</MenuItem>
|
225
233
|
</MenuList>
|
@@ -113,7 +113,14 @@ export default function UnLogin({ session, onLogin = noop, size = 24, dark = fal
|
|
113
113
|
onClick={_onLogin}
|
114
114
|
aria-label="Login button">
|
115
115
|
{isFirstLoading ? (
|
116
|
-
<Box
|
116
|
+
<Box
|
117
|
+
sx={{
|
118
|
+
width: size,
|
119
|
+
height: size,
|
120
|
+
display: 'flex',
|
121
|
+
justifyContent: 'center',
|
122
|
+
alignItems: 'center',
|
123
|
+
}}>
|
117
124
|
<CircularProgress style={{ width: size - 4, height: size - 4, color: dark ? '#fff' : '' }} />
|
118
125
|
</Box>
|
119
126
|
) : (
|
@@ -1,131 +1,126 @@
|
|
1
1
|
import { Box } from '@mui/material';
|
2
2
|
import type { SxProps } from '@mui/material';
|
3
|
-
import {
|
3
|
+
import { memo, useEffect, useId, useImperativeHandle, useRef } from 'react';
|
4
4
|
import { withQuery } from 'ufo';
|
5
5
|
import { useMemoizedFn, useReactive } from 'ahooks';
|
6
6
|
import noop from 'lodash/noop';
|
7
7
|
|
8
8
|
import { mergeSx } from '../Util/style';
|
9
9
|
import { callIframe, getCallbackAction } from '../Util/iframe';
|
10
|
-
import { Locale } from '../type';
|
11
10
|
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
11
|
+
function SharedBridge({
|
12
|
+
ref,
|
13
|
+
src,
|
14
|
+
onClick,
|
15
|
+
onLoad = noop,
|
16
|
+
sx,
|
17
|
+
...rest
|
18
|
+
}: {
|
19
|
+
src: string;
|
20
|
+
onClick: (data: { action: string; value: boolean; visitorId?: string; error?: Error }) => void;
|
21
|
+
onLoad?: () => void;
|
22
|
+
sx?: SxProps;
|
23
|
+
} & {
|
24
|
+
ref?: React.Ref<unknown>;
|
25
|
+
}) {
|
26
|
+
const targetIframeRef = useRef<HTMLIFrameElement>(null);
|
27
|
+
const refId = useId();
|
28
|
+
const dataId = `shared-bridge_${refId}`;
|
29
|
+
const currentState = useReactive<{
|
30
|
+
hasInited?: boolean;
|
31
|
+
open: boolean;
|
32
|
+
hasStorageAccess: boolean;
|
33
|
+
origin: string;
|
34
|
+
host: string;
|
35
|
+
containerEl: HTMLDivElement | null;
|
36
|
+
}>({
|
37
|
+
hasInited: undefined,
|
38
|
+
open: false,
|
39
|
+
hasStorageAccess: false,
|
40
|
+
containerEl: null,
|
41
|
+
get origin() {
|
42
|
+
try {
|
43
|
+
return new URL(src).origin;
|
44
|
+
} catch (error) {
|
45
|
+
return src;
|
46
|
+
}
|
27
47
|
},
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
hasStorageAccess: boolean;
|
37
|
-
origin: string;
|
38
|
-
host: string;
|
39
|
-
containerEl: HTMLDivElement | null;
|
40
|
-
}>({
|
41
|
-
hasInited: undefined,
|
42
|
-
open: false,
|
43
|
-
hasStorageAccess: false,
|
44
|
-
containerEl: null,
|
45
|
-
get origin() {
|
46
|
-
try {
|
47
|
-
return new URL(src).origin;
|
48
|
-
} catch (error) {
|
49
|
-
return src;
|
50
|
-
}
|
51
|
-
},
|
52
|
-
get host() {
|
53
|
-
try {
|
54
|
-
return new URL(src).host;
|
55
|
-
} catch (error) {
|
56
|
-
return src;
|
57
|
-
}
|
58
|
-
},
|
59
|
-
});
|
60
|
-
|
61
|
-
useEffect(() => {
|
62
|
-
async function handleMessage(event: MessageEvent) {
|
63
|
-
const { data } = event;
|
64
|
-
if (data.action === getCallbackAction(dataId, 'requestStorageAccess')) {
|
65
|
-
currentState.open = false;
|
48
|
+
get host() {
|
49
|
+
try {
|
50
|
+
return new URL(src).host;
|
51
|
+
} catch (error) {
|
52
|
+
return src;
|
53
|
+
}
|
54
|
+
},
|
55
|
+
});
|
66
56
|
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
57
|
+
useEffect(() => {
|
58
|
+
async function handleMessage(event: MessageEvent) {
|
59
|
+
const { data } = event;
|
60
|
+
if (data.action === getCallbackAction(dataId, 'requestStorageAccess')) {
|
61
|
+
currentState.open = false;
|
71
62
|
|
72
|
-
|
73
|
-
onClick(
|
74
|
-
|
75
|
-
currentState.open = true;
|
63
|
+
if (!data.value) {
|
64
|
+
onClick(data);
|
65
|
+
return;
|
76
66
|
}
|
67
|
+
|
68
|
+
const { value: visitorId } = await callIframe(targetIframeRef.current as HTMLIFrameElement, 'getVisitorId');
|
69
|
+
onClick({ ...data, visitorId });
|
70
|
+
} else if (data.action === getCallbackAction(dataId, 'preRequestStorageAccess')) {
|
71
|
+
currentState.open = true;
|
77
72
|
}
|
73
|
+
}
|
78
74
|
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
75
|
+
window.addEventListener('message', handleMessage);
|
76
|
+
return () => {
|
77
|
+
window.removeEventListener('message', handleMessage);
|
78
|
+
};
|
79
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
80
|
+
}, [onClick, dataId, targetIframeRef?.current]);
|
85
81
|
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
});
|
91
|
-
// HACK: 如果目标 bridge 1s 内没有初始化,则认为目标 bridge 不兼容,不进行后续内容的加载
|
92
|
-
setTimeout(() => {
|
93
|
-
if (currentState.hasInited === undefined) {
|
94
|
-
currentState.hasInited = false;
|
95
|
-
}
|
96
|
-
}, 1000);
|
97
|
-
onLoad();
|
82
|
+
const handleLoad = useMemoizedFn(() => {
|
83
|
+
callIframe(targetIframeRef.current as HTMLIFrameElement, 'hasStorageAccess').then(({ value }) => {
|
84
|
+
currentState.hasStorageAccess = value;
|
85
|
+
currentState.hasInited = true;
|
98
86
|
});
|
87
|
+
// HACK: 如果目标 bridge 1s 内没有初始化,则认为目标 bridge 不兼容,不进行后续内容的加载
|
88
|
+
setTimeout(() => {
|
89
|
+
if (currentState.hasInited === undefined) {
|
90
|
+
currentState.hasInited = false;
|
91
|
+
}
|
92
|
+
}, 1000);
|
93
|
+
onLoad();
|
94
|
+
});
|
99
95
|
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
);
|
96
|
+
useImperativeHandle(ref, () => ({
|
97
|
+
callIframe(action: string) {
|
98
|
+
return callIframe(targetIframeRef.current as HTMLIFrameElement, action);
|
99
|
+
},
|
100
|
+
}));
|
101
|
+
return (
|
102
|
+
<Box
|
103
|
+
{...rest}
|
104
|
+
component="iframe"
|
105
|
+
ref={targetIframeRef}
|
106
|
+
onLoad={handleLoad}
|
107
|
+
data-id={dataId}
|
108
|
+
src={withQuery(src, { id: dataId })}
|
109
|
+
sx={mergeSx(
|
110
|
+
{
|
111
|
+
border: 0,
|
112
|
+
position: 'absolute',
|
113
|
+
top: 0,
|
114
|
+
left: 0,
|
115
|
+
width: '100%',
|
116
|
+
height: '100%',
|
117
|
+
cursor: 'pointer',
|
118
|
+
backgroundColor: 'transparent',
|
119
|
+
},
|
120
|
+
sx
|
121
|
+
)}
|
122
|
+
/>
|
123
|
+
);
|
124
|
+
}
|
130
125
|
|
131
126
|
export default memo(SharedBridge);
|