@ahooks.js/dumi-theme-antd 0.1.4 → 0.1.6

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.
package/README.md CHANGED
@@ -33,6 +33,13 @@ pnpm run docs
33
33
 
34
34
  Thank you to all the people who already contributed to `@ahooks.js/dumi-theme-antd` !
35
35
 
36
+ ## Publish
37
+
38
+ ```bash
39
+ npm login --registry=https://registry.npmjs.org/
40
+ npm publish
41
+ ```
42
+
36
43
  ## LICENSE
37
44
 
38
45
  MIT
@@ -4,7 +4,7 @@ export interface GroupMaskProps {
4
4
  children?: React.ReactNode;
5
5
  disabled?: boolean;
6
6
  }
7
- export declare function GroupMask({ children, style, disabled }: GroupMaskProps): import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
7
+ export declare function GroupMask({ children, style, disabled }: GroupMaskProps): import("@emotion/react/jsx-runtime").JSX.Element;
8
8
  export interface GroupProps {
9
9
  id?: string;
10
10
  title?: React.ReactNode;
@@ -16,4 +16,4 @@ export interface GroupProps {
16
16
  collapse?: boolean;
17
17
  decoration?: React.ReactNode;
18
18
  }
19
- export default function Group(props: GroupProps): import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
19
+ export default function Group(props: GroupProps): import("@emotion/react/jsx-runtime").JSX.Element;
@@ -5,5 +5,5 @@ interface InstallProps {
5
5
  bun?: string;
6
6
  [key: string]: string | undefined;
7
7
  }
8
- declare const InstallDependencies: (props: InstallProps) => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
8
+ declare const InstallDependencies: (props: InstallProps) => import("@emotion/react/jsx-runtime").JSX.Element;
9
9
  export default InstallDependencies;
@@ -1,2 +1,2 @@
1
- declare const CommonHelmet: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const CommonHelmet: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default CommonHelmet;
@@ -1,2 +1,2 @@
1
- declare const GlobalStyles: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const GlobalStyles: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default GlobalStyles;
@@ -1,2 +1,2 @@
1
- declare const _default: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const _default: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default _default;
@@ -1,2 +1,2 @@
1
- declare const _default: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const _default: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default _default;
@@ -1,2 +1,2 @@
1
- declare const _default: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const _default: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default _default;
@@ -1,2 +1,2 @@
1
- declare const _default: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const _default: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default _default;
@@ -1,2 +1,2 @@
1
- declare const _default: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const _default: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default _default;
@@ -1,2 +1,2 @@
1
- declare const _default: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const _default: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default _default;
@@ -1,2 +1,2 @@
1
- declare const _default: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const _default: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default _default;
@@ -1,2 +1,2 @@
1
- declare const _default: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const _default: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default _default;
@@ -1,2 +1,2 @@
1
- declare const _default: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const _default: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default _default;
@@ -1,2 +1,2 @@
1
- declare const Logo: () => import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
1
+ declare const Logo: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
2
  export default Logo;
@@ -3,4 +3,4 @@ export interface NavigationProps {
3
3
  isMobile: boolean;
4
4
  responsive: IResponsive;
5
5
  }
6
- export default function Navigation({ isMobile, responsive }: NavigationProps): import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
6
+ export default function Navigation({ isMobile, responsive }: NavigationProps): import("@emotion/react/jsx-runtime").JSX.Element;
@@ -8,4 +8,4 @@ export interface LangBtnProps {
8
8
  pure?: boolean;
9
9
  onClick?: React.MouseEventHandler;
10
10
  }
11
- export default function SwitchBtn({ label1, label2, tooltip1, tooltip2, value, pure, onClick }: LangBtnProps): import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
11
+ export default function SwitchBtn({ label1, label2, tooltip1, tooltip2, value, pure, onClick }: LangBtnProps): import("@emotion/react/jsx-runtime").JSX.Element;
@@ -19,16 +19,16 @@ var _ref = process.env.NODE_ENV === "production" ? {
19
19
  } : {
20
20
  name: "iaxhd9-mobileMenu",
21
21
  styles: "position:fixed;z-index:2;bottom:100px;right:20px;cursor:pointer;label:mobileMenu;",
22
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnSW1CIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVub3JkZXJlZExpc3RPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEFmZml4LCBDb2wsIENvbmZpZ1Byb3ZpZGVyLCBNZW51IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VTaWRlYmFyRGF0YSB9IGZyb20gJ2R1bWknO1xuaW1wb3J0IE1vYmlsZU1lbnUgZnJvbSAncmMtZHJhd2VyJztcbmltcG9ydCAncmMtZHJhd2VyL2Fzc2V0cy9pbmRleC5jc3MnO1xuaW1wb3J0IFJlYWN0LCB7IEZDLCB1c2VDYWxsYmFjaywgdXNlQ29udGV4dCwgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB1c2VBZmZpeFRvcCBmcm9tICcuLi8uLi9ob29rcy91c2VBZmZpeFRvcCc7XG5pbXBvcnQgdXNlTWVudSBmcm9tICcuLi8uLi9ob29rcy91c2VNZW51JztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi9TaXRlQ29udGV4dCc7XG5cbmludGVyZmFjZSBTaWRlYmFyU3RhdGUge1xuICBtb2JpbGVNZW51VmlzaWJsZTogYm9vbGVhbjtcbn1cblxuY29uc3QgdXNlU3R5bGUgPSAoKSA9PiB7XG4gIGNvbnN0IHsgdG9rZW4gfSA9IHVzZVNpdGVUb2tlbigpO1xuXG4gIGNvbnN0IHsgYW50Q2xzLCBmb250RmFtaWx5LCBjb2xvclNwbGl0IH0gPSB0b2tlbjtcblxuICByZXR1cm4ge1xuICAgIGFzaWRlQ29udGFpbmVyOiBjc3NgXG4gICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgcGFkZGluZy1ib3R0b206IDQ4cHg7XG4gICAgICBmb250LWZhbWlseTogQXZlbmlyLCAke2ZvbnRGYW1pbHl9LCBzYW5zLXNlcmlmO1xuXG4gICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gICAgICAgICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUgaDQsXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbSBhIHtcbiAgICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgICAgIGZvbnQtc2l6ZTogMTRweDtcbiAgICAgICAgICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cCA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtdGl0bGUge1xuICAgICAgICAgIG1hcmdpbi10b3A6IDE2cHg7XG4gICAgICAgICAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgICAgICAgICBmb250LXNpemU6IDEzcHg7XG5cbiAgICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgICAgICAgICB0b3A6IDEycHg7XG4gICAgICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgICAgIHdpZHRoOiBjYWxjKDEwMCUgLSAyMHB4KTtcbiAgICAgICAgICAgIGhlaWdodDogMXB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogJHtjb2xvclNwbGl0fTtcbiAgICAgICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUsXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlLFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0XG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLFxuICAgICAgICAgICYke2FudENsc30tbWVudS1pbmxpbmVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXBcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgcGFkZGluZy1sZWZ0OiA0MHB4ICFpbXBvcnRhbnQ7XG5cbiAgICAgICAgICAke2FudENsc30tcm93LXJ0bCAmIHtcbiAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDQwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgIHBhZGRpbmctbGVmdDogMTZweCAhaW1wb3J0YW50O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIC8vIE5lc3QgQ2F0ZWdvcnkgPiBUeXBlID4gQXJ0aWNsZVxuICAgICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi1sZWZ0OiA0cHg7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDYwcHg7XG5cbiAgICAgICAgICAgICR7YW50Q2xzfS1yb3ctcnRsICYge1xuICAgICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA2MHB4O1xuICAgICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDE2cHg7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0ID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDgwcHggIWltcG9ydGFudDtcblxuICAgICAgICAgICAgJHthbnRDbHN9LXJvdy1ydGwgJiB7XG4gICAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDgwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiAxNnB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cDpmaXJzdC1vZi10eXBlIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGFbZGlzYWJsZWRdIHtcbiAgICAgICAgY29sb3I6ICNjY2M7XG4gICAgICB9XG5cbiAgICAgIC5jaGluZXNlIHtcbiAgICAgICAgbWFyZ2luLWxlZnQ6IDZweDtcbiAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgZm9udC1zaXplOiAxMnB4O1xuICAgICAgICBvcGFjaXR5OiAwLjY3O1xuICAgICAgfVxuICAgIGAsXG4gICAgbWFpbk1lbnU6IGNzc2BcbiAgICAgIHotaW5kZXg6IDE7XG5cbiAgICAgIC5tYWluLW1lbnUtaW5uZXIge1xuICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGhlaWdodDogMTAwJTtcbiAgICAgICAgbWF4LWhlaWdodDogMTAwdmg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICB9XG5cbiAgICAgICY6aG92ZXIgLm1haW4tbWVudS1pbm5lciB7XG4gICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICB9XG4gICAgYCxcbiAgICBtb2JpbGVNZW51OiBjc3NgXG4gICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICB6LWluZGV4OiAyO1xuICAgICAgYm90dG9tOiAxMDBweDtcbiAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IFNpZGViYXI6IEZDID0gKCkgPT4ge1xuICBjb25zdCBbc2lkZWJhclN0YXRlLCBzZXRTaWRlYmFyU3RhdGVdID0gdXNlU3RhdGU8U2lkZWJhclN0YXRlPih7IG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZSB9KTtcbiAgY29uc3Qgc2lkZWJhckRhdGEgPSB1c2VTaWRlYmFyRGF0YSgpO1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7XG4gICAgdG9rZW46IHsgY29sb3JCZ0NvbnRhaW5lciB9XG4gIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyB0aGVtZSwgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBbbWVudUl0ZW1zLCBzZWxlY3RlZEtleV0gPSB1c2VNZW51KCk7XG5cbiAgY29uc3QgaXNEYXJrID0gdGhlbWUuaW5jbHVkZXMoJ2RhcmsnKTtcblxuICBjb25zdCBoYW5kbGVTaG93TW9iaWxlTWVudSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTaWRlYmFyU3RhdGUoKHByZXYpID0+ICh7XG4gICAgICAuLi5wcmV2LFxuICAgICAgbW9iaWxlTWVudVZpc2libGU6IHRydWVcbiAgICB9KSk7XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZU1vYmlsZU1lbnUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0U2lkZWJhclN0YXRlKChwcmV2KSA9PiAoe1xuICAgICAgLi4ucHJldixcbiAgICAgIG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZVxuICAgIH0pKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBoYW5kbGVDbG9zZU1vYmlsZU1lbnUoKTtcbiAgICB9XG4gIH0sIFtpc01vYmlsZSwgaGFuZGxlQ2xvc2VNb2JpbGVNZW51XSk7XG5cbiAgY29uc3QgeyBtb2JpbGVNZW51VmlzaWJsZSB9ID0gc2lkZWJhclN0YXRlO1xuICBjb25zdCBhZmZpeFRvcCA9IHVzZUFmZml4VG9wKCk7XG5cbiAgY29uc3QgbWVudUNoaWxkID0gKFxuICAgIDxDb25maWdQcm92aWRlclxuICAgICAgdGhlbWU9e3tcbiAgICAgICAgY29tcG9uZW50czoge1xuICAgICAgICAgIE1lbnU6IHtcbiAgICAgICAgICAgIGl0ZW1CZzogY29sb3JCZ0NvbnRhaW5lclxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfX1cbiAgICA+XG4gICAgICA8TWVudVxuICAgICAgICBpdGVtcz17bWVudUl0ZW1zfVxuICAgICAgICBpbmxpbmVJbmRlbnQ9ezMwfVxuICAgICAgICBjc3M9e3N0eWxlcy5hc2lkZUNvbnRhaW5lcn1cbiAgICAgICAgbW9kZT1cImlubGluZVwiXG4gICAgICAgIHRoZW1lPXtpc0RhcmsgPyAnZGFyaycgOiAnbGlnaHQnfVxuICAgICAgICBzZWxlY3RlZEtleXM9e1tzZWxlY3RlZEtleV19XG4gICAgICAgIGRlZmF1bHRPcGVuS2V5cz17c2lkZWJhckRhdGE/Lm1hcCgoeyB0aXRsZSB9KSA9PiB0aXRsZSkuZmlsdGVyKChpdGVtKSA9PiBpdGVtKSBhcyBzdHJpbmdbXX1cbiAgICAgIC8+XG4gICAgPC9Db25maWdQcm92aWRlcj5cbiAgKTtcblxuICByZXR1cm4gaXNNb2JpbGUgPyAoXG4gICAgPFJlYWN0LkZyYWdtZW50PlxuICAgICAgPE1vYmlsZU1lbnVcbiAgICAgICAga2V5PVwibW9iaWxlLW1lbnVcIlxuICAgICAgICBjb250ZW50V3JhcHBlclN0eWxlPXt7XG4gICAgICAgICAgd2lkdGg6ICczMDBweCdcbiAgICAgICAgfX1cbiAgICAgICAgb3Blbj17bW9iaWxlTWVudVZpc2libGV9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlTW9iaWxlTWVudX1cbiAgICAgID5cbiAgICAgICAge21lbnVDaGlsZH1cbiAgICAgIDwvTW9iaWxlTWVudT5cbiAgICAgIHsobWVudUl0ZW1zID8/IFtdKS5sZW5ndGggPiAxID8gKFxuICAgICAgICA8ZGl2IGNzcz17c3R5bGVzLm1vYmlsZU1lbnV9IG9uQ2xpY2s9e2hhbmRsZVNob3dNb2JpbGVNZW51fT5cbiAgICAgICAgICA8VW5vcmRlcmVkTGlzdE91dGxpbmVkIC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgKSA6IG51bGx9XG4gICAgPC9SZWFjdC5GcmFnbWVudD5cbiAgKSA6IChcbiAgICA8Q29sIHh4bD17NH0geGw9ezV9IGxnPXs2fSBtZD17Nn0gc209ezI0fSB4cz17MjR9IGNzcz17c3R5bGVzLm1haW5NZW51fT5cbiAgICAgIDxBZmZpeCBvZmZzZXRUb3A9e2FmZml4VG9wfT5cbiAgICAgICAgPHNlY3Rpb24gY2xhc3NOYW1lPVwibWFpbi1tZW51LWlubmVyXCI+e21lbnVDaGlsZH08L3NlY3Rpb24+XG4gICAgICA8L0FmZml4PlxuICAgIDwvQ29sPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgU2lkZWJhcjtcbiJdfQ== */",
22
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoImB","file":"index.tsx","sourcesContent":["import { UnorderedListOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Col, ConfigProvider, Menu } from 'antd';\nimport { useSidebarData } from 'dumi';\nimport MobileMenu from 'rc-drawer';\nimport 'rc-drawer/assets/index.css';\nimport React, { FC, useCallback, useContext, useEffect, useState } from 'react';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useMenu from '../../hooks/useMenu';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport SiteContext from '../SiteContext';\n\ninterface SidebarState {\n  mobileMenuVisible: boolean;\n}\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls, fontFamily, colorSplit } = token;\n\n  return {\n    asideContainer: css`\n      min-height: 100%;\n      padding-bottom: 48px;\n      font-family: Avenir, ${fontFamily}, sans-serif;\n\n      &${antCls}-menu-inline {\n        user-select: none;\n        ${antCls}-menu-submenu-title h4,\n        > ${antCls}-menu-item,\n        ${antCls}-menu-item a {\n          overflow: hidden;\n          font-size: 14px;\n          text-overflow: ellipsis;\n        }\n\n        > ${antCls}-menu-item-group > ${antCls}-menu-item-group-title {\n          margin-top: 16px;\n          margin-bottom: 16px;\n          font-size: 13px;\n\n          &::after {\n            position: relative;\n            top: 12px;\n            display: block;\n            width: calc(100% - 20px);\n            height: 1px;\n            background: ${colorSplit};\n            content: '';\n          }\n        }\n\n        > ${antCls}-menu-item,\n          > ${antCls}-menu-submenu\n          > ${antCls}-menu-submenu-title,\n          > ${antCls}-menu-item-group\n          > ${antCls}-menu-item-group-title,\n          > ${antCls}-menu-item-group\n          > ${antCls}-menu-item-group-list\n          > ${antCls}-menu-item,\n          &${antCls}-menu-inline\n          > ${antCls}-menu-item-group\n          > ${antCls}-menu-item-group-list\n          > ${antCls}-menu-item {\n          padding-left: 40px !important;\n\n          ${antCls}-row-rtl & {\n            padding-right: 40px !important;\n            padding-left: 16px !important;\n          }\n        }\n\n        // Nest Category > Type > Article\n        &${antCls}-menu-inline {\n          ${antCls}-menu-item-group-title {\n            margin-left: 4px;\n            padding-left: 60px;\n\n            ${antCls}-row-rtl & {\n              padding-right: 60px;\n              padding-left: 16px;\n            }\n          }\n\n          ${antCls}-menu-item-group-list > ${antCls}-menu-item {\n            padding-left: 80px !important;\n\n            ${antCls}-row-rtl & {\n              padding-right: 80px !important;\n              padding-left: 16px !important;\n            }\n          }\n        }\n\n        ${antCls}-menu-item-group:first-of-type {\n          ${antCls}-menu-item-group-title {\n            margin-top: 0;\n          }\n        }\n      }\n\n      a[disabled] {\n        color: #ccc;\n      }\n\n      .chinese {\n        margin-left: 6px;\n        font-weight: normal;\n        font-size: 12px;\n        opacity: 0.67;\n      }\n    `,\n    mainMenu: css`\n      z-index: 1;\n\n      .main-menu-affix {\n        height: 100%;\n      }\n\n      .main-menu-inner {\n        position: sticky;\n        top: 0;\n        height: 100%;\n        max-height: 100vh;\n        overflow: hidden;\n      }\n\n      &:hover .main-menu-inner {\n        overflow-y: auto;\n      }\n    `,\n    mobileMenu: css`\n      position: fixed;\n      z-index: 2;\n      bottom: 100px;\n      right: 20px;\n      cursor: pointer;\n    `\n  };\n};\n\nconst Sidebar: FC = () => {\n  const [sidebarState, setSidebarState] = useState<SidebarState>({ mobileMenuVisible: false });\n  const sidebarData = useSidebarData();\n  const styles = useStyle();\n  const {\n    token: { colorBgContainer }\n  } = useSiteToken();\n  const { theme, isMobile } = useContext(SiteContext);\n  const [menuItems, selectedKey] = useMenu();\n\n  const isDark = theme.includes('dark');\n\n  const handleShowMobileMenu = useCallback(() => {\n    setSidebarState((prev) => ({\n      ...prev,\n      mobileMenuVisible: true\n    }));\n  }, []);\n\n  const handleCloseMobileMenu = useCallback(() => {\n    setSidebarState((prev) => ({\n      ...prev,\n      mobileMenuVisible: false\n    }));\n  }, []);\n\n  useEffect(() => {\n    if (isMobile) {\n      handleCloseMobileMenu();\n    }\n  }, [isMobile, handleCloseMobileMenu]);\n\n  const { mobileMenuVisible } = sidebarState;\n  const affixTop = useAffixTop();\n\n  const menuChild = (\n    <ConfigProvider\n      theme={{\n        components: {\n          Menu: {\n            itemBg: colorBgContainer\n          }\n        }\n      }}\n    >\n      <Menu\n        items={menuItems}\n        inlineIndent={30}\n        css={styles.asideContainer}\n        mode=\"inline\"\n        theme={isDark ? 'dark' : 'light'}\n        selectedKeys={[selectedKey]}\n        defaultOpenKeys={sidebarData?.map(({ title }) => title).filter((item) => item) as string[]}\n      />\n    </ConfigProvider>\n  );\n\n  return isMobile ? (\n    <React.Fragment>\n      <MobileMenu\n        key=\"mobile-menu\"\n        contentWrapperStyle={{\n          width: '300px'\n        }}\n        open={mobileMenuVisible}\n        onClose={handleCloseMobileMenu}\n      >\n        {menuChild}\n      </MobileMenu>\n      {(menuItems ?? []).length > 1 ? (\n        <div css={styles.mobileMenu} onClick={handleShowMobileMenu}>\n          <UnorderedListOutlined />\n        </div>\n      ) : null}\n    </React.Fragment>\n  ) : (\n    <Col xxl={4} xl={5} lg={6} md={6} sm={24} xs={24} css={styles.mainMenu}>\n      <Affix offsetTop={affixTop} className=\"main-menu-affix\">\n        <section className=\"main-menu-inner\">{menuChild}</section>\n      </Affix>\n    </Col>\n  );\n};\n\nexport default Sidebar;\n"]} */",
23
23
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
24
24
  };
25
25
  var _ref2 = process.env.NODE_ENV === "production" ? {
26
- name: "5rjg5z",
27
- styles: "z-index:1;.main-menu-inner{position:sticky;top:0;height:100%;max-height:100vh;overflow:hidden;}&:hover .main-menu-inner{overflow-y:auto;}"
26
+ name: "1owaa6v",
27
+ styles: "z-index:1;.main-menu-affix{height:100%;}.main-menu-inner{position:sticky;top:0;height:100%;max-height:100vh;overflow:hidden;}&:hover .main-menu-inner{overflow-y:auto;}"
28
28
  } : {
29
- name: "82ixzo-mainMenu",
30
- styles: "z-index:1;.main-menu-inner{position:sticky;top:0;height:100%;max-height:100vh;overflow:hidden;}&:hover .main-menu-inner{overflow-y:auto;};label:mainMenu;",
31
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpSGlCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVub3JkZXJlZExpc3RPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEFmZml4LCBDb2wsIENvbmZpZ1Byb3ZpZGVyLCBNZW51IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VTaWRlYmFyRGF0YSB9IGZyb20gJ2R1bWknO1xuaW1wb3J0IE1vYmlsZU1lbnUgZnJvbSAncmMtZHJhd2VyJztcbmltcG9ydCAncmMtZHJhd2VyL2Fzc2V0cy9pbmRleC5jc3MnO1xuaW1wb3J0IFJlYWN0LCB7IEZDLCB1c2VDYWxsYmFjaywgdXNlQ29udGV4dCwgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB1c2VBZmZpeFRvcCBmcm9tICcuLi8uLi9ob29rcy91c2VBZmZpeFRvcCc7XG5pbXBvcnQgdXNlTWVudSBmcm9tICcuLi8uLi9ob29rcy91c2VNZW51JztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi9TaXRlQ29udGV4dCc7XG5cbmludGVyZmFjZSBTaWRlYmFyU3RhdGUge1xuICBtb2JpbGVNZW51VmlzaWJsZTogYm9vbGVhbjtcbn1cblxuY29uc3QgdXNlU3R5bGUgPSAoKSA9PiB7XG4gIGNvbnN0IHsgdG9rZW4gfSA9IHVzZVNpdGVUb2tlbigpO1xuXG4gIGNvbnN0IHsgYW50Q2xzLCBmb250RmFtaWx5LCBjb2xvclNwbGl0IH0gPSB0b2tlbjtcblxuICByZXR1cm4ge1xuICAgIGFzaWRlQ29udGFpbmVyOiBjc3NgXG4gICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgcGFkZGluZy1ib3R0b206IDQ4cHg7XG4gICAgICBmb250LWZhbWlseTogQXZlbmlyLCAke2ZvbnRGYW1pbHl9LCBzYW5zLXNlcmlmO1xuXG4gICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gICAgICAgICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUgaDQsXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbSBhIHtcbiAgICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgICAgIGZvbnQtc2l6ZTogMTRweDtcbiAgICAgICAgICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cCA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtdGl0bGUge1xuICAgICAgICAgIG1hcmdpbi10b3A6IDE2cHg7XG4gICAgICAgICAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgICAgICAgICBmb250LXNpemU6IDEzcHg7XG5cbiAgICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgICAgICAgICB0b3A6IDEycHg7XG4gICAgICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgICAgIHdpZHRoOiBjYWxjKDEwMCUgLSAyMHB4KTtcbiAgICAgICAgICAgIGhlaWdodDogMXB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogJHtjb2xvclNwbGl0fTtcbiAgICAgICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUsXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlLFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0XG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLFxuICAgICAgICAgICYke2FudENsc30tbWVudS1pbmxpbmVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXBcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgcGFkZGluZy1sZWZ0OiA0MHB4ICFpbXBvcnRhbnQ7XG5cbiAgICAgICAgICAke2FudENsc30tcm93LXJ0bCAmIHtcbiAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDQwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgIHBhZGRpbmctbGVmdDogMTZweCAhaW1wb3J0YW50O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIC8vIE5lc3QgQ2F0ZWdvcnkgPiBUeXBlID4gQXJ0aWNsZVxuICAgICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi1sZWZ0OiA0cHg7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDYwcHg7XG5cbiAgICAgICAgICAgICR7YW50Q2xzfS1yb3ctcnRsICYge1xuICAgICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA2MHB4O1xuICAgICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDE2cHg7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0ID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDgwcHggIWltcG9ydGFudDtcblxuICAgICAgICAgICAgJHthbnRDbHN9LXJvdy1ydGwgJiB7XG4gICAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDgwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiAxNnB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cDpmaXJzdC1vZi10eXBlIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGFbZGlzYWJsZWRdIHtcbiAgICAgICAgY29sb3I6ICNjY2M7XG4gICAgICB9XG5cbiAgICAgIC5jaGluZXNlIHtcbiAgICAgICAgbWFyZ2luLWxlZnQ6IDZweDtcbiAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgZm9udC1zaXplOiAxMnB4O1xuICAgICAgICBvcGFjaXR5OiAwLjY3O1xuICAgICAgfVxuICAgIGAsXG4gICAgbWFpbk1lbnU6IGNzc2BcbiAgICAgIHotaW5kZXg6IDE7XG5cbiAgICAgIC5tYWluLW1lbnUtaW5uZXIge1xuICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGhlaWdodDogMTAwJTtcbiAgICAgICAgbWF4LWhlaWdodDogMTAwdmg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICB9XG5cbiAgICAgICY6aG92ZXIgLm1haW4tbWVudS1pbm5lciB7XG4gICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICB9XG4gICAgYCxcbiAgICBtb2JpbGVNZW51OiBjc3NgXG4gICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICB6LWluZGV4OiAyO1xuICAgICAgYm90dG9tOiAxMDBweDtcbiAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IFNpZGViYXI6IEZDID0gKCkgPT4ge1xuICBjb25zdCBbc2lkZWJhclN0YXRlLCBzZXRTaWRlYmFyU3RhdGVdID0gdXNlU3RhdGU8U2lkZWJhclN0YXRlPih7IG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZSB9KTtcbiAgY29uc3Qgc2lkZWJhckRhdGEgPSB1c2VTaWRlYmFyRGF0YSgpO1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7XG4gICAgdG9rZW46IHsgY29sb3JCZ0NvbnRhaW5lciB9XG4gIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyB0aGVtZSwgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBbbWVudUl0ZW1zLCBzZWxlY3RlZEtleV0gPSB1c2VNZW51KCk7XG5cbiAgY29uc3QgaXNEYXJrID0gdGhlbWUuaW5jbHVkZXMoJ2RhcmsnKTtcblxuICBjb25zdCBoYW5kbGVTaG93TW9iaWxlTWVudSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTaWRlYmFyU3RhdGUoKHByZXYpID0+ICh7XG4gICAgICAuLi5wcmV2LFxuICAgICAgbW9iaWxlTWVudVZpc2libGU6IHRydWVcbiAgICB9KSk7XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZU1vYmlsZU1lbnUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0U2lkZWJhclN0YXRlKChwcmV2KSA9PiAoe1xuICAgICAgLi4ucHJldixcbiAgICAgIG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZVxuICAgIH0pKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBoYW5kbGVDbG9zZU1vYmlsZU1lbnUoKTtcbiAgICB9XG4gIH0sIFtpc01vYmlsZSwgaGFuZGxlQ2xvc2VNb2JpbGVNZW51XSk7XG5cbiAgY29uc3QgeyBtb2JpbGVNZW51VmlzaWJsZSB9ID0gc2lkZWJhclN0YXRlO1xuICBjb25zdCBhZmZpeFRvcCA9IHVzZUFmZml4VG9wKCk7XG5cbiAgY29uc3QgbWVudUNoaWxkID0gKFxuICAgIDxDb25maWdQcm92aWRlclxuICAgICAgdGhlbWU9e3tcbiAgICAgICAgY29tcG9uZW50czoge1xuICAgICAgICAgIE1lbnU6IHtcbiAgICAgICAgICAgIGl0ZW1CZzogY29sb3JCZ0NvbnRhaW5lclxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfX1cbiAgICA+XG4gICAgICA8TWVudVxuICAgICAgICBpdGVtcz17bWVudUl0ZW1zfVxuICAgICAgICBpbmxpbmVJbmRlbnQ9ezMwfVxuICAgICAgICBjc3M9e3N0eWxlcy5hc2lkZUNvbnRhaW5lcn1cbiAgICAgICAgbW9kZT1cImlubGluZVwiXG4gICAgICAgIHRoZW1lPXtpc0RhcmsgPyAnZGFyaycgOiAnbGlnaHQnfVxuICAgICAgICBzZWxlY3RlZEtleXM9e1tzZWxlY3RlZEtleV19XG4gICAgICAgIGRlZmF1bHRPcGVuS2V5cz17c2lkZWJhckRhdGE/Lm1hcCgoeyB0aXRsZSB9KSA9PiB0aXRsZSkuZmlsdGVyKChpdGVtKSA9PiBpdGVtKSBhcyBzdHJpbmdbXX1cbiAgICAgIC8+XG4gICAgPC9Db25maWdQcm92aWRlcj5cbiAgKTtcblxuICByZXR1cm4gaXNNb2JpbGUgPyAoXG4gICAgPFJlYWN0LkZyYWdtZW50PlxuICAgICAgPE1vYmlsZU1lbnVcbiAgICAgICAga2V5PVwibW9iaWxlLW1lbnVcIlxuICAgICAgICBjb250ZW50V3JhcHBlclN0eWxlPXt7XG4gICAgICAgICAgd2lkdGg6ICczMDBweCdcbiAgICAgICAgfX1cbiAgICAgICAgb3Blbj17bW9iaWxlTWVudVZpc2libGV9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlTW9iaWxlTWVudX1cbiAgICAgID5cbiAgICAgICAge21lbnVDaGlsZH1cbiAgICAgIDwvTW9iaWxlTWVudT5cbiAgICAgIHsobWVudUl0ZW1zID8/IFtdKS5sZW5ndGggPiAxID8gKFxuICAgICAgICA8ZGl2IGNzcz17c3R5bGVzLm1vYmlsZU1lbnV9IG9uQ2xpY2s9e2hhbmRsZVNob3dNb2JpbGVNZW51fT5cbiAgICAgICAgICA8VW5vcmRlcmVkTGlzdE91dGxpbmVkIC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgKSA6IG51bGx9XG4gICAgPC9SZWFjdC5GcmFnbWVudD5cbiAgKSA6IChcbiAgICA8Q29sIHh4bD17NH0geGw9ezV9IGxnPXs2fSBtZD17Nn0gc209ezI0fSB4cz17MjR9IGNzcz17c3R5bGVzLm1haW5NZW51fT5cbiAgICAgIDxBZmZpeCBvZmZzZXRUb3A9e2FmZml4VG9wfT5cbiAgICAgICAgPHNlY3Rpb24gY2xhc3NOYW1lPVwibWFpbi1tZW51LWlubmVyXCI+e21lbnVDaGlsZH08L3NlY3Rpb24+XG4gICAgICA8L0FmZml4PlxuICAgIDwvQ29sPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgU2lkZWJhcjtcbiJdfQ== */",
29
+ name: "tzeu79-mainMenu",
30
+ styles: "z-index:1;.main-menu-affix{height:100%;}.main-menu-inner{position:sticky;top:0;height:100%;max-height:100vh;overflow:hidden;}&:hover .main-menu-inner{overflow-y:auto;};label:mainMenu;",
31
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiHiB","file":"index.tsx","sourcesContent":["import { UnorderedListOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Col, ConfigProvider, Menu } from 'antd';\nimport { useSidebarData } from 'dumi';\nimport MobileMenu from 'rc-drawer';\nimport 'rc-drawer/assets/index.css';\nimport React, { FC, useCallback, useContext, useEffect, useState } from 'react';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useMenu from '../../hooks/useMenu';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport SiteContext from '../SiteContext';\n\ninterface SidebarState {\n  mobileMenuVisible: boolean;\n}\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls, fontFamily, colorSplit } = token;\n\n  return {\n    asideContainer: css`\n      min-height: 100%;\n      padding-bottom: 48px;\n      font-family: Avenir, ${fontFamily}, sans-serif;\n\n      &${antCls}-menu-inline {\n        user-select: none;\n        ${antCls}-menu-submenu-title h4,\n        > ${antCls}-menu-item,\n        ${antCls}-menu-item a {\n          overflow: hidden;\n          font-size: 14px;\n          text-overflow: ellipsis;\n        }\n\n        > ${antCls}-menu-item-group > ${antCls}-menu-item-group-title {\n          margin-top: 16px;\n          margin-bottom: 16px;\n          font-size: 13px;\n\n          &::after {\n            position: relative;\n            top: 12px;\n            display: block;\n            width: calc(100% - 20px);\n            height: 1px;\n            background: ${colorSplit};\n            content: '';\n          }\n        }\n\n        > ${antCls}-menu-item,\n          > ${antCls}-menu-submenu\n          > ${antCls}-menu-submenu-title,\n          > ${antCls}-menu-item-group\n          > ${antCls}-menu-item-group-title,\n          > ${antCls}-menu-item-group\n          > ${antCls}-menu-item-group-list\n          > ${antCls}-menu-item,\n          &${antCls}-menu-inline\n          > ${antCls}-menu-item-group\n          > ${antCls}-menu-item-group-list\n          > ${antCls}-menu-item {\n          padding-left: 40px !important;\n\n          ${antCls}-row-rtl & {\n            padding-right: 40px !important;\n            padding-left: 16px !important;\n          }\n        }\n\n        // Nest Category > Type > Article\n        &${antCls}-menu-inline {\n          ${antCls}-menu-item-group-title {\n            margin-left: 4px;\n            padding-left: 60px;\n\n            ${antCls}-row-rtl & {\n              padding-right: 60px;\n              padding-left: 16px;\n            }\n          }\n\n          ${antCls}-menu-item-group-list > ${antCls}-menu-item {\n            padding-left: 80px !important;\n\n            ${antCls}-row-rtl & {\n              padding-right: 80px !important;\n              padding-left: 16px !important;\n            }\n          }\n        }\n\n        ${antCls}-menu-item-group:first-of-type {\n          ${antCls}-menu-item-group-title {\n            margin-top: 0;\n          }\n        }\n      }\n\n      a[disabled] {\n        color: #ccc;\n      }\n\n      .chinese {\n        margin-left: 6px;\n        font-weight: normal;\n        font-size: 12px;\n        opacity: 0.67;\n      }\n    `,\n    mainMenu: css`\n      z-index: 1;\n\n      .main-menu-affix {\n        height: 100%;\n      }\n\n      .main-menu-inner {\n        position: sticky;\n        top: 0;\n        height: 100%;\n        max-height: 100vh;\n        overflow: hidden;\n      }\n\n      &:hover .main-menu-inner {\n        overflow-y: auto;\n      }\n    `,\n    mobileMenu: css`\n      position: fixed;\n      z-index: 2;\n      bottom: 100px;\n      right: 20px;\n      cursor: pointer;\n    `\n  };\n};\n\nconst Sidebar: FC = () => {\n  const [sidebarState, setSidebarState] = useState<SidebarState>({ mobileMenuVisible: false });\n  const sidebarData = useSidebarData();\n  const styles = useStyle();\n  const {\n    token: { colorBgContainer }\n  } = useSiteToken();\n  const { theme, isMobile } = useContext(SiteContext);\n  const [menuItems, selectedKey] = useMenu();\n\n  const isDark = theme.includes('dark');\n\n  const handleShowMobileMenu = useCallback(() => {\n    setSidebarState((prev) => ({\n      ...prev,\n      mobileMenuVisible: true\n    }));\n  }, []);\n\n  const handleCloseMobileMenu = useCallback(() => {\n    setSidebarState((prev) => ({\n      ...prev,\n      mobileMenuVisible: false\n    }));\n  }, []);\n\n  useEffect(() => {\n    if (isMobile) {\n      handleCloseMobileMenu();\n    }\n  }, [isMobile, handleCloseMobileMenu]);\n\n  const { mobileMenuVisible } = sidebarState;\n  const affixTop = useAffixTop();\n\n  const menuChild = (\n    <ConfigProvider\n      theme={{\n        components: {\n          Menu: {\n            itemBg: colorBgContainer\n          }\n        }\n      }}\n    >\n      <Menu\n        items={menuItems}\n        inlineIndent={30}\n        css={styles.asideContainer}\n        mode=\"inline\"\n        theme={isDark ? 'dark' : 'light'}\n        selectedKeys={[selectedKey]}\n        defaultOpenKeys={sidebarData?.map(({ title }) => title).filter((item) => item) as string[]}\n      />\n    </ConfigProvider>\n  );\n\n  return isMobile ? (\n    <React.Fragment>\n      <MobileMenu\n        key=\"mobile-menu\"\n        contentWrapperStyle={{\n          width: '300px'\n        }}\n        open={mobileMenuVisible}\n        onClose={handleCloseMobileMenu}\n      >\n        {menuChild}\n      </MobileMenu>\n      {(menuItems ?? []).length > 1 ? (\n        <div css={styles.mobileMenu} onClick={handleShowMobileMenu}>\n          <UnorderedListOutlined />\n        </div>\n      ) : null}\n    </React.Fragment>\n  ) : (\n    <Col xxl={4} xl={5} lg={6} md={6} sm={24} xs={24} css={styles.mainMenu}>\n      <Affix offsetTop={affixTop} className=\"main-menu-affix\">\n        <section className=\"main-menu-inner\">{menuChild}</section>\n      </Affix>\n    </Col>\n  );\n};\n\nexport default Sidebar;\n"]} */",
32
32
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
33
33
  };
34
34
  var useStyle = function useStyle() {
@@ -38,7 +38,7 @@ var useStyle = function useStyle() {
38
38
  fontFamily = token.fontFamily,
39
39
  colorSplit = token.colorSplit;
40
40
  return {
41
- asideContainer: /*#__PURE__*/css("min-height:100%;padding-bottom:48px;font-family:Avenir,", fontFamily, ",sans-serif;&", antCls, "-menu-inline{user-select:none;", antCls, "-menu-submenu-title h4,>", antCls, "-menu-item,", antCls, "-menu-item a{overflow:hidden;font-size:14px;text-overflow:ellipsis;}>", antCls, "-menu-item-group>", antCls, "-menu-item-group-title{margin-top:16px;margin-bottom:16px;font-size:13px;&::after{position:relative;top:12px;display:block;width:calc(100% - 20px);height:1px;background:", colorSplit, ";content:'';}}>", antCls, "-menu-item,>", antCls, "-menu-submenu>", antCls, "-menu-submenu-title,>", antCls, "-menu-item-group>", antCls, "-menu-item-group-title,>", antCls, "-menu-item-group>", antCls, "-menu-item-group-list>", antCls, "-menu-item,&", antCls, "-menu-inline>", antCls, "-menu-item-group>", antCls, "-menu-item-group-list>", antCls, "-menu-item{padding-left:40px!important;", antCls, "-row-rtl &{padding-right:40px!important;padding-left:16px!important;}}&", antCls, "-menu-inline{", antCls, "-menu-item-group-title{margin-left:4px;padding-left:60px;", antCls, "-row-rtl &{padding-right:60px;padding-left:16px;}}", antCls, "-menu-item-group-list>", antCls, "-menu-item{padding-left:80px!important;", antCls, "-row-rtl &{padding-right:80px!important;padding-left:16px!important;}}}", antCls, "-menu-item-group:first-of-type{", antCls, "-menu-item-group-title{margin-top:0;}}}a[disabled]{color:#ccc;}.chinese{margin-left:6px;font-weight:normal;font-size:12px;opacity:0.67;}" + (process.env.NODE_ENV === "production" ? "" : ";label:asideContainer;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQnVCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVub3JkZXJlZExpc3RPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEFmZml4LCBDb2wsIENvbmZpZ1Byb3ZpZGVyLCBNZW51IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VTaWRlYmFyRGF0YSB9IGZyb20gJ2R1bWknO1xuaW1wb3J0IE1vYmlsZU1lbnUgZnJvbSAncmMtZHJhd2VyJztcbmltcG9ydCAncmMtZHJhd2VyL2Fzc2V0cy9pbmRleC5jc3MnO1xuaW1wb3J0IFJlYWN0LCB7IEZDLCB1c2VDYWxsYmFjaywgdXNlQ29udGV4dCwgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB1c2VBZmZpeFRvcCBmcm9tICcuLi8uLi9ob29rcy91c2VBZmZpeFRvcCc7XG5pbXBvcnQgdXNlTWVudSBmcm9tICcuLi8uLi9ob29rcy91c2VNZW51JztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi9TaXRlQ29udGV4dCc7XG5cbmludGVyZmFjZSBTaWRlYmFyU3RhdGUge1xuICBtb2JpbGVNZW51VmlzaWJsZTogYm9vbGVhbjtcbn1cblxuY29uc3QgdXNlU3R5bGUgPSAoKSA9PiB7XG4gIGNvbnN0IHsgdG9rZW4gfSA9IHVzZVNpdGVUb2tlbigpO1xuXG4gIGNvbnN0IHsgYW50Q2xzLCBmb250RmFtaWx5LCBjb2xvclNwbGl0IH0gPSB0b2tlbjtcblxuICByZXR1cm4ge1xuICAgIGFzaWRlQ29udGFpbmVyOiBjc3NgXG4gICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgcGFkZGluZy1ib3R0b206IDQ4cHg7XG4gICAgICBmb250LWZhbWlseTogQXZlbmlyLCAke2ZvbnRGYW1pbHl9LCBzYW5zLXNlcmlmO1xuXG4gICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gICAgICAgICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUgaDQsXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbSBhIHtcbiAgICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgICAgIGZvbnQtc2l6ZTogMTRweDtcbiAgICAgICAgICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cCA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtdGl0bGUge1xuICAgICAgICAgIG1hcmdpbi10b3A6IDE2cHg7XG4gICAgICAgICAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgICAgICAgICBmb250LXNpemU6IDEzcHg7XG5cbiAgICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgICAgICAgICB0b3A6IDEycHg7XG4gICAgICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgICAgIHdpZHRoOiBjYWxjKDEwMCUgLSAyMHB4KTtcbiAgICAgICAgICAgIGhlaWdodDogMXB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogJHtjb2xvclNwbGl0fTtcbiAgICAgICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUsXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlLFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0XG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLFxuICAgICAgICAgICYke2FudENsc30tbWVudS1pbmxpbmVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXBcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgcGFkZGluZy1sZWZ0OiA0MHB4ICFpbXBvcnRhbnQ7XG5cbiAgICAgICAgICAke2FudENsc30tcm93LXJ0bCAmIHtcbiAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDQwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgIHBhZGRpbmctbGVmdDogMTZweCAhaW1wb3J0YW50O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIC8vIE5lc3QgQ2F0ZWdvcnkgPiBUeXBlID4gQXJ0aWNsZVxuICAgICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi1sZWZ0OiA0cHg7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDYwcHg7XG5cbiAgICAgICAgICAgICR7YW50Q2xzfS1yb3ctcnRsICYge1xuICAgICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA2MHB4O1xuICAgICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDE2cHg7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0ID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDgwcHggIWltcG9ydGFudDtcblxuICAgICAgICAgICAgJHthbnRDbHN9LXJvdy1ydGwgJiB7XG4gICAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDgwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiAxNnB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cDpmaXJzdC1vZi10eXBlIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGFbZGlzYWJsZWRdIHtcbiAgICAgICAgY29sb3I6ICNjY2M7XG4gICAgICB9XG5cbiAgICAgIC5jaGluZXNlIHtcbiAgICAgICAgbWFyZ2luLWxlZnQ6IDZweDtcbiAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgZm9udC1zaXplOiAxMnB4O1xuICAgICAgICBvcGFjaXR5OiAwLjY3O1xuICAgICAgfVxuICAgIGAsXG4gICAgbWFpbk1lbnU6IGNzc2BcbiAgICAgIHotaW5kZXg6IDE7XG5cbiAgICAgIC5tYWluLW1lbnUtaW5uZXIge1xuICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGhlaWdodDogMTAwJTtcbiAgICAgICAgbWF4LWhlaWdodDogMTAwdmg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICB9XG5cbiAgICAgICY6aG92ZXIgLm1haW4tbWVudS1pbm5lciB7XG4gICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICB9XG4gICAgYCxcbiAgICBtb2JpbGVNZW51OiBjc3NgXG4gICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICB6LWluZGV4OiAyO1xuICAgICAgYm90dG9tOiAxMDBweDtcbiAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IFNpZGViYXI6IEZDID0gKCkgPT4ge1xuICBjb25zdCBbc2lkZWJhclN0YXRlLCBzZXRTaWRlYmFyU3RhdGVdID0gdXNlU3RhdGU8U2lkZWJhclN0YXRlPih7IG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZSB9KTtcbiAgY29uc3Qgc2lkZWJhckRhdGEgPSB1c2VTaWRlYmFyRGF0YSgpO1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7XG4gICAgdG9rZW46IHsgY29sb3JCZ0NvbnRhaW5lciB9XG4gIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyB0aGVtZSwgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBbbWVudUl0ZW1zLCBzZWxlY3RlZEtleV0gPSB1c2VNZW51KCk7XG5cbiAgY29uc3QgaXNEYXJrID0gdGhlbWUuaW5jbHVkZXMoJ2RhcmsnKTtcblxuICBjb25zdCBoYW5kbGVTaG93TW9iaWxlTWVudSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTaWRlYmFyU3RhdGUoKHByZXYpID0+ICh7XG4gICAgICAuLi5wcmV2LFxuICAgICAgbW9iaWxlTWVudVZpc2libGU6IHRydWVcbiAgICB9KSk7XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZU1vYmlsZU1lbnUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0U2lkZWJhclN0YXRlKChwcmV2KSA9PiAoe1xuICAgICAgLi4ucHJldixcbiAgICAgIG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZVxuICAgIH0pKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBoYW5kbGVDbG9zZU1vYmlsZU1lbnUoKTtcbiAgICB9XG4gIH0sIFtpc01vYmlsZSwgaGFuZGxlQ2xvc2VNb2JpbGVNZW51XSk7XG5cbiAgY29uc3QgeyBtb2JpbGVNZW51VmlzaWJsZSB9ID0gc2lkZWJhclN0YXRlO1xuICBjb25zdCBhZmZpeFRvcCA9IHVzZUFmZml4VG9wKCk7XG5cbiAgY29uc3QgbWVudUNoaWxkID0gKFxuICAgIDxDb25maWdQcm92aWRlclxuICAgICAgdGhlbWU9e3tcbiAgICAgICAgY29tcG9uZW50czoge1xuICAgICAgICAgIE1lbnU6IHtcbiAgICAgICAgICAgIGl0ZW1CZzogY29sb3JCZ0NvbnRhaW5lclxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfX1cbiAgICA+XG4gICAgICA8TWVudVxuICAgICAgICBpdGVtcz17bWVudUl0ZW1zfVxuICAgICAgICBpbmxpbmVJbmRlbnQ9ezMwfVxuICAgICAgICBjc3M9e3N0eWxlcy5hc2lkZUNvbnRhaW5lcn1cbiAgICAgICAgbW9kZT1cImlubGluZVwiXG4gICAgICAgIHRoZW1lPXtpc0RhcmsgPyAnZGFyaycgOiAnbGlnaHQnfVxuICAgICAgICBzZWxlY3RlZEtleXM9e1tzZWxlY3RlZEtleV19XG4gICAgICAgIGRlZmF1bHRPcGVuS2V5cz17c2lkZWJhckRhdGE/Lm1hcCgoeyB0aXRsZSB9KSA9PiB0aXRsZSkuZmlsdGVyKChpdGVtKSA9PiBpdGVtKSBhcyBzdHJpbmdbXX1cbiAgICAgIC8+XG4gICAgPC9Db25maWdQcm92aWRlcj5cbiAgKTtcblxuICByZXR1cm4gaXNNb2JpbGUgPyAoXG4gICAgPFJlYWN0LkZyYWdtZW50PlxuICAgICAgPE1vYmlsZU1lbnVcbiAgICAgICAga2V5PVwibW9iaWxlLW1lbnVcIlxuICAgICAgICBjb250ZW50V3JhcHBlclN0eWxlPXt7XG4gICAgICAgICAgd2lkdGg6ICczMDBweCdcbiAgICAgICAgfX1cbiAgICAgICAgb3Blbj17bW9iaWxlTWVudVZpc2libGV9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlTW9iaWxlTWVudX1cbiAgICAgID5cbiAgICAgICAge21lbnVDaGlsZH1cbiAgICAgIDwvTW9iaWxlTWVudT5cbiAgICAgIHsobWVudUl0ZW1zID8/IFtdKS5sZW5ndGggPiAxID8gKFxuICAgICAgICA8ZGl2IGNzcz17c3R5bGVzLm1vYmlsZU1lbnV9IG9uQ2xpY2s9e2hhbmRsZVNob3dNb2JpbGVNZW51fT5cbiAgICAgICAgICA8VW5vcmRlcmVkTGlzdE91dGxpbmVkIC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgKSA6IG51bGx9XG4gICAgPC9SZWFjdC5GcmFnbWVudD5cbiAgKSA6IChcbiAgICA8Q29sIHh4bD17NH0geGw9ezV9IGxnPXs2fSBtZD17Nn0gc209ezI0fSB4cz17MjR9IGNzcz17c3R5bGVzLm1haW5NZW51fT5cbiAgICAgIDxBZmZpeCBvZmZzZXRUb3A9e2FmZml4VG9wfT5cbiAgICAgICAgPHNlY3Rpb24gY2xhc3NOYW1lPVwibWFpbi1tZW51LWlubmVyXCI+e21lbnVDaGlsZH08L3NlY3Rpb24+XG4gICAgICA8L0FmZml4PlxuICAgIDwvQ29sPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgU2lkZWJhcjtcbiJdfQ== */"),
41
+ asideContainer: /*#__PURE__*/css("min-height:100%;padding-bottom:48px;font-family:Avenir,", fontFamily, ",sans-serif;&", antCls, "-menu-inline{user-select:none;", antCls, "-menu-submenu-title h4,>", antCls, "-menu-item,", antCls, "-menu-item a{overflow:hidden;font-size:14px;text-overflow:ellipsis;}>", antCls, "-menu-item-group>", antCls, "-menu-item-group-title{margin-top:16px;margin-bottom:16px;font-size:13px;&::after{position:relative;top:12px;display:block;width:calc(100% - 20px);height:1px;background:", colorSplit, ";content:'';}}>", antCls, "-menu-item,>", antCls, "-menu-submenu>", antCls, "-menu-submenu-title,>", antCls, "-menu-item-group>", antCls, "-menu-item-group-title,>", antCls, "-menu-item-group>", antCls, "-menu-item-group-list>", antCls, "-menu-item,&", antCls, "-menu-inline>", antCls, "-menu-item-group>", antCls, "-menu-item-group-list>", antCls, "-menu-item{padding-left:40px!important;", antCls, "-row-rtl &{padding-right:40px!important;padding-left:16px!important;}}&", antCls, "-menu-inline{", antCls, "-menu-item-group-title{margin-left:4px;padding-left:60px;", antCls, "-row-rtl &{padding-right:60px;padding-left:16px;}}", antCls, "-menu-item-group-list>", antCls, "-menu-item{padding-left:80px!important;", antCls, "-row-rtl &{padding-right:80px!important;padding-left:16px!important;}}}", antCls, "-menu-item-group:first-of-type{", antCls, "-menu-item-group-title{margin-top:0;}}}a[disabled]{color:#ccc;}.chinese{margin-left:6px;font-weight:normal;font-size:12px;opacity:0.67;}" + (process.env.NODE_ENV === "production" ? "" : ";label:asideContainer;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAsBuB","file":"index.tsx","sourcesContent":["import { UnorderedListOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Col, ConfigProvider, Menu } from 'antd';\nimport { useSidebarData } from 'dumi';\nimport MobileMenu from 'rc-drawer';\nimport 'rc-drawer/assets/index.css';\nimport React, { FC, useCallback, useContext, useEffect, useState } from 'react';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useMenu from '../../hooks/useMenu';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport SiteContext from '../SiteContext';\n\ninterface SidebarState {\n  mobileMenuVisible: boolean;\n}\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls, fontFamily, colorSplit } = token;\n\n  return {\n    asideContainer: css`\n      min-height: 100%;\n      padding-bottom: 48px;\n      font-family: Avenir, ${fontFamily}, sans-serif;\n\n      &${antCls}-menu-inline {\n        user-select: none;\n        ${antCls}-menu-submenu-title h4,\n        > ${antCls}-menu-item,\n        ${antCls}-menu-item a {\n          overflow: hidden;\n          font-size: 14px;\n          text-overflow: ellipsis;\n        }\n\n        > ${antCls}-menu-item-group > ${antCls}-menu-item-group-title {\n          margin-top: 16px;\n          margin-bottom: 16px;\n          font-size: 13px;\n\n          &::after {\n            position: relative;\n            top: 12px;\n            display: block;\n            width: calc(100% - 20px);\n            height: 1px;\n            background: ${colorSplit};\n            content: '';\n          }\n        }\n\n        > ${antCls}-menu-item,\n          > ${antCls}-menu-submenu\n          > ${antCls}-menu-submenu-title,\n          > ${antCls}-menu-item-group\n          > ${antCls}-menu-item-group-title,\n          > ${antCls}-menu-item-group\n          > ${antCls}-menu-item-group-list\n          > ${antCls}-menu-item,\n          &${antCls}-menu-inline\n          > ${antCls}-menu-item-group\n          > ${antCls}-menu-item-group-list\n          > ${antCls}-menu-item {\n          padding-left: 40px !important;\n\n          ${antCls}-row-rtl & {\n            padding-right: 40px !important;\n            padding-left: 16px !important;\n          }\n        }\n\n        // Nest Category > Type > Article\n        &${antCls}-menu-inline {\n          ${antCls}-menu-item-group-title {\n            margin-left: 4px;\n            padding-left: 60px;\n\n            ${antCls}-row-rtl & {\n              padding-right: 60px;\n              padding-left: 16px;\n            }\n          }\n\n          ${antCls}-menu-item-group-list > ${antCls}-menu-item {\n            padding-left: 80px !important;\n\n            ${antCls}-row-rtl & {\n              padding-right: 80px !important;\n              padding-left: 16px !important;\n            }\n          }\n        }\n\n        ${antCls}-menu-item-group:first-of-type {\n          ${antCls}-menu-item-group-title {\n            margin-top: 0;\n          }\n        }\n      }\n\n      a[disabled] {\n        color: #ccc;\n      }\n\n      .chinese {\n        margin-left: 6px;\n        font-weight: normal;\n        font-size: 12px;\n        opacity: 0.67;\n      }\n    `,\n    mainMenu: css`\n      z-index: 1;\n\n      .main-menu-affix {\n        height: 100%;\n      }\n\n      .main-menu-inner {\n        position: sticky;\n        top: 0;\n        height: 100%;\n        max-height: 100vh;\n        overflow: hidden;\n      }\n\n      &:hover .main-menu-inner {\n        overflow-y: auto;\n      }\n    `,\n    mobileMenu: css`\n      position: fixed;\n      z-index: 2;\n      bottom: 100px;\n      right: 20px;\n      cursor: pointer;\n    `\n  };\n};\n\nconst Sidebar: FC = () => {\n  const [sidebarState, setSidebarState] = useState<SidebarState>({ mobileMenuVisible: false });\n  const sidebarData = useSidebarData();\n  const styles = useStyle();\n  const {\n    token: { colorBgContainer }\n  } = useSiteToken();\n  const { theme, isMobile } = useContext(SiteContext);\n  const [menuItems, selectedKey] = useMenu();\n\n  const isDark = theme.includes('dark');\n\n  const handleShowMobileMenu = useCallback(() => {\n    setSidebarState((prev) => ({\n      ...prev,\n      mobileMenuVisible: true\n    }));\n  }, []);\n\n  const handleCloseMobileMenu = useCallback(() => {\n    setSidebarState((prev) => ({\n      ...prev,\n      mobileMenuVisible: false\n    }));\n  }, []);\n\n  useEffect(() => {\n    if (isMobile) {\n      handleCloseMobileMenu();\n    }\n  }, [isMobile, handleCloseMobileMenu]);\n\n  const { mobileMenuVisible } = sidebarState;\n  const affixTop = useAffixTop();\n\n  const menuChild = (\n    <ConfigProvider\n      theme={{\n        components: {\n          Menu: {\n            itemBg: colorBgContainer\n          }\n        }\n      }}\n    >\n      <Menu\n        items={menuItems}\n        inlineIndent={30}\n        css={styles.asideContainer}\n        mode=\"inline\"\n        theme={isDark ? 'dark' : 'light'}\n        selectedKeys={[selectedKey]}\n        defaultOpenKeys={sidebarData?.map(({ title }) => title).filter((item) => item) as string[]}\n      />\n    </ConfigProvider>\n  );\n\n  return isMobile ? (\n    <React.Fragment>\n      <MobileMenu\n        key=\"mobile-menu\"\n        contentWrapperStyle={{\n          width: '300px'\n        }}\n        open={mobileMenuVisible}\n        onClose={handleCloseMobileMenu}\n      >\n        {menuChild}\n      </MobileMenu>\n      {(menuItems ?? []).length > 1 ? (\n        <div css={styles.mobileMenu} onClick={handleShowMobileMenu}>\n          <UnorderedListOutlined />\n        </div>\n      ) : null}\n    </React.Fragment>\n  ) : (\n    <Col xxl={4} xl={5} lg={6} md={6} sm={24} xs={24} css={styles.mainMenu}>\n      <Affix offsetTop={affixTop} className=\"main-menu-affix\">\n        <section className=\"main-menu-inner\">{menuChild}</section>\n      </Affix>\n    </Col>\n  );\n};\n\nexport default Sidebar;\n"]} */"),
42
42
  mainMenu: _ref2,
43
43
  mobileMenu: _ref
44
44
  };
@@ -124,7 +124,8 @@ var Sidebar = function Sidebar() {
124
124
  xs: 24,
125
125
  css: styles.mainMenu
126
126
  }, ___EmotionJSX(Affix, {
127
- offsetTop: affixTop
127
+ offsetTop: affixTop,
128
+ className: "main-menu-affix"
128
129
  }, ___EmotionJSX("section", {
129
130
  className: "main-menu-inner"
130
131
  }, menuChild)));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ahooks.js/dumi-theme-antd",
3
- "version": "0.1.4",
3
+ "version": "0.1.6",
4
4
  "description": "Ant Design 5.0 官网风格类似的 dumi2 主题插件",
5
5
  "keywords": [
6
6
  "dumi",
@@ -19,6 +19,16 @@
19
19
  "files": [
20
20
  "dist"
21
21
  ],
22
+ "scripts": {
23
+ "dev": "cross-env APP_ROOT=example dumi dev",
24
+ "build": "cross-env APP_ROOT=example dumi build",
25
+ "preview": "cross-env APP_ROOT=example dumi preview",
26
+ "lint": "pnpm run lint:es && pnpm run lint:css",
27
+ "lint:css": "stylelint \"{src,test}/**/*.{css,less}\"",
28
+ "lint:es": "eslint \"{src,test}/**/*.{js,jsx,ts,tsx}\" --fix",
29
+ "prepare": "husky install && father link-dev-theme",
30
+ "prepublishOnly": "father doctor && father build"
31
+ },
22
32
  "commitlint": {
23
33
  "extends": [
24
34
  "@commitlint/config-conventional"
@@ -46,7 +56,7 @@
46
56
  "@babel/runtime": "7.22.3",
47
57
  "@ctrl/tinycolor": "3.6.0",
48
58
  "@emotion/css": "11.11.2",
49
- "@emotion/react": "11.11.0",
59
+ "@emotion/react": "11.14.0",
50
60
  "@emotion/server": "11.11.0",
51
61
  "antd-token-previewer": "2.0.0-alpha.6",
52
62
  "classnames": "2.3.2",
@@ -91,16 +101,5 @@
91
101
  "authors": [
92
102
  "KuangPF",
93
103
  "liuyib<https://github.com/liuyib>"
94
- ],
95
- "scripts": {
96
- "build": "father build",
97
- "build:docs": "cross-env APP_ROOT=example dumi build",
98
- "build:site": "cross-env APP_ROOT=example DEPLOY_SITE=local dumi build",
99
- "site": "node app.js",
100
- "dev": "father dev",
101
- "docs": "cross-env APP_ROOT=example dumi dev",
102
- "lint": "pnpm run lint:es && pnpm run lint:css",
103
- "lint:css": "stylelint \"{src,test}/**/*.{css,less}\"",
104
- "lint:es": "eslint \"{src,test}/**/*.{js,jsx,ts,tsx}\" --fix"
105
- }
106
- }
104
+ ]
105
+ }