Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

dumi-theme-nocobase

Package Overview
Dependencies
Maintainers
1
Versions
25
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

dumi-theme-nocobase - npm Package Compare versions

Comparing version 0.2.27 to 0.2.28

10

dist/slots/Header/Navigation.js

@@ -6,4 +6,5 @@ import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";

import { Menu } from 'antd';
import { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';
import { useLocale, useLocation, useNavData, useSiteData } from 'dumi';
import { useCallback } from 'react';
import ExternalLink from "../../common/ExternalLink";
import useAdditionalThemeConfig from "../../hooks/useAdditionalThemeConfig";

@@ -24,4 +25,4 @@ import useSiteToken from "../../hooks/useSiteToken";

return {
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":"AAyBY","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 { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { ILocale, ILocalesConfig } from 'dumi/dist/client/theme-api/types';\nimport { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { ILocaleEnhance } from '../../types';\nimport { getTargetLocalePath } 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: (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\nfunction getNextLang(locale: ILocale, locales: ILocalesConfig, localesEnhance?: ILocaleEnhance[]) {\n  const changeLangByHostname = localesEnhance && localesEnhance.every((item) => item.hostname);\n  if (\n    typeof window !== 'undefined' &&\n    changeLangByHostname &&\n    window.location.hostname !== 'localhost'\n  ) {\n    const nextLocaleEnhance = localesEnhance.find(\n      (item) => item.hostname !== window.location.hostname\n    );\n    if (nextLocaleEnhance) {\n      const nextLang = locales.find((item) => item.id === nextLocaleEnhance.id);\n      if (nextLang) {\n        return {\n          ...nextLang,\n          nextPath: window.location.href.replace(\n            window.location.hostname,\n            nextLocaleEnhance.hostname!\n          )\n        };\n      }\n    }\n  }\n\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    ...nextLang,\n    nextPath\n  };\n}\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const locale = useLocale();\n  const { github, moreLinks = [], localesEnhance } = useAdditionalThemeConfig();\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n\n  // @ts-ignore\n  const menuItems: MenuProps['items'] = (navList ?? []).map((navItem) => {\n    const linkKeyValue = navItem.link?.split('/').slice(0, 2).join('/');\n    return {\n      label: <Link to={`${navItem.link}${search}`}>{navItem.title}</Link>,\n      key: linkKeyValue\n    };\n  });\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback(() => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = getNextLang(locale, locales, localesEnhance);\n      return {\n        label: (\n          <a rel=\"noopener noreferrer\" href={nextLang.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, localesEnhance]);\n\n  let additional: MenuProps['items'];\n  const additionalItems: MenuProps['items'] = [\n    github\n      ? {\n          label: (\n            <a rel=\"noopener noreferrer\" href={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  const items: MenuProps['items'] = [...(menuItems ?? []), ...(additional ?? [])];\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n  return (\n    <Menu\n      items={items}\n      mode={menuMode}\n      css={style.nav}\n      style={{ height: '95%' }}\n      selectedKeys={[activeMenuItem]}\n      disabledOverflow\n    />\n  );\n}\n"]} */"),
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":"AAiEuB","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 { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { ILocale, ILocalesConfig } from 'dumi/dist/client/theme-api/types';\nimport { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { ILocaleEnhance } from '../../types';\nimport { getTargetLocalePath } 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: (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\nfunction getNextLang(locale: ILocale, locales: ILocalesConfig, localesEnhance?: ILocaleEnhance[]) {\n  const changeLangByHostname = localesEnhance && localesEnhance.every((item) => item.hostname);\n  if (\n    typeof window !== 'undefined' &&\n    changeLangByHostname &&\n    window.location.hostname !== 'localhost'\n  ) {\n    const nextLocaleEnhance = localesEnhance.find(\n      (item) => item.hostname !== window.location.hostname\n    );\n    if (nextLocaleEnhance) {\n      const nextLang = locales.find((item) => item.id === nextLocaleEnhance.id);\n      if (nextLang) {\n        return {\n          ...nextLang,\n          nextPath: window.location.href.replace(\n            window.location.hostname,\n            nextLocaleEnhance.hostname!\n          )\n        };\n      }\n    }\n  }\n\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    ...nextLang,\n    nextPath\n  };\n}\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const locale = useLocale();\n  const { github, moreLinks = [], localesEnhance } = useAdditionalThemeConfig();\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n\n  // @ts-ignore\n  const menuItems: MenuProps['items'] = (navList ?? []).map((navItem) => {\n    const linkKeyValue = navItem.link?.split('/').slice(0, 2).join('/');\n    return {\n      label: <Link to={`${navItem.link}${search}`}>{navItem.title}</Link>,\n      key: linkKeyValue\n    };\n  });\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback(() => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = getNextLang(locale, locales, localesEnhance);\n      return {\n        label: (\n          <a rel=\"noopener noreferrer\" href={nextLang.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, localesEnhance]);\n\n  let additional: MenuProps['items'];\n  const additionalItems: MenuProps['items'] = [\n    github\n      ? {\n          label: (\n            <a rel=\"noopener noreferrer\" href={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  const items: MenuProps['items'] = [...(menuItems ?? []), ...(additional ?? [])];\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n  return (\n    <Menu\n      items={items}\n      mode={menuMode}\n      css={style.nav}\n      style={{ height: '95%' }}\n      selectedKeys={[activeMenuItem]}\n      disabledOverflow\n    />\n  );\n}\n"]} */")
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":"AA0BY","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 { useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { ILocale, ILocalesConfig } from 'dumi/dist/client/theme-api/types';\nimport { useCallback } from 'react';\nimport ExternalLink from '../../common/ExternalLink';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { ILocaleEnhance } from '../../types';\nimport { getTargetLocalePath } 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: (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\nfunction getNextLang(locale: ILocale, locales: ILocalesConfig, localesEnhance?: ILocaleEnhance[]) {\n  const changeLangByHostname = localesEnhance && localesEnhance.every((item) => item.hostname);\n  if (\n    typeof window !== 'undefined' &&\n    changeLangByHostname &&\n    window.location.hostname !== 'localhost'\n  ) {\n    const nextLocaleEnhance = localesEnhance.find(\n      (item) => item.hostname !== window.location.hostname\n    );\n    if (nextLocaleEnhance) {\n      const nextLang = locales.find((item) => item.id === nextLocaleEnhance.id);\n      if (nextLang) {\n        return {\n          ...nextLang,\n          nextPath: window.location.href.replace(\n            window.location.hostname,\n            nextLocaleEnhance.hostname!\n          )\n        };\n      }\n    }\n  }\n\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    ...nextLang,\n    nextPath\n  };\n}\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const locale = useLocale();\n  const { github, moreLinks = [], localesEnhance } = useAdditionalThemeConfig();\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n  // @ts-ignore\n  const menuItems: MenuProps['items'] = (navList ?? []).map((navItem) => {\n    const linkKeyValue = navItem.link?.split('/').slice(0, 2).join('/');\n    return {\n      label: <ExternalLink to={`${navItem.link}${search}`}>{navItem.title}</ExternalLink>,\n      key: linkKeyValue\n    };\n  });\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback(() => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = getNextLang(locale, locales, localesEnhance);\n      return {\n        label: (\n          <a rel=\"noopener noreferrer\" href={nextLang.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, localesEnhance]);\n\n  let additional: MenuProps['items'];\n  const additionalItems: MenuProps['items'] = [\n    github\n      ? {\n          label: (\n            <a rel=\"noopener noreferrer\" href={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  const items: MenuProps['items'] = [...(menuItems ?? []), ...(additional ?? [])];\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n  return (\n    <Menu\n      items={items}\n      mode={menuMode}\n      css={style.nav}\n      style={{ height: '95%' }}\n      selectedKeys={[activeMenuItem]}\n      disabledOverflow\n    />\n  );\n}\n"]} */"),
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":"AAkEuB","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 { useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { ILocale, ILocalesConfig } from 'dumi/dist/client/theme-api/types';\nimport { useCallback } from 'react';\nimport ExternalLink from '../../common/ExternalLink';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { ILocaleEnhance } from '../../types';\nimport { getTargetLocalePath } 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: (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\nfunction getNextLang(locale: ILocale, locales: ILocalesConfig, localesEnhance?: ILocaleEnhance[]) {\n  const changeLangByHostname = localesEnhance && localesEnhance.every((item) => item.hostname);\n  if (\n    typeof window !== 'undefined' &&\n    changeLangByHostname &&\n    window.location.hostname !== 'localhost'\n  ) {\n    const nextLocaleEnhance = localesEnhance.find(\n      (item) => item.hostname !== window.location.hostname\n    );\n    if (nextLocaleEnhance) {\n      const nextLang = locales.find((item) => item.id === nextLocaleEnhance.id);\n      if (nextLang) {\n        return {\n          ...nextLang,\n          nextPath: window.location.href.replace(\n            window.location.hostname,\n            nextLocaleEnhance.hostname!\n          )\n        };\n      }\n    }\n  }\n\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    ...nextLang,\n    nextPath\n  };\n}\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const locale = useLocale();\n  const { github, moreLinks = [], localesEnhance } = useAdditionalThemeConfig();\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n  // @ts-ignore\n  const menuItems: MenuProps['items'] = (navList ?? []).map((navItem) => {\n    const linkKeyValue = navItem.link?.split('/').slice(0, 2).join('/');\n    return {\n      label: <ExternalLink to={`${navItem.link}${search}`}>{navItem.title}</ExternalLink>,\n      key: linkKeyValue\n    };\n  });\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback(() => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = getNextLang(locale, locales, localesEnhance);\n      return {\n        label: (\n          <a rel=\"noopener noreferrer\" href={nextLang.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, localesEnhance]);\n\n  let additional: MenuProps['items'];\n  const additionalItems: MenuProps['items'] = [\n    github\n      ? {\n          label: (\n            <a rel=\"noopener noreferrer\" href={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  const items: MenuProps['items'] = [...(menuItems ?? []), ...(additional ?? [])];\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n  return (\n    <Menu\n      items={items}\n      mode={menuMode}\n      css={style.nav}\n      style={{ height: '95%' }}\n      selectedKeys={[activeMenuItem]}\n      disabledOverflow\n    />\n  );\n}\n"]} */")
};

@@ -77,3 +78,2 @@ };

var activeMenuItem = pathname.split('/').slice(0, 2).join('/');
// @ts-ignore

@@ -84,3 +84,3 @@ var menuItems = (navList !== null && navList !== void 0 ? navList : []).map(function (navItem) {

return {
label: ___EmotionJSX(Link, {
label: ___EmotionJSX(ExternalLink, {
to: "".concat(navItem.link).concat(search)

@@ -87,0 +87,0 @@ }, navItem.title),

{
"name": "dumi-theme-nocobase",
"version": "0.2.27",
"version": "0.2.28",
"description": "",

@@ -5,0 +5,0 @@ "keywords": [

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc