@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,629 +0,0 @@
1
- /* eslint-disable react-hooks/exhaustive-deps */
2
- import { useEffect, useRef, isValidElement } from 'react';
3
- import PropTypes from 'prop-types';
4
- import MUIDataTable, { TableFilterList, TableFooter } from 'mui-datatables';
5
- import { css } from '@emotion/react';
6
- import isObject from 'lodash/isObject';
7
- import cloneDeep from 'lodash/cloneDeep';
8
- import get from 'lodash/get';
9
- import clsx from 'clsx';
10
- import CircularProgress from '@mui/material/CircularProgress';
11
- import Empty from '../Empty';
12
- import CustomToolbar from './CustomToolbar';
13
- import { DatatableProvider as DataTableProvider, useDatatableContext } from './DatatableContext';
14
- import { styled } from '../Theme';
15
-
16
- /**
17
- * @typedef {{
18
- * icon: import('react').ReactElement,
19
- * title: string,
20
- * }} DataTableCustomButton
21
- */
22
-
23
- /**
24
- * @typedef {{
25
- * name: string,
26
- * label: string,
27
- * width?: number,
28
- * options?: {
29
- * filter?: boolean,
30
- * sort?: boolean,
31
- * customBodyRender?: (value: any) => import('react').ReactElement,
32
- * customBodyRenderLite?: (index: number) => import('react').ReactElement
33
- * } & import('mui-datatables').MUIDataTableColumnOptions
34
- * } & import('mui-datatables').MUIDataTableColumnDef} DataTableColumn
35
- */
36
-
37
- /**
38
- * @typedef {Pick<import('mui-datatables').MUIDataTableState, 'count' | 'page' | 'rowsPerPage' | 'searchText' | 'sortOrder' | 'filterList'>} DataTableState
39
- */
40
-
41
- /**
42
- * @typedef {{
43
- * data: Array<object | number[] | string[]>,
44
- * columns: Array<DataTableColumn>,
45
- * locale?: string,
46
- * options?: import('mui-datatables').MUIDataTableOptions,
47
- * style?: import('react').CSSProperties,
48
- * customButtons?: Array<DataTableCustomButton>,
49
- * onChange?: (state: DataTableState, action: string) => void | Promise<void>,
50
- * loading?: boolean,
51
- * disabled?: boolean,
52
- * stripped?: boolean,
53
- * verticalKeyWidth?: number | string,
54
- * hideTableHeader?: boolean,
55
- * components?: import('react').ReactElement,
56
- * emptyNode?: import('react').ReactElement,
57
- * durable?: string,
58
- * durableKeys?: 'page' | 'rowsPerPage' | 'searchText' | 'sortOrder'
59
- * } & import('mui-datatables').MUIDataTableProps} DataTableProps
60
- */
61
-
62
- /**
63
- * @description
64
- * @export
65
- * @param {DataTableProps} props
66
- * @return {import('react').ReactComponentElement}
67
- */
68
- import { jsx as _jsx } from "react/jsx-runtime";
69
- import { jsxs as _jsxs } from "react/jsx-runtime";
70
- export default function DataTable(props) {
71
- return /*#__PURE__*/_jsx(DataTableProvider, {
72
- children: /*#__PURE__*/_jsx(ReDataTable, {
73
- ...props
74
- })
75
- });
76
- }
77
- const fixCellProp = (tempObj, cellProps) => {
78
- const cellStyle = {};
79
- if (tempObj.align) {
80
- cellProps.className = clsx(cellProps.className, `pc-align-${tempObj.align}`);
81
- }
82
- if (tempObj.verticalKeyAlign) {
83
- cellProps.className = clsx(cellProps.className, `vertical-align-${tempObj.verticalKeyAlign}`);
84
- }
85
- if (tempObj.minWidth) {
86
- cellStyle.minWidth = tempObj.minWidth;
87
- }
88
- cellProps.style = Object.assign({}, cellProps.style, cellStyle);
89
- };
90
-
91
- /**
92
- * @param {Object} props.options The options of mui-datatable,detail see https://github.com/gregnb/mui-datatables/tree/b8d2eee6af4589d254b40918e5d7e70b1ee4baca
93
- * @param {Array} props.customButtons Custom buttons for toolbar
94
- * @param {Function} props.onChange When onChange is present, serverSide mode is activated by default https://github.com/gregnb/mui-datatables/tree/b8d2eee6af4589d254b40918e5d7e70b1ee4baca#remote-data
95
- * @param {Boolean} props.loading For dynamic data, usually used with onChange
96
- * @returns
97
- */
98
- function ReDataTable({
99
- data: originData,
100
- columns: originColumns,
101
- locale,
102
- options,
103
- // The options object is usually a property supported by mui-datatable
104
- style,
105
- customButtons,
106
- onChange,
107
- loading,
108
- disabled,
109
- stripped,
110
- verticalKeyWidth,
111
- hideTableHeader,
112
- components,
113
- emptyNode,
114
- durable,
115
- durableKeys,
116
- ...rest
117
- }) {
118
- const oldState = useRef(null);
119
- const {
120
- setCustomButtons,
121
- setFilterLabel,
122
- setLoading,
123
- setDisabled
124
- } = useDatatableContext();
125
- const disabledCellStyle = {
126
- cursor: 'not-allowed',
127
- pointerEvents: 'none'
128
- };
129
- const keys = [];
130
-
131
- // Convert Columns fields to object sets to support the width function
132
- const columns = originColumns.map(e => {
133
- let tempObj;
134
- if (!isObject(e)) {
135
- tempObj = {
136
- label: e,
137
- name: e
138
- };
139
- } else {
140
- tempObj = cloneDeep(e);
141
- }
142
- keys.push(tempObj.name);
143
- if (!tempObj.align) {
144
- // There must be an align default for setCellRender to take effect, this is a bug in mui-datatable
145
- tempObj.align = 'left';
146
- }
147
- if (!tempObj.options) {
148
- tempObj.options = {};
149
- }
150
- const {
151
- setCellHeaderProps,
152
- setCellProps
153
- } = tempObj.options;
154
- tempObj.options.setCellHeaderProps = (...args) => {
155
- let cellProps = {
156
- className: ''
157
- };
158
-
159
- // Complementing width while inheriting old setCellHeaderProps
160
- if (setCellHeaderProps && !setCellHeaderProps.__innerFunc) {
161
- cellProps = {
162
- ...cellProps,
163
- ...(setCellHeaderProps(...args) || {})
164
- };
165
- }
166
- if (loading || disabled) {
167
- cellProps = {
168
- ...cellProps,
169
- style: disabledCellStyle
170
- };
171
- }
172
- if (tempObj.width) {
173
- cellProps.width = tempObj.width;
174
- }
175
- fixCellProp(tempObj, cellProps);
176
- return cellProps;
177
- };
178
-
179
- // Prevent memory xie caused by recursive forwarding of setCellHeaderProps functions
180
- tempObj.options.setCellHeaderProps.__innerFunc = 1;
181
- if (tempObj.align || tempObj.style) {
182
- tempObj.options.setCellProps = (...args) => {
183
- let cellProps = {
184
- className: ''
185
- };
186
-
187
- // Complementing width while inheriting old setCellHeaderProps
188
- if (setCellProps && !setCellProps.__innerFunc) {
189
- cellProps = {
190
- ...cellProps,
191
- ...(setCellProps(...args) || {})
192
- };
193
- }
194
- fixCellProp(tempObj, cellProps);
195
- return cellProps;
196
- };
197
- tempObj.options.setCellProps.__innerFunc = 1;
198
- }
199
- return tempObj;
200
- });
201
-
202
- // Fixing object-type structures
203
- const data = originData.map(e => {
204
- if (!Array.isArray(e) && isObject(e)) {
205
- return keys.map(key => get(e, key));
206
- }
207
- return e;
208
- });
209
- useEffect(() => setCustomButtons(customButtons || []), [customButtons]);
210
- useEffect(() => setLoading(loading), [loading]);
211
- useEffect(() => setDisabled(disabled), [disabled]);
212
- let emptyEl;
213
- if (loading) {
214
- emptyEl = /*#__PURE__*/_jsx(CircularProgress, {
215
- color: "primary"
216
- });
217
- } else if ( /*#__PURE__*/isValidElement(emptyNode)) {
218
- emptyEl = emptyNode;
219
- } else if (locale === 'zh') {
220
- emptyEl = /*#__PURE__*/_jsx(Empty, {
221
- children: emptyNode || '没有找到匹配的记录'
222
- });
223
- } else {
224
- emptyEl = /*#__PURE__*/_jsx(Empty, {
225
- children: emptyNode || 'No matching records found'
226
- });
227
- }
228
- let textLabels = {
229
- body: {
230
- noMatch: emptyEl,
231
- toolTip: 'Sort'
232
- },
233
- pagination: {
234
- next: 'Next Page',
235
- previous: 'Previous Page',
236
- rowsPerPage: 'Per page:',
237
- displayRows: 'of',
238
- jumpToPage: 'Jump to Page:'
239
- },
240
- toolbar: {
241
- search: 'Search',
242
- downloadCsv: 'Download CSV',
243
- print: 'Print',
244
- viewColumns: 'View Columns',
245
- filterTable: 'Filter Table'
246
- },
247
- filter: {
248
- all: 'All',
249
- title: 'FILTERS',
250
- reset: 'RESET'
251
- },
252
- viewColumns: {
253
- title: 'Show Columns',
254
- titleAria: 'Show/Hide Table Columns'
255
- },
256
- selectedRows: {
257
- text: 'row(s) selected',
258
- delete: 'Delete',
259
- deleteAria: 'Delete Selected Rows'
260
- }
261
- };
262
- if (locale === 'zh') {
263
- textLabels = {
264
- body: {
265
- noMatch: emptyEl,
266
- toolTip: '排序'
267
- },
268
- pagination: {
269
- next: '下一页',
270
- previous: '上一页',
271
- rowsPerPage: '每页行数',
272
- displayRows: '/',
273
- jumpToPage: '跳转到页面:'
274
- },
275
- toolbar: {
276
- search: '搜索',
277
- downloadCsv: '下载CSV',
278
- print: '打印',
279
- viewColumns: '查看列',
280
- filterTable: '筛选表格'
281
- },
282
- filter: {
283
- all: '全部',
284
- title: '筛选器',
285
- reset: '重置'
286
- },
287
- viewColumns: {
288
- title: '显示的列',
289
- titleAria: '显示/隐藏 表格的列'
290
- },
291
- selectedRows: {
292
- text: '个已选项目',
293
- delete: '删除',
294
- deleteAria: '删除所选项目'
295
- }
296
- };
297
- }
298
- useEffect(() => setFilterLabel(textLabels.filter.title), [textLabels.filter.title]);
299
- const durableData = getDurableData(durable);
300
- const opts = {
301
- selectableRows: 'none',
302
- textLabels,
303
- rowsPerPage: 10,
304
- rowsPerPageOptions: [10, 20, 50],
305
- ...durableData,
306
- ...options,
307
- // Wrap the more friendly onChange callback by listening to onTableChange,
308
- // which will only be triggered when the table key state changes
309
- onTableChange: (action, tableState) => {
310
- if (action === 'propsUpdate') {
311
- return;
312
- }
313
- const state = {
314
- count: tableState.count,
315
- page: tableState.page,
316
- rowsPerPage: tableState.rowsPerPage,
317
- searchText: tableState.searchText,
318
- sortOrder: tableState.sortOrder,
319
- //
320
- filterList: tableState.filterList
321
- };
322
- if (durable) {
323
- const needSaveState = {};
324
- durableKeys.forEach(key => {
325
- needSaveState[key] = state[key];
326
- });
327
- localStorage.setItem(`datatable-durable-${durable}`, JSON.stringify(needSaveState));
328
- }
329
- const stateStr = JSON.stringify(state);
330
- if (stateStr === oldState.current) {
331
- return;
332
- }
333
- oldState.current = stateStr;
334
- if (onChange) {
335
- onChange(state, action);
336
- }
337
- }
338
- };
339
- if (onChange) {
340
- opts.serverSide = true;
341
- }
342
- const props = {
343
- options: opts,
344
- ...rest,
345
- components: {
346
- TableToolbar: CustomToolbar,
347
- TableFooter: WrapTableFooter,
348
- TableFilterList: WrapFilterList,
349
- ...components
350
- }
351
- };
352
- return /*#__PURE__*/_jsx(TableContainer, {
353
- verticalKeyWidth: verticalKeyWidth,
354
- className: clsx({
355
- 'datatable-stripped': stripped,
356
- 'datatable-hide-header': hideTableHeader
357
- }),
358
- style: style,
359
- children: /*#__PURE__*/_jsx(MUIDataTable, {
360
- data: data,
361
- columns: columns,
362
- ...props
363
- })
364
- });
365
- }
366
- ReDataTable.propTypes = {
367
- data: PropTypes.array.isRequired,
368
- columns: PropTypes.array.isRequired,
369
- options: PropTypes.object,
370
- style: PropTypes.object,
371
- locale: PropTypes.string,
372
- loading: PropTypes.bool,
373
- disabled: PropTypes.bool,
374
- customButtons: PropTypes.array,
375
- onChange: PropTypes.oneOfType([PropTypes.func, PropTypes.string]),
376
- stripped: PropTypes.bool,
377
- verticalKeyWidth: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
378
- hideTableHeader: PropTypes.bool,
379
- components: PropTypes.object,
380
- emptyNode: PropTypes.node,
381
- durable: PropTypes.string,
382
- durableKeys: PropTypes.array
383
- };
384
- ReDataTable.defaultProps = {
385
- options: {},
386
- style: {},
387
- locale: 'en',
388
- loading: false,
389
- disabled: false,
390
- customButtons: [],
391
- onChange: '',
392
- stripped: false,
393
- verticalKeyWidth: '',
394
- hideTableHeader: false,
395
- components: {},
396
- emptyNode: '',
397
- durable: '',
398
- durableKeys: ['page', 'rowsPerPage', 'searchText', 'sortOrder']
399
- };
400
- export const getDurableData = key => {
401
- const durableKey = `datatable-durable-${key}`;
402
- let localData = localStorage[durableKey];
403
- if (localData) {
404
- try {
405
- localData = JSON.parse(localData);
406
- } catch (err) {
407
- console.error(`parse durable data error (key:${key}) => `, err);
408
- }
409
- }
410
- return localData || {};
411
- };
412
- const alignCss = css`
413
- .MuiTableCell-head {
414
- [class*='MUIDataTableHeadCell-toolButton'] {
415
- width: 100%;
416
- > [class*='MUIDataTableHeadCell-sortAction'] {
417
- width: 100%;
418
- }
419
- }
420
- &.pc-align-center {
421
- text-align: center;
422
- [class*='MUIDataTableHeadCell-toolButton'] > [class*='MUIDataTableHeadCell-sortAction'] {
423
- justify-content: center;
424
- }
425
- }
426
- &.pc-align-right {
427
- text-align: right;
428
- [class*='MUIDataTableHeadCell-toolButton'] {
429
- margin-right: 0;
430
- padding-right: 0;
431
- & > [class*='MUIDataTableHeadCell-sortAction'] {
432
- justify-content: flex-end;
433
- }
434
- }
435
- }
436
- }
437
- .MuiTableCell-body {
438
- &.pc-align-center {
439
- text-align: center;
440
- }
441
- &.pc-align-right {
442
- text-align: right;
443
- }
444
- }
445
- `;
446
- const TableContainer = styled('div', {
447
- shouldForwardProp: prop => prop !== 'verticalKeyWidth'
448
- })`
449
- &.datatable-hide-header {
450
- thead.MuiTableHead-root {
451
- display: none;
452
- }
453
- }
454
-
455
- td {
456
- &.vertical-align-top {
457
- align-items: flex-start;
458
- }
459
- &.vertical-align-center {
460
- align-items: center;
461
- }
462
- &.vertical-align-bottom {
463
- align-items: flex-end;
464
- }
465
- }
466
-
467
- height: 100%;
468
- > .MuiPaper-root {
469
- display: flex;
470
- flex-direction: column;
471
- height: 100%;
472
- box-shadow: none;
473
- }
474
- ${props => props.theme.breakpoints.down('md')} {
475
- td.MuiTableCell-body {
476
- padding-right: 0;
477
- }
478
- [class*='MUIDataTable-responsiveBase'] {
479
- tr:not([class*='responsiveSimple']) {
480
- td.MuiTableCell-body {
481
- display: flex;
482
- > div {
483
- width: auto;
484
- flex: 1;
485
- &:first-of-type {
486
- font-weight: bold;
487
- font-size: 14px;
488
- width: auto;
489
- flex: 0 0 auto;
490
- padding-right: 16px;
491
- &:empty {
492
- padding-right: 0;
493
- }
494
- }
495
- }
496
- }
497
- }
498
- }
499
- }
500
- ${props => props.theme.breakpoints.up('md')} {
501
- ${alignCss}
502
- }
503
- ${props => props.theme.breakpoints.up('sm')} {
504
- [class*='responsiveSimple'] {
505
- ${alignCss}
506
- }
507
- }
508
-
509
- ${inProps => {
510
- if (inProps.verticalKeyWidth) {
511
- return `
512
- ${inProps.theme.breakpoints.down('md')} {
513
- [class*='MUIDataTable-responsiveBase'] {
514
- tr:not([class*='responsiveSimple']) {
515
- td.MuiTableCell-body {
516
- > div {
517
- &:first-of-type {
518
- width: ${inProps.verticalKeyWidth + (!/\D/.test(inProps.verticalKeyWidth) ? 'px' : '')};
519
- }
520
- }
521
- }
522
- }
523
- }
524
- }
525
- `;
526
- }
527
- return '';
528
- }}
529
-
530
- &.datatable-stripped {
531
- .MuiTableBody-root {
532
- tr:nth-of-type(odd) {
533
- background-color: ${props => props.theme.palette.action.hover};
534
- }
535
- }
536
- }
537
- `;
538
- const FilterLine = styled('div')`
539
- display: flex;
540
- align-items: center;
541
- .toolbar-filter-content {
542
- margin-bottom: 8px;
543
- }
544
- .toolbar-filter-title {
545
- font-weight: 700;
546
- font-size: 14px;
547
- }
548
- `;
549
- function WrapFilterList(props) {
550
- const {
551
- filterLabel
552
- } = useDatatableContext();
553
- const hasFilter = !!props.filterList.filter(e => e.length).length;
554
- if (hasFilter) {
555
- return /*#__PURE__*/_jsxs(FilterLine, {
556
- children: [hasFilter && /*#__PURE__*/_jsx("div", {
557
- className: "toolbar-filter-title",
558
- children: filterLabel
559
- }), /*#__PURE__*/_jsx("div", {
560
- className: "toolbar-filter-content",
561
- children: /*#__PURE__*/_jsx(TableFilterList, {
562
- ...props
563
- })
564
- })]
565
- });
566
- }
567
- return '';
568
- }
569
- WrapFilterList.propTypes = {
570
- filterList: PropTypes.array
571
- };
572
- WrapFilterList.defaultProps = {
573
- filterList: []
574
- };
575
- function WrapTableFooter(props) {
576
- const {
577
- loading,
578
- disabled
579
- } = useDatatableContext();
580
- return /*#__PURE__*/_jsx(FooterContainer, {
581
- children: /*#__PURE__*/_jsx("div", {
582
- className: `datatable-footer ${loading || disabled ? 'datatable-footer-disabled' : ''}`,
583
- children: /*#__PURE__*/_jsx(TableFooter, {
584
- ...props
585
- })
586
- })
587
- });
588
- }
589
- const FooterContainer = styled('div')`
590
- display: flex;
591
- align-items: center;
592
- .datatable-footer {
593
- position: relative;
594
- margin-left: auto;
595
- &.datatable-footer-disabled {
596
- position: relative;
597
- .MuiTablePagination-root {
598
- opacity: 0.6;
599
- }
600
- &:after {
601
- position: absolute;
602
- display: block;
603
- z-index: 2;
604
- width: 100%;
605
- height: 100%;
606
- left: 0;
607
- top: 0;
608
- content: '';
609
- cursor: not-allowed;
610
- }
611
- }
612
- }
613
-
614
- ${props => props.theme.breakpoints.down('sm')} {
615
- .MuiTableCell-footer,
616
- .MuiToolbar-gutters {
617
- padding: 0;
618
- }
619
-
620
- div[variant='standard'] {
621
- margin-left: 4px;
622
- margin-right: 16px;
623
- }
624
-
625
- .MuiTablePagination-actions {
626
- margin-left: 10px;
627
- }
628
- }
629
- `;