docs: fix footer PrevAndNext icons in RTL (#42837)

* fix: footer PrevAndNext rtl

* chore: adjust

* Update useMenu.tsx

---------

Co-authored-by: lijianan <574980606@qq.com>
pull/42858/head
未觉雨声 2 years ago committed by GitHub
parent 2710923800
commit e2eab5d813
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -1,15 +1,14 @@
import type { ReactNode } from 'react';
import React, { useMemo } from 'react';
import type { MenuProps } from 'antd';
import { useFullSidebarData, useSidebarData } from 'dumi';
import { Tag, theme } from 'antd';
import useLocation from './useLocation';
import { useFullSidebarData, useSidebarData } from 'dumi';
import React, { useMemo } from 'react';
import Link from '../theme/common/Link';
import useLocation from './useLocation';
export type UseMenuOptions = {
before?: ReactNode;
after?: ReactNode;
};
export interface UseMenuOptions {
before?: React.ReactNode;
after?: React.ReactNode;
}
const useMenu = (options: UseMenuOptions = {}): [MenuProps['items'], string] => {
const fullData = useFullSidebarData();
@ -145,7 +144,7 @@ const useMenu = (options: UseMenuOptions = {}): [MenuProps['items'], string] =>
return result;
}, []) ?? []
);
}, [sidebarData, fullData, pathname, search]);
}, [sidebarData, fullData, pathname, search, options]);
return [menuItems, pathname];
};

@ -1,10 +1,10 @@
import type { ReactElement } from 'react';
import React, { useMemo } from 'react';
import type { MenuProps } from 'antd';
import type { MenuItemType } from 'antd/es/menu/hooks/useItems';
import { LeftOutlined, RightOutlined } from '@ant-design/icons';
import type { MenuProps } from 'antd';
import { createStyles, css } from 'antd-style';
import type { MenuItemType } from 'antd/es/menu/hooks/useItems';
import classNames from 'classnames';
import type { ReactElement } from 'react';
import React, { useMemo } from 'react';
import useMenu from '../../hooks/useMenu';
const useStyle = createStyles(({ token }) => {
@ -44,15 +44,15 @@ const useStyle = createStyles(({ token }) => {
.footer-nav-icon-before {
position: relative;
margin-inline-end: 1em;
vertical-align: middle;
line-height: 0;
right: 0;
transition: right 0.3s;
vertical-align: middle;
transition: inset-inline-end 0.3s;
margin-inline-end: 1em;
inset-inline-end: 0;
}
&:hover .footer-nav-icon-before {
right: 0.2em;
inset-inline-end: 0.2em;
}
`,
nextNav: css`
@ -64,16 +64,16 @@ const useStyle = createStyles(({ token }) => {
.footer-nav-icon-after {
position: relative;
margin-inline-start: 1em;
margin-bottom: 1px;
vertical-align: middle;
line-height: 0;
left: 0;
transition: left 0.3s;
vertical-align: middle;
transition: inset-inline-start 0.3s;
margin-inline-start: 1em;
inset-inline-start: 0;
}
&:hover .footer-nav-icon-after {
left: 0.2em;
inset-inline-start: 0.2em;
}
`,
};
@ -100,8 +100,8 @@ const PrevAndNext: React.FC<{ rtl?: boolean }> = ({ rtl }) => {
const beforeProps = { className: 'footer-nav-icon-before' };
const afterProps = { className: 'footer-nav-icon-after' };
const before = rtl ? <LeftOutlined {...beforeProps} /> : <RightOutlined {...beforeProps} />;
const after = rtl ? <RightOutlined {...afterProps} /> : <LeftOutlined {...afterProps} />;
const before = rtl ? <RightOutlined {...beforeProps} /> : <LeftOutlined {...beforeProps} />;
const after = rtl ? <LeftOutlined {...afterProps} /> : <RightOutlined {...afterProps} />;
const [menuItems, selectedKey] = useMenu({ before, after });

Loading…
Cancel
Save