@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.
Files changed (337) hide show
  1. package/lib/ActionButton/index.js +36 -48
  2. package/lib/ActivityIndicator/index.js +122 -75
  3. package/lib/Address/compact-text.js +48 -66
  4. package/lib/Address/did-address.js +114 -87
  5. package/lib/Address/index.js +15 -27
  6. package/lib/Address/responsive-did-address.js +48 -50
  7. package/lib/Alert/index.js +58 -52
  8. package/lib/AnimationWaiter/index.js +123 -69
  9. package/lib/Async/index.js +8 -22
  10. package/lib/Avatar/did-motif.js +38 -52
  11. package/lib/Avatar/etherscan-blockies.js +4 -10
  12. package/lib/Avatar/index.js +71 -77
  13. package/lib/Badge/index.js +49 -56
  14. package/lib/Blocklet/blocklet.js +181 -97
  15. package/lib/Blocklet/index.js +4 -24
  16. package/lib/Blocklet/utils.js +50 -13
  17. package/lib/BlockletContext/index.js +21 -31
  18. package/lib/BlockletNFT/index.js +255 -115
  19. package/lib/Button/index.js +5 -11
  20. package/lib/Button/wrap.js +45 -56
  21. package/lib/ButtonGroup/index.js +3 -9
  22. package/lib/CardSelector/index.js +67 -43
  23. package/lib/Center/index.js +19 -20
  24. package/lib/ClickToCopy/copy-button.js +37 -50
  25. package/lib/ClickToCopy/hook.js +10 -18
  26. package/lib/ClickToCopy/index.js +54 -66
  27. package/lib/CodeBlock/LightBox.js +84 -11
  28. package/lib/CodeBlock/index.js +175 -101
  29. package/lib/Colors/index.js +3 -20
  30. package/lib/Colors/themes/default.js +1 -7
  31. package/lib/Colors/themes/temp.js +1 -7
  32. package/lib/ContactForm/index.js +95 -60
  33. package/lib/CookieConsent/index.js +58 -52
  34. package/lib/CountDown/index.js +90 -59
  35. package/lib/DID/index.js +80 -96
  36. package/lib/Datatable/CustomToolbar.js +188 -137
  37. package/lib/Datatable/DatatableContext.js +14 -21
  38. package/lib/Datatable/TableSearch.js +99 -58
  39. package/lib/Datatable/index.js +312 -139
  40. package/lib/Datatable/utils.js +9 -17
  41. package/lib/Dialog/confirm.js +46 -58
  42. package/lib/Dialog/dialog.js +110 -66
  43. package/lib/Dialog/index.js +4 -27
  44. package/lib/Dialog/use-confirm.js +40 -65
  45. package/lib/DidLogo/index.js +14 -22
  46. package/lib/DriftBot/index.js +34 -19
  47. package/lib/Earth/index.js +214 -110
  48. package/lib/Earth/util.js +6 -19
  49. package/lib/Empty/index.js +33 -38
  50. package/lib/ErrorBoundary/fallback.js +45 -43
  51. package/lib/ErrorBoundary/index.js +1 -16
  52. package/lib/Footer/index.js +96 -48
  53. package/lib/Header/auto-hidden.js +28 -31
  54. package/lib/Header/header.js +151 -69
  55. package/lib/Header/index.js +2 -20
  56. package/lib/Header/responsive-header.js +67 -60
  57. package/lib/Icon/image.js +41 -45
  58. package/lib/Icon/index.js +51 -53
  59. package/lib/Img/index.js +77 -88
  60. package/lib/InfoRow/index.js +66 -48
  61. package/lib/Layout/dashboard/external-link.js +38 -53
  62. package/lib/Layout/dashboard/full-page.js +27 -41
  63. package/lib/Layout/dashboard/index.js +177 -132
  64. package/lib/Layout/dashboard/sidebar.js +164 -61
  65. package/lib/Layout/dashboard-legacy/header.js +119 -66
  66. package/lib/Layout/dashboard-legacy/index.js +90 -79
  67. package/lib/Layout/dashboard-legacy/sidebar.js +95 -62
  68. package/lib/Layout/index.js +200 -106
  69. package/lib/LoadingMask/index.js +31 -38
  70. package/lib/Locale/browser-lang.js +2 -8
  71. package/lib/Locale/context.js +46 -69
  72. package/lib/Locale/languages.js +6 -15
  73. package/lib/Locale/selector.js +116 -92
  74. package/lib/Locale/util.js +7 -16
  75. package/lib/Logo/index.js +54 -57
  76. package/lib/Metric/index.js +103 -40
  77. package/lib/NFTDisplay/aspect-ratio-container.js +33 -40
  78. package/lib/NFTDisplay/broken.js +68 -52
  79. package/lib/NFTDisplay/index.js +140 -129
  80. package/lib/NFTDisplay/loading.js +14 -13
  81. package/lib/NFTDisplay/svg-embedder/img.js +18 -33
  82. package/lib/NFTDisplay/svg-embedder/inline-svg.js +28 -32
  83. package/lib/NavMenu/index.js +2 -13
  84. package/lib/NavMenu/nav-menu.js +133 -148
  85. package/lib/NavMenu/style.js +179 -12
  86. package/lib/PageScroller/index.js +82 -93
  87. package/lib/PageScroller/story/FifthComponent.js +4 -10
  88. package/lib/PageScroller/story/FirstComponent.js +4 -10
  89. package/lib/PageScroller/story/FourthComponent.js +4 -10
  90. package/lib/PageScroller/story/FullPage.js +21 -28
  91. package/lib/PageScroller/story/PageContain.js +23 -30
  92. package/lib/PageScroller/story/SecondComponent.js +4 -10
  93. package/lib/PageScroller/story/ThirdComponent.js +4 -10
  94. package/lib/PageScroller/usePrevValue.js +4 -11
  95. package/lib/Passport/index.js +2 -9
  96. package/lib/Passport/passport.js +38 -51
  97. package/lib/PoweredByArcBlock/index.js +19 -33
  98. package/lib/PricingTable/PricingPlan.js +90 -34
  99. package/lib/PricingTable/index.js +28 -26
  100. package/lib/QRCode/index.js +38 -50
  101. package/lib/RelativeTime/index.js +44 -59
  102. package/lib/Result/common.js +85 -107
  103. package/lib/Result/index.js +22 -34
  104. package/lib/Result/result.js +35 -41
  105. package/lib/Result/translations.js +1 -7
  106. package/lib/Screenshot/BaseScreenshot/index.js +65 -43
  107. package/lib/Screenshot/BaseScreenshot/shells/Macbook.js +17 -27
  108. package/lib/Screenshot/BaseScreenshot/shells/Phone.js +14 -25
  109. package/lib/Screenshot/index.js +103 -92
  110. package/lib/SessionBlocklet/index.js +125 -143
  111. package/lib/SessionManager/index.js +2 -9
  112. package/lib/SessionPermission/index.js +13 -23
  113. package/lib/SessionUser/components/logged-in.js +139 -158
  114. package/lib/SessionUser/components/session-user-item.js +44 -58
  115. package/lib/SessionUser/components/session-user-switch.js +133 -152
  116. package/lib/SessionUser/components/un-login.js +27 -35
  117. package/lib/SessionUser/components/user-info.js +62 -74
  118. package/lib/SessionUser/index.js +26 -34
  119. package/lib/SessionUser/libs/translation.js +1 -7
  120. package/lib/SessionUser/libs/utils.js +13 -34
  121. package/lib/Sparkline/index.js +4 -10
  122. package/lib/Spinner/index.js +11 -17
  123. package/lib/SplitButton/index.js +72 -68
  124. package/lib/Success/index.js +28 -34
  125. package/lib/Switch/index.js +64 -75
  126. package/lib/Tabs/index.js +84 -103
  127. package/lib/Tag/index.js +52 -56
  128. package/lib/TextCollapse/index.js +57 -50
  129. package/lib/Theme/index.js +8 -47
  130. package/lib/Theme/theme-provider.js +19 -26
  131. package/lib/Theme/theme.js +49 -62
  132. package/lib/Toast/index.js +41 -73
  133. package/lib/Typography/index.js +44 -55
  134. package/lib/Util/constant.js +16 -22
  135. package/lib/Util/deprecate.js +14 -26
  136. package/lib/Util/federated.js +16 -38
  137. package/lib/Util/index.js +63 -113
  138. package/lib/Util/passport.js +23 -33
  139. package/lib/Util/wallet.js +5 -14
  140. package/lib/Video/index.js +34 -34
  141. package/lib/Wallet/Action.js +72 -49
  142. package/lib/Wallet/Download.js +132 -115
  143. package/lib/Wallet/Open.js +26 -25
  144. package/lib/WalletOSIcon/index.js +33 -42
  145. package/lib/WebWalletSWKeeper/index.js +42 -55
  146. package/lib/WechatPrompt/index.js +53 -33
  147. package/lib/index.js +38 -265
  148. package/lib/withTheme/index.js +53 -33
  149. package/lib/withTracker/error_boundary.js +7 -18
  150. package/lib/withTracker/index.js +25 -34
  151. package/package.json +9 -316
  152. package/src/WalletOSIcon/index.jsx +1 -1
  153. package/es/ActionButton/index.js +0 -99
  154. package/es/ActivityIndicator/index.js +0 -180
  155. package/es/Address/compact-text.js +0 -105
  156. package/es/Address/did-address.js +0 -222
  157. package/es/Address/index.js +0 -23
  158. package/es/Address/responsive-did-address.js +0 -87
  159. package/es/Alert/index.js +0 -134
  160. package/es/AnimationWaiter/default-animation.json +0 -1
  161. package/es/AnimationWaiter/index.js +0 -240
  162. package/es/Async/index.js +0 -38
  163. package/es/Avatar/did-motif.js +0 -68
  164. package/es/Avatar/etherscan-blockies.js +0 -83
  165. package/es/Avatar/index.js +0 -179
  166. package/es/Badge/index.js +0 -98
  167. package/es/Blocklet/blocklet.js +0 -298
  168. package/es/Blocklet/index.js +0 -4
  169. package/es/Blocklet/utils.js +0 -52
  170. package/es/BlockletContext/index.js +0 -65
  171. package/es/BlockletNFT/index.js +0 -412
  172. package/es/Button/index.js +0 -8
  173. package/es/Button/wrap.js +0 -140
  174. package/es/ButtonGroup/index.js +0 -6
  175. package/es/CardSelector/index.js +0 -149
  176. package/es/Center/index.js +0 -41
  177. package/es/ClickToCopy/copy-button.js +0 -72
  178. package/es/ClickToCopy/hook.js +0 -39
  179. package/es/ClickToCopy/index.js +0 -92
  180. package/es/CodeBlock/LightBox.js +0 -85
  181. package/es/CodeBlock/index.js +0 -222
  182. package/es/Colors/index.js +0 -3
  183. package/es/Colors/themes/default.js +0 -77
  184. package/es/Colors/themes/temp.js +0 -41
  185. package/es/ContactForm/index.js +0 -230
  186. package/es/CookieConsent/index.js +0 -113
  187. package/es/CountDown/index.js +0 -178
  188. package/es/DID/index.js +0 -249
  189. package/es/Datatable/CustomToolbar.js +0 -396
  190. package/es/Datatable/DatatableContext.js +0 -34
  191. package/es/Datatable/TableSearch.js +0 -166
  192. package/es/Datatable/index.js +0 -629
  193. package/es/Datatable/utils.js +0 -132
  194. package/es/Dialog/confirm.js +0 -123
  195. package/es/Dialog/dialog.js +0 -201
  196. package/es/Dialog/index.js +0 -4
  197. package/es/Dialog/types.d.ts +0 -17
  198. package/es/Dialog/use-confirm.js +0 -133
  199. package/es/DidLogo/index.js +0 -31
  200. package/es/DriftBot/index.js +0 -70
  201. package/es/Earth/countries.json +0 -8057
  202. package/es/Earth/index.js +0 -521
  203. package/es/Earth/util.js +0 -51
  204. package/es/Empty/index.js +0 -65
  205. package/es/ErrorBoundary/fallback.js +0 -73
  206. package/es/ErrorBoundary/index.js +0 -1
  207. package/es/Footer/index.js +0 -172
  208. package/es/Header/auto-hidden.js +0 -35
  209. package/es/Header/header.js +0 -223
  210. package/es/Header/index.js +0 -2
  211. package/es/Header/responsive-header.js +0 -146
  212. package/es/Icon/image.js +0 -65
  213. package/es/Icon/index.js +0 -84
  214. package/es/Img/index.js +0 -218
  215. package/es/InfoRow/index.js +0 -87
  216. package/es/Layout/dashboard/external-link.js +0 -58
  217. package/es/Layout/dashboard/full-page.js +0 -53
  218. package/es/Layout/dashboard/index.js +0 -282
  219. package/es/Layout/dashboard/sidebar.js +0 -209
  220. package/es/Layout/dashboard-legacy/header.js +0 -174
  221. package/es/Layout/dashboard-legacy/index.js +0 -148
  222. package/es/Layout/dashboard-legacy/sidebar.js +0 -129
  223. package/es/Layout/index.js +0 -335
  224. package/es/LoadingMask/index.js +0 -102
  225. package/es/Locale/browser-lang.js +0 -52
  226. package/es/Locale/context.js +0 -139
  227. package/es/Locale/languages.js +0 -60
  228. package/es/Locale/selector.js +0 -186
  229. package/es/Locale/util.js +0 -21
  230. package/es/Logo/images/logo-dark-text.svg +0 -3
  231. package/es/Logo/images/logo-dark-top.svg +0 -6
  232. package/es/Logo/images/logo-light-text.svg +0 -3
  233. package/es/Logo/images/logo-light-top.svg +0 -6
  234. package/es/Logo/index.js +0 -136
  235. package/es/Metric/index.js +0 -132
  236. package/es/NFTDisplay/NFTBroken.svg +0 -34
  237. package/es/NFTDisplay/README.md +0 -59
  238. package/es/NFTDisplay/aspect-ratio-container.js +0 -39
  239. package/es/NFTDisplay/broken.js +0 -132
  240. package/es/NFTDisplay/demo/data/asset-state-display-url.json +0 -7
  241. package/es/NFTDisplay/demo/data/asset-state-gzipped-svg-1-1.json +0 -10
  242. package/es/NFTDisplay/demo/data/asset-state-gzipped-svg-374-130.json +0 -10
  243. package/es/NFTDisplay/demo/data/asset-state-gzipped-svg-with-foreign-object.json +0 -20
  244. package/es/NFTDisplay/demo/data/asset-state-svg.json +0 -29
  245. package/es/NFTDisplay/demo/data/asset-state-url.json +0 -10
  246. package/es/NFTDisplay/index.js +0 -328
  247. package/es/NFTDisplay/loading.js +0 -18
  248. package/es/NFTDisplay/svg-embedder/img.js +0 -45
  249. package/es/NFTDisplay/svg-embedder/inline-svg.js +0 -39
  250. package/es/NavMenu/index.js +0 -2
  251. package/es/NavMenu/nav-menu.js +0 -358
  252. package/es/NavMenu/style.js +0 -181
  253. package/es/PageScroller/index.js +0 -286
  254. package/es/PageScroller/story/FifthComponent.js +0 -9
  255. package/es/PageScroller/story/FirstComponent.js +0 -9
  256. package/es/PageScroller/story/FourthComponent.js +0 -12
  257. package/es/PageScroller/story/FullPage.js +0 -47
  258. package/es/PageScroller/story/PageContain.js +0 -59
  259. package/es/PageScroller/story/SecondComponent.js +0 -9
  260. package/es/PageScroller/story/ThirdComponent.js +0 -9
  261. package/es/PageScroller/story/index.css +0 -115
  262. package/es/PageScroller/usePrevValue.js +0 -9
  263. package/es/Passport/index.js +0 -2
  264. package/es/Passport/passport.js +0 -103
  265. package/es/PoweredByArcBlock/index.js +0 -31
  266. package/es/PricingTable/PricingPlan.js +0 -124
  267. package/es/PricingTable/index.js +0 -53
  268. package/es/QRCode/index.js +0 -73
  269. package/es/RelativeTime/index.js +0 -107
  270. package/es/Result/common.js +0 -140
  271. package/es/Result/demo/fixtures/result-image-404.svg +0 -1
  272. package/es/Result/index.js +0 -33
  273. package/es/Result/result.js +0 -59
  274. package/es/Result/translations.js +0 -54
  275. package/es/Screenshot/BaseScreenshot/index.js +0 -91
  276. package/es/Screenshot/BaseScreenshot/shells/Macbook.js +0 -51
  277. package/es/Screenshot/BaseScreenshot/shells/Phone.js +0 -36
  278. package/es/Screenshot/demo/images/bg-00.jpg +0 -0
  279. package/es/Screenshot/demo/images/bg-01.jpg +0 -0
  280. package/es/Screenshot/demo/images/bg-02.jpg +0 -0
  281. package/es/Screenshot/demo/images/bg-03.jpg +0 -0
  282. package/es/Screenshot/demo/images/bg-04.jpg +0 -0
  283. package/es/Screenshot/demo/images/bg-05.jpg +0 -0
  284. package/es/Screenshot/demo/images/bg-06.jpg +0 -0
  285. package/es/Screenshot/demo/images/bg-07.jpg +0 -0
  286. package/es/Screenshot/demo/images/bg-08.jpg +0 -0
  287. package/es/Screenshot/demo/images/bg-09.jpg +0 -0
  288. package/es/Screenshot/devices.css +0 -1366
  289. package/es/Screenshot/index.js +0 -299
  290. package/es/SessionBlocklet/index.js +0 -173
  291. package/es/SessionManager/index.js +0 -2
  292. package/es/SessionPermission/index.js +0 -28
  293. package/es/SessionUser/components/logged-in.js +0 -229
  294. package/es/SessionUser/components/session-user-item.js +0 -102
  295. package/es/SessionUser/components/session-user-switch.js +0 -223
  296. package/es/SessionUser/components/un-login.js +0 -64
  297. package/es/SessionUser/components/user-info.js +0 -167
  298. package/es/SessionUser/index.js +0 -49
  299. package/es/SessionUser/libs/translation.js +0 -19
  300. package/es/SessionUser/libs/utils.js +0 -29
  301. package/es/Sparkline/index.js +0 -193
  302. package/es/Spinner/index.js +0 -28
  303. package/es/SplitButton/index.js +0 -145
  304. package/es/Success/index.js +0 -175
  305. package/es/Switch/index.js +0 -96
  306. package/es/Tabs/index.js +0 -214
  307. package/es/Tag/index.js +0 -108
  308. package/es/TextCollapse/index.js +0 -92
  309. package/es/Theme/index.js +0 -16
  310. package/es/Theme/theme-provider.js +0 -39
  311. package/es/Theme/theme.js +0 -145
  312. package/es/Toast/index.js +0 -97
  313. package/es/Typography/index.js +0 -95
  314. package/es/Util/constant.js +0 -42
  315. package/es/Util/deprecate.js +0 -28
  316. package/es/Util/federated.js +0 -91
  317. package/es/Util/index.js +0 -363
  318. package/es/Util/passport.js +0 -62
  319. package/es/Util/wallet.js +0 -32
  320. package/es/Video/index.js +0 -89
  321. package/es/Wallet/Action.js +0 -119
  322. package/es/Wallet/Download.js +0 -331
  323. package/es/Wallet/Open.js +0 -45
  324. package/es/Wallet/images/abtwallet.png +0 -0
  325. package/es/Wallet/images/android_download.svg +0 -23
  326. package/es/Wallet/images/app-store.svg +0 -20
  327. package/es/Wallet/images/google-play.svg +0 -70
  328. package/es/WalletOSIcon/index.js +0 -82
  329. package/es/WebWalletSWKeeper/index.js +0 -117
  330. package/es/WechatPrompt/images/android.png +0 -0
  331. package/es/WechatPrompt/images/ios.png +0 -0
  332. package/es/WechatPrompt/index.js +0 -88
  333. package/es/index.js +0 -38
  334. package/es/withTheme/index.js +0 -69
  335. package/es/withTracker/README.md +0 -34
  336. package/es/withTracker/error_boundary.js +0 -34
  337. 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
@@ -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 };
@@ -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;
@@ -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
- }
@@ -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
- });