@ahooks.js/dumi-theme-antd 0.1.0 → 0.1.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/README.md CHANGED
@@ -4,7 +4,7 @@
4
4
 
5
5
  [dumi](https://d.umijs.org) theme similar to antd v5 website
6
6
 
7
- [![NPM Version](https://img.shields.io/npm/v/%40ahooksjs%2Fdumi-theme-antd)](https://npmjs.org/package/@ahooksjs/dumi-theme-antd) [![NPM Downloads](https://img.shields.io/npm/dm/%40ahooksjs%2Fdumi-theme-antd)](https://npmjs.org/package/@ahooksjs/dumi-theme-antd) [![Deploy](https://github.com/ahooksjs/dumi-theme-antd/actions/workflows/gh-pages.yml/badge.svg?branch=main)](https://github.com/ahooksjs/dumi-theme-antd/actions/workflows/gh-pages.yml)
7
+ [![NPM Version](https://img.shields.io/npm/v/%40ahooksjs%2Fdumi-theme-antd)](https://npmjs.org/package/@ahooks.js/dumi-theme-antd) [![NPM Downloads](https://img.shields.io/npm/dm/%40ahooksjs%2Fdumi-theme-antd)](https://npmjs.org/package/@ahooks.js/dumi-theme-antd) [![Deploy](https://github.com/ahooksjs/dumi-theme-antd/actions/workflows/gh-pages.yml/badge.svg?branch=main)](https://github.com/ahooksjs/dumi-theme-antd/actions/workflows/gh-pages.yml)
8
8
 
9
9
  </div>
10
10
 
@@ -19,7 +19,7 @@
19
19
  Install this theme into `devDependencies`:
20
20
 
21
21
  ```bash
22
- $ pnpm i @ahooksjs/dumi-theme-antd -D
22
+ $ pnpm i @ahooks.js/dumi-theme-antd -D
23
23
  ```
24
24
 
25
25
  ## Contributing
@@ -31,7 +31,7 @@ pnpm install
31
31
  pnpm run docs
32
32
  ```
33
33
 
34
- Thank you to all the people who already contributed to `@ahooksjs/dumi-theme-antd` !
34
+ Thank you to all the people who already contributed to `@ahooks.js/dumi-theme-antd` !
35
35
 
36
36
  ## LICENSE
37
37
 
@@ -10,9 +10,9 @@ import useSiteToken from "../../hooks/useSiteToken";
10
10
  import { getTargetLocalePath, isExternalLinks } from "../../utils";
11
11
  import { getMoreLinksGroup } from "./More";
12
12
  import { jsx as ___EmotionJSX } from "@emotion/react";
13
- var getFirstPathAndIgnoreLocale = function getFirstPathAndIgnoreLocale(pathname, localeBase) {
13
+ var getWithoutLocaleFirstPath = function getWithoutLocaleFirstPath(pathname, localeBase) {
14
14
  if (!pathname) return '';
15
- if (!localeBase) return pathname;
15
+ if (!localeBase || isExternalLinks(pathname)) return pathname;
16
16
  var splitPaths = pathname.split('/').filter(Boolean);
17
17
  var pathLocalePrefix = localeBase === '/' ? '' : localeBase;
18
18
  var firstPath = splitPaths.slice(0, pathLocalePrefix ? 2 : 1).join('/');
@@ -28,8 +28,8 @@ var useStyle = function useStyle() {
28
28
  menuItemBorder = token.menuItemBorder,
29
29
  colorPrimary = token.colorPrimary;
30
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 getFirstPathAndIgnoreLocale = (pathname?: string, localeBase?: string) => {\n  if (!pathname) return '';\n  if (!localeBase) 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 = getFirstPathAndIgnoreLocale(pathname, locale.base);\n\n  const menuItems: MenuItemType[] = (navList ?? [])\n    .map((navItem) => {\n      const { title, link } = navItem || {};\n      const key = getFirstPathAndIgnoreLocale(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 getFirstPathAndIgnoreLocale = (pathname?: string, localeBase?: string) => {\n  if (!pathname) return '';\n  if (!localeBase) 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 = getFirstPathAndIgnoreLocale(pathname, locale.base);\n\n  const menuItems: MenuItemType[] = (navList ?? [])\n    .map((navItem) => {\n      const { title, link } = navItem || {};\n      const key = getFirstPathAndIgnoreLocale(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"]} */")
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
33
  };
34
34
  };
35
35
  export default function Navigation(_ref) {
@@ -49,12 +49,12 @@ export default function Navigation(_ref) {
49
49
  var navList = useNavData();
50
50
  var locale = useLocale();
51
51
  var moreLinks = useLocaleValue('moreLinks');
52
- var activeKey = getFirstPathAndIgnoreLocale(pathname, locale.base);
52
+ var activeKey = getWithoutLocaleFirstPath(pathname, locale.base);
53
53
  var menuItems = (navList !== null && navList !== void 0 ? navList : []).map(function (navItem) {
54
54
  var _ref2 = navItem || {},
55
55
  title = _ref2.title,
56
56
  link = _ref2.link;
57
- var key = getFirstPathAndIgnoreLocale(link, locale.base);
57
+ var key = getWithoutLocaleFirstPath(link, locale.base);
58
58
  var path = "".concat(link).concat(search);
59
59
  return {
60
60
  key: key,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ahooks.js/dumi-theme-antd",
3
- "version": "0.1.0",
3
+ "version": "0.1.1",
4
4
  "description": "Ant Design 5.0 官网风格类似的 dumi2 主题插件",
5
5
  "keywords": [
6
6
  "dumi",