@ahooks.js/dumi-theme-antd 0.1.3 → 0.1.4
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.
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { useEffect, useRef } from 'react';
|
|
2
|
+
var useAffixTop = function useAffixTop() {
|
|
3
|
+
var offsetTop = useRef(0);
|
|
4
|
+
useEffect(function () {
|
|
5
|
+
var main = document.getElementsByTagName('main')[0];
|
|
6
|
+
if (!main) {
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
offsetTop.current = main.getBoundingClientRect().top;
|
|
10
|
+
}, []);
|
|
11
|
+
|
|
12
|
+
// +1: prevent the page from jumping when scrolling
|
|
13
|
+
return offsetTop.current + 1;
|
|
14
|
+
};
|
|
15
|
+
export default useAffixTop;
|
|
@@ -13,12 +13,12 @@ import SiteContext from "dumi/theme/slots/SiteContext";
|
|
|
13
13
|
import "../../static/style";
|
|
14
14
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
15
15
|
var _ref = process.env.NODE_ENV === "production" ? {
|
|
16
|
-
name: "
|
|
17
|
-
styles: "display:flex;flex-direction:column"
|
|
16
|
+
name: "11pfcjj",
|
|
17
|
+
styles: "display:flex;flex-direction:column;min-height:100vh"
|
|
18
18
|
} : {
|
|
19
|
-
name: "
|
|
20
|
-
styles: "display:flex;flex-direction:column;label:layoutWrap;",
|
|
21
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
19
|
+
name: "rorlea-layoutWrap",
|
|
20
|
+
styles: "display:flex;flex-direction:column;min-height:100vh;label:layoutWrap;",
|
|
21
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlbUIiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgSGVsbWV0LCBPdXRsZXQsIHVzZUxvY2FsZSwgdXNlTG9jYXRpb24sIHVzZU91dGxldCwgdXNlUm91dGVNZXRhLCB1c2VTaXRlRGF0YSB9IGZyb20gJ2R1bWknO1xuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlQ29udGV4dCwgdXNlTWVtbywgdHlwZSBGQyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBjbGFzc05hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuaW1wb3J0IEdsb2JhbFN0eWxlcyBmcm9tICcuLi8uLi9jb21tb24vR2xvYmFsU3R5bGVzJztcbmltcG9ydCB1c2VMb2NhbGVWYWx1ZSBmcm9tICcuLi8uLi9ob29rcy91c2VMb2NhbGVWYWx1ZSc7XG5pbXBvcnQgRm9vdGVyIGZyb20gJy4uLy4uL3Nsb3RzL0Zvb3Rlcic7XG5pbXBvcnQgSGVhZGVyIGZyb20gJy4uLy4uL3Nsb3RzL0hlYWRlcic7XG5pbXBvcnQgSG9tZXBhZ2UgZnJvbSAnLi4vSG9tZVBhZ2VMYXlvdXQnO1xuaW1wb3J0IFNpZGViYXJMYXlvdXQgZnJvbSAnLi4vU2lkZWJhckxheW91dCc7XG5pbXBvcnQgU2l0ZUNvbnRleHQgZnJvbSAnLi4vLi4vc2xvdHMvU2l0ZUNvbnRleHQnO1xuaW1wb3J0ICcuLi8uLi9zdGF0aWMvc3R5bGUnO1xuXG5jb25zdCB1c2VTdHlsZXMgPSAoKSA9PiB7XG4gIHJldHVybiB7XG4gICAgbGF5b3V0V3JhcDogY3NzYFxuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICBtaW4taGVpZ2h0OiAxMDB2aDtcbiAgICBgXG4gIH07XG59O1xuXG5jb25zdCBEb2NMYXlvdXQ6IEZDID0gKCkgPT4ge1xuICBjb25zdCBvdXRsZXQgPSB1c2VPdXRsZXQoKTtcbiAgY29uc3QgbG9jYWxlID0gdXNlTG9jYWxlKCk7XG4gIGNvbnN0IGxvY2F0aW9uID0gdXNlTG9jYXRpb24oKTtcbiAgY29uc3Qgc3R5bGVzID0gdXNlU3R5bGVzKCk7XG4gIGNvbnN0IHJvdXRlTWV0YSA9IHVzZVJvdXRlTWV0YSgpO1xuICBjb25zdCB0aXRsZSA9IHVzZUxvY2FsZVZhbHVlKCd0aXRsZScpO1xuICBjb25zdCBkZXNjcmlwdGlvbiA9IHVzZUxvY2FsZVZhbHVlKCdkZXNjcmlwdGlvbicpO1xuICBjb25zdCB7IHBhdGhuYW1lLCBoYXNoIH0gPSBsb2NhdGlvbjtcbiAgY29uc3QgeyBsb2FkaW5nIH0gPSB1c2VTaXRlRGF0YSgpO1xuICBjb25zdCB7IGRpcmVjdGlvbiB9ID0gdXNlQ29udGV4dChTaXRlQ29udGV4dCk7XG5cbiAgY29uc3QgY29udGVudCA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIGlmIChcbiAgICAgIFsnJywgJy8nXS5zb21lKChwYXRoKSA9PiBwYXRoID09PSBwYXRobmFtZSkgfHxcbiAgICAgIFsnL2luZGV4J10uc29tZSgocGF0aCkgPT4gcGF0aG5hbWUuc3RhcnRzV2l0aChwYXRoKSlcbiAgICApIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxSZWFjdC5GcmFnbWVudD5cbiAgICAgICAgICB7b3V0bGV0ICYmIHJvdXRlTWV0YS50ZXh0cy5sZW5ndGggPT09IDAgPyBvdXRsZXQgOiA8SG9tZXBhZ2UgLz59XG4gICAgICAgICAgPEZvb3RlciAvPlxuICAgICAgICA8L1JlYWN0LkZyYWdtZW50PlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIHJvdXRlTWV0YS5mcm9udG1hdHRlcj8uc2lkZWJhciA9PT0gZmFsc2UgPyAoXG4gICAgICA8ZGl2PlxuICAgICAgICA8T3V0bGV0IC8+XG4gICAgICAgIDxGb290ZXIgLz5cbiAgICAgIDwvZGl2PlxuICAgICkgOiAoXG4gICAgICA8U2lkZWJhckxheW91dD5cbiAgICAgICAgPE91dGxldCAvPlxuICAgICAgPC9TaWRlYmFyTGF5b3V0PlxuICAgICk7XG4gIH0sIFtvdXRsZXQsIHBhdGhuYW1lLCByb3V0ZU1ldGFdKTtcblxuICAvLyBoYW5kbGUgaGFzaCBjaGFuZ2Ugb3IgdmlzaXQgcGFnZSBoYXNoIGZyb20gTGluayBjb21wb25lbnQsIGFuZCBqdW1wIGFmdGVyIGFzeW5jIGNodW5rIGxvYWRlZFxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGlkID0gaGFzaC5yZXBsYWNlKCcjJywgJycpO1xuICAgIGlmIChpZCkgZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoZGVjb2RlVVJJQ29tcG9uZW50KGlkKSk/LnNjcm9sbEludG9WaWV3KCk7XG4gIH0sIFtsb2FkaW5nLCBoYXNoXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17c3R5bGVzLmxheW91dFdyYXB9PlxuICAgICAgPEhlbG1ldCBlbmNvZGVTcGVjaWFsQ2hhcmFjdGVycz17ZmFsc2V9PlxuICAgICAgICA8aHRtbFxuICAgICAgICAgIGxhbmc9e2xvY2FsZS5pZH1cbiAgICAgICAgICBkYXRhLWRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lcyhbJ2R1bWktdGhlbWUtYW50ZC1yb290JywgeyBydGw6IGRpcmVjdGlvbiA9PT0gJ3J0bCcgfV0pfVxuICAgICAgICAvPlxuICAgICAgICA8dGl0bGU+e2Ake3RpdGxlIHx8ICdkdW1pLXRoZW1lLWFudGQnfSR7ZGVzY3JpcHRpb24gPyBgLSR7ZGVzY3JpcHRpb259YCA6ICcnfWB9PC90aXRsZT5cbiAgICAgICAgPGxpbmsgaHJlZj1cImh0dHBzOi8vYWhvb2tzLmpzLm9yZy9zaW1wbGUtbG9nby5zdmdcIiAvPlxuICAgICAgICA8bWV0YSBuYW1lPVwiZGVzY3JpcHRpb25cIiBjb250ZW50PXtkZXNjcmlwdGlvbn0gLz5cbiAgICAgICAgPG1ldGEgcHJvcGVydHk9XCJvZzp0aXRsZVwiIGNvbnRlbnQ9e3RpdGxlfSAvPlxuICAgICAgICA8bWV0YSBwcm9wZXJ0eT1cIm9nOnR5cGVcIiBjb250ZW50PVwid2Vic2l0ZVwiIC8+XG4gICAgICAgIDxtZXRhIHByb3BlcnR5PVwib2c6aW1hZ2VcIiBjb250ZW50PVwiaHR0cHM6Ly9haG9va3MuanMub3JnL3NpbXBsZS1sb2dvLnN2Z1wiIC8+XG4gICAgICA8L0hlbG1ldD5cbiAgICAgIDxHbG9iYWxTdHlsZXMgLz5cbiAgICAgIDxIZWFkZXIgLz5cbiAgICAgIHtjb250ZW50fVxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgRG9jTGF5b3V0O1xuIl19 */",
|
|
22
22
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
23
23
|
};
|
|
24
24
|
var useStyles = function useStyles() {
|
|
@@ -10,6 +10,7 @@ import { useMemo, useContext } from 'react';
|
|
|
10
10
|
import PrevAndNext from "../../common/PrevAndNext";
|
|
11
11
|
import LastUpdated from "../../common/LastUpdated";
|
|
12
12
|
import EditLink from "../../common/EditLink";
|
|
13
|
+
import useAffixTop from "../../hooks/useAffixTop";
|
|
13
14
|
import useSiteToken from "../../hooks/useSiteToken";
|
|
14
15
|
import Footer from "dumi/theme/slots/Footer";
|
|
15
16
|
import SiteContext from "dumi/theme/slots/SiteContext";
|
|
@@ -20,7 +21,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
20
21
|
} : {
|
|
21
22
|
name: "18ub4tx-colContent",
|
|
22
23
|
styles: "display:flex;flex-direction:column;label:colContent;",
|
|
23
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
24
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmGmB","file":"index.tsx","sourcesContent":["import { CalendarOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Anchor, Col, Space, Typography } from 'antd';\nimport classNames from 'classnames';\nimport DayJS from 'dayjs';\nimport { useRouteMeta, useTabMeta } from 'dumi';\nimport type { FC, ReactNode } from 'react';\nimport { useMemo, useContext } from 'react';\nimport PrevAndNext from '../../common/PrevAndNext';\nimport LastUpdated from '../../common/LastUpdated';\nimport EditLink from '../../common/EditLink';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport Footer from '../Footer';\nimport SiteContext from '../SiteContext';\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls } = token;\n\n  return {\n    contributorsList: css`\n      display: flex;\n      flex-wrap: wrap;\n      margin-top: 120px !important;\n\n      a,\n      ${antCls}-avatar + ${antCls}-avatar {\n        margin-bottom: 8px;\n        margin-inline-end: 8px;\n      }\n    `,\n    toc: css`\n      ${antCls}-anchor {\n        ${antCls}-anchor-link-title {\n          font-size: 12px;\n        }\n      }\n    `,\n    tocWrapper: css`\n      position: absolute;\n      top: 8px;\n      right: 0;\n      width: 160px;\n      margin: 12px 0;\n      padding: 8px 8px 8px 4px;\n      backdrop-filter: blur(8px);\n      border-radius: ${token.borderRadius}px;\n      box-sizing: border-box;\n\n      .toc-debug {\n        color: ${token['purple-6']};\n\n        &:hover {\n          color: ${token['purple-5']};\n        }\n      }\n\n      > div {\n        box-sizing: border-box;\n        width: 100%;\n        max-height: calc(100vh - 40px) !important;\n        margin: 0 auto;\n        overflow: auto;\n        padding-inline: 4px;\n      }\n\n      &.rtl {\n        right: auto;\n        left: 20px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        display: none;\n      }\n    `,\n    articleWrapper: css`\n      padding: 0 170px 32px 64px;\n      flex: 1;\n\n      &.rtl {\n        padding: 0 64px 144px 170px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        &,\n        &.rtl {\n          padding-right: 24px;\n          padding-left: 24px;\n        }\n      }\n    `,\n    bottomEditContent: css`\n      display: flex;\n      justify-content: space-between;\n      align-items: center;\n      padding-bottom: 12px;\n    `,\n    colContent: css`\n      display: flex;\n      flex-direction: column;\n    `\n  };\n};\n\ntype AnchorItem = {\n  id: string;\n  title: string;\n  children?: AnchorItem[];\n};\n\nconst Content: FC<{ children: ReactNode }> = ({ children }) => {\n  const meta = useRouteMeta();\n  const tab = useTabMeta();\n  const styles = useStyle();\n  const { token } = useSiteToken();\n  const { direction } = useContext(SiteContext);\n\n  const debugDemos = useMemo(\n    () => meta.toc?.filter((item) => item._debug_demo).map((item) => item.id) || [],\n    [meta]\n  );\n\n  const isShowTitle = useMemo(() => {\n    const title = meta.frontmatter?.title || meta.frontmatter.subtitle;\n    if (!title) return false;\n\n    // 避免 markdown 里有 h1 导致双标题\n    const firstToc = meta.toc[0];\n    if (firstToc && firstToc.depth === 1) return false;\n\n    return true;\n  }, [meta.frontmatter?.title, meta.frontmatter.subtitle, meta.toc]);\n\n  const anchorItems = useMemo(\n    () =>\n      (tab?.toc || meta.toc).reduce<AnchorItem[]>((result, item) => {\n        if (item.depth === 2) {\n          result.push({\n            ...item\n          });\n        } else if (item.depth === 3) {\n          const parent = result[result.length - 1];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push({\n              ...item\n            });\n          }\n        }\n        return result;\n      }, []),\n    [meta.toc, tab]\n  );\n\n  const isRTL = direction === 'rtl';\n  const affixTop = useAffixTop();\n\n  return (\n    <Col xxl={20} xl={19} lg={18} md={18} sm={24} xs={24} css={styles.colContent}>\n      {!!meta.frontmatter.toc && (\n        <Affix offsetTop={affixTop}>\n          <section css={styles.tocWrapper} className={classNames({ rtl: isRTL })}>\n            <Anchor\n              css={styles.toc}\n              affix={false}\n              targetOffset={token.marginXXL}\n              showInkInFixed\n              items={anchorItems.map((item) => ({\n                href: `#${item.id}`,\n                title: item.title,\n                key: item.id,\n                children: item.children\n                  ?.filter((child) => !debugDemos.includes(child.id))\n                  .map((child) => ({\n                    href: `#${child.id}`,\n                    title: (\n                      <span className={classNames(debugDemos.includes(child.id) && 'toc-debug')}>\n                        {child?.title}\n                      </span>\n                    ),\n                    key: child.id\n                  }))\n              }))}\n            />\n          </section>\n        </Affix>\n      )}\n\n      <article css={styles.articleWrapper} className={classNames({ rtl: isRTL })}>\n        {isShowTitle ? (\n          <Typography.Title\n            style={{\n              fontSize: 30\n            }}\n          >\n            {meta.frontmatter?.title}\n            {meta.frontmatter.subtitle && (\n              <span\n                style={{\n                  marginLeft: 12\n                }}\n              >\n                {meta.frontmatter.subtitle}\n              </span>\n            )}\n          </Typography.Title>\n        ) : null}\n\n        {/* 添加作者、时间等信息 */}\n        {meta.frontmatter.date || meta.frontmatter.author ? (\n          <Typography.Paragraph\n            style={{\n              opacity: 0.65\n            }}\n          >\n            <Space>\n              {meta.frontmatter.date && (\n                <span>\n                  <CalendarOutlined />\n                  {DayJS(meta.frontmatter.date).format('YYYY-MM-DD')}\n                </span>\n              )}\n              {meta.frontmatter.author &&\n                (meta.frontmatter.author as string)?.split(',')?.map((author) => (\n                  <Typography.Link\n                    href={`https://github.com/${author}`}\n                    key={author}\n                    target=\"_blank\"\n                  >\n                    {`@${author}`}\n                  </Typography.Link>\n                ))}\n            </Space>\n          </Typography.Paragraph>\n        ) : null}\n\n        {children}\n      </article>\n      <div\n        css={css`\n          ${styles.articleWrapper}\n          ${styles.bottomEditContent}\n        `}\n      >\n        <LastUpdated time={meta.frontmatter?.lastUpdated} />\n        <EditLink />\n      </div>\n      <PrevAndNext rtl={isRTL} />\n      <Footer />\n    </Col>\n  );\n};\n\nexport default Content;\n"]} */",
|
|
24
25
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
25
26
|
};
|
|
26
27
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
@@ -29,7 +30,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
29
30
|
} : {
|
|
30
31
|
name: "c4gwd4-bottomEditContent",
|
|
31
32
|
styles: "display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;label:bottomEditContent;",
|
|
32
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
33
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA6F0B","file":"index.tsx","sourcesContent":["import { CalendarOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Anchor, Col, Space, Typography } from 'antd';\nimport classNames from 'classnames';\nimport DayJS from 'dayjs';\nimport { useRouteMeta, useTabMeta } from 'dumi';\nimport type { FC, ReactNode } from 'react';\nimport { useMemo, useContext } from 'react';\nimport PrevAndNext from '../../common/PrevAndNext';\nimport LastUpdated from '../../common/LastUpdated';\nimport EditLink from '../../common/EditLink';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport Footer from '../Footer';\nimport SiteContext from '../SiteContext';\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls } = token;\n\n  return {\n    contributorsList: css`\n      display: flex;\n      flex-wrap: wrap;\n      margin-top: 120px !important;\n\n      a,\n      ${antCls}-avatar + ${antCls}-avatar {\n        margin-bottom: 8px;\n        margin-inline-end: 8px;\n      }\n    `,\n    toc: css`\n      ${antCls}-anchor {\n        ${antCls}-anchor-link-title {\n          font-size: 12px;\n        }\n      }\n    `,\n    tocWrapper: css`\n      position: absolute;\n      top: 8px;\n      right: 0;\n      width: 160px;\n      margin: 12px 0;\n      padding: 8px 8px 8px 4px;\n      backdrop-filter: blur(8px);\n      border-radius: ${token.borderRadius}px;\n      box-sizing: border-box;\n\n      .toc-debug {\n        color: ${token['purple-6']};\n\n        &:hover {\n          color: ${token['purple-5']};\n        }\n      }\n\n      > div {\n        box-sizing: border-box;\n        width: 100%;\n        max-height: calc(100vh - 40px) !important;\n        margin: 0 auto;\n        overflow: auto;\n        padding-inline: 4px;\n      }\n\n      &.rtl {\n        right: auto;\n        left: 20px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        display: none;\n      }\n    `,\n    articleWrapper: css`\n      padding: 0 170px 32px 64px;\n      flex: 1;\n\n      &.rtl {\n        padding: 0 64px 144px 170px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        &,\n        &.rtl {\n          padding-right: 24px;\n          padding-left: 24px;\n        }\n      }\n    `,\n    bottomEditContent: css`\n      display: flex;\n      justify-content: space-between;\n      align-items: center;\n      padding-bottom: 12px;\n    `,\n    colContent: css`\n      display: flex;\n      flex-direction: column;\n    `\n  };\n};\n\ntype AnchorItem = {\n  id: string;\n  title: string;\n  children?: AnchorItem[];\n};\n\nconst Content: FC<{ children: ReactNode }> = ({ children }) => {\n  const meta = useRouteMeta();\n  const tab = useTabMeta();\n  const styles = useStyle();\n  const { token } = useSiteToken();\n  const { direction } = useContext(SiteContext);\n\n  const debugDemos = useMemo(\n    () => meta.toc?.filter((item) => item._debug_demo).map((item) => item.id) || [],\n    [meta]\n  );\n\n  const isShowTitle = useMemo(() => {\n    const title = meta.frontmatter?.title || meta.frontmatter.subtitle;\n    if (!title) return false;\n\n    // 避免 markdown 里有 h1 导致双标题\n    const firstToc = meta.toc[0];\n    if (firstToc && firstToc.depth === 1) return false;\n\n    return true;\n  }, [meta.frontmatter?.title, meta.frontmatter.subtitle, meta.toc]);\n\n  const anchorItems = useMemo(\n    () =>\n      (tab?.toc || meta.toc).reduce<AnchorItem[]>((result, item) => {\n        if (item.depth === 2) {\n          result.push({\n            ...item\n          });\n        } else if (item.depth === 3) {\n          const parent = result[result.length - 1];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push({\n              ...item\n            });\n          }\n        }\n        return result;\n      }, []),\n    [meta.toc, tab]\n  );\n\n  const isRTL = direction === 'rtl';\n  const affixTop = useAffixTop();\n\n  return (\n    <Col xxl={20} xl={19} lg={18} md={18} sm={24} xs={24} css={styles.colContent}>\n      {!!meta.frontmatter.toc && (\n        <Affix offsetTop={affixTop}>\n          <section css={styles.tocWrapper} className={classNames({ rtl: isRTL })}>\n            <Anchor\n              css={styles.toc}\n              affix={false}\n              targetOffset={token.marginXXL}\n              showInkInFixed\n              items={anchorItems.map((item) => ({\n                href: `#${item.id}`,\n                title: item.title,\n                key: item.id,\n                children: item.children\n                  ?.filter((child) => !debugDemos.includes(child.id))\n                  .map((child) => ({\n                    href: `#${child.id}`,\n                    title: (\n                      <span className={classNames(debugDemos.includes(child.id) && 'toc-debug')}>\n                        {child?.title}\n                      </span>\n                    ),\n                    key: child.id\n                  }))\n              }))}\n            />\n          </section>\n        </Affix>\n      )}\n\n      <article css={styles.articleWrapper} className={classNames({ rtl: isRTL })}>\n        {isShowTitle ? (\n          <Typography.Title\n            style={{\n              fontSize: 30\n            }}\n          >\n            {meta.frontmatter?.title}\n            {meta.frontmatter.subtitle && (\n              <span\n                style={{\n                  marginLeft: 12\n                }}\n              >\n                {meta.frontmatter.subtitle}\n              </span>\n            )}\n          </Typography.Title>\n        ) : null}\n\n        {/* 添加作者、时间等信息 */}\n        {meta.frontmatter.date || meta.frontmatter.author ? (\n          <Typography.Paragraph\n            style={{\n              opacity: 0.65\n            }}\n          >\n            <Space>\n              {meta.frontmatter.date && (\n                <span>\n                  <CalendarOutlined />\n                  {DayJS(meta.frontmatter.date).format('YYYY-MM-DD')}\n                </span>\n              )}\n              {meta.frontmatter.author &&\n                (meta.frontmatter.author as string)?.split(',')?.map((author) => (\n                  <Typography.Link\n                    href={`https://github.com/${author}`}\n                    key={author}\n                    target=\"_blank\"\n                  >\n                    {`@${author}`}\n                  </Typography.Link>\n                ))}\n            </Space>\n          </Typography.Paragraph>\n        ) : null}\n\n        {children}\n      </article>\n      <div\n        css={css`\n          ${styles.articleWrapper}\n          ${styles.bottomEditContent}\n        `}\n      >\n        <LastUpdated time={meta.frontmatter?.lastUpdated} />\n        <EditLink />\n      </div>\n      <PrevAndNext rtl={isRTL} />\n      <Footer />\n    </Col>\n  );\n};\n\nexport default Content;\n"]} */",
|
|
33
34
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
34
35
|
};
|
|
35
36
|
var useStyle = function useStyle() {
|
|
@@ -37,10 +38,10 @@ var useStyle = function useStyle() {
|
|
|
37
38
|
token = _useSiteToken.token;
|
|
38
39
|
var antCls = token.antCls;
|
|
39
40
|
return {
|
|
40
|
-
contributorsList: /*#__PURE__*/css("display:flex;flex-wrap:wrap;margin-top:120px!important;a,", antCls, "-avatar+", antCls, "-avatar{margin-bottom:8px;margin-inline-end:8px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:contributorsList;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41
|
-
toc: /*#__PURE__*/css(antCls, "-anchor{", antCls, "-anchor-link-title{font-size:12px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:toc;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42
|
-
tocWrapper: /*#__PURE__*/css("position:absolute;top:8px;right:0;width:160px;margin:12px 0;padding:8px 8px 8px 4px;backdrop-filter:blur(8px);border-radius:", token.borderRadius, "px;box-sizing:border-box;.toc-debug{color:", token['purple-6'], ";&:hover{color:", token['purple-5'], ";}}>div{box-sizing:border-box;width:100%;max-height:calc(100vh - 40px)!important;margin:0 auto;overflow:auto;padding-inline:4px;}&.rtl{right:auto;left:20px;}@media only screen and (max-width: ", token.screenLG, "px){display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:tocWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuCmB","file":"index.tsx","sourcesContent":["import { CalendarOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Anchor, Col, Space, Typography } from 'antd';\nimport classNames from 'classnames';\nimport DayJS from 'dayjs';\nimport { useRouteMeta, useTabMeta } from 'dumi';\nimport type { FC, ReactNode } from 'react';\nimport { useMemo, useContext } from 'react';\nimport PrevAndNext from '../../common/PrevAndNext';\nimport LastUpdated from '../../common/LastUpdated';\nimport EditLink from '../../common/EditLink';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport Footer from '../Footer';\nimport SiteContext from '../SiteContext';\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls } = token;\n\n  return {\n    contributorsList: css`\n      display: flex;\n      flex-wrap: wrap;\n      margin-top: 120px !important;\n\n      a,\n      ${antCls}-avatar + ${antCls}-avatar {\n        margin-bottom: 8px;\n        margin-inline-end: 8px;\n      }\n    `,\n    toc: css`\n      ${antCls}-anchor {\n        ${antCls}-anchor-link-title {\n          font-size: 12px;\n        }\n      }\n    `,\n    tocWrapper: css`\n      position: absolute;\n      top: 8px;\n      right: 0;\n      width: 160px;\n      margin: 12px 0;\n      padding: 8px 8px 8px 4px;\n      backdrop-filter: blur(8px);\n      border-radius: ${token.borderRadius}px;\n      box-sizing: border-box;\n\n      .toc-debug {\n        color: ${token['purple-6']};\n\n        &:hover {\n          color: ${token['purple-5']};\n        }\n      }\n\n      > div {\n        box-sizing: border-box;\n        width: 100%;\n        max-height: calc(100vh - 40px) !important;\n        margin: 0 auto;\n        overflow: auto;\n        padding-inline: 4px;\n      }\n\n      &.rtl {\n        right: auto;\n        left: 20px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        display: none;\n      }\n    `,\n    articleWrapper: css`\n      padding: 0 170px 32px 64px;\n      flex: 1;\n\n      &.rtl {\n        padding: 0 64px 144px 170px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        &,\n        &.rtl {\n          padding-right: 24px;\n          padding-left: 24px;\n        }\n      }\n    `,\n    bottomEditContent: css`\n      display: flex;\n      justify-content: space-between;\n      align-items: center;\n      padding-bottom: 12px;\n    `,\n    colContent: css`\n      display: flex;\n      flex-direction: column;\n    `\n  };\n};\n\ntype AnchorItem = {\n  id: string;\n  title: string;\n  children?: AnchorItem[];\n};\n\nconst Content: FC<{ children: ReactNode }> = ({ children }) => {\n  const meta = useRouteMeta();\n  const tab = useTabMeta();\n  const styles = useStyle();\n  const { token } = useSiteToken();\n  const { direction } = useContext(SiteContext);\n\n  const debugDemos = useMemo(\n    () => meta.toc?.filter((item) => item._debug_demo).map((item) => item.id) || [],\n    [meta]\n  );\n\n  const isShowTitle = useMemo(() => {\n    const title = meta.frontmatter?.title || meta.frontmatter.subtitle;\n    if (!title) return false;\n\n    // 避免 markdown 里有 h1 导致双标题\n    const firstToc = meta.toc[0];\n    if (firstToc && firstToc.depth === 1) return false;\n\n    return true;\n  }, [meta.frontmatter?.title, meta.frontmatter.subtitle, meta.toc]);\n\n  const anchorItems = useMemo(\n    () =>\n      (tab?.toc || meta.toc).reduce<AnchorItem[]>((result, item) => {\n        if (item.depth === 2) {\n          result.push({\n            ...item\n          });\n        } else if (item.depth === 3) {\n          const parent = result[result.length - 1];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push({\n              ...item\n            });\n          }\n        }\n        return result;\n      }, []),\n    [meta.toc, tab]\n  );\n\n  const isRTL = direction === 'rtl';\n\n  return (\n    <Col xxl={20} xl={19} lg={18} md={18} sm={24} xs={24} css={styles.colContent}>\n      {!!meta.frontmatter.toc && (\n        <Affix>\n          <section css={styles.tocWrapper} className={classNames({ rtl: isRTL })}>\n            <Anchor\n              css={styles.toc}\n              affix={false}\n              targetOffset={token.marginXXL}\n              showInkInFixed\n              items={anchorItems.map((item) => ({\n                href: `#${item.id}`,\n                title: item.title,\n                key: item.id,\n                children: item.children\n                  ?.filter((child) => !debugDemos.includes(child.id))\n                  .map((child) => ({\n                    href: `#${child.id}`,\n                    title: (\n                      <span className={classNames(debugDemos.includes(child.id) && 'toc-debug')}>\n                        {child?.title}\n                      </span>\n                    ),\n                    key: child.id\n                  }))\n              }))}\n            />\n          </section>\n        </Affix>\n      )}\n\n      <article css={styles.articleWrapper} className={classNames({ rtl: isRTL })}>\n        {isShowTitle ? (\n          <Typography.Title\n            style={{\n              fontSize: 30\n            }}\n          >\n            {meta.frontmatter?.title}\n            {meta.frontmatter.subtitle && (\n              <span\n                style={{\n                  marginLeft: 12\n                }}\n              >\n                {meta.frontmatter.subtitle}\n              </span>\n            )}\n          </Typography.Title>\n        ) : null}\n\n        {/* 添加作者、时间等信息 */}\n        {meta.frontmatter.date || meta.frontmatter.author ? (\n          <Typography.Paragraph\n            style={{\n              opacity: 0.65\n            }}\n          >\n            <Space>\n              {meta.frontmatter.date && (\n                <span>\n                  <CalendarOutlined />\n                  {DayJS(meta.frontmatter.date).format('YYYY-MM-DD')}\n                </span>\n              )}\n              {meta.frontmatter.author &&\n                (meta.frontmatter.author as string)?.split(',')?.map((author) => (\n                  <Typography.Link\n                    href={`https://github.com/${author}`}\n                    key={author}\n                    target=\"_blank\"\n                  >\n                    {`@${author}`}\n                  </Typography.Link>\n                ))}\n            </Space>\n          </Typography.Paragraph>\n        ) : null}\n\n        {children}\n      </article>\n      <div\n        css={css`\n          ${styles.articleWrapper}\n          ${styles.bottomEditContent}\n        `}\n      >\n        <LastUpdated time={meta.frontmatter?.lastUpdated} />\n        <EditLink />\n      </div>\n      <PrevAndNext rtl={isRTL} />\n      <Footer />\n    </Col>\n  );\n};\n\nexport default Content;\n"]} */"),
|
|
43
|
-
articleWrapper: /*#__PURE__*/css("padding:0 170px 32px 64px;flex:1;&.rtl{padding:0 64px 144px 170px;}@media only screen and (max-width: ", token.screenLG, "px){&,&.rtl{padding-right:24px;padding-left:24px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:articleWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41
|
+
contributorsList: /*#__PURE__*/css("display:flex;flex-wrap:wrap;margin-top:120px!important;a,", antCls, "-avatar+", antCls, "-avatar{margin-bottom:8px;margin-inline-end:8px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:contributorsList;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAsByB","file":"index.tsx","sourcesContent":["import { CalendarOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Anchor, Col, Space, Typography } from 'antd';\nimport classNames from 'classnames';\nimport DayJS from 'dayjs';\nimport { useRouteMeta, useTabMeta } from 'dumi';\nimport type { FC, ReactNode } from 'react';\nimport { useMemo, useContext } from 'react';\nimport PrevAndNext from '../../common/PrevAndNext';\nimport LastUpdated from '../../common/LastUpdated';\nimport EditLink from '../../common/EditLink';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport Footer from '../Footer';\nimport SiteContext from '../SiteContext';\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls } = token;\n\n  return {\n    contributorsList: css`\n      display: flex;\n      flex-wrap: wrap;\n      margin-top: 120px !important;\n\n      a,\n      ${antCls}-avatar + ${antCls}-avatar {\n        margin-bottom: 8px;\n        margin-inline-end: 8px;\n      }\n    `,\n    toc: css`\n      ${antCls}-anchor {\n        ${antCls}-anchor-link-title {\n          font-size: 12px;\n        }\n      }\n    `,\n    tocWrapper: css`\n      position: absolute;\n      top: 8px;\n      right: 0;\n      width: 160px;\n      margin: 12px 0;\n      padding: 8px 8px 8px 4px;\n      backdrop-filter: blur(8px);\n      border-radius: ${token.borderRadius}px;\n      box-sizing: border-box;\n\n      .toc-debug {\n        color: ${token['purple-6']};\n\n        &:hover {\n          color: ${token['purple-5']};\n        }\n      }\n\n      > div {\n        box-sizing: border-box;\n        width: 100%;\n        max-height: calc(100vh - 40px) !important;\n        margin: 0 auto;\n        overflow: auto;\n        padding-inline: 4px;\n      }\n\n      &.rtl {\n        right: auto;\n        left: 20px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        display: none;\n      }\n    `,\n    articleWrapper: css`\n      padding: 0 170px 32px 64px;\n      flex: 1;\n\n      &.rtl {\n        padding: 0 64px 144px 170px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        &,\n        &.rtl {\n          padding-right: 24px;\n          padding-left: 24px;\n        }\n      }\n    `,\n    bottomEditContent: css`\n      display: flex;\n      justify-content: space-between;\n      align-items: center;\n      padding-bottom: 12px;\n    `,\n    colContent: css`\n      display: flex;\n      flex-direction: column;\n    `\n  };\n};\n\ntype AnchorItem = {\n  id: string;\n  title: string;\n  children?: AnchorItem[];\n};\n\nconst Content: FC<{ children: ReactNode }> = ({ children }) => {\n  const meta = useRouteMeta();\n  const tab = useTabMeta();\n  const styles = useStyle();\n  const { token } = useSiteToken();\n  const { direction } = useContext(SiteContext);\n\n  const debugDemos = useMemo(\n    () => meta.toc?.filter((item) => item._debug_demo).map((item) => item.id) || [],\n    [meta]\n  );\n\n  const isShowTitle = useMemo(() => {\n    const title = meta.frontmatter?.title || meta.frontmatter.subtitle;\n    if (!title) return false;\n\n    // 避免 markdown 里有 h1 导致双标题\n    const firstToc = meta.toc[0];\n    if (firstToc && firstToc.depth === 1) return false;\n\n    return true;\n  }, [meta.frontmatter?.title, meta.frontmatter.subtitle, meta.toc]);\n\n  const anchorItems = useMemo(\n    () =>\n      (tab?.toc || meta.toc).reduce<AnchorItem[]>((result, item) => {\n        if (item.depth === 2) {\n          result.push({\n            ...item\n          });\n        } else if (item.depth === 3) {\n          const parent = result[result.length - 1];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push({\n              ...item\n            });\n          }\n        }\n        return result;\n      }, []),\n    [meta.toc, tab]\n  );\n\n  const isRTL = direction === 'rtl';\n  const affixTop = useAffixTop();\n\n  return (\n    <Col xxl={20} xl={19} lg={18} md={18} sm={24} xs={24} css={styles.colContent}>\n      {!!meta.frontmatter.toc && (\n        <Affix offsetTop={affixTop}>\n          <section css={styles.tocWrapper} className={classNames({ rtl: isRTL })}>\n            <Anchor\n              css={styles.toc}\n              affix={false}\n              targetOffset={token.marginXXL}\n              showInkInFixed\n              items={anchorItems.map((item) => ({\n                href: `#${item.id}`,\n                title: item.title,\n                key: item.id,\n                children: item.children\n                  ?.filter((child) => !debugDemos.includes(child.id))\n                  .map((child) => ({\n                    href: `#${child.id}`,\n                    title: (\n                      <span className={classNames(debugDemos.includes(child.id) && 'toc-debug')}>\n                        {child?.title}\n                      </span>\n                    ),\n                    key: child.id\n                  }))\n              }))}\n            />\n          </section>\n        </Affix>\n      )}\n\n      <article css={styles.articleWrapper} className={classNames({ rtl: isRTL })}>\n        {isShowTitle ? (\n          <Typography.Title\n            style={{\n              fontSize: 30\n            }}\n          >\n            {meta.frontmatter?.title}\n            {meta.frontmatter.subtitle && (\n              <span\n                style={{\n                  marginLeft: 12\n                }}\n              >\n                {meta.frontmatter.subtitle}\n              </span>\n            )}\n          </Typography.Title>\n        ) : null}\n\n        {/* 添加作者、时间等信息 */}\n        {meta.frontmatter.date || meta.frontmatter.author ? (\n          <Typography.Paragraph\n            style={{\n              opacity: 0.65\n            }}\n          >\n            <Space>\n              {meta.frontmatter.date && (\n                <span>\n                  <CalendarOutlined />\n                  {DayJS(meta.frontmatter.date).format('YYYY-MM-DD')}\n                </span>\n              )}\n              {meta.frontmatter.author &&\n                (meta.frontmatter.author as string)?.split(',')?.map((author) => (\n                  <Typography.Link\n                    href={`https://github.com/${author}`}\n                    key={author}\n                    target=\"_blank\"\n                  >\n                    {`@${author}`}\n                  </Typography.Link>\n                ))}\n            </Space>\n          </Typography.Paragraph>\n        ) : null}\n\n        {children}\n      </article>\n      <div\n        css={css`\n          ${styles.articleWrapper}\n          ${styles.bottomEditContent}\n        `}\n      >\n        <LastUpdated time={meta.frontmatter?.lastUpdated} />\n        <EditLink />\n      </div>\n      <PrevAndNext rtl={isRTL} />\n      <Footer />\n    </Col>\n  );\n};\n\nexport default Content;\n"]} */"),
|
|
42
|
+
toc: /*#__PURE__*/css(antCls, "-anchor{", antCls, "-anchor-link-title{font-size:12px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:toc;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiCY","file":"index.tsx","sourcesContent":["import { CalendarOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Anchor, Col, Space, Typography } from 'antd';\nimport classNames from 'classnames';\nimport DayJS from 'dayjs';\nimport { useRouteMeta, useTabMeta } from 'dumi';\nimport type { FC, ReactNode } from 'react';\nimport { useMemo, useContext } from 'react';\nimport PrevAndNext from '../../common/PrevAndNext';\nimport LastUpdated from '../../common/LastUpdated';\nimport EditLink from '../../common/EditLink';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport Footer from '../Footer';\nimport SiteContext from '../SiteContext';\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls } = token;\n\n  return {\n    contributorsList: css`\n      display: flex;\n      flex-wrap: wrap;\n      margin-top: 120px !important;\n\n      a,\n      ${antCls}-avatar + ${antCls}-avatar {\n        margin-bottom: 8px;\n        margin-inline-end: 8px;\n      }\n    `,\n    toc: css`\n      ${antCls}-anchor {\n        ${antCls}-anchor-link-title {\n          font-size: 12px;\n        }\n      }\n    `,\n    tocWrapper: css`\n      position: absolute;\n      top: 8px;\n      right: 0;\n      width: 160px;\n      margin: 12px 0;\n      padding: 8px 8px 8px 4px;\n      backdrop-filter: blur(8px);\n      border-radius: ${token.borderRadius}px;\n      box-sizing: border-box;\n\n      .toc-debug {\n        color: ${token['purple-6']};\n\n        &:hover {\n          color: ${token['purple-5']};\n        }\n      }\n\n      > div {\n        box-sizing: border-box;\n        width: 100%;\n        max-height: calc(100vh - 40px) !important;\n        margin: 0 auto;\n        overflow: auto;\n        padding-inline: 4px;\n      }\n\n      &.rtl {\n        right: auto;\n        left: 20px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        display: none;\n      }\n    `,\n    articleWrapper: css`\n      padding: 0 170px 32px 64px;\n      flex: 1;\n\n      &.rtl {\n        padding: 0 64px 144px 170px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        &,\n        &.rtl {\n          padding-right: 24px;\n          padding-left: 24px;\n        }\n      }\n    `,\n    bottomEditContent: css`\n      display: flex;\n      justify-content: space-between;\n      align-items: center;\n      padding-bottom: 12px;\n    `,\n    colContent: css`\n      display: flex;\n      flex-direction: column;\n    `\n  };\n};\n\ntype AnchorItem = {\n  id: string;\n  title: string;\n  children?: AnchorItem[];\n};\n\nconst Content: FC<{ children: ReactNode }> = ({ children }) => {\n  const meta = useRouteMeta();\n  const tab = useTabMeta();\n  const styles = useStyle();\n  const { token } = useSiteToken();\n  const { direction } = useContext(SiteContext);\n\n  const debugDemos = useMemo(\n    () => meta.toc?.filter((item) => item._debug_demo).map((item) => item.id) || [],\n    [meta]\n  );\n\n  const isShowTitle = useMemo(() => {\n    const title = meta.frontmatter?.title || meta.frontmatter.subtitle;\n    if (!title) return false;\n\n    // 避免 markdown 里有 h1 导致双标题\n    const firstToc = meta.toc[0];\n    if (firstToc && firstToc.depth === 1) return false;\n\n    return true;\n  }, [meta.frontmatter?.title, meta.frontmatter.subtitle, meta.toc]);\n\n  const anchorItems = useMemo(\n    () =>\n      (tab?.toc || meta.toc).reduce<AnchorItem[]>((result, item) => {\n        if (item.depth === 2) {\n          result.push({\n            ...item\n          });\n        } else if (item.depth === 3) {\n          const parent = result[result.length - 1];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push({\n              ...item\n            });\n          }\n        }\n        return result;\n      }, []),\n    [meta.toc, tab]\n  );\n\n  const isRTL = direction === 'rtl';\n  const affixTop = useAffixTop();\n\n  return (\n    <Col xxl={20} xl={19} lg={18} md={18} sm={24} xs={24} css={styles.colContent}>\n      {!!meta.frontmatter.toc && (\n        <Affix offsetTop={affixTop}>\n          <section css={styles.tocWrapper} className={classNames({ rtl: isRTL })}>\n            <Anchor\n              css={styles.toc}\n              affix={false}\n              targetOffset={token.marginXXL}\n              showInkInFixed\n              items={anchorItems.map((item) => ({\n                href: `#${item.id}`,\n                title: item.title,\n                key: item.id,\n                children: item.children\n                  ?.filter((child) => !debugDemos.includes(child.id))\n                  .map((child) => ({\n                    href: `#${child.id}`,\n                    title: (\n                      <span className={classNames(debugDemos.includes(child.id) && 'toc-debug')}>\n                        {child?.title}\n                      </span>\n                    ),\n                    key: child.id\n                  }))\n              }))}\n            />\n          </section>\n        </Affix>\n      )}\n\n      <article css={styles.articleWrapper} className={classNames({ rtl: isRTL })}>\n        {isShowTitle ? (\n          <Typography.Title\n            style={{\n              fontSize: 30\n            }}\n          >\n            {meta.frontmatter?.title}\n            {meta.frontmatter.subtitle && (\n              <span\n                style={{\n                  marginLeft: 12\n                }}\n              >\n                {meta.frontmatter.subtitle}\n              </span>\n            )}\n          </Typography.Title>\n        ) : null}\n\n        {/* 添加作者、时间等信息 */}\n        {meta.frontmatter.date || meta.frontmatter.author ? (\n          <Typography.Paragraph\n            style={{\n              opacity: 0.65\n            }}\n          >\n            <Space>\n              {meta.frontmatter.date && (\n                <span>\n                  <CalendarOutlined />\n                  {DayJS(meta.frontmatter.date).format('YYYY-MM-DD')}\n                </span>\n              )}\n              {meta.frontmatter.author &&\n                (meta.frontmatter.author as string)?.split(',')?.map((author) => (\n                  <Typography.Link\n                    href={`https://github.com/${author}`}\n                    key={author}\n                    target=\"_blank\"\n                  >\n                    {`@${author}`}\n                  </Typography.Link>\n                ))}\n            </Space>\n          </Typography.Paragraph>\n        ) : null}\n\n        {children}\n      </article>\n      <div\n        css={css`\n          ${styles.articleWrapper}\n          ${styles.bottomEditContent}\n        `}\n      >\n        <LastUpdated time={meta.frontmatter?.lastUpdated} />\n        <EditLink />\n      </div>\n      <PrevAndNext rtl={isRTL} />\n      <Footer />\n    </Col>\n  );\n};\n\nexport default Content;\n"]} */"),
|
|
43
|
+
tocWrapper: /*#__PURE__*/css("position:absolute;top:8px;right:0;width:160px;margin:12px 0;padding:8px 8px 8px 4px;backdrop-filter:blur(8px);border-radius:", token.borderRadius, "px;box-sizing:border-box;.toc-debug{color:", token['purple-6'], ";&:hover{color:", token['purple-5'], ";}}>div{box-sizing:border-box;width:100%;max-height:calc(100vh - 40px)!important;margin:0 auto;overflow:auto;padding-inline:4px;}&.rtl{right:auto;left:20px;}@media only screen and (max-width: ", token.screenLG, "px){display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:tocWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAwCmB","file":"index.tsx","sourcesContent":["import { CalendarOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Anchor, Col, Space, Typography } from 'antd';\nimport classNames from 'classnames';\nimport DayJS from 'dayjs';\nimport { useRouteMeta, useTabMeta } from 'dumi';\nimport type { FC, ReactNode } from 'react';\nimport { useMemo, useContext } from 'react';\nimport PrevAndNext from '../../common/PrevAndNext';\nimport LastUpdated from '../../common/LastUpdated';\nimport EditLink from '../../common/EditLink';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport Footer from '../Footer';\nimport SiteContext from '../SiteContext';\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls } = token;\n\n  return {\n    contributorsList: css`\n      display: flex;\n      flex-wrap: wrap;\n      margin-top: 120px !important;\n\n      a,\n      ${antCls}-avatar + ${antCls}-avatar {\n        margin-bottom: 8px;\n        margin-inline-end: 8px;\n      }\n    `,\n    toc: css`\n      ${antCls}-anchor {\n        ${antCls}-anchor-link-title {\n          font-size: 12px;\n        }\n      }\n    `,\n    tocWrapper: css`\n      position: absolute;\n      top: 8px;\n      right: 0;\n      width: 160px;\n      margin: 12px 0;\n      padding: 8px 8px 8px 4px;\n      backdrop-filter: blur(8px);\n      border-radius: ${token.borderRadius}px;\n      box-sizing: border-box;\n\n      .toc-debug {\n        color: ${token['purple-6']};\n\n        &:hover {\n          color: ${token['purple-5']};\n        }\n      }\n\n      > div {\n        box-sizing: border-box;\n        width: 100%;\n        max-height: calc(100vh - 40px) !important;\n        margin: 0 auto;\n        overflow: auto;\n        padding-inline: 4px;\n      }\n\n      &.rtl {\n        right: auto;\n        left: 20px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        display: none;\n      }\n    `,\n    articleWrapper: css`\n      padding: 0 170px 32px 64px;\n      flex: 1;\n\n      &.rtl {\n        padding: 0 64px 144px 170px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        &,\n        &.rtl {\n          padding-right: 24px;\n          padding-left: 24px;\n        }\n      }\n    `,\n    bottomEditContent: css`\n      display: flex;\n      justify-content: space-between;\n      align-items: center;\n      padding-bottom: 12px;\n    `,\n    colContent: css`\n      display: flex;\n      flex-direction: column;\n    `\n  };\n};\n\ntype AnchorItem = {\n  id: string;\n  title: string;\n  children?: AnchorItem[];\n};\n\nconst Content: FC<{ children: ReactNode }> = ({ children }) => {\n  const meta = useRouteMeta();\n  const tab = useTabMeta();\n  const styles = useStyle();\n  const { token } = useSiteToken();\n  const { direction } = useContext(SiteContext);\n\n  const debugDemos = useMemo(\n    () => meta.toc?.filter((item) => item._debug_demo).map((item) => item.id) || [],\n    [meta]\n  );\n\n  const isShowTitle = useMemo(() => {\n    const title = meta.frontmatter?.title || meta.frontmatter.subtitle;\n    if (!title) return false;\n\n    // 避免 markdown 里有 h1 导致双标题\n    const firstToc = meta.toc[0];\n    if (firstToc && firstToc.depth === 1) return false;\n\n    return true;\n  }, [meta.frontmatter?.title, meta.frontmatter.subtitle, meta.toc]);\n\n  const anchorItems = useMemo(\n    () =>\n      (tab?.toc || meta.toc).reduce<AnchorItem[]>((result, item) => {\n        if (item.depth === 2) {\n          result.push({\n            ...item\n          });\n        } else if (item.depth === 3) {\n          const parent = result[result.length - 1];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push({\n              ...item\n            });\n          }\n        }\n        return result;\n      }, []),\n    [meta.toc, tab]\n  );\n\n  const isRTL = direction === 'rtl';\n  const affixTop = useAffixTop();\n\n  return (\n    <Col xxl={20} xl={19} lg={18} md={18} sm={24} xs={24} css={styles.colContent}>\n      {!!meta.frontmatter.toc && (\n        <Affix offsetTop={affixTop}>\n          <section css={styles.tocWrapper} className={classNames({ rtl: isRTL })}>\n            <Anchor\n              css={styles.toc}\n              affix={false}\n              targetOffset={token.marginXXL}\n              showInkInFixed\n              items={anchorItems.map((item) => ({\n                href: `#${item.id}`,\n                title: item.title,\n                key: item.id,\n                children: item.children\n                  ?.filter((child) => !debugDemos.includes(child.id))\n                  .map((child) => ({\n                    href: `#${child.id}`,\n                    title: (\n                      <span className={classNames(debugDemos.includes(child.id) && 'toc-debug')}>\n                        {child?.title}\n                      </span>\n                    ),\n                    key: child.id\n                  }))\n              }))}\n            />\n          </section>\n        </Affix>\n      )}\n\n      <article css={styles.articleWrapper} className={classNames({ rtl: isRTL })}>\n        {isShowTitle ? (\n          <Typography.Title\n            style={{\n              fontSize: 30\n            }}\n          >\n            {meta.frontmatter?.title}\n            {meta.frontmatter.subtitle && (\n              <span\n                style={{\n                  marginLeft: 12\n                }}\n              >\n                {meta.frontmatter.subtitle}\n              </span>\n            )}\n          </Typography.Title>\n        ) : null}\n\n        {/* 添加作者、时间等信息 */}\n        {meta.frontmatter.date || meta.frontmatter.author ? (\n          <Typography.Paragraph\n            style={{\n              opacity: 0.65\n            }}\n          >\n            <Space>\n              {meta.frontmatter.date && (\n                <span>\n                  <CalendarOutlined />\n                  {DayJS(meta.frontmatter.date).format('YYYY-MM-DD')}\n                </span>\n              )}\n              {meta.frontmatter.author &&\n                (meta.frontmatter.author as string)?.split(',')?.map((author) => (\n                  <Typography.Link\n                    href={`https://github.com/${author}`}\n                    key={author}\n                    target=\"_blank\"\n                  >\n                    {`@${author}`}\n                  </Typography.Link>\n                ))}\n            </Space>\n          </Typography.Paragraph>\n        ) : null}\n\n        {children}\n      </article>\n      <div\n        css={css`\n          ${styles.articleWrapper}\n          ${styles.bottomEditContent}\n        `}\n      >\n        <LastUpdated time={meta.frontmatter?.lastUpdated} />\n        <EditLink />\n      </div>\n      <PrevAndNext rtl={isRTL} />\n      <Footer />\n    </Col>\n  );\n};\n\nexport default Content;\n"]} */"),
|
|
44
|
+
articleWrapper: /*#__PURE__*/css("padding:0 170px 32px 64px;flex:1;&.rtl{padding:0 64px 144px 170px;}@media only screen and (max-width: ", token.screenLG, "px){&,&.rtl{padding-right:24px;padding-left:24px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:articleWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA6EuB","file":"index.tsx","sourcesContent":["import { CalendarOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Anchor, Col, Space, Typography } from 'antd';\nimport classNames from 'classnames';\nimport DayJS from 'dayjs';\nimport { useRouteMeta, useTabMeta } from 'dumi';\nimport type { FC, ReactNode } from 'react';\nimport { useMemo, useContext } from 'react';\nimport PrevAndNext from '../../common/PrevAndNext';\nimport LastUpdated from '../../common/LastUpdated';\nimport EditLink from '../../common/EditLink';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport Footer from '../Footer';\nimport SiteContext from '../SiteContext';\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls } = token;\n\n  return {\n    contributorsList: css`\n      display: flex;\n      flex-wrap: wrap;\n      margin-top: 120px !important;\n\n      a,\n      ${antCls}-avatar + ${antCls}-avatar {\n        margin-bottom: 8px;\n        margin-inline-end: 8px;\n      }\n    `,\n    toc: css`\n      ${antCls}-anchor {\n        ${antCls}-anchor-link-title {\n          font-size: 12px;\n        }\n      }\n    `,\n    tocWrapper: css`\n      position: absolute;\n      top: 8px;\n      right: 0;\n      width: 160px;\n      margin: 12px 0;\n      padding: 8px 8px 8px 4px;\n      backdrop-filter: blur(8px);\n      border-radius: ${token.borderRadius}px;\n      box-sizing: border-box;\n\n      .toc-debug {\n        color: ${token['purple-6']};\n\n        &:hover {\n          color: ${token['purple-5']};\n        }\n      }\n\n      > div {\n        box-sizing: border-box;\n        width: 100%;\n        max-height: calc(100vh - 40px) !important;\n        margin: 0 auto;\n        overflow: auto;\n        padding-inline: 4px;\n      }\n\n      &.rtl {\n        right: auto;\n        left: 20px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        display: none;\n      }\n    `,\n    articleWrapper: css`\n      padding: 0 170px 32px 64px;\n      flex: 1;\n\n      &.rtl {\n        padding: 0 64px 144px 170px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        &,\n        &.rtl {\n          padding-right: 24px;\n          padding-left: 24px;\n        }\n      }\n    `,\n    bottomEditContent: css`\n      display: flex;\n      justify-content: space-between;\n      align-items: center;\n      padding-bottom: 12px;\n    `,\n    colContent: css`\n      display: flex;\n      flex-direction: column;\n    `\n  };\n};\n\ntype AnchorItem = {\n  id: string;\n  title: string;\n  children?: AnchorItem[];\n};\n\nconst Content: FC<{ children: ReactNode }> = ({ children }) => {\n  const meta = useRouteMeta();\n  const tab = useTabMeta();\n  const styles = useStyle();\n  const { token } = useSiteToken();\n  const { direction } = useContext(SiteContext);\n\n  const debugDemos = useMemo(\n    () => meta.toc?.filter((item) => item._debug_demo).map((item) => item.id) || [],\n    [meta]\n  );\n\n  const isShowTitle = useMemo(() => {\n    const title = meta.frontmatter?.title || meta.frontmatter.subtitle;\n    if (!title) return false;\n\n    // 避免 markdown 里有 h1 导致双标题\n    const firstToc = meta.toc[0];\n    if (firstToc && firstToc.depth === 1) return false;\n\n    return true;\n  }, [meta.frontmatter?.title, meta.frontmatter.subtitle, meta.toc]);\n\n  const anchorItems = useMemo(\n    () =>\n      (tab?.toc || meta.toc).reduce<AnchorItem[]>((result, item) => {\n        if (item.depth === 2) {\n          result.push({\n            ...item\n          });\n        } else if (item.depth === 3) {\n          const parent = result[result.length - 1];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push({\n              ...item\n            });\n          }\n        }\n        return result;\n      }, []),\n    [meta.toc, tab]\n  );\n\n  const isRTL = direction === 'rtl';\n  const affixTop = useAffixTop();\n\n  return (\n    <Col xxl={20} xl={19} lg={18} md={18} sm={24} xs={24} css={styles.colContent}>\n      {!!meta.frontmatter.toc && (\n        <Affix offsetTop={affixTop}>\n          <section css={styles.tocWrapper} className={classNames({ rtl: isRTL })}>\n            <Anchor\n              css={styles.toc}\n              affix={false}\n              targetOffset={token.marginXXL}\n              showInkInFixed\n              items={anchorItems.map((item) => ({\n                href: `#${item.id}`,\n                title: item.title,\n                key: item.id,\n                children: item.children\n                  ?.filter((child) => !debugDemos.includes(child.id))\n                  .map((child) => ({\n                    href: `#${child.id}`,\n                    title: (\n                      <span className={classNames(debugDemos.includes(child.id) && 'toc-debug')}>\n                        {child?.title}\n                      </span>\n                    ),\n                    key: child.id\n                  }))\n              }))}\n            />\n          </section>\n        </Affix>\n      )}\n\n      <article css={styles.articleWrapper} className={classNames({ rtl: isRTL })}>\n        {isShowTitle ? (\n          <Typography.Title\n            style={{\n              fontSize: 30\n            }}\n          >\n            {meta.frontmatter?.title}\n            {meta.frontmatter.subtitle && (\n              <span\n                style={{\n                  marginLeft: 12\n                }}\n              >\n                {meta.frontmatter.subtitle}\n              </span>\n            )}\n          </Typography.Title>\n        ) : null}\n\n        {/* 添加作者、时间等信息 */}\n        {meta.frontmatter.date || meta.frontmatter.author ? (\n          <Typography.Paragraph\n            style={{\n              opacity: 0.65\n            }}\n          >\n            <Space>\n              {meta.frontmatter.date && (\n                <span>\n                  <CalendarOutlined />\n                  {DayJS(meta.frontmatter.date).format('YYYY-MM-DD')}\n                </span>\n              )}\n              {meta.frontmatter.author &&\n                (meta.frontmatter.author as string)?.split(',')?.map((author) => (\n                  <Typography.Link\n                    href={`https://github.com/${author}`}\n                    key={author}\n                    target=\"_blank\"\n                  >\n                    {`@${author}`}\n                  </Typography.Link>\n                ))}\n            </Space>\n          </Typography.Paragraph>\n        ) : null}\n\n        {children}\n      </article>\n      <div\n        css={css`\n          ${styles.articleWrapper}\n          ${styles.bottomEditContent}\n        `}\n      >\n        <LastUpdated time={meta.frontmatter?.lastUpdated} />\n        <EditLink />\n      </div>\n      <PrevAndNext rtl={isRTL} />\n      <Footer />\n    </Col>\n  );\n};\n\nexport default Content;\n"]} */"),
|
|
44
45
|
bottomEditContent: _ref2,
|
|
45
46
|
colContent: _ref
|
|
46
47
|
};
|
|
@@ -88,6 +89,7 @@ var Content = function Content(_ref3) {
|
|
|
88
89
|
}, []);
|
|
89
90
|
}, [meta.toc, tab]);
|
|
90
91
|
var isRTL = direction === 'rtl';
|
|
92
|
+
var affixTop = useAffixTop();
|
|
91
93
|
return ___EmotionJSX(Col, {
|
|
92
94
|
xxl: 20,
|
|
93
95
|
xl: 19,
|
|
@@ -96,7 +98,9 @@ var Content = function Content(_ref3) {
|
|
|
96
98
|
sm: 24,
|
|
97
99
|
xs: 24,
|
|
98
100
|
css: styles.colContent
|
|
99
|
-
}, !!meta.frontmatter.toc && ___EmotionJSX(Affix,
|
|
101
|
+
}, !!meta.frontmatter.toc && ___EmotionJSX(Affix, {
|
|
102
|
+
offsetTop: affixTop
|
|
103
|
+
}, ___EmotionJSX("section", {
|
|
100
104
|
css: styles.tocWrapper,
|
|
101
105
|
className: classNames({
|
|
102
106
|
rtl: isRTL
|
|
@@ -149,7 +153,7 @@ var Content = function Content(_ref3) {
|
|
|
149
153
|
target: "_blank"
|
|
150
154
|
}, "@".concat(author));
|
|
151
155
|
})))) : null, children), ___EmotionJSX("div", {
|
|
152
|
-
css: /*#__PURE__*/css(styles.articleWrapper, " ", styles.bottomEditContent, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Content;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
156
|
+
css: /*#__PURE__*/css(styles.articleWrapper, " ", styles.bottomEditContent, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Content;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiPgB","file":"index.tsx","sourcesContent":["import { CalendarOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Affix, Anchor, Col, Space, Typography } from 'antd';\nimport classNames from 'classnames';\nimport DayJS from 'dayjs';\nimport { useRouteMeta, useTabMeta } from 'dumi';\nimport type { FC, ReactNode } from 'react';\nimport { useMemo, useContext } from 'react';\nimport PrevAndNext from '../../common/PrevAndNext';\nimport LastUpdated from '../../common/LastUpdated';\nimport EditLink from '../../common/EditLink';\nimport useAffixTop from '../../hooks/useAffixTop';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport Footer from '../Footer';\nimport SiteContext from '../SiteContext';\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls } = token;\n\n  return {\n    contributorsList: css`\n      display: flex;\n      flex-wrap: wrap;\n      margin-top: 120px !important;\n\n      a,\n      ${antCls}-avatar + ${antCls}-avatar {\n        margin-bottom: 8px;\n        margin-inline-end: 8px;\n      }\n    `,\n    toc: css`\n      ${antCls}-anchor {\n        ${antCls}-anchor-link-title {\n          font-size: 12px;\n        }\n      }\n    `,\n    tocWrapper: css`\n      position: absolute;\n      top: 8px;\n      right: 0;\n      width: 160px;\n      margin: 12px 0;\n      padding: 8px 8px 8px 4px;\n      backdrop-filter: blur(8px);\n      border-radius: ${token.borderRadius}px;\n      box-sizing: border-box;\n\n      .toc-debug {\n        color: ${token['purple-6']};\n\n        &:hover {\n          color: ${token['purple-5']};\n        }\n      }\n\n      > div {\n        box-sizing: border-box;\n        width: 100%;\n        max-height: calc(100vh - 40px) !important;\n        margin: 0 auto;\n        overflow: auto;\n        padding-inline: 4px;\n      }\n\n      &.rtl {\n        right: auto;\n        left: 20px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        display: none;\n      }\n    `,\n    articleWrapper: css`\n      padding: 0 170px 32px 64px;\n      flex: 1;\n\n      &.rtl {\n        padding: 0 64px 144px 170px;\n      }\n\n      @media only screen and (max-width: ${token.screenLG}px) {\n        &,\n        &.rtl {\n          padding-right: 24px;\n          padding-left: 24px;\n        }\n      }\n    `,\n    bottomEditContent: css`\n      display: flex;\n      justify-content: space-between;\n      align-items: center;\n      padding-bottom: 12px;\n    `,\n    colContent: css`\n      display: flex;\n      flex-direction: column;\n    `\n  };\n};\n\ntype AnchorItem = {\n  id: string;\n  title: string;\n  children?: AnchorItem[];\n};\n\nconst Content: FC<{ children: ReactNode }> = ({ children }) => {\n  const meta = useRouteMeta();\n  const tab = useTabMeta();\n  const styles = useStyle();\n  const { token } = useSiteToken();\n  const { direction } = useContext(SiteContext);\n\n  const debugDemos = useMemo(\n    () => meta.toc?.filter((item) => item._debug_demo).map((item) => item.id) || [],\n    [meta]\n  );\n\n  const isShowTitle = useMemo(() => {\n    const title = meta.frontmatter?.title || meta.frontmatter.subtitle;\n    if (!title) return false;\n\n    // 避免 markdown 里有 h1 导致双标题\n    const firstToc = meta.toc[0];\n    if (firstToc && firstToc.depth === 1) return false;\n\n    return true;\n  }, [meta.frontmatter?.title, meta.frontmatter.subtitle, meta.toc]);\n\n  const anchorItems = useMemo(\n    () =>\n      (tab?.toc || meta.toc).reduce<AnchorItem[]>((result, item) => {\n        if (item.depth === 2) {\n          result.push({\n            ...item\n          });\n        } else if (item.depth === 3) {\n          const parent = result[result.length - 1];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push({\n              ...item\n            });\n          }\n        }\n        return result;\n      }, []),\n    [meta.toc, tab]\n  );\n\n  const isRTL = direction === 'rtl';\n  const affixTop = useAffixTop();\n\n  return (\n    <Col xxl={20} xl={19} lg={18} md={18} sm={24} xs={24} css={styles.colContent}>\n      {!!meta.frontmatter.toc && (\n        <Affix offsetTop={affixTop}>\n          <section css={styles.tocWrapper} className={classNames({ rtl: isRTL })}>\n            <Anchor\n              css={styles.toc}\n              affix={false}\n              targetOffset={token.marginXXL}\n              showInkInFixed\n              items={anchorItems.map((item) => ({\n                href: `#${item.id}`,\n                title: item.title,\n                key: item.id,\n                children: item.children\n                  ?.filter((child) => !debugDemos.includes(child.id))\n                  .map((child) => ({\n                    href: `#${child.id}`,\n                    title: (\n                      <span className={classNames(debugDemos.includes(child.id) && 'toc-debug')}>\n                        {child?.title}\n                      </span>\n                    ),\n                    key: child.id\n                  }))\n              }))}\n            />\n          </section>\n        </Affix>\n      )}\n\n      <article css={styles.articleWrapper} className={classNames({ rtl: isRTL })}>\n        {isShowTitle ? (\n          <Typography.Title\n            style={{\n              fontSize: 30\n            }}\n          >\n            {meta.frontmatter?.title}\n            {meta.frontmatter.subtitle && (\n              <span\n                style={{\n                  marginLeft: 12\n                }}\n              >\n                {meta.frontmatter.subtitle}\n              </span>\n            )}\n          </Typography.Title>\n        ) : null}\n\n        {/* 添加作者、时间等信息 */}\n        {meta.frontmatter.date || meta.frontmatter.author ? (\n          <Typography.Paragraph\n            style={{\n              opacity: 0.65\n            }}\n          >\n            <Space>\n              {meta.frontmatter.date && (\n                <span>\n                  <CalendarOutlined />\n                  {DayJS(meta.frontmatter.date).format('YYYY-MM-DD')}\n                </span>\n              )}\n              {meta.frontmatter.author &&\n                (meta.frontmatter.author as string)?.split(',')?.map((author) => (\n                  <Typography.Link\n                    href={`https://github.com/${author}`}\n                    key={author}\n                    target=\"_blank\"\n                  >\n                    {`@${author}`}\n                  </Typography.Link>\n                ))}\n            </Space>\n          </Typography.Paragraph>\n        ) : null}\n\n        {children}\n      </article>\n      <div\n        css={css`\n          ${styles.articleWrapper}\n          ${styles.bottomEditContent}\n        `}\n      >\n        <LastUpdated time={meta.frontmatter?.lastUpdated} />\n        <EditLink />\n      </div>\n      <PrevAndNext rtl={isRTL} />\n      <Footer />\n    </Col>\n  );\n};\n\nexport default Content;\n"]} */")
|
|
153
157
|
}, ___EmotionJSX(LastUpdated, {
|
|
154
158
|
time: (_meta$frontmatter4 = meta.frontmatter) === null || _meta$frontmatter4 === void 0 ? void 0 : _meta$frontmatter4.lastUpdated
|
|
155
159
|
}), ___EmotionJSX(EditLink, null)), ___EmotionJSX(PrevAndNext, {
|
|
@@ -16,8 +16,8 @@ var useStyle = function useStyle() {
|
|
|
16
16
|
isMobile = _useContext.isMobile;
|
|
17
17
|
var background = new TinyColor(getAlphaColor('#f0f3fa', '#fff')).onBackground(token.colorBgContainer).toHexString();
|
|
18
18
|
return {
|
|
19
|
-
holder: /*#__PURE__*/css("background:", background, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:holder;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQmUiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGlueUNvbG9yIH0gZnJvbSAnQGN0cmwvdGlueWNvbG9yJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBSY0Zvb3RlciBmcm9tICdyYy1mb290ZXInO1xuaW1wb3J0IGNsb25lRGVlcCBmcm9tICdsb2Rhc2guY2xvbmVkZWVwJztcbmltcG9ydCBnZXRBbHBoYUNvbG9yIGZyb20gJ2FudGQvbGliL3RoZW1lL3V0aWwvZ2V0QWxwaGFDb2xvcic7XG5pbXBvcnQgeyB1c2VDb250ZXh0LCB1c2VDYWxsYmFjayB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHR5cGUgRkMgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdHlwZSB7IEZvb3RlckNvbHVtbiB9IGZyb20gJ3JjLWZvb3Rlci9saWIvY29sdW1uJztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCB1c2VMb2NhbGVWYWx1ZSBmcm9tICcuLi8uLi9ob29rcy91c2VMb2NhbGVWYWx1ZSc7XG5pbXBvcnQgU2l0ZUNvbnRleHQgZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuaW1wb3J0IHR5cGUgeyBTaXRlQ29udGV4dFByb3BzIH0gZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIGNvbnN0IGZvb3RlckxpbmtzID0gdXNlTG9jYWxlVmFsdWUoJ2Zvb3RlckxpbmtzJyk7XG4gIGNvbnN0IHsgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQ8U2l0ZUNvbnRleHRQcm9wcz4oU2l0ZUNvbnRleHQpO1xuICBjb25zdCBiYWNrZ3JvdW5kID0gbmV3IFRpbnlDb2xvcihnZXRBbHBoYUNvbG9yKCcjZjBmM2ZhJywgJyNmZmYnKSlcbiAgICAub25CYWNrZ3JvdW5kKHRva2VuLmNvbG9yQmdDb250YWluZXIpXG4gICAgLnRvSGV4U3RyaW5nKCk7XG5cbiAgcmV0dXJuIHtcbiAgICBob2xkZXI6IGNzc2BcbiAgICAgIGJhY2tncm91bmQ6ICR7YmFja2dyb3VuZH07XG4gICAgYCxcblxuICAgIGZvb3RlcjogY3NzYFxuICAgICAgYmFja2dyb3VuZDogJHtiYWNrZ3JvdW5kfTtcbiAgICAgIGNvbG9yOiAke3Rva2VuLmNvbG9yVGV4dFNlY29uZGFyeX07XG4gICAgICBib3gtc2hhZG93OiBpbnNldCAwIDEwNnB4IDM2cHggLTExNnB4IHJnYmEoMCwgMCwgMCwgMC4xNCk7XG5cbiAgICAgICoge1xuICAgICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgfVxuXG4gICAgICBoMixcbiAgICAgIGEge1xuICAgICAgICBjb2xvcjogJHt0b2tlbi5jb2xvclRleHR9O1xuICAgICAgfVxuXG4gICAgICAucmMtZm9vdGVyLWNvbHVtbiB7XG4gICAgICAgIG1hcmdpbi1ib3R0b206ICR7aXNNb2JpbGUgPyA2MCA6IDB9cHg7XG4gICAgICAgIDpsYXN0LWNoaWxkIHtcbiAgICAgICAgICBtYXJnaW4tYm90dG9tOiAke2lzTW9iaWxlID8gMjAgOiAwfXB4O1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItaXRlbS1pY29uIHtcbiAgICAgICAgdG9wOiAtMS41cHg7XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItY29udGFpbmVyIHtcbiAgICAgICAgZGlzcGxheTogJHtBcnJheS5pc0FycmF5KGZvb3RlckxpbmtzKSAmJiBmb290ZXJMaW5rcy5sZW5ndGggPiAwID8gJ2Jsb2NrJyA6ICdub25lJ307XG4gICAgICAgIG1heC13aWR0aDogMTIwOHB4O1xuICAgICAgICBtYXJnaW4taW5saW5lOiBhdXRvO1xuICAgICAgICBwYWRkaW5nLWlubGluZTogJHt0b2tlbi5tYXJnaW5YWEx9cHg7XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItYm90dG9tIHtcbiAgICAgICAgYm94LXNoYWRvdzogaW5zZXQgMCAxMDZweCAzNnB4IC0xMTZweCByZ2JhKDAsIDAsIDAsIDAuMTQpO1xuICAgICAgICAucmMtZm9vdGVyLWJvdHRvbS1jb250YWluZXIge1xuICAgICAgICAgIGZvbnQtc2l6ZTogJHt0b2tlbi5mb250U2l6ZX1weDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IEZvb3RlcjogRkMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlID0gdXNlU3R5bGUoKTtcbiAgY29uc3QgZm9vdGVyID0gdXNlTG9jYWxlVmFsdWUoJ2Zvb3RlcicpO1xuICBjb25zdCBmb290ZXJMaW5rcyA9IHVzZUxvY2FsZVZhbHVlKCdmb290ZXJMaW5rcycpO1xuXG4gIGNvbnN0IGdldEZvb3RlckxpbmtzID0gdXNlQ2FsbGJhY2soKGxpbmtzOiBGb290ZXJDb2x1bW5bXSkgPT4ge1xuICAgIGlmIChBcnJheS5pc0FycmF5KGxpbmtzKSkge1xuICAgICAgbGlua3MuZm9yRWFjaCgoaXRlbSkgPT4ge1xuICAgICAgICBjb25zdCBpY29uVXJsID0gaXRlbS5pY29uO1xuICAgICAgICBpZiAoaXRlbS5pY29uKSB7XG4gICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXBhcmFtLXJlYXNzaWduXG4gICAgICAgICAgZGVsZXRlIGl0ZW0uaWNvbjtcbiAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcGFyYW0tcmVhc3NpZ25cbiAgICAgICAgICBpdGVtLmljb24gPSA8aW1nIHNyYz17U3RyaW5nKGljb25VcmwpfSBhbHQ9XCJcIiBzdHlsZT17eyBtYXhXaWR0aDogJzEwMCUnIH19IC8+
|
|
20
|
-
footer: /*#__PURE__*/css("background:", background, ";color:", token.colorTextSecondary, ";box-shadow:inset 0 106px 36px -116px rgba(0, 0, 0, 0.14);*{box-sizing:border-box;}h2,a{color:", token.colorText, ";}.rc-footer-column{margin-bottom:", isMobile ? 60 : 0, "px;:last-child{margin-bottom:", isMobile ? 20 : 0, "px;}}.rc-footer-item-icon{top:-1.5px;}.rc-footer-container{display:", Array.isArray(footerLinks) && footerLinks.length > 0 ? 'block' : 'none', ";max-width:1208px;margin-inline:auto;padding-inline:", token.marginXXL, "px;}.rc-footer-bottom{box-shadow:inset 0 106px 36px -116px rgba(0, 0, 0, 0.14);.rc-footer-bottom-container{font-size:", token.fontSize, "px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:footer;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQmUiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGlueUNvbG9yIH0gZnJvbSAnQGN0cmwvdGlueWNvbG9yJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBSY0Zvb3RlciBmcm9tICdyYy1mb290ZXInO1xuaW1wb3J0IGNsb25lRGVlcCBmcm9tICdsb2Rhc2guY2xvbmVkZWVwJztcbmltcG9ydCBnZXRBbHBoYUNvbG9yIGZyb20gJ2FudGQvbGliL3RoZW1lL3V0aWwvZ2V0QWxwaGFDb2xvcic7XG5pbXBvcnQgeyB1c2VDb250ZXh0LCB1c2VDYWxsYmFjayB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHR5cGUgRkMgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdHlwZSB7IEZvb3RlckNvbHVtbiB9IGZyb20gJ3JjLWZvb3Rlci9saWIvY29sdW1uJztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCB1c2VMb2NhbGVWYWx1ZSBmcm9tICcuLi8uLi9ob29rcy91c2VMb2NhbGVWYWx1ZSc7XG5pbXBvcnQgU2l0ZUNvbnRleHQgZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuaW1wb3J0IHR5cGUgeyBTaXRlQ29udGV4dFByb3BzIH0gZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIGNvbnN0IGZvb3RlckxpbmtzID0gdXNlTG9jYWxlVmFsdWUoJ2Zvb3RlckxpbmtzJyk7XG4gIGNvbnN0IHsgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQ8U2l0ZUNvbnRleHRQcm9wcz4oU2l0ZUNvbnRleHQpO1xuICBjb25zdCBiYWNrZ3JvdW5kID0gbmV3IFRpbnlDb2xvcihnZXRBbHBoYUNvbG9yKCcjZjBmM2ZhJywgJyNmZmYnKSlcbiAgICAub25CYWNrZ3JvdW5kKHRva2VuLmNvbG9yQmdDb250YWluZXIpXG4gICAgLnRvSGV4U3RyaW5nKCk7XG5cbiAgcmV0dXJuIHtcbiAgICBob2xkZXI6IGNzc2BcbiAgICAgIGJhY2tncm91bmQ6ICR7YmFja2dyb3VuZH07XG4gICAgYCxcblxuICAgIGZvb3RlcjogY3NzYFxuICAgICAgYmFja2dyb3VuZDogJHtiYWNrZ3JvdW5kfTtcbiAgICAgIGNvbG9yOiAke3Rva2VuLmNvbG9yVGV4dFNlY29uZGFyeX07XG4gICAgICBib3gtc2hhZG93OiBpbnNldCAwIDEwNnB4IDM2cHggLTExNnB4IHJnYmEoMCwgMCwgMCwgMC4xNCk7XG5cbiAgICAgICoge1xuICAgICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgfVxuXG4gICAgICBoMixcbiAgICAgIGEge1xuICAgICAgICBjb2xvcjogJHt0b2tlbi5jb2xvclRleHR9O1xuICAgICAgfVxuXG4gICAgICAucmMtZm9vdGVyLWNvbHVtbiB7XG4gICAgICAgIG1hcmdpbi1ib3R0b206ICR7aXNNb2JpbGUgPyA2MCA6IDB9cHg7XG4gICAgICAgIDpsYXN0LWNoaWxkIHtcbiAgICAgICAgICBtYXJnaW4tYm90dG9tOiAke2lzTW9iaWxlID8gMjAgOiAwfXB4O1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItaXRlbS1pY29uIHtcbiAgICAgICAgdG9wOiAtMS41cHg7XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItY29udGFpbmVyIHtcbiAgICAgICAgZGlzcGxheTogJHtBcnJheS5pc0FycmF5KGZvb3RlckxpbmtzKSAmJiBmb290ZXJMaW5rcy5sZW5ndGggPiAwID8gJ2Jsb2NrJyA6ICdub25lJ307XG4gICAgICAgIG1heC13aWR0aDogMTIwOHB4O1xuICAgICAgICBtYXJnaW4taW5saW5lOiBhdXRvO1xuICAgICAgICBwYWRkaW5nLWlubGluZTogJHt0b2tlbi5tYXJnaW5YWEx9cHg7XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItYm90dG9tIHtcbiAgICAgICAgYm94LXNoYWRvdzogaW5zZXQgMCAxMDZweCAzNnB4IC0xMTZweCByZ2JhKDAsIDAsIDAsIDAuMTQpO1xuICAgICAgICAucmMtZm9vdGVyLWJvdHRvbS1jb250YWluZXIge1xuICAgICAgICAgIGZvbnQtc2l6ZTogJHt0b2tlbi5mb250U2l6ZX1weDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IEZvb3RlcjogRkMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlID0gdXNlU3R5bGUoKTtcbiAgY29uc3QgZm9vdGVyID0gdXNlTG9jYWxlVmFsdWUoJ2Zvb3RlcicpO1xuICBjb25zdCBmb290ZXJMaW5rcyA9IHVzZUxvY2FsZVZhbHVlKCdmb290ZXJMaW5rcycpO1xuXG4gIGNvbnN0IGdldEZvb3RlckxpbmtzID0gdXNlQ2FsbGJhY2soKGxpbmtzOiBGb290ZXJDb2x1bW5bXSkgPT4ge1xuICAgIGlmIChBcnJheS5pc0FycmF5KGxpbmtzKSkge1xuICAgICAgbGlua3MuZm9yRWFjaCgoaXRlbSkgPT4ge1xuICAgICAgICBjb25zdCBpY29uVXJsID0gaXRlbS5pY29uO1xuICAgICAgICBpZiAoaXRlbS5pY29uKSB7XG4gICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXBhcmFtLXJlYXNzaWduXG4gICAgICAgICAgZGVsZXRlIGl0ZW0uaWNvbjtcbiAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcGFyYW0tcmVhc3NpZ25cbiAgICAgICAgICBpdGVtLmljb24gPSA8aW1nIHNyYz17U3RyaW5nKGljb25VcmwpfSBhbHQ9XCJcIiBzdHlsZT17eyBtYXhXaWR0aDogJzEwMCUnIH19IC8+
|
|
19
|
+
holder: /*#__PURE__*/css("background:", background, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:holder;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQmUiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGlueUNvbG9yIH0gZnJvbSAnQGN0cmwvdGlueWNvbG9yJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBSY0Zvb3RlciBmcm9tICdyYy1mb290ZXInO1xuaW1wb3J0IGNsb25lRGVlcCBmcm9tICdsb2Rhc2guY2xvbmVkZWVwJztcbmltcG9ydCBnZXRBbHBoYUNvbG9yIGZyb20gJ2FudGQvbGliL3RoZW1lL3V0aWwvZ2V0QWxwaGFDb2xvcic7XG5pbXBvcnQgeyB1c2VDb250ZXh0LCB1c2VDYWxsYmFjayB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHR5cGUgRkMgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdHlwZSB7IEZvb3RlckNvbHVtbiB9IGZyb20gJ3JjLWZvb3Rlci9saWIvY29sdW1uJztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCB1c2VMb2NhbGVWYWx1ZSBmcm9tICcuLi8uLi9ob29rcy91c2VMb2NhbGVWYWx1ZSc7XG5pbXBvcnQgU2l0ZUNvbnRleHQgZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuaW1wb3J0IHR5cGUgeyBTaXRlQ29udGV4dFByb3BzIH0gZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIGNvbnN0IGZvb3RlckxpbmtzID0gdXNlTG9jYWxlVmFsdWUoJ2Zvb3RlckxpbmtzJyk7XG4gIGNvbnN0IHsgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQ8U2l0ZUNvbnRleHRQcm9wcz4oU2l0ZUNvbnRleHQpO1xuICBjb25zdCBiYWNrZ3JvdW5kID0gbmV3IFRpbnlDb2xvcihnZXRBbHBoYUNvbG9yKCcjZjBmM2ZhJywgJyNmZmYnKSlcbiAgICAub25CYWNrZ3JvdW5kKHRva2VuLmNvbG9yQmdDb250YWluZXIpXG4gICAgLnRvSGV4U3RyaW5nKCk7XG5cbiAgcmV0dXJuIHtcbiAgICBob2xkZXI6IGNzc2BcbiAgICAgIGJhY2tncm91bmQ6ICR7YmFja2dyb3VuZH07XG4gICAgYCxcblxuICAgIGZvb3RlcjogY3NzYFxuICAgICAgYmFja2dyb3VuZDogJHtiYWNrZ3JvdW5kfTtcbiAgICAgIGNvbG9yOiAke3Rva2VuLmNvbG9yVGV4dFNlY29uZGFyeX07XG4gICAgICBib3gtc2hhZG93OiBpbnNldCAwIDEwNnB4IDM2cHggLTExNnB4IHJnYmEoMCwgMCwgMCwgMC4xNCk7XG5cbiAgICAgICoge1xuICAgICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgfVxuXG4gICAgICBoMixcbiAgICAgIGEge1xuICAgICAgICBjb2xvcjogJHt0b2tlbi5jb2xvclRleHR9O1xuICAgICAgfVxuXG4gICAgICAucmMtZm9vdGVyLWNvbHVtbiB7XG4gICAgICAgIG1hcmdpbi1ib3R0b206ICR7aXNNb2JpbGUgPyA2MCA6IDB9cHg7XG4gICAgICAgIDpsYXN0LWNoaWxkIHtcbiAgICAgICAgICBtYXJnaW4tYm90dG9tOiAke2lzTW9iaWxlID8gMjAgOiAwfXB4O1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItaXRlbS1pY29uIHtcbiAgICAgICAgdG9wOiAtMS41cHg7XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItY29udGFpbmVyIHtcbiAgICAgICAgZGlzcGxheTogJHtBcnJheS5pc0FycmF5KGZvb3RlckxpbmtzKSAmJiBmb290ZXJMaW5rcy5sZW5ndGggPiAwID8gJ2Jsb2NrJyA6ICdub25lJ307XG4gICAgICAgIG1heC13aWR0aDogMTIwOHB4O1xuICAgICAgICBtYXJnaW4taW5saW5lOiBhdXRvO1xuICAgICAgICBwYWRkaW5nLWlubGluZTogJHt0b2tlbi5tYXJnaW5YWEx9cHg7XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItYm90dG9tIHtcbiAgICAgICAgYm94LXNoYWRvdzogaW5zZXQgMCAxMDZweCAzNnB4IC0xMTZweCByZ2JhKDAsIDAsIDAsIDAuMTQpO1xuICAgICAgICAucmMtZm9vdGVyLWJvdHRvbS1jb250YWluZXIge1xuICAgICAgICAgIGZvbnQtc2l6ZTogJHt0b2tlbi5mb250U2l6ZX1weDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IEZvb3RlcjogRkMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlID0gdXNlU3R5bGUoKTtcbiAgY29uc3QgZm9vdGVyID0gdXNlTG9jYWxlVmFsdWUoJ2Zvb3RlcicpO1xuICBjb25zdCBmb290ZXJMaW5rcyA9IHVzZUxvY2FsZVZhbHVlKCdmb290ZXJMaW5rcycpO1xuXG4gIGNvbnN0IGdldEZvb3RlckxpbmtzID0gdXNlQ2FsbGJhY2soKGxpbmtzOiBGb290ZXJDb2x1bW5bXSkgPT4ge1xuICAgIGlmIChBcnJheS5pc0FycmF5KGxpbmtzKSkge1xuICAgICAgbGlua3MuZm9yRWFjaCgoaXRlbSkgPT4ge1xuICAgICAgICBjb25zdCBpY29uVXJsID0gaXRlbS5pY29uO1xuICAgICAgICBpZiAoaXRlbS5pY29uKSB7XG4gICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXBhcmFtLXJlYXNzaWduXG4gICAgICAgICAgZGVsZXRlIGl0ZW0uaWNvbjtcbiAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcGFyYW0tcmVhc3NpZ25cbiAgICAgICAgICBpdGVtLmljb24gPSA8aW1nIHNyYz17U3RyaW5nKGljb25VcmwpfSBhbHQ9XCJcIiBzdHlsZT17eyBtYXhXaWR0aDogJzEwMCUnIH19IC8+O1xuICAgICAgICB9XG4gICAgICAgIGlmIChBcnJheS5pc0FycmF5KGl0ZW0uaXRlbXMpKSB7XG4gICAgICAgICAgZ2V0Rm9vdGVyTGlua3MoaXRlbS5pdGVtcyk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cbiAgICByZXR1cm4gbGlua3M7XG4gIH0sIFtdKTtcblxuICBpZiAoIWZvb3RlcikgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICA8UmNGb290ZXJcbiAgICAgIGNvbHVtbnM9e2dldEZvb3RlckxpbmtzKGNsb25lRGVlcChmb290ZXJMaW5rcykpfVxuICAgICAgY3NzPXtzdHlsZS5mb290ZXJ9XG4gICAgICBib3R0b209e1xuICAgICAgICA8c3BhblxuICAgICAgICAgIGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7XG4gICAgICAgICAgICBfX2h0bWw6IGZvb3RlclxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICB9XG4gICAgLz5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEZvb3RlcjtcbiJdfQ== */"),
|
|
20
|
+
footer: /*#__PURE__*/css("background:", background, ";color:", token.colorTextSecondary, ";box-shadow:inset 0 106px 36px -116px rgba(0, 0, 0, 0.14);*{box-sizing:border-box;}h2,a{color:", token.colorText, ";}.rc-footer-column{margin-bottom:", isMobile ? 60 : 0, "px;:last-child{margin-bottom:", isMobile ? 20 : 0, "px;}}.rc-footer-item-icon{top:-1.5px;}.rc-footer-container{display:", Array.isArray(footerLinks) && footerLinks.length > 0 ? 'block' : 'none', ";max-width:1208px;margin-inline:auto;padding-inline:", token.marginXXL, "px;}.rc-footer-bottom{box-shadow:inset 0 106px 36px -116px rgba(0, 0, 0, 0.14);.rc-footer-bottom-container{font-size:", token.fontSize, "px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:footer;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQmUiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGlueUNvbG9yIH0gZnJvbSAnQGN0cmwvdGlueWNvbG9yJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBSY0Zvb3RlciBmcm9tICdyYy1mb290ZXInO1xuaW1wb3J0IGNsb25lRGVlcCBmcm9tICdsb2Rhc2guY2xvbmVkZWVwJztcbmltcG9ydCBnZXRBbHBoYUNvbG9yIGZyb20gJ2FudGQvbGliL3RoZW1lL3V0aWwvZ2V0QWxwaGFDb2xvcic7XG5pbXBvcnQgeyB1c2VDb250ZXh0LCB1c2VDYWxsYmFjayB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHR5cGUgRkMgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdHlwZSB7IEZvb3RlckNvbHVtbiB9IGZyb20gJ3JjLWZvb3Rlci9saWIvY29sdW1uJztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCB1c2VMb2NhbGVWYWx1ZSBmcm9tICcuLi8uLi9ob29rcy91c2VMb2NhbGVWYWx1ZSc7XG5pbXBvcnQgU2l0ZUNvbnRleHQgZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuaW1wb3J0IHR5cGUgeyBTaXRlQ29udGV4dFByb3BzIH0gZnJvbSAnLi4vU2l0ZUNvbnRleHQnO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG4gIGNvbnN0IGZvb3RlckxpbmtzID0gdXNlTG9jYWxlVmFsdWUoJ2Zvb3RlckxpbmtzJyk7XG4gIGNvbnN0IHsgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQ8U2l0ZUNvbnRleHRQcm9wcz4oU2l0ZUNvbnRleHQpO1xuICBjb25zdCBiYWNrZ3JvdW5kID0gbmV3IFRpbnlDb2xvcihnZXRBbHBoYUNvbG9yKCcjZjBmM2ZhJywgJyNmZmYnKSlcbiAgICAub25CYWNrZ3JvdW5kKHRva2VuLmNvbG9yQmdDb250YWluZXIpXG4gICAgLnRvSGV4U3RyaW5nKCk7XG5cbiAgcmV0dXJuIHtcbiAgICBob2xkZXI6IGNzc2BcbiAgICAgIGJhY2tncm91bmQ6ICR7YmFja2dyb3VuZH07XG4gICAgYCxcblxuICAgIGZvb3RlcjogY3NzYFxuICAgICAgYmFja2dyb3VuZDogJHtiYWNrZ3JvdW5kfTtcbiAgICAgIGNvbG9yOiAke3Rva2VuLmNvbG9yVGV4dFNlY29uZGFyeX07XG4gICAgICBib3gtc2hhZG93OiBpbnNldCAwIDEwNnB4IDM2cHggLTExNnB4IHJnYmEoMCwgMCwgMCwgMC4xNCk7XG5cbiAgICAgICoge1xuICAgICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgfVxuXG4gICAgICBoMixcbiAgICAgIGEge1xuICAgICAgICBjb2xvcjogJHt0b2tlbi5jb2xvclRleHR9O1xuICAgICAgfVxuXG4gICAgICAucmMtZm9vdGVyLWNvbHVtbiB7XG4gICAgICAgIG1hcmdpbi1ib3R0b206ICR7aXNNb2JpbGUgPyA2MCA6IDB9cHg7XG4gICAgICAgIDpsYXN0LWNoaWxkIHtcbiAgICAgICAgICBtYXJnaW4tYm90dG9tOiAke2lzTW9iaWxlID8gMjAgOiAwfXB4O1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItaXRlbS1pY29uIHtcbiAgICAgICAgdG9wOiAtMS41cHg7XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItY29udGFpbmVyIHtcbiAgICAgICAgZGlzcGxheTogJHtBcnJheS5pc0FycmF5KGZvb3RlckxpbmtzKSAmJiBmb290ZXJMaW5rcy5sZW5ndGggPiAwID8gJ2Jsb2NrJyA6ICdub25lJ307XG4gICAgICAgIG1heC13aWR0aDogMTIwOHB4O1xuICAgICAgICBtYXJnaW4taW5saW5lOiBhdXRvO1xuICAgICAgICBwYWRkaW5nLWlubGluZTogJHt0b2tlbi5tYXJnaW5YWEx9cHg7XG4gICAgICB9XG5cbiAgICAgIC5yYy1mb290ZXItYm90dG9tIHtcbiAgICAgICAgYm94LXNoYWRvdzogaW5zZXQgMCAxMDZweCAzNnB4IC0xMTZweCByZ2JhKDAsIDAsIDAsIDAuMTQpO1xuICAgICAgICAucmMtZm9vdGVyLWJvdHRvbS1jb250YWluZXIge1xuICAgICAgICAgIGZvbnQtc2l6ZTogJHt0b2tlbi5mb250U2l6ZX1weDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IEZvb3RlcjogRkMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlID0gdXNlU3R5bGUoKTtcbiAgY29uc3QgZm9vdGVyID0gdXNlTG9jYWxlVmFsdWUoJ2Zvb3RlcicpO1xuICBjb25zdCBmb290ZXJMaW5rcyA9IHVzZUxvY2FsZVZhbHVlKCdmb290ZXJMaW5rcycpO1xuXG4gIGNvbnN0IGdldEZvb3RlckxpbmtzID0gdXNlQ2FsbGJhY2soKGxpbmtzOiBGb290ZXJDb2x1bW5bXSkgPT4ge1xuICAgIGlmIChBcnJheS5pc0FycmF5KGxpbmtzKSkge1xuICAgICAgbGlua3MuZm9yRWFjaCgoaXRlbSkgPT4ge1xuICAgICAgICBjb25zdCBpY29uVXJsID0gaXRlbS5pY29uO1xuICAgICAgICBpZiAoaXRlbS5pY29uKSB7XG4gICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXBhcmFtLXJlYXNzaWduXG4gICAgICAgICAgZGVsZXRlIGl0ZW0uaWNvbjtcbiAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcGFyYW0tcmVhc3NpZ25cbiAgICAgICAgICBpdGVtLmljb24gPSA8aW1nIHNyYz17U3RyaW5nKGljb25VcmwpfSBhbHQ9XCJcIiBzdHlsZT17eyBtYXhXaWR0aDogJzEwMCUnIH19IC8+O1xuICAgICAgICB9XG4gICAgICAgIGlmIChBcnJheS5pc0FycmF5KGl0ZW0uaXRlbXMpKSB7XG4gICAgICAgICAgZ2V0Rm9vdGVyTGlua3MoaXRlbS5pdGVtcyk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cbiAgICByZXR1cm4gbGlua3M7XG4gIH0sIFtdKTtcblxuICBpZiAoIWZvb3RlcikgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICA8UmNGb290ZXJcbiAgICAgIGNvbHVtbnM9e2dldEZvb3RlckxpbmtzKGNsb25lRGVlcChmb290ZXJMaW5rcykpfVxuICAgICAgY3NzPXtzdHlsZS5mb290ZXJ9XG4gICAgICBib3R0b209e1xuICAgICAgICA8c3BhblxuICAgICAgICAgIGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7XG4gICAgICAgICAgICBfX2h0bWw6IGZvb3RlclxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICB9XG4gICAgLz5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEZvb3RlcjtcbiJdfQ== */")
|
|
21
21
|
};
|
|
22
22
|
};
|
|
23
23
|
var Footer = function Footer() {
|
|
@@ -8,6 +8,7 @@ import { useSidebarData } from 'dumi';
|
|
|
8
8
|
import MobileMenu from 'rc-drawer';
|
|
9
9
|
import 'rc-drawer/assets/index.css';
|
|
10
10
|
import React, { useCallback, useContext, useEffect, useState } from 'react';
|
|
11
|
+
import useAffixTop from "../../hooks/useAffixTop";
|
|
11
12
|
import useMenu from "../../hooks/useMenu";
|
|
12
13
|
import useSiteToken from "../../hooks/useSiteToken";
|
|
13
14
|
import SiteContext from "dumi/theme/slots/SiteContext";
|
|
@@ -18,7 +19,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
18
19
|
} : {
|
|
19
20
|
name: "iaxhd9-mobileMenu",
|
|
20
21
|
styles: "position:fixed;z-index:2;bottom:100px;right:20px;cursor:pointer;label:mobileMenu;",
|
|
21
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
22
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnSW1CIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVub3JkZXJlZExpc3RPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEFmZml4LCBDb2wsIENvbmZpZ1Byb3ZpZGVyLCBNZW51IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VTaWRlYmFyRGF0YSB9IGZyb20gJ2R1bWknO1xuaW1wb3J0IE1vYmlsZU1lbnUgZnJvbSAncmMtZHJhd2VyJztcbmltcG9ydCAncmMtZHJhd2VyL2Fzc2V0cy9pbmRleC5jc3MnO1xuaW1wb3J0IFJlYWN0LCB7IEZDLCB1c2VDYWxsYmFjaywgdXNlQ29udGV4dCwgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB1c2VBZmZpeFRvcCBmcm9tICcuLi8uLi9ob29rcy91c2VBZmZpeFRvcCc7XG5pbXBvcnQgdXNlTWVudSBmcm9tICcuLi8uLi9ob29rcy91c2VNZW51JztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi9TaXRlQ29udGV4dCc7XG5cbmludGVyZmFjZSBTaWRlYmFyU3RhdGUge1xuICBtb2JpbGVNZW51VmlzaWJsZTogYm9vbGVhbjtcbn1cblxuY29uc3QgdXNlU3R5bGUgPSAoKSA9PiB7XG4gIGNvbnN0IHsgdG9rZW4gfSA9IHVzZVNpdGVUb2tlbigpO1xuXG4gIGNvbnN0IHsgYW50Q2xzLCBmb250RmFtaWx5LCBjb2xvclNwbGl0IH0gPSB0b2tlbjtcblxuICByZXR1cm4ge1xuICAgIGFzaWRlQ29udGFpbmVyOiBjc3NgXG4gICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgcGFkZGluZy1ib3R0b206IDQ4cHg7XG4gICAgICBmb250LWZhbWlseTogQXZlbmlyLCAke2ZvbnRGYW1pbHl9LCBzYW5zLXNlcmlmO1xuXG4gICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gICAgICAgICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUgaDQsXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbSBhIHtcbiAgICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgICAgIGZvbnQtc2l6ZTogMTRweDtcbiAgICAgICAgICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cCA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtdGl0bGUge1xuICAgICAgICAgIG1hcmdpbi10b3A6IDE2cHg7XG4gICAgICAgICAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgICAgICAgICBmb250LXNpemU6IDEzcHg7XG5cbiAgICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgICAgICAgICB0b3A6IDEycHg7XG4gICAgICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgICAgIHdpZHRoOiBjYWxjKDEwMCUgLSAyMHB4KTtcbiAgICAgICAgICAgIGhlaWdodDogMXB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogJHtjb2xvclNwbGl0fTtcbiAgICAgICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUsXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlLFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0XG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLFxuICAgICAgICAgICYke2FudENsc30tbWVudS1pbmxpbmVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXBcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgcGFkZGluZy1sZWZ0OiA0MHB4ICFpbXBvcnRhbnQ7XG5cbiAgICAgICAgICAke2FudENsc30tcm93LXJ0bCAmIHtcbiAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDQwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgIHBhZGRpbmctbGVmdDogMTZweCAhaW1wb3J0YW50O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIC8vIE5lc3QgQ2F0ZWdvcnkgPiBUeXBlID4gQXJ0aWNsZVxuICAgICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi1sZWZ0OiA0cHg7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDYwcHg7XG5cbiAgICAgICAgICAgICR7YW50Q2xzfS1yb3ctcnRsICYge1xuICAgICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA2MHB4O1xuICAgICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDE2cHg7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0ID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDgwcHggIWltcG9ydGFudDtcblxuICAgICAgICAgICAgJHthbnRDbHN9LXJvdy1ydGwgJiB7XG4gICAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDgwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiAxNnB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cDpmaXJzdC1vZi10eXBlIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGFbZGlzYWJsZWRdIHtcbiAgICAgICAgY29sb3I6ICNjY2M7XG4gICAgICB9XG5cbiAgICAgIC5jaGluZXNlIHtcbiAgICAgICAgbWFyZ2luLWxlZnQ6IDZweDtcbiAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgZm9udC1zaXplOiAxMnB4O1xuICAgICAgICBvcGFjaXR5OiAwLjY3O1xuICAgICAgfVxuICAgIGAsXG4gICAgbWFpbk1lbnU6IGNzc2BcbiAgICAgIHotaW5kZXg6IDE7XG5cbiAgICAgIC5tYWluLW1lbnUtaW5uZXIge1xuICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGhlaWdodDogMTAwJTtcbiAgICAgICAgbWF4LWhlaWdodDogMTAwdmg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICB9XG5cbiAgICAgICY6aG92ZXIgLm1haW4tbWVudS1pbm5lciB7XG4gICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICB9XG4gICAgYCxcbiAgICBtb2JpbGVNZW51OiBjc3NgXG4gICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICB6LWluZGV4OiAyO1xuICAgICAgYm90dG9tOiAxMDBweDtcbiAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IFNpZGViYXI6IEZDID0gKCkgPT4ge1xuICBjb25zdCBbc2lkZWJhclN0YXRlLCBzZXRTaWRlYmFyU3RhdGVdID0gdXNlU3RhdGU8U2lkZWJhclN0YXRlPih7IG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZSB9KTtcbiAgY29uc3Qgc2lkZWJhckRhdGEgPSB1c2VTaWRlYmFyRGF0YSgpO1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7XG4gICAgdG9rZW46IHsgY29sb3JCZ0NvbnRhaW5lciB9XG4gIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyB0aGVtZSwgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBbbWVudUl0ZW1zLCBzZWxlY3RlZEtleV0gPSB1c2VNZW51KCk7XG5cbiAgY29uc3QgaXNEYXJrID0gdGhlbWUuaW5jbHVkZXMoJ2RhcmsnKTtcblxuICBjb25zdCBoYW5kbGVTaG93TW9iaWxlTWVudSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTaWRlYmFyU3RhdGUoKHByZXYpID0+ICh7XG4gICAgICAuLi5wcmV2LFxuICAgICAgbW9iaWxlTWVudVZpc2libGU6IHRydWVcbiAgICB9KSk7XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZU1vYmlsZU1lbnUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0U2lkZWJhclN0YXRlKChwcmV2KSA9PiAoe1xuICAgICAgLi4ucHJldixcbiAgICAgIG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZVxuICAgIH0pKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBoYW5kbGVDbG9zZU1vYmlsZU1lbnUoKTtcbiAgICB9XG4gIH0sIFtpc01vYmlsZSwgaGFuZGxlQ2xvc2VNb2JpbGVNZW51XSk7XG5cbiAgY29uc3QgeyBtb2JpbGVNZW51VmlzaWJsZSB9ID0gc2lkZWJhclN0YXRlO1xuICBjb25zdCBhZmZpeFRvcCA9IHVzZUFmZml4VG9wKCk7XG5cbiAgY29uc3QgbWVudUNoaWxkID0gKFxuICAgIDxDb25maWdQcm92aWRlclxuICAgICAgdGhlbWU9e3tcbiAgICAgICAgY29tcG9uZW50czoge1xuICAgICAgICAgIE1lbnU6IHtcbiAgICAgICAgICAgIGl0ZW1CZzogY29sb3JCZ0NvbnRhaW5lclxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfX1cbiAgICA+XG4gICAgICA8TWVudVxuICAgICAgICBpdGVtcz17bWVudUl0ZW1zfVxuICAgICAgICBpbmxpbmVJbmRlbnQ9ezMwfVxuICAgICAgICBjc3M9e3N0eWxlcy5hc2lkZUNvbnRhaW5lcn1cbiAgICAgICAgbW9kZT1cImlubGluZVwiXG4gICAgICAgIHRoZW1lPXtpc0RhcmsgPyAnZGFyaycgOiAnbGlnaHQnfVxuICAgICAgICBzZWxlY3RlZEtleXM9e1tzZWxlY3RlZEtleV19XG4gICAgICAgIGRlZmF1bHRPcGVuS2V5cz17c2lkZWJhckRhdGE/Lm1hcCgoeyB0aXRsZSB9KSA9PiB0aXRsZSkuZmlsdGVyKChpdGVtKSA9PiBpdGVtKSBhcyBzdHJpbmdbXX1cbiAgICAgIC8+XG4gICAgPC9Db25maWdQcm92aWRlcj5cbiAgKTtcblxuICByZXR1cm4gaXNNb2JpbGUgPyAoXG4gICAgPFJlYWN0LkZyYWdtZW50PlxuICAgICAgPE1vYmlsZU1lbnVcbiAgICAgICAga2V5PVwibW9iaWxlLW1lbnVcIlxuICAgICAgICBjb250ZW50V3JhcHBlclN0eWxlPXt7XG4gICAgICAgICAgd2lkdGg6ICczMDBweCdcbiAgICAgICAgfX1cbiAgICAgICAgb3Blbj17bW9iaWxlTWVudVZpc2libGV9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlTW9iaWxlTWVudX1cbiAgICAgID5cbiAgICAgICAge21lbnVDaGlsZH1cbiAgICAgIDwvTW9iaWxlTWVudT5cbiAgICAgIHsobWVudUl0ZW1zID8/IFtdKS5sZW5ndGggPiAxID8gKFxuICAgICAgICA8ZGl2IGNzcz17c3R5bGVzLm1vYmlsZU1lbnV9IG9uQ2xpY2s9e2hhbmRsZVNob3dNb2JpbGVNZW51fT5cbiAgICAgICAgICA8VW5vcmRlcmVkTGlzdE91dGxpbmVkIC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgKSA6IG51bGx9XG4gICAgPC9SZWFjdC5GcmFnbWVudD5cbiAgKSA6IChcbiAgICA8Q29sIHh4bD17NH0geGw9ezV9IGxnPXs2fSBtZD17Nn0gc209ezI0fSB4cz17MjR9IGNzcz17c3R5bGVzLm1haW5NZW51fT5cbiAgICAgIDxBZmZpeCBvZmZzZXRUb3A9e2FmZml4VG9wfT5cbiAgICAgICAgPHNlY3Rpb24gY2xhc3NOYW1lPVwibWFpbi1tZW51LWlubmVyXCI+e21lbnVDaGlsZH08L3NlY3Rpb24+XG4gICAgICA8L0FmZml4PlxuICAgIDwvQ29sPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgU2lkZWJhcjtcbiJdfQ== */",
|
|
22
23
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
23
24
|
};
|
|
24
25
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
@@ -27,7 +28,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
27
28
|
} : {
|
|
28
29
|
name: "82ixzo-mainMenu",
|
|
29
30
|
styles: "z-index:1;.main-menu-inner{position:sticky;top:0;height:100%;max-height:100vh;overflow:hidden;}&:hover .main-menu-inner{overflow-y:auto;};label:mainMenu;",
|
|
30
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
31
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpSGlCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVub3JkZXJlZExpc3RPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEFmZml4LCBDb2wsIENvbmZpZ1Byb3ZpZGVyLCBNZW51IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VTaWRlYmFyRGF0YSB9IGZyb20gJ2R1bWknO1xuaW1wb3J0IE1vYmlsZU1lbnUgZnJvbSAncmMtZHJhd2VyJztcbmltcG9ydCAncmMtZHJhd2VyL2Fzc2V0cy9pbmRleC5jc3MnO1xuaW1wb3J0IFJlYWN0LCB7IEZDLCB1c2VDYWxsYmFjaywgdXNlQ29udGV4dCwgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB1c2VBZmZpeFRvcCBmcm9tICcuLi8uLi9ob29rcy91c2VBZmZpeFRvcCc7XG5pbXBvcnQgdXNlTWVudSBmcm9tICcuLi8uLi9ob29rcy91c2VNZW51JztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi9TaXRlQ29udGV4dCc7XG5cbmludGVyZmFjZSBTaWRlYmFyU3RhdGUge1xuICBtb2JpbGVNZW51VmlzaWJsZTogYm9vbGVhbjtcbn1cblxuY29uc3QgdXNlU3R5bGUgPSAoKSA9PiB7XG4gIGNvbnN0IHsgdG9rZW4gfSA9IHVzZVNpdGVUb2tlbigpO1xuXG4gIGNvbnN0IHsgYW50Q2xzLCBmb250RmFtaWx5LCBjb2xvclNwbGl0IH0gPSB0b2tlbjtcblxuICByZXR1cm4ge1xuICAgIGFzaWRlQ29udGFpbmVyOiBjc3NgXG4gICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgcGFkZGluZy1ib3R0b206IDQ4cHg7XG4gICAgICBmb250LWZhbWlseTogQXZlbmlyLCAke2ZvbnRGYW1pbHl9LCBzYW5zLXNlcmlmO1xuXG4gICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gICAgICAgICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUgaDQsXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbSBhIHtcbiAgICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgICAgIGZvbnQtc2l6ZTogMTRweDtcbiAgICAgICAgICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cCA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtdGl0bGUge1xuICAgICAgICAgIG1hcmdpbi10b3A6IDE2cHg7XG4gICAgICAgICAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgICAgICAgICBmb250LXNpemU6IDEzcHg7XG5cbiAgICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgICAgICAgICB0b3A6IDEycHg7XG4gICAgICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgICAgIHdpZHRoOiBjYWxjKDEwMCUgLSAyMHB4KTtcbiAgICAgICAgICAgIGhlaWdodDogMXB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogJHtjb2xvclNwbGl0fTtcbiAgICAgICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUsXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlLFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0XG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLFxuICAgICAgICAgICYke2FudENsc30tbWVudS1pbmxpbmVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXBcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgcGFkZGluZy1sZWZ0OiA0MHB4ICFpbXBvcnRhbnQ7XG5cbiAgICAgICAgICAke2FudENsc30tcm93LXJ0bCAmIHtcbiAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDQwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgIHBhZGRpbmctbGVmdDogMTZweCAhaW1wb3J0YW50O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIC8vIE5lc3QgQ2F0ZWdvcnkgPiBUeXBlID4gQXJ0aWNsZVxuICAgICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi1sZWZ0OiA0cHg7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDYwcHg7XG5cbiAgICAgICAgICAgICR7YW50Q2xzfS1yb3ctcnRsICYge1xuICAgICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA2MHB4O1xuICAgICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDE2cHg7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0ID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDgwcHggIWltcG9ydGFudDtcblxuICAgICAgICAgICAgJHthbnRDbHN9LXJvdy1ydGwgJiB7XG4gICAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDgwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiAxNnB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cDpmaXJzdC1vZi10eXBlIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGFbZGlzYWJsZWRdIHtcbiAgICAgICAgY29sb3I6ICNjY2M7XG4gICAgICB9XG5cbiAgICAgIC5jaGluZXNlIHtcbiAgICAgICAgbWFyZ2luLWxlZnQ6IDZweDtcbiAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgZm9udC1zaXplOiAxMnB4O1xuICAgICAgICBvcGFjaXR5OiAwLjY3O1xuICAgICAgfVxuICAgIGAsXG4gICAgbWFpbk1lbnU6IGNzc2BcbiAgICAgIHotaW5kZXg6IDE7XG5cbiAgICAgIC5tYWluLW1lbnUtaW5uZXIge1xuICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGhlaWdodDogMTAwJTtcbiAgICAgICAgbWF4LWhlaWdodDogMTAwdmg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICB9XG5cbiAgICAgICY6aG92ZXIgLm1haW4tbWVudS1pbm5lciB7XG4gICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICB9XG4gICAgYCxcbiAgICBtb2JpbGVNZW51OiBjc3NgXG4gICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICB6LWluZGV4OiAyO1xuICAgICAgYm90dG9tOiAxMDBweDtcbiAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IFNpZGViYXI6IEZDID0gKCkgPT4ge1xuICBjb25zdCBbc2lkZWJhclN0YXRlLCBzZXRTaWRlYmFyU3RhdGVdID0gdXNlU3RhdGU8U2lkZWJhclN0YXRlPih7IG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZSB9KTtcbiAgY29uc3Qgc2lkZWJhckRhdGEgPSB1c2VTaWRlYmFyRGF0YSgpO1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7XG4gICAgdG9rZW46IHsgY29sb3JCZ0NvbnRhaW5lciB9XG4gIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyB0aGVtZSwgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBbbWVudUl0ZW1zLCBzZWxlY3RlZEtleV0gPSB1c2VNZW51KCk7XG5cbiAgY29uc3QgaXNEYXJrID0gdGhlbWUuaW5jbHVkZXMoJ2RhcmsnKTtcblxuICBjb25zdCBoYW5kbGVTaG93TW9iaWxlTWVudSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTaWRlYmFyU3RhdGUoKHByZXYpID0+ICh7XG4gICAgICAuLi5wcmV2LFxuICAgICAgbW9iaWxlTWVudVZpc2libGU6IHRydWVcbiAgICB9KSk7XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZU1vYmlsZU1lbnUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0U2lkZWJhclN0YXRlKChwcmV2KSA9PiAoe1xuICAgICAgLi4ucHJldixcbiAgICAgIG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZVxuICAgIH0pKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBoYW5kbGVDbG9zZU1vYmlsZU1lbnUoKTtcbiAgICB9XG4gIH0sIFtpc01vYmlsZSwgaGFuZGxlQ2xvc2VNb2JpbGVNZW51XSk7XG5cbiAgY29uc3QgeyBtb2JpbGVNZW51VmlzaWJsZSB9ID0gc2lkZWJhclN0YXRlO1xuICBjb25zdCBhZmZpeFRvcCA9IHVzZUFmZml4VG9wKCk7XG5cbiAgY29uc3QgbWVudUNoaWxkID0gKFxuICAgIDxDb25maWdQcm92aWRlclxuICAgICAgdGhlbWU9e3tcbiAgICAgICAgY29tcG9uZW50czoge1xuICAgICAgICAgIE1lbnU6IHtcbiAgICAgICAgICAgIGl0ZW1CZzogY29sb3JCZ0NvbnRhaW5lclxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfX1cbiAgICA+XG4gICAgICA8TWVudVxuICAgICAgICBpdGVtcz17bWVudUl0ZW1zfVxuICAgICAgICBpbmxpbmVJbmRlbnQ9ezMwfVxuICAgICAgICBjc3M9e3N0eWxlcy5hc2lkZUNvbnRhaW5lcn1cbiAgICAgICAgbW9kZT1cImlubGluZVwiXG4gICAgICAgIHRoZW1lPXtpc0RhcmsgPyAnZGFyaycgOiAnbGlnaHQnfVxuICAgICAgICBzZWxlY3RlZEtleXM9e1tzZWxlY3RlZEtleV19XG4gICAgICAgIGRlZmF1bHRPcGVuS2V5cz17c2lkZWJhckRhdGE/Lm1hcCgoeyB0aXRsZSB9KSA9PiB0aXRsZSkuZmlsdGVyKChpdGVtKSA9PiBpdGVtKSBhcyBzdHJpbmdbXX1cbiAgICAgIC8+XG4gICAgPC9Db25maWdQcm92aWRlcj5cbiAgKTtcblxuICByZXR1cm4gaXNNb2JpbGUgPyAoXG4gICAgPFJlYWN0LkZyYWdtZW50PlxuICAgICAgPE1vYmlsZU1lbnVcbiAgICAgICAga2V5PVwibW9iaWxlLW1lbnVcIlxuICAgICAgICBjb250ZW50V3JhcHBlclN0eWxlPXt7XG4gICAgICAgICAgd2lkdGg6ICczMDBweCdcbiAgICAgICAgfX1cbiAgICAgICAgb3Blbj17bW9iaWxlTWVudVZpc2libGV9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlTW9iaWxlTWVudX1cbiAgICAgID5cbiAgICAgICAge21lbnVDaGlsZH1cbiAgICAgIDwvTW9iaWxlTWVudT5cbiAgICAgIHsobWVudUl0ZW1zID8/IFtdKS5sZW5ndGggPiAxID8gKFxuICAgICAgICA8ZGl2IGNzcz17c3R5bGVzLm1vYmlsZU1lbnV9IG9uQ2xpY2s9e2hhbmRsZVNob3dNb2JpbGVNZW51fT5cbiAgICAgICAgICA8VW5vcmRlcmVkTGlzdE91dGxpbmVkIC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgKSA6IG51bGx9XG4gICAgPC9SZWFjdC5GcmFnbWVudD5cbiAgKSA6IChcbiAgICA8Q29sIHh4bD17NH0geGw9ezV9IGxnPXs2fSBtZD17Nn0gc209ezI0fSB4cz17MjR9IGNzcz17c3R5bGVzLm1haW5NZW51fT5cbiAgICAgIDxBZmZpeCBvZmZzZXRUb3A9e2FmZml4VG9wfT5cbiAgICAgICAgPHNlY3Rpb24gY2xhc3NOYW1lPVwibWFpbi1tZW51LWlubmVyXCI+e21lbnVDaGlsZH08L3NlY3Rpb24+XG4gICAgICA8L0FmZml4PlxuICAgIDwvQ29sPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgU2lkZWJhcjtcbiJdfQ== */",
|
|
31
32
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
32
33
|
};
|
|
33
34
|
var useStyle = function useStyle() {
|
|
@@ -37,7 +38,7 @@ var useStyle = function useStyle() {
|
|
|
37
38
|
fontFamily = token.fontFamily,
|
|
38
39
|
colorSplit = token.colorSplit;
|
|
39
40
|
return {
|
|
40
|
-
asideContainer: /*#__PURE__*/css("min-height:100%;padding-bottom:48px;font-family:Avenir,", fontFamily, ",sans-serif;&", antCls, "-menu-inline{user-select:none;", antCls, "-menu-submenu-title h4,>", antCls, "-menu-item,", antCls, "-menu-item a{overflow:hidden;font-size:14px;text-overflow:ellipsis;}>", antCls, "-menu-item-group>", antCls, "-menu-item-group-title{margin-top:16px;margin-bottom:16px;font-size:13px;&::after{position:relative;top:12px;display:block;width:calc(100% - 20px);height:1px;background:", colorSplit, ";content:'';}}>", antCls, "-menu-item,>", antCls, "-menu-submenu>", antCls, "-menu-submenu-title,>", antCls, "-menu-item-group>", antCls, "-menu-item-group-title,>", antCls, "-menu-item-group>", antCls, "-menu-item-group-list>", antCls, "-menu-item,&", antCls, "-menu-inline>", antCls, "-menu-item-group>", antCls, "-menu-item-group-list>", antCls, "-menu-item{padding-left:40px!important;", antCls, "-row-rtl &{padding-right:40px!important;padding-left:16px!important;}}&", antCls, "-menu-inline{", antCls, "-menu-item-group-title{margin-left:4px;padding-left:60px;", antCls, "-row-rtl &{padding-right:60px;padding-left:16px;}}", antCls, "-menu-item-group-list>", antCls, "-menu-item{padding-left:80px!important;", antCls, "-row-rtl &{padding-right:80px!important;padding-left:16px!important;}}}", antCls, "-menu-item-group:first-of-type{", antCls, "-menu-item-group-title{margin-top:0;}}}a[disabled]{color:#ccc;}.chinese{margin-left:6px;font-weight:normal;font-size:12px;opacity:0.67;}" + (process.env.NODE_ENV === "production" ? "" : ";label:asideContainer;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41
|
+
asideContainer: /*#__PURE__*/css("min-height:100%;padding-bottom:48px;font-family:Avenir,", fontFamily, ",sans-serif;&", antCls, "-menu-inline{user-select:none;", antCls, "-menu-submenu-title h4,>", antCls, "-menu-item,", antCls, "-menu-item a{overflow:hidden;font-size:14px;text-overflow:ellipsis;}>", antCls, "-menu-item-group>", antCls, "-menu-item-group-title{margin-top:16px;margin-bottom:16px;font-size:13px;&::after{position:relative;top:12px;display:block;width:calc(100% - 20px);height:1px;background:", colorSplit, ";content:'';}}>", antCls, "-menu-item,>", antCls, "-menu-submenu>", antCls, "-menu-submenu-title,>", antCls, "-menu-item-group>", antCls, "-menu-item-group-title,>", antCls, "-menu-item-group>", antCls, "-menu-item-group-list>", antCls, "-menu-item,&", antCls, "-menu-inline>", antCls, "-menu-item-group>", antCls, "-menu-item-group-list>", antCls, "-menu-item{padding-left:40px!important;", antCls, "-row-rtl &{padding-right:40px!important;padding-left:16px!important;}}&", antCls, "-menu-inline{", antCls, "-menu-item-group-title{margin-left:4px;padding-left:60px;", antCls, "-row-rtl &{padding-right:60px;padding-left:16px;}}", antCls, "-menu-item-group-list>", antCls, "-menu-item{padding-left:80px!important;", antCls, "-row-rtl &{padding-right:80px!important;padding-left:16px!important;}}}", antCls, "-menu-item-group:first-of-type{", antCls, "-menu-item-group-title{margin-top:0;}}}a[disabled]{color:#ccc;}.chinese{margin-left:6px;font-weight:normal;font-size:12px;opacity:0.67;}" + (process.env.NODE_ENV === "production" ? "" : ";label:asideContainer;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQnVCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVub3JkZXJlZExpc3RPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEFmZml4LCBDb2wsIENvbmZpZ1Byb3ZpZGVyLCBNZW51IH0gZnJvbSAnYW50ZCc7XG5pbXBvcnQgeyB1c2VTaWRlYmFyRGF0YSB9IGZyb20gJ2R1bWknO1xuaW1wb3J0IE1vYmlsZU1lbnUgZnJvbSAncmMtZHJhd2VyJztcbmltcG9ydCAncmMtZHJhd2VyL2Fzc2V0cy9pbmRleC5jc3MnO1xuaW1wb3J0IFJlYWN0LCB7IEZDLCB1c2VDYWxsYmFjaywgdXNlQ29udGV4dCwgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB1c2VBZmZpeFRvcCBmcm9tICcuLi8uLi9ob29rcy91c2VBZmZpeFRvcCc7XG5pbXBvcnQgdXNlTWVudSBmcm9tICcuLi8uLi9ob29rcy91c2VNZW51JztcbmltcG9ydCB1c2VTaXRlVG9rZW4gZnJvbSAnLi4vLi4vaG9va3MvdXNlU2l0ZVRva2VuJztcbmltcG9ydCBTaXRlQ29udGV4dCBmcm9tICcuLi9TaXRlQ29udGV4dCc7XG5cbmludGVyZmFjZSBTaWRlYmFyU3RhdGUge1xuICBtb2JpbGVNZW51VmlzaWJsZTogYm9vbGVhbjtcbn1cblxuY29uc3QgdXNlU3R5bGUgPSAoKSA9PiB7XG4gIGNvbnN0IHsgdG9rZW4gfSA9IHVzZVNpdGVUb2tlbigpO1xuXG4gIGNvbnN0IHsgYW50Q2xzLCBmb250RmFtaWx5LCBjb2xvclNwbGl0IH0gPSB0b2tlbjtcblxuICByZXR1cm4ge1xuICAgIGFzaWRlQ29udGFpbmVyOiBjc3NgXG4gICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgcGFkZGluZy1ib3R0b206IDQ4cHg7XG4gICAgICBmb250LWZhbWlseTogQXZlbmlyLCAke2ZvbnRGYW1pbHl9LCBzYW5zLXNlcmlmO1xuXG4gICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gICAgICAgICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUgaDQsXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbSBhIHtcbiAgICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgICAgIGZvbnQtc2l6ZTogMTRweDtcbiAgICAgICAgICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cCA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtdGl0bGUge1xuICAgICAgICAgIG1hcmdpbi10b3A6IDE2cHg7XG4gICAgICAgICAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgICAgICAgICBmb250LXNpemU6IDEzcHg7XG5cbiAgICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgICAgICAgICB0b3A6IDEycHg7XG4gICAgICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgICAgIHdpZHRoOiBjYWxjKDEwMCUgLSAyMHB4KTtcbiAgICAgICAgICAgIGhlaWdodDogMXB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZDogJHtjb2xvclNwbGl0fTtcbiAgICAgICAgICAgIGNvbnRlbnQ6ICcnO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSxcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LXN1Ym1lbnUtdGl0bGUsXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwXG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlLFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0XG4gICAgICAgICAgPiAke2FudENsc30tbWVudS1pdGVtLFxuICAgICAgICAgICYke2FudENsc30tbWVudS1pbmxpbmVcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXBcbiAgICAgICAgICA+ICR7YW50Q2xzfS1tZW51LWl0ZW0tZ3JvdXAtbGlzdFxuICAgICAgICAgID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgcGFkZGluZy1sZWZ0OiA0MHB4ICFpbXBvcnRhbnQ7XG5cbiAgICAgICAgICAke2FudENsc30tcm93LXJ0bCAmIHtcbiAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDQwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgIHBhZGRpbmctbGVmdDogMTZweCAhaW1wb3J0YW50O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIC8vIE5lc3QgQ2F0ZWdvcnkgPiBUeXBlID4gQXJ0aWNsZVxuICAgICAgICAmJHthbnRDbHN9LW1lbnUtaW5saW5lIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi1sZWZ0OiA0cHg7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDYwcHg7XG5cbiAgICAgICAgICAgICR7YW50Q2xzfS1yb3ctcnRsICYge1xuICAgICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiA2MHB4O1xuICAgICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDE2cHg7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cC1saXN0ID4gJHthbnRDbHN9LW1lbnUtaXRlbSB7XG4gICAgICAgICAgICBwYWRkaW5nLWxlZnQ6IDgwcHggIWltcG9ydGFudDtcblxuICAgICAgICAgICAgJHthbnRDbHN9LXJvdy1ydGwgJiB7XG4gICAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IDgwcHggIWltcG9ydGFudDtcbiAgICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiAxNnB4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgJHthbnRDbHN9LW1lbnUtaXRlbS1ncm91cDpmaXJzdC1vZi10eXBlIHtcbiAgICAgICAgICAke2FudENsc30tbWVudS1pdGVtLWdyb3VwLXRpdGxlIHtcbiAgICAgICAgICAgIG1hcmdpbi10b3A6IDA7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGFbZGlzYWJsZWRdIHtcbiAgICAgICAgY29sb3I6ICNjY2M7XG4gICAgICB9XG5cbiAgICAgIC5jaGluZXNlIHtcbiAgICAgICAgbWFyZ2luLWxlZnQ6IDZweDtcbiAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgZm9udC1zaXplOiAxMnB4O1xuICAgICAgICBvcGFjaXR5OiAwLjY3O1xuICAgICAgfVxuICAgIGAsXG4gICAgbWFpbk1lbnU6IGNzc2BcbiAgICAgIHotaW5kZXg6IDE7XG5cbiAgICAgIC5tYWluLW1lbnUtaW5uZXIge1xuICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGhlaWdodDogMTAwJTtcbiAgICAgICAgbWF4LWhlaWdodDogMTAwdmg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICB9XG5cbiAgICAgICY6aG92ZXIgLm1haW4tbWVudS1pbm5lciB7XG4gICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICB9XG4gICAgYCxcbiAgICBtb2JpbGVNZW51OiBjc3NgXG4gICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICB6LWluZGV4OiAyO1xuICAgICAgYm90dG9tOiAxMDBweDtcbiAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIGBcbiAgfTtcbn07XG5cbmNvbnN0IFNpZGViYXI6IEZDID0gKCkgPT4ge1xuICBjb25zdCBbc2lkZWJhclN0YXRlLCBzZXRTaWRlYmFyU3RhdGVdID0gdXNlU3RhdGU8U2lkZWJhclN0YXRlPih7IG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZSB9KTtcbiAgY29uc3Qgc2lkZWJhckRhdGEgPSB1c2VTaWRlYmFyRGF0YSgpO1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7XG4gICAgdG9rZW46IHsgY29sb3JCZ0NvbnRhaW5lciB9XG4gIH0gPSB1c2VTaXRlVG9rZW4oKTtcbiAgY29uc3QgeyB0aGVtZSwgaXNNb2JpbGUgfSA9IHVzZUNvbnRleHQoU2l0ZUNvbnRleHQpO1xuICBjb25zdCBbbWVudUl0ZW1zLCBzZWxlY3RlZEtleV0gPSB1c2VNZW51KCk7XG5cbiAgY29uc3QgaXNEYXJrID0gdGhlbWUuaW5jbHVkZXMoJ2RhcmsnKTtcblxuICBjb25zdCBoYW5kbGVTaG93TW9iaWxlTWVudSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTaWRlYmFyU3RhdGUoKHByZXYpID0+ICh7XG4gICAgICAuLi5wcmV2LFxuICAgICAgbW9iaWxlTWVudVZpc2libGU6IHRydWVcbiAgICB9KSk7XG4gIH0sIFtdKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZU1vYmlsZU1lbnUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0U2lkZWJhclN0YXRlKChwcmV2KSA9PiAoe1xuICAgICAgLi4ucHJldixcbiAgICAgIG1vYmlsZU1lbnVWaXNpYmxlOiBmYWxzZVxuICAgIH0pKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGlzTW9iaWxlKSB7XG4gICAgICBoYW5kbGVDbG9zZU1vYmlsZU1lbnUoKTtcbiAgICB9XG4gIH0sIFtpc01vYmlsZSwgaGFuZGxlQ2xvc2VNb2JpbGVNZW51XSk7XG5cbiAgY29uc3QgeyBtb2JpbGVNZW51VmlzaWJsZSB9ID0gc2lkZWJhclN0YXRlO1xuICBjb25zdCBhZmZpeFRvcCA9IHVzZUFmZml4VG9wKCk7XG5cbiAgY29uc3QgbWVudUNoaWxkID0gKFxuICAgIDxDb25maWdQcm92aWRlclxuICAgICAgdGhlbWU9e3tcbiAgICAgICAgY29tcG9uZW50czoge1xuICAgICAgICAgIE1lbnU6IHtcbiAgICAgICAgICAgIGl0ZW1CZzogY29sb3JCZ0NvbnRhaW5lclxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfX1cbiAgICA+XG4gICAgICA8TWVudVxuICAgICAgICBpdGVtcz17bWVudUl0ZW1zfVxuICAgICAgICBpbmxpbmVJbmRlbnQ9ezMwfVxuICAgICAgICBjc3M9e3N0eWxlcy5hc2lkZUNvbnRhaW5lcn1cbiAgICAgICAgbW9kZT1cImlubGluZVwiXG4gICAgICAgIHRoZW1lPXtpc0RhcmsgPyAnZGFyaycgOiAnbGlnaHQnfVxuICAgICAgICBzZWxlY3RlZEtleXM9e1tzZWxlY3RlZEtleV19XG4gICAgICAgIGRlZmF1bHRPcGVuS2V5cz17c2lkZWJhckRhdGE/Lm1hcCgoeyB0aXRsZSB9KSA9PiB0aXRsZSkuZmlsdGVyKChpdGVtKSA9PiBpdGVtKSBhcyBzdHJpbmdbXX1cbiAgICAgIC8+XG4gICAgPC9Db25maWdQcm92aWRlcj5cbiAgKTtcblxuICByZXR1cm4gaXNNb2JpbGUgPyAoXG4gICAgPFJlYWN0LkZyYWdtZW50PlxuICAgICAgPE1vYmlsZU1lbnVcbiAgICAgICAga2V5PVwibW9iaWxlLW1lbnVcIlxuICAgICAgICBjb250ZW50V3JhcHBlclN0eWxlPXt7XG4gICAgICAgICAgd2lkdGg6ICczMDBweCdcbiAgICAgICAgfX1cbiAgICAgICAgb3Blbj17bW9iaWxlTWVudVZpc2libGV9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlTW9iaWxlTWVudX1cbiAgICAgID5cbiAgICAgICAge21lbnVDaGlsZH1cbiAgICAgIDwvTW9iaWxlTWVudT5cbiAgICAgIHsobWVudUl0ZW1zID8/IFtdKS5sZW5ndGggPiAxID8gKFxuICAgICAgICA8ZGl2IGNzcz17c3R5bGVzLm1vYmlsZU1lbnV9IG9uQ2xpY2s9e2hhbmRsZVNob3dNb2JpbGVNZW51fT5cbiAgICAgICAgICA8VW5vcmRlcmVkTGlzdE91dGxpbmVkIC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgKSA6IG51bGx9XG4gICAgPC9SZWFjdC5GcmFnbWVudD5cbiAgKSA6IChcbiAgICA8Q29sIHh4bD17NH0geGw9ezV9IGxnPXs2fSBtZD17Nn0gc209ezI0fSB4cz17MjR9IGNzcz17c3R5bGVzLm1haW5NZW51fT5cbiAgICAgIDxBZmZpeCBvZmZzZXRUb3A9e2FmZml4VG9wfT5cbiAgICAgICAgPHNlY3Rpb24gY2xhc3NOYW1lPVwibWFpbi1tZW51LWlubmVyXCI+e21lbnVDaGlsZH08L3NlY3Rpb24+XG4gICAgICA8L0FmZml4PlxuICAgIDwvQ29sPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgU2lkZWJhcjtcbiJdfQ== */"),
|
|
41
42
|
mainMenu: _ref2,
|
|
42
43
|
mobileMenu: _ref
|
|
43
44
|
};
|
|
@@ -81,6 +82,7 @@ var Sidebar = function Sidebar() {
|
|
|
81
82
|
}
|
|
82
83
|
}, [isMobile, handleCloseMobileMenu]);
|
|
83
84
|
var mobileMenuVisible = sidebarState.mobileMenuVisible;
|
|
85
|
+
var affixTop = useAffixTop();
|
|
84
86
|
var menuChild = ___EmotionJSX(ConfigProvider, {
|
|
85
87
|
theme: {
|
|
86
88
|
components: {
|
|
@@ -121,7 +123,9 @@ var Sidebar = function Sidebar() {
|
|
|
121
123
|
sm: 24,
|
|
122
124
|
xs: 24,
|
|
123
125
|
css: styles.mainMenu
|
|
124
|
-
}, ___EmotionJSX(Affix,
|
|
126
|
+
}, ___EmotionJSX(Affix, {
|
|
127
|
+
offsetTop: affixTop
|
|
128
|
+
}, ___EmotionJSX("section", {
|
|
125
129
|
className: "main-menu-inner"
|
|
126
130
|
}, menuChild)));
|
|
127
131
|
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ahooks.js/dumi-theme-antd",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.4",
|
|
4
4
|
"description": "Ant Design 5.0 官网风格类似的 dumi2 主题插件",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"dumi",
|
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
"homepage": "https://ahooks.js.org",
|
|
12
12
|
"repository": {
|
|
13
13
|
"type": "git",
|
|
14
|
-
"url": "https://github.com/ahooksjs/dumi-theme-antd.git"
|
|
14
|
+
"url": "git+https://github.com/ahooksjs/dumi-theme-antd.git"
|
|
15
15
|
},
|
|
16
16
|
"license": "MIT",
|
|
17
17
|
"main": "dist/index.js",
|
|
@@ -19,19 +19,6 @@
|
|
|
19
19
|
"files": [
|
|
20
20
|
"dist"
|
|
21
21
|
],
|
|
22
|
-
"scripts": {
|
|
23
|
-
"build": "father build",
|
|
24
|
-
"build:docs": "cross-env APP_ROOT=example dumi build",
|
|
25
|
-
"build:site": "cross-env APP_ROOT=example DEPLOY_SITE=local dumi build",
|
|
26
|
-
"site": "node app.js",
|
|
27
|
-
"dev": "father dev",
|
|
28
|
-
"docs": "cross-env APP_ROOT=example dumi dev",
|
|
29
|
-
"lint": "pnpm run lint:es && pnpm run lint:css",
|
|
30
|
-
"lint:css": "stylelint \"{src,test}/**/*.{css,less}\"",
|
|
31
|
-
"lint:es": "eslint \"{src,test}/**/*.{js,jsx,ts,tsx}\" --fix",
|
|
32
|
-
"prepare": "husky install && father link-dev-theme",
|
|
33
|
-
"prepublishOnly": "father doctor && pnpm run build"
|
|
34
|
-
},
|
|
35
22
|
"commitlint": {
|
|
36
23
|
"extends": [
|
|
37
24
|
"@commitlint/config-conventional"
|
|
@@ -104,5 +91,16 @@
|
|
|
104
91
|
"authors": [
|
|
105
92
|
"KuangPF",
|
|
106
93
|
"liuyib<https://github.com/liuyib>"
|
|
107
|
-
]
|
|
108
|
-
|
|
94
|
+
],
|
|
95
|
+
"scripts": {
|
|
96
|
+
"build": "father build",
|
|
97
|
+
"build:docs": "cross-env APP_ROOT=example dumi build",
|
|
98
|
+
"build:site": "cross-env APP_ROOT=example DEPLOY_SITE=local dumi build",
|
|
99
|
+
"site": "node app.js",
|
|
100
|
+
"dev": "father dev",
|
|
101
|
+
"docs": "cross-env APP_ROOT=example dumi dev",
|
|
102
|
+
"lint": "pnpm run lint:es && pnpm run lint:css",
|
|
103
|
+
"lint:css": "stylelint \"{src,test}/**/*.{css,less}\"",
|
|
104
|
+
"lint:es": "eslint \"{src,test}/**/*.{js,jsx,ts,tsx}\" --fix"
|
|
105
|
+
}
|
|
106
|
+
}
|