@arcblock/ux 2.9.91 → 2.10.1
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/index.js +36 -48
- package/lib/ActivityIndicator/index.js +122 -75
- package/lib/Address/compact-text.js +48 -66
- package/lib/Address/did-address.js +114 -87
- package/lib/Address/index.js +15 -27
- package/lib/Address/responsive-did-address.js +48 -50
- package/lib/Alert/index.js +58 -52
- package/lib/AnimationWaiter/index.js +123 -69
- package/lib/Async/index.js +8 -22
- package/lib/Avatar/did-motif.js +38 -52
- package/lib/Avatar/etherscan-blockies.js +4 -10
- package/lib/Avatar/index.js +71 -77
- package/lib/Badge/index.js +49 -56
- package/lib/Blocklet/blocklet.js +181 -97
- package/lib/Blocklet/index.js +4 -24
- package/lib/Blocklet/utils.js +50 -13
- package/lib/BlockletContext/index.js +21 -31
- package/lib/BlockletNFT/index.js +255 -115
- package/lib/Button/index.js +5 -11
- package/lib/Button/wrap.js +45 -56
- package/lib/ButtonGroup/index.js +3 -9
- package/lib/CardSelector/index.js +67 -43
- package/lib/Center/index.js +19 -20
- package/lib/ClickToCopy/copy-button.js +37 -50
- package/lib/ClickToCopy/hook.js +10 -18
- package/lib/ClickToCopy/index.js +54 -66
- package/lib/CodeBlock/LightBox.js +84 -11
- package/lib/CodeBlock/index.js +175 -101
- package/lib/Colors/index.js +3 -20
- package/lib/Colors/themes/default.js +1 -7
- package/lib/Colors/themes/temp.js +1 -7
- package/lib/ContactForm/index.js +95 -60
- package/lib/CookieConsent/index.js +58 -52
- package/lib/CountDown/index.js +90 -59
- package/lib/DID/index.js +80 -96
- package/lib/Datatable/CustomToolbar.js +188 -137
- package/lib/Datatable/DatatableContext.js +14 -21
- package/lib/Datatable/TableSearch.js +99 -58
- package/lib/Datatable/index.js +312 -139
- package/lib/Datatable/utils.js +9 -17
- package/lib/Dialog/confirm.js +46 -58
- package/lib/Dialog/dialog.js +110 -66
- package/lib/Dialog/index.js +4 -27
- package/lib/Dialog/use-confirm.js +40 -65
- package/lib/DidLogo/index.js +14 -22
- package/lib/DriftBot/index.js +34 -19
- package/lib/Earth/index.js +214 -110
- package/lib/Earth/util.js +6 -19
- package/lib/Empty/index.js +33 -38
- package/lib/ErrorBoundary/fallback.js +45 -43
- package/lib/ErrorBoundary/index.js +1 -16
- package/lib/Footer/index.js +96 -48
- package/lib/Header/auto-hidden.js +28 -31
- package/lib/Header/header.js +151 -69
- package/lib/Header/index.js +2 -20
- package/lib/Header/responsive-header.js +67 -60
- package/lib/Icon/image.js +41 -45
- package/lib/Icon/index.js +51 -53
- package/lib/Img/index.js +77 -88
- package/lib/InfoRow/index.js +66 -48
- package/lib/Layout/dashboard/external-link.js +38 -53
- package/lib/Layout/dashboard/full-page.js +27 -41
- package/lib/Layout/dashboard/index.js +177 -132
- package/lib/Layout/dashboard/sidebar.js +164 -61
- package/lib/Layout/dashboard-legacy/header.js +119 -66
- package/lib/Layout/dashboard-legacy/index.js +90 -79
- package/lib/Layout/dashboard-legacy/sidebar.js +95 -62
- package/lib/Layout/index.js +200 -106
- package/lib/LoadingMask/index.js +31 -38
- package/lib/Locale/browser-lang.js +2 -8
- package/lib/Locale/context.js +46 -69
- package/lib/Locale/languages.js +6 -15
- package/lib/Locale/selector.js +116 -92
- package/lib/Locale/util.js +7 -16
- package/lib/Logo/index.js +54 -57
- package/lib/Metric/index.js +103 -40
- package/lib/NFTDisplay/aspect-ratio-container.js +33 -40
- package/lib/NFTDisplay/broken.js +68 -52
- package/lib/NFTDisplay/index.js +140 -129
- package/lib/NFTDisplay/loading.js +14 -13
- package/lib/NFTDisplay/svg-embedder/img.js +18 -33
- package/lib/NFTDisplay/svg-embedder/inline-svg.js +28 -32
- package/lib/NavMenu/index.js +2 -13
- package/lib/NavMenu/nav-menu.js +133 -148
- package/lib/NavMenu/style.js +179 -12
- package/lib/PageScroller/index.js +82 -93
- package/lib/PageScroller/story/FifthComponent.js +4 -10
- package/lib/PageScroller/story/FirstComponent.js +4 -10
- package/lib/PageScroller/story/FourthComponent.js +4 -10
- package/lib/PageScroller/story/FullPage.js +21 -28
- package/lib/PageScroller/story/PageContain.js +23 -30
- package/lib/PageScroller/story/SecondComponent.js +4 -10
- package/lib/PageScroller/story/ThirdComponent.js +4 -10
- package/lib/PageScroller/usePrevValue.js +4 -11
- package/lib/Passport/index.js +2 -9
- package/lib/Passport/passport.js +38 -51
- package/lib/PoweredByArcBlock/index.js +19 -33
- package/lib/PricingTable/PricingPlan.js +90 -34
- package/lib/PricingTable/index.js +28 -26
- package/lib/QRCode/index.js +38 -50
- package/lib/RelativeTime/index.js +44 -59
- package/lib/Result/common.js +85 -107
- package/lib/Result/index.js +22 -34
- package/lib/Result/result.js +35 -41
- package/lib/Result/translations.js +1 -7
- package/lib/Screenshot/BaseScreenshot/index.js +65 -43
- package/lib/Screenshot/BaseScreenshot/shells/Macbook.js +17 -27
- package/lib/Screenshot/BaseScreenshot/shells/Phone.js +14 -25
- package/lib/Screenshot/index.js +103 -92
- package/lib/SessionBlocklet/index.js +125 -143
- package/lib/SessionManager/index.js +2 -9
- package/lib/SessionPermission/index.js +13 -23
- package/lib/SessionUser/components/logged-in.js +139 -158
- package/lib/SessionUser/components/session-user-item.js +44 -58
- package/lib/SessionUser/components/session-user-switch.js +133 -152
- package/lib/SessionUser/components/un-login.js +27 -35
- package/lib/SessionUser/components/user-info.js +62 -74
- package/lib/SessionUser/index.js +26 -34
- package/lib/SessionUser/libs/translation.js +1 -7
- package/lib/SessionUser/libs/utils.js +13 -34
- package/lib/Sparkline/index.js +4 -10
- package/lib/Spinner/index.js +11 -17
- package/lib/SplitButton/index.js +72 -68
- package/lib/Success/index.js +28 -34
- package/lib/Switch/index.js +64 -75
- package/lib/Tabs/index.js +84 -103
- package/lib/Tag/index.js +52 -56
- package/lib/TextCollapse/index.js +57 -50
- package/lib/Theme/index.js +8 -47
- package/lib/Theme/theme-provider.js +19 -26
- package/lib/Theme/theme.js +49 -62
- package/lib/Toast/index.js +41 -73
- package/lib/Typography/index.js +44 -55
- package/lib/Util/constant.js +16 -22
- package/lib/Util/deprecate.js +14 -26
- package/lib/Util/federated.js +16 -38
- package/lib/Util/index.js +63 -113
- package/lib/Util/passport.js +23 -33
- package/lib/Util/wallet.js +5 -14
- package/lib/Video/index.js +34 -34
- package/lib/Wallet/Action.js +72 -49
- package/lib/Wallet/Download.js +132 -115
- package/lib/Wallet/Open.js +26 -25
- package/lib/WalletOSIcon/index.js +33 -42
- package/lib/WebWalletSWKeeper/index.js +42 -55
- package/lib/WechatPrompt/index.js +53 -33
- package/lib/index.js +38 -265
- package/lib/withTheme/index.js +53 -33
- package/lib/withTracker/error_boundary.js +7 -18
- package/lib/withTracker/index.js +25 -34
- package/package.json +9 -316
- package/src/WalletOSIcon/index.jsx +1 -1
- package/es/ActionButton/index.js +0 -99
- package/es/ActivityIndicator/index.js +0 -180
- package/es/Address/compact-text.js +0 -105
- package/es/Address/did-address.js +0 -222
- package/es/Address/index.js +0 -23
- package/es/Address/responsive-did-address.js +0 -87
- package/es/Alert/index.js +0 -134
- package/es/AnimationWaiter/default-animation.json +0 -1
- package/es/AnimationWaiter/index.js +0 -240
- package/es/Async/index.js +0 -38
- package/es/Avatar/did-motif.js +0 -68
- package/es/Avatar/etherscan-blockies.js +0 -83
- package/es/Avatar/index.js +0 -179
- package/es/Badge/index.js +0 -98
- package/es/Blocklet/blocklet.js +0 -298
- package/es/Blocklet/index.js +0 -4
- package/es/Blocklet/utils.js +0 -52
- package/es/BlockletContext/index.js +0 -65
- package/es/BlockletNFT/index.js +0 -412
- package/es/Button/index.js +0 -8
- package/es/Button/wrap.js +0 -140
- package/es/ButtonGroup/index.js +0 -6
- package/es/CardSelector/index.js +0 -149
- package/es/Center/index.js +0 -41
- package/es/ClickToCopy/copy-button.js +0 -72
- package/es/ClickToCopy/hook.js +0 -39
- package/es/ClickToCopy/index.js +0 -92
- package/es/CodeBlock/LightBox.js +0 -85
- package/es/CodeBlock/index.js +0 -222
- package/es/Colors/index.js +0 -3
- package/es/Colors/themes/default.js +0 -77
- package/es/Colors/themes/temp.js +0 -41
- package/es/ContactForm/index.js +0 -230
- package/es/CookieConsent/index.js +0 -113
- package/es/CountDown/index.js +0 -178
- package/es/DID/index.js +0 -249
- package/es/Datatable/CustomToolbar.js +0 -396
- package/es/Datatable/DatatableContext.js +0 -34
- package/es/Datatable/TableSearch.js +0 -166
- package/es/Datatable/index.js +0 -629
- package/es/Datatable/utils.js +0 -132
- package/es/Dialog/confirm.js +0 -123
- package/es/Dialog/dialog.js +0 -201
- package/es/Dialog/index.js +0 -4
- package/es/Dialog/types.d.ts +0 -17
- package/es/Dialog/use-confirm.js +0 -133
- package/es/DidLogo/index.js +0 -31
- package/es/DriftBot/index.js +0 -70
- package/es/Earth/countries.json +0 -8057
- package/es/Earth/index.js +0 -521
- package/es/Earth/util.js +0 -51
- package/es/Empty/index.js +0 -65
- package/es/ErrorBoundary/fallback.js +0 -73
- package/es/ErrorBoundary/index.js +0 -1
- package/es/Footer/index.js +0 -172
- package/es/Header/auto-hidden.js +0 -35
- package/es/Header/header.js +0 -223
- package/es/Header/index.js +0 -2
- package/es/Header/responsive-header.js +0 -146
- package/es/Icon/image.js +0 -65
- package/es/Icon/index.js +0 -84
- package/es/Img/index.js +0 -218
- package/es/InfoRow/index.js +0 -87
- package/es/Layout/dashboard/external-link.js +0 -58
- package/es/Layout/dashboard/full-page.js +0 -53
- package/es/Layout/dashboard/index.js +0 -282
- package/es/Layout/dashboard/sidebar.js +0 -209
- package/es/Layout/dashboard-legacy/header.js +0 -174
- package/es/Layout/dashboard-legacy/index.js +0 -148
- package/es/Layout/dashboard-legacy/sidebar.js +0 -129
- package/es/Layout/index.js +0 -335
- package/es/LoadingMask/index.js +0 -102
- package/es/Locale/browser-lang.js +0 -52
- package/es/Locale/context.js +0 -139
- package/es/Locale/languages.js +0 -60
- package/es/Locale/selector.js +0 -186
- package/es/Locale/util.js +0 -21
- package/es/Logo/images/logo-dark-text.svg +0 -3
- package/es/Logo/images/logo-dark-top.svg +0 -6
- package/es/Logo/images/logo-light-text.svg +0 -3
- package/es/Logo/images/logo-light-top.svg +0 -6
- package/es/Logo/index.js +0 -136
- package/es/Metric/index.js +0 -132
- package/es/NFTDisplay/NFTBroken.svg +0 -34
- package/es/NFTDisplay/README.md +0 -59
- package/es/NFTDisplay/aspect-ratio-container.js +0 -39
- package/es/NFTDisplay/broken.js +0 -132
- package/es/NFTDisplay/demo/data/asset-state-display-url.json +0 -7
- package/es/NFTDisplay/demo/data/asset-state-gzipped-svg-1-1.json +0 -10
- package/es/NFTDisplay/demo/data/asset-state-gzipped-svg-374-130.json +0 -10
- package/es/NFTDisplay/demo/data/asset-state-gzipped-svg-with-foreign-object.json +0 -20
- package/es/NFTDisplay/demo/data/asset-state-svg.json +0 -29
- package/es/NFTDisplay/demo/data/asset-state-url.json +0 -10
- package/es/NFTDisplay/index.js +0 -328
- package/es/NFTDisplay/loading.js +0 -18
- package/es/NFTDisplay/svg-embedder/img.js +0 -45
- package/es/NFTDisplay/svg-embedder/inline-svg.js +0 -39
- package/es/NavMenu/index.js +0 -2
- package/es/NavMenu/nav-menu.js +0 -358
- package/es/NavMenu/style.js +0 -181
- package/es/PageScroller/index.js +0 -286
- package/es/PageScroller/story/FifthComponent.js +0 -9
- package/es/PageScroller/story/FirstComponent.js +0 -9
- package/es/PageScroller/story/FourthComponent.js +0 -12
- package/es/PageScroller/story/FullPage.js +0 -47
- package/es/PageScroller/story/PageContain.js +0 -59
- package/es/PageScroller/story/SecondComponent.js +0 -9
- package/es/PageScroller/story/ThirdComponent.js +0 -9
- package/es/PageScroller/story/index.css +0 -115
- package/es/PageScroller/usePrevValue.js +0 -9
- package/es/Passport/index.js +0 -2
- package/es/Passport/passport.js +0 -103
- package/es/PoweredByArcBlock/index.js +0 -31
- package/es/PricingTable/PricingPlan.js +0 -124
- package/es/PricingTable/index.js +0 -53
- package/es/QRCode/index.js +0 -73
- package/es/RelativeTime/index.js +0 -107
- package/es/Result/common.js +0 -140
- package/es/Result/demo/fixtures/result-image-404.svg +0 -1
- package/es/Result/index.js +0 -33
- package/es/Result/result.js +0 -59
- package/es/Result/translations.js +0 -54
- package/es/Screenshot/BaseScreenshot/index.js +0 -91
- package/es/Screenshot/BaseScreenshot/shells/Macbook.js +0 -51
- package/es/Screenshot/BaseScreenshot/shells/Phone.js +0 -36
- package/es/Screenshot/demo/images/bg-00.jpg +0 -0
- package/es/Screenshot/demo/images/bg-01.jpg +0 -0
- package/es/Screenshot/demo/images/bg-02.jpg +0 -0
- package/es/Screenshot/demo/images/bg-03.jpg +0 -0
- package/es/Screenshot/demo/images/bg-04.jpg +0 -0
- package/es/Screenshot/demo/images/bg-05.jpg +0 -0
- package/es/Screenshot/demo/images/bg-06.jpg +0 -0
- package/es/Screenshot/demo/images/bg-07.jpg +0 -0
- package/es/Screenshot/demo/images/bg-08.jpg +0 -0
- package/es/Screenshot/demo/images/bg-09.jpg +0 -0
- package/es/Screenshot/devices.css +0 -1366
- package/es/Screenshot/index.js +0 -299
- package/es/SessionBlocklet/index.js +0 -173
- package/es/SessionManager/index.js +0 -2
- package/es/SessionPermission/index.js +0 -28
- package/es/SessionUser/components/logged-in.js +0 -229
- package/es/SessionUser/components/session-user-item.js +0 -102
- package/es/SessionUser/components/session-user-switch.js +0 -223
- package/es/SessionUser/components/un-login.js +0 -64
- package/es/SessionUser/components/user-info.js +0 -167
- package/es/SessionUser/index.js +0 -49
- package/es/SessionUser/libs/translation.js +0 -19
- package/es/SessionUser/libs/utils.js +0 -29
- package/es/Sparkline/index.js +0 -193
- package/es/Spinner/index.js +0 -28
- package/es/SplitButton/index.js +0 -145
- package/es/Success/index.js +0 -175
- package/es/Switch/index.js +0 -96
- package/es/Tabs/index.js +0 -214
- package/es/Tag/index.js +0 -108
- package/es/TextCollapse/index.js +0 -92
- package/es/Theme/index.js +0 -16
- package/es/Theme/theme-provider.js +0 -39
- package/es/Theme/theme.js +0 -145
- package/es/Toast/index.js +0 -97
- package/es/Typography/index.js +0 -95
- package/es/Util/constant.js +0 -42
- package/es/Util/deprecate.js +0 -28
- package/es/Util/federated.js +0 -91
- package/es/Util/index.js +0 -363
- package/es/Util/passport.js +0 -62
- package/es/Util/wallet.js +0 -32
- package/es/Video/index.js +0 -89
- package/es/Wallet/Action.js +0 -119
- package/es/Wallet/Download.js +0 -331
- package/es/Wallet/Open.js +0 -45
- package/es/Wallet/images/abtwallet.png +0 -0
- package/es/Wallet/images/android_download.svg +0 -23
- package/es/Wallet/images/app-store.svg +0 -20
- package/es/Wallet/images/google-play.svg +0 -70
- package/es/WalletOSIcon/index.js +0 -82
- package/es/WebWalletSWKeeper/index.js +0 -117
- package/es/WechatPrompt/images/android.png +0 -0
- package/es/WechatPrompt/images/ios.png +0 -0
- package/es/WechatPrompt/index.js +0 -88
- package/es/index.js +0 -38
- package/es/withTheme/index.js +0 -69
- package/es/withTracker/README.md +0 -34
- package/es/withTracker/error_boundary.js +0 -34
- package/es/withTracker/index.js +0 -55
@@ -1,117 +0,0 @@
|
|
1
|
-
import { useEffect, useRef } from 'react';
|
2
|
-
import PropTypes from 'prop-types';
|
3
|
-
import useIdle from 'react-use/lib/useIdle';
|
4
|
-
import { useLocalStorageState } from 'ahooks';
|
5
|
-
import useBrowser from '@arcblock/react-hooks/lib/useBrowser';
|
6
|
-
import { detectWalletExtension } from '@arcblock/ux/lib/Util';
|
7
|
-
import { getWebWalletUrl, checkSameProtocol } from '../Util/wallet';
|
8
|
-
|
9
|
-
// 默认最大空闲时间: 30min
|
10
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
11
|
-
import { Fragment as _Fragment } from "react/jsx-runtime";
|
12
|
-
import { jsxs as _jsxs } from "react/jsx-runtime";
|
13
|
-
const DEFAULT_MAX_IDLE_TIME = 1000 * 60 * 30;
|
14
|
-
// 可使用 localStorage.setItem('wallet_sw_keeper_disabled', 1) 来禁用嵌入 wallet iframe
|
15
|
-
const STORAGE_KEY_DISABLED = 'wallet_sw_keeper_disabled';
|
16
|
-
// iframe id, 如果存在多个 WebWalletSWKeeper 组件实例, 共享此 id, 保证只有一个 iframe
|
17
|
-
let id;
|
18
|
-
const injectIframe = webWalletUrl => {
|
19
|
-
const iframe = document.createElement('iframe');
|
20
|
-
iframe.title = 'abt wallet';
|
21
|
-
iframe.id = id;
|
22
|
-
iframe.style.width = 0;
|
23
|
-
iframe.style.height = 0;
|
24
|
-
iframe.style.border = 0;
|
25
|
-
// https://stackoverflow.com/questions/27858989/iframe-with-0-height-creates-a-gap
|
26
|
-
iframe.style.display = 'block';
|
27
|
-
// fix: 页面自动滚动到底部问题 (https://github.com/blocklet/abt-wallet/issues/1160)
|
28
|
-
// top: 0 可能不是必须的, 但测试中发现, 如果不设置, 在某些特殊情况下似乎也会导致页面自动滚动到底部
|
29
|
-
iframe.style.position = 'absolute';
|
30
|
-
iframe.style.top = 0;
|
31
|
-
iframe.src = `${webWalletUrl}?action=iframe`;
|
32
|
-
document.body.appendChild(iframe);
|
33
|
-
};
|
34
|
-
const removeIframe = () => {
|
35
|
-
const iframe = document.getElementById(id);
|
36
|
-
if (iframe) {
|
37
|
-
document.body.removeChild(iframe);
|
38
|
-
}
|
39
|
-
};
|
40
|
-
const cleanup = () => {
|
41
|
-
removeIframe();
|
42
|
-
id = null;
|
43
|
-
};
|
44
|
-
const enable = webWalletUrl => {
|
45
|
-
if (!id) {
|
46
|
-
id = `web_wallet_sw_keeper_${Date.now()}`;
|
47
|
-
injectIframe(webWalletUrl);
|
48
|
-
}
|
49
|
-
};
|
50
|
-
|
51
|
-
// 该组件通过嵌入一个 web wallet iframe 帮助 web wallet service worker 延最大空闲时间
|
52
|
-
function WebWalletSWKeeper({
|
53
|
-
webWalletUrl,
|
54
|
-
maxIdleTime
|
55
|
-
}) {
|
56
|
-
// 渲染前先记录是否已经存在一个 WebWalletSWKeeper 实例
|
57
|
-
const instanceExists = useRef(!!id);
|
58
|
-
const isIdle = useIdle(maxIdleTime);
|
59
|
-
// 如果已经存在一个 WebWalletSWKeeper 实例, cleanup 的时机应该由该实例控制
|
60
|
-
const _cleanup = () => {
|
61
|
-
if (!instanceExists.current) {
|
62
|
-
cleanup();
|
63
|
-
}
|
64
|
-
};
|
65
|
-
// 用户操作空闲时间超过 maxIdleTime 时禁用, 活跃时启用
|
66
|
-
useEffect(() => {
|
67
|
-
if (isIdle) {
|
68
|
-
_cleanup();
|
69
|
-
} else {
|
70
|
-
enable(webWalletUrl);
|
71
|
-
}
|
72
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
73
|
-
}, [isIdle]);
|
74
|
-
// 组件销毁时自动清理
|
75
|
-
useEffect(() => () => _cleanup(), []);
|
76
|
-
return null;
|
77
|
-
}
|
78
|
-
WebWalletSWKeeper.propTypes = {
|
79
|
-
webWalletUrl: PropTypes.string.isRequired,
|
80
|
-
maxIdleTime: PropTypes.number
|
81
|
-
};
|
82
|
-
WebWalletSWKeeper.defaultProps = {
|
83
|
-
maxIdleTime: DEFAULT_MAX_IDLE_TIME
|
84
|
-
};
|
85
|
-
export default WebWalletSWKeeper;
|
86
|
-
export const withWebWalletSWKeeper = Component => {
|
87
|
-
// eslint-disable-next-line react/prop-types
|
88
|
-
return function WithWebWalletSWKeeperComponent({
|
89
|
-
webWalletUrl,
|
90
|
-
maxIdleTime,
|
91
|
-
...rest
|
92
|
-
}) {
|
93
|
-
const browser = useBrowser();
|
94
|
-
// eslint-disable-next-line no-param-reassign
|
95
|
-
webWalletUrl = webWalletUrl || getWebWalletUrl();
|
96
|
-
const [disabled] = useLocalStorageState(STORAGE_KEY_DISABLED, {
|
97
|
-
defaultValue: 1
|
98
|
-
});
|
99
|
-
const extension = detectWalletExtension();
|
100
|
-
const isSameProtocol = checkSameProtocol(webWalletUrl);
|
101
|
-
const isWalletWebview = browser.wallet;
|
102
|
-
// 以下几种情况不会嵌入 wallet iframe :
|
103
|
-
// - 通过设置 localStorage#wallet_sw_keeper_disabled = 1 明确禁止 (开发调试过程中可以使用, 避免控制台打印一堆日志影响调试)
|
104
|
-
// - 检查到 wallet 浏览器插件
|
105
|
-
// - webWalletUrl 与当前页面 url 的 protocol 不同
|
106
|
-
// - wallet webview
|
107
|
-
return /*#__PURE__*/_jsxs(_Fragment, {
|
108
|
-
children: [!disabled && !extension && isSameProtocol && !isWalletWebview && /*#__PURE__*/_jsx(WebWalletSWKeeper, {
|
109
|
-
webWalletUrl: webWalletUrl,
|
110
|
-
maxIdleTime: maxIdleTime
|
111
|
-
}), /*#__PURE__*/_jsx(Component, {
|
112
|
-
webWalletUrl: webWalletUrl,
|
113
|
-
...rest
|
114
|
-
})]
|
115
|
-
});
|
116
|
-
};
|
117
|
-
};
|
Binary file
|
Binary file
|
package/es/WechatPrompt/index.js
DELETED
@@ -1,88 +0,0 @@
|
|
1
|
-
import Typography from '@mui/material/Typography';
|
2
|
-
import Dialog from '@mui/material/Dialog';
|
3
|
-
import useBrowser from '@arcblock/react-hooks/lib/useBrowser';
|
4
|
-
import IosImage from './images/ios.png';
|
5
|
-
import AndroidImage from './images/android.png';
|
6
|
-
import { styled } from '../Theme';
|
7
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
8
|
-
import { jsxs as _jsxs } from "react/jsx-runtime";
|
9
|
-
export default function WechatPrompt() {
|
10
|
-
const browser = useBrowser();
|
11
|
-
if (!browser.mobile.any) {
|
12
|
-
return null;
|
13
|
-
}
|
14
|
-
if (!browser.wechat) {
|
15
|
-
return null;
|
16
|
-
}
|
17
|
-
if (browser.android) {
|
18
|
-
return /*#__PURE__*/_jsx(Dialog, {
|
19
|
-
open: true,
|
20
|
-
fullScreen: true,
|
21
|
-
children: /*#__PURE__*/_jsxs(Container, {
|
22
|
-
children: [/*#__PURE__*/_jsx(Typography, {
|
23
|
-
className: "wechat-title",
|
24
|
-
children: "1. \u8F7B\u89E6\u53F3\u4E0A\u65B9\u83DC\u5355"
|
25
|
-
}), /*#__PURE__*/_jsxs("div", {
|
26
|
-
className: "wechat-tip",
|
27
|
-
children: [/*#__PURE__*/_jsx(Typography, {
|
28
|
-
className: "wechat-tip-text",
|
29
|
-
children: "2. \u70B9\u51FB\u201C\u5728\u6D4F\u89C8\u5668\u6253\u5F00\u201D\uFF0C\u624D\u80FD\u8C03\u8D77 DID \u94B1\u5305"
|
30
|
-
}), /*#__PURE__*/_jsx("img", {
|
31
|
-
className: "wechat-tip-img",
|
32
|
-
src: AndroidImage,
|
33
|
-
alt: "Open in Android Browser"
|
34
|
-
})]
|
35
|
-
})]
|
36
|
-
})
|
37
|
-
});
|
38
|
-
}
|
39
|
-
return /*#__PURE__*/_jsx(Dialog, {
|
40
|
-
open: true,
|
41
|
-
fullScreen: true,
|
42
|
-
children: /*#__PURE__*/_jsxs(Container, {
|
43
|
-
children: [/*#__PURE__*/_jsx(Typography, {
|
44
|
-
className: "wechat-title",
|
45
|
-
children: "1. \u8F7B\u89E6\u53F3\u4E0A\u65B9\u83DC\u5355"
|
46
|
-
}), /*#__PURE__*/_jsxs("div", {
|
47
|
-
className: "wechat-tip",
|
48
|
-
children: [/*#__PURE__*/_jsx(Typography, {
|
49
|
-
className: "wechat-tip-text",
|
50
|
-
children: "2. \u70B9\u51FB\u201C\u5728Safari\u4E2D\u6253\u5F00\u201D\uFF0C\u624D\u80FD\u8C03\u8D77 DID \u94B1\u5305"
|
51
|
-
}), /*#__PURE__*/_jsx("img", {
|
52
|
-
className: "wechat-tip-img",
|
53
|
-
src: IosImage,
|
54
|
-
alt: "Open in Safari"
|
55
|
-
})]
|
56
|
-
})]
|
57
|
-
})
|
58
|
-
});
|
59
|
-
}
|
60
|
-
const Container = styled('div')`
|
61
|
-
.wechat-title {
|
62
|
-
height: 80px;
|
63
|
-
line-height: 80px;
|
64
|
-
text-align: center;
|
65
|
-
font-size: 20px;
|
66
|
-
color: #fff;
|
67
|
-
background-color: #9cdbd8;
|
68
|
-
}
|
69
|
-
|
70
|
-
.wechat-tip {
|
71
|
-
display: flex;
|
72
|
-
flex-direction: column;
|
73
|
-
align-items: center;
|
74
|
-
|
75
|
-
.wechat-tip-text {
|
76
|
-
font-size: 20px;
|
77
|
-
padding: 10px 10px;
|
78
|
-
overflow: auto;
|
79
|
-
word-break: break-word;
|
80
|
-
text-align: center;
|
81
|
-
}
|
82
|
-
|
83
|
-
.wechat-tip-img {
|
84
|
-
width: 90%;
|
85
|
-
object-fit: cover;
|
86
|
-
}
|
87
|
-
}
|
88
|
-
`;
|
package/es/index.js
DELETED
@@ -1,38 +0,0 @@
|
|
1
|
-
import ActionButton from './ActionButton';
|
2
|
-
import ActivityIndicator from './ActivityIndicator';
|
3
|
-
import Address from './Address';
|
4
|
-
import Alert from './Alert';
|
5
|
-
import AnimationWaiter from './AnimationWaiter';
|
6
|
-
import Async from './Async';
|
7
|
-
import Avatar from './Avatar';
|
8
|
-
import Badge from './Badge';
|
9
|
-
import Button from './Button';
|
10
|
-
import ClickToCopy from './ClickToCopy';
|
11
|
-
import CodeBlock from './CodeBlock';
|
12
|
-
import ContactForm from './ContactForm';
|
13
|
-
import CountDown from './CountDown';
|
14
|
-
import Earth from './Earth';
|
15
|
-
import Footer from './Footer';
|
16
|
-
import Icon from './Icon';
|
17
|
-
import LocaleSelector from './Locale/selector';
|
18
|
-
import Logo from './Logo';
|
19
|
-
import RelativeTime from './RelativeTime';
|
20
|
-
import SessionManager from './SessionManager';
|
21
|
-
import Datatable from './Datatable';
|
22
|
-
import Dialog from './Dialog';
|
23
|
-
import DidLogo from './DidLogo';
|
24
|
-
import Tabs from './Tabs';
|
25
|
-
import Tag from './Tag';
|
26
|
-
import TextCollapse from './TextCollapse';
|
27
|
-
import Theme from './Theme';
|
28
|
-
import Toast from './Toast';
|
29
|
-
import Util from './Util';
|
30
|
-
import Video from './Video';
|
31
|
-
import WebWalletSWKeeper from './WebWalletSWKeeper';
|
32
|
-
import WalletAction from './Wallet/Action';
|
33
|
-
import WalletDownload from './Wallet/Download';
|
34
|
-
import WechatPrompt from './WechatPrompt';
|
35
|
-
import withTheme from './withTheme';
|
36
|
-
import withTracker from './withTracker';
|
37
|
-
import Img from './Img';
|
38
|
-
export { ActionButton, ActivityIndicator, Address, Alert, AnimationWaiter, Async, Avatar, Badge, Button, ClickToCopy, CodeBlock, ContactForm, CountDown, Earth, Footer, Icon, LocaleSelector, Logo, Tabs, RelativeTime, SessionManager, Datatable, Dialog, DidLogo, Tag, TextCollapse, Theme, Toast, Util, Video, WebWalletSWKeeper, WalletAction, WalletDownload, WechatPrompt, withTheme, withTracker, Img };
|
package/es/withTheme/index.js
DELETED
@@ -1,69 +0,0 @@
|
|
1
|
-
import { useEffect } from 'react';
|
2
|
-
import { Global, css } from '@emotion/react';
|
3
|
-
import CssBaseline from '@mui/material/CssBaseline';
|
4
|
-
import { createTheme, ThemeProvider } from '../Theme';
|
5
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
6
|
-
import { jsxs as _jsxs } from "react/jsx-runtime";
|
7
|
-
function withTheme(Component, {
|
8
|
-
mode = 'light',
|
9
|
-
pageWidth = 'md',
|
10
|
-
palette,
|
11
|
-
typography
|
12
|
-
} = {}) {
|
13
|
-
const theme = createTheme({
|
14
|
-
mode,
|
15
|
-
pageWidth,
|
16
|
-
palette,
|
17
|
-
typography
|
18
|
-
});
|
19
|
-
const globalStyles = css`
|
20
|
-
font-family: ${theme.typography.fontFamily};
|
21
|
-
color: ${theme.typography.color.main};
|
22
|
-
|
23
|
-
a,
|
24
|
-
a:hover,
|
25
|
-
a:active {
|
26
|
-
text-decoration: none;
|
27
|
-
color: ${theme.palette.primary.dark};
|
28
|
-
}
|
29
|
-
|
30
|
-
a:hover {
|
31
|
-
color: ${theme.palette.primary.main};
|
32
|
-
}
|
33
|
-
|
34
|
-
.section--latest-post {
|
35
|
-
p:last-of-type {
|
36
|
-
margin: 0;
|
37
|
-
}
|
38
|
-
}
|
39
|
-
|
40
|
-
.has-scrolled {
|
41
|
-
.section--footnotes {
|
42
|
-
position: static !important;
|
43
|
-
transition-property: background-color;
|
44
|
-
transition-duration: 600ms;
|
45
|
-
transition-timing-function: ease;
|
46
|
-
.footnote__title {
|
47
|
-
color: #fff;
|
48
|
-
}
|
49
|
-
}
|
50
|
-
}
|
51
|
-
`;
|
52
|
-
return function WithTheme(props) {
|
53
|
-
useEffect(() => {
|
54
|
-
const jssStyles = document.querySelector('#jss-server-side');
|
55
|
-
if (jssStyles && jssStyles.parentNode) {
|
56
|
-
jssStyles.parentNode.removeChild(jssStyles);
|
57
|
-
}
|
58
|
-
}, []);
|
59
|
-
return /*#__PURE__*/_jsxs(ThemeProvider, {
|
60
|
-
theme: theme,
|
61
|
-
children: [/*#__PURE__*/_jsx(CssBaseline, {}), /*#__PURE__*/_jsx(Global, {
|
62
|
-
styles: globalStyles
|
63
|
-
}), /*#__PURE__*/_jsx(Component, {
|
64
|
-
...props
|
65
|
-
})]
|
66
|
-
});
|
67
|
-
};
|
68
|
-
}
|
69
|
-
export default withTheme;
|
package/es/withTracker/README.md
DELETED
@@ -1,34 +0,0 @@
|
|
1
|
-
# withTracker
|
2
|
-
|
3
|
-
Add arcblock analytics, google analytics and sentry error reporting to your application.
|
4
|
-
|
5
|
-
## Usage
|
6
|
-
|
7
|
-
### Installation
|
8
|
-
|
9
|
-
```bash
|
10
|
-
yarn add react-ga @arcblock/analytics-js @sentry/browser @arcblock/ux
|
11
|
-
```
|
12
|
-
|
13
|
-
### Configuration & Usage
|
14
|
-
|
15
|
-
In your application entry file
|
16
|
-
|
17
|
-
```javascript
|
18
|
-
import React from 'react';
|
19
|
-
import ReactDOM from 'react-dom';
|
20
|
-
import withTracker from '@arcblock/ux/lib/withTracker';
|
21
|
-
|
22
|
-
function App() {
|
23
|
-
return <p>My awesome application</p>;
|
24
|
-
}
|
25
|
-
|
26
|
-
const Wrapped = withTracker(App, {
|
27
|
-
appName: 'my-awesome-app',
|
28
|
-
appVersion: '0.1.0',
|
29
|
-
gaAccount: '',
|
30
|
-
sentryDSN: '',
|
31
|
-
});
|
32
|
-
|
33
|
-
ReactDOM.render(<Wrapped />, document.getElementById('root'));
|
34
|
-
```
|
@@ -1,34 +0,0 @@
|
|
1
|
-
/* eslint-disable import/no-unresolved */
|
2
|
-
import { Component } from 'react';
|
3
|
-
import * as Sentry from '@sentry/browser';
|
4
|
-
import Alert from '../Alert';
|
5
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
6
|
-
export default class ErrorBoundary extends Component {
|
7
|
-
constructor(props) {
|
8
|
-
super(props);
|
9
|
-
this.state = {
|
10
|
-
error: null
|
11
|
-
};
|
12
|
-
}
|
13
|
-
componentDidCatch(error, info) {
|
14
|
-
this.setState({
|
15
|
-
error
|
16
|
-
});
|
17
|
-
Sentry.withScope(scope => {
|
18
|
-
scope.setExtras(info);
|
19
|
-
Sentry.captureException(error);
|
20
|
-
});
|
21
|
-
}
|
22
|
-
render() {
|
23
|
-
if (this.state.error) {
|
24
|
-
return /*#__PURE__*/_jsx(Alert, {
|
25
|
-
type: "error",
|
26
|
-
variant: "icon",
|
27
|
-
children: "Oops! We encountered an error, please try reload this application."
|
28
|
-
});
|
29
|
-
}
|
30
|
-
|
31
|
-
// eslint-disable-next-line react/prop-types
|
32
|
-
return this.props.children;
|
33
|
-
}
|
34
|
-
}
|
package/es/withTracker/index.js
DELETED
@@ -1,55 +0,0 @@
|
|
1
|
-
/* eslint-disable import/no-unresolved */
|
2
|
-
import ReactGA from 'react-ga';
|
3
|
-
import * as Sentry from '@sentry/browser';
|
4
|
-
import { useMount, useDeepCompareEffect } from 'ahooks';
|
5
|
-
import { useLocation } from 'react-router-dom';
|
6
|
-
import ErrorBoundary from './error_boundary';
|
7
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
8
|
-
export default ((WrappedComponent, options = {}) => {
|
9
|
-
const {
|
10
|
-
appVersion,
|
11
|
-
gaAccount,
|
12
|
-
sentryDSN
|
13
|
-
} = options;
|
14
|
-
if (gaAccount) {
|
15
|
-
ReactGA.initialize(gaAccount);
|
16
|
-
}
|
17
|
-
if (sentryDSN) {
|
18
|
-
Sentry.init({
|
19
|
-
dsn: sentryDSN,
|
20
|
-
release: appVersion || 'unknown',
|
21
|
-
environment: process.env.NODE_ENV || 'development'
|
22
|
-
});
|
23
|
-
}
|
24
|
-
const trackPage = page => {
|
25
|
-
if (!process.env.NODE_ENV || process.env.NODE_ENV === 'development') {
|
26
|
-
return;
|
27
|
-
}
|
28
|
-
if (gaAccount) {
|
29
|
-
ReactGA.set({
|
30
|
-
page,
|
31
|
-
...options
|
32
|
-
});
|
33
|
-
ReactGA.pageview(page);
|
34
|
-
}
|
35
|
-
};
|
36
|
-
return function TrackedComponent(props) {
|
37
|
-
const location = useLocation();
|
38
|
-
useMount(() => {
|
39
|
-
trackPage(location.pathname);
|
40
|
-
});
|
41
|
-
useDeepCompareEffect(() => {
|
42
|
-
trackPage(location.pathname);
|
43
|
-
}, [location.pathname]);
|
44
|
-
if (process.env.NODE_ENV === 'production') {
|
45
|
-
return /*#__PURE__*/_jsx(ErrorBoundary, {
|
46
|
-
children: /*#__PURE__*/_jsx(WrappedComponent, {
|
47
|
-
...props
|
48
|
-
})
|
49
|
-
});
|
50
|
-
}
|
51
|
-
return /*#__PURE__*/_jsx(WrappedComponent, {
|
52
|
-
...props
|
53
|
-
});
|
54
|
-
};
|
55
|
-
});
|