@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,328 +0,0 @@
1
- /* eslint-disable react-hooks/rules-of-hooks */
2
- import { useRef, useEffect, useState } from 'react';
3
- import PropTypes from 'prop-types';
4
- import clsx from 'clsx';
5
- import { Buffer } from 'buffer';
6
- import get from 'lodash/get';
7
- import pako from 'pako';
8
- import base64 from 'base64-url';
9
- import isSvg from 'is-svg';
10
- import { ReactSVG } from 'react-svg';
11
- import noop from 'lodash/noop';
12
- import AspectRatioContainer from './aspect-ratio-container';
13
- import ImgSvgEmbedder from './svg-embedder/img';
14
- import InlineSvgEmbedder from './svg-embedder/inline-svg';
15
- import DefaultLoading from './loading';
16
- import DefaultBrokenImage from './broken';
17
- import { styled } from '../Theme';
18
-
19
- /**
20
- * 从 assetState 中获取 nft data, 兼容新旧两种类型的数据结构, 建议将该方法的返回值传入 NFTDisplay 组件的 data prop
21
- * - 旧: assetState.data.value (.credentialSubject.display)
22
- * - 新: assetState.display
23
- */
24
- import { jsx as _jsx } from "react/jsx-runtime";
25
- import { Fragment as _Fragment } from "react/jsx-runtime";
26
- import { jsxs as _jsxs } from "react/jsx-runtime";
27
- export function getNFTData(assetState) {
28
- return assetState?.display || assetState?.data?.value;
29
- }
30
- function fromBase64(v) {
31
- if (typeof v !== 'string') {
32
- throw new Error('fromBase64 requires input to be a string');
33
- }
34
- return Buffer.from(base64.unescape(v), 'base64');
35
- }
36
-
37
- // const isVC = type => {
38
- // return String(type).includes('VerifiableCredential');
39
- // };
40
-
41
- // 仅针对非 url type 的情况
42
- const getSvgEmbedder = preferredSvgEmbedder => {
43
- const embedders = {
44
- img: ImgSvgEmbedder,
45
- svg: InlineSvgEmbedder
46
- };
47
- return embedders[preferredSvgEmbedder];
48
- };
49
-
50
- /**
51
- * TODO:
52
- * 考虑把 asset data 解析部分和 nft display 分离, android 端有相关使用场景 - 只传入 svg 或 url, 也可以传入 asset data,
53
- * 目前如果想直接传入 svg 或 url, 需要构造一个 asset data 的数据才能使用 NFTDisplay 组件
54
- */
55
- function NFTDisplay({
56
- data,
57
- address,
58
- inset,
59
- aspect,
60
- component,
61
- className,
62
- renderError,
63
- renderLoading,
64
- preferredSvgEmbedder,
65
- checkSvg,
66
- minimumLoadingTime,
67
- onCompleted,
68
- ...rest
69
- }) {
70
- const wrapRoot = children => /*#__PURE__*/_jsx(Root, {
71
- as: component,
72
- ...rest,
73
- className: clsx(className, {
74
- 'nft-display--inset': inset
75
- }),
76
- children: children
77
- });
78
- const parsed = useRef(data);
79
- try {
80
- // 如果是 raw data 先解析
81
- if (typeof parsed.current === 'string') {
82
- parsed.current = JSON.parse(data);
83
- // console.log('[debug] parse data')
84
- }
85
- const {
86
- vcId
87
- } = parsed.current;
88
- // 需要兼容新旧两种类型的数据结构, nft data 有 credentialSubject 属性, 说明是旧 nft data, 否则是新 nft data
89
- const display = parsed.current.credentialSubject ? get(parsed.current, 'credentialSubject.display') : parsed.current;
90
- const {
91
- content,
92
- type
93
- } = display;
94
- const isUrlType = type === 'url';
95
-
96
- // 首次加载, 对于 url type 的情况, loading 为 true
97
- const [state, setState] = useState({
98
- loading: isUrlType,
99
- error: false
100
- });
101
- const [minimumLoadingReady, setMinimumLoadingReady] = useState(minimumLoadingTime <= 0);
102
- // console.log('[debug] render', {type, minimumLoadingTime}, JSON.stringify(state))
103
-
104
- useEffect(() => {
105
- let timer;
106
- if (minimumLoadingTime > 0) {
107
- timer = setTimeout(() => setMinimumLoadingReady(true), minimumLoadingTime);
108
- }
109
- return () => clearTimeout(timer);
110
- // eslint-disable-next-line react-hooks/exhaustive-deps
111
- }, []);
112
-
113
- // onCompleted
114
- useEffect(() => {
115
- if (!state.loading && minimumLoadingReady || state.error) {
116
- onCompleted();
117
- }
118
- // eslint-disable-next-line react-hooks/exhaustive-deps
119
- }, [state, minimumLoadingReady]);
120
- if (state.error) {
121
- throw new Error('Failed to render NFT Display.');
122
- }
123
- const renderNFT = () => {
124
- if (content) {
125
- switch (type) {
126
- case 'url':
127
- {
128
- const urlObj = new URL(content);
129
- if (!urlObj.searchParams.has('assetId')) {
130
- urlObj.searchParams.append('assetId', address);
131
- }
132
- if (!urlObj.searchParams.has('vcId') && vcId) {
133
- urlObj.searchParams.append('vcId', vcId);
134
- }
135
- const url = urlObj.href;
136
- const safeOnLoad = () => {
137
- if (state.loading) {
138
- setState({
139
- ...state,
140
- loading: false
141
- });
142
- }
143
- };
144
- return state.fallback ? state.fallback?.() : /*#__PURE__*/_jsx(ReactSVG, {
145
- src: url,
146
- beforeInjection: svg => {
147
- svg.setAttribute('style', 'pointer-events: none; width: 100%; height: 100%;');
148
- },
149
- afterInjection: safeOnLoad,
150
- onError: error => {
151
- let objectType = null;
152
- if (error?.message?.indexOf('Invalid content type: ') > -1) {
153
- objectType = error.message.split('Invalid content type: ')?.[1];
154
- } else if (error?.message?.indexOf('Unable to load SVG file: ') > -1) {
155
- objectType = 'image/svg+xml';
156
- }
157
- setState({
158
- ...state,
159
- // fallback to object, and use objectType to render
160
- fallback: () =>
161
- /*#__PURE__*/
162
- // eslint-disable-next-line jsx-a11y/alt-text
163
- _jsx("object", {
164
- type: objectType,
165
- data: url,
166
- onErrorCapture: () => {
167
- setState({
168
- ...state,
169
- error: true,
170
- loading: false
171
- });
172
- },
173
- onLoad: safeOnLoad,
174
- style: {
175
- width: 'auto',
176
- height: 'auto',
177
- pointerEvents: 'none'
178
- }
179
- }, url)
180
- });
181
- }
182
- // evalScripts="always"
183
- ,
184
- wrapper: "div"
185
- });
186
- }
187
- case 'uri':
188
- {
189
- return /*#__PURE__*/_jsx("img", {
190
- src: content,
191
- onError: () => setState({
192
- ...state,
193
- error: true
194
- }),
195
- onLoad: () => setState({
196
- ...state,
197
- loading: false
198
- }),
199
- alt: "NFT Display"
200
- });
201
- }
202
- case 'svg_gzipped':
203
- {
204
- const buffer = pako.ungzip(fromBase64(content), {});
205
- const svg = Buffer.from(buffer).toString('utf8');
206
- if (checkSvg && !isSvg(svg)) {
207
- throw new Error('Invalid SVG of type svg_gzipped');
208
- }
209
- const Embedder = getSvgEmbedder(preferredSvgEmbedder);
210
- return /*#__PURE__*/_jsx(Embedder, {
211
- svg: svg
212
- });
213
- }
214
- case 'svg':
215
- {
216
- if (checkSvg && !isSvg(content)) {
217
- throw new Error('Invalid SVG of type svg');
218
- }
219
- const Embedder = getSvgEmbedder(preferredSvgEmbedder);
220
- return /*#__PURE__*/_jsx(Embedder, {
221
- svg: content
222
- });
223
- }
224
- // TODO: 准备测试数据
225
- case 'html':
226
- {
227
- break;
228
- }
229
- default:
230
- }
231
- }
232
- throw new Error(`unsupported display protocol: ${display.type}`);
233
- };
234
- return wrapRoot( /*#__PURE__*/_jsxs(_Fragment, {
235
- children: [(state.loading || !minimumLoadingReady) && (renderLoading ? renderLoading() : /*#__PURE__*/_jsx(DefaultLoading, {})), renderNFT()]
236
- }));
237
- } catch (e) {
238
- console.error(e?.message, {
239
- nftId: address,
240
- vcId: parsed?.current?.vcId
241
- });
242
- return wrapRoot(renderError ? renderError() : /*#__PURE__*/_jsx(DefaultBrokenImage, {}));
243
- }
244
- }
245
- NFTDisplay.propTypes = {
246
- // asset data 可以是 raw data 和 parsed data
247
- data: PropTypes.oneOfType([PropTypes.object, PropTypes.string]).isRequired,
248
- address: PropTypes.string.isRequired,
249
- component: PropTypes.string,
250
- inset: PropTypes.bool,
251
- aspect: PropTypes.number,
252
- className: PropTypes.string,
253
- renderError: PropTypes.func,
254
- renderLoading: PropTypes.func,
255
- // 对于非 url type 的情况, 支持优先选用的 svg 嵌入方式, 默认是 img
256
- preferredSvgEmbedder: PropTypes.oneOf(['img', 'svg']),
257
- // 针对非 url type 的情况, 检测 svg 有效性, 默认禁用
258
- checkSvg: PropTypes.bool,
259
- // loading 最小显示时间 (避免闪烁)
260
- minimumLoadingTime: PropTypes.number,
261
- // 完成回调, 无论加载成功|失败
262
- onCompleted: PropTypes.func
263
- };
264
- NFTDisplay.defaultProps = {
265
- component: 'span',
266
- inset: false,
267
- aspect: 0,
268
- className: '',
269
- renderError: null,
270
- renderLoading: null,
271
- preferredSvgEmbedder: 'img',
272
- checkSvg: false,
273
- minimumLoadingTime: 0,
274
- onCompleted: noop
275
- };
276
- const Root = styled('div')`
277
- display: flex;
278
- justify-content: center;
279
- align-items: center;
280
- position: relative;
281
- /* 默认尺寸 */
282
- width: 150px;
283
- height: 150px;
284
- overflow: hidden;
285
-
286
- &,
287
- img,
288
- object {
289
- max-width: 100%;
290
- max-height: 100%;
291
- }
292
-
293
- img,
294
- object {
295
- width: 100%;
296
- height: 100%;
297
- }
298
-
299
- &.nft-display--inset {
300
- width: 100%;
301
- height: 100%;
302
- }
303
- `;
304
- function withAspectRatio(Component) {
305
- // eslint-disable-next-line func-names, react/prop-types
306
- return function ({
307
- aspect,
308
- inset,
309
- ...rest
310
- }) {
311
- // inset 比 aspect ratio 优先级高, 如果同时设置了 inset 和 aspect, 则后者不生效
312
- const applyAspectRatio = aspect > 0 && !inset;
313
- if (applyAspectRatio) {
314
- return /*#__PURE__*/_jsx(AspectRatioContainer, {
315
- aspect: aspect,
316
- children: /*#__PURE__*/_jsx(Component, {
317
- inset: true,
318
- ...rest
319
- })
320
- });
321
- }
322
- return /*#__PURE__*/_jsx(Component, {
323
- inset: inset,
324
- ...rest
325
- });
326
- };
327
- }
328
- export default withAspectRatio(NFTDisplay);
@@ -1,18 +0,0 @@
1
- import { styled } from '../Theme';
2
- import { jsx as _jsx } from "react/jsx-runtime";
3
- export default function Loading() {
4
- return /*#__PURE__*/_jsx(Root, {
5
- className: "nft-display__loading",
6
- children: "Loading..."
7
- });
8
- }
9
- const Root = styled('span')`
10
- display: flex;
11
- justify-content: center;
12
- align-items: center;
13
- position: absolute;
14
- width: 100%;
15
- height: 100%;
16
- color: #ccc;
17
- background-color: #eee;
18
- `;
@@ -1,45 +0,0 @@
1
- import PropTypes from 'prop-types';
2
- import InlineSvgEmbedder from './inline-svg';
3
- import { jsx as _jsx } from "react/jsx-runtime";
4
- const svgToImgUrl = svg => {
5
- // fix: #225, https://stackoverflow.com/a/52135328)
6
- const blob = new Blob([svg], {
7
- type: 'image/svg+xml'
8
- });
9
- return URL.createObjectURL(blob);
10
- };
11
-
12
- /**
13
- * 基于 <img> 嵌入 svg
14
- */
15
- function ImgEmbedder({
16
- svg,
17
- alt,
18
- fallback,
19
- ...rest
20
- }) {
21
- // 包含 foreignObject 的 svg, fallback 到 shadow dom
22
- if (fallback && svg.indexOf('</foreignObject>') > -1) {
23
- return /*#__PURE__*/_jsx(InlineSvgEmbedder, {
24
- svg: svg
25
- });
26
- }
27
- const url = svgToImgUrl(svg);
28
- return /*#__PURE__*/_jsx("img", {
29
- src: url,
30
- onLoad: () => URL.revokeObjectURL(url),
31
- alt: alt,
32
- ...rest
33
- });
34
- }
35
- ImgEmbedder.propTypes = {
36
- svg: PropTypes.string.isRequired,
37
- alt: PropTypes.string,
38
- // 对于包含 foreignObject 的 svg, fallback 到 inline svg + shadow DOM
39
- fallback: PropTypes.bool
40
- };
41
- ImgEmbedder.defaultProps = {
42
- alt: '',
43
- fallback: true
44
- };
45
- export default ImgEmbedder;
@@ -1,39 +0,0 @@
1
- import PropTypes from 'prop-types';
2
- import root from 'react-shadow/emotion';
3
- import { styled } from '../../Theme';
4
-
5
- /**
6
- * inline svg 的方式嵌入 svg, 使用 shadow DOM 避免样式污染
7
- */
8
- import { jsx as _jsx } from "react/jsx-runtime";
9
- function InlineSvg({
10
- svg,
11
- ...rest
12
- }) {
13
- return /*#__PURE__*/_jsx(Root, {
14
- ...rest,
15
- children: /*#__PURE__*/_jsx(Inner, {
16
- dangerouslySetInnerHTML: {
17
- __html: svg
18
- }
19
- })
20
- });
21
- }
22
- InlineSvg.propTypes = {
23
- svg: PropTypes.string.isRequired
24
- };
25
- const Root = styled(root.span)`
26
- display: block;
27
- width: 100%;
28
- height: 100%;
29
- `;
30
- const Inner = styled('div')`
31
- &,
32
- & > svg {
33
- height: 100%;
34
- width: 100%;
35
- min-width: 100%;
36
- max-width: 100%;
37
- }
38
- `;
39
- export default InlineSvg;
@@ -1,2 +0,0 @@
1
- // eslint-disable-next-line no-restricted-exports
2
- export { default } from './nav-menu';