@arcblock/ux 2.9.91 → 2.10.0

Sign up to get free protection for your applications and to get access to all the features.
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,42 +1,25 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _propTypes = _interopRequireDefault(require("prop-types"));
8
- var _Typography = _interopRequireDefault(require("@mui/material/Typography"));
9
- var _colors = require("@mui/material/colors");
10
- var _clsx = _interopRequireDefault(require("clsx"));
11
- var _Theme = require("../../Theme");
12
- var _externalLink = require("./external-link");
13
- var _jsxRuntime = require("react/jsx-runtime");
14
- var _templateObject;
15
- const _excluded = ["links", "addons", "dense"];
16
1
  /* eslint-disable react/no-array-index-key */
17
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
18
- function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
19
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
20
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
21
- 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; }
22
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
23
- 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); }
24
- function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
25
- function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
2
+ import PropTypes from 'prop-types';
3
+ import Typography from '@mui/material/Typography';
4
+ import { teal } from '@mui/material/colors';
5
+ import clsx from 'clsx';
6
+ import { styled } from '../../Theme';
7
+ import { NavLink } from './external-link';
8
+ import { jsx as _jsx } from "react/jsx-runtime";
9
+ import { jsxs as _jsxs } from "react/jsx-runtime";
26
10
  function renderGroup(item, index) {
27
- return /*#__PURE__*/(0, _jsxRuntime.jsxs)("li", {
11
+ return /*#__PURE__*/_jsxs("li", {
28
12
  className: "layout-sidebar-group",
29
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
13
+ children: [/*#__PURE__*/_jsx("span", {
30
14
  className: "layout-sidebar-group-title",
31
15
  children: item.title
32
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("ul", {
16
+ }), /*#__PURE__*/_jsx("ul", {
33
17
  children: item.children.map(renderItem)
34
18
  })]
35
- }, "group-".concat(item.title, "-").concat(index));
19
+ }, `group-${item.title}-${index}`);
36
20
  }
37
21
  function renderItem(item, index) {
38
- var _item$children;
39
- if ((_item$children = item.children) !== null && _item$children !== void 0 && _item$children.length) {
22
+ if (item.children?.length) {
40
23
  return renderGroup(item, index);
41
24
  }
42
25
  const {
@@ -48,59 +31,179 @@ function renderItem(item, index) {
48
31
  active
49
32
  } = item;
50
33
  // external = true 时 link active 状态由传入 links 的调用方决定 (适用于 blocklet ui dashboard 的情况)
51
- return /*#__PURE__*/(0, _jsxRuntime.jsx)("li", {
34
+ return /*#__PURE__*/_jsx("li", {
52
35
  className: "layout-sidebar-item",
53
- children: /*#__PURE__*/(0, _jsxRuntime.jsxs)(_externalLink.NavLink, {
36
+ children: /*#__PURE__*/_jsxs(NavLink, {
54
37
  external: external,
55
38
  to: url,
56
- className: _ref => {
57
- let {
58
- isActive
59
- } = _ref;
60
- return (0, _clsx.default)('layout-sidebar-link', {
61
- 'layout-sidebar-link--active': external ? active : isActive
62
- });
63
- },
64
- children: [icon && /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
65
- className: "layout-sidebar-icon ".concat(showBadge ? 'layout-sidebar-badge' : ''),
39
+ className: ({
40
+ isActive
41
+ }) => clsx('layout-sidebar-link', {
42
+ 'layout-sidebar-link--active': external ? active : isActive
43
+ }),
44
+ children: [icon && /*#__PURE__*/_jsx("span", {
45
+ className: `layout-sidebar-icon ${showBadge ? 'layout-sidebar-badge' : ''}`,
66
46
  children: icon
67
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_Typography.default, {
47
+ }), /*#__PURE__*/_jsx(Typography, {
68
48
  component: "span",
69
49
  className: "layout-sidebar-link-text",
70
50
  children: title
71
51
  })]
72
52
  })
73
- }, "".concat(url, "-").concat(index));
53
+ }, `${url}-${index}`);
74
54
  }
75
- function Sidebar(_ref2) {
76
- let {
77
- links,
78
- addons,
79
- dense
80
- } = _ref2,
81
- rest = _objectWithoutProperties(_ref2, _excluded);
82
- return /*#__PURE__*/(0, _jsxRuntime.jsxs)(Root, _objectSpread(_objectSpread({}, rest), {}, {
83
- className: (0, _clsx.default)({
55
+ function Sidebar({
56
+ links,
57
+ addons,
58
+ dense,
59
+ ...rest
60
+ }) {
61
+ return /*#__PURE__*/_jsxs(Root, {
62
+ ...rest,
63
+ className: clsx({
84
64
  'layout-sidebar-dense': dense
85
65
  }),
86
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("ul", {
66
+ children: [/*#__PURE__*/_jsx("ul", {
87
67
  children: links.map(renderItem)
88
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
68
+ }), /*#__PURE__*/_jsx("div", {
89
69
  style: {
90
70
  flex: 1
91
71
  }
92
72
  }), addons]
93
- }));
73
+ });
94
74
  }
95
75
  Sidebar.propTypes = {
96
- links: _propTypes.default.array.isRequired,
97
- addons: _propTypes.default.any,
98
- dense: _propTypes.default.bool
76
+ links: PropTypes.array.isRequired,
77
+ addons: PropTypes.any,
78
+ dense: PropTypes.bool
99
79
  };
100
80
  Sidebar.defaultProps = {
101
81
  addons: null,
102
82
  dense: false
103
83
  };
104
84
  const gradient = 'linear-gradient(32deg, rgba(144, 255, 230, 0.1), rgba(144, 255, 230, 0))';
105
- const Root = (0, _Theme.styled)('div')(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n display: flex;\n flex-direction: column;\n ul {\n list-style: none;\n margin: 0;\n padding: 0;\n }\n .layout-sidebar-link {\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 22px 24px;\n color: ", ";\n text-decoration: none;\n\n &:hover,\n &.layout-sidebar-link--active {\n color: ", ";\n background: ", ";\n border-left-color: ", ";\n }\n }\n .layout-sidebar-icon {\n display: inline-block;\n width: 32px;\n height: 32px;\n > img,\n > svg {\n width: 32px;\n height: 32px;\n }\n }\n .layout-sidebar-badge {\n position: relative;\n &:after {\n content: '';\n position: absolute;\n width: 10px;\n height: 10px;\n border-radius: 10px;\n background-color: #fe4e44;\n right: -2px;\n top: 0;\n box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.3), 0px 0px 20px rgba(0, 0, 0, 0.1);\n }\n }\n .layout-sidebar-link-text {\n margin-top: 8px;\n font-size: 12px;\n font-weight: 500;\n text-align: center;\n text-transform: capitalize;\n letter-spacing: normal;\n }\n /* dense=false \u65F6\u9690\u85CF group title */\n .layout-sidebar-group-title {\n display: none;\n }\n &.layout-sidebar-dense {\n box-sizing: border-box;\n padding: 20px 0;\n font-weight: bold;\n .layout-sidebar-item {\n padding: 0 16px;\n }\n .layout-sidebar-item + .layout-sidebar-item {\n margin-top: 1px;\n }\n .layout-sidebar-link {\n box-sizing: border-box;\n flex-direction: row;\n align-items: center;\n width: 100%;\n padding: 8px;\n &:hover,\n &.layout-sidebar-link--active {\n color: ", ";\n background: ", ";\n border: 0;\n border-radius: 4px;\n }\n }\n .layout-sidebar-icon {\n display: inline-block;\n width: 20px;\n height: 20px;\n margin-right: 8px;\n > img,\n > svg {\n width: 20px;\n height: 20px;\n }\n }\n .layout-sidebar-badge {\n &:after {\n width: 6px;\n height: 6px;\n border-radius: 6px;\n right: -2px;\n top: 0;\n }\n }\n .layout-sidebar-link-text {\n margin-top: 0;\n font-size: 14px;\n line-height: 1;\n }\n .layout-sidebar-group {\n color: ", ";\n .layout-sidebar-group-title {\n display: inline-block;\n padding: 8px 0 8px 24px;\n font-size: 13px;\n text-transform: uppercase;\n }\n }\n .layout-sidebar-group + .layout-sidebar-group,\n .layout-sidebar-group + .layout-sidebar-item,\n .layout-sidebar-item + .layout-sidebar-group {\n margin-top: 16px;\n }\n }\n"])), props => props.theme.palette.text.secondary, props => props.theme.palette.primary.main, gradient, _colors.teal.A700, props => props.theme.palette.grey[900], props => props.theme.palette.grey[100], props => props.theme.palette.text.hint);
106
- var _default = exports.default = Sidebar;
85
+ const Root = styled('div')`
86
+ display: flex;
87
+ flex-direction: column;
88
+ ul {
89
+ list-style: none;
90
+ margin: 0;
91
+ padding: 0;
92
+ }
93
+ .layout-sidebar-link {
94
+ display: flex;
95
+ flex-direction: column;
96
+ align-items: center;
97
+ padding: 22px 24px;
98
+ color: ${props => props.theme.palette.text.secondary};
99
+ text-decoration: none;
100
+
101
+ &:hover,
102
+ &.layout-sidebar-link--active {
103
+ color: ${props => props.theme.palette.primary.main};
104
+ background: ${gradient};
105
+ border-left-color: ${teal.A700};
106
+ }
107
+ }
108
+ .layout-sidebar-icon {
109
+ display: inline-block;
110
+ width: 32px;
111
+ height: 32px;
112
+ > img,
113
+ > svg {
114
+ width: 32px;
115
+ height: 32px;
116
+ }
117
+ }
118
+ .layout-sidebar-badge {
119
+ position: relative;
120
+ &:after {
121
+ content: '';
122
+ position: absolute;
123
+ width: 10px;
124
+ height: 10px;
125
+ border-radius: 10px;
126
+ background-color: #fe4e44;
127
+ right: -2px;
128
+ top: 0;
129
+ box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.3), 0px 0px 20px rgba(0, 0, 0, 0.1);
130
+ }
131
+ }
132
+ .layout-sidebar-link-text {
133
+ margin-top: 8px;
134
+ font-size: 12px;
135
+ font-weight: 500;
136
+ text-align: center;
137
+ text-transform: capitalize;
138
+ letter-spacing: normal;
139
+ }
140
+ /* dense=false 时隐藏 group title */
141
+ .layout-sidebar-group-title {
142
+ display: none;
143
+ }
144
+ &.layout-sidebar-dense {
145
+ box-sizing: border-box;
146
+ padding: 20px 0;
147
+ font-weight: bold;
148
+ .layout-sidebar-item {
149
+ padding: 0 16px;
150
+ }
151
+ .layout-sidebar-item + .layout-sidebar-item {
152
+ margin-top: 1px;
153
+ }
154
+ .layout-sidebar-link {
155
+ box-sizing: border-box;
156
+ flex-direction: row;
157
+ align-items: center;
158
+ width: 100%;
159
+ padding: 8px;
160
+ &:hover,
161
+ &.layout-sidebar-link--active {
162
+ color: ${props => props.theme.palette.grey[900]};
163
+ background: ${props => props.theme.palette.grey[100]};
164
+ border: 0;
165
+ border-radius: 4px;
166
+ }
167
+ }
168
+ .layout-sidebar-icon {
169
+ display: inline-block;
170
+ width: 20px;
171
+ height: 20px;
172
+ margin-right: 8px;
173
+ > img,
174
+ > svg {
175
+ width: 20px;
176
+ height: 20px;
177
+ }
178
+ }
179
+ .layout-sidebar-badge {
180
+ &:after {
181
+ width: 6px;
182
+ height: 6px;
183
+ border-radius: 6px;
184
+ right: -2px;
185
+ top: 0;
186
+ }
187
+ }
188
+ .layout-sidebar-link-text {
189
+ margin-top: 0;
190
+ font-size: 14px;
191
+ line-height: 1;
192
+ }
193
+ .layout-sidebar-group {
194
+ color: ${props => props.theme.palette.text.hint};
195
+ .layout-sidebar-group-title {
196
+ display: inline-block;
197
+ padding: 8px 0 8px 24px;
198
+ font-size: 13px;
199
+ text-transform: uppercase;
200
+ }
201
+ }
202
+ .layout-sidebar-group + .layout-sidebar-group,
203
+ .layout-sidebar-group + .layout-sidebar-item,
204
+ .layout-sidebar-item + .layout-sidebar-group {
205
+ margin-top: 16px;
206
+ }
207
+ }
208
+ `;
209
+ export default Sidebar;
@@ -1,33 +1,87 @@
1
- "use strict";
1
+ import PropTypes from 'prop-types';
2
+ import Button from '@mui/material/IconButton';
3
+ import AppBar from '@mui/material/AppBar';
4
+ import Toolbar from '@mui/material/Toolbar';
5
+ import Box from '@mui/material/Box';
6
+ import Typography from '@mui/material/Typography';
7
+ import Hidden from '@mui/material/Hidden';
8
+ import MenuIcon from '@mui/icons-material/Menu';
9
+ import { Link } from 'react-router-dom';
10
+ import Logo from '../../Logo';
11
+ import { styled } from '../../Theme';
12
+ import { jsx as _jsx } from "react/jsx-runtime";
13
+ import { jsxs as _jsxs } from "react/jsx-runtime";
14
+ const StyledAppBar = styled(AppBar)`
15
+ && {
16
+ z-index: ${props => props.theme.zIndex.drawer};
17
+ background: ${props => props.theme.palette.background.default};
18
+ box-shadow: none;
19
+ top: 0;
20
+ height: auto;
21
+ }
22
+ .header-toolbar {
23
+ background: ${props => props.theme.palette.background.default};
24
+ color: ${props => props.theme.palette.text.primary};
25
+ margin: ${props => props.theme.spacing(1)}px 0;
26
+ }
27
+ .header-link {
28
+ display: flex;
29
+ text-decoration: none;
30
+ flex-shrink: 1;
31
+ overflow: hidden;
32
+ }
33
+ .header-logo {
34
+ margin-right: 20px;
35
+ }
36
+ .header-title {
37
+ display: flex;
38
+ flex-direction: column;
39
+ justify-content: center;
40
+ align-items: flex-start;
41
+ }
42
+ .header-title__primary {
43
+ font-size: 24px;
44
+ font-weight: 800;
45
+ color: ${props => props.theme.typography.color.main};
46
+ text-transform: uppercase;
47
+ display: flex;
48
+ align-items: center;
49
+ }
50
+ .header-title__secondary {
51
+ font-size: 14px;
52
+ line-height: 1.71;
53
+ color: ${props => props.theme.typography.color.gray};
54
+ }
2
55
 
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = Header;
7
- var _propTypes = _interopRequireDefault(require("prop-types"));
8
- var _IconButton = _interopRequireDefault(require("@mui/material/IconButton"));
9
- var _AppBar = _interopRequireDefault(require("@mui/material/AppBar"));
10
- var _Toolbar = _interopRequireDefault(require("@mui/material/Toolbar"));
11
- var _Box = _interopRequireDefault(require("@mui/material/Box"));
12
- var _Typography = _interopRequireDefault(require("@mui/material/Typography"));
13
- var _Hidden = _interopRequireDefault(require("@mui/material/Hidden"));
14
- var _Menu = _interopRequireDefault(require("@mui/icons-material/Menu"));
15
- var _reactRouterDom = require("react-router-dom");
16
- var _Logo = _interopRequireDefault(require("../../Logo"));
17
- var _Theme = require("../../Theme");
18
- var _jsxRuntime = require("react/jsx-runtime");
19
- const _excluded = ["children", "brand", "brandAddon", "description", "addons", "onToggleMenu", "homeUrl", "logo"];
20
- var _templateObject;
21
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
22
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
23
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
24
- 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; }
25
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
26
- 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); }
27
- function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
28
- function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
29
- function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
30
- const StyledAppBar = (0, _Theme.styled)(_AppBar.default)(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n && {\n z-index: ", ";\n background: ", ";\n box-shadow: none;\n top: 0;\n height: auto;\n }\n .header-toolbar {\n background: ", ";\n color: ", ";\n margin: ", "px 0;\n }\n .header-link {\n display: flex;\n text-decoration: none;\n flex-shrink: 1;\n overflow: hidden;\n }\n .header-logo {\n margin-right: 20px;\n }\n .header-title {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n }\n .header-title__primary {\n font-size: 24px;\n font-weight: 800;\n color: ", ";\n text-transform: uppercase;\n display: flex;\n align-items: center;\n }\n .header-title__secondary {\n font-size: 14px;\n line-height: 1.71;\n color: ", ";\n }\n\n .header-addons {\n display: flex;\n justify-content: center;\n align-items: center;\n flex-shrink: 9999999;\n\n .user-addon {\n .header-avatar {\n width: 32px;\n border-radius: 16px;\n height: auto;\n }\n }\n }\n .header-menu {\n display: none;\n }\n ", " {\n .header-title {\n display: none;\n }\n .header-title__primary {\n font-size: 20px;\n }\n .header-menu {\n display: block;\n }\n }\n"])), props => props.theme.zIndex.drawer, props => props.theme.palette.background.default, props => props.theme.palette.background.default, props => props.theme.palette.text.primary, props => props.theme.spacing(1), props => props.theme.typography.color.main, props => props.theme.typography.color.gray, props => props.theme.breakpoints.down('md'));
56
+ .header-addons {
57
+ display: flex;
58
+ justify-content: center;
59
+ align-items: center;
60
+ flex-shrink: 9999999;
61
+
62
+ .user-addon {
63
+ .header-avatar {
64
+ width: 32px;
65
+ border-radius: 16px;
66
+ height: auto;
67
+ }
68
+ }
69
+ }
70
+ .header-menu {
71
+ display: none;
72
+ }
73
+ ${props => props.theme.breakpoints.down('md')} {
74
+ .header-title {
75
+ display: none;
76
+ }
77
+ .header-title__primary {
78
+ font-size: 20px;
79
+ }
80
+ .header-menu {
81
+ display: block;
82
+ }
83
+ }
84
+ `;
31
85
 
32
86
  /*
33
87
  自定义 logo 相关:
@@ -38,79 +92,78 @@ const StyledAppBar = (0, _Theme.styled)(_AppBar.default)(_templateObject || (_te
38
92
  考虑到上述问题, 目前使用 Hidden 组件控制 logo 的显示/隐藏
39
93
  参考: https://blog.patw.me/archives/1820/inline-svg-same-id-and-display-none-issue/
40
94
  */
41
- function Header(_ref) {
42
- let {
43
- children,
44
- brand,
45
- brandAddon,
46
- description,
47
- addons,
48
- onToggleMenu,
49
- homeUrl,
50
- logo
51
- } = _ref,
52
- rest = _objectWithoutProperties(_ref, _excluded);
53
- return /*#__PURE__*/(0, _jsxRuntime.jsx)(StyledAppBar, _objectSpread(_objectSpread({
95
+ export default function Header({
96
+ children,
97
+ brand,
98
+ brandAddon,
99
+ description,
100
+ addons,
101
+ onToggleMenu,
102
+ homeUrl,
103
+ logo,
104
+ ...rest
105
+ }) {
106
+ return /*#__PURE__*/_jsx(StyledAppBar, {
54
107
  position: "sticky",
55
- className: "header"
56
- }, rest), {}, {
57
- children: /*#__PURE__*/(0, _jsxRuntime.jsxs)(_Toolbar.default, {
108
+ className: "header",
109
+ ...rest,
110
+ children: /*#__PURE__*/_jsxs(Toolbar, {
58
111
  disableGutters: false,
59
112
  className: "header-toolbar",
60
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_IconButton.default, {
113
+ children: [/*#__PURE__*/_jsx(Button, {
61
114
  color: "inherit",
62
115
  "aria-label": "open drawer",
63
116
  edge: "start",
64
117
  className: "header-menu",
65
118
  "aira-label": "header menu button",
66
119
  onClick: onToggleMenu,
67
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_Menu.default, {})
68
- }), /*#__PURE__*/(0, _jsxRuntime.jsxs)(_reactRouterDom.Link, {
120
+ children: /*#__PURE__*/_jsx(MenuIcon, {})
121
+ }), /*#__PURE__*/_jsxs(Link, {
69
122
  to: homeUrl,
70
123
  className: "header-link",
71
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_Hidden.default, {
124
+ children: [/*#__PURE__*/_jsx(Hidden, {
72
125
  mdDown: true,
73
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
126
+ children: /*#__PURE__*/_jsx("div", {
74
127
  className: "header-logo",
75
- children: logo || /*#__PURE__*/(0, _jsxRuntime.jsx)(_Logo.default, {
128
+ children: logo || /*#__PURE__*/_jsx(Logo, {
76
129
  showText: false
77
130
  })
78
131
  })
79
- }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
132
+ }), /*#__PURE__*/_jsxs("div", {
80
133
  className: "header-title",
81
- children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)(_Typography.default, {
134
+ children: [/*#__PURE__*/_jsxs(Typography, {
82
135
  component: "h2",
83
136
  noWrap: true,
84
137
  className: "header-title__primary",
85
138
  children: [brand, brandAddon]
86
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_Typography.default, {
139
+ }), /*#__PURE__*/_jsx(Typography, {
87
140
  component: "p",
88
141
  noWrap: true,
89
142
  className: "header-title__secondary",
90
143
  children: description
91
144
  })]
92
145
  })]
93
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_Box.default, {
146
+ }), /*#__PURE__*/_jsx(Box, {
94
147
  flexGrow: 1
95
- }), !!children && /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
148
+ }), !!children && /*#__PURE__*/_jsx("div", {
96
149
  className: "header-children",
97
150
  children: children
98
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
151
+ }), /*#__PURE__*/_jsx("div", {
99
152
  className: "header-addons",
100
153
  children: addons
101
154
  })]
102
155
  })
103
- }));
156
+ });
104
157
  }
105
158
  Header.propTypes = {
106
- onToggleMenu: _propTypes.default.func.isRequired,
107
- brand: _propTypes.default.string.isRequired,
108
- brandAddon: _propTypes.default.object,
109
- description: _propTypes.default.any.isRequired,
110
- children: _propTypes.default.any,
111
- addons: _propTypes.default.any,
112
- homeUrl: _propTypes.default.string,
113
- logo: _propTypes.default.any
159
+ onToggleMenu: PropTypes.func.isRequired,
160
+ brand: PropTypes.string.isRequired,
161
+ brandAddon: PropTypes.object,
162
+ description: PropTypes.any.isRequired,
163
+ children: PropTypes.any,
164
+ addons: PropTypes.any,
165
+ homeUrl: PropTypes.string,
166
+ logo: PropTypes.any
114
167
  };
115
168
  Header.defaultProps = {
116
169
  children: null,