@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 +3 -3
- package/dist/slots/Header/Navigation.js +6 -6
- package/package.json +1 -1
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
|
-
[](https://npmjs.org/package/@
|
|
7
|
+
[](https://npmjs.org/package/@ahooks.js/dumi-theme-antd) [](https://npmjs.org/package/@ahooks.js/dumi-theme-antd) [](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 @
|
|
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 `@
|
|
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
|
|
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,
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdmlnYXRpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThFdUIiLCJmaWxlIjoiTmF2aWdhdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNZW51Rm9sZE91dGxpbmVkIH0gZnJvbSAnQGFudC1kZXNpZ24vaWNvbnMnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHR5cGUgeyBNZW51UHJvcHMgfSBmcm9tICdhbnRkJztcbmltcG9ydCB7IE1lbnUgfSBmcm9tICdhbnRkJztcbmltcG9ydCB7IE1lbnVJdGVtVHlwZSB9IGZyb20gJ2FudGQvZXMvbWVudS9ob29rcy91c2VJdGVtcyc7XG5pbXBvcnQgeyBMaW5rLCB1c2VMb2NhbGUsIHVzZUxvY2F0aW9uLCB1c2VOYXZEYXRhLCB1c2VTaXRlRGF0YSB9IGZyb20gJ2R1bWknO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2sgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdXNlQWRkaXRpb25hbFRoZW1lQ29uZmlnIGZyb20gJy4uLy4uL2hvb2tzL3VzZUFkZGl0aW9uYWxUaGVtZUNvbmZpZyc7XG5pbXBvcnQgdXNlTG9jYWxlVmFsdWUgZnJvbSAnLi4vLi4vaG9va3MvdXNlTG9jYWxlVmFsdWUnO1xuaW1wb3J0IHVzZVNpdGVUb2tlbiBmcm9tICcuLi8uLi9ob29rcy91c2VTaXRlVG9rZW4nO1xuaW1wb3J0IHsgZ2V0VGFyZ2V0TG9jYWxlUGF0aCwgaXNFeHRlcm5hbExpbmtzIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgdHlwZSBJUmVzcG9uc2l2ZSB9IGZyb20gJy4vaW5kZXgnO1xuaW1wb3J0IHsgZ2V0TW9yZUxpbmtzR3JvdXAgfSBmcm9tICcuL01vcmUnO1xuXG50eXBlIE1lbnVJdGVtc1R5cGUgPSBSZXF1aXJlZDxNZW51UHJvcHM+
|
|
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 =
|
|
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 =
|
|
57
|
+
var key = getWithoutLocaleFirstPath(link, locale.base);
|
|
58
58
|
var path = "".concat(link).concat(search);
|
|
59
59
|
return {
|
|
60
60
|
key: key,
|