dumi-theme-antd4 0.0.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 (130) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +109 -0
  3. package/dist/builtins/Alert/index.d.ts +6 -0
  4. package/dist/builtins/Alert/index.js +25 -0
  5. package/dist/builtins/BashOSPlatform/android.d.ts +7 -0
  6. package/dist/builtins/BashOSPlatform/android.js +37 -0
  7. package/dist/builtins/BashOSPlatform/index.d.ts +11 -0
  8. package/dist/builtins/BashOSPlatform/index.js +51 -0
  9. package/dist/builtins/BashOSPlatform/linux.d.ts +7 -0
  10. package/dist/builtins/BashOSPlatform/linux.js +60 -0
  11. package/dist/builtins/BashOSPlatform/macos.d.ts +7 -0
  12. package/dist/builtins/BashOSPlatform/macos.js +20 -0
  13. package/dist/builtins/BashOSPlatform/windows.d.ts +7 -0
  14. package/dist/builtins/BashOSPlatform/windows.js +20 -0
  15. package/dist/builtins/BashTabs/index.d.ts +21 -0
  16. package/dist/builtins/BashTabs/index.js +52 -0
  17. package/dist/builtins/HomeBaseLayout/components/Features/index.d.ts +3 -0
  18. package/dist/builtins/HomeBaseLayout/components/Features/index.js +78 -0
  19. package/dist/builtins/HomeBaseLayout/components/Group.d.ts +19 -0
  20. package/dist/builtins/HomeBaseLayout/components/Group.js +89 -0
  21. package/dist/builtins/HomeBaseLayout/index.d.ts +3 -0
  22. package/dist/builtins/HomeBaseLayout/index.js +201 -0
  23. package/dist/builtins/ImagePreview/index.d.ts +3 -0
  24. package/dist/builtins/ImagePreview/index.js +105 -0
  25. package/dist/builtins/InstallDependencies/index.d.ts +9 -0
  26. package/dist/builtins/InstallDependencies/index.js +38 -0
  27. package/dist/builtins/InstallDependencies/npm.d.ts +7 -0
  28. package/dist/builtins/InstallDependencies/npm.js +20 -0
  29. package/dist/builtins/InstallDependencies/pnpm.d.ts +7 -0
  30. package/dist/builtins/InstallDependencies/pnpm.js +22 -0
  31. package/dist/builtins/InstallDependencies/yarn.d.ts +7 -0
  32. package/dist/builtins/InstallDependencies/yarn.js +21 -0
  33. package/dist/common/CommonHelmet.d.ts +2 -0
  34. package/dist/common/CommonHelmet.js +27 -0
  35. package/dist/common/EditLink.d.ts +2 -0
  36. package/dist/common/EditLink.js +24 -0
  37. package/dist/common/GlobalStyles.d.ts +2 -0
  38. package/dist/common/GlobalStyles.js +7 -0
  39. package/dist/common/LastUpdated.d.ts +5 -0
  40. package/dist/common/LastUpdated.js +53 -0
  41. package/dist/common/Loading/index.d.ts +3 -0
  42. package/dist/common/Loading/index.js +67 -0
  43. package/dist/common/PrevAndNext.d.ts +5 -0
  44. package/dist/common/PrevAndNext.js +88 -0
  45. package/dist/common/styles/Common.d.ts +2 -0
  46. package/dist/common/styles/Common.js +16 -0
  47. package/dist/common/styles/DumiDefaultStyleOverride.d.ts +2 -0
  48. package/dist/common/styles/DumiDefaultStyleOverride.js +12 -0
  49. package/dist/common/styles/HeadingAnchor.d.ts +2 -0
  50. package/dist/common/styles/HeadingAnchor.js +17 -0
  51. package/dist/common/styles/Highlight.d.ts +2 -0
  52. package/dist/common/styles/Highlight.js +10 -0
  53. package/dist/common/styles/Markdown.d.ts +2 -0
  54. package/dist/common/styles/Markdown.js +13 -0
  55. package/dist/common/styles/PreviewImage.d.ts +2 -0
  56. package/dist/common/styles/PreviewImage.js +10 -0
  57. package/dist/common/styles/Reset.d.ts +2 -0
  58. package/dist/common/styles/Reset.js +17 -0
  59. package/dist/common/styles/Responsive.d.ts +2 -0
  60. package/dist/common/styles/Responsive.js +10 -0
  61. package/dist/common/styles/SearchBar.d.ts +2 -0
  62. package/dist/common/styles/SearchBar.js +11 -0
  63. package/dist/common/styles/index.d.ts +9 -0
  64. package/dist/common/styles/index.js +9 -0
  65. package/dist/defineThemeConfig/index.d.ts +7 -0
  66. package/dist/defineThemeConfig/index.js +31 -0
  67. package/dist/hooks/useAdditionalThemeConfig.d.ts +6 -0
  68. package/dist/hooks/useAdditionalThemeConfig.js +9 -0
  69. package/dist/hooks/useLocaleValue.d.ts +1 -0
  70. package/dist/hooks/useLocaleValue.js +10 -0
  71. package/dist/hooks/useMenu.d.ts +14 -0
  72. package/dist/hooks/useMenu.js +266 -0
  73. package/dist/hooks/useSiteToken.d.ts +66 -0
  74. package/dist/hooks/useSiteToken.js +105 -0
  75. package/dist/hooks/uselocale.d.ts +5 -0
  76. package/dist/hooks/uselocale.js +7 -0
  77. package/dist/icons/LTRIcon.d.ts +5 -0
  78. package/dist/icons/LTRIcon.js +20 -0
  79. package/dist/icons/RTLIcon.d.ts +5 -0
  80. package/dist/icons/RTLIcon.js +23 -0
  81. package/dist/index.d.ts +4 -0
  82. package/dist/index.js +4 -0
  83. package/dist/layouts/DocLayout/index.d.ts +4 -0
  84. package/dist/layouts/DocLayout/index.js +90 -0
  85. package/dist/layouts/GlobalLayout.d.ts +3 -0
  86. package/dist/layouts/GlobalLayout.js +88 -0
  87. package/dist/layouts/HomePageLayout/index.d.ts +3 -0
  88. package/dist/layouts/HomePageLayout/index.js +7 -0
  89. package/dist/layouts/SidebarLayout/index.d.ts +3 -0
  90. package/dist/layouts/SidebarLayout/index.js +28 -0
  91. package/dist/locales/en-US.json +9 -0
  92. package/dist/locales/zh-CN.json +9 -0
  93. package/dist/slots/Content/DocAnchor.d.ts +7 -0
  94. package/dist/slots/Content/DocAnchor.js +75 -0
  95. package/dist/slots/Content/InViewSuspense.d.ts +8 -0
  96. package/dist/slots/Content/InViewSuspense.js +27 -0
  97. package/dist/slots/Content/index.d.ts +5 -0
  98. package/dist/slots/Content/index.js +118 -0
  99. package/dist/slots/Footer/index.d.ts +3 -0
  100. package/dist/slots/Footer/index.js +75 -0
  101. package/dist/slots/Header/HeaderExtral.d.ts +3 -0
  102. package/dist/slots/Header/HeaderExtral.js +34 -0
  103. package/dist/slots/Header/Logo.d.ts +2 -0
  104. package/dist/slots/Header/Logo.js +48 -0
  105. package/dist/slots/Header/More.d.ts +5 -0
  106. package/dist/slots/Header/More.js +32 -0
  107. package/dist/slots/Header/Navigation.d.ts +6 -0
  108. package/dist/slots/Header/Navigation.js +154 -0
  109. package/dist/slots/Header/SwitchBtn.d.ts +11 -0
  110. package/dist/slots/Header/SwitchBtn.js +85 -0
  111. package/dist/slots/Header/index.d.ts +4 -0
  112. package/dist/slots/Header/index.js +193 -0
  113. package/dist/slots/LangSwitch/index.d.ts +3 -0
  114. package/dist/slots/LangSwitch/index.js +86 -0
  115. package/dist/slots/NotFound/index.d.ts +9 -0
  116. package/dist/slots/NotFound/index.js +25 -0
  117. package/dist/slots/RtlSwitch/index.d.ts +3 -0
  118. package/dist/slots/RtlSwitch/index.js +53 -0
  119. package/dist/slots/Sidebar/index.d.ts +4 -0
  120. package/dist/slots/Sidebar/index.js +108 -0
  121. package/dist/slots/SiteContext.d.ts +9 -0
  122. package/dist/slots/SiteContext.js +7 -0
  123. package/dist/static/style.d.ts +2 -0
  124. package/dist/static/style.js +2 -0
  125. package/dist/styles/variables.less +1 -0
  126. package/dist/types.d.ts +103 -0
  127. package/dist/types.js +1 -0
  128. package/dist/utils.d.ts +24 -0
  129. package/dist/utils.js +112 -0
  130. package/package.json +101 -0
@@ -0,0 +1,78 @@
1
+ import _extends from "@babel/runtime/helpers/esm/extends";
2
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
3
+ import { css } from '@emotion/react';
4
+ import { Carousel, Typography } from 'antd';
5
+ import { useContext } from 'react';
6
+ import useLocaleValue from "../../../../hooks/useLocaleValue";
7
+ import useSiteToken from "../../../../hooks/useSiteToken";
8
+ import SiteContext from "dumi/theme/slots/SiteContext";
9
+ import { jsx as ___EmotionJSX } from "@emotion/react";
10
+ var _ref = process.env.NODE_ENV === "production" ? {
11
+ name: "1khcbj8",
12
+ styles: "display:flex;flex-wrap:wrap;max-width:1208px;margin-inline:auto;box-sizing:border-box;padding-inline:2.5%;column-gap:2.5%;align-items:stretch;text-align:start"
13
+ } : {
14
+ name: "1bmsiea-container",
15
+ styles: "display:flex;flex-wrap:wrap;max-width:1208px;margin-inline:auto;box-sizing:border-box;padding-inline:2.5%;column-gap:2.5%;align-items:stretch;text-align:start;label:container;",
16
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ2tCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENhcm91c2VsLCBUeXBvZ3JhcGh5IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VDb250ZXh0LCB0eXBlIEZDIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZUxvY2FsZVZhbHVlIGZyb20gJy4uLy4uLy4uLy4uL2hvb2tzL3VzZUxvY2FsZVZhbHVlJztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi8uLi8uLi8uLi9zbG90cy9TaXRlQ29udGV4dCc7XG5pbXBvcnQgeyB0eXBlIElGZWF0dXJlIH0gZnJvbSAnLi4vLi4vLi4vLi4vdHlwZXMnO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIHJldHVybiB7XG4gICAgY2Fyb3VzZWw6IGNzc2BcbiAgICAgIC5zbGljay1kb3RzLnNsaWNrLWRvdHMtYm90dG9tIHtcbiAgICAgICAgYm90dG9tOiAtMjJweDtcbiAgICAgICAgbGkge1xuICAgICAgICAgIHdpZHRoOiA2cHg7XG4gICAgICAgICAgaGVpZ2h0OiA2cHg7XG4gICAgICAgICAgYmFja2dyb3VuZDogI2UxZWVmZjtcbiAgICAgICAgICBib3JkZXItcmFkaXVzOiA1MCU7XG4gICAgICAgICAgYnV0dG9uIHtcbiAgICAgICAgICAgIGhlaWdodDogNnB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogI2UxZWVmZjtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgICAgICAgICB9XG4gICAgICAgICAgJi5zbGljay1hY3RpdmUge1xuICAgICAgICAgICAgYmFja2dyb3VuZDogIzRiOWNmZjtcbiAgICAgICAgICAgIGJ1dHRvbiB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICM0YjljZmY7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgYCxcbiAgICBjb250YWluZXI6IGNzc2BcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBmbGV4LXdyYXA6IHdyYXA7XG4gICAgICBtYXgtd2lkdGg6IDEyMDhweDtcbiAgICAgIG1hcmdpbi1pbmxpbmU6IGF1dG87XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgcGFkZGluZy1pbmxpbmU6IDIuNSU7XG4gICAgICBjb2x1bW4tZ2FwOiAyLjUlO1xuICAgICAgYWxpZ24taXRlbXM6IHN0cmV0Y2g7XG4gICAgICB0ZXh0LWFsaWduOiBzdGFydDtcbiAgICBgLFxuICAgIGl0ZW1CYXNlOiBjc3NgXG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgICAgYmFja2dyb3VuZDogJHt0b2tlbi5jb2xvckJnQ29udGFpbmVyfTtcbiAgICAgIGJvcmRlcjogJHt0b2tlbi5saW5lV2lkdGh9cHggc29saWQgJHt0b2tlbi5jb2xvckJvcmRlclNlY29uZGFyeX07XG4gICAgICBib3JkZXItcmFkaXVzOiAke3Rva2VuLmJvcmRlclJhZGl1c0xHfXB4O1xuICAgICAgdHJhbnNpdGlvbjogYWxsICR7dG9rZW4ubW90aW9uRHVyYXRpb25TbG93fTtcbiAgICAgIHBhZGRpbmctYmxvY2s6ICR7dG9rZW4ucGFkZGluZ31weDtcbiAgICAgIHBhZGRpbmctaW5saW5lOiAke3Rva2VuLnBhZGRpbmd9cHg7XG4gICAgICBtYXJnaW4tYmxvY2stZW5kOiAke3Rva2VuLm1hcmdpbn1weDtcbiAgICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYCxcbiAgICBjYXJkSXRlbTogY3NzYFxuICAgICAgd2lkdGg6IDMwJTtcbiAgICAgICY6aG92ZXIge1xuICAgICAgICBib3gtc2hhZG93OiAke3Rva2VuLmJveFNoYWRvd0NhcmR9O1xuICAgICAgfVxuICAgIGAsXG4gICAgc2xpZGVySXRlbTogY3NzYFxuICAgICAgbWFyZ2luOiAwICR7dG9rZW4ubWFyZ2lufXB4O1xuICAgICAgdGV4dC1hbGlnbjogc3RhcnQ7XG4gICAgYFxuICB9O1xufTtcblxuY29uc3QgUmVjb21tZW5kSXRlbSA9ICh7IHRpdGxlLCBkZXRhaWxzLCBpdGVtQ3NzIH06IElGZWF0dXJlKSA9PiB7XG4gIGNvbnN0IHN0eWxlID0gdXNlU3R5bGUoKTtcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY3NzPXtbc3R5bGUuaXRlbUJhc2UsIGl0ZW1Dc3NdfT5cbiAgICAgIDxUeXBvZ3JhcGh5LlRpdGxlIGxldmVsPXs1fT57dGl0bGV9PC9UeXBvZ3JhcGh5LlRpdGxlPlxuICAgICAgPFR5cG9ncmFwaHkuUGFyYWdyYXBoXG4gICAgICAgIHR5cGU9XCJzZWNvbmRhcnlcIlxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZsZXg6ICdhdXRvJ1xuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7ZGV0YWlsc31cbiAgICAgIDwvVHlwb2dyYXBoeS5QYXJhZ3JhcGg+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5jb25zdCBGZWF0dXJlczogRkMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlcyA9IHVzZVN0eWxlKCk7XG4gIGNvbnN0IHsgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBmZWF0dXJlcyA9IHVzZUxvY2FsZVZhbHVlKCdmZWF0dXJlcycpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdj5cbiAgICAgIHtpc01vYmlsZSA/IChcbiAgICAgICAgPENhcm91c2VsIGNzcz17c3R5bGVzLmNhcm91c2VsfT5cbiAgICAgICAgICB7QXJyYXkuaXNBcnJheShmZWF0dXJlcykgJiZcbiAgICAgICAgICAgIGZlYXR1cmVzPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgIDxSZWNvbW1lbmRJdGVtIGtleT17aW5kZXh9IHsuLi5pdGVtfSBpdGVtQ3NzPXtzdHlsZXMuc2xpZGVySXRlbX0gLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L0Nhcm91c2VsPlxuICAgICAgKSA6IChcbiAgICAgICAgPGRpdiBjc3M9e3N0eWxlcy5jb250YWluZXJ9PlxuICAgICAgICAgIHtBcnJheS5pc0FycmF5KGZlYXR1cmVzKSAmJlxuICAgICAgICAgICAgZmVhdHVyZXM/Lm1hcCgoaXRlbSwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgPFJlY29tbWVuZEl0ZW0ga2V5PXtpbmRleH0gey4uLml0ZW19IGl0ZW1Dc3M9e3N0eWxlcy5jYXJkSXRlbX0gLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGZWF0dXJlcztcbiJdfQ== */",
17
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
18
+ };
19
+ var _ref2 = process.env.NODE_ENV === "production" ? {
20
+ name: "pe4q6k",
21
+ styles: ".slick-dots.slick-dots-bottom{bottom:-22px;li{width:6px;height:6px;background:#e1eeff;border-radius:50%;button{height:6px;background:#e1eeff;border-radius:50%;}&.slick-active{background:#4b9cff;button{background:#4b9cff;}}}}"
22
+ } : {
23
+ name: "fjvctd-carousel",
24
+ styles: ".slick-dots.slick-dots-bottom{bottom:-22px;li{width:6px;height:6px;background:#e1eeff;border-radius:50%;button{height:6px;background:#e1eeff;border-radius:50%;}&.slick-active{background:#4b9cff;button{background:#4b9cff;}}}};label:carousel;",
25
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXaUIiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgQ2Fyb3VzZWwsIFR5cG9ncmFwaHkgfSBmcm9tICdhbnRkJztcbmltcG9ydCB7IHVzZUNvbnRleHQsIHR5cGUgRkMgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdXNlTG9jYWxlVmFsdWUgZnJvbSAnLi4vLi4vLi4vLi4vaG9va3MvdXNlTG9jYWxlVmFsdWUnO1xuaW1wb3J0IHVzZVNpdGVUb2tlbiBmcm9tICcuLi8uLi8uLi8uLi9ob29rcy91c2VTaXRlVG9rZW4nO1xuaW1wb3J0IFNpdGVDb250ZXh0IGZyb20gJy4uLy4uLy4uLy4uL3Nsb3RzL1NpdGVDb250ZXh0JztcbmltcG9ydCB7IHR5cGUgSUZlYXR1cmUgfSBmcm9tICcuLi8uLi8uLi8uLi90eXBlcyc7XG5cbmNvbnN0IHVzZVN0eWxlID0gKCkgPT4ge1xuICBjb25zdCB7IHRva2VuIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgcmV0dXJuIHtcbiAgICBjYXJvdXNlbDogY3NzYFxuICAgICAgLnNsaWNrLWRvdHMuc2xpY2stZG90cy1ib3R0b20ge1xuICAgICAgICBib3R0b206IC0yMnB4O1xuICAgICAgICBsaSB7XG4gICAgICAgICAgd2lkdGg6IDZweDtcbiAgICAgICAgICBoZWlnaHQ6IDZweDtcbiAgICAgICAgICBiYWNrZ3JvdW5kOiAjZTFlZWZmO1xuICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgICAgICAgICBidXR0b24ge1xuICAgICAgICAgICAgaGVpZ2h0OiA2cHg7XG4gICAgICAgICAgICBiYWNrZ3JvdW5kOiAjZTFlZWZmO1xuICAgICAgICAgICAgYm9yZGVyLXJhZGl1czogNTAlO1xuICAgICAgICAgIH1cbiAgICAgICAgICAmLnNsaWNrLWFjdGl2ZSB7XG4gICAgICAgICAgICBiYWNrZ3JvdW5kOiAjNGI5Y2ZmO1xuICAgICAgICAgICAgYnV0dG9uIHtcbiAgICAgICAgICAgICAgYmFja2dyb3VuZDogIzRiOWNmZjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICBgLFxuICAgIGNvbnRhaW5lcjogY3NzYFxuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGZsZXgtd3JhcDogd3JhcDtcbiAgICAgIG1heC13aWR0aDogMTIwOHB4O1xuICAgICAgbWFyZ2luLWlubGluZTogYXV0bztcbiAgICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgICBwYWRkaW5nLWlubGluZTogMi41JTtcbiAgICAgIGNvbHVtbi1nYXA6IDIuNSU7XG4gICAgICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAgICAgIHRleHQtYWxpZ246IHN0YXJ0O1xuICAgIGAsXG4gICAgaXRlbUJhc2U6IGNzc2BcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgYWxpZ24taXRlbXM6IHN0cmV0Y2g7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgICBiYWNrZ3JvdW5kOiAke3Rva2VuLmNvbG9yQmdDb250YWluZXJ9O1xuICAgICAgYm9yZGVyOiAke3Rva2VuLmxpbmVXaWR0aH1weCBzb2xpZCAke3Rva2VuLmNvbG9yQm9yZGVyU2Vjb25kYXJ5fTtcbiAgICAgIGJvcmRlci1yYWRpdXM6ICR7dG9rZW4uYm9yZGVyUmFkaXVzTEd9cHg7XG4gICAgICB0cmFuc2l0aW9uOiBhbGwgJHt0b2tlbi5tb3Rpb25EdXJhdGlvblNsb3d9O1xuICAgICAgcGFkZGluZy1ibG9jazogJHt0b2tlbi5wYWRkaW5nfXB4O1xuICAgICAgcGFkZGluZy1pbmxpbmU6ICR7dG9rZW4ucGFkZGluZ31weDtcbiAgICAgIG1hcmdpbi1ibG9jay1lbmQ6ICR7dG9rZW4ubWFyZ2lufXB4O1xuICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBgLFxuICAgIGNhcmRJdGVtOiBjc3NgXG4gICAgICB3aWR0aDogMzAlO1xuICAgICAgJjpob3ZlciB7XG4gICAgICAgIGJveC1zaGFkb3c6ICR7dG9rZW4uYm94U2hhZG93Q2FyZH07XG4gICAgICB9XG4gICAgYCxcbiAgICBzbGlkZXJJdGVtOiBjc3NgXG4gICAgICBtYXJnaW46IDAgJHt0b2tlbi5tYXJnaW59cHg7XG4gICAgICB0ZXh0LWFsaWduOiBzdGFydDtcbiAgICBgXG4gIH07XG59O1xuXG5jb25zdCBSZWNvbW1lbmRJdGVtID0gKHsgdGl0bGUsIGRldGFpbHMsIGl0ZW1Dc3MgfTogSUZlYXR1cmUpID0+IHtcbiAgY29uc3Qgc3R5bGUgPSB1c2VTdHlsZSgpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjc3M9e1tzdHlsZS5pdGVtQmFzZSwgaXRlbUNzc119PlxuICAgICAgPFR5cG9ncmFwaHkuVGl0bGUgbGV2ZWw9ezV9Pnt0aXRsZX08L1R5cG9ncmFwaHkuVGl0bGU+XG4gICAgICA8VHlwb2dyYXBoeS5QYXJhZ3JhcGhcbiAgICAgICAgdHlwZT1cInNlY29uZGFyeVwiXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZmxleDogJ2F1dG8nXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHtkZXRhaWxzfVxuICAgICAgPC9UeXBvZ3JhcGh5LlBhcmFncmFwaD5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmNvbnN0IEZlYXR1cmVzOiBGQyA9ICgpID0+IHtcbiAgY29uc3Qgc3R5bGVzID0gdXNlU3R5bGUoKTtcbiAgY29uc3QgeyBpc01vYmlsZSB9ID0gdXNlQ29udGV4dChTaXRlQ29udGV4dCk7XG4gIGNvbnN0IGZlYXR1cmVzID0gdXNlTG9jYWxlVmFsdWUoJ2ZlYXR1cmVzJyk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAge2lzTW9iaWxlID8gKFxuICAgICAgICA8Q2Fyb3VzZWwgY3NzPXtzdHlsZXMuY2Fyb3VzZWx9PlxuICAgICAgICAgIHtBcnJheS5pc0FycmF5KGZlYXR1cmVzKSAmJlxuICAgICAgICAgICAgZmVhdHVyZXM/Lm1hcCgoaXRlbSwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgPFJlY29tbWVuZEl0ZW0ga2V5PXtpbmRleH0gey4uLml0ZW19IGl0ZW1Dc3M9e3N0eWxlcy5zbGlkZXJJdGVtfSAvPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgIDwvQ2Fyb3VzZWw+XG4gICAgICApIDogKFxuICAgICAgICA8ZGl2IGNzcz17c3R5bGVzLmNvbnRhaW5lcn0+XG4gICAgICAgICAge0FycmF5LmlzQXJyYXkoZmVhdHVyZXMpICYmXG4gICAgICAgICAgICBmZWF0dXJlcz8ubWFwKChpdGVtLCBpbmRleCkgPT4gKFxuICAgICAgICAgICAgICA8UmVjb21tZW5kSXRlbSBrZXk9e2luZGV4fSB7Li4uaXRlbX0gaXRlbUNzcz17c3R5bGVzLmNhcmRJdGVtfSAvPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgIDwvZGl2PlxuICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEZlYXR1cmVzO1xuIl19 */",
26
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
27
+ };
28
+ var useStyle = function useStyle() {
29
+ var _useSiteToken = useSiteToken(),
30
+ token = _useSiteToken.token;
31
+ return {
32
+ carousel: _ref2,
33
+ container: _ref,
34
+ itemBase: /*#__PURE__*/css("display:flex;flex-direction:column;align-items:stretch;text-decoration:none;background:", token.colorBgContainer, ";border:", token.lineWidth, "px solid ", token.colorBorderSecondary, ";border-radius:", token.borderRadiusLG, "px;transition:all ", token.motionDurationSlow, ";padding-block:", token.padding, "px;padding-inline:", token.padding, "px;margin-block-end:", token.margin, "px;box-sizing:border-box;" + (process.env.NODE_ENV === "production" ? "" : ";label:itemBase;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0Q2lCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENhcm91c2VsLCBUeXBvZ3JhcGh5IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VDb250ZXh0LCB0eXBlIEZDIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZUxvY2FsZVZhbHVlIGZyb20gJy4uLy4uLy4uLy4uL2hvb2tzL3VzZUxvY2FsZVZhbHVlJztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi8uLi8uLi8uLi9zbG90cy9TaXRlQ29udGV4dCc7XG5pbXBvcnQgeyB0eXBlIElGZWF0dXJlIH0gZnJvbSAnLi4vLi4vLi4vLi4vdHlwZXMnO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIHJldHVybiB7XG4gICAgY2Fyb3VzZWw6IGNzc2BcbiAgICAgIC5zbGljay1kb3RzLnNsaWNrLWRvdHMtYm90dG9tIHtcbiAgICAgICAgYm90dG9tOiAtMjJweDtcbiAgICAgICAgbGkge1xuICAgICAgICAgIHdpZHRoOiA2cHg7XG4gICAgICAgICAgaGVpZ2h0OiA2cHg7XG4gICAgICAgICAgYmFja2dyb3VuZDogI2UxZWVmZjtcbiAgICAgICAgICBib3JkZXItcmFkaXVzOiA1MCU7XG4gICAgICAgICAgYnV0dG9uIHtcbiAgICAgICAgICAgIGhlaWdodDogNnB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogI2UxZWVmZjtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgICAgICAgICB9XG4gICAgICAgICAgJi5zbGljay1hY3RpdmUge1xuICAgICAgICAgICAgYmFja2dyb3VuZDogIzRiOWNmZjtcbiAgICAgICAgICAgIGJ1dHRvbiB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICM0YjljZmY7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgYCxcbiAgICBjb250YWluZXI6IGNzc2BcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBmbGV4LXdyYXA6IHdyYXA7XG4gICAgICBtYXgtd2lkdGg6IDEyMDhweDtcbiAgICAgIG1hcmdpbi1pbmxpbmU6IGF1dG87XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgcGFkZGluZy1pbmxpbmU6IDIuNSU7XG4gICAgICBjb2x1bW4tZ2FwOiAyLjUlO1xuICAgICAgYWxpZ24taXRlbXM6IHN0cmV0Y2g7XG4gICAgICB0ZXh0LWFsaWduOiBzdGFydDtcbiAgICBgLFxuICAgIGl0ZW1CYXNlOiBjc3NgXG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgICAgYmFja2dyb3VuZDogJHt0b2tlbi5jb2xvckJnQ29udGFpbmVyfTtcbiAgICAgIGJvcmRlcjogJHt0b2tlbi5saW5lV2lkdGh9cHggc29saWQgJHt0b2tlbi5jb2xvckJvcmRlclNlY29uZGFyeX07XG4gICAgICBib3JkZXItcmFkaXVzOiAke3Rva2VuLmJvcmRlclJhZGl1c0xHfXB4O1xuICAgICAgdHJhbnNpdGlvbjogYWxsICR7dG9rZW4ubW90aW9uRHVyYXRpb25TbG93fTtcbiAgICAgIHBhZGRpbmctYmxvY2s6ICR7dG9rZW4ucGFkZGluZ31weDtcbiAgICAgIHBhZGRpbmctaW5saW5lOiAke3Rva2VuLnBhZGRpbmd9cHg7XG4gICAgICBtYXJnaW4tYmxvY2stZW5kOiAke3Rva2VuLm1hcmdpbn1weDtcbiAgICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYCxcbiAgICBjYXJkSXRlbTogY3NzYFxuICAgICAgd2lkdGg6IDMwJTtcbiAgICAgICY6aG92ZXIge1xuICAgICAgICBib3gtc2hhZG93OiAke3Rva2VuLmJveFNoYWRvd0NhcmR9O1xuICAgICAgfVxuICAgIGAsXG4gICAgc2xpZGVySXRlbTogY3NzYFxuICAgICAgbWFyZ2luOiAwICR7dG9rZW4ubWFyZ2lufXB4O1xuICAgICAgdGV4dC1hbGlnbjogc3RhcnQ7XG4gICAgYFxuICB9O1xufTtcblxuY29uc3QgUmVjb21tZW5kSXRlbSA9ICh7IHRpdGxlLCBkZXRhaWxzLCBpdGVtQ3NzIH06IElGZWF0dXJlKSA9PiB7XG4gIGNvbnN0IHN0eWxlID0gdXNlU3R5bGUoKTtcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY3NzPXtbc3R5bGUuaXRlbUJhc2UsIGl0ZW1Dc3NdfT5cbiAgICAgIDxUeXBvZ3JhcGh5LlRpdGxlIGxldmVsPXs1fT57dGl0bGV9PC9UeXBvZ3JhcGh5LlRpdGxlPlxuICAgICAgPFR5cG9ncmFwaHkuUGFyYWdyYXBoXG4gICAgICAgIHR5cGU9XCJzZWNvbmRhcnlcIlxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZsZXg6ICdhdXRvJ1xuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7ZGV0YWlsc31cbiAgICAgIDwvVHlwb2dyYXBoeS5QYXJhZ3JhcGg+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5jb25zdCBGZWF0dXJlczogRkMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlcyA9IHVzZVN0eWxlKCk7XG4gIGNvbnN0IHsgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBmZWF0dXJlcyA9IHVzZUxvY2FsZVZhbHVlKCdmZWF0dXJlcycpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdj5cbiAgICAgIHtpc01vYmlsZSA/IChcbiAgICAgICAgPENhcm91c2VsIGNzcz17c3R5bGVzLmNhcm91c2VsfT5cbiAgICAgICAgICB7QXJyYXkuaXNBcnJheShmZWF0dXJlcykgJiZcbiAgICAgICAgICAgIGZlYXR1cmVzPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgIDxSZWNvbW1lbmRJdGVtIGtleT17aW5kZXh9IHsuLi5pdGVtfSBpdGVtQ3NzPXtzdHlsZXMuc2xpZGVySXRlbX0gLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L0Nhcm91c2VsPlxuICAgICAgKSA6IChcbiAgICAgICAgPGRpdiBjc3M9e3N0eWxlcy5jb250YWluZXJ9PlxuICAgICAgICAgIHtBcnJheS5pc0FycmF5KGZlYXR1cmVzKSAmJlxuICAgICAgICAgICAgZmVhdHVyZXM/Lm1hcCgoaXRlbSwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgPFJlY29tbWVuZEl0ZW0ga2V5PXtpbmRleH0gey4uLml0ZW19IGl0ZW1Dc3M9e3N0eWxlcy5jYXJkSXRlbX0gLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGZWF0dXJlcztcbiJdfQ== */"),
35
+ cardItem: /*#__PURE__*/css("width:30%;&:hover{box-shadow:", token.boxShadowCard, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:cardItem;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRGlCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENhcm91c2VsLCBUeXBvZ3JhcGh5IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VDb250ZXh0LCB0eXBlIEZDIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZUxvY2FsZVZhbHVlIGZyb20gJy4uLy4uLy4uLy4uL2hvb2tzL3VzZUxvY2FsZVZhbHVlJztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi8uLi8uLi8uLi9zbG90cy9TaXRlQ29udGV4dCc7XG5pbXBvcnQgeyB0eXBlIElGZWF0dXJlIH0gZnJvbSAnLi4vLi4vLi4vLi4vdHlwZXMnO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIHJldHVybiB7XG4gICAgY2Fyb3VzZWw6IGNzc2BcbiAgICAgIC5zbGljay1kb3RzLnNsaWNrLWRvdHMtYm90dG9tIHtcbiAgICAgICAgYm90dG9tOiAtMjJweDtcbiAgICAgICAgbGkge1xuICAgICAgICAgIHdpZHRoOiA2cHg7XG4gICAgICAgICAgaGVpZ2h0OiA2cHg7XG4gICAgICAgICAgYmFja2dyb3VuZDogI2UxZWVmZjtcbiAgICAgICAgICBib3JkZXItcmFkaXVzOiA1MCU7XG4gICAgICAgICAgYnV0dG9uIHtcbiAgICAgICAgICAgIGhlaWdodDogNnB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogI2UxZWVmZjtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgICAgICAgICB9XG4gICAgICAgICAgJi5zbGljay1hY3RpdmUge1xuICAgICAgICAgICAgYmFja2dyb3VuZDogIzRiOWNmZjtcbiAgICAgICAgICAgIGJ1dHRvbiB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICM0YjljZmY7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgYCxcbiAgICBjb250YWluZXI6IGNzc2BcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBmbGV4LXdyYXA6IHdyYXA7XG4gICAgICBtYXgtd2lkdGg6IDEyMDhweDtcbiAgICAgIG1hcmdpbi1pbmxpbmU6IGF1dG87XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgcGFkZGluZy1pbmxpbmU6IDIuNSU7XG4gICAgICBjb2x1bW4tZ2FwOiAyLjUlO1xuICAgICAgYWxpZ24taXRlbXM6IHN0cmV0Y2g7XG4gICAgICB0ZXh0LWFsaWduOiBzdGFydDtcbiAgICBgLFxuICAgIGl0ZW1CYXNlOiBjc3NgXG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgICAgYmFja2dyb3VuZDogJHt0b2tlbi5jb2xvckJnQ29udGFpbmVyfTtcbiAgICAgIGJvcmRlcjogJHt0b2tlbi5saW5lV2lkdGh9cHggc29saWQgJHt0b2tlbi5jb2xvckJvcmRlclNlY29uZGFyeX07XG4gICAgICBib3JkZXItcmFkaXVzOiAke3Rva2VuLmJvcmRlclJhZGl1c0xHfXB4O1xuICAgICAgdHJhbnNpdGlvbjogYWxsICR7dG9rZW4ubW90aW9uRHVyYXRpb25TbG93fTtcbiAgICAgIHBhZGRpbmctYmxvY2s6ICR7dG9rZW4ucGFkZGluZ31weDtcbiAgICAgIHBhZGRpbmctaW5saW5lOiAke3Rva2VuLnBhZGRpbmd9cHg7XG4gICAgICBtYXJnaW4tYmxvY2stZW5kOiAke3Rva2VuLm1hcmdpbn1weDtcbiAgICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYCxcbiAgICBjYXJkSXRlbTogY3NzYFxuICAgICAgd2lkdGg6IDMwJTtcbiAgICAgICY6aG92ZXIge1xuICAgICAgICBib3gtc2hhZG93OiAke3Rva2VuLmJveFNoYWRvd0NhcmR9O1xuICAgICAgfVxuICAgIGAsXG4gICAgc2xpZGVySXRlbTogY3NzYFxuICAgICAgbWFyZ2luOiAwICR7dG9rZW4ubWFyZ2lufXB4O1xuICAgICAgdGV4dC1hbGlnbjogc3RhcnQ7XG4gICAgYFxuICB9O1xufTtcblxuY29uc3QgUmVjb21tZW5kSXRlbSA9ICh7IHRpdGxlLCBkZXRhaWxzLCBpdGVtQ3NzIH06IElGZWF0dXJlKSA9PiB7XG4gIGNvbnN0IHN0eWxlID0gdXNlU3R5bGUoKTtcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY3NzPXtbc3R5bGUuaXRlbUJhc2UsIGl0ZW1Dc3NdfT5cbiAgICAgIDxUeXBvZ3JhcGh5LlRpdGxlIGxldmVsPXs1fT57dGl0bGV9PC9UeXBvZ3JhcGh5LlRpdGxlPlxuICAgICAgPFR5cG9ncmFwaHkuUGFyYWdyYXBoXG4gICAgICAgIHR5cGU9XCJzZWNvbmRhcnlcIlxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZsZXg6ICdhdXRvJ1xuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7ZGV0YWlsc31cbiAgICAgIDwvVHlwb2dyYXBoeS5QYXJhZ3JhcGg+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5jb25zdCBGZWF0dXJlczogRkMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlcyA9IHVzZVN0eWxlKCk7XG4gIGNvbnN0IHsgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBmZWF0dXJlcyA9IHVzZUxvY2FsZVZhbHVlKCdmZWF0dXJlcycpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdj5cbiAgICAgIHtpc01vYmlsZSA/IChcbiAgICAgICAgPENhcm91c2VsIGNzcz17c3R5bGVzLmNhcm91c2VsfT5cbiAgICAgICAgICB7QXJyYXkuaXNBcnJheShmZWF0dXJlcykgJiZcbiAgICAgICAgICAgIGZlYXR1cmVzPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgIDxSZWNvbW1lbmRJdGVtIGtleT17aW5kZXh9IHsuLi5pdGVtfSBpdGVtQ3NzPXtzdHlsZXMuc2xpZGVySXRlbX0gLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L0Nhcm91c2VsPlxuICAgICAgKSA6IChcbiAgICAgICAgPGRpdiBjc3M9e3N0eWxlcy5jb250YWluZXJ9PlxuICAgICAgICAgIHtBcnJheS5pc0FycmF5KGZlYXR1cmVzKSAmJlxuICAgICAgICAgICAgZmVhdHVyZXM/Lm1hcCgoaXRlbSwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgPFJlY29tbWVuZEl0ZW0ga2V5PXtpbmRleH0gey4uLml0ZW19IGl0ZW1Dc3M9e3N0eWxlcy5jYXJkSXRlbX0gLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGZWF0dXJlcztcbiJdfQ== */"),
36
+ sliderItem: /*#__PURE__*/css("margin:0 ", token.margin, "px;text-align:start;" + (process.env.NODE_ENV === "production" ? "" : ";label:sliderItem;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRW1CIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENhcm91c2VsLCBUeXBvZ3JhcGh5IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VDb250ZXh0LCB0eXBlIEZDIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZUxvY2FsZVZhbHVlIGZyb20gJy4uLy4uLy4uLy4uL2hvb2tzL3VzZUxvY2FsZVZhbHVlJztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi8uLi8uLi8uLi9zbG90cy9TaXRlQ29udGV4dCc7XG5pbXBvcnQgeyB0eXBlIElGZWF0dXJlIH0gZnJvbSAnLi4vLi4vLi4vLi4vdHlwZXMnO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIHJldHVybiB7XG4gICAgY2Fyb3VzZWw6IGNzc2BcbiAgICAgIC5zbGljay1kb3RzLnNsaWNrLWRvdHMtYm90dG9tIHtcbiAgICAgICAgYm90dG9tOiAtMjJweDtcbiAgICAgICAgbGkge1xuICAgICAgICAgIHdpZHRoOiA2cHg7XG4gICAgICAgICAgaGVpZ2h0OiA2cHg7XG4gICAgICAgICAgYmFja2dyb3VuZDogI2UxZWVmZjtcbiAgICAgICAgICBib3JkZXItcmFkaXVzOiA1MCU7XG4gICAgICAgICAgYnV0dG9uIHtcbiAgICAgICAgICAgIGhlaWdodDogNnB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogI2UxZWVmZjtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgICAgICAgICB9XG4gICAgICAgICAgJi5zbGljay1hY3RpdmUge1xuICAgICAgICAgICAgYmFja2dyb3VuZDogIzRiOWNmZjtcbiAgICAgICAgICAgIGJ1dHRvbiB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICM0YjljZmY7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgYCxcbiAgICBjb250YWluZXI6IGNzc2BcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBmbGV4LXdyYXA6IHdyYXA7XG4gICAgICBtYXgtd2lkdGg6IDEyMDhweDtcbiAgICAgIG1hcmdpbi1pbmxpbmU6IGF1dG87XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgcGFkZGluZy1pbmxpbmU6IDIuNSU7XG4gICAgICBjb2x1bW4tZ2FwOiAyLjUlO1xuICAgICAgYWxpZ24taXRlbXM6IHN0cmV0Y2g7XG4gICAgICB0ZXh0LWFsaWduOiBzdGFydDtcbiAgICBgLFxuICAgIGl0ZW1CYXNlOiBjc3NgXG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgICAgYmFja2dyb3VuZDogJHt0b2tlbi5jb2xvckJnQ29udGFpbmVyfTtcbiAgICAgIGJvcmRlcjogJHt0b2tlbi5saW5lV2lkdGh9cHggc29saWQgJHt0b2tlbi5jb2xvckJvcmRlclNlY29uZGFyeX07XG4gICAgICBib3JkZXItcmFkaXVzOiAke3Rva2VuLmJvcmRlclJhZGl1c0xHfXB4O1xuICAgICAgdHJhbnNpdGlvbjogYWxsICR7dG9rZW4ubW90aW9uRHVyYXRpb25TbG93fTtcbiAgICAgIHBhZGRpbmctYmxvY2s6ICR7dG9rZW4ucGFkZGluZ31weDtcbiAgICAgIHBhZGRpbmctaW5saW5lOiAke3Rva2VuLnBhZGRpbmd9cHg7XG4gICAgICBtYXJnaW4tYmxvY2stZW5kOiAke3Rva2VuLm1hcmdpbn1weDtcbiAgICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgYCxcbiAgICBjYXJkSXRlbTogY3NzYFxuICAgICAgd2lkdGg6IDMwJTtcbiAgICAgICY6aG92ZXIge1xuICAgICAgICBib3gtc2hhZG93OiAke3Rva2VuLmJveFNoYWRvd0NhcmR9O1xuICAgICAgfVxuICAgIGAsXG4gICAgc2xpZGVySXRlbTogY3NzYFxuICAgICAgbWFyZ2luOiAwICR7dG9rZW4ubWFyZ2lufXB4O1xuICAgICAgdGV4dC1hbGlnbjogc3RhcnQ7XG4gICAgYFxuICB9O1xufTtcblxuY29uc3QgUmVjb21tZW5kSXRlbSA9ICh7IHRpdGxlLCBkZXRhaWxzLCBpdGVtQ3NzIH06IElGZWF0dXJlKSA9PiB7XG4gIGNvbnN0IHN0eWxlID0gdXNlU3R5bGUoKTtcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY3NzPXtbc3R5bGUuaXRlbUJhc2UsIGl0ZW1Dc3NdfT5cbiAgICAgIDxUeXBvZ3JhcGh5LlRpdGxlIGxldmVsPXs1fT57dGl0bGV9PC9UeXBvZ3JhcGh5LlRpdGxlPlxuICAgICAgPFR5cG9ncmFwaHkuUGFyYWdyYXBoXG4gICAgICAgIHR5cGU9XCJzZWNvbmRhcnlcIlxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZsZXg6ICdhdXRvJ1xuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7ZGV0YWlsc31cbiAgICAgIDwvVHlwb2dyYXBoeS5QYXJhZ3JhcGg+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5jb25zdCBGZWF0dXJlczogRkMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlcyA9IHVzZVN0eWxlKCk7XG4gIGNvbnN0IHsgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBmZWF0dXJlcyA9IHVzZUxvY2FsZVZhbHVlKCdmZWF0dXJlcycpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdj5cbiAgICAgIHtpc01vYmlsZSA/IChcbiAgICAgICAgPENhcm91c2VsIGNzcz17c3R5bGVzLmNhcm91c2VsfT5cbiAgICAgICAgICB7QXJyYXkuaXNBcnJheShmZWF0dXJlcykgJiZcbiAgICAgICAgICAgIGZlYXR1cmVzPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgIDxSZWNvbW1lbmRJdGVtIGtleT17aW5kZXh9IHsuLi5pdGVtfSBpdGVtQ3NzPXtzdHlsZXMuc2xpZGVySXRlbX0gLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L0Nhcm91c2VsPlxuICAgICAgKSA6IChcbiAgICAgICAgPGRpdiBjc3M9e3N0eWxlcy5jb250YWluZXJ9PlxuICAgICAgICAgIHtBcnJheS5pc0FycmF5KGZlYXR1cmVzKSAmJlxuICAgICAgICAgICAgZmVhdHVyZXM/Lm1hcCgoaXRlbSwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgPFJlY29tbWVuZEl0ZW0ga2V5PXtpbmRleH0gey4uLml0ZW19IGl0ZW1Dc3M9e3N0eWxlcy5jYXJkSXRlbX0gLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGZWF0dXJlcztcbiJdfQ== */")
37
+ };
38
+ };
39
+ var RecommendItem = function RecommendItem(_ref3) {
40
+ var title = _ref3.title,
41
+ details = _ref3.details,
42
+ itemCss = _ref3.itemCss;
43
+ var style = useStyle();
44
+ return ___EmotionJSX("div", {
45
+ css: [style.itemBase, itemCss, process.env.NODE_ENV === "production" ? "" : ";label:RecommendItem;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyRVMiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgQ2Fyb3VzZWwsIFR5cG9ncmFwaHkgfSBmcm9tICdhbnRkJztcbmltcG9ydCB7IHVzZUNvbnRleHQsIHR5cGUgRkMgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdXNlTG9jYWxlVmFsdWUgZnJvbSAnLi4vLi4vLi4vLi4vaG9va3MvdXNlTG9jYWxlVmFsdWUnO1xuaW1wb3J0IHVzZVNpdGVUb2tlbiBmcm9tICcuLi8uLi8uLi8uLi9ob29rcy91c2VTaXRlVG9rZW4nO1xuaW1wb3J0IFNpdGVDb250ZXh0IGZyb20gJy4uLy4uLy4uLy4uL3Nsb3RzL1NpdGVDb250ZXh0JztcbmltcG9ydCB7IHR5cGUgSUZlYXR1cmUgfSBmcm9tICcuLi8uLi8uLi8uLi90eXBlcyc7XG5cbmNvbnN0IHVzZVN0eWxlID0gKCkgPT4ge1xuICBjb25zdCB7IHRva2VuIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgcmV0dXJuIHtcbiAgICBjYXJvdXNlbDogY3NzYFxuICAgICAgLnNsaWNrLWRvdHMuc2xpY2stZG90cy1ib3R0b20ge1xuICAgICAgICBib3R0b206IC0yMnB4O1xuICAgICAgICBsaSB7XG4gICAgICAgICAgd2lkdGg6IDZweDtcbiAgICAgICAgICBoZWlnaHQ6IDZweDtcbiAgICAgICAgICBiYWNrZ3JvdW5kOiAjZTFlZWZmO1xuICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgICAgICAgICBidXR0b24ge1xuICAgICAgICAgICAgaGVpZ2h0OiA2cHg7XG4gICAgICAgICAgICBiYWNrZ3JvdW5kOiAjZTFlZWZmO1xuICAgICAgICAgICAgYm9yZGVyLXJhZGl1czogNTAlO1xuICAgICAgICAgIH1cbiAgICAgICAgICAmLnNsaWNrLWFjdGl2ZSB7XG4gICAgICAgICAgICBiYWNrZ3JvdW5kOiAjNGI5Y2ZmO1xuICAgICAgICAgICAgYnV0dG9uIHtcbiAgICAgICAgICAgICAgYmFja2dyb3VuZDogIzRiOWNmZjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICBgLFxuICAgIGNvbnRhaW5lcjogY3NzYFxuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGZsZXgtd3JhcDogd3JhcDtcbiAgICAgIG1heC13aWR0aDogMTIwOHB4O1xuICAgICAgbWFyZ2luLWlubGluZTogYXV0bztcbiAgICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgICBwYWRkaW5nLWlubGluZTogMi41JTtcbiAgICAgIGNvbHVtbi1nYXA6IDIuNSU7XG4gICAgICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAgICAgIHRleHQtYWxpZ246IHN0YXJ0O1xuICAgIGAsXG4gICAgaXRlbUJhc2U6IGNzc2BcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgYWxpZ24taXRlbXM6IHN0cmV0Y2g7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgICBiYWNrZ3JvdW5kOiAke3Rva2VuLmNvbG9yQmdDb250YWluZXJ9O1xuICAgICAgYm9yZGVyOiAke3Rva2VuLmxpbmVXaWR0aH1weCBzb2xpZCAke3Rva2VuLmNvbG9yQm9yZGVyU2Vjb25kYXJ5fTtcbiAgICAgIGJvcmRlci1yYWRpdXM6ICR7dG9rZW4uYm9yZGVyUmFkaXVzTEd9cHg7XG4gICAgICB0cmFuc2l0aW9uOiBhbGwgJHt0b2tlbi5tb3Rpb25EdXJhdGlvblNsb3d9O1xuICAgICAgcGFkZGluZy1ibG9jazogJHt0b2tlbi5wYWRkaW5nfXB4O1xuICAgICAgcGFkZGluZy1pbmxpbmU6ICR7dG9rZW4ucGFkZGluZ31weDtcbiAgICAgIG1hcmdpbi1ibG9jay1lbmQ6ICR7dG9rZW4ubWFyZ2lufXB4O1xuICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBgLFxuICAgIGNhcmRJdGVtOiBjc3NgXG4gICAgICB3aWR0aDogMzAlO1xuICAgICAgJjpob3ZlciB7XG4gICAgICAgIGJveC1zaGFkb3c6ICR7dG9rZW4uYm94U2hhZG93Q2FyZH07XG4gICAgICB9XG4gICAgYCxcbiAgICBzbGlkZXJJdGVtOiBjc3NgXG4gICAgICBtYXJnaW46IDAgJHt0b2tlbi5tYXJnaW59cHg7XG4gICAgICB0ZXh0LWFsaWduOiBzdGFydDtcbiAgICBgXG4gIH07XG59O1xuXG5jb25zdCBSZWNvbW1lbmRJdGVtID0gKHsgdGl0bGUsIGRldGFpbHMsIGl0ZW1Dc3MgfTogSUZlYXR1cmUpID0+IHtcbiAgY29uc3Qgc3R5bGUgPSB1c2VTdHlsZSgpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjc3M9e1tzdHlsZS5pdGVtQmFzZSwgaXRlbUNzc119PlxuICAgICAgPFR5cG9ncmFwaHkuVGl0bGUgbGV2ZWw9ezV9Pnt0aXRsZX08L1R5cG9ncmFwaHkuVGl0bGU+XG4gICAgICA8VHlwb2dyYXBoeS5QYXJhZ3JhcGhcbiAgICAgICAgdHlwZT1cInNlY29uZGFyeVwiXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZmxleDogJ2F1dG8nXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHtkZXRhaWxzfVxuICAgICAgPC9UeXBvZ3JhcGh5LlBhcmFncmFwaD5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmNvbnN0IEZlYXR1cmVzOiBGQyA9ICgpID0+IHtcbiAgY29uc3Qgc3R5bGVzID0gdXNlU3R5bGUoKTtcbiAgY29uc3QgeyBpc01vYmlsZSB9ID0gdXNlQ29udGV4dChTaXRlQ29udGV4dCk7XG4gIGNvbnN0IGZlYXR1cmVzID0gdXNlTG9jYWxlVmFsdWUoJ2ZlYXR1cmVzJyk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAge2lzTW9iaWxlID8gKFxuICAgICAgICA8Q2Fyb3VzZWwgY3NzPXtzdHlsZXMuY2Fyb3VzZWx9PlxuICAgICAgICAgIHtBcnJheS5pc0FycmF5KGZlYXR1cmVzKSAmJlxuICAgICAgICAgICAgZmVhdHVyZXM/Lm1hcCgoaXRlbSwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgPFJlY29tbWVuZEl0ZW0ga2V5PXtpbmRleH0gey4uLml0ZW19IGl0ZW1Dc3M9e3N0eWxlcy5zbGlkZXJJdGVtfSAvPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgIDwvQ2Fyb3VzZWw+XG4gICAgICApIDogKFxuICAgICAgICA8ZGl2IGNzcz17c3R5bGVzLmNvbnRhaW5lcn0+XG4gICAgICAgICAge0FycmF5LmlzQXJyYXkoZmVhdHVyZXMpICYmXG4gICAgICAgICAgICBmZWF0dXJlcz8ubWFwKChpdGVtLCBpbmRleCkgPT4gKFxuICAgICAgICAgICAgICA8UmVjb21tZW5kSXRlbSBrZXk9e2luZGV4fSB7Li4uaXRlbX0gaXRlbUNzcz17c3R5bGVzLmNhcmRJdGVtfSAvPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgIDwvZGl2PlxuICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEZlYXR1cmVzO1xuIl19 */"]
46
+ }, ___EmotionJSX(Typography.Title, {
47
+ level: 5
48
+ }, title), ___EmotionJSX(Typography.Paragraph, {
49
+ type: "secondary",
50
+ style: {
51
+ flex: 'auto'
52
+ }
53
+ }, details));
54
+ };
55
+ var Features = function Features() {
56
+ var styles = useStyle();
57
+ var _useContext = useContext(SiteContext),
58
+ isMobile = _useContext.isMobile;
59
+ var features = useLocaleValue('features');
60
+ return ___EmotionJSX("div", null, isMobile ? ___EmotionJSX(Carousel, {
61
+ css: styles.carousel
62
+ }, Array.isArray(features) && (features === null || features === void 0 ? void 0 : features.map(function (item, index) {
63
+ return ___EmotionJSX(RecommendItem, _extends({
64
+ key: index
65
+ }, item, {
66
+ itemCss: styles.sliderItem
67
+ }));
68
+ }))) : ___EmotionJSX("div", {
69
+ css: styles.container
70
+ }, Array.isArray(features) && (features === null || features === void 0 ? void 0 : features.map(function (item, index) {
71
+ return ___EmotionJSX(RecommendItem, _extends({
72
+ key: index
73
+ }, item, {
74
+ itemCss: styles.cardItem
75
+ }));
76
+ }))));
77
+ };
78
+ export default Features;
@@ -0,0 +1,19 @@
1
+ import * as React from 'react';
2
+ export interface GroupMaskProps {
3
+ style?: React.CSSProperties;
4
+ children?: React.ReactNode;
5
+ disabled?: boolean;
6
+ }
7
+ export declare function GroupMask({ children, style, disabled }: GroupMaskProps): import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
8
+ export interface GroupProps {
9
+ id?: string;
10
+ title?: React.ReactNode;
11
+ titleColor?: string;
12
+ description?: React.ReactNode;
13
+ children?: React.ReactNode;
14
+ background?: string;
15
+ /** 是否不使用两侧 margin */
16
+ collapse?: boolean;
17
+ decoration?: React.ReactNode;
18
+ }
19
+ export default function Group(props: GroupProps): import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
@@ -0,0 +1,89 @@
1
+ import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
+ import { Typography } from 'antd';
3
+ import * as React from 'react';
4
+ import { useContext } from 'react';
5
+ import useSiteToken from "../../../hooks/useSiteToken";
6
+ import SiteContext from "dumi/theme/slots/SiteContext";
7
+ import { jsx as ___EmotionJSX } from "@emotion/react";
8
+ export function GroupMask(_ref) {
9
+ var children = _ref.children,
10
+ style = _ref.style,
11
+ disabled = _ref.disabled;
12
+ var additionalStyle = disabled ? {} : {
13
+ position: 'relative',
14
+ background: 'rgba(255,255,255,0.1)',
15
+ backdropFilter: 'blur(25px)',
16
+ zIndex: 1
17
+ };
18
+ return ___EmotionJSX("div", {
19
+ className: "site-mask",
20
+ style: _objectSpread(_objectSpread({
21
+ position: 'relative'
22
+ }, style), additionalStyle)
23
+ }, children);
24
+ }
25
+ export default function Group(props) {
26
+ var id = props.id,
27
+ title = props.title,
28
+ titleColor = props.titleColor,
29
+ description = props.description,
30
+ children = props.children,
31
+ decoration = props.decoration,
32
+ background = props.background,
33
+ collapse = props.collapse;
34
+ var _useSiteToken = useSiteToken(),
35
+ token = _useSiteToken.token;
36
+ var _useContext = useContext(SiteContext),
37
+ isMobile = _useContext.isMobile;
38
+ var marginStyle = collapse ? {} : {
39
+ maxWidth: 1208,
40
+ marginInline: 'auto',
41
+ boxSizing: 'border-box',
42
+ paddingInline: isMobile ? token.margin : token.marginXXL
43
+ };
44
+ var childNode = ___EmotionJSX(React.Fragment, null, ___EmotionJSX("div", {
45
+ style: {
46
+ textAlign: 'center'
47
+ }
48
+ }, ___EmotionJSX(Typography.Title, {
49
+ id: id,
50
+ level: 1,
51
+ style: {
52
+ fontWeight: 900,
53
+ color: titleColor,
54
+ // Special for the title
55
+ fontFamily: "AliPuHui, ".concat(token.fontFamily),
56
+ fontSize: isMobile ? token.fontSizeHeading2 : token.fontSizeHeading1
57
+ }
58
+ }, title), ___EmotionJSX(Typography.Paragraph, {
59
+ style: {
60
+ marginBottom: isMobile ? token.marginXXL : token.marginFarXS,
61
+ color: titleColor
62
+ }
63
+ }, description)), ___EmotionJSX("div", {
64
+ style: marginStyle
65
+ }, children ? ___EmotionJSX("div", null, children) : ___EmotionJSX("div", {
66
+ style: {
67
+ borderRadius: token.borderRadiusLG,
68
+ minHeight: 300,
69
+ background: '#e9e9e9'
70
+ }
71
+ })));
72
+ return ___EmotionJSX("div", {
73
+ style: {
74
+ position: 'relative',
75
+ background: background,
76
+ transition: "all ".concat(token.motionDurationSlow)
77
+ }
78
+ }, ___EmotionJSX("div", {
79
+ style: {
80
+ position: 'absolute',
81
+ inset: 0
82
+ }
83
+ }, decoration), ___EmotionJSX(GroupMask, {
84
+ disabled: !!background,
85
+ style: {
86
+ paddingBlock: token.marginFarSM
87
+ }
88
+ }, childNode));
89
+ }
@@ -0,0 +1,3 @@
1
+ import { type FC } from 'react';
2
+ declare const HomeBaseLayout: FC;
3
+ export default HomeBaseLayout;
@@ -0,0 +1,201 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
3
+ import { css } from '@emotion/react';
4
+ import { Button, Space, Typography } from 'antd';
5
+ import { Link, useSearchParams } from 'dumi';
6
+ import React, { useContext } from 'react';
7
+ import useAdditionalThemeConfig from "../../hooks/useAdditionalThemeConfig";
8
+ import useLocaleValue from "../../hooks/useLocaleValue";
9
+ import useSiteToken from "../../hooks/useSiteToken";
10
+ import SiteContext from "dumi/theme/slots/SiteContext";
11
+ import { isExternalLinks } from "../../utils";
12
+ import Features from "./components/Features";
13
+ import { GroupMask } from "./components/Group";
14
+ import { jsx as ___EmotionJSX } from "@emotion/react";
15
+ var bannerConfigDefault = {
16
+ showBanner: true,
17
+ bannerMobileImgUrl: 'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',
18
+ bannerImgUrl: ''
19
+ };
20
+ var _ref = process.env.NODE_ENV === "production" ? {
21
+ name: "eivff4",
22
+ styles: "display:none"
23
+ } : {
24
+ name: "1iadxno-bannerDisplayNone",
25
+ styles: "display:none;label:bannerDisplayNone;",
26
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkC0B","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport SiteContext from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: 1\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: 1\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n            {...({} as any)}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */",
27
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
28
+ };
29
+ var _ref2 = process.env.NODE_ENV === "production" ? {
30
+ name: "4zleql",
31
+ styles: "display:block"
32
+ } : {
33
+ name: "e4uzn-bannerDisplay",
34
+ styles: "display:block;label:bannerDisplay;",
35
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+BsB","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport SiteContext from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: 1\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: 1\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n            {...({} as any)}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */",
36
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
+ };
38
+ var _ref3 = process.env.NODE_ENV === "production" ? {
39
+ name: "od9oaz",
40
+ styles: "position:relative;text-align:center;flex:1"
41
+ } : {
42
+ name: "n73971-mainContent",
43
+ styles: "position:relative;text-align:center;flex:1;label:mainContent;",
44
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0BoB","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport SiteContext from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: 1\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: 1\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n            {...({} as any)}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */",
45
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
46
+ };
47
+ var useStyle = function useStyle() {
48
+ var _useSiteToken = useSiteToken(),
49
+ token = _useSiteToken.token;
50
+ var _useContext = useContext(SiteContext),
51
+ isMobile = _useContext.isMobile;
52
+ return {
53
+ mainContent: _ref3,
54
+ bannerDisplay: _ref2,
55
+ bannerDisplayNone: _ref,
56
+ titleBase: /*#__PURE__*/css("h1&{font-family:AliPuHui,", token.fontFamily, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:titleBase;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqCkB","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport SiteContext from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: 1\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: 1\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n            {...({} as any)}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */"),
57
+ title: isMobile ? /*#__PURE__*/css("h1&{margin-bottom:", token.margin, "px;font-weight:normal;font-size:", token.fontSizeHeading1 + 2, "px;line-height:", token.lineHeightHeading2, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:title;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2CW","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport SiteContext from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: 1\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: 1\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n            {...({} as any)}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */") : /*#__PURE__*/css("h1&{margin-bottom:", token.marginMD, "px;font-weight:900;font-size:68px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:title;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmDW","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport SiteContext from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: 1\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: 1\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n            {...({} as any)}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */")
58
+ };
59
+ };
60
+ var HomeBaseLayout = function HomeBaseLayout() {
61
+ var style = useStyle();
62
+ var _useSiteToken2 = useSiteToken(),
63
+ token = _useSiteToken2.token;
64
+ var _useContext2 = useContext(SiteContext),
65
+ isMobile = _useContext2.isMobile;
66
+ var _useAdditionalThemeCo = useAdditionalThemeConfig(),
67
+ bannerConfig = _useAdditionalThemeCo.bannerConfig,
68
+ name = _useAdditionalThemeCo.name;
69
+ var actions = useLocaleValue('actions');
70
+ var title = useLocaleValue('title');
71
+ var description = useLocaleValue('description');
72
+ var _useSearchParams = useSearchParams(),
73
+ _useSearchParams2 = _slicedToArray(_useSearchParams, 1),
74
+ searchParams = _useSearchParams2[0];
75
+
76
+ // 如果配置了 bannerImgUrl 字段,展示配置图片,否则展示 ant-design 默认 banner 视频
77
+ var _Object$assign = Object.assign(bannerConfigDefault, bannerConfig),
78
+ showBanner = _Object$assign.showBanner,
79
+ bannerImgUrl = _Object$assign.bannerImgUrl,
80
+ bannerMobileImgUrl = _Object$assign.bannerMobileImgUrl;
81
+ var bannerContent = bannerImgUrl ? ___EmotionJSX("img", {
82
+ src: bannerImgUrl,
83
+ style: {
84
+ width: '100%',
85
+ maxWidth: '100%'
86
+ },
87
+ alt: ""
88
+ }) : ___EmotionJSX(React.Fragment, null, ___EmotionJSX("div", {
89
+ style: {
90
+ backgroundImage: 'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',
91
+ flex: 'auto',
92
+ backgroundRepeat: 'repeat-x',
93
+ backgroundPosition: '100% 0',
94
+ backgroundSize: 'auto 100%'
95
+ }
96
+ }), ___EmotionJSX("video", {
97
+ style: {
98
+ height: '100%',
99
+ objectFit: 'contain'
100
+ },
101
+ autoPlay: true,
102
+ muted: true,
103
+ loop: true
104
+ }, ___EmotionJSX("source", {
105
+ src: "https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ",
106
+ type: "video/webm"
107
+ }), ___EmotionJSX("source", {
108
+ src: "https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ",
109
+ type: "video/mp4"
110
+ })), ___EmotionJSX("div", {
111
+ style: {
112
+ backgroundImage: 'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',
113
+ flex: 'auto',
114
+ backgroundRepeat: 'repeat-x',
115
+ backgroundPosition: '0 0',
116
+ backgroundSize: 'auto 100%',
117
+ marginLeft: -1
118
+ }
119
+ }));
120
+ return ___EmotionJSX("div", {
121
+ css: style.mainContent
122
+ }, isMobile ? ___EmotionJSX("img", {
123
+ src: bannerMobileImgUrl,
124
+ style: {
125
+ width: '100%',
126
+ maxWidth: '100%',
127
+ display: "".concat(showBanner ? 'inline-block' : 'none', " "),
128
+ opacity: 1
129
+ },
130
+ alt: ""
131
+ }) : ___EmotionJSX("div", {
132
+ style: {
133
+ height: bannerConfig ? 'auto' : 320,
134
+ background: '#77C6FF',
135
+ display: "".concat(showBanner ? 'flex' : 'none', " "),
136
+ flexWrap: 'nowrap',
137
+ justifyContent: 'center',
138
+ opacity: 1
139
+ }
140
+ }, bannerContent), ___EmotionJSX("div", {
141
+ style: {
142
+ position: 'relative'
143
+ }
144
+ }, ___EmotionJSX(GroupMask, {
145
+ style: {
146
+ textAlign: 'center',
147
+ paddingTop: token.marginFar - 16,
148
+ paddingBottom: token.marginFarSM
149
+ }
150
+ }, ___EmotionJSX("img", {
151
+ style: {
152
+ position: 'absolute',
153
+ left: isMobile ? -120 : 0,
154
+ top: 0,
155
+ width: 240
156
+ },
157
+ src: "https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg",
158
+ alt: "bg"
159
+ }), ___EmotionJSX("img", {
160
+ style: {
161
+ position: 'absolute',
162
+ right: isMobile ? 0 : 120,
163
+ top: 0,
164
+ width: 240
165
+ },
166
+ src: "https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg",
167
+ alt: "bg"
168
+ }), ___EmotionJSX(Typography.Title, {
169
+ level: 1,
170
+ css: [style.titleBase, style.title, process.env.NODE_ENV === "production" ? "" : ";label:HomeBaseLayout;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoKsC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport SiteContext from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: 1\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: 1\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n            {...({} as any)}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */"]
171
+ }, title || name), ___EmotionJSX(Typography.Paragraph, {
172
+ style: {
173
+ fontSize: token.fontSizeHeading5,
174
+ lineHeight: token.lineHeightHeading5,
175
+ marginBottom: token.marginMD * 2
176
+ }
177
+ }, ___EmotionJSX("div", null, description)), ___EmotionJSX(Space, {
178
+ size: "middle",
179
+ style: {
180
+ marginBottom: token.marginFar
181
+ }
182
+ }, actions === null || actions === void 0 ? void 0 : actions.map(function (_ref4) {
183
+ var link = _ref4.link,
184
+ text = _ref4.text,
185
+ type = _ref4.type;
186
+ return isExternalLinks(link) ? ___EmotionJSX(Button, {
187
+ size: "large",
188
+ type: type,
189
+ href: link,
190
+ target: "_blank",
191
+ key: link
192
+ }, text) : ___EmotionJSX(Link, {
193
+ to: "".concat(link).concat(link.search(/\?/) === -1 ? '?' : '&').concat(searchParams.toString()),
194
+ key: link
195
+ }, ___EmotionJSX(Button, {
196
+ size: "large",
197
+ type: type
198
+ }, text));
199
+ })), ___EmotionJSX(Features, null))));
200
+ };
201
+ export default HomeBaseLayout;
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ declare const ImagePreview: React.FC;
3
+ export default ImagePreview;