@ahooks.js/dumi-theme-antd 0.1.3 → 0.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (123) hide show
  1. package/README.md +7 -0
  2. package/package.json +6 -9
  3. package/dist/builtins/Alert/index.d.ts +0 -6
  4. package/dist/builtins/Alert/index.js +0 -25
  5. package/dist/builtins/BashOSPlatform/index.d.ts +0 -8
  6. package/dist/builtins/BashOSPlatform/index.js +0 -57
  7. package/dist/builtins/BashOSPlatform/linux.d.ts +0 -7
  8. package/dist/builtins/BashOSPlatform/linux.js +0 -60
  9. package/dist/builtins/BashOSPlatform/macos.d.ts +0 -7
  10. package/dist/builtins/BashOSPlatform/macos.js +0 -22
  11. package/dist/builtins/BashOSPlatform/windows.d.ts +0 -7
  12. package/dist/builtins/BashOSPlatform/windows.js +0 -20
  13. package/dist/builtins/HomeBaseLayout/components/Features/index.d.ts +0 -3
  14. package/dist/builtins/HomeBaseLayout/components/Features/index.js +0 -78
  15. package/dist/builtins/HomeBaseLayout/components/Group.d.ts +0 -19
  16. package/dist/builtins/HomeBaseLayout/components/Group.js +0 -89
  17. package/dist/builtins/HomeBaseLayout/index.d.ts +0 -3
  18. package/dist/builtins/HomeBaseLayout/index.js +0 -202
  19. package/dist/builtins/ImagePreview/index.d.ts +0 -3
  20. package/dist/builtins/ImagePreview/index.js +0 -105
  21. package/dist/builtins/InstallDependencies/icons.d.ts +0 -10
  22. package/dist/builtins/InstallDependencies/icons.js +0 -131
  23. package/dist/builtins/InstallDependencies/index.d.ts +0 -9
  24. package/dist/builtins/InstallDependencies/index.js +0 -58
  25. package/dist/common/CommonHelmet.d.ts +0 -2
  26. package/dist/common/CommonHelmet.js +0 -27
  27. package/dist/common/EditLink.d.ts +0 -2
  28. package/dist/common/EditLink.js +0 -24
  29. package/dist/common/GlobalStyles.d.ts +0 -2
  30. package/dist/common/GlobalStyles.js +0 -7
  31. package/dist/common/LastUpdated.d.ts +0 -5
  32. package/dist/common/LastUpdated.js +0 -53
  33. package/dist/common/Loading/index.d.ts +0 -3
  34. package/dist/common/Loading/index.js +0 -67
  35. package/dist/common/PrevAndNext.d.ts +0 -3
  36. package/dist/common/PrevAndNext.js +0 -88
  37. package/dist/common/ThemeSwitch/ThemeIcon.d.ts +0 -5
  38. package/dist/common/ThemeSwitch/ThemeIcon.js +0 -24
  39. package/dist/common/ThemeSwitch/index.d.ts +0 -8
  40. package/dist/common/ThemeSwitch/index.js +0 -45
  41. package/dist/common/styles/Common.d.ts +0 -2
  42. package/dist/common/styles/Common.js +0 -10
  43. package/dist/common/styles/DumiDefaultStyleOverride.d.ts +0 -2
  44. package/dist/common/styles/DumiDefaultStyleOverride.js +0 -12
  45. package/dist/common/styles/HeadingAnchor.d.ts +0 -2
  46. package/dist/common/styles/HeadingAnchor.js +0 -17
  47. package/dist/common/styles/Highlight.d.ts +0 -2
  48. package/dist/common/styles/Highlight.js +0 -10
  49. package/dist/common/styles/Markdown.d.ts +0 -2
  50. package/dist/common/styles/Markdown.js +0 -13
  51. package/dist/common/styles/PreviewImage.d.ts +0 -2
  52. package/dist/common/styles/PreviewImage.js +0 -10
  53. package/dist/common/styles/Reset.d.ts +0 -2
  54. package/dist/common/styles/Reset.js +0 -17
  55. package/dist/common/styles/Responsive.d.ts +0 -2
  56. package/dist/common/styles/Responsive.js +0 -10
  57. package/dist/common/styles/SearchBar.d.ts +0 -2
  58. package/dist/common/styles/SearchBar.js +0 -11
  59. package/dist/common/styles/index.d.ts +0 -9
  60. package/dist/common/styles/index.js +0 -9
  61. package/dist/hooks/useAdditionalThemeConfig.d.ts +0 -3
  62. package/dist/hooks/useAdditionalThemeConfig.js +0 -9
  63. package/dist/hooks/useLocaleValue.d.ts +0 -1
  64. package/dist/hooks/useLocaleValue.js +0 -10
  65. package/dist/hooks/useMenu.d.ts +0 -8
  66. package/dist/hooks/useMenu.js +0 -263
  67. package/dist/hooks/useSiteToken.d.ts +0 -21
  68. package/dist/hooks/useSiteToken.js +0 -41
  69. package/dist/hooks/uselocale.d.ts +0 -5
  70. package/dist/hooks/uselocale.js +0 -7
  71. package/dist/icons/LTRIcon.d.ts +0 -5
  72. package/dist/icons/LTRIcon.js +0 -18
  73. package/dist/icons/RTLIcon.d.ts +0 -5
  74. package/dist/icons/RTLIcon.js +0 -18
  75. package/dist/index.d.ts +0 -11
  76. package/dist/index.js +0 -13
  77. package/dist/layouts/DocLayout/index.d.ts +0 -4
  78. package/dist/layouts/DocLayout/index.js +0 -87
  79. package/dist/layouts/GlobalLayout.d.ts +0 -3
  80. package/dist/layouts/GlobalLayout.js +0 -153
  81. package/dist/layouts/HomePageLayout/index.d.ts +0 -3
  82. package/dist/layouts/HomePageLayout/index.js +0 -7
  83. package/dist/layouts/SidebarLayout/index.d.ts +0 -3
  84. package/dist/layouts/SidebarLayout/index.js +0 -28
  85. package/dist/locales/en-US.json +0 -9
  86. package/dist/locales/zh-CN.json +0 -9
  87. package/dist/plugin/index.d.ts +0 -3
  88. package/dist/plugin/index.js +0 -30
  89. package/dist/plugin.d.ts +0 -4
  90. package/dist/plugin.js +0 -117
  91. package/dist/slots/Content/index.d.ts +0 -5
  92. package/dist/slots/Content/index.js +0 -159
  93. package/dist/slots/Footer/index.d.ts +0 -3
  94. package/dist/slots/Footer/index.js +0 -61
  95. package/dist/slots/Header/HeaderExtral.d.ts +0 -3
  96. package/dist/slots/Header/HeaderExtral.js +0 -34
  97. package/dist/slots/Header/Logo.d.ts +0 -2
  98. package/dist/slots/Header/Logo.js +0 -55
  99. package/dist/slots/Header/More.d.ts +0 -6
  100. package/dist/slots/Header/More.js +0 -32
  101. package/dist/slots/Header/Navigation.d.ts +0 -6
  102. package/dist/slots/Header/Navigation.js +0 -140
  103. package/dist/slots/Header/SwitchBtn.d.ts +0 -11
  104. package/dist/slots/Header/SwitchBtn.js +0 -85
  105. package/dist/slots/Header/index.d.ts +0 -4
  106. package/dist/slots/Header/index.js +0 -187
  107. package/dist/slots/LangSwitch/index.d.ts +0 -3
  108. package/dist/slots/LangSwitch/index.js +0 -84
  109. package/dist/slots/NotFound/index.d.ts +0 -9
  110. package/dist/slots/NotFound/index.js +0 -25
  111. package/dist/slots/RtlSwitch/index.d.ts +0 -3
  112. package/dist/slots/RtlSwitch/index.js +0 -53
  113. package/dist/slots/Sidebar/index.d.ts +0 -4
  114. package/dist/slots/Sidebar/index.js +0 -128
  115. package/dist/slots/SiteContext.d.ts +0 -10
  116. package/dist/slots/SiteContext.js +0 -8
  117. package/dist/static/style.d.ts +0 -1
  118. package/dist/static/style.js +0 -1
  119. package/dist/styles/variables.less +0 -1
  120. package/dist/types.d.ts +0 -105
  121. package/dist/types.js +0 -1
  122. package/dist/utils.d.ts +0 -10
  123. package/dist/utils.js +0 -18
@@ -1,140 +0,0 @@
1
- import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
2
- import { MenuFoldOutlined } from '@ant-design/icons';
3
- import { css } from '@emotion/react';
4
- import { Menu } from 'antd';
5
- import { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';
6
- import { useCallback } from 'react';
7
- import useAdditionalThemeConfig from "../../hooks/useAdditionalThemeConfig";
8
- import useLocaleValue from "../../hooks/useLocaleValue";
9
- import useSiteToken from "../../hooks/useSiteToken";
10
- import { getTargetLocalePath, isExternalLinks } from "../../utils";
11
- import { getMoreLinksGroup } from "./More";
12
- import { jsx as ___EmotionJSX } from "@emotion/react";
13
- var getWithoutLocaleFirstPath = function getWithoutLocaleFirstPath(pathname, localeBase) {
14
- if (!pathname) return '';
15
- if (!localeBase || isExternalLinks(pathname)) return pathname;
16
- var splitPaths = pathname.split('/').filter(Boolean);
17
- var pathLocalePrefix = localeBase === '/' ? '' : localeBase;
18
- var firstPath = splitPaths.slice(0, pathLocalePrefix ? 2 : 1).join('/');
19
- return firstPath;
20
- };
21
- var useStyle = function useStyle() {
22
- var _useSiteToken = useSiteToken(),
23
- token = _useSiteToken.token;
24
- var antCls = token.antCls,
25
- iconCls = token.iconCls,
26
- fontFamily = token.fontFamily,
27
- headerHeight = token.headerHeight,
28
- menuItemBorder = token.menuItemBorder,
29
- colorPrimary = token.colorPrimary;
30
- return {
31
- nav: /*#__PURE__*/css("height:100%;font-size:14px;font-family:Avenir,", fontFamily, ",sans-serif;border:0;&", antCls, "-menu-horizontal{border-bottom:none;&>", antCls, "-menu-item,&>", antCls, "-menu-submenu{min-width:(40px + 12px * 2);height:", headerHeight, "px;padding-right:12px;padding-left:12px;line-height:", headerHeight, "px;&::after{top:0;right:12px;bottom:auto;left:12px;border-width:", menuItemBorder, "px;}}& ", antCls, "-menu-submenu-title ", iconCls, "{margin:0;}&>", antCls, "-menu-item-selected{a{color:", colorPrimary, ";}}}&>", antCls, "-menu-item,&>", antCls, "-menu-submenu{text-align:center;}" + (process.env.NODE_ENV === "production" ? "" : ";label:nav;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Navigation.tsx"],"names":[],"mappings":"AAsCY","file":"Navigation.tsx","sourcesContent":["import { MenuFoldOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport type { MenuProps } from 'antd';\nimport { Menu } from 'antd';\nimport { MenuItemType } from 'antd/es/menu/hooks/useItems';\nimport { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { getTargetLocalePath, isExternalLinks } from '../../utils';\nimport { type IResponsive } from './index';\nimport { getMoreLinksGroup } from './More';\n\ntype MenuItemsType = Required<MenuProps>['items'];\n\nexport interface NavigationProps {\n  isMobile: boolean;\n  responsive: IResponsive;\n}\n\nconst getWithoutLocaleFirstPath = (pathname?: string, localeBase?: string) => {\n  if (!pathname) return '';\n  if (!localeBase || isExternalLinks(pathname)) return pathname;\n\n  const splitPaths = pathname.split('/').filter(Boolean);\n  const pathLocalePrefix = localeBase === '/' ? '' : localeBase;\n  const firstPath = splitPaths.slice(0, pathLocalePrefix ? 2 : 1).join('/');\n\n  return firstPath;\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls, iconCls, fontFamily, headerHeight, menuItemBorder, colorPrimary } = token;\n\n  return {\n    nav: css`\n      height: 100%;\n      font-size: 14px;\n      font-family: Avenir, ${fontFamily}, sans-serif;\n      border: 0;\n\n      &${antCls}-menu-horizontal {\n        border-bottom: none;\n\n        & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n          min-width: (40px + 12px * 2);\n          height: ${headerHeight}px;\n          padding-right: 12px;\n          padding-left: 12px;\n          line-height: ${headerHeight}px;\n\n          &::after {\n            top: 0;\n            right: 12px;\n            bottom: auto;\n            left: 12px;\n            border-width: ${menuItemBorder}px;\n          }\n        }\n\n        & ${antCls}-menu-submenu-title ${iconCls} {\n          margin: 0;\n        }\n\n        & > ${antCls}-menu-item-selected {\n          a {\n            color: ${colorPrimary};\n          }\n        }\n      }\n\n      & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n        text-align: center;\n      }\n    `,\n    popoverMenuNav: css`\n      ${antCls}-menu-item,\n      ${antCls}-menu-submenu {\n        text-align: left;\n      }\n\n      ${antCls}-menu-item-group-title {\n        padding-left: 24px;\n      }\n\n      ${antCls}-menu-item-group-list {\n        padding: 0 16px;\n      }\n\n      ${antCls}-menu-item,\n      a {\n        color: #333;\n      }\n    `\n  };\n};\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const { github, socialLinks } = useAdditionalThemeConfig();\n\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n  const locale = useLocale() as ReturnType<typeof useLocale> & { base: string };\n  const moreLinks = useLocaleValue('moreLinks');\n  const activeKey = getWithoutLocaleFirstPath(pathname, locale.base);\n\n  const menuItems: MenuItemType[] = (navList ?? [])\n    .map((navItem) => {\n      const { title, link } = navItem || {};\n      const key = getWithoutLocaleFirstPath(link, locale.base);\n      const path = `${link}${search}`;\n\n      return {\n        key,\n        label: isExternalLinks(link) ? (\n          <a href={path} target=\"_blank\" rel=\"noopener noreferrer\">\n            {title}\n          </a>\n        ) : (\n          <Link to={path}>{title}</Link>\n        )\n      } as MenuItemType;\n    })\n    .filter(Boolean);\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback(() => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = locales.filter((item) => item.id !== locale.id)[0];\n      const nextPath = getTargetLocalePath({\n        current: locale,\n        target: nextLang\n      });\n      return {\n        label: (\n          <a rel=\"noopener noreferrer\" href={nextPath}>\n            {nextLang.name}\n          </a>\n        ),\n        key: nextLang.id\n      };\n    }\n    return {\n      label: <span>{locale.name}</span>,\n      key: 'multi-lang',\n      children: locales\n        .filter((item) => item.id !== locale.id)\n        .map((item) => {\n          const nextPath = getTargetLocalePath({\n            current: locale,\n            target: item\n          });\n          return {\n            label: (\n              <a rel=\"noopener noreferrer\" href={nextPath}>\n                {item.name}\n              </a>\n            ),\n            key: item.id\n          };\n        })\n    };\n  }, [locale, locales]);\n\n  let additional: MenuItemsType;\n  const additionalItems: MenuItemsType = [\n    github || socialLinks?.github\n      ? {\n          label: (\n            <a rel=\"noopener noreferrer\" href={github || socialLinks?.github} target=\"_blank\">\n              GitHub\n            </a>\n          ),\n          key: 'github'\n        }\n      : null,\n    getLangNode(),\n    ...(getMoreLinksGroup(moreLinks) || [])\n  ];\n\n  if (isMobile) {\n    additional = additionalItems;\n  } else if (responsive === 'crowded') {\n    additional = [\n      {\n        label: <MenuFoldOutlined />,\n        key: 'additional',\n        children: [...additionalItems]\n      }\n    ];\n  }\n\n  const items: MenuItemsType = [...(menuItems ?? []), ...(additional ?? [])];\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n\n  return (\n    <Menu\n      items={items}\n      mode={menuMode}\n      css={style.nav}\n      selectedKeys={[activeKey]}\n      disabledOverflow\n    />\n  );\n}\n"]} */"),
32
- popoverMenuNav: /*#__PURE__*/css(antCls, "-menu-item,", antCls, "-menu-submenu{text-align:left;}", antCls, "-menu-item-group-title{padding-left:24px;}", antCls, "-menu-item-group-list{padding:0 16px;}", antCls, "-menu-item,a{color:#333;}" + (process.env.NODE_ENV === "production" ? "" : ";label:popoverMenuNav;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Navigation.tsx"],"names":[],"mappings":"AA8EuB","file":"Navigation.tsx","sourcesContent":["import { MenuFoldOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport type { MenuProps } from 'antd';\nimport { Menu } from 'antd';\nimport { MenuItemType } from 'antd/es/menu/hooks/useItems';\nimport { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { getTargetLocalePath, isExternalLinks } from '../../utils';\nimport { type IResponsive } from './index';\nimport { getMoreLinksGroup } from './More';\n\ntype MenuItemsType = Required<MenuProps>['items'];\n\nexport interface NavigationProps {\n  isMobile: boolean;\n  responsive: IResponsive;\n}\n\nconst getWithoutLocaleFirstPath = (pathname?: string, localeBase?: string) => {\n  if (!pathname) return '';\n  if (!localeBase || isExternalLinks(pathname)) return pathname;\n\n  const splitPaths = pathname.split('/').filter(Boolean);\n  const pathLocalePrefix = localeBase === '/' ? '' : localeBase;\n  const firstPath = splitPaths.slice(0, pathLocalePrefix ? 2 : 1).join('/');\n\n  return firstPath;\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls, iconCls, fontFamily, headerHeight, menuItemBorder, colorPrimary } = token;\n\n  return {\n    nav: css`\n      height: 100%;\n      font-size: 14px;\n      font-family: Avenir, ${fontFamily}, sans-serif;\n      border: 0;\n\n      &${antCls}-menu-horizontal {\n        border-bottom: none;\n\n        & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n          min-width: (40px + 12px * 2);\n          height: ${headerHeight}px;\n          padding-right: 12px;\n          padding-left: 12px;\n          line-height: ${headerHeight}px;\n\n          &::after {\n            top: 0;\n            right: 12px;\n            bottom: auto;\n            left: 12px;\n            border-width: ${menuItemBorder}px;\n          }\n        }\n\n        & ${antCls}-menu-submenu-title ${iconCls} {\n          margin: 0;\n        }\n\n        & > ${antCls}-menu-item-selected {\n          a {\n            color: ${colorPrimary};\n          }\n        }\n      }\n\n      & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n        text-align: center;\n      }\n    `,\n    popoverMenuNav: css`\n      ${antCls}-menu-item,\n      ${antCls}-menu-submenu {\n        text-align: left;\n      }\n\n      ${antCls}-menu-item-group-title {\n        padding-left: 24px;\n      }\n\n      ${antCls}-menu-item-group-list {\n        padding: 0 16px;\n      }\n\n      ${antCls}-menu-item,\n      a {\n        color: #333;\n      }\n    `\n  };\n};\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const { github, socialLinks } = useAdditionalThemeConfig();\n\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n  const locale = useLocale() as ReturnType<typeof useLocale> & { base: string };\n  const moreLinks = useLocaleValue('moreLinks');\n  const activeKey = getWithoutLocaleFirstPath(pathname, locale.base);\n\n  const menuItems: MenuItemType[] = (navList ?? [])\n    .map((navItem) => {\n      const { title, link } = navItem || {};\n      const key = getWithoutLocaleFirstPath(link, locale.base);\n      const path = `${link}${search}`;\n\n      return {\n        key,\n        label: isExternalLinks(link) ? (\n          <a href={path} target=\"_blank\" rel=\"noopener noreferrer\">\n            {title}\n          </a>\n        ) : (\n          <Link to={path}>{title}</Link>\n        )\n      } as MenuItemType;\n    })\n    .filter(Boolean);\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback(() => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = locales.filter((item) => item.id !== locale.id)[0];\n      const nextPath = getTargetLocalePath({\n        current: locale,\n        target: nextLang\n      });\n      return {\n        label: (\n          <a rel=\"noopener noreferrer\" href={nextPath}>\n            {nextLang.name}\n          </a>\n        ),\n        key: nextLang.id\n      };\n    }\n    return {\n      label: <span>{locale.name}</span>,\n      key: 'multi-lang',\n      children: locales\n        .filter((item) => item.id !== locale.id)\n        .map((item) => {\n          const nextPath = getTargetLocalePath({\n            current: locale,\n            target: item\n          });\n          return {\n            label: (\n              <a rel=\"noopener noreferrer\" href={nextPath}>\n                {item.name}\n              </a>\n            ),\n            key: item.id\n          };\n        })\n    };\n  }, [locale, locales]);\n\n  let additional: MenuItemsType;\n  const additionalItems: MenuItemsType = [\n    github || socialLinks?.github\n      ? {\n          label: (\n            <a rel=\"noopener noreferrer\" href={github || socialLinks?.github} target=\"_blank\">\n              GitHub\n            </a>\n          ),\n          key: 'github'\n        }\n      : null,\n    getLangNode(),\n    ...(getMoreLinksGroup(moreLinks) || [])\n  ];\n\n  if (isMobile) {\n    additional = additionalItems;\n  } else if (responsive === 'crowded') {\n    additional = [\n      {\n        label: <MenuFoldOutlined />,\n        key: 'additional',\n        children: [...additionalItems]\n      }\n    ];\n  }\n\n  const items: MenuItemsType = [...(menuItems ?? []), ...(additional ?? [])];\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n\n  return (\n    <Menu\n      items={items}\n      mode={menuMode}\n      css={style.nav}\n      selectedKeys={[activeKey]}\n      disabledOverflow\n    />\n  );\n}\n"]} */")
33
- };
34
- };
35
- export default function Navigation(_ref) {
36
- var _additional;
37
- var isMobile = _ref.isMobile,
38
- responsive = _ref.responsive;
39
- var _useLocation = useLocation(),
40
- pathname = _useLocation.pathname,
41
- search = _useLocation.search;
42
- var _useSiteData = useSiteData(),
43
- locales = _useSiteData.locales;
44
- var _useAdditionalThemeCo = useAdditionalThemeConfig(),
45
- github = _useAdditionalThemeCo.github,
46
- socialLinks = _useAdditionalThemeCo.socialLinks;
47
-
48
- // 统一使用 themeConfig.nav,使用 useNavData,当存在自定义 pages 时,会导致 nav 混乱
49
- var navList = useNavData();
50
- var locale = useLocale();
51
- var moreLinks = useLocaleValue('moreLinks');
52
- var activeKey = getWithoutLocaleFirstPath(pathname, locale.base);
53
- var menuItems = (navList !== null && navList !== void 0 ? navList : []).map(function (navItem) {
54
- var _ref2 = navItem || {},
55
- title = _ref2.title,
56
- link = _ref2.link;
57
- var key = getWithoutLocaleFirstPath(link, locale.base);
58
- var path = "".concat(link).concat(search);
59
- return {
60
- key: key,
61
- label: isExternalLinks(link) ? ___EmotionJSX("a", {
62
- href: path,
63
- target: "_blank",
64
- rel: "noopener noreferrer"
65
- }, title) : ___EmotionJSX(Link, {
66
- to: path
67
- }, title)
68
- };
69
- }).filter(Boolean);
70
-
71
- // 获取小屏幕下多语言导航栏节点
72
- var getLangNode = useCallback(function () {
73
- if (locales.length < 2) {
74
- return null;
75
- }
76
- if (locales.length === 2) {
77
- var nextLang = locales.filter(function (item) {
78
- return item.id !== locale.id;
79
- })[0];
80
- var nextPath = getTargetLocalePath({
81
- current: locale,
82
- target: nextLang
83
- });
84
- return {
85
- label: ___EmotionJSX("a", {
86
- rel: "noopener noreferrer",
87
- href: nextPath
88
- }, nextLang.name),
89
- key: nextLang.id
90
- };
91
- }
92
- return {
93
- label: ___EmotionJSX("span", null, locale.name),
94
- key: 'multi-lang',
95
- children: locales.filter(function (item) {
96
- return item.id !== locale.id;
97
- }).map(function (item) {
98
- var nextPath = getTargetLocalePath({
99
- current: locale,
100
- target: item
101
- });
102
- return {
103
- label: ___EmotionJSX("a", {
104
- rel: "noopener noreferrer",
105
- href: nextPath
106
- }, item.name),
107
- key: item.id
108
- };
109
- })
110
- };
111
- }, [locale, locales]);
112
- var additional;
113
- var additionalItems = [github || socialLinks !== null && socialLinks !== void 0 && socialLinks.github ? {
114
- label: ___EmotionJSX("a", {
115
- rel: "noopener noreferrer",
116
- href: github || (socialLinks === null || socialLinks === void 0 ? void 0 : socialLinks.github),
117
- target: "_blank"
118
- }, "GitHub"),
119
- key: 'github'
120
- } : null, getLangNode()].concat(_toConsumableArray(getMoreLinksGroup(moreLinks) || []));
121
- if (isMobile) {
122
- additional = additionalItems;
123
- } else if (responsive === 'crowded') {
124
- additional = [{
125
- label: ___EmotionJSX(MenuFoldOutlined, null),
126
- key: 'additional',
127
- children: _toConsumableArray(additionalItems)
128
- }];
129
- }
130
- var items = [].concat(_toConsumableArray(menuItems !== null && menuItems !== void 0 ? menuItems : []), _toConsumableArray((_additional = additional) !== null && _additional !== void 0 ? _additional : []));
131
- var menuMode = isMobile ? 'inline' : 'horizontal';
132
- var style = useStyle();
133
- return ___EmotionJSX(Menu, {
134
- items: items,
135
- mode: menuMode,
136
- css: style.nav,
137
- selectedKeys: [activeKey],
138
- disabledOverflow: true
139
- });
140
- }
@@ -1,11 +0,0 @@
1
- import React from 'react';
2
- export interface LangBtnProps {
3
- label1: React.ReactNode;
4
- label2: React.ReactNode;
5
- tooltip1?: React.ReactNode;
6
- tooltip2?: React.ReactNode;
7
- value: 1 | 2;
8
- pure?: boolean;
9
- onClick?: React.MouseEventHandler;
10
- }
11
- export default function SwitchBtn({ label1, label2, tooltip1, tooltip2, value, pure, onClick }: LangBtnProps): import("@emotion/react/types/jsx-namespace").EmotionJSX.Element;
@@ -1,85 +0,0 @@
1
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
- import { css } from '@emotion/react';
3
- import { Tooltip } from 'antd';
4
- import React from 'react';
5
- import useSiteToken from "../../hooks/useSiteToken";
6
- import { jsx as ___EmotionJSX } from "@emotion/react";
7
- var BASE_SIZE = '1.2em';
8
- var useStyle = function useStyle() {
9
- var _useSiteToken = useSiteToken(),
10
- token = _useSiteToken.token;
11
- var controlHeight = token.controlHeight,
12
- motionDurationMid = token.motionDurationMid;
13
- return {
14
- btn: /*#__PURE__*/css("color:", token.colorText, ";border-color:", token.colorBorder, ";padding:0!important;width:", controlHeight, "px;height:", controlHeight, "px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:", token.borderRadius, "px;transition:all ", motionDurationMid, ";cursor:pointer;.btn-inner{transition:all ", motionDurationMid, ";}&:hover{background:", token.colorBgTextHover, ";}img{width:", BASE_SIZE, ";height:", BASE_SIZE, ";}.anticon{font-size:", BASE_SIZE, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:btn;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN3aXRjaEJ0bi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0JZIiwiZmlsZSI6IlN3aXRjaEJ0bi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZVNpdGVUb2tlbiBmcm9tICcuLi8uLi9ob29rcy91c2VTaXRlVG9rZW4nO1xuXG5leHBvcnQgaW50ZXJmYWNlIExhbmdCdG5Qcm9wcyB7XG4gIGxhYmVsMTogUmVhY3QuUmVhY3ROb2RlO1xuICBsYWJlbDI6IFJlYWN0LlJlYWN0Tm9kZTtcbiAgdG9vbHRpcDE/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIHRvb2x0aXAyPzogUmVhY3QuUmVhY3ROb2RlO1xuICB2YWx1ZTogMSB8IDI7XG4gIHB1cmU/OiBib29sZWFuO1xuICBvbkNsaWNrPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI7XG59XG5cbmNvbnN0IEJBU0VfU0laRSA9ICcxLjJlbSc7XG5cbmNvbnN0IHVzZVN0eWxlID0gKCkgPT4ge1xuICBjb25zdCB7IHRva2VuIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyBjb250cm9sSGVpZ2h0LCBtb3Rpb25EdXJhdGlvbk1pZCB9ID0gdG9rZW47XG5cbiAgcmV0dXJuIHtcbiAgICBidG46IGNzc2BcbiAgICAgIGNvbG9yOiAke3Rva2VuLmNvbG9yVGV4dH07XG4gICAgICBib3JkZXItY29sb3I6ICR7dG9rZW4uY29sb3JCb3JkZXJ9O1xuICAgICAgcGFkZGluZzogMCAhaW1wb3J0YW50O1xuICAgICAgd2lkdGg6ICR7Y29udHJvbEhlaWdodH1weDtcbiAgICAgIGhlaWdodDogJHtjb250cm9sSGVpZ2h0fXB4O1xuICAgICAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gICAgICBib3JkZXI6IG5vbmU7XG4gICAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgICAgIGJvcmRlci1yYWRpdXM6ICR7dG9rZW4uYm9yZGVyUmFkaXVzfXB4O1xuICAgICAgdHJhbnNpdGlvbjogYWxsICR7bW90aW9uRHVyYXRpb25NaWR9O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuXG4gICAgICAuYnRuLWlubmVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogYWxsICR7bW90aW9uRHVyYXRpb25NaWR9O1xuICAgICAgfVxuXG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgYmFja2dyb3VuZDogJHt0b2tlbi5jb2xvckJnVGV4dEhvdmVyfTtcbiAgICAgIH1cblxuICAgICAgaW1nIHtcbiAgICAgICAgd2lkdGg6ICR7QkFTRV9TSVpFfTtcbiAgICAgICAgaGVpZ2h0OiAke0JBU0VfU0laRX07XG4gICAgICB9XG5cbiAgICAgIC5hbnRpY29uIHtcbiAgICAgICAgZm9udC1zaXplOiAke0JBU0VfU0laRX07XG4gICAgICB9XG4gICAgYFxuICB9O1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gU3dpdGNoQnRuKHtcbiAgbGFiZWwxLFxuICBsYWJlbDIsXG4gIHRvb2x0aXAxLFxuICB0b29sdGlwMixcbiAgdmFsdWUsXG4gIHB1cmUsXG4gIG9uQ2xpY2tcbn06IExhbmdCdG5Qcm9wcykge1xuICBjb25zdCB7IHRva2VuIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3Qgc3R5bGUgPSB1c2VTdHlsZSgpO1xuXG4gIGxldCBsYWJlbDFTdHlsZTogUmVhY3QuQ1NTUHJvcGVydGllcztcbiAgbGV0IGxhYmVsMlN0eWxlOiBSZWFjdC5DU1NQcm9wZXJ0aWVzO1xuXG4gIGNvbnN0IGljb25TdHlsZTogUmVhY3QuQ1NTUHJvcGVydGllcyA9IHtcbiAgICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgICBmb250U2l6ZTogQkFTRV9TSVpFLFxuICAgIGxpbmVIZWlnaHQ6IDEsXG4gICAgYm9yZGVyOiBgMXB4IHNvbGlkICR7dG9rZW4uY29sb3JUZXh0fWAsXG4gICAgY29sb3I6IHRva2VuLmNvbG9yVGV4dFxuICB9O1xuXG4gIGNvbnN0IGZvbnRTdHlsZTogUmVhY3QuQ1NTUHJvcGVydGllcyA9IHtcbiAgICBsZWZ0OiAnLTUlJyxcbiAgICB0b3A6IDAsXG4gICAgekluZGV4OiAxLFxuICAgIGJhY2tncm91bmQ6IHRva2VuLmNvbG9yVGV4dCxcbiAgICBjb2xvcjogdG9rZW4uY29sb3JCZ0NvbnRhaW5lcixcbiAgICB0cmFuc2Zvcm1PcmlnaW46ICcwIDAnLFxuICAgIHRyYW5zZm9ybTogJ3NjYWxlKDAuNyknXG4gIH07XG4gIGNvbnN0IGJhY2tTdHlsZTogUmVhY3QuQ1NTUHJvcGVydGllcyA9IHtcbiAgICByaWdodDogJy01JScsXG4gICAgYm90dG9tOiAwLFxuICAgIHpJbmRleDogMCxcbiAgICB0cmFuc2Zvcm1PcmlnaW46ICcxMDAlIDEwMCUnLFxuICAgIHRyYW5zZm9ybTogJ3NjYWxlKDAuNSknXG4gIH07XG5cbiAgaWYgKHZhbHVlID09PSAxKSB7XG4gICAgbGFiZWwxU3R5bGUgPSBmb250U3R5bGU7XG4gICAgbGFiZWwyU3R5bGUgPSBiYWNrU3R5bGU7XG4gIH0gZWxzZSB7XG4gICAgbGFiZWwxU3R5bGUgPSBiYWNrU3R5bGU7XG4gICAgbGFiZWwyU3R5bGUgPSBmb250U3R5bGU7XG4gIH1cblxuICBsZXQgbm9kZSA9IChcbiAgICA8YnV0dG9uIG9uQ2xpY2s9e29uQ2xpY2t9IGNzcz17W3N0eWxlLmJ0bl19IGtleT1cImxhbmctYnV0dG9uXCIgZGF0YS12YWx1ZT17dmFsdWV9IHR5cGU9XCJidXR0b25cIj5cbiAgICAgIDxkaXYgY2xhc3NOYW1lPVwiYnRuLWlubmVyXCI+XG4gICAgICAgIHtwdXJlICYmICh2YWx1ZSA9PT0gMSA/IGxhYmVsMSA6IGxhYmVsMil9XG4gICAgICAgIHshcHVyZSAmJiAoXG4gICAgICAgICAgPGRpdlxuICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICAgICAgICAgIHdpZHRoOiBCQVNFX1NJWkUsXG4gICAgICAgICAgICAgIGhlaWdodDogQkFTRV9TSVpFXG4gICAgICAgICAgICB9fVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxzcGFuXG4gICAgICAgICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgICAgICAgLi4uaWNvblN0eWxlLFxuICAgICAgICAgICAgICAgIC4uLmxhYmVsMVN0eWxlXG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsYWJlbDF9XG4gICAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICAgICA8c3BhblxuICAgICAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgICAgIC4uLmljb25TdHlsZSxcbiAgICAgICAgICAgICAgICAuLi5sYWJlbDJTdHlsZVxuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bGFiZWwyfVxuICAgICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG4gICAgPC9idXR0b24+XG4gICk7XG5cbiAgaWYgKHRvb2x0aXAxIHx8IHRvb2x0aXAyKSB7XG4gICAgbm9kZSA9IDxUb29sdGlwIHRpdGxlPXt2YWx1ZSA9PT0gMSA/IHRvb2x0aXAxIDogdG9vbHRpcDJ9Pntub2RlfTwvVG9vbHRpcD47XG4gIH1cblxuICByZXR1cm4gbm9kZTtcbn1cbiJdfQ== */")
15
- };
16
- };
17
- export default function SwitchBtn(_ref) {
18
- var label1 = _ref.label1,
19
- label2 = _ref.label2,
20
- tooltip1 = _ref.tooltip1,
21
- tooltip2 = _ref.tooltip2,
22
- value = _ref.value,
23
- pure = _ref.pure,
24
- onClick = _ref.onClick;
25
- var _useSiteToken2 = useSiteToken(),
26
- token = _useSiteToken2.token;
27
- var style = useStyle();
28
- var label1Style;
29
- var label2Style;
30
- var iconStyle = {
31
- position: 'absolute',
32
- fontSize: BASE_SIZE,
33
- lineHeight: 1,
34
- border: "1px solid ".concat(token.colorText),
35
- color: token.colorText
36
- };
37
- var fontStyle = {
38
- left: '-5%',
39
- top: 0,
40
- zIndex: 1,
41
- background: token.colorText,
42
- color: token.colorBgContainer,
43
- transformOrigin: '0 0',
44
- transform: 'scale(0.7)'
45
- };
46
- var backStyle = {
47
- right: '-5%',
48
- bottom: 0,
49
- zIndex: 0,
50
- transformOrigin: '100% 100%',
51
- transform: 'scale(0.5)'
52
- };
53
- if (value === 1) {
54
- label1Style = fontStyle;
55
- label2Style = backStyle;
56
- } else {
57
- label1Style = backStyle;
58
- label2Style = fontStyle;
59
- }
60
- var node = ___EmotionJSX("button", {
61
- onClick: onClick,
62
- css: [style.btn, process.env.NODE_ENV === "production" ? "" : ";label:node;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN3aXRjaEJ0bi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEc4QiIsImZpbGUiOiJTd2l0Y2hCdG4udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJ2FudGQnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcblxuZXhwb3J0IGludGVyZmFjZSBMYW5nQnRuUHJvcHMge1xuICBsYWJlbDE6IFJlYWN0LlJlYWN0Tm9kZTtcbiAgbGFiZWwyOiBSZWFjdC5SZWFjdE5vZGU7XG4gIHRvb2x0aXAxPzogUmVhY3QuUmVhY3ROb2RlO1xuICB0b29sdGlwMj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgdmFsdWU6IDEgfCAyO1xuICBwdXJlPzogYm9vbGVhbjtcbiAgb25DbGljaz86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyO1xufVxuXG5jb25zdCBCQVNFX1NJWkUgPSAnMS4yZW0nO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIGNvbnN0IHsgY29udHJvbEhlaWdodCwgbW90aW9uRHVyYXRpb25NaWQgfSA9IHRva2VuO1xuXG4gIHJldHVybiB7XG4gICAgYnRuOiBjc3NgXG4gICAgICBjb2xvcjogJHt0b2tlbi5jb2xvclRleHR9O1xuICAgICAgYm9yZGVyLWNvbG9yOiAke3Rva2VuLmNvbG9yQm9yZGVyfTtcbiAgICAgIHBhZGRpbmc6IDAgIWltcG9ydGFudDtcbiAgICAgIHdpZHRoOiAke2NvbnRyb2xIZWlnaHR9cHg7XG4gICAgICBoZWlnaHQ6ICR7Y29udHJvbEhlaWdodH1weDtcbiAgICAgIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgICAgYm9yZGVyOiBub25lO1xuICAgICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgICBib3JkZXItcmFkaXVzOiAke3Rva2VuLmJvcmRlclJhZGl1c31weDtcbiAgICAgIHRyYW5zaXRpb246IGFsbCAke21vdGlvbkR1cmF0aW9uTWlkfTtcbiAgICAgIGN1cnNvcjogcG9pbnRlcjtcblxuICAgICAgLmJ0bi1pbm5lciB7XG4gICAgICAgIHRyYW5zaXRpb246IGFsbCAke21vdGlvbkR1cmF0aW9uTWlkfTtcbiAgICAgIH1cblxuICAgICAgJjpob3ZlciB7XG4gICAgICAgIGJhY2tncm91bmQ6ICR7dG9rZW4uY29sb3JCZ1RleHRIb3Zlcn07XG4gICAgICB9XG5cbiAgICAgIGltZyB7XG4gICAgICAgIHdpZHRoOiAke0JBU0VfU0laRX07XG4gICAgICAgIGhlaWdodDogJHtCQVNFX1NJWkV9O1xuICAgICAgfVxuXG4gICAgICAuYW50aWNvbiB7XG4gICAgICAgIGZvbnQtc2l6ZTogJHtCQVNFX1NJWkV9O1xuICAgICAgfVxuICAgIGBcbiAgfTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIFN3aXRjaEJ0bih7XG4gIGxhYmVsMSxcbiAgbGFiZWwyLFxuICB0b29sdGlwMSxcbiAgdG9vbHRpcDIsXG4gIHZhbHVlLFxuICBwdXJlLFxuICBvbkNsaWNrXG59OiBMYW5nQnRuUHJvcHMpIHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIGNvbnN0IHN0eWxlID0gdXNlU3R5bGUoKTtcblxuICBsZXQgbGFiZWwxU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXM7XG4gIGxldCBsYWJlbDJTdHlsZTogUmVhY3QuQ1NTUHJvcGVydGllcztcblxuICBjb25zdCBpY29uU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgZm9udFNpemU6IEJBU0VfU0laRSxcbiAgICBsaW5lSGVpZ2h0OiAxLFxuICAgIGJvcmRlcjogYDFweCBzb2xpZCAke3Rva2VuLmNvbG9yVGV4dH1gLFxuICAgIGNvbG9yOiB0b2tlbi5jb2xvclRleHRcbiAgfTtcblxuICBjb25zdCBmb250U3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgbGVmdDogJy01JScsXG4gICAgdG9wOiAwLFxuICAgIHpJbmRleDogMSxcbiAgICBiYWNrZ3JvdW5kOiB0b2tlbi5jb2xvclRleHQsXG4gICAgY29sb3I6IHRva2VuLmNvbG9yQmdDb250YWluZXIsXG4gICAgdHJhbnNmb3JtT3JpZ2luOiAnMCAwJyxcbiAgICB0cmFuc2Zvcm06ICdzY2FsZSgwLjcpJ1xuICB9O1xuICBjb25zdCBiYWNrU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgcmlnaHQ6ICctNSUnLFxuICAgIGJvdHRvbTogMCxcbiAgICB6SW5kZXg6IDAsXG4gICAgdHJhbnNmb3JtT3JpZ2luOiAnMTAwJSAxMDAlJyxcbiAgICB0cmFuc2Zvcm06ICdzY2FsZSgwLjUpJ1xuICB9O1xuXG4gIGlmICh2YWx1ZSA9PT0gMSkge1xuICAgIGxhYmVsMVN0eWxlID0gZm9udFN0eWxlO1xuICAgIGxhYmVsMlN0eWxlID0gYmFja1N0eWxlO1xuICB9IGVsc2Uge1xuICAgIGxhYmVsMVN0eWxlID0gYmFja1N0eWxlO1xuICAgIGxhYmVsMlN0eWxlID0gZm9udFN0eWxlO1xuICB9XG5cbiAgbGV0IG5vZGUgPSAoXG4gICAgPGJ1dHRvbiBvbkNsaWNrPXtvbkNsaWNrfSBjc3M9e1tzdHlsZS5idG5dfSBrZXk9XCJsYW5nLWJ1dHRvblwiIGRhdGEtdmFsdWU9e3ZhbHVlfSB0eXBlPVwiYnV0dG9uXCI+XG4gICAgICA8ZGl2IGNsYXNzTmFtZT1cImJ0bi1pbm5lclwiPlxuICAgICAgICB7cHVyZSAmJiAodmFsdWUgPT09IDEgPyBsYWJlbDEgOiBsYWJlbDIpfVxuICAgICAgICB7IXB1cmUgJiYgKFxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgICAgICAgICB3aWR0aDogQkFTRV9TSVpFLFxuICAgICAgICAgICAgICBoZWlnaHQ6IEJBU0VfU0laRVxuICAgICAgICAgICAgfX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICA8c3BhblxuICAgICAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgICAgIC4uLmljb25TdHlsZSxcbiAgICAgICAgICAgICAgICAuLi5sYWJlbDFTdHlsZVxuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bGFiZWwxfVxuICAgICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgICAgPHNwYW5cbiAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAuLi5pY29uU3R5bGUsXG4gICAgICAgICAgICAgICAgLi4ubGFiZWwyU3R5bGVcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2xhYmVsMn1cbiAgICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgKX1cbiAgICAgIDwvZGl2PlxuICAgIDwvYnV0dG9uPlxuICApO1xuXG4gIGlmICh0b29sdGlwMSB8fCB0b29sdGlwMikge1xuICAgIG5vZGUgPSA8VG9vbHRpcCB0aXRsZT17dmFsdWUgPT09IDEgPyB0b29sdGlwMSA6IHRvb2x0aXAyfT57bm9kZX08L1Rvb2x0aXA+O1xuICB9XG5cbiAgcmV0dXJuIG5vZGU7XG59XG4iXX0= */"],
63
- key: "lang-button",
64
- "data-value": value,
65
- type: "button"
66
- }, ___EmotionJSX("div", {
67
- className: "btn-inner"
68
- }, pure && (value === 1 ? label1 : label2), !pure && ___EmotionJSX("div", {
69
- style: {
70
- position: 'relative',
71
- width: BASE_SIZE,
72
- height: BASE_SIZE
73
- }
74
- }, ___EmotionJSX("span", {
75
- style: _objectSpread(_objectSpread({}, iconStyle), label1Style)
76
- }, label1), ___EmotionJSX("span", {
77
- style: _objectSpread(_objectSpread({}, iconStyle), label2Style)
78
- }, label2))));
79
- if (tooltip1 || tooltip2) {
80
- node = ___EmotionJSX(Tooltip, {
81
- title: value === 1 ? tooltip1 : tooltip2
82
- }, node);
83
- }
84
- return node;
85
- }
@@ -1,4 +0,0 @@
1
- import { type FC } from 'react';
2
- export declare type IResponsive = null | 'narrow' | 'crowded';
3
- declare const Header: FC;
4
- export default Header;
@@ -1,187 +0,0 @@
1
- import _extends from "@babel/runtime/helpers/esm/extends";
2
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
3
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
4
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
5
- /* eslint-disable import/no-unresolved */
6
- import { MenuOutlined } from '@ant-design/icons';
7
- import { ClassNames, css } from '@emotion/react';
8
- import { Col, Popover, Row, Select } from 'antd';
9
- import classNames from 'classnames';
10
- import { useLocale, useLocation } from 'dumi';
11
- import DumiSearchBar from 'dumi/theme-default/slots/SearchBar';
12
- import React, { useCallback, useContext, useEffect, useState } from 'react';
13
- import LangSwitch from "dumi/theme/slots/LangSwitch";
14
- import RtlSwitch from "dumi/theme/slots/RtlSwitch";
15
- import useAdditionalThemeConfig from "../../hooks/useAdditionalThemeConfig";
16
- import useSiteToken from "../../hooks/useSiteToken";
17
- import SiteContext from "dumi/theme/slots/SiteContext";
18
- import HeaderExtra from "./HeaderExtral";
19
- import Logo from "./Logo";
20
- import More from "./More";
21
- import Navigation from "./Navigation";
22
- import { jsx as ___EmotionJSX } from "@emotion/react";
23
- var RESPONSIVE_XS = 1120;
24
- var RESPONSIVE_SM = 1200;
25
- var colPropsHome = [{
26
- flex: 'none'
27
- }, {
28
- flex: 'auto'
29
- }];
30
- var _colProps = [{
31
- xxl: 4,
32
- xl: 5,
33
- lg: 6,
34
- md: 6,
35
- sm: 24,
36
- xs: 24
37
- }, {
38
- xxl: 20,
39
- xl: 19,
40
- lg: 18,
41
- md: 18,
42
- sm: 0,
43
- xs: 0
44
- }];
45
- var useStyle = function useStyle() {
46
- var _useSiteToken = useSiteToken(),
47
- token = _useSiteToken.token;
48
- var searchIconColor = '#ced4d9';
49
- return {
50
- header: /*#__PURE__*/css("position:sticky;top:0;z-index:99;max-width:100%;background:", token.colorBgContainer, ";box-shadow:", token.boxShadowTertiary, ";border-bottom:", token.lineWidth, "px solid ", token.colorBorderSecondary, ";@media only screen and (max-width: ", token.mobileMaxWidth, "px){text-align:center;}.nav-search-wrapper{display:flex;flex:auto;}.dumi-default-search-bar{border-inline-start:1px solid rgba(0, 0, 0, 0.06);>svg{width:14px;fill:", searchIconColor, ";}>input{height:22px;border:0;&:focus{box-shadow:none;}&::placeholder{color:", searchIconColor, ";}}.dumi-default-search-shortcut{color:", searchIconColor, ";background-color:rgba(150, 150, 150, 0.06);border-color:rgba(100, 100, 100, 0.2);border-radius:4px;}.dumi-default-search-popover{inset-inline-start:11px;inset-inline-end:unset;&::before{inset-inline-start:100px;inset-inline-end:unset;}}}" + (process.env.NODE_ENV === "production" ? "" : ";label:header;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4De","file":"index.tsx","sourcesContent":["/* eslint-disable import/no-unresolved */\nimport { MenuOutlined } from '@ant-design/icons';\nimport { ClassNames, css } from '@emotion/react';\nimport { Col, Popover, Row, Select } from 'antd';\nimport classNames from 'classnames';\nimport { useLocale, useLocation } from 'dumi';\nimport DumiSearchBar from 'dumi/theme-default/slots/SearchBar';\nimport React, { useCallback, useContext, useEffect, useState, type FC } from 'react';\nimport LangSwitch from 'dumi/theme/slots/LangSwitch';\nimport RtlSwitch from 'dumi/theme/slots/RtlSwitch';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../SiteContext';\nimport SiteContext from '../SiteContext';\nimport HeaderExtra from './HeaderExtral';\nimport Logo from './Logo';\nimport More from './More';\nimport Navigation from './Navigation';\n\ninterface HeaderState {\n  windowWidth: number;\n  menuVisible: boolean;\n}\nexport type IResponsive = null | 'narrow' | 'crowded';\n\nconst RESPONSIVE_XS = 1120;\nconst RESPONSIVE_SM = 1200;\n\nconst colPropsHome = [\n  {\n    flex: 'none'\n  },\n  {\n    flex: 'auto'\n  }\n];\nconst _colProps = [\n  {\n    xxl: 4,\n    xl: 5,\n    lg: 6,\n    md: 6,\n    sm: 24,\n    xs: 24\n  },\n  {\n    xxl: 20,\n    xl: 19,\n    lg: 18,\n    md: 18,\n    sm: 0,\n    xs: 0\n  }\n];\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const searchIconColor = '#ced4d9';\n\n  return {\n    header: css`\n      position: sticky;\n      top: 0;\n      z-index: 99;\n      max-width: 100%;\n      background: ${token.colorBgContainer};\n      box-shadow: ${token.boxShadowTertiary};\n      border-bottom: ${token.lineWidth}px solid ${token.colorBorderSecondary};\n\n      @media only screen and (max-width: ${token.mobileMaxWidth}px) {\n        text-align: center;\n      }\n\n      .nav-search-wrapper {\n        display: flex;\n        flex: auto;\n      }\n\n      .dumi-default-search-bar {\n        border-inline-start: 1px solid rgba(0, 0, 0, 0.06);\n\n        > svg {\n          width: 14px;\n          fill: ${searchIconColor};\n        }\n\n        > input {\n          height: 22px;\n          border: 0;\n\n          &:focus {\n            box-shadow: none;\n          }\n\n          &::placeholder {\n            color: ${searchIconColor};\n          }\n        }\n\n        .dumi-default-search-shortcut {\n          color: ${searchIconColor};\n          background-color: rgba(150, 150, 150, 0.06);\n          border-color: rgba(100, 100, 100, 0.2);\n          border-radius: 4px;\n        }\n\n        .dumi-default-search-popover {\n          inset-inline-start: 11px;\n          inset-inline-end: unset;\n\n          &::before {\n            inset-inline-start: 100px;\n            inset-inline-end: unset;\n          }\n        }\n      }\n    `,\n    menuRow: css`\n      display: flex;\n      align-items: center;\n      margin: 0;\n\n      > * {\n        flex: none;\n        margin: 0 12px 0 0;\n\n        &:last-child {\n          margin-inline-end: 40px;\n        }\n      }\n\n      ${token.antCls}-row-rtl & {\n        > * {\n          &:last-child {\n            margin-right: 12px;\n            margin-left: 40px;\n          }\n        }\n      }\n    `,\n    popoverMenu: {\n      width: 300,\n\n      [`${token.antCls}-popover-inner-content`]: {\n        padding: 0\n      }\n    }\n  };\n};\n\nconst Header: FC = () => {\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const [headerState, setHeaderState] = useState<HeaderState>({\n    windowWidth: 1400,\n    menuVisible: false\n  });\n  const locale = useLocale();\n  const location = useLocation();\n  const { docVersions } = useAdditionalThemeConfig();\n\n  const onWindowResize = useCallback(() => {\n    setHeaderState((prev) => ({\n      ...prev,\n      windowWidth: window.innerWidth\n    }));\n  }, []);\n  const handleHideMenu = useCallback(() => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: false\n    }));\n  }, []);\n  const onMenuVisibleChange = useCallback((visible: boolean) => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: visible\n    }));\n  }, []);\n\n  const handleVersionChange = useCallback((url: string) => {\n    window.location.href = url;\n  }, []);\n\n  useEffect(() => {\n    handleHideMenu();\n  }, [location, handleHideMenu]);\n\n  useEffect(() => {\n    onWindowResize();\n    window.addEventListener('resize', onWindowResize);\n    return () => {\n      window.removeEventListener('resize', onWindowResize);\n    };\n  }, [onWindowResize]);\n\n  const localeBase = 'base' in locale ? locale.base : '';\n  const localeSuffix = 'suffix' in locale ? locale.suffix : '';\n  const { pathname } = location;\n\n  const path = pathname.endsWith('/') ? pathname.slice(0, -1) : pathname;\n  const isHome = ['', 'index', `index${localeSuffix}`, localeBase].includes(path);\n\n  const { windowWidth, menuVisible } = headerState;\n  const style = useStyle();\n  const headerClassName = classNames({\n    clearfix: true,\n    'home-header': isHome\n  });\n  let responsive: IResponsive = null;\n\n  if (windowWidth < RESPONSIVE_XS) {\n    responsive = 'crowded';\n  } else if (windowWidth < RESPONSIVE_SM) {\n    responsive = 'narrow';\n  }\n\n  const navigationNode = <Navigation key=\"nav\" isMobile={isMobile} responsive={responsive} />;\n  const versionOptions = Object.keys(docVersions ?? {}).map((version) => ({\n    value: docVersions?.[version],\n    label: version\n  }));\n  let menu: (React.ReactElement | null)[] = [\n    navigationNode,\n    versionOptions.length > 0 ? (\n      <Select\n        key=\"version\"\n        size=\"small\"\n        defaultValue={versionOptions[0]?.value}\n        onChange={handleVersionChange}\n        popupMatchSelectWidth={false}\n        getPopupContainer={(trigger) => trigger.parentNode}\n        options={versionOptions}\n      />\n    ) : null,\n    <More key=\"more\" />,\n    <LangSwitch key={new Date().getTime()} />,\n    <RtlSwitch key=\"direction\" />,\n    <HeaderExtra key=\"header-Extra\" />\n  ];\n  if (windowWidth < RESPONSIVE_XS) {\n    menu = [navigationNode];\n  }\n\n  const colProps = isHome ? colPropsHome : _colProps;\n\n  return (\n    <header css={style.header} className={headerClassName}>\n      {isMobile && (\n        <ClassNames>\n          {({ css: cssFn }) => (\n            <Popover\n              overlayClassName={cssFn(style.popoverMenu)}\n              placement=\"bottomRight\"\n              content={menu}\n              trigger=\"click\"\n              open={menuVisible}\n              arrow\n              onOpenChange={onMenuVisibleChange}\n            >\n              <MenuOutlined className=\"nav-phone-icon\" rev={undefined} />\n            </Popover>\n          )}\n        </ClassNames>\n      )}\n      <Row\n        style={{\n          height: 64\n        }}\n      >\n        <Col {...colProps[0]}>\n          <Logo />\n        </Col>\n        <Col {...colProps[1]} css={style.menuRow}>\n          <div className=\"nav-search-wrapper\">\n            <DumiSearchBar />\n          </div>\n          {!isMobile && menu}\n        </Col>\n      </Row>\n    </header>\n  );\n};\n\nexport default Header;\n"]} */"),
51
- menuRow: /*#__PURE__*/css("display:flex;align-items:center;margin:0;>*{flex:none;margin:0 12px 0 0;&:last-child{margin-inline-end:40px;}}", token.antCls, "-row-rtl &{>*{&:last-child{margin-right:12px;margin-left:40px;}}}" + (process.env.NODE_ENV === "production" ? "" : ";label:menuRow;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqHgB","file":"index.tsx","sourcesContent":["/* eslint-disable import/no-unresolved */\nimport { MenuOutlined } from '@ant-design/icons';\nimport { ClassNames, css } from '@emotion/react';\nimport { Col, Popover, Row, Select } from 'antd';\nimport classNames from 'classnames';\nimport { useLocale, useLocation } from 'dumi';\nimport DumiSearchBar from 'dumi/theme-default/slots/SearchBar';\nimport React, { useCallback, useContext, useEffect, useState, type FC } from 'react';\nimport LangSwitch from 'dumi/theme/slots/LangSwitch';\nimport RtlSwitch from 'dumi/theme/slots/RtlSwitch';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../SiteContext';\nimport SiteContext from '../SiteContext';\nimport HeaderExtra from './HeaderExtral';\nimport Logo from './Logo';\nimport More from './More';\nimport Navigation from './Navigation';\n\ninterface HeaderState {\n  windowWidth: number;\n  menuVisible: boolean;\n}\nexport type IResponsive = null | 'narrow' | 'crowded';\n\nconst RESPONSIVE_XS = 1120;\nconst RESPONSIVE_SM = 1200;\n\nconst colPropsHome = [\n  {\n    flex: 'none'\n  },\n  {\n    flex: 'auto'\n  }\n];\nconst _colProps = [\n  {\n    xxl: 4,\n    xl: 5,\n    lg: 6,\n    md: 6,\n    sm: 24,\n    xs: 24\n  },\n  {\n    xxl: 20,\n    xl: 19,\n    lg: 18,\n    md: 18,\n    sm: 0,\n    xs: 0\n  }\n];\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const searchIconColor = '#ced4d9';\n\n  return {\n    header: css`\n      position: sticky;\n      top: 0;\n      z-index: 99;\n      max-width: 100%;\n      background: ${token.colorBgContainer};\n      box-shadow: ${token.boxShadowTertiary};\n      border-bottom: ${token.lineWidth}px solid ${token.colorBorderSecondary};\n\n      @media only screen and (max-width: ${token.mobileMaxWidth}px) {\n        text-align: center;\n      }\n\n      .nav-search-wrapper {\n        display: flex;\n        flex: auto;\n      }\n\n      .dumi-default-search-bar {\n        border-inline-start: 1px solid rgba(0, 0, 0, 0.06);\n\n        > svg {\n          width: 14px;\n          fill: ${searchIconColor};\n        }\n\n        > input {\n          height: 22px;\n          border: 0;\n\n          &:focus {\n            box-shadow: none;\n          }\n\n          &::placeholder {\n            color: ${searchIconColor};\n          }\n        }\n\n        .dumi-default-search-shortcut {\n          color: ${searchIconColor};\n          background-color: rgba(150, 150, 150, 0.06);\n          border-color: rgba(100, 100, 100, 0.2);\n          border-radius: 4px;\n        }\n\n        .dumi-default-search-popover {\n          inset-inline-start: 11px;\n          inset-inline-end: unset;\n\n          &::before {\n            inset-inline-start: 100px;\n            inset-inline-end: unset;\n          }\n        }\n      }\n    `,\n    menuRow: css`\n      display: flex;\n      align-items: center;\n      margin: 0;\n\n      > * {\n        flex: none;\n        margin: 0 12px 0 0;\n\n        &:last-child {\n          margin-inline-end: 40px;\n        }\n      }\n\n      ${token.antCls}-row-rtl & {\n        > * {\n          &:last-child {\n            margin-right: 12px;\n            margin-left: 40px;\n          }\n        }\n      }\n    `,\n    popoverMenu: {\n      width: 300,\n\n      [`${token.antCls}-popover-inner-content`]: {\n        padding: 0\n      }\n    }\n  };\n};\n\nconst Header: FC = () => {\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const [headerState, setHeaderState] = useState<HeaderState>({\n    windowWidth: 1400,\n    menuVisible: false\n  });\n  const locale = useLocale();\n  const location = useLocation();\n  const { docVersions } = useAdditionalThemeConfig();\n\n  const onWindowResize = useCallback(() => {\n    setHeaderState((prev) => ({\n      ...prev,\n      windowWidth: window.innerWidth\n    }));\n  }, []);\n  const handleHideMenu = useCallback(() => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: false\n    }));\n  }, []);\n  const onMenuVisibleChange = useCallback((visible: boolean) => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: visible\n    }));\n  }, []);\n\n  const handleVersionChange = useCallback((url: string) => {\n    window.location.href = url;\n  }, []);\n\n  useEffect(() => {\n    handleHideMenu();\n  }, [location, handleHideMenu]);\n\n  useEffect(() => {\n    onWindowResize();\n    window.addEventListener('resize', onWindowResize);\n    return () => {\n      window.removeEventListener('resize', onWindowResize);\n    };\n  }, [onWindowResize]);\n\n  const localeBase = 'base' in locale ? locale.base : '';\n  const localeSuffix = 'suffix' in locale ? locale.suffix : '';\n  const { pathname } = location;\n\n  const path = pathname.endsWith('/') ? pathname.slice(0, -1) : pathname;\n  const isHome = ['', 'index', `index${localeSuffix}`, localeBase].includes(path);\n\n  const { windowWidth, menuVisible } = headerState;\n  const style = useStyle();\n  const headerClassName = classNames({\n    clearfix: true,\n    'home-header': isHome\n  });\n  let responsive: IResponsive = null;\n\n  if (windowWidth < RESPONSIVE_XS) {\n    responsive = 'crowded';\n  } else if (windowWidth < RESPONSIVE_SM) {\n    responsive = 'narrow';\n  }\n\n  const navigationNode = <Navigation key=\"nav\" isMobile={isMobile} responsive={responsive} />;\n  const versionOptions = Object.keys(docVersions ?? {}).map((version) => ({\n    value: docVersions?.[version],\n    label: version\n  }));\n  let menu: (React.ReactElement | null)[] = [\n    navigationNode,\n    versionOptions.length > 0 ? (\n      <Select\n        key=\"version\"\n        size=\"small\"\n        defaultValue={versionOptions[0]?.value}\n        onChange={handleVersionChange}\n        popupMatchSelectWidth={false}\n        getPopupContainer={(trigger) => trigger.parentNode}\n        options={versionOptions}\n      />\n    ) : null,\n    <More key=\"more\" />,\n    <LangSwitch key={new Date().getTime()} />,\n    <RtlSwitch key=\"direction\" />,\n    <HeaderExtra key=\"header-Extra\" />\n  ];\n  if (windowWidth < RESPONSIVE_XS) {\n    menu = [navigationNode];\n  }\n\n  const colProps = isHome ? colPropsHome : _colProps;\n\n  return (\n    <header css={style.header} className={headerClassName}>\n      {isMobile && (\n        <ClassNames>\n          {({ css: cssFn }) => (\n            <Popover\n              overlayClassName={cssFn(style.popoverMenu)}\n              placement=\"bottomRight\"\n              content={menu}\n              trigger=\"click\"\n              open={menuVisible}\n              arrow\n              onOpenChange={onMenuVisibleChange}\n            >\n              <MenuOutlined className=\"nav-phone-icon\" rev={undefined} />\n            </Popover>\n          )}\n        </ClassNames>\n      )}\n      <Row\n        style={{\n          height: 64\n        }}\n      >\n        <Col {...colProps[0]}>\n          <Logo />\n        </Col>\n        <Col {...colProps[1]} css={style.menuRow}>\n          <div className=\"nav-search-wrapper\">\n            <DumiSearchBar />\n          </div>\n          {!isMobile && menu}\n        </Col>\n      </Row>\n    </header>\n  );\n};\n\nexport default Header;\n"]} */"),
52
- popoverMenu: _defineProperty({
53
- width: 300
54
- }, "".concat(token.antCls, "-popover-inner-content"), {
55
- padding: 0
56
- })
57
- };
58
- };
59
- var Header = function Header() {
60
- var _versionOptions$;
61
- var _useContext = useContext(SiteContext),
62
- isMobile = _useContext.isMobile;
63
- var _useState = useState({
64
- windowWidth: 1400,
65
- menuVisible: false
66
- }),
67
- _useState2 = _slicedToArray(_useState, 2),
68
- headerState = _useState2[0],
69
- setHeaderState = _useState2[1];
70
- var locale = useLocale();
71
- var location = useLocation();
72
- var _useAdditionalThemeCo = useAdditionalThemeConfig(),
73
- docVersions = _useAdditionalThemeCo.docVersions;
74
- var onWindowResize = useCallback(function () {
75
- setHeaderState(function (prev) {
76
- return _objectSpread(_objectSpread({}, prev), {}, {
77
- windowWidth: window.innerWidth
78
- });
79
- });
80
- }, []);
81
- var handleHideMenu = useCallback(function () {
82
- setHeaderState(function (prev) {
83
- return _objectSpread(_objectSpread({}, prev), {}, {
84
- menuVisible: false
85
- });
86
- });
87
- }, []);
88
- var onMenuVisibleChange = useCallback(function (visible) {
89
- setHeaderState(function (prev) {
90
- return _objectSpread(_objectSpread({}, prev), {}, {
91
- menuVisible: visible
92
- });
93
- });
94
- }, []);
95
- var handleVersionChange = useCallback(function (url) {
96
- window.location.href = url;
97
- }, []);
98
- useEffect(function () {
99
- handleHideMenu();
100
- }, [location, handleHideMenu]);
101
- useEffect(function () {
102
- onWindowResize();
103
- window.addEventListener('resize', onWindowResize);
104
- return function () {
105
- window.removeEventListener('resize', onWindowResize);
106
- };
107
- }, [onWindowResize]);
108
- var localeBase = 'base' in locale ? locale.base : '';
109
- var localeSuffix = 'suffix' in locale ? locale.suffix : '';
110
- var pathname = location.pathname;
111
- var path = pathname.endsWith('/') ? pathname.slice(0, -1) : pathname;
112
- var isHome = ['', 'index', "index".concat(localeSuffix), localeBase].includes(path);
113
- var windowWidth = headerState.windowWidth,
114
- menuVisible = headerState.menuVisible;
115
- var style = useStyle();
116
- var headerClassName = classNames({
117
- clearfix: true,
118
- 'home-header': isHome
119
- });
120
- var responsive = null;
121
- if (windowWidth < RESPONSIVE_XS) {
122
- responsive = 'crowded';
123
- } else if (windowWidth < RESPONSIVE_SM) {
124
- responsive = 'narrow';
125
- }
126
- var navigationNode = ___EmotionJSX(Navigation, {
127
- key: "nav",
128
- isMobile: isMobile,
129
- responsive: responsive
130
- });
131
- var versionOptions = Object.keys(docVersions !== null && docVersions !== void 0 ? docVersions : {}).map(function (version) {
132
- return {
133
- value: docVersions === null || docVersions === void 0 ? void 0 : docVersions[version],
134
- label: version
135
- };
136
- });
137
- var menu = [navigationNode, versionOptions.length > 0 ? ___EmotionJSX(Select, {
138
- key: "version",
139
- size: "small",
140
- defaultValue: (_versionOptions$ = versionOptions[0]) === null || _versionOptions$ === void 0 ? void 0 : _versionOptions$.value,
141
- onChange: handleVersionChange,
142
- popupMatchSelectWidth: false,
143
- getPopupContainer: function getPopupContainer(trigger) {
144
- return trigger.parentNode;
145
- },
146
- options: versionOptions
147
- }) : null, ___EmotionJSX(More, {
148
- key: "more"
149
- }), ___EmotionJSX(LangSwitch, {
150
- key: new Date().getTime()
151
- }), ___EmotionJSX(RtlSwitch, {
152
- key: "direction"
153
- }), ___EmotionJSX(HeaderExtra, {
154
- key: "header-Extra"
155
- })];
156
- if (windowWidth < RESPONSIVE_XS) {
157
- menu = [navigationNode];
158
- }
159
- var colProps = isHome ? colPropsHome : _colProps;
160
- return ___EmotionJSX("header", {
161
- css: style.header,
162
- className: headerClassName
163
- }, isMobile && ___EmotionJSX(ClassNames, null, function (_ref) {
164
- var cssFn = _ref.css;
165
- return ___EmotionJSX(Popover, {
166
- overlayClassName: cssFn(style.popoverMenu),
167
- placement: "bottomRight",
168
- content: menu,
169
- trigger: "click",
170
- open: menuVisible,
171
- arrow: true,
172
- onOpenChange: onMenuVisibleChange
173
- }, ___EmotionJSX(MenuOutlined, {
174
- className: "nav-phone-icon",
175
- rev: undefined
176
- }));
177
- }), ___EmotionJSX(Row, {
178
- style: {
179
- height: 64
180
- }
181
- }, ___EmotionJSX(Col, colProps[0], ___EmotionJSX(Logo, null)), ___EmotionJSX(Col, _extends({}, colProps[1], {
182
- css: style.menuRow
183
- }), ___EmotionJSX("div", {
184
- className: "nav-search-wrapper"
185
- }, ___EmotionJSX(DumiSearchBar, null)), !isMobile && menu)));
186
- };
187
- export default Header;
@@ -1,3 +0,0 @@
1
- import { type FC } from 'react';
2
- declare const LangSwitch: FC;
3
- export default LangSwitch;
@@ -1,84 +0,0 @@
1
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
- // 多语言切换
3
- import { Select } from 'antd';
4
- import { history, useIntl, useLocale, useLocation, useSearchParams, useSiteData } from 'dumi';
5
- import { useCallback } from 'react';
6
- import useAdditionalThemeConfig from "../../hooks/useAdditionalThemeConfig";
7
- import { getTargetLocalePath } from "../../utils";
8
- import SwitchBtn from "../Header/SwitchBtn";
9
- import { jsx as ___EmotionJSX } from "@emotion/react";
10
- var Option = Select.Option;
11
- var LangSwitch = function LangSwitch() {
12
- var _useSearchParams = useSearchParams(),
13
- _useSearchParams2 = _slicedToArray(_useSearchParams, 1),
14
- searchParams = _useSearchParams2[0];
15
- var _useAdditionalThemeCo = useAdditionalThemeConfig(),
16
- localesEnhance = _useAdditionalThemeCo.localesEnhance;
17
- var _useSiteData = useSiteData(),
18
- locales = _useSiteData.locales;
19
- var _useIntl = useIntl(),
20
- locale = _useIntl.locale;
21
- var current = useLocale();
22
- var _useLocation = useLocation(),
23
- pathname = _useLocation.pathname;
24
- var handleLangChange = useCallback(function (lang) {
25
- var path = getTargetLocalePath({
26
- pathname: pathname,
27
- current: current,
28
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
29
- target: locales.find(function (_ref) {
30
- var id = _ref.id;
31
- return id === lang;
32
- })
33
- });
34
-
35
- // remove trailing slash if path is not root
36
- if (path.endsWith('/') && path !== '/') {
37
- path = path.slice(0, -1);
38
- }
39
- history.push({
40
- pathname: path,
41
- search: searchParams.toString()
42
- });
43
- }, [pathname, current, locales, searchParams]);
44
- var onLangChange = useCallback(function () {
45
- handleLangChange(locales.filter(function (item) {
46
- return item.id !== locale;
47
- })[0].id);
48
- }, [locale, handleLangChange, locales]);
49
- var LangSwitchJSX;
50
- // do not render in single language
51
- if (locales.length > 2 || !localesEnhance && locales.length > 2) {
52
- var langOptions = locales.map(function (lang) {
53
- return ___EmotionJSX(Option, {
54
- value: lang.id,
55
- key: lang.id
56
- }, lang.name);
57
- });
58
- LangSwitchJSX = ___EmotionJSX(Select, {
59
- key: "lang",
60
- className: "version",
61
- size: "small",
62
- defaultValue: locale,
63
- onChange: handleLangChange,
64
- popupMatchSelectWidth: false,
65
- getPopupContainer: function getPopupContainer(trigger) {
66
- return trigger.parentNode;
67
- }
68
- }, langOptions);
69
- } else if (locales.length === 2 && Array.isArray(localesEnhance) && localesEnhance.length > 1) {
70
- // 按 locales 顺序展示
71
- var switchValue = locales[0].id === locale ? 1 : 2;
72
- LangSwitchJSX = ___EmotionJSX(SwitchBtn, {
73
- key: "lang",
74
- onClick: onLangChange,
75
- value: switchValue,
76
- label1: localesEnhance[0].switchPrefix,
77
- label2: localesEnhance[1].switchPrefix,
78
- tooltip1: "".concat(locales[0].name, " / ").concat(locales[1].name),
79
- tooltip2: "".concat(locales[1].name, " / ").concat(locales[0].name)
80
- });
81
- }
82
- return LangSwitchJSX;
83
- };
84
- export default LangSwitch;
@@ -1,9 +0,0 @@
1
- import React from 'react';
2
- export interface NotFoundProps {
3
- router: {
4
- push: (pathname: string) => void;
5
- replace: (pathname: string) => void;
6
- };
7
- }
8
- declare const NotFoundPage: React.FC<NotFoundProps>;
9
- export default NotFoundPage;
@@ -1,25 +0,0 @@
1
- import { HomeOutlined } from '@ant-design/icons';
2
- import { Button, Result } from 'antd';
3
- import { FormattedMessage, Link } from 'dumi';
4
- import React from 'react';
5
- import { jsx as ___EmotionJSX } from "@emotion/react";
6
- var NotFoundPage = function NotFoundPage() {
7
- return ___EmotionJSX("div", {
8
- id: "page-404"
9
- }, ___EmotionJSX("section", null, ___EmotionJSX(Result, {
10
- status: "404",
11
- title: "404",
12
- subTitle: ___EmotionJSX(FormattedMessage, {
13
- id: "app.not-found.subTitle"
14
- }),
15
- extra: ___EmotionJSX(Link, {
16
- to: "/"
17
- }, ___EmotionJSX(Button, {
18
- type: "primary",
19
- icon: ___EmotionJSX(HomeOutlined, null)
20
- }, ' ', ___EmotionJSX(FormattedMessage, {
21
- id: "app.not-found.back-home"
22
- })))
23
- })));
24
- };
25
- export default NotFoundPage;
@@ -1,3 +0,0 @@
1
- import { type FC } from 'react';
2
- declare const RtlSwitch: FC;
3
- export default RtlSwitch;