dumi-theme-antd4 0.0.1 → 0.0.3
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.
|
@@ -1,20 +1,21 @@
|
|
|
1
1
|
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
2
2
|
// 最后更新时间
|
|
3
|
-
import
|
|
3
|
+
import { ClockCircleOutlined } from '@ant-design/icons';
|
|
4
4
|
import { css } from '@emotion/react';
|
|
5
5
|
import { FormattedMessage } from 'dumi';
|
|
6
|
-
import {
|
|
7
|
-
import useSiteToken from "../hooks/useSiteToken";
|
|
6
|
+
import React, { useEffect, useState } from 'react';
|
|
8
7
|
import useAdditionalThemeConfig from "../hooks/useAdditionalThemeConfig";
|
|
8
|
+
import useSiteToken from "../hooks/useSiteToken";
|
|
9
9
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
10
10
|
var useStyle = function useStyle() {
|
|
11
11
|
var _useSiteToken = useSiteToken(),
|
|
12
12
|
token = _useSiteToken.token;
|
|
13
|
-
var
|
|
13
|
+
var colorTextSecondary = token.colorTextSecondary,
|
|
14
14
|
marginXXS = token.marginXXS;
|
|
15
15
|
return {
|
|
16
|
-
lastUpdatedWrap: /*#__PURE__*/css("color:",
|
|
17
|
-
lastUpdatedLabel: /*#__PURE__*/css("margin-inline-start:", marginXXS, "px;margin-inline-end:", marginXXS, "px;" + (process.env.NODE_ENV === "production" ? "" : ";label:lastUpdatedLabel;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
16
|
+
lastUpdatedWrap: /*#__PURE__*/css("color:", colorTextSecondary, ";display:flex;align-items:center;font-size:", token.fontSize, "px;line-height:", token.lineHeight, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:lastUpdatedWrap;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxhc3RVcGRhdGVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjd0IiLCJmaWxlIjoiTGFzdFVwZGF0ZWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLy8g5pyA5ZCO5pu05paw5pe26Ze0XG5pbXBvcnQgeyBDbG9ja0NpcmNsZU91dGxpbmVkIH0gZnJvbSAnQGFudC1kZXNpZ24vaWNvbnMnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgRm9ybWF0dGVkTWVzc2FnZSB9IGZyb20gJ2R1bWknO1xuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdXNlQWRkaXRpb25hbFRoZW1lQ29uZmlnIGZyb20gJy4uL2hvb2tzL3VzZUFkZGl0aW9uYWxUaGVtZUNvbmZpZyc7XG5pbXBvcnQgdXNlU2l0ZVRva2VuIGZyb20gJy4uL2hvb2tzL3VzZVNpdGVUb2tlbic7XG5cbmNvbnN0IHVzZVN0eWxlID0gKCkgPT4ge1xuICBjb25zdCB7IHRva2VuIH0gPSB1c2VTaXRlVG9rZW4oKTtcblxuICBjb25zdCB7IGNvbG9yVGV4dFNlY29uZGFyeSwgbWFyZ2luWFhTIH0gPSB0b2tlbjtcblxuICByZXR1cm4ge1xuICAgIGxhc3RVcGRhdGVkV3JhcDogY3NzYFxuICAgICAgY29sb3I6ICR7Y29sb3JUZXh0U2Vjb25kYXJ5fTtcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgZm9udC1zaXplOiAke3Rva2VuLmZvbnRTaXplfXB4O1xuICAgICAgbGluZS1oZWlnaHQ6ICR7dG9rZW4ubGluZUhlaWdodH07XG4gICAgYCxcbiAgICBsYXN0VXBkYXRlZExhYmVsOiBjc3NgXG4gICAgICBtYXJnaW4taW5saW5lLXN0YXJ0OiAke21hcmdpblhYU31weDtcbiAgICAgIG1hcmdpbi1pbmxpbmUtZW5kOiAke21hcmdpblhYU31weDtcbiAgICBgLFxuICAgIGxhc3RVcGRhdGVkSWNvbjogY3NzYFxuICAgICAgZm9udC1zaXplOiAke3Rva2VuLmZvbnRTaXplfXB4O1xuICAgICAgY29sb3I6ICR7Y29sb3JUZXh0U2Vjb25kYXJ5fTtcbiAgICBgXG4gIH07XG59O1xuXG5jb25zdCBMYXN0VXBkYXRlZDogUmVhY3QuRkM8eyB0aW1lPzogbnVtYmVyIH0+ID0gKHsgdGltZSB9KSA9PiB7XG4gIGNvbnN0IHN0eWxlcyA9IHVzZVN0eWxlKCk7XG4gIGNvbnN0IHsgbGFzdFVwZGF0ZWQgfSA9IHVzZUFkZGl0aW9uYWxUaGVtZUNvbmZpZygpO1xuICBjb25zdCBbaXNvTGFzdFVwZGF0ZWQsIHNldElzb0xhc3RVcGRhdGVkXSA9IHVzZVN0YXRlKCcnKTtcbiAgY29uc3QgW2xhc3RVcGRhdGVkVGltZSwgc2V0TGFzdFVwZGF0ZWRUaW1lXSA9IHVzZVN0YXRlKCcnKTtcbiAgY29uc3Qgc2hvd0xhc3RVcGRhdGVkID0gbGFzdFVwZGF0ZWQgJiYgdGltZTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzaG93TGFzdFVwZGF0ZWQpIHtcbiAgICAgIHNldElzb0xhc3RVcGRhdGVkKG5ldyBEYXRlKHRpbWUhKS50b0lTT1N0cmluZygpKTtcbiAgICAgIHNldExhc3RVcGRhdGVkVGltZShcbiAgICAgICAgbmV3IEludGwuRGF0ZVRpbWVGb3JtYXQodW5kZWZpbmVkLCB7XG4gICAgICAgICAgZGF0ZVN0eWxlOiAnc2hvcnQnLFxuICAgICAgICAgIHRpbWVTdHlsZTogJ3Nob3J0J1xuICAgICAgICB9KS5mb3JtYXQodGltZSlcbiAgICAgICk7XG4gICAgfVxuICB9LCBbc2hvd0xhc3RVcGRhdGVkLCB0aW1lXSk7XG5cbiAgcmV0dXJuIGxhc3RVcGRhdGVkICYmIHRpbWUgPyAoXG4gICAgPGRpdiBjc3M9e3N0eWxlcy5sYXN0VXBkYXRlZFdyYXB9PlxuICAgICAgPENsb2NrQ2lyY2xlT3V0bGluZWQgY3NzPXtzdHlsZXMubGFzdFVwZGF0ZWRJY29ufSAvPlxuICAgICAgPHNwYW4gY3NzPXtzdHlsZXMubGFzdFVwZGF0ZWRMYWJlbH0+XG4gICAgICAgIDxGb3JtYXR0ZWRNZXNzYWdlIGlkPVwiY29udGVudC5mb290ZXIubGFzdC51cGRhdGVkXCIgLz5cbiAgICAgIDwvc3Bhbj5cbiAgICAgIDx0aW1lIGRhdGVUaW1lPXtpc29MYXN0VXBkYXRlZH0+e2xhc3RVcGRhdGVkVGltZX08L3RpbWU+XG4gICAgPC9kaXY+XG4gICkgOiBudWxsO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgTGFzdFVwZGF0ZWQ7XG4iXX0= */"),
|
|
17
|
+
lastUpdatedLabel: /*#__PURE__*/css("margin-inline-start:", marginXXS, "px;margin-inline-end:", marginXXS, "px;" + (process.env.NODE_ENV === "production" ? "" : ";label:lastUpdatedLabel;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxhc3RVcGRhdGVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnlCIiwiZmlsZSI6Ikxhc3RVcGRhdGVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8vIOacgOWQjuabtOaWsOaXtumXtFxuaW1wb3J0IHsgQ2xvY2tDaXJjbGVPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEZvcm1hdHRlZE1lc3NhZ2UgfSBmcm9tICdkdW1pJztcbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZUFkZGl0aW9uYWxUaGVtZUNvbmZpZyBmcm9tICcuLi9ob29rcy91c2VBZGRpdGlvbmFsVGhlbWVDb25maWcnO1xuaW1wb3J0IHVzZVNpdGVUb2tlbiBmcm9tICcuLi9ob29rcy91c2VTaXRlVG9rZW4nO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG5cbiAgY29uc3QgeyBjb2xvclRleHRTZWNvbmRhcnksIG1hcmdpblhYUyB9ID0gdG9rZW47XG5cbiAgcmV0dXJuIHtcbiAgICBsYXN0VXBkYXRlZFdyYXA6IGNzc2BcbiAgICAgIGNvbG9yOiAke2NvbG9yVGV4dFNlY29uZGFyeX07XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIGZvbnQtc2l6ZTogJHt0b2tlbi5mb250U2l6ZX1weDtcbiAgICAgIGxpbmUtaGVpZ2h0OiAke3Rva2VuLmxpbmVIZWlnaHR9O1xuICAgIGAsXG4gICAgbGFzdFVwZGF0ZWRMYWJlbDogY3NzYFxuICAgICAgbWFyZ2luLWlubGluZS1zdGFydDogJHttYXJnaW5YWFN9cHg7XG4gICAgICBtYXJnaW4taW5saW5lLWVuZDogJHttYXJnaW5YWFN9cHg7XG4gICAgYCxcbiAgICBsYXN0VXBkYXRlZEljb246IGNzc2BcbiAgICAgIGZvbnQtc2l6ZTogJHt0b2tlbi5mb250U2l6ZX1weDtcbiAgICAgIGNvbG9yOiAke2NvbG9yVGV4dFNlY29uZGFyeX07XG4gICAgYFxuICB9O1xufTtcblxuY29uc3QgTGFzdFVwZGF0ZWQ6IFJlYWN0LkZDPHsgdGltZT86IG51bWJlciB9PiA9ICh7IHRpbWUgfSkgPT4ge1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7IGxhc3RVcGRhdGVkIH0gPSB1c2VBZGRpdGlvbmFsVGhlbWVDb25maWcoKTtcbiAgY29uc3QgW2lzb0xhc3RVcGRhdGVkLCBzZXRJc29MYXN0VXBkYXRlZF0gPSB1c2VTdGF0ZSgnJyk7XG4gIGNvbnN0IFtsYXN0VXBkYXRlZFRpbWUsIHNldExhc3RVcGRhdGVkVGltZV0gPSB1c2VTdGF0ZSgnJyk7XG4gIGNvbnN0IHNob3dMYXN0VXBkYXRlZCA9IGxhc3RVcGRhdGVkICYmIHRpbWU7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoc2hvd0xhc3RVcGRhdGVkKSB7XG4gICAgICBzZXRJc29MYXN0VXBkYXRlZChuZXcgRGF0ZSh0aW1lISkudG9JU09TdHJpbmcoKSk7XG4gICAgICBzZXRMYXN0VXBkYXRlZFRpbWUoXG4gICAgICAgIG5ldyBJbnRsLkRhdGVUaW1lRm9ybWF0KHVuZGVmaW5lZCwge1xuICAgICAgICAgIGRhdGVTdHlsZTogJ3Nob3J0JyxcbiAgICAgICAgICB0aW1lU3R5bGU6ICdzaG9ydCdcbiAgICAgICAgfSkuZm9ybWF0KHRpbWUpXG4gICAgICApO1xuICAgIH1cbiAgfSwgW3Nob3dMYXN0VXBkYXRlZCwgdGltZV0pO1xuXG4gIHJldHVybiBsYXN0VXBkYXRlZCAmJiB0aW1lID8gKFxuICAgIDxkaXYgY3NzPXtzdHlsZXMubGFzdFVwZGF0ZWRXcmFwfT5cbiAgICAgIDxDbG9ja0NpcmNsZU91dGxpbmVkIGNzcz17c3R5bGVzLmxhc3RVcGRhdGVkSWNvbn0gLz5cbiAgICAgIDxzcGFuIGNzcz17c3R5bGVzLmxhc3RVcGRhdGVkTGFiZWx9PlxuICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZSBpZD1cImNvbnRlbnQuZm9vdGVyLmxhc3QudXBkYXRlZFwiIC8+XG4gICAgICA8L3NwYW4+XG4gICAgICA8dGltZSBkYXRlVGltZT17aXNvTGFzdFVwZGF0ZWR9PntsYXN0VXBkYXRlZFRpbWV9PC90aW1lPlxuICAgIDwvZGl2PlxuICApIDogbnVsbDtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IExhc3RVcGRhdGVkO1xuIl19 */"),
|
|
18
|
+
lastUpdatedIcon: /*#__PURE__*/css("font-size:", token.fontSize, "px;color:", colorTextSecondary, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:lastUpdatedIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxhc3RVcGRhdGVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QndCIiwiZmlsZSI6Ikxhc3RVcGRhdGVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8vIOacgOWQjuabtOaWsOaXtumXtFxuaW1wb3J0IHsgQ2xvY2tDaXJjbGVPdXRsaW5lZCB9IGZyb20gJ0BhbnQtZGVzaWduL2ljb25zJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEZvcm1hdHRlZE1lc3NhZ2UgfSBmcm9tICdkdW1pJztcbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZUFkZGl0aW9uYWxUaGVtZUNvbmZpZyBmcm9tICcuLi9ob29rcy91c2VBZGRpdGlvbmFsVGhlbWVDb25maWcnO1xuaW1wb3J0IHVzZVNpdGVUb2tlbiBmcm9tICcuLi9ob29rcy91c2VTaXRlVG9rZW4nO1xuXG5jb25zdCB1c2VTdHlsZSA9ICgpID0+IHtcbiAgY29uc3QgeyB0b2tlbiB9ID0gdXNlU2l0ZVRva2VuKCk7XG5cbiAgY29uc3QgeyBjb2xvclRleHRTZWNvbmRhcnksIG1hcmdpblhYUyB9ID0gdG9rZW47XG5cbiAgcmV0dXJuIHtcbiAgICBsYXN0VXBkYXRlZFdyYXA6IGNzc2BcbiAgICAgIGNvbG9yOiAke2NvbG9yVGV4dFNlY29uZGFyeX07XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIGZvbnQtc2l6ZTogJHt0b2tlbi5mb250U2l6ZX1weDtcbiAgICAgIGxpbmUtaGVpZ2h0OiAke3Rva2VuLmxpbmVIZWlnaHR9O1xuICAgIGAsXG4gICAgbGFzdFVwZGF0ZWRMYWJlbDogY3NzYFxuICAgICAgbWFyZ2luLWlubGluZS1zdGFydDogJHttYXJnaW5YWFN9cHg7XG4gICAgICBtYXJnaW4taW5saW5lLWVuZDogJHttYXJnaW5YWFN9cHg7XG4gICAgYCxcbiAgICBsYXN0VXBkYXRlZEljb246IGNzc2BcbiAgICAgIGZvbnQtc2l6ZTogJHt0b2tlbi5mb250U2l6ZX1weDtcbiAgICAgIGNvbG9yOiAke2NvbG9yVGV4dFNlY29uZGFyeX07XG4gICAgYFxuICB9O1xufTtcblxuY29uc3QgTGFzdFVwZGF0ZWQ6IFJlYWN0LkZDPHsgdGltZT86IG51bWJlciB9PiA9ICh7IHRpbWUgfSkgPT4ge1xuICBjb25zdCBzdHlsZXMgPSB1c2VTdHlsZSgpO1xuICBjb25zdCB7IGxhc3RVcGRhdGVkIH0gPSB1c2VBZGRpdGlvbmFsVGhlbWVDb25maWcoKTtcbiAgY29uc3QgW2lzb0xhc3RVcGRhdGVkLCBzZXRJc29MYXN0VXBkYXRlZF0gPSB1c2VTdGF0ZSgnJyk7XG4gIGNvbnN0IFtsYXN0VXBkYXRlZFRpbWUsIHNldExhc3RVcGRhdGVkVGltZV0gPSB1c2VTdGF0ZSgnJyk7XG4gIGNvbnN0IHNob3dMYXN0VXBkYXRlZCA9IGxhc3RVcGRhdGVkICYmIHRpbWU7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoc2hvd0xhc3RVcGRhdGVkKSB7XG4gICAgICBzZXRJc29MYXN0VXBkYXRlZChuZXcgRGF0ZSh0aW1lISkudG9JU09TdHJpbmcoKSk7XG4gICAgICBzZXRMYXN0VXBkYXRlZFRpbWUoXG4gICAgICAgIG5ldyBJbnRsLkRhdGVUaW1lRm9ybWF0KHVuZGVmaW5lZCwge1xuICAgICAgICAgIGRhdGVTdHlsZTogJ3Nob3J0JyxcbiAgICAgICAgICB0aW1lU3R5bGU6ICdzaG9ydCdcbiAgICAgICAgfSkuZm9ybWF0KHRpbWUpXG4gICAgICApO1xuICAgIH1cbiAgfSwgW3Nob3dMYXN0VXBkYXRlZCwgdGltZV0pO1xuXG4gIHJldHVybiBsYXN0VXBkYXRlZCAmJiB0aW1lID8gKFxuICAgIDxkaXYgY3NzPXtzdHlsZXMubGFzdFVwZGF0ZWRXcmFwfT5cbiAgICAgIDxDbG9ja0NpcmNsZU91dGxpbmVkIGNzcz17c3R5bGVzLmxhc3RVcGRhdGVkSWNvbn0gLz5cbiAgICAgIDxzcGFuIGNzcz17c3R5bGVzLmxhc3RVcGRhdGVkTGFiZWx9PlxuICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZSBpZD1cImNvbnRlbnQuZm9vdGVyLmxhc3QudXBkYXRlZFwiIC8+XG4gICAgICA8L3NwYW4+XG4gICAgICA8dGltZSBkYXRlVGltZT17aXNvTGFzdFVwZGF0ZWR9PntsYXN0VXBkYXRlZFRpbWV9PC90aW1lPlxuICAgIDwvZGl2PlxuICApIDogbnVsbDtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IExhc3RVcGRhdGVkO1xuIl19 */")
|
|
18
19
|
};
|
|
19
20
|
};
|
|
20
21
|
var LastUpdated = function LastUpdated(_ref) {
|
|
@@ -42,7 +43,9 @@ var LastUpdated = function LastUpdated(_ref) {
|
|
|
42
43
|
}, [showLastUpdated, time]);
|
|
43
44
|
return lastUpdated && time ? ___EmotionJSX("div", {
|
|
44
45
|
css: styles.lastUpdatedWrap
|
|
45
|
-
}, ___EmotionJSX(ClockCircleOutlined,
|
|
46
|
+
}, ___EmotionJSX(ClockCircleOutlined, {
|
|
47
|
+
css: styles.lastUpdatedIcon
|
|
48
|
+
}), ___EmotionJSX("span", {
|
|
46
49
|
css: styles.lastUpdatedLabel
|
|
47
50
|
}, ___EmotionJSX(FormattedMessage, {
|
|
48
51
|
id: "content.footer.last.updated"
|
|
@@ -4,6 +4,7 @@ interface IUseSiteToken {
|
|
|
4
4
|
colorBgContainer: string;
|
|
5
5
|
colorText: string;
|
|
6
6
|
colorTextSecondary: string;
|
|
7
|
+
colorTextTertiary: string;
|
|
7
8
|
colorSplit: string;
|
|
8
9
|
colorFillTertiary: string;
|
|
9
10
|
colorPrimaryBg: string;
|
|
@@ -29,6 +30,7 @@ interface IUseSiteToken {
|
|
|
29
30
|
margin: number;
|
|
30
31
|
marginSM: number;
|
|
31
32
|
marginMD: number;
|
|
33
|
+
marginXXS: number;
|
|
32
34
|
marginXXL: number;
|
|
33
35
|
borderRadius: number;
|
|
34
36
|
borderRadiusLG: number;
|
|
@@ -19,6 +19,7 @@ var useSiteToken = function useSiteToken() {
|
|
|
19
19
|
colorBgContainer: '#fff',
|
|
20
20
|
colorText: 'rgba(0, 0, 0, 0.85)',
|
|
21
21
|
colorTextSecondary: 'rgba(0, 0, 0, 0.45)',
|
|
22
|
+
colorTextTertiary: 'rgba(0, 0, 0, 0.25)',
|
|
22
23
|
colorSplit: '#f0f0f0',
|
|
23
24
|
colorFillTertiary: 'rgba(0, 0, 0, 0.04)',
|
|
24
25
|
colorPrimaryBg: '#e6f7ff',
|
|
@@ -48,6 +49,8 @@ var useSiteToken = function useSiteToken() {
|
|
|
48
49
|
// antd 默认小间距
|
|
49
50
|
marginMD: 24,
|
|
50
51
|
// antd 5.x 默认是 24
|
|
52
|
+
marginXXS: 4,
|
|
53
|
+
// antd 默认极小间距
|
|
51
54
|
marginXXL: marginXXL,
|
|
52
55
|
// antd 4.x 默认圆角(调整为接近 5.x 视觉效果)
|
|
53
56
|
borderRadius: 6,
|
|
@@ -20,8 +20,8 @@ var useStyle = function useStyle() {
|
|
|
20
20
|
menuItemBorder = token.menuItemBorder,
|
|
21
21
|
colorPrimary = token.colorPrimary;
|
|
22
22
|
return {
|
|
23
|
-
nav: /*#__PURE__*/css("height:100%;font-size:14px;font-family:Avenir,", fontFamily, ",sans-serif;border:0;&", antCls, "-menu-horizontal{border-bottom:none;&>", antCls, "-menu-item,&>", antCls, "-menu-submenu{min-width:auto;height:", headerHeight, "px;padding:0 12px;margin:0;line-height:", headerHeight, "px;&::after{top:0;right:12px;bottom:auto;left:12px;border-width:", menuItemBorder, "px;}}& ", antCls, "-menu-submenu-title ", iconCls, "{margin:0;}&>", antCls, "-menu-item-selected{a{color:", colorPrimary, ";}}}&>", antCls, "-menu-item,&>", antCls, "-menu-submenu{text-align:center;}" + (process.env.NODE_ENV === "production" ? "" : ";label:nav;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Navigation.tsx"],"names":[],"mappings":"AAwBY","file":"Navigation.tsx","sourcesContent":["import { MenuFoldOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Menu } from 'antd';\nimport { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { INavItem } from 'dumi/dist/client/theme-api/types';\nimport React, { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { getTargetLocalePath, isExternalLinks } from '../../utils';\nimport { getMoreLinksGroup } from './More';\nimport { type IResponsive } from './index';\n\nexport interface NavigationProps {\n  isMobile: boolean;\n  responsive: IResponsive;\n}\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls, iconCls, fontFamily, headerHeight, menuItemBorder, colorPrimary } = token;\n\n  return {\n    nav: css`\n      height: 100%;\n      font-size: 14px;\n      font-family: Avenir, ${fontFamily}, sans-serif;\n      border: 0;\n\n      &${antCls}-menu-horizontal {\n        border-bottom: none;\n\n        & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n          min-width: auto;\n          height: ${headerHeight}px;\n          padding: 0 12px;\n          margin: 0;\n          line-height: ${headerHeight}px;\n\n          &::after {\n            top: 0;\n            right: 12px;\n            bottom: auto;\n            left: 12px;\n            border-width: ${menuItemBorder}px;\n          }\n        }\n\n        & ${antCls}-menu-submenu-title ${iconCls} {\n          margin: 0;\n        }\n\n        & > ${antCls}-menu-item-selected {\n          a {\n            color: ${colorPrimary};\n          }\n        }\n      }\n\n      & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n        text-align: center;\n      }\n    `,\n    popoverMenuNav: css`\n      ${antCls}-menu-item,\n      ${antCls}-menu-submenu {\n        text-align: left;\n      }\n\n      ${antCls}-menu-item-group-title {\n        padding-left: 24px;\n      }\n\n      ${antCls}-menu-item-group-list {\n        padding: 0 16px;\n      }\n\n      ${antCls}-menu-item,\n      a {\n        color: #333;\n      }\n    `\n  };\n};\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const { github, socialLinks } = useAdditionalThemeConfig();\n\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n  const locale = useLocale();\n  const moreLinks = useLocaleValue('moreLinks');\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n\n  const createMenuItems = (navs: INavItem[]): React.ReactNode => {\n    return navs.map((navItem: INavItem) => {\n      const linkKeyValue = (navItem.link ?? '').split('/').slice(0, 2).join('/');\n      const key = isExternalLinks(navItem.link) ? navItem.link : linkKeyValue;\n\n      // eslint-disable-next-line no-nested-ternary\n      const label = navItem.children ? (\n        navItem.title\n      ) : isExternalLinks(navItem.link) ? (\n        <a href={`${navItem.link}${search}`} target=\"_blank\" rel=\"noreferrer\">\n          {navItem.title}\n        </a>\n      ) : (\n        <Link to={`${navItem.link}${search}`}>{navItem.title}</Link>\n      );\n\n      if (navItem.children) {\n        return (\n          <Menu.SubMenu key={key} title={label}>\n            {createMenuItems(navItem.children)}\n          </Menu.SubMenu>\n        );\n      }\n\n      return <Menu.Item key={key}>{label}</Menu.Item>;\n    });\n  };\n  const menuItems = createMenuItems(navList);\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback((): React.ReactNode => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = locales.filter((item) => item.id !== locale.id)[0];\n      const nextPath = getTargetLocalePath({\n        current: locale,\n        target: nextLang\n      });\n      return (\n        <Menu.Item key={nextLang.id}>\n          <a rel=\"noopener noreferrer\" href={nextPath}>\n            {nextLang.name}\n          </a>\n        </Menu.Item>\n      );\n    }\n    return (\n      <Menu.SubMenu key=\"multi-lang\" title={<span>{locale.name}</span>}>\n        {locales\n          .filter((item) => item.id !== locale.id)\n          .map((item) => {\n            const nextPath = getTargetLocalePath({\n              current: locale,\n              target: item\n            });\n            return (\n              <Menu.Item key={item.id}>\n                <a rel=\"noopener noreferrer\" href={nextPath}>\n                  {item.name}\n                </a>\n              </Menu.Item>\n            );\n          })}\n      </Menu.SubMenu>\n    );\n  }, [locale, locales]);\n\n  const moreLinksItems = getMoreLinksGroup(moreLinks) || [];\n  const additionalItems: React.ReactNode[] = [\n    github || socialLinks?.github ? (\n      <Menu.Item key=\"github\">\n        <a rel=\"noopener noreferrer\" href={github || socialLinks?.github} target=\"_blank\">\n          GitHub\n        </a>\n      </Menu.Item>\n    ) : null,\n    getLangNode(),\n    ...moreLinksItems\n      .filter((item) => item !== null)\n      .map((item) => {\n        const menuItem = item as { key: string; label: React.ReactNode; children?: any[] };\n        if (menuItem.children && menuItem.children.length > 0) {\n          return (\n            <Menu.SubMenu key={menuItem.key} title={menuItem.label}>\n              {menuItem.children\n                .filter((child) => child !== null)\n                .map((child) => {\n                  const childItem = child as { key: string; label: React.ReactNode };\n                  return <Menu.Item key={childItem.key}>{childItem.label}</Menu.Item>;\n                })}\n            </Menu.SubMenu>\n          );\n        }\n        return <Menu.Item key={menuItem.key}>{menuItem.label}</Menu.Item>;\n      })\n  ].filter(Boolean) as React.ReactNode[];\n\n  let additional: React.ReactNode[] = [];\n  if (isMobile) {\n    additional = additionalItems;\n  } else if (responsive === 'crowded') {\n    additional = [\n      <Menu.SubMenu key=\"additional\" title={<MenuFoldOutlined />
|
|
24
|
-
popoverMenuNav: /*#__PURE__*/css(antCls, "-menu-item,", antCls, "-menu-submenu{text-align:left;}", antCls, "-menu-item-group-title{padding-left:24px;}", antCls, "-menu-item-group-list{padding:0 16px;}", antCls, "-menu-item,a{color:#333;}" + (process.env.NODE_ENV === "production" ? "" : ";label:popoverMenuNav;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Navigation.tsx"],"names":[],"mappings":"AAgEuB","file":"Navigation.tsx","sourcesContent":["import { MenuFoldOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Menu } from 'antd';\nimport { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { INavItem } from 'dumi/dist/client/theme-api/types';\nimport React, { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { getTargetLocalePath, isExternalLinks } from '../../utils';\nimport { getMoreLinksGroup } from './More';\nimport { type IResponsive } from './index';\n\nexport interface NavigationProps {\n  isMobile: boolean;\n  responsive: IResponsive;\n}\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls, iconCls, fontFamily, headerHeight, menuItemBorder, colorPrimary } = token;\n\n  return {\n    nav: css`\n      height: 100%;\n      font-size: 14px;\n      font-family: Avenir, ${fontFamily}, sans-serif;\n      border: 0;\n\n      &${antCls}-menu-horizontal {\n        border-bottom: none;\n\n        & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n          min-width: auto;\n          height: ${headerHeight}px;\n          padding: 0 12px;\n          margin: 0;\n          line-height: ${headerHeight}px;\n\n          &::after {\n            top: 0;\n            right: 12px;\n            bottom: auto;\n            left: 12px;\n            border-width: ${menuItemBorder}px;\n          }\n        }\n\n        & ${antCls}-menu-submenu-title ${iconCls} {\n          margin: 0;\n        }\n\n        & > ${antCls}-menu-item-selected {\n          a {\n            color: ${colorPrimary};\n          }\n        }\n      }\n\n      & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n        text-align: center;\n      }\n    `,\n    popoverMenuNav: css`\n      ${antCls}-menu-item,\n      ${antCls}-menu-submenu {\n        text-align: left;\n      }\n\n      ${antCls}-menu-item-group-title {\n        padding-left: 24px;\n      }\n\n      ${antCls}-menu-item-group-list {\n        padding: 0 16px;\n      }\n\n      ${antCls}-menu-item,\n      a {\n        color: #333;\n      }\n    `\n  };\n};\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const { github, socialLinks } = useAdditionalThemeConfig();\n\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n  const locale = useLocale();\n  const moreLinks = useLocaleValue('moreLinks');\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n\n  const createMenuItems = (navs: INavItem[]): React.ReactNode => {\n    return navs.map((navItem: INavItem) => {\n      const linkKeyValue = (navItem.link ?? '').split('/').slice(0, 2).join('/');\n      const key = isExternalLinks(navItem.link) ? navItem.link : linkKeyValue;\n\n      // eslint-disable-next-line no-nested-ternary\n      const label = navItem.children ? (\n        navItem.title\n      ) : isExternalLinks(navItem.link) ? (\n        <a href={`${navItem.link}${search}`} target=\"_blank\" rel=\"noreferrer\">\n          {navItem.title}\n        </a>\n      ) : (\n        <Link to={`${navItem.link}${search}`}>{navItem.title}</Link>\n      );\n\n      if (navItem.children) {\n        return (\n          <Menu.SubMenu key={key} title={label}>\n            {createMenuItems(navItem.children)}\n          </Menu.SubMenu>\n        );\n      }\n\n      return <Menu.Item key={key}>{label}</Menu.Item>;\n    });\n  };\n  const menuItems = createMenuItems(navList);\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback((): React.ReactNode => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = locales.filter((item) => item.id !== locale.id)[0];\n      const nextPath = getTargetLocalePath({\n        current: locale,\n        target: nextLang\n      });\n      return (\n        <Menu.Item key={nextLang.id}>\n          <a rel=\"noopener noreferrer\" href={nextPath}>\n            {nextLang.name}\n          </a>\n        </Menu.Item>\n      );\n    }\n    return (\n      <Menu.SubMenu key=\"multi-lang\" title={<span>{locale.name}</span>}>\n        {locales\n          .filter((item) => item.id !== locale.id)\n          .map((item) => {\n            const nextPath = getTargetLocalePath({\n              current: locale,\n              target: item\n            });\n            return (\n              <Menu.Item key={item.id}>\n                <a rel=\"noopener noreferrer\" href={nextPath}>\n                  {item.name}\n                </a>\n              </Menu.Item>\n            );\n          })}\n      </Menu.SubMenu>\n    );\n  }, [locale, locales]);\n\n  const moreLinksItems = getMoreLinksGroup(moreLinks) || [];\n  const additionalItems: React.ReactNode[] = [\n    github || socialLinks?.github ? (\n      <Menu.Item key=\"github\">\n        <a rel=\"noopener noreferrer\" href={github || socialLinks?.github} target=\"_blank\">\n          GitHub\n        </a>\n      </Menu.Item>\n    ) : null,\n    getLangNode(),\n    ...moreLinksItems\n      .filter((item) => item !== null)\n      .map((item) => {\n        const menuItem = item as { key: string; label: React.ReactNode; children?: any[] };\n        if (menuItem.children && menuItem.children.length > 0) {\n          return (\n            <Menu.SubMenu key={menuItem.key} title={menuItem.label}>\n              {menuItem.children\n                .filter((child) => child !== null)\n                .map((child) => {\n                  const childItem = child as { key: string; label: React.ReactNode };\n                  return <Menu.Item key={childItem.key}>{childItem.label}</Menu.Item>;\n                })}\n            </Menu.SubMenu>\n          );\n        }\n        return <Menu.Item key={menuItem.key}>{menuItem.label}</Menu.Item>;\n      })\n  ].filter(Boolean) as React.ReactNode[];\n\n  let additional: React.ReactNode[] = [];\n  if (isMobile) {\n    additional = additionalItems;\n  } else if (responsive === 'crowded') {\n    additional = [\n      <Menu.SubMenu key=\"additional\" title={<MenuFoldOutlined />}>\n        {additionalItems}\n      </Menu.SubMenu>\n    ];\n  }\n\n  const menuMode = isMobile ?
|
|
23
|
+
nav: /*#__PURE__*/css("height:100%;font-size:14px;font-family:Avenir,", fontFamily, ",sans-serif;border:0;&", antCls, "-menu-horizontal{border-bottom:none;&>", antCls, "-menu-item,&>", antCls, "-menu-submenu{min-width:auto;height:", headerHeight, "px;padding:0 12px;margin:0;line-height:", headerHeight, "px;&::after{top:0;right:12px;bottom:auto;left:12px;border-width:", menuItemBorder, "px;}}& ", antCls, "-menu-submenu-title ", iconCls, "{margin:0;}&>", antCls, "-menu-item-selected{a{color:", colorPrimary, ";}}}&>", antCls, "-menu-item,&>", antCls, "-menu-submenu{text-align:center;}" + (process.env.NODE_ENV === "production" ? "" : ";label:nav;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Navigation.tsx"],"names":[],"mappings":"AAwBY","file":"Navigation.tsx","sourcesContent":["import { MenuFoldOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Menu } from 'antd';\nimport { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { INavItem } from 'dumi/dist/client/theme-api/types';\nimport React, { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { getTargetLocalePath, isExternalLinks } from '../../utils';\nimport { getMoreLinksGroup } from './More';\nimport { type IResponsive } from './index';\n\nexport interface NavigationProps {\n  isMobile: boolean;\n  responsive: IResponsive;\n}\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls, iconCls, fontFamily, headerHeight, menuItemBorder, colorPrimary } = token;\n\n  return {\n    nav: css`\n      height: 100%;\n      font-size: 14px;\n      font-family: Avenir, ${fontFamily}, sans-serif;\n      border: 0;\n\n      &${antCls}-menu-horizontal {\n        border-bottom: none;\n\n        & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n          min-width: auto;\n          height: ${headerHeight}px;\n          padding: 0 12px;\n          margin: 0;\n          line-height: ${headerHeight}px;\n\n          &::after {\n            top: 0;\n            right: 12px;\n            bottom: auto;\n            left: 12px;\n            border-width: ${menuItemBorder}px;\n          }\n        }\n\n        & ${antCls}-menu-submenu-title ${iconCls} {\n          margin: 0;\n        }\n\n        & > ${antCls}-menu-item-selected {\n          a {\n            color: ${colorPrimary};\n          }\n        }\n      }\n\n      & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n        text-align: center;\n      }\n    `,\n    popoverMenuNav: css`\n      ${antCls}-menu-item,\n      ${antCls}-menu-submenu {\n        text-align: left;\n      }\n\n      ${antCls}-menu-item-group-title {\n        padding-left: 24px;\n      }\n\n      ${antCls}-menu-item-group-list {\n        padding: 0 16px;\n      }\n\n      ${antCls}-menu-item,\n      a {\n        color: #333;\n      }\n    `\n  };\n};\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const { github, socialLinks } = useAdditionalThemeConfig();\n\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n  const locale = useLocale();\n  const moreLinks = useLocaleValue('moreLinks');\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n\n  const createMenuItems = (navs: INavItem[]): React.ReactNode => {\n    return navs.map((navItem: INavItem) => {\n      const linkKeyValue = (navItem.link ?? '').split('/').slice(0, 2).join('/');\n      const key = isExternalLinks(navItem.link) ? navItem.link : linkKeyValue;\n\n      // eslint-disable-next-line no-nested-ternary\n      const label = navItem.children ? (\n        navItem.title\n      ) : isExternalLinks(navItem.link) ? (\n        <a href={`${navItem.link}${search}`} target=\"_blank\" rel=\"noreferrer\">\n          {navItem.title}\n        </a>\n      ) : (\n        <Link to={`${navItem.link}${search}`}>{navItem.title}</Link>\n      );\n\n      if (navItem.children) {\n        return (\n          <Menu.SubMenu key={key} title={label}>\n            {createMenuItems(navItem.children)}\n          </Menu.SubMenu>\n        );\n      }\n\n      return <Menu.Item key={key}>{label}</Menu.Item>;\n    });\n  };\n  const menuItems = createMenuItems(navList);\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback((): React.ReactNode => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = locales.filter((item) => item.id !== locale.id)[0];\n      const nextPath = getTargetLocalePath({\n        current: locale,\n        target: nextLang\n      });\n      return (\n        <Menu.Item key={nextLang.id}>\n          <a rel=\"noopener noreferrer\" href={nextPath}>\n            {nextLang.name}\n          </a>\n        </Menu.Item>\n      );\n    }\n    return (\n      <Menu.SubMenu key=\"multi-lang\" title={<span>{locale.name}</span>}>\n        {locales\n          .filter((item) => item.id !== locale.id)\n          .map((item) => {\n            const nextPath = getTargetLocalePath({\n              current: locale,\n              target: item\n            });\n            return (\n              <Menu.Item key={item.id}>\n                <a rel=\"noopener noreferrer\" href={nextPath}>\n                  {item.name}\n                </a>\n              </Menu.Item>\n            );\n          })}\n      </Menu.SubMenu>\n    );\n  }, [locale, locales]);\n\n  const moreLinksItems = getMoreLinksGroup(moreLinks) || [];\n  const additionalItems: React.ReactNode[] = [\n    github || socialLinks?.github ? (\n      <Menu.Item key=\"github\">\n        <a rel=\"noopener noreferrer\" href={github || socialLinks?.github} target=\"_blank\">\n          GitHub\n        </a>\n      </Menu.Item>\n    ) : null,\n    getLangNode(),\n    ...moreLinksItems\n      .filter((item) => item !== null)\n      .map((item) => {\n        const menuItem = item as { key: string; label: React.ReactNode; children?: any[] };\n        if (menuItem.children && menuItem.children.length > 0) {\n          return (\n            <Menu.SubMenu key={menuItem.key} title={menuItem.label}>\n              {menuItem.children\n                .filter((child) => child !== null)\n                .map((child) => {\n                  const childItem = child as { key: string; label: React.ReactNode };\n                  return <Menu.Item key={childItem.key}>{childItem.label}</Menu.Item>;\n                })}\n            </Menu.SubMenu>\n          );\n        }\n        return <Menu.Item key={menuItem.key}>{menuItem.label}</Menu.Item>;\n      })\n  ].filter(Boolean) as React.ReactNode[];\n\n  let additional: React.ReactNode[] = [];\n  if (isMobile) {\n    additional = additionalItems;\n  } else if (responsive === 'crowded') {\n    additional = [\n      <Menu.SubMenu key=\"additional\" title={<MenuFoldOutlined />}>\n        {additionalItems}\n      </Menu.SubMenu>\n    ];\n  }\n\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n  return (\n    <Menu mode={menuMode} css={style.nav} selectedKeys={[activeMenuItem]}>\n      {menuItems}\n      {additional}\n    </Menu>\n  );\n}\n"]} */"),
|
|
24
|
+
popoverMenuNav: /*#__PURE__*/css(antCls, "-menu-item,", antCls, "-menu-submenu{text-align:left;}", antCls, "-menu-item-group-title{padding-left:24px;}", antCls, "-menu-item-group-list{padding:0 16px;}", antCls, "-menu-item,a{color:#333;}" + (process.env.NODE_ENV === "production" ? "" : ";label:popoverMenuNav;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Navigation.tsx"],"names":[],"mappings":"AAgEuB","file":"Navigation.tsx","sourcesContent":["import { MenuFoldOutlined } from '@ant-design/icons';\nimport { css } from '@emotion/react';\nimport { Menu } from 'antd';\nimport { Link, useLocale, useLocation, useNavData, useSiteData } from 'dumi';\nimport { INavItem } from 'dumi/dist/client/theme-api/types';\nimport React, { useCallback } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport { getTargetLocalePath, isExternalLinks } from '../../utils';\nimport { getMoreLinksGroup } from './More';\nimport { type IResponsive } from './index';\n\nexport interface NavigationProps {\n  isMobile: boolean;\n  responsive: IResponsive;\n}\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n\n  const { antCls, iconCls, fontFamily, headerHeight, menuItemBorder, colorPrimary } = token;\n\n  return {\n    nav: css`\n      height: 100%;\n      font-size: 14px;\n      font-family: Avenir, ${fontFamily}, sans-serif;\n      border: 0;\n\n      &${antCls}-menu-horizontal {\n        border-bottom: none;\n\n        & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n          min-width: auto;\n          height: ${headerHeight}px;\n          padding: 0 12px;\n          margin: 0;\n          line-height: ${headerHeight}px;\n\n          &::after {\n            top: 0;\n            right: 12px;\n            bottom: auto;\n            left: 12px;\n            border-width: ${menuItemBorder}px;\n          }\n        }\n\n        & ${antCls}-menu-submenu-title ${iconCls} {\n          margin: 0;\n        }\n\n        & > ${antCls}-menu-item-selected {\n          a {\n            color: ${colorPrimary};\n          }\n        }\n      }\n\n      & > ${antCls}-menu-item, & > ${antCls}-menu-submenu {\n        text-align: center;\n      }\n    `,\n    popoverMenuNav: css`\n      ${antCls}-menu-item,\n      ${antCls}-menu-submenu {\n        text-align: left;\n      }\n\n      ${antCls}-menu-item-group-title {\n        padding-left: 24px;\n      }\n\n      ${antCls}-menu-item-group-list {\n        padding: 0 16px;\n      }\n\n      ${antCls}-menu-item,\n      a {\n        color: #333;\n      }\n    `\n  };\n};\n\nexport default function Navigation({ isMobile, responsive }: NavigationProps) {\n  const { pathname, search } = useLocation();\n  const { locales } = useSiteData();\n  const { github, socialLinks } = useAdditionalThemeConfig();\n\n  // 统一使用 themeConfig.nav，使用 useNavData，当存在自定义 pages 时，会导致 nav 混乱\n  const navList = useNavData();\n  const locale = useLocale();\n  const moreLinks = useLocaleValue('moreLinks');\n  const activeMenuItem = pathname.split('/').slice(0, 2).join('/');\n\n  const createMenuItems = (navs: INavItem[]): React.ReactNode => {\n    return navs.map((navItem: INavItem) => {\n      const linkKeyValue = (navItem.link ?? '').split('/').slice(0, 2).join('/');\n      const key = isExternalLinks(navItem.link) ? navItem.link : linkKeyValue;\n\n      // eslint-disable-next-line no-nested-ternary\n      const label = navItem.children ? (\n        navItem.title\n      ) : isExternalLinks(navItem.link) ? (\n        <a href={`${navItem.link}${search}`} target=\"_blank\" rel=\"noreferrer\">\n          {navItem.title}\n        </a>\n      ) : (\n        <Link to={`${navItem.link}${search}`}>{navItem.title}</Link>\n      );\n\n      if (navItem.children) {\n        return (\n          <Menu.SubMenu key={key} title={label}>\n            {createMenuItems(navItem.children)}\n          </Menu.SubMenu>\n        );\n      }\n\n      return <Menu.Item key={key}>{label}</Menu.Item>;\n    });\n  };\n  const menuItems = createMenuItems(navList);\n\n  // 获取小屏幕下多语言导航栏节点\n  const getLangNode = useCallback((): React.ReactNode => {\n    if (locales.length < 2) {\n      return null;\n    }\n    if (locales.length === 2) {\n      const nextLang = locales.filter((item) => item.id !== locale.id)[0];\n      const nextPath = getTargetLocalePath({\n        current: locale,\n        target: nextLang\n      });\n      return (\n        <Menu.Item key={nextLang.id}>\n          <a rel=\"noopener noreferrer\" href={nextPath}>\n            {nextLang.name}\n          </a>\n        </Menu.Item>\n      );\n    }\n    return (\n      <Menu.SubMenu key=\"multi-lang\" title={<span>{locale.name}</span>}>\n        {locales\n          .filter((item) => item.id !== locale.id)\n          .map((item) => {\n            const nextPath = getTargetLocalePath({\n              current: locale,\n              target: item\n            });\n            return (\n              <Menu.Item key={item.id}>\n                <a rel=\"noopener noreferrer\" href={nextPath}>\n                  {item.name}\n                </a>\n              </Menu.Item>\n            );\n          })}\n      </Menu.SubMenu>\n    );\n  }, [locale, locales]);\n\n  const moreLinksItems = getMoreLinksGroup(moreLinks) || [];\n  const additionalItems: React.ReactNode[] = [\n    github || socialLinks?.github ? (\n      <Menu.Item key=\"github\">\n        <a rel=\"noopener noreferrer\" href={github || socialLinks?.github} target=\"_blank\">\n          GitHub\n        </a>\n      </Menu.Item>\n    ) : null,\n    getLangNode(),\n    ...moreLinksItems\n      .filter((item) => item !== null)\n      .map((item) => {\n        const menuItem = item as { key: string; label: React.ReactNode; children?: any[] };\n        if (menuItem.children && menuItem.children.length > 0) {\n          return (\n            <Menu.SubMenu key={menuItem.key} title={menuItem.label}>\n              {menuItem.children\n                .filter((child) => child !== null)\n                .map((child) => {\n                  const childItem = child as { key: string; label: React.ReactNode };\n                  return <Menu.Item key={childItem.key}>{childItem.label}</Menu.Item>;\n                })}\n            </Menu.SubMenu>\n          );\n        }\n        return <Menu.Item key={menuItem.key}>{menuItem.label}</Menu.Item>;\n      })\n  ].filter(Boolean) as React.ReactNode[];\n\n  let additional: React.ReactNode[] = [];\n  if (isMobile) {\n    additional = additionalItems;\n  } else if (responsive === 'crowded') {\n    additional = [\n      <Menu.SubMenu key=\"additional\" title={<MenuFoldOutlined />}>\n        {additionalItems}\n      </Menu.SubMenu>\n    ];\n  }\n\n  const menuMode = isMobile ? 'inline' : 'horizontal';\n  const style = useStyle();\n  return (\n    <Menu mode={menuMode} css={style.nav} selectedKeys={[activeMenuItem]}>\n      {menuItems}\n      {additional}\n    </Menu>\n  );\n}\n"]} */")
|
|
25
25
|
};
|
|
26
26
|
};
|
|
27
27
|
export default function Navigation(_ref) {
|
|
@@ -148,7 +148,6 @@ export default function Navigation(_ref) {
|
|
|
148
148
|
return ___EmotionJSX(Menu, {
|
|
149
149
|
mode: menuMode,
|
|
150
150
|
css: style.nav,
|
|
151
|
-
selectedKeys: [activeMenuItem]
|
|
152
|
-
disabledOverflow: true
|
|
151
|
+
selectedKeys: [activeMenuItem]
|
|
153
152
|
}, menuItems, additional);
|
|
154
153
|
}
|
|
@@ -9,9 +9,9 @@ import { Col, Popover, Row, Select } from 'antd';
|
|
|
9
9
|
import classNames from 'classnames';
|
|
10
10
|
import { useLocale, useLocation } from 'dumi';
|
|
11
11
|
import DumiSearchBar from 'dumi/theme-default/slots/SearchBar';
|
|
12
|
-
import React, { useCallback, useContext, useEffect, useState } from 'react';
|
|
13
12
|
import LangSwitch from "dumi/theme/slots/LangSwitch";
|
|
14
13
|
import RtlSwitch from "dumi/theme/slots/RtlSwitch";
|
|
14
|
+
import React, { useCallback, useContext, useEffect, useState } from 'react';
|
|
15
15
|
import useAdditionalThemeConfig from "../../hooks/useAdditionalThemeConfig";
|
|
16
16
|
import useSiteToken from "../../hooks/useSiteToken";
|
|
17
17
|
import SiteContext from "dumi/theme/slots/SiteContext";
|
|
@@ -47,8 +47,8 @@ var useStyle = function useStyle() {
|
|
|
47
47
|
token = _useSiteToken.token;
|
|
48
48
|
var searchIconColor = '#ced4d9';
|
|
49
49
|
return {
|
|
50
|
-
header: /*#__PURE__*/css("position:sticky;top:0;z-index:99;max-width:100%;background:", token.colorBgContainer, ";box-shadow:", token.boxShadowTertiary, ";@media only screen and (max-width: ", token.mobileMaxWidth, "px){text-align:center;}.nav-search-wrapper{display:flex;flex:auto;}.dumi-default-search-bar{border-inline-start:1px solid rgba(0, 0, 0, 0.06);>svg{width:14px;fill:", searchIconColor, ";}>input{height:22px;border:0;&:focus{box-shadow:none;}&::placeholder{color:", searchIconColor, ";}}.dumi-default-search-shortcut{color:", searchIconColor, ";background-color:rgba(150, 150, 150, 0.06);border-color:rgba(100, 100, 100, 0.2);border-radius:4px;}.dumi-default-search-popover{inset-inline-start:11px;inset-inline-end:unset;&::before{inset-inline-start:100px;inset-inline-end:unset;}}}" + (process.env.NODE_ENV === "production" ? "" : ";label:header;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4De","file":"index.tsx","sourcesContent":["/* eslint-disable import/no-unresolved */\nimport { MenuOutlined } from '@ant-design/icons';\nimport { ClassNames, css } from '@emotion/react';\nimport { Col, Popover, Row, Select } from 'antd';\nimport classNames from 'classnames';\nimport { useLocale, useLocation } from 'dumi';\nimport DumiSearchBar from 'dumi/theme-default/slots/SearchBar';\nimport React, { useCallback, useContext, useEffect, useState, type FC } from 'react';\nimport LangSwitch from 'dumi/theme/slots/LangSwitch';\nimport RtlSwitch from 'dumi/theme/slots/RtlSwitch';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../SiteContext';\nimport SiteContext from '../SiteContext';\nimport HeaderExtra from './HeaderExtral';\nimport Logo from './Logo';\nimport More from './More';\nimport Navigation from './Navigation';\n\ninterface HeaderState {\n  windowWidth: number;\n  menuVisible: boolean;\n}\nexport type IResponsive = null | 'narrow' | 'crowded';\n\nconst RESPONSIVE_XS = 1120;\nconst RESPONSIVE_SM = 1200;\n\nconst colPropsHome = [\n  {\n    flex: 'none'\n  },\n  {\n    flex: 'auto'\n  }\n];\nconst _colProps = [\n  {\n    xxl: 4,\n    xl: 5,\n    lg: 6,\n    md: 6,\n    sm: 24,\n    xs: 24\n  },\n  {\n    xxl: 20,\n    xl: 19,\n    lg: 18,\n    md: 18,\n    sm: 0,\n    xs: 0\n  }\n];\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const searchIconColor = '#ced4d9';\n\n  return {\n    header: css`\n      position: sticky;\n      top: 0;\n      z-index: 99;\n      max-width: 100%;\n      background: ${token.colorBgContainer};\n      box-shadow: ${token.boxShadowTertiary};\n\n      @media only screen and (max-width: ${token.mobileMaxWidth}px) {\n        text-align: center;\n      }\n\n      .nav-search-wrapper {\n        display: flex;\n        flex: auto;\n      }\n\n      .dumi-default-search-bar {\n        border-inline-start: 1px solid rgba(0, 0, 0, 0.06);\n\n        > svg {\n          width: 14px;\n          fill: ${searchIconColor};\n        }\n\n        > input {\n          height: 22px;\n          border: 0;\n\n          &:focus {\n            box-shadow: none;\n          }\n\n          &::placeholder {\n            color: ${searchIconColor};\n          }\n        }\n\n        .dumi-default-search-shortcut {\n          color: ${searchIconColor};\n          background-color: rgba(150, 150, 150, 0.06);\n          border-color: rgba(100, 100, 100, 0.2);\n          border-radius: 4px;\n        }\n\n        .dumi-default-search-popover {\n          inset-inline-start: 11px;\n          inset-inline-end: unset;\n\n          &::before {\n            inset-inline-start: 100px;\n            inset-inline-end: unset;\n          }\n        }\n      }\n    `,\n    menuRow: css`\n      display: flex;\n      align-items: center;\n      margin: 0;\n\n      > * {\n        flex: none;\n        margin: 0 12px 0 0;\n\n        &:last-child {\n          margin-inline-end: 40px;\n        }\n      }\n\n      ${token.antCls}-row-rtl & {\n        > * {\n          &:last-child {\n            margin-right: 12px;\n            margin-left: 40px;\n          }\n        }\n      }\n    `,\n    popoverMenu: {\n      width: 300,\n\n      [`${token.antCls}-popover-inner-content`]: {\n        padding: 0\n      }\n    }\n  };\n};\n\nconst Header: FC = () => {\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const [headerState, setHeaderState] = useState<HeaderState>({\n    windowWidth: 1400,\n    menuVisible: false\n  });\n  const location = useLocation();\n  const { docVersions } = useAdditionalThemeConfig();\n\n  const onWindowResize = useCallback(() => {\n    if (typeof window === 'undefined') {\n      return;\n    }\n    setHeaderState((prev) => ({\n      ...prev,\n      windowWidth: window.innerWidth\n    }));\n  }, []);\n  const handleHideMenu = useCallback(() => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: false\n    }));\n  }, []);\n  const onMenuVisibleChange = useCallback((visible: boolean) => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: visible\n    }));\n  }, []);\n\n  const handleVersionChange = useCallback((url: string) => {\n    if (typeof window === 'undefined') {\n      return;\n    }\n    window.location.href = url;\n  }, []);\n\n  useEffect(() => {\n    handleHideMenu();\n  }, [location, handleHideMenu]);\n\n  useEffect(() => {\n    if (typeof window === 'undefined') {\n      return () => {};\n    }\n    onWindowResize();\n    window.addEventListener('resize', onWindowResize);\n    return () => {\n      window.removeEventListener('resize', onWindowResize);\n    };\n  }, [onWindowResize]);\n\n  const { pathname } = location;\n  const locale = useLocale();\n  const suffix: string = (locale as any).suffex || '';\n  const isHome = ['', `index${suffix}`].includes(pathname);\n  const { windowWidth, menuVisible } = headerState;\n  const style = useStyle();\n  const headerClassName = classNames({\n    clearfix: true,\n    'home-header': isHome\n  });\n  let responsive: IResponsive = null;\n\n  if (windowWidth < RESPONSIVE_XS) {\n    responsive = 'crowded';\n  } else if (windowWidth < RESPONSIVE_SM) {\n    responsive = 'narrow';\n  }\n\n  const navigationNode = <Navigation key=\"nav\" isMobile={isMobile} responsive={responsive} />;\n  const versionOptions = Object.keys(docVersions ?? {}).map((version) => ({\n    value: docVersions?.[version],\n    label: version\n  }));\n  let menu: (React.ReactElement | null)[] = [\n    navigationNode,\n    versionOptions.length > 0 ? (\n      <Select\n        key=\"version\"\n        size=\"small\"\n        defaultValue={versionOptions[0]?.value}\n        onChange={handleVersionChange}\n        popupMatchSelectWidth={false}\n        getPopupContainer={(trigger) => trigger.parentNode}\n        options={versionOptions}\n      />\n    ) : null,\n    <More key=\"more\" />,\n    <LangSwitch key={new Date().getTime()} />,\n    <RtlSwitch key=\"direction\" />,\n    <HeaderExtra key=\"header-Extra\" />\n  ];\n  if (windowWidth < RESPONSIVE_XS) {\n    menu = [navigationNode];\n  }\n\n  const colProps = isHome ? colPropsHome : _colProps;\n\n  return (\n    <header css={style.header} className={headerClassName}>\n      {isMobile && (\n        <ClassNames>\n          {({ css: cssFn }) => (\n            <Popover\n              overlayClassName={cssFn(style.popoverMenu)}\n              placement=\"bottomRight\"\n              content={menu}\n              trigger=\"click\"\n              open={menuVisible}\n              arrow\n              onOpenChange={onMenuVisibleChange}\n            >\n              <MenuOutlined className=\"nav-phone-icon\" />\n            </Popover>\n          )}\n        </ClassNames>\n      )}\n      <Row\n        style={{\n          height: 64\n        }}\n      >\n        <Col {...colProps[0]}>\n          <Logo />\n        </Col>\n        <Col {...colProps[1]} css={style.menuRow}>\n          <div className=\"nav-search-wrapper\">\n            <DumiSearchBar />\n          </div>\n          {!isMobile && menu}\n        </Col>\n      </Row>\n    </header>\n  );\n};\n\nexport default Header;\n"]} */"),
|
|
51
|
-
menuRow: /*#__PURE__*/css("display:flex;align-items:center;margin:0;>*{flex:none;margin:0 12px 0 0;&:last-child{margin-inline-end:40px;}}", token.antCls, "-row-rtl &{>*{&:last-child{margin-right:12px;margin-left:40px;}}}" + (process.env.NODE_ENV === "production" ? "" : ";label:menuRow;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoHgB","file":"index.tsx","sourcesContent":["/* eslint-disable import/no-unresolved */\nimport { MenuOutlined } from '@ant-design/icons';\nimport { ClassNames, css } from '@emotion/react';\nimport { Col, Popover, Row, Select } from 'antd';\nimport classNames from 'classnames';\nimport { useLocale, useLocation } from 'dumi';\nimport DumiSearchBar from 'dumi/theme-default/slots/SearchBar';\nimport React, { useCallback, useContext, useEffect, useState, type FC } from 'react';\nimport LangSwitch from 'dumi/theme/slots/LangSwitch';\nimport RtlSwitch from 'dumi/theme/slots/RtlSwitch';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../SiteContext';\nimport SiteContext from '../SiteContext';\nimport HeaderExtra from './HeaderExtral';\nimport Logo from './Logo';\nimport More from './More';\nimport Navigation from './Navigation';\n\ninterface HeaderState {\n  windowWidth: number;\n  menuVisible: boolean;\n}\nexport type IResponsive = null | 'narrow' | 'crowded';\n\nconst RESPONSIVE_XS = 1120;\nconst RESPONSIVE_SM = 1200;\n\nconst colPropsHome = [\n  {\n    flex: 'none'\n  },\n  {\n    flex: 'auto'\n  }\n];\nconst _colProps = [\n  {\n    xxl: 4,\n    xl: 5,\n    lg: 6,\n    md: 6,\n    sm: 24,\n    xs: 24\n  },\n  {\n    xxl: 20,\n    xl: 19,\n    lg: 18,\n    md: 18,\n    sm: 0,\n    xs: 0\n  }\n];\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const searchIconColor = '#ced4d9';\n\n  return {\n    header: css`\n      position: sticky;\n      top: 0;\n      z-index: 99;\n      max-width: 100%;\n      background: ${token.colorBgContainer};\n      box-shadow: ${token.boxShadowTertiary};\n\n      @media only screen and (max-width: ${token.mobileMaxWidth}px) {\n        text-align: center;\n      }\n\n      .nav-search-wrapper {\n        display: flex;\n        flex: auto;\n      }\n\n      .dumi-default-search-bar {\n        border-inline-start: 1px solid rgba(0, 0, 0, 0.06);\n\n        > svg {\n          width: 14px;\n          fill: ${searchIconColor};\n        }\n\n        > input {\n          height: 22px;\n          border: 0;\n\n          &:focus {\n            box-shadow: none;\n          }\n\n          &::placeholder {\n            color: ${searchIconColor};\n          }\n        }\n\n        .dumi-default-search-shortcut {\n          color: ${searchIconColor};\n          background-color: rgba(150, 150, 150, 0.06);\n          border-color: rgba(100, 100, 100, 0.2);\n          border-radius: 4px;\n        }\n\n        .dumi-default-search-popover {\n          inset-inline-start: 11px;\n          inset-inline-end: unset;\n\n          &::before {\n            inset-inline-start: 100px;\n            inset-inline-end: unset;\n          }\n        }\n      }\n    `,\n    menuRow: css`\n      display: flex;\n      align-items: center;\n      margin: 0;\n\n      > * {\n        flex: none;\n        margin: 0 12px 0 0;\n\n        &:last-child {\n          margin-inline-end: 40px;\n        }\n      }\n\n      ${token.antCls}-row-rtl & {\n        > * {\n          &:last-child {\n            margin-right: 12px;\n            margin-left: 40px;\n          }\n        }\n      }\n    `,\n    popoverMenu: {\n      width: 300,\n\n      [`${token.antCls}-popover-inner-content`]: {\n        padding: 0\n      }\n    }\n  };\n};\n\nconst Header: FC = () => {\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const [headerState, setHeaderState] = useState<HeaderState>({\n    windowWidth: 1400,\n    menuVisible: false\n  });\n  const location = useLocation();\n  const { docVersions } = useAdditionalThemeConfig();\n\n  const onWindowResize = useCallback(() => {\n    if (typeof window === 'undefined') {\n      return;\n    }\n    setHeaderState((prev) => ({\n      ...prev,\n      windowWidth: window.innerWidth\n    }));\n  }, []);\n  const handleHideMenu = useCallback(() => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: false\n    }));\n  }, []);\n  const onMenuVisibleChange = useCallback((visible: boolean) => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: visible\n    }));\n  }, []);\n\n  const handleVersionChange = useCallback((url: string) => {\n    if (typeof window === 'undefined') {\n      return;\n    }\n    window.location.href = url;\n  }, []);\n\n  useEffect(() => {\n    handleHideMenu();\n  }, [location, handleHideMenu]);\n\n  useEffect(() => {\n    if (typeof window === 'undefined') {\n      return () => {};\n    }\n    onWindowResize();\n    window.addEventListener('resize', onWindowResize);\n    return () => {\n      window.removeEventListener('resize', onWindowResize);\n    };\n  }, [onWindowResize]);\n\n  const { pathname } = location;\n  const locale = useLocale();\n  const suffix: string = (locale as any).suffex || '';\n  const isHome = ['', `index${suffix}`].includes(pathname);\n  const { windowWidth, menuVisible } = headerState;\n  const style = useStyle();\n  const headerClassName = classNames({\n    clearfix: true,\n    'home-header': isHome\n  });\n  let responsive: IResponsive = null;\n\n  if (windowWidth < RESPONSIVE_XS) {\n    responsive = 'crowded';\n  } else if (windowWidth < RESPONSIVE_SM) {\n    responsive = 'narrow';\n  }\n\n  const navigationNode = <Navigation key=\"nav\" isMobile={isMobile} responsive={responsive} />;\n  const versionOptions = Object.keys(docVersions ?? {}).map((version) => ({\n    value: docVersions?.[version],\n    label: version\n  }));\n  let menu: (React.ReactElement | null)[] = [\n    navigationNode,\n    versionOptions.length > 0 ? (\n      <Select\n        key=\"version\"\n        size=\"small\"\n        defaultValue={versionOptions[0]?.value}\n        onChange={handleVersionChange}\n        popupMatchSelectWidth={false}\n        getPopupContainer={(trigger) => trigger.parentNode}\n        options={versionOptions}\n      />\n    ) : null,\n    <More key=\"more\" />,\n    <LangSwitch key={new Date().getTime()} />,\n    <RtlSwitch key=\"direction\" />,\n    <HeaderExtra key=\"header-Extra\" />\n  ];\n  if (windowWidth < RESPONSIVE_XS) {\n    menu = [navigationNode];\n  }\n\n  const colProps = isHome ? colPropsHome : _colProps;\n\n  return (\n    <header css={style.header} className={headerClassName}>\n      {isMobile && (\n        <ClassNames>\n          {({ css: cssFn }) => (\n            <Popover\n              overlayClassName={cssFn(style.popoverMenu)}\n              placement=\"bottomRight\"\n              content={menu}\n              trigger=\"click\"\n              open={menuVisible}\n              arrow\n              onOpenChange={onMenuVisibleChange}\n            >\n              <MenuOutlined className=\"nav-phone-icon\" />\n            </Popover>\n          )}\n        </ClassNames>\n      )}\n      <Row\n        style={{\n          height: 64\n        }}\n      >\n        <Col {...colProps[0]}>\n          <Logo />\n        </Col>\n        <Col {...colProps[1]} css={style.menuRow}>\n          <div className=\"nav-search-wrapper\">\n            <DumiSearchBar />\n          </div>\n          {!isMobile && menu}\n        </Col>\n      </Row>\n    </header>\n  );\n};\n\nexport default Header;\n"]} */"),
|
|
50
|
+
header: /*#__PURE__*/css("position:sticky;top:0;z-index:99;max-width:100%;background:", token.colorBgContainer, ";box-shadow:", token.boxShadowTertiary, ";@media only screen and (max-width: ", token.mobileMaxWidth, "px){text-align:center;}.nav-search-wrapper{display:flex;flex:auto;}.dumi-default-search-bar{border-inline-start:1px solid rgba(0, 0, 0, 0.06);>svg{width:14px;fill:", searchIconColor, ";}>input{height:22px;border:0;&:focus{box-shadow:none;}&::placeholder{color:", searchIconColor, ";}}.dumi-default-search-shortcut{color:", searchIconColor, ";background-color:rgba(150, 150, 150, 0.06);border-color:rgba(100, 100, 100, 0.2);border-radius:4px;}.dumi-default-search-popover{inset-inline-start:11px;inset-inline-end:unset;&::before{inset-inline-start:100px;inset-inline-end:unset;}}}" + (process.env.NODE_ENV === "production" ? "" : ";label:header;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4De","file":"index.tsx","sourcesContent":["/* eslint-disable import/no-unresolved */\nimport { MenuOutlined } from '@ant-design/icons';\nimport { ClassNames, css } from '@emotion/react';\nimport { Col, Popover, Row, Select } from 'antd';\nimport classNames from 'classnames';\nimport { useLocale, useLocation } from 'dumi';\nimport DumiSearchBar from 'dumi/theme-default/slots/SearchBar';\nimport LangSwitch from 'dumi/theme/slots/LangSwitch';\nimport RtlSwitch from 'dumi/theme/slots/RtlSwitch';\nimport React, { useCallback, useContext, useEffect, useState, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../SiteContext';\nimport SiteContext from '../SiteContext';\nimport HeaderExtra from './HeaderExtral';\nimport Logo from './Logo';\nimport More from './More';\nimport Navigation from './Navigation';\n\ninterface HeaderState {\n  windowWidth: number;\n  menuVisible: boolean;\n}\nexport type IResponsive = null | 'narrow' | 'crowded';\n\nconst RESPONSIVE_XS = 1120;\nconst RESPONSIVE_SM = 1200;\n\nconst colPropsHome = [\n  {\n    flex: 'none'\n  },\n  {\n    flex: 'auto'\n  }\n];\nconst _colProps = [\n  {\n    xxl: 4,\n    xl: 5,\n    lg: 6,\n    md: 6,\n    sm: 24,\n    xs: 24\n  },\n  {\n    xxl: 20,\n    xl: 19,\n    lg: 18,\n    md: 18,\n    sm: 0,\n    xs: 0\n  }\n];\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const searchIconColor = '#ced4d9';\n\n  return {\n    header: css`\n      position: sticky;\n      top: 0;\n      z-index: 99;\n      max-width: 100%;\n      background: ${token.colorBgContainer};\n      box-shadow: ${token.boxShadowTertiary};\n\n      @media only screen and (max-width: ${token.mobileMaxWidth}px) {\n        text-align: center;\n      }\n\n      .nav-search-wrapper {\n        display: flex;\n        flex: auto;\n      }\n\n      .dumi-default-search-bar {\n        border-inline-start: 1px solid rgba(0, 0, 0, 0.06);\n\n        > svg {\n          width: 14px;\n          fill: ${searchIconColor};\n        }\n\n        > input {\n          height: 22px;\n          border: 0;\n\n          &:focus {\n            box-shadow: none;\n          }\n\n          &::placeholder {\n            color: ${searchIconColor};\n          }\n        }\n\n        .dumi-default-search-shortcut {\n          color: ${searchIconColor};\n          background-color: rgba(150, 150, 150, 0.06);\n          border-color: rgba(100, 100, 100, 0.2);\n          border-radius: 4px;\n        }\n\n        .dumi-default-search-popover {\n          inset-inline-start: 11px;\n          inset-inline-end: unset;\n\n          &::before {\n            inset-inline-start: 100px;\n            inset-inline-end: unset;\n          }\n        }\n      }\n    `,\n    menuRow: css`\n      display: flex;\n      align-items: center;\n      margin: 0;\n\n      > * {\n        flex: none;\n        margin: 0 12px 0 0;\n\n        &:last-child {\n          margin-inline-end: 40px;\n        }\n      }\n\n      ${token.antCls}-row-rtl & {\n        > * {\n          &:last-child {\n            margin-right: 12px;\n            margin-left: 40px;\n          }\n        }\n      }\n    `,\n    popoverMenu: {\n      width: 300,\n\n      [`${token.antCls}-popover-inner-content`]: {\n        padding: 0\n      }\n    }\n  };\n};\n\nconst Header: FC = () => {\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const [headerState, setHeaderState] = useState<HeaderState>({\n    windowWidth: 1400,\n    menuVisible: false\n  });\n  const location = useLocation();\n  const { docVersions } = useAdditionalThemeConfig();\n\n  const onWindowResize = useCallback(() => {\n    if (typeof window === 'undefined') {\n      return;\n    }\n    setHeaderState((prev) => ({\n      ...prev,\n      windowWidth: window.innerWidth\n    }));\n  }, []);\n  const handleHideMenu = useCallback(() => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: false\n    }));\n  }, []);\n  const onMenuVisibleChange = useCallback((visible: boolean) => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: visible\n    }));\n  }, []);\n\n  const handleVersionChange = useCallback((url: string) => {\n    if (typeof window === 'undefined') {\n      return;\n    }\n    window.location.href = url;\n  }, []);\n\n  useEffect(() => {\n    handleHideMenu();\n  }, [location, handleHideMenu]);\n\n  useEffect(() => {\n    if (typeof window === 'undefined') {\n      return () => {};\n    }\n    onWindowResize();\n    window.addEventListener('resize', onWindowResize);\n    return () => {\n      window.removeEventListener('resize', onWindowResize);\n    };\n  }, [onWindowResize]);\n\n  const { pathname } = location;\n  const locale = useLocale();\n  const suffix: string = (locale as any).suffex || '';\n  const isHome = ['', `index${suffix}`].includes(pathname);\n  const { windowWidth, menuVisible } = headerState;\n  const style = useStyle();\n  const headerClassName = classNames({\n    clearfix: true,\n    'home-header': isHome\n  });\n  let responsive: IResponsive = null;\n\n  if (windowWidth < RESPONSIVE_XS) {\n    responsive = 'crowded';\n  } else if (windowWidth < RESPONSIVE_SM) {\n    responsive = 'narrow';\n  }\n\n  const navigationNode = <Navigation key=\"nav\" isMobile={isMobile} responsive={responsive} />;\n  const versionOptions = Object.keys(docVersions ?? {}).map((version) => ({\n    value: docVersions?.[version],\n    label: version\n  }));\n  let menu: (React.ReactElement | null)[] = [\n    navigationNode,\n    versionOptions.length > 0 ? (\n      <Select\n        key=\"version\"\n        size=\"small\"\n        defaultValue={versionOptions[0]?.value}\n        onChange={handleVersionChange}\n        dropdownMatchSelectWidth={false}\n        getPopupContainer={(trigger) => trigger.parentNode}\n      >\n        {versionOptions.map((option) => (\n          <Select.Option key={option.value} value={option.value}>\n            {option.label}\n          </Select.Option>\n        ))}\n      </Select>\n    ) : null,\n    <More key=\"more\" />,\n    <LangSwitch key={new Date().getTime()} />,\n    <RtlSwitch key=\"direction\" />,\n    <HeaderExtra key=\"header-Extra\" />\n  ];\n  if (windowWidth < RESPONSIVE_XS) {\n    menu = [navigationNode];\n  }\n\n  const colProps = isHome ? colPropsHome : _colProps;\n\n  return (\n    <header css={style.header} className={headerClassName}>\n      {isMobile && (\n        <ClassNames>\n          {({ css: cssFn }) => (\n            <Popover\n              overlayClassName={cssFn(style.popoverMenu)}\n              placement=\"bottomRight\"\n              content={menu}\n              trigger=\"click\"\n              open={menuVisible}\n              arrow\n              onOpenChange={onMenuVisibleChange}\n            >\n              <MenuOutlined className=\"nav-phone-icon\" />\n            </Popover>\n          )}\n        </ClassNames>\n      )}\n      <Row\n        style={{\n          height: 64\n        }}\n      >\n        <Col {...colProps[0]}>\n          <Logo />\n        </Col>\n        <Col {...colProps[1]} css={style.menuRow}>\n          <div className=\"nav-search-wrapper\">\n            <DumiSearchBar />\n          </div>\n          {!isMobile && menu}\n        </Col>\n      </Row>\n    </header>\n  );\n};\n\nexport default Header;\n"]} */"),
|
|
51
|
+
menuRow: /*#__PURE__*/css("display:flex;align-items:center;margin:0;>*{flex:none;margin:0 12px 0 0;&:last-child{margin-inline-end:40px;}}", token.antCls, "-row-rtl &{>*{&:last-child{margin-right:12px;margin-left:40px;}}}" + (process.env.NODE_ENV === "production" ? "" : ";label:menuRow;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoHgB","file":"index.tsx","sourcesContent":["/* eslint-disable import/no-unresolved */\nimport { MenuOutlined } from '@ant-design/icons';\nimport { ClassNames, css } from '@emotion/react';\nimport { Col, Popover, Row, Select } from 'antd';\nimport classNames from 'classnames';\nimport { useLocale, useLocation } from 'dumi';\nimport DumiSearchBar from 'dumi/theme-default/slots/SearchBar';\nimport LangSwitch from 'dumi/theme/slots/LangSwitch';\nimport RtlSwitch from 'dumi/theme/slots/RtlSwitch';\nimport React, { useCallback, useContext, useEffect, useState, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport type { SiteContextProps } from '../SiteContext';\nimport SiteContext from '../SiteContext';\nimport HeaderExtra from './HeaderExtral';\nimport Logo from './Logo';\nimport More from './More';\nimport Navigation from './Navigation';\n\ninterface HeaderState {\n  windowWidth: number;\n  menuVisible: boolean;\n}\nexport type IResponsive = null | 'narrow' | 'crowded';\n\nconst RESPONSIVE_XS = 1120;\nconst RESPONSIVE_SM = 1200;\n\nconst colPropsHome = [\n  {\n    flex: 'none'\n  },\n  {\n    flex: 'auto'\n  }\n];\nconst _colProps = [\n  {\n    xxl: 4,\n    xl: 5,\n    lg: 6,\n    md: 6,\n    sm: 24,\n    xs: 24\n  },\n  {\n    xxl: 20,\n    xl: 19,\n    lg: 18,\n    md: 18,\n    sm: 0,\n    xs: 0\n  }\n];\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const searchIconColor = '#ced4d9';\n\n  return {\n    header: css`\n      position: sticky;\n      top: 0;\n      z-index: 99;\n      max-width: 100%;\n      background: ${token.colorBgContainer};\n      box-shadow: ${token.boxShadowTertiary};\n\n      @media only screen and (max-width: ${token.mobileMaxWidth}px) {\n        text-align: center;\n      }\n\n      .nav-search-wrapper {\n        display: flex;\n        flex: auto;\n      }\n\n      .dumi-default-search-bar {\n        border-inline-start: 1px solid rgba(0, 0, 0, 0.06);\n\n        > svg {\n          width: 14px;\n          fill: ${searchIconColor};\n        }\n\n        > input {\n          height: 22px;\n          border: 0;\n\n          &:focus {\n            box-shadow: none;\n          }\n\n          &::placeholder {\n            color: ${searchIconColor};\n          }\n        }\n\n        .dumi-default-search-shortcut {\n          color: ${searchIconColor};\n          background-color: rgba(150, 150, 150, 0.06);\n          border-color: rgba(100, 100, 100, 0.2);\n          border-radius: 4px;\n        }\n\n        .dumi-default-search-popover {\n          inset-inline-start: 11px;\n          inset-inline-end: unset;\n\n          &::before {\n            inset-inline-start: 100px;\n            inset-inline-end: unset;\n          }\n        }\n      }\n    `,\n    menuRow: css`\n      display: flex;\n      align-items: center;\n      margin: 0;\n\n      > * {\n        flex: none;\n        margin: 0 12px 0 0;\n\n        &:last-child {\n          margin-inline-end: 40px;\n        }\n      }\n\n      ${token.antCls}-row-rtl & {\n        > * {\n          &:last-child {\n            margin-right: 12px;\n            margin-left: 40px;\n          }\n        }\n      }\n    `,\n    popoverMenu: {\n      width: 300,\n\n      [`${token.antCls}-popover-inner-content`]: {\n        padding: 0\n      }\n    }\n  };\n};\n\nconst Header: FC = () => {\n  const { isMobile } = useContext<SiteContextProps>(SiteContext);\n  const [headerState, setHeaderState] = useState<HeaderState>({\n    windowWidth: 1400,\n    menuVisible: false\n  });\n  const location = useLocation();\n  const { docVersions } = useAdditionalThemeConfig();\n\n  const onWindowResize = useCallback(() => {\n    if (typeof window === 'undefined') {\n      return;\n    }\n    setHeaderState((prev) => ({\n      ...prev,\n      windowWidth: window.innerWidth\n    }));\n  }, []);\n  const handleHideMenu = useCallback(() => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: false\n    }));\n  }, []);\n  const onMenuVisibleChange = useCallback((visible: boolean) => {\n    setHeaderState((prev) => ({\n      ...prev,\n      menuVisible: visible\n    }));\n  }, []);\n\n  const handleVersionChange = useCallback((url: string) => {\n    if (typeof window === 'undefined') {\n      return;\n    }\n    window.location.href = url;\n  }, []);\n\n  useEffect(() => {\n    handleHideMenu();\n  }, [location, handleHideMenu]);\n\n  useEffect(() => {\n    if (typeof window === 'undefined') {\n      return () => {};\n    }\n    onWindowResize();\n    window.addEventListener('resize', onWindowResize);\n    return () => {\n      window.removeEventListener('resize', onWindowResize);\n    };\n  }, [onWindowResize]);\n\n  const { pathname } = location;\n  const locale = useLocale();\n  const suffix: string = (locale as any).suffex || '';\n  const isHome = ['', `index${suffix}`].includes(pathname);\n  const { windowWidth, menuVisible } = headerState;\n  const style = useStyle();\n  const headerClassName = classNames({\n    clearfix: true,\n    'home-header': isHome\n  });\n  let responsive: IResponsive = null;\n\n  if (windowWidth < RESPONSIVE_XS) {\n    responsive = 'crowded';\n  } else if (windowWidth < RESPONSIVE_SM) {\n    responsive = 'narrow';\n  }\n\n  const navigationNode = <Navigation key=\"nav\" isMobile={isMobile} responsive={responsive} />;\n  const versionOptions = Object.keys(docVersions ?? {}).map((version) => ({\n    value: docVersions?.[version],\n    label: version\n  }));\n  let menu: (React.ReactElement | null)[] = [\n    navigationNode,\n    versionOptions.length > 0 ? (\n      <Select\n        key=\"version\"\n        size=\"small\"\n        defaultValue={versionOptions[0]?.value}\n        onChange={handleVersionChange}\n        dropdownMatchSelectWidth={false}\n        getPopupContainer={(trigger) => trigger.parentNode}\n      >\n        {versionOptions.map((option) => (\n          <Select.Option key={option.value} value={option.value}>\n            {option.label}\n          </Select.Option>\n        ))}\n      </Select>\n    ) : null,\n    <More key=\"more\" />,\n    <LangSwitch key={new Date().getTime()} />,\n    <RtlSwitch key=\"direction\" />,\n    <HeaderExtra key=\"header-Extra\" />\n  ];\n  if (windowWidth < RESPONSIVE_XS) {\n    menu = [navigationNode];\n  }\n\n  const colProps = isHome ? colPropsHome : _colProps;\n\n  return (\n    <header css={style.header} className={headerClassName}>\n      {isMobile && (\n        <ClassNames>\n          {({ css: cssFn }) => (\n            <Popover\n              overlayClassName={cssFn(style.popoverMenu)}\n              placement=\"bottomRight\"\n              content={menu}\n              trigger=\"click\"\n              open={menuVisible}\n              arrow\n              onOpenChange={onMenuVisibleChange}\n            >\n              <MenuOutlined className=\"nav-phone-icon\" />\n            </Popover>\n          )}\n        </ClassNames>\n      )}\n      <Row\n        style={{\n          height: 64\n        }}\n      >\n        <Col {...colProps[0]}>\n          <Logo />\n        </Col>\n        <Col {...colProps[1]} css={style.menuRow}>\n          <div className=\"nav-search-wrapper\">\n            <DumiSearchBar />\n          </div>\n          {!isMobile && menu}\n        </Col>\n      </Row>\n    </header>\n  );\n};\n\nexport default Header;\n"]} */"),
|
|
52
52
|
popoverMenu: _defineProperty({
|
|
53
53
|
width: 300
|
|
54
54
|
}, "".concat(token.antCls, "-popover-inner-content"), {
|
|
@@ -146,12 +146,16 @@ var Header = function Header() {
|
|
|
146
146
|
size: "small",
|
|
147
147
|
defaultValue: (_versionOptions$ = versionOptions[0]) === null || _versionOptions$ === void 0 ? void 0 : _versionOptions$.value,
|
|
148
148
|
onChange: handleVersionChange,
|
|
149
|
-
|
|
149
|
+
dropdownMatchSelectWidth: false,
|
|
150
150
|
getPopupContainer: function getPopupContainer(trigger) {
|
|
151
151
|
return trigger.parentNode;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
|
|
152
|
+
}
|
|
153
|
+
}, versionOptions.map(function (option) {
|
|
154
|
+
return ___EmotionJSX(Select.Option, {
|
|
155
|
+
key: option.value,
|
|
156
|
+
value: option.value
|
|
157
|
+
}, option.label);
|
|
158
|
+
})) : null, ___EmotionJSX(More, {
|
|
155
159
|
key: "more"
|
|
156
160
|
}), ___EmotionJSX(LangSwitch, {
|
|
157
161
|
key: new Date().getTime()
|
|
@@ -48,7 +48,7 @@ var LangSwitch = function LangSwitch() {
|
|
|
48
48
|
return item.id !== locale;
|
|
49
49
|
})[0].id);
|
|
50
50
|
}, [locale, handleLangChange, locales]);
|
|
51
|
-
var LangSwitchJSX;
|
|
51
|
+
var LangSwitchJSX = null;
|
|
52
52
|
// do not render in single language
|
|
53
53
|
if (locales.length > 2 || !localesEnhance && locales.length > 2) {
|
|
54
54
|
var langOptions = locales.map(function (lang) {
|
|
@@ -63,7 +63,7 @@ var LangSwitch = function LangSwitch() {
|
|
|
63
63
|
size: "small",
|
|
64
64
|
defaultValue: locale,
|
|
65
65
|
onChange: handleLangChange,
|
|
66
|
-
|
|
66
|
+
dropdownMatchSelectWidth: false,
|
|
67
67
|
getPopupContainer: function getPopupContainer(trigger) {
|
|
68
68
|
return trigger.parentNode;
|
|
69
69
|
}
|