@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,230 +0,0 @@
1
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
2
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
3
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
4
- /* eslint-disable react/no-unused-prop-types */
5
- /* eslint-disable react/static-property-placement */
6
- import React from 'react';
7
- import PropTypes from 'prop-types';
8
- import axios from 'axios';
9
- import Typography from '@mui/material/Typography';
10
- import CircularProgress from '@mui/material/CircularProgress';
11
- import { mergeProps } from '../Util';
12
- import { warn as deprecatedWarn } from '../Util/deprecate';
13
- import Button from '../Button';
14
- import { styled } from '../Theme';
15
- import { jsx as _jsx } from "react/jsx-runtime";
16
- import { jsxs as _jsxs } from "react/jsx-runtime";
17
- export function submitContactForm({
18
- formId,
19
- portalId
20
- }, fields, context) {
21
- const url = `https://api.hsforms.com/submissions/v3/integration/submit/${portalId}/${formId}`;
22
- return axios.post(url, {
23
- submittedAt: Date.now(),
24
- fields: Object.keys(fields).map(x => ({
25
- name: x.replace(/\s+/, '').toLowerCase(),
26
- value: fields[x]
27
- })),
28
- context,
29
- skipValidation: false
30
- }).then(res => res.data.inlineMessage).catch(res => res.data ? res.data.message : 'Form Submit Failed');
31
- }
32
- export default class ContactForm extends React.Component {
33
- constructor(props) {
34
- super(props);
35
- _defineProperty(this, "onSubmit", async e => {
36
- e.preventDefault();
37
- this.setState({
38
- loading: true
39
- });
40
- try {
41
- const message = await submitContactForm({
42
- formId: this.props.formId,
43
- portalId: this.props.portalId
44
- }, this.fields.reduce((obj, x) => {
45
- obj[x] = this.state[x];
46
- return obj;
47
- }, {}), {
48
- pageUri: window.location.href,
49
- pageName: window.location.title
50
- });
51
- this.setState({
52
- loading: false,
53
- successMessage: message || this.props.successMessage
54
- });
55
- } catch (err) {
56
- this.setState({
57
- loading: false,
58
- errorMessage: err ? err.message : 'Form submit failed'
59
- });
60
- }
61
- });
62
- _defineProperty(this, "getInputHandler", (name, state = {}) => e => {
63
- this.setState(Object.assign(state, {
64
- [name]: e.target.value
65
- }));
66
- });
67
- if (typeof props.fields === 'string') {
68
- this.fields = props.fields.split(',').map(x => x.trim());
69
- } else {
70
- this.fields = props.fields;
71
- }
72
- this.state = {
73
- loading: false,
74
- errorMessage: '',
75
- successMessage: ''
76
- };
77
- this.fields.forEach(x => {
78
- this.state[x] = '';
79
- });
80
- deprecatedWarn('ContactForm');
81
- }
82
- deriveProps() {
83
- const newProps = mergeProps(this.props, ContactForm);
84
- if (typeof newProps.title === 'undefined') {
85
- newProps.title = 'Signup for our news letter';
86
- }
87
- if (!newProps.button) {
88
- newProps.button = 'Subscribe';
89
- }
90
- return newProps;
91
- }
92
- render() {
93
- const {
94
- className,
95
- style,
96
- title,
97
- button,
98
- layout
99
- } = this.deriveProps();
100
- const {
101
- loading,
102
- errorMessage,
103
- successMessage
104
- } = this.state;
105
- return /*#__PURE__*/_jsxs(Form, {
106
- onSubmit: this.onSubmit,
107
- className: className,
108
- style: style,
109
- layout: layout,
110
- fieldCount: this.fields.length,
111
- name: "subscribe",
112
- children: [!!title && /*#__PURE__*/_jsx(Typography, {
113
- component: "p",
114
- className: "title",
115
- children: title
116
- }), /*#__PURE__*/_jsxs("div", {
117
- className: "form-controls",
118
- children: [this.fields.map(x => /*#__PURE__*/_jsx("input", {
119
- required: true,
120
- type: "text",
121
- value: this.state[x],
122
- onChange: this.getInputHandler(x),
123
- className: "input",
124
- placeholder: x
125
- }, x)), /*#__PURE__*/_jsx(Button, {
126
- variant: "outlined",
127
- type: "submit",
128
- color: "inherit",
129
- size: "large",
130
- disabled: loading,
131
- className: "subscribe-btn-empty",
132
- children: loading ? /*#__PURE__*/_jsx(CircularProgress, {
133
- size: 28
134
- }) : button
135
- })]
136
- }), !!errorMessage && /*#__PURE__*/_jsx(Typography, {
137
- component: "p",
138
- variant: "body1",
139
- className: "error",
140
- color: "secondary",
141
- dangerouslySetInnerHTML: {
142
- __html: errorMessage
143
- }
144
- }), !!successMessage && /*#__PURE__*/_jsx(Typography, {
145
- component: "p",
146
- variant: "body1",
147
- className: "success",
148
- color: "primary",
149
- dangerouslySetInnerHTML: {
150
- __html: successMessage
151
- }
152
- })]
153
- });
154
- }
155
- }
156
-
157
- // prettier-ignore
158
- _defineProperty(ContactForm, "propTypes", {
159
- style: PropTypes.object,
160
- className: PropTypes.string,
161
- portalId: PropTypes.string,
162
- formId: PropTypes.string,
163
- title: PropTypes.string,
164
- button: PropTypes.string,
165
- successMessage: PropTypes.string,
166
- layout: PropTypes.oneOf(['horizontal', 'vertical']),
167
- fields: PropTypes.oneOfType([PropTypes.string, PropTypes.array])
168
- });
169
- _defineProperty(ContactForm, "defaultProps", {
170
- style: {},
171
- className: '',
172
- portalId: '4796488',
173
- formId: '929a510f-34f4-4251-98b3-34175200aebd',
174
- title: undefined,
175
- button: '',
176
- layout: 'vertical',
177
- successMessage: 'Form Submit Success',
178
- fields: ['Email', 'First Name', 'Last Name']
179
- });
180
- const getInputWidth = props => props.layout === 'vertical' ? '100%' : `${Math.max(95 / (props.fieldCount + 1), 20)}%`;
181
- const Form = styled('form')`
182
- display: flex;
183
- flex-direction: column;
184
- justify-content: center;
185
- align-items: center;
186
- @media (max-width: ${props => props.theme.breakpoints.values.sm}px) {
187
- width: 100% !important;
188
- }
189
- max-width: 800px;
190
- margin: 0px auto;
191
-
192
- .title {
193
- font-size: 30px;
194
- text-align: center;
195
- color: ${props => props.theme.typography.color.main};
196
- }
197
-
198
- .form-controls {
199
- width: 100%;
200
- flex-direction: ${props => props.layout === 'vertical' ? 'column' : 'row'};
201
- justify-content: space-between;
202
- align-items: center;
203
-
204
- .input {
205
- width: ${props => getInputWidth(props)};
206
- height: 50px;
207
- border: none;
208
- border-bottom: 1px solid ${props => props.theme.typography.color.main};
209
- font-size: 16px;
210
- letter-spacing: 1.8px;
211
- outline: none;
212
- margin: ${props => props.layout === 'vertical' ? '12px 0' : '12px'};
213
- background: transparent;
214
-
215
- &:first-of-type {
216
- margin-top: 40px;
217
- }
218
- }
219
-
220
- .subscribe-btn-empty {
221
- margin-top: ${props => props.layout === 'vertical' ? '40px' : '0'};
222
- width: ${props => props.layout === 'vertical' ? '100%' : 'auto'};
223
- }
224
- }
225
-
226
- .error,
227
- .success {
228
- margin-top: 20px;
229
- }
230
- `;
@@ -1,113 +0,0 @@
1
- import PropTypes from 'prop-types';
2
- import Button from '@mui/material/Button';
3
- import CookieConsent, { resetCookieConsentValue } from 'react-cookie-consent';
4
- import { styled } from '../Theme';
5
- import { jsx as _jsx } from "react/jsx-runtime";
6
- export { resetCookieConsentValue };
7
- const translations = {
8
- en: {
9
- content: 'We use cookies and other tracking technologies to improve your browsing experience on our website, to show you personalized content, to analyze our website traffic, and to understand where our visitors are coming from.',
10
- agree: 'I Understand'
11
- },
12
- zh: {
13
- content: '我们使用 cookies 和其他跟踪技术来改善您在我们网站上的浏览体验,向您展示个性化的内容,分析我们的网站流量,并了解我们的访问者来自哪里。',
14
- agree: '我知道了'
15
- }
16
- };
17
- function inIframe() {
18
- try {
19
- return window.self !== window.top;
20
- } catch (e) {
21
- return true;
22
- }
23
- }
24
- function AcceptButton(props) {
25
- return /*#__PURE__*/_jsx(Button, {
26
- variant: "contained",
27
- ...props
28
- });
29
- }
30
-
31
- /**
32
- * DefaultCookieConsent, 对 react-cookie-consent package 封装, 以便 arcblock 内部产品可以快速使用
33
- * - 默认内容
34
- * - 默认配置/样式
35
- */
36
- export default function DefaultCookieConsent({
37
- children,
38
- locale,
39
- style,
40
- displayInIframe,
41
- ...rest
42
- }) {
43
- if (!displayInIframe && inIframe()) {
44
- return null;
45
- }
46
- if (locale && !translations[locale]) {
47
- // eslint-disable-next-line no-param-reassign
48
- locale = 'en';
49
- }
50
- return /*#__PURE__*/_jsx(Wrapper, {
51
- style: style,
52
- children: /*#__PURE__*/_jsx(CookieConsent, {
53
- disableStyles: true,
54
- disableButtonStyles: true,
55
- ButtonComponent: AcceptButton,
56
- buttonText: translations[locale].agree,
57
- buttonStyle: {
58
- marginTop: 16,
59
- padding: '6px 16px'
60
- },
61
- ...rest,
62
- children: children || /*#__PURE__*/_jsx("p", {
63
- style: {
64
- margin: 0
65
- },
66
- children: translations[locale].content
67
- })
68
- })
69
- });
70
- }
71
- DefaultCookieConsent.propTypes = {
72
- children: PropTypes.any,
73
- style: PropTypes.object,
74
- locale: PropTypes.string,
75
- displayInIframe: PropTypes.bool
76
- };
77
- DefaultCookieConsent.defaultProps = {
78
- children: null,
79
- style: {},
80
- locale: 'en',
81
- displayInIframe: false
82
- };
83
- const Wrapper = styled('div')`
84
- box-sizing: border-box;
85
- position: fixed;
86
- right: 20px;
87
- bottom: 20px;
88
- z-index: 999;
89
- max-width: 440px;
90
- padding: 16px 24px;
91
- font-size: 16px;
92
- color: #666;
93
- background: #fff;
94
- border-radius: 6px;
95
- box-shadow: 0 0 18px rgba(0, 0, 0, 0.2);
96
- &:empty {
97
- display: none;
98
- }
99
- button {
100
- min-width: 200px;
101
- }
102
-
103
- @media screen and (max-width: 480px) {
104
- left: 16px;
105
- right: 16px;
106
- bottom: 16px;
107
- width: auto;
108
- button {
109
- display: block;
110
- width: 100%;
111
- }
112
- }
113
- `;
@@ -1,178 +0,0 @@
1
- import { Component } from 'react';
2
- import PropTypes from 'prop-types';
3
- import { getColor, mergeProps } from '../Util';
4
- import { styled } from '../Theme';
5
- import { jsx as _jsx } from "react/jsx-runtime";
6
- import { jsxs as _jsxs } from "react/jsx-runtime";
7
- const SECONDS_OF_MINUTE = 60;
8
- const SECONDS_OF_HOUR = 60 * SECONDS_OF_MINUTE;
9
- const SECONDS_OF_DAY = 24 * SECONDS_OF_HOUR;
10
- function getRemaining(endTime) {
11
- const now = new Date().getTime();
12
- const diff = Math.round((endTime - now) / 1000);
13
- const days = Math.floor(diff / SECONDS_OF_DAY);
14
- const hours = Math.floor(diff % SECONDS_OF_DAY / SECONDS_OF_HOUR);
15
- const minutes = Math.floor(diff % SECONDS_OF_DAY % SECONDS_OF_HOUR / SECONDS_OF_MINUTE);
16
- const seconds = Math.round(diff % SECONDS_OF_DAY % SECONDS_OF_HOUR % SECONDS_OF_MINUTE);
17
- return {
18
- days,
19
- hours,
20
- minutes,
21
- seconds,
22
- done: diff <= 0
23
- };
24
- }
25
-
26
- // eslint-disable-next-line react/prop-types
27
- function FixWidthNumber({
28
- number,
29
- label,
30
- length = 2
31
- }) {
32
- let str = number.toString();
33
- while (str.length < length) {
34
- str = `0${str}`;
35
- }
36
- const numbers = str.split('');
37
- return /*#__PURE__*/_jsxs("span", {
38
- className: "num-group",
39
- children: [/*#__PURE__*/_jsx("span", {
40
- className: "num-items",
41
- children: numbers.map((x, i) =>
42
- /*#__PURE__*/
43
- // eslint-disable-next-line react/no-array-index-key
44
- _jsx("strong", {
45
- className: "num-item",
46
- children: x
47
- }, `num-${i}`))
48
- }), /*#__PURE__*/_jsx("span", {
49
- className: "num-label",
50
- children: label
51
- })]
52
- });
53
- }
54
- export default class CountDown extends Component {
55
- constructor(props) {
56
- super(props);
57
- const newProps = mergeProps(props, CountDown, ['dark', 'endTime', 'style']);
58
- this.state = getRemaining(newProps.endTime);
59
- this.timer = null;
60
- }
61
- componentDidMount() {
62
- this.timer = setInterval(() => {
63
- const remaining = getRemaining(this.props.endTime);
64
- if (remaining.done) {
65
- clearInterval(this.timer);
66
- this.timer = null;
67
- }
68
- this.setState(remaining);
69
- }, 1000);
70
- }
71
- componentWillUnmount() {
72
- if (this.timer) {
73
- clearInterval(this.timer);
74
- this.timer = null;
75
- }
76
- }
77
- render() {
78
- const {
79
- dark,
80
- endTime,
81
- ...rest
82
- } = this.props;
83
- const {
84
- days,
85
- hours,
86
- minutes,
87
- seconds
88
- } = this.state;
89
- return /*#__PURE__*/_jsxs(Container, {
90
- dark: dark,
91
- ...rest,
92
- children: [/*#__PURE__*/_jsx(FixWidthNumber, {
93
- number: days,
94
- label: "D"
95
- }), /*#__PURE__*/_jsx("span", {
96
- className: "num-sep",
97
- children: ":"
98
- }), /*#__PURE__*/_jsx(FixWidthNumber, {
99
- number: hours,
100
- label: "H"
101
- }), /*#__PURE__*/_jsx("span", {
102
- className: "num-sep",
103
- children: ":"
104
- }), /*#__PURE__*/_jsx(FixWidthNumber, {
105
- number: minutes,
106
- label: "M"
107
- }), /*#__PURE__*/_jsx("span", {
108
- className: "num-sep",
109
- children: ":"
110
- }), /*#__PURE__*/_jsx(FixWidthNumber, {
111
- number: seconds,
112
- label: "S"
113
- })]
114
- });
115
- }
116
- }
117
- CountDown.propTypes = {
118
- endTime: PropTypes.number.isRequired,
119
- // endTime should be UTC
120
- dark: PropTypes.bool,
121
- style: PropTypes.object
122
- };
123
- CountDown.defaultProps = {
124
- dark: true,
125
- style: {}
126
- };
127
- const textBackground = `linear-gradient(to bottom, rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.4)),
128
- linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.5) 77%, rgba(0, 0, 0, 0.5))`;
129
- const Container = styled('div')`
130
- color: ${props => getColor(props)};
131
- font-size: 50px;
132
- display: flex;
133
- flex-direction: row;
134
- justify-content: center;
135
- align-items: flex-start;
136
-
137
- .num-group {
138
- display: flex;
139
- flex-direction: column;
140
- justify-content: center;
141
- align-items: center;
142
- margin: 0 60px;
143
-
144
- @media (max-width: ${props => props.theme.breakpoints.values.md}px) {
145
- margin: 0 20px;
146
- }
147
- @media (max-width: ${props => props.theme.breakpoints.values.sm}px) {
148
- margin: 0;
149
- }
150
-
151
- .num-items {
152
- display: flex;
153
- flex-direction: row;
154
- }
155
-
156
- .num-item {
157
- display: inline-block;
158
- width: 40px;
159
- height: 60px;
160
- line-height: 60px;
161
- background-image: ${props => props.dark ? textBackground : 'none'};
162
- text-align: center;
163
-
164
- &:first-of-type {
165
- margin-right: 10px;
166
- @media (max-width: ${props => props.theme.breakpoints.values.sm}px) {
167
- margin: 0;
168
- }
169
- }
170
- }
171
-
172
- .num-label {
173
- margin-top: 20px;
174
- font-size: 24px;
175
- color: ${props => getColor(props)};
176
- }
177
- }
178
- `;