dumi-theme-antd4 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +109 -0
- package/dist/builtins/Alert/index.d.ts +6 -0
- package/dist/builtins/Alert/index.js +25 -0
- package/dist/builtins/BashOSPlatform/android.d.ts +7 -0
- package/dist/builtins/BashOSPlatform/android.js +37 -0
- package/dist/builtins/BashOSPlatform/index.d.ts +11 -0
- package/dist/builtins/BashOSPlatform/index.js +51 -0
- package/dist/builtins/BashOSPlatform/linux.d.ts +7 -0
- package/dist/builtins/BashOSPlatform/linux.js +60 -0
- package/dist/builtins/BashOSPlatform/macos.d.ts +7 -0
- package/dist/builtins/BashOSPlatform/macos.js +20 -0
- package/dist/builtins/BashOSPlatform/windows.d.ts +7 -0
- package/dist/builtins/BashOSPlatform/windows.js +20 -0
- package/dist/builtins/BashTabs/index.d.ts +21 -0
- package/dist/builtins/BashTabs/index.js +52 -0
- package/dist/builtins/HomeBaseLayout/components/Features/index.d.ts +3 -0
- package/dist/builtins/HomeBaseLayout/components/Features/index.js +78 -0
- package/dist/builtins/HomeBaseLayout/components/Group.d.ts +19 -0
- package/dist/builtins/HomeBaseLayout/components/Group.js +89 -0
- package/dist/builtins/HomeBaseLayout/index.d.ts +3 -0
- package/dist/builtins/HomeBaseLayout/index.js +201 -0
- package/dist/builtins/ImagePreview/index.d.ts +3 -0
- package/dist/builtins/ImagePreview/index.js +105 -0
- package/dist/builtins/InstallDependencies/index.d.ts +9 -0
- package/dist/builtins/InstallDependencies/index.js +38 -0
- package/dist/builtins/InstallDependencies/npm.d.ts +7 -0
- package/dist/builtins/InstallDependencies/npm.js +20 -0
- package/dist/builtins/InstallDependencies/pnpm.d.ts +7 -0
- package/dist/builtins/InstallDependencies/pnpm.js +22 -0
- package/dist/builtins/InstallDependencies/yarn.d.ts +7 -0
- package/dist/builtins/InstallDependencies/yarn.js +21 -0
- package/dist/common/CommonHelmet.d.ts +2 -0
- package/dist/common/CommonHelmet.js +27 -0
- package/dist/common/EditLink.d.ts +2 -0
- package/dist/common/EditLink.js +24 -0
- package/dist/common/GlobalStyles.d.ts +2 -0
- package/dist/common/GlobalStyles.js +7 -0
- package/dist/common/LastUpdated.d.ts +5 -0
- package/dist/common/LastUpdated.js +53 -0
- package/dist/common/Loading/index.d.ts +3 -0
- package/dist/common/Loading/index.js +67 -0
- package/dist/common/PrevAndNext.d.ts +5 -0
- package/dist/common/PrevAndNext.js +88 -0
- package/dist/common/styles/Common.d.ts +2 -0
- package/dist/common/styles/Common.js +16 -0
- package/dist/common/styles/DumiDefaultStyleOverride.d.ts +2 -0
- package/dist/common/styles/DumiDefaultStyleOverride.js +12 -0
- package/dist/common/styles/HeadingAnchor.d.ts +2 -0
- package/dist/common/styles/HeadingAnchor.js +17 -0
- package/dist/common/styles/Highlight.d.ts +2 -0
- package/dist/common/styles/Highlight.js +10 -0
- package/dist/common/styles/Markdown.d.ts +2 -0
- package/dist/common/styles/Markdown.js +13 -0
- package/dist/common/styles/PreviewImage.d.ts +2 -0
- package/dist/common/styles/PreviewImage.js +10 -0
- package/dist/common/styles/Reset.d.ts +2 -0
- package/dist/common/styles/Reset.js +17 -0
- package/dist/common/styles/Responsive.d.ts +2 -0
- package/dist/common/styles/Responsive.js +10 -0
- package/dist/common/styles/SearchBar.d.ts +2 -0
- package/dist/common/styles/SearchBar.js +11 -0
- package/dist/common/styles/index.d.ts +9 -0
- package/dist/common/styles/index.js +9 -0
- package/dist/defineThemeConfig/index.d.ts +7 -0
- package/dist/defineThemeConfig/index.js +31 -0
- package/dist/hooks/useAdditionalThemeConfig.d.ts +6 -0
- package/dist/hooks/useAdditionalThemeConfig.js +9 -0
- package/dist/hooks/useLocaleValue.d.ts +1 -0
- package/dist/hooks/useLocaleValue.js +10 -0
- package/dist/hooks/useMenu.d.ts +14 -0
- package/dist/hooks/useMenu.js +266 -0
- package/dist/hooks/useSiteToken.d.ts +66 -0
- package/dist/hooks/useSiteToken.js +105 -0
- package/dist/hooks/uselocale.d.ts +5 -0
- package/dist/hooks/uselocale.js +7 -0
- package/dist/icons/LTRIcon.d.ts +5 -0
- package/dist/icons/LTRIcon.js +20 -0
- package/dist/icons/RTLIcon.d.ts +5 -0
- package/dist/icons/RTLIcon.js +23 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +4 -0
- package/dist/layouts/DocLayout/index.d.ts +4 -0
- package/dist/layouts/DocLayout/index.js +90 -0
- package/dist/layouts/GlobalLayout.d.ts +3 -0
- package/dist/layouts/GlobalLayout.js +88 -0
- package/dist/layouts/HomePageLayout/index.d.ts +3 -0
- package/dist/layouts/HomePageLayout/index.js +7 -0
- package/dist/layouts/SidebarLayout/index.d.ts +3 -0
- package/dist/layouts/SidebarLayout/index.js +28 -0
- package/dist/locales/en-US.json +9 -0
- package/dist/locales/zh-CN.json +9 -0
- package/dist/slots/Content/DocAnchor.d.ts +7 -0
- package/dist/slots/Content/DocAnchor.js +75 -0
- package/dist/slots/Content/InViewSuspense.d.ts +8 -0
- package/dist/slots/Content/InViewSuspense.js +27 -0
- package/dist/slots/Content/index.d.ts +5 -0
- package/dist/slots/Content/index.js +118 -0
- package/dist/slots/Footer/index.d.ts +3 -0
- package/dist/slots/Footer/index.js +75 -0
- package/dist/slots/Header/HeaderExtral.d.ts +3 -0
- package/dist/slots/Header/HeaderExtral.js +34 -0
- package/dist/slots/Header/Logo.d.ts +2 -0
- package/dist/slots/Header/Logo.js +48 -0
- package/dist/slots/Header/More.d.ts +5 -0
- package/dist/slots/Header/More.js +32 -0
- package/dist/slots/Header/Navigation.d.ts +6 -0
- package/dist/slots/Header/Navigation.js +154 -0
- package/dist/slots/Header/SwitchBtn.d.ts +11 -0
- package/dist/slots/Header/SwitchBtn.js +85 -0
- package/dist/slots/Header/index.d.ts +4 -0
- package/dist/slots/Header/index.js +193 -0
- package/dist/slots/LangSwitch/index.d.ts +3 -0
- package/dist/slots/LangSwitch/index.js +86 -0
- package/dist/slots/NotFound/index.d.ts +9 -0
- package/dist/slots/NotFound/index.js +25 -0
- package/dist/slots/RtlSwitch/index.d.ts +3 -0
- package/dist/slots/RtlSwitch/index.js +53 -0
- package/dist/slots/Sidebar/index.d.ts +4 -0
- package/dist/slots/Sidebar/index.js +108 -0
- package/dist/slots/SiteContext.d.ts +9 -0
- package/dist/slots/SiteContext.js +7 -0
- package/dist/static/style.d.ts +2 -0
- package/dist/static/style.js +2 -0
- package/dist/styles/variables.less +1 -0
- package/dist/types.d.ts +103 -0
- package/dist/types.js +1 -0
- package/dist/utils.d.ts +24 -0
- package/dist/utils.js +112 -0
- package/package.json +101 -0
|
@@ -0,0 +1,154 @@
|
|
|
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 React, { 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 useStyle = function useStyle() {
|
|
14
|
+
var _useSiteToken = useSiteToken(),
|
|
15
|
+
token = _useSiteToken.token;
|
|
16
|
+
var antCls = token.antCls,
|
|
17
|
+
iconCls = token.iconCls,
|
|
18
|
+
fontFamily = token.fontFamily,
|
|
19
|
+
headerHeight = token.headerHeight,
|
|
20
|
+
menuItemBorder = token.menuItemBorder,
|
|
21
|
+
colorPrimary = token.colorPrimary;
|
|
22
|
+
return {
|
|
23
|
+
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:auto;height:", headerHeight, "px;padding:0 12px;margin:0;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":"AAwBY","file":"Navigation.tsx","sourcesContent":["import { MenuFoldOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Menu } from 'antd';\nimport { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { INavItem } from 'dumi/dist/client/theme-api/types';\nimport React, { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { getTargetLocalePath, isExternalLinks } from '../../utils';\nimport { getMoreLinksGroup } from './More';\nimport { type IResponsive } from './index';\n\nexport interface NavigationProps {\n  isMobile: boolean;\n  responsive: IResponsive;\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: auto;\n          height: ${headerHeight}px;\n          padding: 0 12px;\n          margin: 0;\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();\n  const moreLinks = useLocaleValue('moreLinks');\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n\n  const createMenuItems = (navs: INavItem[]): React.ReactNode => {\n    return navs.map((navItem: INavItem) => {\n      const linkKeyValue = (navItem.link ?? '').split('/').slice(0, 2).join('/');\n      const key = isExternalLinks(navItem.link) ? navItem.link : linkKeyValue;\n\n      // eslint-disable-next-line no-nested-ternary\n      const label = navItem.children ? (\n        navItem.title\n      ) : isExternalLinks(navItem.link) ? (\n        <a href={`${navItem.link}${search}`} target=\"_blank\" rel=\"noreferrer\">\n          {navItem.title}\n        </a>\n      ) : (\n        <Link to={`${navItem.link}${search}`}>{navItem.title}</Link>\n      );\n\n      if (navItem.children) {\n        return (\n          <Menu.SubMenu key={key} title={label}>\n            {createMenuItems(navItem.children)}\n          </Menu.SubMenu>\n        );\n      }\n\n      return <Menu.Item key={key}>{label}</Menu.Item>;\n    });\n  };\n  const menuItems = createMenuItems(navList);\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback((): React.ReactNode => {\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        <Menu.Item key={nextLang.id}>\n          <a rel=\"noopener noreferrer\" href={nextPath}>\n            {nextLang.name}\n          </a>\n        </Menu.Item>\n      );\n    }\n    return (\n      <Menu.SubMenu key=\"multi-lang\" title={<span>{locale.name}</span>}>\n        {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              <Menu.Item key={item.id}>\n                <a rel=\"noopener noreferrer\" href={nextPath}>\n                  {item.name}\n                </a>\n              </Menu.Item>\n            );\n          })}\n      </Menu.SubMenu>\n    );\n  }, [locale, locales]);\n\n  const moreLinksItems = getMoreLinksGroup(moreLinks) || [];\n  const additionalItems: React.ReactNode[] = [\n    github || socialLinks?.github ? (\n      <Menu.Item key=\"github\">\n        <a rel=\"noopener noreferrer\" href={github || socialLinks?.github} target=\"_blank\">\n          GitHub\n        </a>\n      </Menu.Item>\n    ) : null,\n    getLangNode(),\n    ...moreLinksItems\n      .filter((item) => item !== null)\n      .map((item) => {\n        const menuItem = item as { key: string; label: React.ReactNode; children?: any[] };\n        if (menuItem.children && menuItem.children.length > 0) {\n          return (\n            <Menu.SubMenu key={menuItem.key} title={menuItem.label}>\n              {menuItem.children\n                .filter((child) => child !== null)\n                .map((child) => {\n                  const childItem = child as { key: string; label: React.ReactNode };\n                  return <Menu.Item key={childItem.key}>{childItem.label}</Menu.Item>;\n                })}\n            </Menu.SubMenu>\n          );\n        }\n        return <Menu.Item key={menuItem.key}>{menuItem.label}</Menu.Item>;\n      })\n  ].filter(Boolean) as React.ReactNode[];\n\n  let additional: React.ReactNode[] = [];\n  if (isMobile) {\n    additional = additionalItems;\n  } else if (responsive === 'crowded') {\n    additional = [\n      <Menu.SubMenu key=\"additional\" title={<MenuFoldOutlined />}>\n        {additionalItems}\n      </Menu.SubMenu>\n    ];\n  }\n\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n  return (\n    <Menu mode={menuMode} css={style.nav} selectedKeys={[activeMenuItem]} disabledOverflow>\n      {menuItems}\n      {additional}\n    </Menu>\n  );\n}\n"]} */"),
|
|
24
|
+
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":"AAgEuB","file":"Navigation.tsx","sourcesContent":["import { MenuFoldOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Menu } from 'antd';\nimport { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { INavItem } from 'dumi/dist/client/theme-api/types';\nimport React, { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { getTargetLocalePath, isExternalLinks } from '../../utils';\nimport { getMoreLinksGroup } from './More';\nimport { type IResponsive } from './index';\n\nexport interface NavigationProps {\n  isMobile: boolean;\n  responsive: IResponsive;\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: auto;\n          height: ${headerHeight}px;\n          padding: 0 12px;\n          margin: 0;\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();\n  const moreLinks = useLocaleValue('moreLinks');\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n\n  const createMenuItems = (navs: INavItem[]): React.ReactNode => {\n    return navs.map((navItem: INavItem) => {\n      const linkKeyValue = (navItem.link ?? '').split('/').slice(0, 2).join('/');\n      const key = isExternalLinks(navItem.link) ? navItem.link : linkKeyValue;\n\n      // eslint-disable-next-line no-nested-ternary\n      const label = navItem.children ? (\n        navItem.title\n      ) : isExternalLinks(navItem.link) ? (\n        <a href={`${navItem.link}${search}`} target=\"_blank\" rel=\"noreferrer\">\n          {navItem.title}\n        </a>\n      ) : (\n        <Link to={`${navItem.link}${search}`}>{navItem.title}</Link>\n      );\n\n      if (navItem.children) {\n        return (\n          <Menu.SubMenu key={key} title={label}>\n            {createMenuItems(navItem.children)}\n          </Menu.SubMenu>\n        );\n      }\n\n      return <Menu.Item key={key}>{label}</Menu.Item>;\n    });\n  };\n  const menuItems = createMenuItems(navList);\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback((): React.ReactNode => {\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        <Menu.Item key={nextLang.id}>\n          <a rel=\"noopener noreferrer\" href={nextPath}>\n            {nextLang.name}\n          </a>\n        </Menu.Item>\n      );\n    }\n    return (\n      <Menu.SubMenu key=\"multi-lang\" title={<span>{locale.name}</span>}>\n        {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              <Menu.Item key={item.id}>\n                <a rel=\"noopener noreferrer\" href={nextPath}>\n                  {item.name}\n                </a>\n              </Menu.Item>\n            );\n          })}\n      </Menu.SubMenu>\n    );\n  }, [locale, locales]);\n\n  const moreLinksItems = getMoreLinksGroup(moreLinks) || [];\n  const additionalItems: React.ReactNode[] = [\n    github || socialLinks?.github ? (\n      <Menu.Item key=\"github\">\n        <a rel=\"noopener noreferrer\" href={github || socialLinks?.github} target=\"_blank\">\n          GitHub\n        </a>\n      </Menu.Item>\n    ) : null,\n    getLangNode(),\n    ...moreLinksItems\n      .filter((item) => item !== null)\n      .map((item) => {\n        const menuItem = item as { key: string; label: React.ReactNode; children?: any[] };\n        if (menuItem.children && menuItem.children.length > 0) {\n          return (\n            <Menu.SubMenu key={menuItem.key} title={menuItem.label}>\n              {menuItem.children\n                .filter((child) => child !== null)\n                .map((child) => {\n                  const childItem = child as { key: string; label: React.ReactNode };\n                  return <Menu.Item key={childItem.key}>{childItem.label}</Menu.Item>;\n                })}\n            </Menu.SubMenu>\n          );\n        }\n        return <Menu.Item key={menuItem.key}>{menuItem.label}</Menu.Item>;\n      })\n  ].filter(Boolean) as React.ReactNode[];\n\n  let additional: React.ReactNode[] = [];\n  if (isMobile) {\n    additional = additionalItems;\n  } else if (responsive === 'crowded') {\n    additional = [\n      <Menu.SubMenu key=\"additional\" title={<MenuFoldOutlined />}>\n        {additionalItems}\n      </Menu.SubMenu>\n    ];\n  }\n\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n  return (\n    <Menu mode={menuMode} css={style.nav} selectedKeys={[activeMenuItem]} disabledOverflow>\n      {menuItems}\n      {additional}\n    </Menu>\n  );\n}\n"]} */")
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
export default function Navigation(_ref) {
|
|
28
|
+
var isMobile = _ref.isMobile,
|
|
29
|
+
responsive = _ref.responsive;
|
|
30
|
+
var _useLocation = useLocation(),
|
|
31
|
+
pathname = _useLocation.pathname,
|
|
32
|
+
search = _useLocation.search;
|
|
33
|
+
var _useSiteData = useSiteData(),
|
|
34
|
+
locales = _useSiteData.locales;
|
|
35
|
+
var _useAdditionalThemeCo = useAdditionalThemeConfig(),
|
|
36
|
+
github = _useAdditionalThemeCo.github,
|
|
37
|
+
socialLinks = _useAdditionalThemeCo.socialLinks;
|
|
38
|
+
|
|
39
|
+
// 统一使用 themeConfig.nav,使用 useNavData,当存在自定义 pages 时,会导致 nav 混乱
|
|
40
|
+
var navList = useNavData();
|
|
41
|
+
var locale = useLocale();
|
|
42
|
+
var moreLinks = useLocaleValue('moreLinks');
|
|
43
|
+
var activeMenuItem = pathname.split('/').slice(0, 2).join('/');
|
|
44
|
+
var createMenuItems = function createMenuItems(navs) {
|
|
45
|
+
return navs.map(function (navItem) {
|
|
46
|
+
var _navItem$link;
|
|
47
|
+
var linkKeyValue = ((_navItem$link = navItem.link) !== null && _navItem$link !== void 0 ? _navItem$link : '').split('/').slice(0, 2).join('/');
|
|
48
|
+
var key = isExternalLinks(navItem.link) ? navItem.link : linkKeyValue;
|
|
49
|
+
|
|
50
|
+
// eslint-disable-next-line no-nested-ternary
|
|
51
|
+
var label = navItem.children ? navItem.title : isExternalLinks(navItem.link) ? ___EmotionJSX("a", {
|
|
52
|
+
href: "".concat(navItem.link).concat(search),
|
|
53
|
+
target: "_blank",
|
|
54
|
+
rel: "noreferrer"
|
|
55
|
+
}, navItem.title) : ___EmotionJSX(Link, {
|
|
56
|
+
to: "".concat(navItem.link).concat(search)
|
|
57
|
+
}, navItem.title);
|
|
58
|
+
if (navItem.children) {
|
|
59
|
+
return ___EmotionJSX(Menu.SubMenu, {
|
|
60
|
+
key: key,
|
|
61
|
+
title: label
|
|
62
|
+
}, createMenuItems(navItem.children));
|
|
63
|
+
}
|
|
64
|
+
return ___EmotionJSX(Menu.Item, {
|
|
65
|
+
key: key
|
|
66
|
+
}, label);
|
|
67
|
+
});
|
|
68
|
+
};
|
|
69
|
+
var menuItems = createMenuItems(navList);
|
|
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 ___EmotionJSX(Menu.Item, {
|
|
85
|
+
key: nextLang.id
|
|
86
|
+
}, ___EmotionJSX("a", {
|
|
87
|
+
rel: "noopener noreferrer",
|
|
88
|
+
href: nextPath
|
|
89
|
+
}, nextLang.name));
|
|
90
|
+
}
|
|
91
|
+
return ___EmotionJSX(Menu.SubMenu, {
|
|
92
|
+
key: "multi-lang",
|
|
93
|
+
title: ___EmotionJSX("span", null, locale.name)
|
|
94
|
+
}, locales.filter(function (item) {
|
|
95
|
+
return item.id !== locale.id;
|
|
96
|
+
}).map(function (item) {
|
|
97
|
+
var nextPath = getTargetLocalePath({
|
|
98
|
+
current: locale,
|
|
99
|
+
target: item
|
|
100
|
+
});
|
|
101
|
+
return ___EmotionJSX(Menu.Item, {
|
|
102
|
+
key: item.id
|
|
103
|
+
}, ___EmotionJSX("a", {
|
|
104
|
+
rel: "noopener noreferrer",
|
|
105
|
+
href: nextPath
|
|
106
|
+
}, item.name));
|
|
107
|
+
}));
|
|
108
|
+
}, [locale, locales]);
|
|
109
|
+
var moreLinksItems = getMoreLinksGroup(moreLinks) || [];
|
|
110
|
+
var additionalItems = [github || socialLinks !== null && socialLinks !== void 0 && socialLinks.github ? ___EmotionJSX(Menu.Item, {
|
|
111
|
+
key: "github"
|
|
112
|
+
}, ___EmotionJSX("a", {
|
|
113
|
+
rel: "noopener noreferrer",
|
|
114
|
+
href: github || (socialLinks === null || socialLinks === void 0 ? void 0 : socialLinks.github),
|
|
115
|
+
target: "_blank"
|
|
116
|
+
}, "GitHub")) : null, getLangNode()].concat(_toConsumableArray(moreLinksItems.filter(function (item) {
|
|
117
|
+
return item !== null;
|
|
118
|
+
}).map(function (item) {
|
|
119
|
+
var menuItem = item;
|
|
120
|
+
if (menuItem.children && menuItem.children.length > 0) {
|
|
121
|
+
return ___EmotionJSX(Menu.SubMenu, {
|
|
122
|
+
key: menuItem.key,
|
|
123
|
+
title: menuItem.label
|
|
124
|
+
}, menuItem.children.filter(function (child) {
|
|
125
|
+
return child !== null;
|
|
126
|
+
}).map(function (child) {
|
|
127
|
+
var childItem = child;
|
|
128
|
+
return ___EmotionJSX(Menu.Item, {
|
|
129
|
+
key: childItem.key
|
|
130
|
+
}, childItem.label);
|
|
131
|
+
}));
|
|
132
|
+
}
|
|
133
|
+
return ___EmotionJSX(Menu.Item, {
|
|
134
|
+
key: menuItem.key
|
|
135
|
+
}, menuItem.label);
|
|
136
|
+
}))).filter(Boolean);
|
|
137
|
+
var additional = [];
|
|
138
|
+
if (isMobile) {
|
|
139
|
+
additional = additionalItems;
|
|
140
|
+
} else if (responsive === 'crowded') {
|
|
141
|
+
additional = [___EmotionJSX(Menu.SubMenu, {
|
|
142
|
+
key: "additional",
|
|
143
|
+
title: ___EmotionJSX(MenuFoldOutlined, null)
|
|
144
|
+
}, additionalItems)];
|
|
145
|
+
}
|
|
146
|
+
var menuMode = isMobile ? 'inline' : 'horizontal';
|
|
147
|
+
var style = useStyle();
|
|
148
|
+
return ___EmotionJSX(Menu, {
|
|
149
|
+
mode: menuMode,
|
|
150
|
+
css: style.nav,
|
|
151
|
+
selectedKeys: [activeMenuItem],
|
|
152
|
+
disabledOverflow: true
|
|
153
|
+
}, menuItems, additional);
|
|
154
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
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;
|
|
@@ -0,0 +1,85 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,193 @@
|
|
|
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, ";@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\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 location = useLocation();\n  const { docVersions } = useAdditionalThemeConfig();\n\n  const onWindowResize = useCallback(() => {\n    if (typeof window === 'undefined') {\n      return;\n    }\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    if (typeof window === 'undefined') {\n      return;\n    }\n    window.location.href = url;\n  }, []);\n\n  useEffect(() => {\n    handleHideMenu();\n  }, [location, handleHideMenu]);\n\n  useEffect(() => {\n    if (typeof window === 'undefined') {\n      return () => {};\n    }\n    onWindowResize();\n    window.addEventListener('resize', onWindowResize);\n    return () => {\n      window.removeEventListener('resize', onWindowResize);\n    };\n  }, [onWindowResize]);\n\n  const { pathname } = location;\n  const locale = useLocale();\n  const suffix: string = (locale as any).suffex || '';\n  const isHome = ['', `index${suffix}`].includes(pathname);\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\" />\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":"AAoHgB","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\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 location = useLocation();\n  const { docVersions } = useAdditionalThemeConfig();\n\n  const onWindowResize = useCallback(() => {\n    if (typeof window === 'undefined') {\n      return;\n    }\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    if (typeof window === 'undefined') {\n      return;\n    }\n    window.location.href = url;\n  }, []);\n\n  useEffect(() => {\n    handleHideMenu();\n  }, [location, handleHideMenu]);\n\n  useEffect(() => {\n    if (typeof window === 'undefined') {\n      return () => {};\n    }\n    onWindowResize();\n    window.addEventListener('resize', onWindowResize);\n    return () => {\n      window.removeEventListener('resize', onWindowResize);\n    };\n  }, [onWindowResize]);\n\n  const { pathname } = location;\n  const locale = useLocale();\n  const suffix: string = (locale as any).suffex || '';\n  const isHome = ['', `index${suffix}`].includes(pathname);\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\" />\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 location = useLocation();
|
|
71
|
+
var _useAdditionalThemeCo = useAdditionalThemeConfig(),
|
|
72
|
+
docVersions = _useAdditionalThemeCo.docVersions;
|
|
73
|
+
var onWindowResize = useCallback(function () {
|
|
74
|
+
if (typeof window === 'undefined') {
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
setHeaderState(function (prev) {
|
|
78
|
+
return _objectSpread(_objectSpread({}, prev), {}, {
|
|
79
|
+
windowWidth: window.innerWidth
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
}, []);
|
|
83
|
+
var handleHideMenu = useCallback(function () {
|
|
84
|
+
setHeaderState(function (prev) {
|
|
85
|
+
return _objectSpread(_objectSpread({}, prev), {}, {
|
|
86
|
+
menuVisible: false
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
}, []);
|
|
90
|
+
var onMenuVisibleChange = useCallback(function (visible) {
|
|
91
|
+
setHeaderState(function (prev) {
|
|
92
|
+
return _objectSpread(_objectSpread({}, prev), {}, {
|
|
93
|
+
menuVisible: visible
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
}, []);
|
|
97
|
+
var handleVersionChange = useCallback(function (url) {
|
|
98
|
+
if (typeof window === 'undefined') {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
window.location.href = url;
|
|
102
|
+
}, []);
|
|
103
|
+
useEffect(function () {
|
|
104
|
+
handleHideMenu();
|
|
105
|
+
}, [location, handleHideMenu]);
|
|
106
|
+
useEffect(function () {
|
|
107
|
+
if (typeof window === 'undefined') {
|
|
108
|
+
return function () {};
|
|
109
|
+
}
|
|
110
|
+
onWindowResize();
|
|
111
|
+
window.addEventListener('resize', onWindowResize);
|
|
112
|
+
return function () {
|
|
113
|
+
window.removeEventListener('resize', onWindowResize);
|
|
114
|
+
};
|
|
115
|
+
}, [onWindowResize]);
|
|
116
|
+
var pathname = location.pathname;
|
|
117
|
+
var locale = useLocale();
|
|
118
|
+
var suffix = locale.suffex || '';
|
|
119
|
+
var isHome = ['', "index".concat(suffix)].includes(pathname);
|
|
120
|
+
var windowWidth = headerState.windowWidth,
|
|
121
|
+
menuVisible = headerState.menuVisible;
|
|
122
|
+
var style = useStyle();
|
|
123
|
+
var headerClassName = classNames({
|
|
124
|
+
clearfix: true,
|
|
125
|
+
'home-header': isHome
|
|
126
|
+
});
|
|
127
|
+
var responsive = null;
|
|
128
|
+
if (windowWidth < RESPONSIVE_XS) {
|
|
129
|
+
responsive = 'crowded';
|
|
130
|
+
} else if (windowWidth < RESPONSIVE_SM) {
|
|
131
|
+
responsive = 'narrow';
|
|
132
|
+
}
|
|
133
|
+
var navigationNode = ___EmotionJSX(Navigation, {
|
|
134
|
+
key: "nav",
|
|
135
|
+
isMobile: isMobile,
|
|
136
|
+
responsive: responsive
|
|
137
|
+
});
|
|
138
|
+
var versionOptions = Object.keys(docVersions !== null && docVersions !== void 0 ? docVersions : {}).map(function (version) {
|
|
139
|
+
return {
|
|
140
|
+
value: docVersions === null || docVersions === void 0 ? void 0 : docVersions[version],
|
|
141
|
+
label: version
|
|
142
|
+
};
|
|
143
|
+
});
|
|
144
|
+
var menu = [navigationNode, versionOptions.length > 0 ? ___EmotionJSX(Select, {
|
|
145
|
+
key: "version",
|
|
146
|
+
size: "small",
|
|
147
|
+
defaultValue: (_versionOptions$ = versionOptions[0]) === null || _versionOptions$ === void 0 ? void 0 : _versionOptions$.value,
|
|
148
|
+
onChange: handleVersionChange,
|
|
149
|
+
popupMatchSelectWidth: false,
|
|
150
|
+
getPopupContainer: function getPopupContainer(trigger) {
|
|
151
|
+
return trigger.parentNode;
|
|
152
|
+
},
|
|
153
|
+
options: versionOptions
|
|
154
|
+
}) : null, ___EmotionJSX(More, {
|
|
155
|
+
key: "more"
|
|
156
|
+
}), ___EmotionJSX(LangSwitch, {
|
|
157
|
+
key: new Date().getTime()
|
|
158
|
+
}), ___EmotionJSX(RtlSwitch, {
|
|
159
|
+
key: "direction"
|
|
160
|
+
}), ___EmotionJSX(HeaderExtra, {
|
|
161
|
+
key: "header-Extra"
|
|
162
|
+
})];
|
|
163
|
+
if (windowWidth < RESPONSIVE_XS) {
|
|
164
|
+
menu = [navigationNode];
|
|
165
|
+
}
|
|
166
|
+
var colProps = isHome ? colPropsHome : _colProps;
|
|
167
|
+
return ___EmotionJSX("header", {
|
|
168
|
+
css: style.header,
|
|
169
|
+
className: headerClassName
|
|
170
|
+
}, isMobile && ___EmotionJSX(ClassNames, null, function (_ref) {
|
|
171
|
+
var cssFn = _ref.css;
|
|
172
|
+
return ___EmotionJSX(Popover, {
|
|
173
|
+
overlayClassName: cssFn(style.popoverMenu),
|
|
174
|
+
placement: "bottomRight",
|
|
175
|
+
content: menu,
|
|
176
|
+
trigger: "click",
|
|
177
|
+
open: menuVisible,
|
|
178
|
+
arrow: true,
|
|
179
|
+
onOpenChange: onMenuVisibleChange
|
|
180
|
+
}, ___EmotionJSX(MenuOutlined, {
|
|
181
|
+
className: "nav-phone-icon"
|
|
182
|
+
}));
|
|
183
|
+
}), ___EmotionJSX(Row, {
|
|
184
|
+
style: {
|
|
185
|
+
height: 64
|
|
186
|
+
}
|
|
187
|
+
}, ___EmotionJSX(Col, colProps[0], ___EmotionJSX(Logo, null)), ___EmotionJSX(Col, _extends({}, colProps[1], {
|
|
188
|
+
css: style.menuRow
|
|
189
|
+
}), ___EmotionJSX("div", {
|
|
190
|
+
className: "nav-search-wrapper"
|
|
191
|
+
}, ___EmotionJSX(DumiSearchBar, null)), !isMobile && menu)));
|
|
192
|
+
};
|
|
193
|
+
export default Header;
|
|
@@ -0,0 +1,86 @@
|
|
|
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
|
+
// 多多语言首页做特殊处理 eg. /index-en
|
|
36
|
+
if (path.startsWith('/-')) {
|
|
37
|
+
path = "/index".concat(path.substring(1));
|
|
38
|
+
} else if (path.endsWith('/index')) {
|
|
39
|
+
path = path.replace('/index', '/');
|
|
40
|
+
}
|
|
41
|
+
history.push({
|
|
42
|
+
pathname: path,
|
|
43
|
+
search: searchParams.toString()
|
|
44
|
+
});
|
|
45
|
+
}, [pathname, current, locales, searchParams]);
|
|
46
|
+
var onLangChange = useCallback(function () {
|
|
47
|
+
handleLangChange(locales.filter(function (item) {
|
|
48
|
+
return item.id !== locale;
|
|
49
|
+
})[0].id);
|
|
50
|
+
}, [locale, handleLangChange, locales]);
|
|
51
|
+
var LangSwitchJSX;
|
|
52
|
+
// do not render in single language
|
|
53
|
+
if (locales.length > 2 || !localesEnhance && locales.length > 2) {
|
|
54
|
+
var langOptions = locales.map(function (lang) {
|
|
55
|
+
return ___EmotionJSX(Option, {
|
|
56
|
+
value: lang.id,
|
|
57
|
+
key: lang.id
|
|
58
|
+
}, lang.name);
|
|
59
|
+
});
|
|
60
|
+
LangSwitchJSX = ___EmotionJSX(Select, {
|
|
61
|
+
key: "lang",
|
|
62
|
+
className: "version",
|
|
63
|
+
size: "small",
|
|
64
|
+
defaultValue: locale,
|
|
65
|
+
onChange: handleLangChange,
|
|
66
|
+
popupMatchSelectWidth: false,
|
|
67
|
+
getPopupContainer: function getPopupContainer(trigger) {
|
|
68
|
+
return trigger.parentNode;
|
|
69
|
+
}
|
|
70
|
+
}, langOptions);
|
|
71
|
+
} else if (locales.length === 2 && Array.isArray(localesEnhance) && localesEnhance.length > 1) {
|
|
72
|
+
// 按 locales 顺序展示
|
|
73
|
+
var switchValue = locales[0].id === locale ? 1 : 2;
|
|
74
|
+
LangSwitchJSX = ___EmotionJSX(SwitchBtn, {
|
|
75
|
+
key: "lang",
|
|
76
|
+
onClick: onLangChange,
|
|
77
|
+
value: switchValue,
|
|
78
|
+
label1: localesEnhance[0].switchPrefix,
|
|
79
|
+
label2: localesEnhance[1].switchPrefix,
|
|
80
|
+
tooltip1: "".concat(locales[0].name, " / ").concat(locales[1].name),
|
|
81
|
+
tooltip2: "".concat(locales[1].name, " / ").concat(locales[0].name)
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
return LangSwitchJSX;
|
|
85
|
+
};
|
|
86
|
+
export default LangSwitch;
|