@ahooks.js/dumi-theme-antd 0.1.7 → 0.1.8

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.
@@ -3,12 +3,11 @@ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
3
3
  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)."; }
4
4
  import { UnorderedListOutlined } from '@ant-design/icons';
5
5
  import { css } from '@emotion/react';
6
- import { Affix, Col, ConfigProvider, Menu } from 'antd';
6
+ import { Col, ConfigProvider, Menu } from 'antd';
7
7
  import { useSidebarData } from 'dumi';
8
8
  import MobileMenu from 'rc-drawer';
9
9
  import 'rc-drawer/assets/index.css';
10
10
  import React, { useCallback, useContext, useEffect, useState } from 'react';
11
- import useAffixTop from "../../hooks/useAffixTop";
12
11
  import useMenu from "../../hooks/useMenu";
13
12
  import useSiteToken from "../../hooks/useSiteToken";
14
13
  import SiteContext from "dumi/theme/slots/SiteContext";
@@ -19,16 +18,16 @@ var _ref = process.env.NODE_ENV === "production" ? {
19
18
  } : {
20
19
  name: "iaxhd9-mobileMenu",
21
20
  styles: "position:fixed;z-index:2;bottom:100px;right:20px;cursor:pointer;label:mobileMenu;",
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"]} */",
21
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErSG1CIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVub3JkZXJlZExpc3RPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENvbCwgQ29uZmlnUHJvdmlkZXIsIE1lbnUgfSBmcm9tICdhbnRkJztcbmltcG9ydCB7IHVzZVNpZGViYXJEYXRhIH0gZnJvbSAnZHVtaSc7XG5pbXBvcnQgTW9iaWxlTWVudSBmcm9tICdyYy1kcmF3ZXInO1xuaW1wb3J0ICdyYy1kcmF3ZXIvYXNzZXRzL2luZGV4LmNzcyc7XG5pbXBvcnQgUmVhY3QsIHsgRkMsIHVzZUNhbGxiYWNrLCB1c2VDb250ZXh0LCB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZU1lbnUgZnJvbSAnLi4vLi4vaG9va3MvdXNlTWVudSc7XG5pbXBvcnQgdXNlU2l0ZVRva2VuIGZyb20gJy4uLy4uL2hvb2tzL3VzZVNpdGVUb2tlbic7XG5pbXBvcnQgU2l0ZUNvbnRleHQgZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuXG5pbnRlcmZhY2UgU2lkZWJhclN0YXRlIHtcbiAgbW9iaWxlTWVudVZpc2libGU6IGJvb2xlYW47XG59XG5cbmNvbnN0IHVzZVN0eWxlID0gKCkgPT4ge1xuICBjb25zdCB7IHRva2VuIH0gPSB1c2VTaXRlVG9rZW4oKTtcblxuICBjb25zdCB7IGFudENscywgZm9udEZhbWlseSwgY29sb3JTcGxpdCB9ID0gdG9rZW47XG5cbiAgcmV0dXJuIHtcbiAgICBhc2lkZUNvbnRhaW5lcjogY3NzYFxuICAgICAgbWluLWhlaWdodDogMTAwJTtcbiAgICAgIHBhZGRpbmctYm90dG9tOiA0OHB4O1xuICAgICAgZm9udC1mYW1pbHk6IEF2ZW5pciwgJHtmb250RmFtaWx5fSwgc2Fucy1zZXJpZjtcblxuICAgICAgJiR7YW50Q2xzfS1tZW51LWlubGluZSB7XG4gICAgICAgIHVzZXItc2VsZWN0OiBub25lO1xuICAgICAgICAke2FudENsc30tbWVudS1zdWJtZW51LXRpdGxlIGg0LFxuICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0sXG4gICAgICAgICR7YW50Q2xzfS1tZW51LWl0ZW0gYSB7XG4gICAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgICAgICBmb250LXNpemU6IDE0cHg7XG4gICAgICAgICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgICAgIH1cblxuICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICBtYXJnaW4tdG9wOiAxNnB4O1xuICAgICAgICAgIG1hcmdpbi1ib3R0b206IDE2cHg7XG4gICAgICAgICAgZm9udC1zaXplOiAxM3B4O1xuXG4gICAgICAgICAgJjo6YWZ0ZXIge1xuICAgICAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICAgICAgdG9wOiAxMnB4O1xuICAgICAgICAgICAgZGlzcGxheTogYmxvY2s7XG4gICAgICAgICAgICB3aWR0aDogY2FsYygxMDAlIC0gMjBweCk7XG4gICAgICAgICAgICBoZWlnaHQ6IDFweDtcbiAgICAgICAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JTcGxpdH07XG4gICAgICAgICAgICBjb250ZW50OiAnJztcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0sXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1zdWJtZW51XG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1zdWJtZW51LXRpdGxlLFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC10aXRsZSxcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXBcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLWxpc3RcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0ge1xuICAgICAgICAgIHBhZGRpbmctbGVmdDogNDBweCAhaW1wb3J0YW50O1xuXG4gICAgICAgICAgJHthbnRDbHN9LXJvdy1ydGwgJiB7XG4gICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA0MHB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDE2cHggIWltcG9ydGFudDtcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICAvLyBOZXN0IENhdGVnb3J5ID4gVHlwZSA+IEFydGljbGVcbiAgICAgICAgJiR7YW50Q2xzfS1tZW51LWlubGluZSB7XG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC10aXRsZSB7XG4gICAgICAgICAgICBtYXJnaW4tbGVmdDogNHB4O1xuICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiA2MHB4O1xuXG4gICAgICAgICAgICAke2FudENsc30tcm93LXJ0bCAmIHtcbiAgICAgICAgICAgICAgcGFkZGluZy1yaWdodDogNjBweDtcbiAgICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiAxNnB4O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cblxuICAgICAgICAgICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdCA+ICR7YW50Q2xzfS1tZW51LWl0ZW0ge1xuICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiA4MHB4ICFpbXBvcnRhbnQ7XG5cbiAgICAgICAgICAgICR7YW50Q2xzfS1yb3ctcnRsICYge1xuICAgICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA4MHB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICAgIHBhZGRpbmctbGVmdDogMTZweCAhaW1wb3J0YW50O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXA6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC10aXRsZSB7XG4gICAgICAgICAgICBtYXJnaW4tdG9wOiAwO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBhW2Rpc2FibGVkXSB7XG4gICAgICAgIGNvbG9yOiAjY2NjO1xuICAgICAgfVxuXG4gICAgICAuY2hpbmVzZSB7XG4gICAgICAgIG1hcmdpbi1sZWZ0OiA2cHg7XG4gICAgICAgIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gICAgICAgIGZvbnQtc2l6ZTogMTJweDtcbiAgICAgICAgb3BhY2l0eTogMC42NztcbiAgICAgIH1cbiAgICBgLFxuICAgIG1haW5NZW51OiBjc3NgXG4gICAgICB6LWluZGV4OiAxO1xuXG4gICAgICAubWFpbi1tZW51LWlubmVyIHtcbiAgICAgICAgcG9zaXRpb246IHN0aWNreTtcbiAgICAgICAgdG9wOiA2NHB4O1xuICAgICAgICBoZWlnaHQ6IGNhbGMoMTAwdmggLSA2NHB4KTtcbiAgICAgICAgbWF4LWhlaWdodDogMTAwdmg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICB9XG5cbiAgICAgICY6aG92ZXIgLm1haW4tbWVudS1pbm5lciB7XG4gICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICB9XG4gICAgYCxcbiAgICBtb2JpbGVNZW51OiBjc3NgXG4gICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICB6LWluZGV4OiAyO1xuICAgICAgYm90dG9tOiAxMDBweDtcbiAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IFNpZGViYXI6IEZDID0gKCkgPT4ge1xuICBjb25zdCBbc2lkZWJhclN0YXRlLCBzZXRTaWRlYmFyU3RhdGVdID0gdXNlU3RhdGU8U2lkZWJhclN0YXRlPih7IG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZSB9KTtcbiAgY29uc3Qgc2lkZWJhckRhdGEgPSB1c2VTaWRlYmFyRGF0YSgpO1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7XG4gICAgdG9rZW46IHsgY29sb3JCZ0NvbnRhaW5lciB9XG4gIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyB0aGVtZSwgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBbbWVudUl0ZW1zLCBzZWxlY3RlZEtleV0gPSB1c2VNZW51KCk7XG5cbiAgY29uc3QgaXNEYXJrID0gdGhlbWUuaW5jbHVkZXMoJ2RhcmsnKTtcblxuICBjb25zdCBoYW5kbGVTaG93TW9iaWxlTWVudSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTaWRlYmFyU3RhdGUoKHByZXYpID0+ICh7XG4gICAgICAuLi5wcmV2LFxuICAgICAgbW9iaWxlTWVudVZpc2libGU6IHRydWVcbiAgICB9KSk7XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZU1vYmlsZU1lbnUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0U2lkZWJhclN0YXRlKChwcmV2KSA9PiAoe1xuICAgICAgLi4ucHJldixcbiAgICAgIG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZVxuICAgIH0pKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBoYW5kbGVDbG9zZU1vYmlsZU1lbnUoKTtcbiAgICB9XG4gIH0sIFtpc01vYmlsZSwgaGFuZGxlQ2xvc2VNb2JpbGVNZW51XSk7XG5cbiAgY29uc3QgeyBtb2JpbGVNZW51VmlzaWJsZSB9ID0gc2lkZWJhclN0YXRlO1xuXG4gIGNvbnN0IG1lbnVDaGlsZCA9IChcbiAgICA8Q29uZmlnUHJvdmlkZXJcbiAgICAgIHRoZW1lPXt7XG4gICAgICAgIGNvbXBvbmVudHM6IHtcbiAgICAgICAgICBNZW51OiB7XG4gICAgICAgICAgICBpdGVtQmc6IGNvbG9yQmdDb250YWluZXJcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgPlxuICAgICAgPE1lbnVcbiAgICAgICAgaXRlbXM9e21lbnVJdGVtc31cbiAgICAgICAgaW5saW5lSW5kZW50PXszMH1cbiAgICAgICAgY3NzPXtzdHlsZXMuYXNpZGVDb250YWluZXJ9XG4gICAgICAgIG1vZGU9XCJpbmxpbmVcIlxuICAgICAgICB0aGVtZT17aXNEYXJrID8gJ2RhcmsnIDogJ2xpZ2h0J31cbiAgICAgICAgc2VsZWN0ZWRLZXlzPXtbc2VsZWN0ZWRLZXldfVxuICAgICAgICBkZWZhdWx0T3BlbktleXM9e3NpZGViYXJEYXRhPy5tYXAoKHsgdGl0bGUgfSkgPT4gdGl0bGUpLmZpbHRlcigoaXRlbSkgPT4gaXRlbSkgYXMgc3RyaW5nW119XG4gICAgICAvPlxuICAgIDwvQ29uZmlnUHJvdmlkZXI+XG4gICk7XG5cbiAgcmV0dXJuIGlzTW9iaWxlID8gKFxuICAgIDxSZWFjdC5GcmFnbWVudD5cbiAgICAgIDxNb2JpbGVNZW51XG4gICAgICAgIGtleT1cIm1vYmlsZS1tZW51XCJcbiAgICAgICAgY29udGVudFdyYXBwZXJTdHlsZT17e1xuICAgICAgICAgIHdpZHRoOiAnMzAwcHgnXG4gICAgICAgIH19XG4gICAgICAgIG9wZW49e21vYmlsZU1lbnVWaXNpYmxlfVxuICAgICAgICBvbkNsb3NlPXtoYW5kbGVDbG9zZU1vYmlsZU1lbnV9XG4gICAgICA+XG4gICAgICAgIHttZW51Q2hpbGR9XG4gICAgICA8L01vYmlsZU1lbnU+XG4gICAgICB7KG1lbnVJdGVtcyA/PyBbXSkubGVuZ3RoID4gMSA/IChcbiAgICAgICAgPGRpdiBjc3M9e3N0eWxlcy5tb2JpbGVNZW51fSBvbkNsaWNrPXtoYW5kbGVTaG93TW9iaWxlTWVudX0+XG4gICAgICAgICAgPFVub3JkZXJlZExpc3RPdXRsaW5lZCAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICkgOiBudWxsfVxuICAgIDwvUmVhY3QuRnJhZ21lbnQ+XG4gICkgOiAoXG4gICAgPENvbCB4eGw9ezR9IHhsPXs1fSBsZz17Nn0gbWQ9ezZ9IHNtPXsyNH0geHM9ezI0fSBjc3M9e3N0eWxlcy5tYWluTWVudX0+XG4gICAgICA8c2VjdGlvbiBjbGFzc05hbWU9XCJtYWluLW1lbnUtaW5uZXJcIj57bWVudUNoaWxkfTwvc2VjdGlvbj5cbiAgICA8L0NvbD5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFNpZGViYXI7XG4iXX0= */",
23
22
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
24
23
  };
25
24
  var _ref2 = process.env.NODE_ENV === "production" ? {
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;}"
25
+ name: "3vru34",
26
+ styles: "z-index:1;.main-menu-inner{position:sticky;top:64px;height:calc(100vh - 64px);max-height:100vh;overflow:hidden;}&:hover .main-menu-inner{overflow-y:auto;}"
28
27
  } : {
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"]} */",
28
+ name: "jg72re-mainMenu",
29
+ styles: "z-index:1;.main-menu-inner{position:sticky;top:64px;height:calc(100vh - 64px);max-height:100vh;overflow:hidden;}&:hover .main-menu-inner{overflow-y:auto;};label:mainMenu;",
30
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnSGlCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVub3JkZXJlZExpc3RPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENvbCwgQ29uZmlnUHJvdmlkZXIsIE1lbnUgfSBmcm9tICdhbnRkJztcbmltcG9ydCB7IHVzZVNpZGViYXJEYXRhIH0gZnJvbSAnZHVtaSc7XG5pbXBvcnQgTW9iaWxlTWVudSBmcm9tICdyYy1kcmF3ZXInO1xuaW1wb3J0ICdyYy1kcmF3ZXIvYXNzZXRzL2luZGV4LmNzcyc7XG5pbXBvcnQgUmVhY3QsIHsgRkMsIHVzZUNhbGxiYWNrLCB1c2VDb250ZXh0LCB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZU1lbnUgZnJvbSAnLi4vLi4vaG9va3MvdXNlTWVudSc7XG5pbXBvcnQgdXNlU2l0ZVRva2VuIGZyb20gJy4uLy4uL2hvb2tzL3VzZVNpdGVUb2tlbic7XG5pbXBvcnQgU2l0ZUNvbnRleHQgZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuXG5pbnRlcmZhY2UgU2lkZWJhclN0YXRlIHtcbiAgbW9iaWxlTWVudVZpc2libGU6IGJvb2xlYW47XG59XG5cbmNvbnN0IHVzZVN0eWxlID0gKCkgPT4ge1xuICBjb25zdCB7IHRva2VuIH0gPSB1c2VTaXRlVG9rZW4oKTtcblxuICBjb25zdCB7IGFudENscywgZm9udEZhbWlseSwgY29sb3JTcGxpdCB9ID0gdG9rZW47XG5cbiAgcmV0dXJuIHtcbiAgICBhc2lkZUNvbnRhaW5lcjogY3NzYFxuICAgICAgbWluLWhlaWdodDogMTAwJTtcbiAgICAgIHBhZGRpbmctYm90dG9tOiA0OHB4O1xuICAgICAgZm9udC1mYW1pbHk6IEF2ZW5pciwgJHtmb250RmFtaWx5fSwgc2Fucy1zZXJpZjtcblxuICAgICAgJiR7YW50Q2xzfS1tZW51LWlubGluZSB7XG4gICAgICAgIHVzZXItc2VsZWN0OiBub25lO1xuICAgICAgICAke2FudENsc30tbWVudS1zdWJtZW51LXRpdGxlIGg0LFxuICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0sXG4gICAgICAgICR7YW50Q2xzfS1tZW51LWl0ZW0gYSB7XG4gICAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgICAgICBmb250LXNpemU6IDE0cHg7XG4gICAgICAgICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgICAgIH1cblxuICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICBtYXJnaW4tdG9wOiAxNnB4O1xuICAgICAgICAgIG1hcmdpbi1ib3R0b206IDE2cHg7XG4gICAgICAgICAgZm9udC1zaXplOiAxM3B4O1xuXG4gICAgICAgICAgJjo6YWZ0ZXIge1xuICAgICAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICAgICAgdG9wOiAxMnB4O1xuICAgICAgICAgICAgZGlzcGxheTogYmxvY2s7XG4gICAgICAgICAgICB3aWR0aDogY2FsYygxMDAlIC0gMjBweCk7XG4gICAgICAgICAgICBoZWlnaHQ6IDFweDtcbiAgICAgICAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JTcGxpdH07XG4gICAgICAgICAgICBjb250ZW50OiAnJztcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0sXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1zdWJtZW51XG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1zdWJtZW51LXRpdGxlLFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC10aXRsZSxcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXBcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLWxpc3RcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0ge1xuICAgICAgICAgIHBhZGRpbmctbGVmdDogNDBweCAhaW1wb3J0YW50O1xuXG4gICAgICAgICAgJHthbnRDbHN9LXJvdy1ydGwgJiB7XG4gICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA0MHB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDE2cHggIWltcG9ydGFudDtcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICAvLyBOZXN0IENhdGVnb3J5ID4gVHlwZSA+IEFydGljbGVcbiAgICAgICAgJiR7YW50Q2xzfS1tZW51LWlubGluZSB7XG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC10aXRsZSB7XG4gICAgICAgICAgICBtYXJnaW4tbGVmdDogNHB4O1xuICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiA2MHB4O1xuXG4gICAgICAgICAgICAke2FudENsc30tcm93LXJ0bCAmIHtcbiAgICAgICAgICAgICAgcGFkZGluZy1yaWdodDogNjBweDtcbiAgICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiAxNnB4O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cblxuICAgICAgICAgICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdCA+ICR7YW50Q2xzfS1tZW51LWl0ZW0ge1xuICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiA4MHB4ICFpbXBvcnRhbnQ7XG5cbiAgICAgICAgICAgICR7YW50Q2xzfS1yb3ctcnRsICYge1xuICAgICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA4MHB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICAgIHBhZGRpbmctbGVmdDogMTZweCAhaW1wb3J0YW50O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXA6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC10aXRsZSB7XG4gICAgICAgICAgICBtYXJnaW4tdG9wOiAwO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBhW2Rpc2FibGVkXSB7XG4gICAgICAgIGNvbG9yOiAjY2NjO1xuICAgICAgfVxuXG4gICAgICAuY2hpbmVzZSB7XG4gICAgICAgIG1hcmdpbi1sZWZ0OiA2cHg7XG4gICAgICAgIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gICAgICAgIGZvbnQtc2l6ZTogMTJweDtcbiAgICAgICAgb3BhY2l0eTogMC42NztcbiAgICAgIH1cbiAgICBgLFxuICAgIG1haW5NZW51OiBjc3NgXG4gICAgICB6LWluZGV4OiAxO1xuXG4gICAgICAubWFpbi1tZW51LWlubmVyIHtcbiAgICAgICAgcG9zaXRpb246IHN0aWNreTtcbiAgICAgICAgdG9wOiA2NHB4O1xuICAgICAgICBoZWlnaHQ6IGNhbGMoMTAwdmggLSA2NHB4KTtcbiAgICAgICAgbWF4LWhlaWdodDogMTAwdmg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICB9XG5cbiAgICAgICY6aG92ZXIgLm1haW4tbWVudS1pbm5lciB7XG4gICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICB9XG4gICAgYCxcbiAgICBtb2JpbGVNZW51OiBjc3NgXG4gICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICB6LWluZGV4OiAyO1xuICAgICAgYm90dG9tOiAxMDBweDtcbiAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IFNpZGViYXI6IEZDID0gKCkgPT4ge1xuICBjb25zdCBbc2lkZWJhclN0YXRlLCBzZXRTaWRlYmFyU3RhdGVdID0gdXNlU3RhdGU8U2lkZWJhclN0YXRlPih7IG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZSB9KTtcbiAgY29uc3Qgc2lkZWJhckRhdGEgPSB1c2VTaWRlYmFyRGF0YSgpO1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7XG4gICAgdG9rZW46IHsgY29sb3JCZ0NvbnRhaW5lciB9XG4gIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyB0aGVtZSwgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBbbWVudUl0ZW1zLCBzZWxlY3RlZEtleV0gPSB1c2VNZW51KCk7XG5cbiAgY29uc3QgaXNEYXJrID0gdGhlbWUuaW5jbHVkZXMoJ2RhcmsnKTtcblxuICBjb25zdCBoYW5kbGVTaG93TW9iaWxlTWVudSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTaWRlYmFyU3RhdGUoKHByZXYpID0+ICh7XG4gICAgICAuLi5wcmV2LFxuICAgICAgbW9iaWxlTWVudVZpc2libGU6IHRydWVcbiAgICB9KSk7XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZU1vYmlsZU1lbnUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0U2lkZWJhclN0YXRlKChwcmV2KSA9PiAoe1xuICAgICAgLi4ucHJldixcbiAgICAgIG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZVxuICAgIH0pKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBoYW5kbGVDbG9zZU1vYmlsZU1lbnUoKTtcbiAgICB9XG4gIH0sIFtpc01vYmlsZSwgaGFuZGxlQ2xvc2VNb2JpbGVNZW51XSk7XG5cbiAgY29uc3QgeyBtb2JpbGVNZW51VmlzaWJsZSB9ID0gc2lkZWJhclN0YXRlO1xuXG4gIGNvbnN0IG1lbnVDaGlsZCA9IChcbiAgICA8Q29uZmlnUHJvdmlkZXJcbiAgICAgIHRoZW1lPXt7XG4gICAgICAgIGNvbXBvbmVudHM6IHtcbiAgICAgICAgICBNZW51OiB7XG4gICAgICAgICAgICBpdGVtQmc6IGNvbG9yQmdDb250YWluZXJcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgPlxuICAgICAgPE1lbnVcbiAgICAgICAgaXRlbXM9e21lbnVJdGVtc31cbiAgICAgICAgaW5saW5lSW5kZW50PXszMH1cbiAgICAgICAgY3NzPXtzdHlsZXMuYXNpZGVDb250YWluZXJ9XG4gICAgICAgIG1vZGU9XCJpbmxpbmVcIlxuICAgICAgICB0aGVtZT17aXNEYXJrID8gJ2RhcmsnIDogJ2xpZ2h0J31cbiAgICAgICAgc2VsZWN0ZWRLZXlzPXtbc2VsZWN0ZWRLZXldfVxuICAgICAgICBkZWZhdWx0T3BlbktleXM9e3NpZGViYXJEYXRhPy5tYXAoKHsgdGl0bGUgfSkgPT4gdGl0bGUpLmZpbHRlcigoaXRlbSkgPT4gaXRlbSkgYXMgc3RyaW5nW119XG4gICAgICAvPlxuICAgIDwvQ29uZmlnUHJvdmlkZXI+XG4gICk7XG5cbiAgcmV0dXJuIGlzTW9iaWxlID8gKFxuICAgIDxSZWFjdC5GcmFnbWVudD5cbiAgICAgIDxNb2JpbGVNZW51XG4gICAgICAgIGtleT1cIm1vYmlsZS1tZW51XCJcbiAgICAgICAgY29udGVudFdyYXBwZXJTdHlsZT17e1xuICAgICAgICAgIHdpZHRoOiAnMzAwcHgnXG4gICAgICAgIH19XG4gICAgICAgIG9wZW49e21vYmlsZU1lbnVWaXNpYmxlfVxuICAgICAgICBvbkNsb3NlPXtoYW5kbGVDbG9zZU1vYmlsZU1lbnV9XG4gICAgICA+XG4gICAgICAgIHttZW51Q2hpbGR9XG4gICAgICA8L01vYmlsZU1lbnU+XG4gICAgICB7KG1lbnVJdGVtcyA/PyBbXSkubGVuZ3RoID4gMSA/IChcbiAgICAgICAgPGRpdiBjc3M9e3N0eWxlcy5tb2JpbGVNZW51fSBvbkNsaWNrPXtoYW5kbGVTaG93TW9iaWxlTWVudX0+XG4gICAgICAgICAgPFVub3JkZXJlZExpc3RPdXRsaW5lZCAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICkgOiBudWxsfVxuICAgIDwvUmVhY3QuRnJhZ21lbnQ+XG4gICkgOiAoXG4gICAgPENvbCB4eGw9ezR9IHhsPXs1fSBsZz17Nn0gbWQ9ezZ9IHNtPXsyNH0geHM9ezI0fSBjc3M9e3N0eWxlcy5tYWluTWVudX0+XG4gICAgICA8c2VjdGlvbiBjbGFzc05hbWU9XCJtYWluLW1lbnUtaW5uZXJcIj57bWVudUNoaWxkfTwvc2VjdGlvbj5cbiAgICA8L0NvbD5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFNpZGViYXI7XG4iXX0= */",
32
31
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
33
32
  };
34
33
  var useStyle = function useStyle() {
@@ -38,7 +37,7 @@ var useStyle = function useStyle() {
38
37
  fontFamily = token.fontFamily,
39
38
  colorSplit = token.colorSplit;
40
39
  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,{"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"]} */"),
40
+ 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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnVCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVub3JkZXJlZExpc3RPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENvbCwgQ29uZmlnUHJvdmlkZXIsIE1lbnUgfSBmcm9tICdhbnRkJztcbmltcG9ydCB7IHVzZVNpZGViYXJEYXRhIH0gZnJvbSAnZHVtaSc7XG5pbXBvcnQgTW9iaWxlTWVudSBmcm9tICdyYy1kcmF3ZXInO1xuaW1wb3J0ICdyYy1kcmF3ZXIvYXNzZXRzL2luZGV4LmNzcyc7XG5pbXBvcnQgUmVhY3QsIHsgRkMsIHVzZUNhbGxiYWNrLCB1c2VDb250ZXh0LCB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZU1lbnUgZnJvbSAnLi4vLi4vaG9va3MvdXNlTWVudSc7XG5pbXBvcnQgdXNlU2l0ZVRva2VuIGZyb20gJy4uLy4uL2hvb2tzL3VzZVNpdGVUb2tlbic7XG5pbXBvcnQgU2l0ZUNvbnRleHQgZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuXG5pbnRlcmZhY2UgU2lkZWJhclN0YXRlIHtcbiAgbW9iaWxlTWVudVZpc2libGU6IGJvb2xlYW47XG59XG5cbmNvbnN0IHVzZVN0eWxlID0gKCkgPT4ge1xuICBjb25zdCB7IHRva2VuIH0gPSB1c2VTaXRlVG9rZW4oKTtcblxuICBjb25zdCB7IGFudENscywgZm9udEZhbWlseSwgY29sb3JTcGxpdCB9ID0gdG9rZW47XG5cbiAgcmV0dXJuIHtcbiAgICBhc2lkZUNvbnRhaW5lcjogY3NzYFxuICAgICAgbWluLWhlaWdodDogMTAwJTtcbiAgICAgIHBhZGRpbmctYm90dG9tOiA0OHB4O1xuICAgICAgZm9udC1mYW1pbHk6IEF2ZW5pciwgJHtmb250RmFtaWx5fSwgc2Fucy1zZXJpZjtcblxuICAgICAgJiR7YW50Q2xzfS1tZW51LWlubGluZSB7XG4gICAgICAgIHVzZXItc2VsZWN0OiBub25lO1xuICAgICAgICAke2FudENsc30tbWVudS1zdWJtZW51LXRpdGxlIGg0LFxuICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0sXG4gICAgICAgICR7YW50Q2xzfS1tZW51LWl0ZW0gYSB7XG4gICAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgICAgICBmb250LXNpemU6IDE0cHg7XG4gICAgICAgICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgICAgIH1cblxuICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICBtYXJnaW4tdG9wOiAxNnB4O1xuICAgICAgICAgIG1hcmdpbi1ib3R0b206IDE2cHg7XG4gICAgICAgICAgZm9udC1zaXplOiAxM3B4O1xuXG4gICAgICAgICAgJjo6YWZ0ZXIge1xuICAgICAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICAgICAgdG9wOiAxMnB4O1xuICAgICAgICAgICAgZGlzcGxheTogYmxvY2s7XG4gICAgICAgICAgICB3aWR0aDogY2FsYygxMDAlIC0gMjBweCk7XG4gICAgICAgICAgICBoZWlnaHQ6IDFweDtcbiAgICAgICAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JTcGxpdH07XG4gICAgICAgICAgICBjb250ZW50OiAnJztcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0sXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1zdWJtZW51XG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1zdWJtZW51LXRpdGxlLFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC10aXRsZSxcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXBcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLWxpc3RcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0ge1xuICAgICAgICAgIHBhZGRpbmctbGVmdDogNDBweCAhaW1wb3J0YW50O1xuXG4gICAgICAgICAgJHthbnRDbHN9LXJvdy1ydGwgJiB7XG4gICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA0MHB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDE2cHggIWltcG9ydGFudDtcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICAvLyBOZXN0IENhdGVnb3J5ID4gVHlwZSA+IEFydGljbGVcbiAgICAgICAgJiR7YW50Q2xzfS1tZW51LWlubGluZSB7XG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC10aXRsZSB7XG4gICAgICAgICAgICBtYXJnaW4tbGVmdDogNHB4O1xuICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiA2MHB4O1xuXG4gICAgICAgICAgICAke2FudENsc30tcm93LXJ0bCAmIHtcbiAgICAgICAgICAgICAgcGFkZGluZy1yaWdodDogNjBweDtcbiAgICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiAxNnB4O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cblxuICAgICAgICAgICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdCA+ICR7YW50Q2xzfS1tZW51LWl0ZW0ge1xuICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiA4MHB4ICFpbXBvcnRhbnQ7XG5cbiAgICAgICAgICAgICR7YW50Q2xzfS1yb3ctcnRsICYge1xuICAgICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA4MHB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICAgIHBhZGRpbmctbGVmdDogMTZweCAhaW1wb3J0YW50O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXA6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC10aXRsZSB7XG4gICAgICAgICAgICBtYXJnaW4tdG9wOiAwO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBhW2Rpc2FibGVkXSB7XG4gICAgICAgIGNvbG9yOiAjY2NjO1xuICAgICAgfVxuXG4gICAgICAuY2hpbmVzZSB7XG4gICAgICAgIG1hcmdpbi1sZWZ0OiA2cHg7XG4gICAgICAgIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gICAgICAgIGZvbnQtc2l6ZTogMTJweDtcbiAgICAgICAgb3BhY2l0eTogMC42NztcbiAgICAgIH1cbiAgICBgLFxuICAgIG1haW5NZW51OiBjc3NgXG4gICAgICB6LWluZGV4OiAxO1xuXG4gICAgICAubWFpbi1tZW51LWlubmVyIHtcbiAgICAgICAgcG9zaXRpb246IHN0aWNreTtcbiAgICAgICAgdG9wOiA2NHB4O1xuICAgICAgICBoZWlnaHQ6IGNhbGMoMTAwdmggLSA2NHB4KTtcbiAgICAgICAgbWF4LWhlaWdodDogMTAwdmg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICB9XG5cbiAgICAgICY6aG92ZXIgLm1haW4tbWVudS1pbm5lciB7XG4gICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICB9XG4gICAgYCxcbiAgICBtb2JpbGVNZW51OiBjc3NgXG4gICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICB6LWluZGV4OiAyO1xuICAgICAgYm90dG9tOiAxMDBweDtcbiAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IFNpZGViYXI6IEZDID0gKCkgPT4ge1xuICBjb25zdCBbc2lkZWJhclN0YXRlLCBzZXRTaWRlYmFyU3RhdGVdID0gdXNlU3RhdGU8U2lkZWJhclN0YXRlPih7IG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZSB9KTtcbiAgY29uc3Qgc2lkZWJhckRhdGEgPSB1c2VTaWRlYmFyRGF0YSgpO1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7XG4gICAgdG9rZW46IHsgY29sb3JCZ0NvbnRhaW5lciB9XG4gIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyB0aGVtZSwgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBbbWVudUl0ZW1zLCBzZWxlY3RlZEtleV0gPSB1c2VNZW51KCk7XG5cbiAgY29uc3QgaXNEYXJrID0gdGhlbWUuaW5jbHVkZXMoJ2RhcmsnKTtcblxuICBjb25zdCBoYW5kbGVTaG93TW9iaWxlTWVudSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTaWRlYmFyU3RhdGUoKHByZXYpID0+ICh7XG4gICAgICAuLi5wcmV2LFxuICAgICAgbW9iaWxlTWVudVZpc2libGU6IHRydWVcbiAgICB9KSk7XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZU1vYmlsZU1lbnUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0U2lkZWJhclN0YXRlKChwcmV2KSA9PiAoe1xuICAgICAgLi4ucHJldixcbiAgICAgIG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZVxuICAgIH0pKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBoYW5kbGVDbG9zZU1vYmlsZU1lbnUoKTtcbiAgICB9XG4gIH0sIFtpc01vYmlsZSwgaGFuZGxlQ2xvc2VNb2JpbGVNZW51XSk7XG5cbiAgY29uc3QgeyBtb2JpbGVNZW51VmlzaWJsZSB9ID0gc2lkZWJhclN0YXRlO1xuXG4gIGNvbnN0IG1lbnVDaGlsZCA9IChcbiAgICA8Q29uZmlnUHJvdmlkZXJcbiAgICAgIHRoZW1lPXt7XG4gICAgICAgIGNvbXBvbmVudHM6IHtcbiAgICAgICAgICBNZW51OiB7XG4gICAgICAgICAgICBpdGVtQmc6IGNvbG9yQmdDb250YWluZXJcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgPlxuICAgICAgPE1lbnVcbiAgICAgICAgaXRlbXM9e21lbnVJdGVtc31cbiAgICAgICAgaW5saW5lSW5kZW50PXszMH1cbiAgICAgICAgY3NzPXtzdHlsZXMuYXNpZGVDb250YWluZXJ9XG4gICAgICAgIG1vZGU9XCJpbmxpbmVcIlxuICAgICAgICB0aGVtZT17aXNEYXJrID8gJ2RhcmsnIDogJ2xpZ2h0J31cbiAgICAgICAgc2VsZWN0ZWRLZXlzPXtbc2VsZWN0ZWRLZXldfVxuICAgICAgICBkZWZhdWx0T3BlbktleXM9e3NpZGViYXJEYXRhPy5tYXAoKHsgdGl0bGUgfSkgPT4gdGl0bGUpLmZpbHRlcigoaXRlbSkgPT4gaXRlbSkgYXMgc3RyaW5nW119XG4gICAgICAvPlxuICAgIDwvQ29uZmlnUHJvdmlkZXI+XG4gICk7XG5cbiAgcmV0dXJuIGlzTW9iaWxlID8gKFxuICAgIDxSZWFjdC5GcmFnbWVudD5cbiAgICAgIDxNb2JpbGVNZW51XG4gICAgICAgIGtleT1cIm1vYmlsZS1tZW51XCJcbiAgICAgICAgY29udGVudFdyYXBwZXJTdHlsZT17e1xuICAgICAgICAgIHdpZHRoOiAnMzAwcHgnXG4gICAgICAgIH19XG4gICAgICAgIG9wZW49e21vYmlsZU1lbnVWaXNpYmxlfVxuICAgICAgICBvbkNsb3NlPXtoYW5kbGVDbG9zZU1vYmlsZU1lbnV9XG4gICAgICA+XG4gICAgICAgIHttZW51Q2hpbGR9XG4gICAgICA8L01vYmlsZU1lbnU+XG4gICAgICB7KG1lbnVJdGVtcyA/PyBbXSkubGVuZ3RoID4gMSA/IChcbiAgICAgICAgPGRpdiBjc3M9e3N0eWxlcy5tb2JpbGVNZW51fSBvbkNsaWNrPXtoYW5kbGVTaG93TW9iaWxlTWVudX0+XG4gICAgICAgICAgPFVub3JkZXJlZExpc3RPdXRsaW5lZCAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICkgOiBudWxsfVxuICAgIDwvUmVhY3QuRnJhZ21lbnQ+XG4gICkgOiAoXG4gICAgPENvbCB4eGw9ezR9IHhsPXs1fSBsZz17Nn0gbWQ9ezZ9IHNtPXsyNH0geHM9ezI0fSBjc3M9e3N0eWxlcy5tYWluTWVudX0+XG4gICAgICA8c2VjdGlvbiBjbGFzc05hbWU9XCJtYWluLW1lbnUtaW5uZXJcIj57bWVudUNoaWxkfTwvc2VjdGlvbj5cbiAgICA8L0NvbD5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFNpZGViYXI7XG4iXX0= */"),
42
41
  mainMenu: _ref2,
43
42
  mobileMenu: _ref
44
43
  };
@@ -82,7 +81,6 @@ var Sidebar = function Sidebar() {
82
81
  }
83
82
  }, [isMobile, handleCloseMobileMenu]);
84
83
  var mobileMenuVisible = sidebarState.mobileMenuVisible;
85
- var affixTop = useAffixTop();
86
84
  var menuChild = ___EmotionJSX(ConfigProvider, {
87
85
  theme: {
88
86
  components: {
@@ -123,11 +121,8 @@ var Sidebar = function Sidebar() {
123
121
  sm: 24,
124
122
  xs: 24,
125
123
  css: styles.mainMenu
126
- }, ___EmotionJSX(Affix, {
127
- offsetTop: affixTop,
128
- className: "main-menu-affix"
129
124
  }, ___EmotionJSX("section", {
130
125
  className: "main-menu-inner"
131
- }, menuChild)));
126
+ }, menuChild));
132
127
  };
133
128
  export default Sidebar;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ahooks.js/dumi-theme-antd",
3
- "version": "0.1.7",
3
+ "version": "0.1.8",
4
4
  "description": "Ant Design 5.0 官网风格类似的 dumi2 主题插件",
5
5
  "keywords": [
6
6
  "dumi",
@@ -29,6 +29,7 @@
29
29
  "lint": "pnpm run lint:es && pnpm run lint:css",
30
30
  "lint:css": "stylelint \"{src,test}/**/*.{css,less}\"",
31
31
  "lint:es": "eslint \"{src,test}/**/*.{js,jsx,ts,tsx}\" --fix",
32
+ "clean": "pnpx rimraf --glob node_modules",
32
33
  "prepare": "husky install && father link-dev-theme",
33
34
  "prepublishOnly": "pnpm run doctor && pnpm run build"
34
35
  },
@@ -55,13 +56,13 @@
55
56
  },
56
57
  "dependencies": {
57
58
  "@ant-design/cssinjs": "1.16.2",
58
- "@ant-design/icons": "5.1.4",
59
+ "@ant-design/icons": "^6.1.0",
59
60
  "@babel/runtime": "7.22.3",
60
61
  "@ctrl/tinycolor": "3.6.0",
61
62
  "@emotion/css": "11.11.2",
62
63
  "@emotion/react": "11.14.0",
63
64
  "@emotion/server": "11.11.0",
64
- "antd-token-previewer": "2.0.0-alpha.6",
65
+ "antd-token-previewer": "^3.0.0",
65
66
  "classnames": "2.3.2",
66
67
  "crypto": "1.0.1",
67
68
  "dayjs": "1.11.7",