mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-18 14:13:37 +08:00
commit
a64f73a83d
@ -173,12 +173,13 @@ const AnchorContent: React.FC<InternalAnchorProps> = (props) => {
|
||||
`.${prefixCls}-link-title-active`,
|
||||
);
|
||||
if (linkNode && spanLinkNode.current) {
|
||||
if (anchorDirection !== 'horizontal') {
|
||||
spanLinkNode.current.style.top = `${linkNode.offsetTop + linkNode.clientHeight / 2}px`;
|
||||
spanLinkNode.current.style.height = `${linkNode.clientHeight}px`;
|
||||
} else {
|
||||
spanLinkNode.current.style.left = `${linkNode.offsetLeft}px`;
|
||||
spanLinkNode.current.style.width = `${linkNode.clientWidth}px`;
|
||||
const { style: inkStyle } = spanLinkNode.current;
|
||||
const horizontalAnchor = anchorDirection === 'horizontal';
|
||||
inkStyle.top = horizontalAnchor ? '' : `${linkNode.offsetTop + linkNode.clientHeight / 2}px`;
|
||||
inkStyle.height = horizontalAnchor ? '' : `${linkNode.clientHeight}px`;
|
||||
inkStyle.left = horizontalAnchor ? `${linkNode.offsetLeft}px` : '';
|
||||
inkStyle.width = horizontalAnchor ? `${linkNode.clientWidth}px` : '';
|
||||
if (horizontalAnchor) {
|
||||
scrollIntoView(linkNode, {
|
||||
scrollMode: 'if-needed',
|
||||
block: 'nearest',
|
||||
|
@ -1,9 +1,10 @@
|
||||
import React from 'react';
|
||||
import React, { useState } from 'react';
|
||||
import { resetWarned } from 'rc-util/lib/warning';
|
||||
import scrollIntoView from 'scroll-into-view-if-needed';
|
||||
|
||||
import Anchor from '..';
|
||||
import { fireEvent, render, waitFakeTimer } from '../../../tests/utils';
|
||||
import { act, fireEvent, render, waitFakeTimer } from '../../../tests/utils';
|
||||
import type { AnchorDirection } from '../Anchor';
|
||||
|
||||
const { Link } = Anchor;
|
||||
|
||||
@ -886,5 +887,54 @@ describe('Anchor Render', () => {
|
||||
'Warning: [antd: Anchor.Link] `Anchor.Link children` is not supported when `Anchor` direction is horizontal',
|
||||
);
|
||||
});
|
||||
it('switch direction', async () => {
|
||||
const Foo: React.FC = () => {
|
||||
const [direction, setDirection] = useState<AnchorDirection>('vertical');
|
||||
const toggle = () => {
|
||||
setDirection(direction === 'vertical' ? 'horizontal' : 'vertical');
|
||||
};
|
||||
return (
|
||||
<div>
|
||||
<button onClick={toggle} type="button">
|
||||
toggle
|
||||
</button>
|
||||
<Anchor
|
||||
direction={direction}
|
||||
items={[
|
||||
{
|
||||
title: 'part-1',
|
||||
href: 'part-1',
|
||||
key: 'part-1',
|
||||
},
|
||||
{
|
||||
title: 'part-2',
|
||||
href: 'part-2',
|
||||
key: 'part-2',
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
const wrapper = await render(<Foo />);
|
||||
(await wrapper.findByText('part-1')).click();
|
||||
await waitFakeTimer();
|
||||
const ink = wrapper.container.querySelector<HTMLSpanElement>('.ant-anchor-ink')!;
|
||||
const toggleButton = wrapper.container.querySelector('button')!;
|
||||
|
||||
fireEvent.click(toggleButton);
|
||||
act(() => jest.runAllTimers());
|
||||
expect(!!ink.style.left).toBe(true);
|
||||
expect(!!ink.style.width).toBe(true);
|
||||
expect(ink.style.top).toBe('');
|
||||
expect(ink.style.height).toBe('');
|
||||
|
||||
fireEvent.click(toggleButton);
|
||||
act(() => jest.runAllTimers());
|
||||
expect(!!ink.style.top).toBe(true);
|
||||
expect(!!ink.style.height).toBe(true);
|
||||
expect(ink.style.left).toBe('');
|
||||
expect(ink.style.width).toBe('');
|
||||
});
|
||||
});
|
||||
});
|
||||
|
@ -69,7 +69,7 @@ const genSharedAnchorStyle: GenerateStyle<AnchorToken> = (token): CSSObject => {
|
||||
},
|
||||
},
|
||||
|
||||
[`&:not(${componentCls}-horizontal)`]: {
|
||||
[`&:not(${componentCls}-wrapper-horizontal)`]: {
|
||||
[componentCls]: {
|
||||
'&::before': {
|
||||
position: 'absolute',
|
||||
|
@ -33,6 +33,8 @@ export interface BreadcrumbItemType {
|
||||
menu?: BreadcrumbItemProps['menu'];
|
||||
/** @deprecated Please use `menu` instead */
|
||||
overlay?: React.ReactNode;
|
||||
className?: string;
|
||||
onClick?: React.MouseEventHandler<HTMLAnchorElement | HTMLSpanElement>;
|
||||
}
|
||||
export interface BreadcrumbSeparatorType {
|
||||
type: 'separator';
|
||||
@ -145,7 +147,16 @@ const Breadcrumb: CompoundedComponent = (props) => {
|
||||
const itemRenderRoutes: any = items || legacyRoutes;
|
||||
|
||||
crumbs = mergedItems.map((item, index) => {
|
||||
const { path, key, type, menu, overlay, separator: itemSeparator } = item;
|
||||
const {
|
||||
path,
|
||||
key,
|
||||
type,
|
||||
menu,
|
||||
overlay,
|
||||
onClick,
|
||||
className: itemClassName,
|
||||
separator: itemSeparator,
|
||||
} = item;
|
||||
const mergedPath = getPath(params, path);
|
||||
|
||||
if (mergedPath !== undefined) {
|
||||
@ -167,6 +178,10 @@ const Breadcrumb: CompoundedComponent = (props) => {
|
||||
itemProps.overlay = overlay as any;
|
||||
}
|
||||
|
||||
if (itemClassName) {
|
||||
itemProps.className = itemClassName;
|
||||
}
|
||||
|
||||
let { href } = item;
|
||||
if (paths.length && mergedPath !== undefined) {
|
||||
href = `#/${paths.join('/')}`;
|
||||
@ -182,6 +197,7 @@ const Breadcrumb: CompoundedComponent = (props) => {
|
||||
})}
|
||||
href={href}
|
||||
separator={isLastItem ? '' : separator}
|
||||
onClick={onClick}
|
||||
>
|
||||
{mergedItemRender(item as BreadcrumbItemType, params, itemRenderRoutes, paths)}
|
||||
</BreadcrumbItem>
|
||||
|
@ -329,4 +329,18 @@ describe('Breadcrumb', () => {
|
||||
expect(errSpy).not.toHaveBeenCalled();
|
||||
errSpy.mockRestore();
|
||||
});
|
||||
|
||||
it('should use `onClick`', async () => {
|
||||
const onClick = jest.fn();
|
||||
const wrapper = render(<Breadcrumb items={[{ title: 'test', onClick }]} />);
|
||||
const item = await wrapper.findByText('test');
|
||||
item.click();
|
||||
expect(onClick).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
it('should use `className`', async () => {
|
||||
const testClassName = 'testClassName';
|
||||
const wrapper = render(<Breadcrumb items={[{ title: 'test', className: testClassName }]} />);
|
||||
const item = await wrapper.findByText('test');
|
||||
expect(item).toHaveClass(testClassName);
|
||||
});
|
||||
});
|
||||
|
@ -520,7 +520,7 @@ export default genComponentStyleHook('Button', (token) => {
|
||||
genGroupStyle(buttonToken),
|
||||
|
||||
// Space Compact
|
||||
genCompactItemStyle(token, { focus: false }),
|
||||
genCompactItemStyle(token),
|
||||
genCompactItemVerticalStyle(token),
|
||||
];
|
||||
});
|
||||
|
@ -14,8 +14,8 @@ const App: React.FC = () => {
|
||||
if (!dates) {
|
||||
return false;
|
||||
}
|
||||
const tooLate = dates[0] && current.diff(dates[0], 'days') > 7;
|
||||
const tooEarly = dates[1] && dates[1].diff(current, 'days') > 7;
|
||||
const tooLate = dates[0] && current.diff(dates[0], 'days') >= 7;
|
||||
const tooEarly = dates[1] && dates[1].diff(current, 'days') >= 7;
|
||||
return !!tooEarly || !!tooLate;
|
||||
};
|
||||
|
||||
|
@ -57,7 +57,7 @@ const Divider: React.FC<DividerProps> = (props) => {
|
||||
rootClassName,
|
||||
);
|
||||
|
||||
const innerStyle = {
|
||||
const innerStyle: React.CSSProperties = {
|
||||
...(hasCustomMarginLeft && { marginLeft: orientationMargin }),
|
||||
...(hasCustomMarginRight && { marginRight: orientationMargin }),
|
||||
};
|
||||
|
@ -2,7 +2,7 @@ import { TinyColor } from '@ctrl/tinycolor';
|
||||
import * as React from 'react';
|
||||
import { useToken } from '../theme/internal';
|
||||
|
||||
const Empty = () => {
|
||||
const Empty: React.FC = () => {
|
||||
const [, token] = useToken();
|
||||
|
||||
const bgColor = new TinyColor(token.colorBgBase);
|
||||
|
@ -3,7 +3,7 @@ import * as React from 'react';
|
||||
import { useMemo } from 'react';
|
||||
import { useToken } from '../theme/internal';
|
||||
|
||||
const Simple = () => {
|
||||
const Simple: React.FC = () => {
|
||||
const [, token] = useToken();
|
||||
|
||||
const { colorFill, colorFillTertiary, colorFillQuaternary, colorBgContainer } = token;
|
||||
|
@ -104,7 +104,7 @@ const genLoopGridColumnsStyle = (token: GridColToken, sizeCls: string): CSSObjec
|
||||
insetInlineEnd: 'auto',
|
||||
};
|
||||
gridColumnsStyle[`${componentCls}${sizeCls}-offset-${i}`] = {
|
||||
marginInlineEnd: 0,
|
||||
marginInlineStart: 0,
|
||||
};
|
||||
gridColumnsStyle[`${componentCls}${sizeCls}-order-${i}`] = {
|
||||
order: 0,
|
||||
|
@ -1,3 +1,4 @@
|
||||
export type { Breakpoint } from './_util/responsiveObserver';
|
||||
export { default as Affix } from './affix';
|
||||
export type { AffixProps } from './affix';
|
||||
export { default as Alert } from './alert';
|
||||
@ -44,10 +45,10 @@ export { default as Drawer } from './drawer';
|
||||
export type { DrawerProps } from './drawer';
|
||||
export { default as Dropdown } from './dropdown';
|
||||
export type {
|
||||
DropdownProps,
|
||||
// typo, but we need to support it for backwards compatibility
|
||||
// https://github.com/ant-design/ant-design/pull/35161
|
||||
DropdownProps as DropDownProps,
|
||||
DropdownProps,
|
||||
} from './dropdown';
|
||||
export { default as Empty } from './empty';
|
||||
export type { EmptyProps } from './empty';
|
||||
@ -113,7 +114,7 @@ export type { SpaceProps } from './space';
|
||||
export { default as Spin } from './spin';
|
||||
export type { SpinProps } from './spin';
|
||||
export { default as Statistic } from './statistic';
|
||||
export type { StatisticProps } from './statistic';
|
||||
export type { CountdownProps, StatisticProps } from './statistic';
|
||||
export { default as Steps } from './steps';
|
||||
export type { StepProps, StepsProps } from './steps';
|
||||
export { default as Switch } from './switch';
|
||||
@ -122,8 +123,8 @@ export { default as Table } from './table';
|
||||
export type {
|
||||
ColumnGroupType as TableColumnGroupType,
|
||||
ColumnProps as TableColumnProps,
|
||||
ColumnsType as TableColumnsType,
|
||||
ColumnType as TableColumnType,
|
||||
ColumnsType as TableColumnsType,
|
||||
TablePaginationConfig,
|
||||
TableProps,
|
||||
} from './table';
|
||||
@ -145,8 +146,8 @@ export { default as Transfer } from './transfer';
|
||||
export type { TransferProps } from './transfer';
|
||||
export { default as Tree } from './tree';
|
||||
export type {
|
||||
AntTreeNodeProps as TreeNodeProps,
|
||||
DataNode as TreeDataNode,
|
||||
AntTreeNodeProps as TreeNodeProps,
|
||||
TreeProps,
|
||||
} from './tree';
|
||||
export { default as TreeSelect } from './tree-select';
|
||||
@ -158,4 +159,3 @@ export type { UploadFile, UploadProps } from './upload';
|
||||
export { default as version } from './version';
|
||||
export { default as Watermark } from './watermark';
|
||||
export type { WatermarkProps } from './watermark';
|
||||
export type { Breakpoint } from './_util/responsiveObserver';
|
||||
|
@ -104,6 +104,7 @@ const TextArea = forwardRef<TextAreaRef, TextAreaProps>(
|
||||
countWrapper: classNames(
|
||||
`${prefixCls}-textarea`,
|
||||
`${prefixCls}-textarea-show-count`,
|
||||
{ [`${prefixCls}-textarea-show-count-rtl`]: direction === 'rtl' },
|
||||
hashId,
|
||||
),
|
||||
textarea: classNames(
|
||||
|
@ -2,13 +2,13 @@ import { ReloadOutlined } from '@ant-design/icons';
|
||||
import classNames from 'classnames';
|
||||
import { QRCodeCanvas } from 'qrcode.react';
|
||||
import React, { useContext, useMemo } from 'react';
|
||||
import warning from '../_util/warning';
|
||||
import Button from '../button';
|
||||
import type { ConfigConsumerProps } from '../config-provider';
|
||||
import { ConfigContext } from '../config-provider';
|
||||
import useLocale from '../locale/useLocale';
|
||||
import Spin from '../spin';
|
||||
import theme from '../theme';
|
||||
import warning from '../_util/warning';
|
||||
import type { QRCodeProps, QRPropsCanvas } from './interface';
|
||||
import useStyle from './style/index';
|
||||
|
||||
@ -82,7 +82,7 @@ const QRCode: React.FC<QRCodeProps> = (props) => {
|
||||
{status === 'expired' && (
|
||||
<>
|
||||
<p className={`${prefixCls}-expired`}>{locale?.expired}</p>
|
||||
{typeof onRefresh === 'function' && (
|
||||
{onRefresh && (
|
||||
<Button type="link" icon={<ReloadOutlined />} onClick={onRefresh}>
|
||||
{locale?.refresh}
|
||||
</Button>
|
||||
|
@ -1,5 +1,6 @@
|
||||
import Statistic from './Statistic';
|
||||
import type { CountdownProps } from './Countdown';
|
||||
import type { StatisticProps } from './Statistic';
|
||||
import Statistic from './Statistic';
|
||||
|
||||
export type { StatisticProps };
|
||||
export type { StatisticProps, CountdownProps };
|
||||
export default Statistic;
|
||||
|
@ -772,6 +772,7 @@ const genTabsStyle: GenerateStyle<TabsToken> = (token: TabsToken): CSSObject =>
|
||||
padding: tabsCardHorizontalPadding,
|
||||
background: 'transparent',
|
||||
border: 0,
|
||||
color: token.colorText,
|
||||
|
||||
'&::after': {
|
||||
position: 'absolute',
|
||||
|
@ -8,175 +8,334 @@ import type { MapToken } from './maps';
|
||||
|
||||
export interface AliasToken extends MapToken {
|
||||
// Background
|
||||
colorFillContentHover: string;
|
||||
colorFillAlter: string;
|
||||
colorFillContent: string;
|
||||
|
||||
/**
|
||||
* @desc 容器禁用态下的背景色
|
||||
* @descEN Disabled container background color.
|
||||
* @nameZH 内容区域背景色(悬停)
|
||||
* @nameEN Background color of content area (hover)
|
||||
* @desc 控制内容区域背景色在鼠标悬停时的样式。
|
||||
* @descEN Control the style of background color of content area when mouse hovers over it.
|
||||
*/
|
||||
colorFillContentHover: string;
|
||||
/**
|
||||
* @nameZH 替代背景色
|
||||
* @nameEN Alternative background color
|
||||
* @desc 控制元素替代背景色。
|
||||
* @descEN Control the alternative background color of element.
|
||||
*/
|
||||
colorFillAlter: string;
|
||||
/**
|
||||
* @nameZH 内容区域背景色
|
||||
* @nameEN Background color of content area
|
||||
* @desc 控制内容区域的背景色。
|
||||
* @descEN Control the background color of content area.
|
||||
*/
|
||||
colorFillContent: string;
|
||||
/**
|
||||
* @nameZH 容器禁用态下的背景色
|
||||
* @nameEN Disabled container background color
|
||||
* @desc 控制容器在禁用状态下的背景色。
|
||||
* @descEN Control the background color of container in disabled state.
|
||||
*/
|
||||
colorBgContainerDisabled: string;
|
||||
/**
|
||||
* @desc 文本态悬浮态背景色
|
||||
* @descEN Hover text background color.
|
||||
* @nameZH 文本悬停态背景色
|
||||
* @nameEN Text hover background color
|
||||
* @desc 控制文本在悬停状态下的背景色。
|
||||
* @descEN Control the background color of text in hover state.
|
||||
*/
|
||||
colorBgTextHover: string;
|
||||
/**
|
||||
* @desc 文本态激活态背景色
|
||||
* @descEN Active text background color.
|
||||
* @nameZH 文本激活态背景色
|
||||
* @nameEN Text active background color
|
||||
* @desc 控制文本在激活状态下的背景色。
|
||||
* @descEN Control the background color of text in active state.
|
||||
*/
|
||||
colorBgTextActive: string;
|
||||
|
||||
// Border
|
||||
/**
|
||||
* @nameZH 背景边框颜色
|
||||
* @nameEN Background border color
|
||||
* @desc 控制元素背景边框的颜色。
|
||||
* @descEN Control the color of background border of element.
|
||||
*/
|
||||
colorBorderBg: string;
|
||||
/**
|
||||
* @nameZH 分割线颜色
|
||||
* @nameEN Separator color
|
||||
* @desc 用于作为分割线的颜色,此颜色和 colorBorderSecondary 的颜色一致,但是用的是透明色。
|
||||
* @descEN Used as the color of separator, this color is the same as colorBorderSecondary but with transparency.
|
||||
*/
|
||||
colorSplit: string;
|
||||
|
||||
// Text
|
||||
/**
|
||||
* @nameZH 占位文本颜色
|
||||
* @nameEN Placeholder text color
|
||||
* @desc 控制占位文本的颜色。
|
||||
* @descEN Control the color of placeholder text.
|
||||
*/
|
||||
colorTextPlaceholder: string;
|
||||
/**
|
||||
* @desc 禁用字体颜色
|
||||
* @descEN Disabled text color
|
||||
* @nameZH 禁用字体颜色
|
||||
* @nameEN Disabled text color
|
||||
* @desc 控制禁用状态下的字体颜色。
|
||||
* @descEN Control the color of text in disabled state.
|
||||
*/
|
||||
colorTextDisabled: string;
|
||||
/**
|
||||
* @nameZH 标题字体颜色
|
||||
* @nameEN Heading font color
|
||||
* @desc 控制标题字体颜色。
|
||||
* @descEN Control the font color of heading.
|
||||
*/
|
||||
colorTextHeading: string;
|
||||
/**
|
||||
* @nameZH 文本标签字体颜色
|
||||
* @nameEN Text label font color
|
||||
* @desc 控制文本标签字体颜色。
|
||||
* @descEN Control the font color of text label.
|
||||
*/
|
||||
colorTextLabel: string;
|
||||
/**
|
||||
* @nameZH 文本描述字体颜色
|
||||
* @nameEN Text description font color
|
||||
* @desc 控制文本描述字体颜色。
|
||||
* @descEN Control the font color of text description.
|
||||
*/
|
||||
colorTextDescription: string;
|
||||
/**
|
||||
* @desc 固定文本高亮颜色,用于带背景色的文本如 Primary Button 组件
|
||||
* @descEN Fixed text highlight color, used for text with background color such as Primary Button components
|
||||
* @nameZH 固定文本高亮颜色
|
||||
* @nameEN Fixed text highlight color
|
||||
* @desc 控制带背景色的文本,例如 Primary Button 组件中的文本高亮颜色。
|
||||
* @descEN Control the highlight color of text with background color, such as the text in Primary Button components.
|
||||
*/
|
||||
colorTextLightSolid: string;
|
||||
|
||||
/** Weak action. Such as `allowClear` or Alert close button */
|
||||
/**
|
||||
/**
|
||||
* @nameZH 弱操作图标颜色
|
||||
* @nameEN Weak action icon color
|
||||
* @desc 控制弱操作图标的颜色,例如 allowClear 或 Alert 关闭按钮。
|
||||
* @descEN Weak action. Such as `allowClear` or Alert close button
|
||||
*/
|
||||
colorIcon: string;
|
||||
/** Weak action hover color. Such as `allowClear` or Alert close button */
|
||||
/** */
|
||||
/**
|
||||
* @nameZH 弱操作图标悬浮态颜色
|
||||
* @nameEN Weak action icon hover color
|
||||
* @desc 控制弱操作图标在悬浮状态下的颜色,例如 allowClear 或 Alert 关闭按钮。
|
||||
* @descEN Weak action hover color. Such as `allowClear` or Alert close button
|
||||
*/
|
||||
colorIconHover: string;
|
||||
|
||||
/**
|
||||
* @desc 超链接颜色
|
||||
* @descEN hyperlink color
|
||||
* @nameZH 超链接颜色
|
||||
* @nameEN Hyperlink color
|
||||
* @desc 控制超链接的颜色。
|
||||
* @descEN Control the color of hyperlink.
|
||||
*/
|
||||
colorLink: string;
|
||||
/**
|
||||
* @desc 超链接悬浮颜色
|
||||
* @descEN hyperlink hover color
|
||||
* @nameZH 超链接悬浮颜色
|
||||
* @nameEN Hyperlink hover color
|
||||
* @desc 控制超链接悬浮时的颜色。
|
||||
* @descEN Control the color of hyperlink when hovering.
|
||||
*/
|
||||
colorLinkHover: string;
|
||||
/**
|
||||
* @desc 超链接激活颜色
|
||||
* @descEN hyperlink active color
|
||||
* @nameZH 超链接激活颜色
|
||||
* @nameEN Hyperlink active color
|
||||
* @desc 控制超链接被点击时的颜色。
|
||||
* @descEN Control the color of hyperlink when clicked.
|
||||
*/
|
||||
colorLinkActive: string;
|
||||
|
||||
/**
|
||||
* @nameZH 高亮颜色
|
||||
* @nameEN Highlight color
|
||||
* @desc 控制页面元素高亮时的颜色。
|
||||
* @descEN Control the color of page element when highlighted.
|
||||
*/
|
||||
colorHighlight: string;
|
||||
|
||||
/**
|
||||
* @desc 输入组件的 Outline 颜色
|
||||
* @descEN Input component outline color
|
||||
* @nameZH 输入组件的 Outline 颜色
|
||||
* @nameEN Input component outline color
|
||||
* @desc 控制输入组件的外轮廓线颜色。
|
||||
* @descEN Control the outline color of input component.
|
||||
*/
|
||||
controlOutline: string;
|
||||
colorWarningOutline: string;
|
||||
|
||||
/**
|
||||
* @desc 输入组件错误状态下的 Outline 颜色
|
||||
* @descEN Input component error outline color
|
||||
* @nameZH 警告状态下的 Outline 颜色
|
||||
* @nameEN Warning outline color
|
||||
* @desc 控制输入组件警告状态下的外轮廓线颜色。
|
||||
* @descEN Control the outline color of input component in warning state.
|
||||
*/
|
||||
colorWarningOutline: string;
|
||||
|
||||
/**
|
||||
* @nameZH 错误状态下的 Outline 颜色
|
||||
* @nameEN Error outline color
|
||||
* @desc 控制输入组件错误状态下的外轮廓线颜色。
|
||||
* @descEN Control the outline color of input component in error state.
|
||||
*/
|
||||
colorErrorOutline: string;
|
||||
|
||||
// Font
|
||||
/** Operation icon in Select, Cascader, etc. icon fontSize. Normal is same as fontSizeSM */
|
||||
/**
|
||||
* @nameZH 选择器、级联选择器等中的操作图标字体大小
|
||||
* @nameEN Operation icon font size in Select, Cascader, etc.
|
||||
* @desc 控制选择器、级联选择器等中的操作图标字体大小。正常情况下与 fontSizeSM 相同。
|
||||
* @descEN Control the font size of operation icon in Select, Cascader, etc. Normally same as fontSizeSM.
|
||||
*/
|
||||
fontSizeIcon: number;
|
||||
|
||||
/** For heading like h1, h2, h3 or option selected item */
|
||||
/**
|
||||
* @nameZH 标题类组件(如 h1、h2、h3)或选中项的字体粗细
|
||||
* @nameEN Font weight for heading components (such as h1, h2, h3) or selected item
|
||||
* @desc 控制标题类组件(如 h1、h2、h3)或选中项的字体粗细。
|
||||
* @descEN Control the font weight of heading components (such as h1, h2, h3) or selected item.
|
||||
*/
|
||||
fontWeightStrong: number;
|
||||
|
||||
// Control
|
||||
|
||||
/**
|
||||
* @desc 输入组件的 Outline 尺寸
|
||||
* @descEN Input component outline size
|
||||
* @nameZH 输入组件的外轮廓线宽度
|
||||
* @nameEN Input component outline width
|
||||
* @desc 控制输入组件的外轮廓线宽度。
|
||||
* @descEN Control the outline width of input component.
|
||||
*/
|
||||
controlOutlineWidth: number;
|
||||
|
||||
/**
|
||||
* @nameZH 控制组件项在鼠标悬浮时的背景颜色
|
||||
* @nameEN Background color of control component item when hovering
|
||||
* @desc 控制组件项在鼠标悬浮时的背景颜色。
|
||||
* @descEN Control the background color of control component item when hovering.
|
||||
*/
|
||||
controlItemBgHover: string; // Note. It also is a color
|
||||
|
||||
/**
|
||||
* @nameZH 控制组件项在激活状态下的背景颜色
|
||||
* @nameEN Background color of control component item when active
|
||||
* @desc 控制组件项在激活状态下的背景颜色。
|
||||
* @descEN Control the background color of control component item when active.
|
||||
*/
|
||||
controlItemBgActive: string; // Note. It also is a color
|
||||
|
||||
/**
|
||||
* @nameZH 控制组件项在鼠标悬浮且激活状态下的背景颜色
|
||||
* @nameEN Background color of control component item when hovering and active
|
||||
* @desc 控制组件项在鼠标悬浮且激活状态下的背景颜色。
|
||||
* @descEN Control the background color of control component item when hovering and active.
|
||||
*/
|
||||
controlItemBgActiveHover: string; // Note. It also is a color
|
||||
|
||||
/**
|
||||
* @nameZH 控制组件的交互大小
|
||||
* @nameEN Interactive size of control component
|
||||
* @desc 控制组件的交互大小。
|
||||
* @descEN Control the interactive size of control component.
|
||||
*/
|
||||
controlInteractiveSize: number;
|
||||
|
||||
/**
|
||||
* @nameZH 控制组件项在禁用状态下的激活背景颜色
|
||||
* @nameEN Background color of control component item when active and disabled
|
||||
* @desc 控制组件项在禁用状态下的激活背景颜色。
|
||||
* @descEN Control the background color of control component item when active and disabled.
|
||||
*/
|
||||
controlItemBgActiveDisabled: string; // Note. It also is a color
|
||||
|
||||
// Line
|
||||
/**
|
||||
* @desc 聚焦时 Outline 尺寸
|
||||
* @descEN Outline size when focused
|
||||
* @nameZH 线条宽度(聚焦态)
|
||||
* @nameEN Line width(focus state)
|
||||
* @desc 控制线条的宽度,当组件处于聚焦态时。
|
||||
* @descEN Control the width of the line when the component is in focus state.
|
||||
*/
|
||||
lineWidthFocus: number;
|
||||
|
||||
// Padding
|
||||
/**
|
||||
* @desc 内间距尺寸
|
||||
* @descEN Padding size
|
||||
* @nameZH 极小内间距
|
||||
* @nameEN Extra extra small padding
|
||||
* @desc 控制元素的极小内间距。
|
||||
* @descEN Control the extra extra small padding of the element.
|
||||
*/
|
||||
paddingXXS: number;
|
||||
/**
|
||||
* @desc 内间距尺寸
|
||||
* @descEN Padding size
|
||||
* @nameZH 特小内间距
|
||||
* @nameEN Extra small padding
|
||||
* @desc 控制元素的特小内间距。
|
||||
* @descEN Control the extra small padding of the element.
|
||||
*/
|
||||
paddingXS: number;
|
||||
/**
|
||||
* @desc 内间距尺寸
|
||||
* @descEN Padding size
|
||||
* @nameZH 小内间距
|
||||
* @nameEN Small padding
|
||||
* @desc 控制元素的小内间距。
|
||||
* @descEN Control the small padding of the element.
|
||||
*/
|
||||
paddingSM: number;
|
||||
/**
|
||||
* @desc 内间距尺寸
|
||||
* @descEN Padding size
|
||||
* @nameZH 内间距
|
||||
* @nameEN Padding
|
||||
* @desc 控制元素的内间距。
|
||||
* @descEN Control the padding of the element.
|
||||
*/
|
||||
padding: number;
|
||||
/**
|
||||
* @desc 内间距尺寸
|
||||
* @descEN Padding size
|
||||
* @nameZH 中等内间距
|
||||
* @nameEN Medium padding
|
||||
* @desc 控制元素的中等内间距。
|
||||
* @descEN Control the medium padding of the element.
|
||||
*/
|
||||
paddingMD: number;
|
||||
/**
|
||||
* @desc 内间距尺寸
|
||||
* @descEN Padding size
|
||||
* @nameZH 大内间距
|
||||
* @nameEN Large padding
|
||||
* @desc 控制元素的大内间距。
|
||||
* @descEN Control the large padding of the element.
|
||||
*/
|
||||
paddingLG: number;
|
||||
/**
|
||||
* @desc 内间距尺寸
|
||||
* @descEN Padding size
|
||||
* @nameZH 特大内间距
|
||||
* @nameEN Extra large padding
|
||||
* @desc 控制元素的特大内间距。
|
||||
* @descEN Control the extra large padding of the element.
|
||||
*/
|
||||
paddingXL: number;
|
||||
|
||||
// Padding Content
|
||||
/**
|
||||
* @nameZH 内容水平内间距
|
||||
* @nameEN Content horizontal padding
|
||||
* @desc 控制内容元素水平内间距
|
||||
* @descEN Control the horizontal padding of content element.
|
||||
* @nameZH 内容水平内间距(LG)
|
||||
* @nameEN Content horizontal padding (LG)
|
||||
* @desc 控制内容元素水平内间距,适用于大屏幕设备。
|
||||
* @descEN Control the horizontal padding of content element, suitable for large screen devices.
|
||||
*/
|
||||
paddingContentHorizontalLG: number;
|
||||
/**
|
||||
* @nameZH 内容水平内间距
|
||||
* @nameEN Content horizontal padding
|
||||
* @desc 控制内容元素水平内间距
|
||||
* @desc 控制内容元素水平内间距。
|
||||
* @descEN Control the horizontal padding of content element.
|
||||
*/
|
||||
paddingContentHorizontal: number;
|
||||
/**
|
||||
* @nameZH 内容水平内间距
|
||||
* @nameEN Content horizontal padding
|
||||
* @desc 控制内容元素水平内间距
|
||||
* @descEN Control the horizontal padding of content element.
|
||||
* @nameZH 内容水平内间距(SM)
|
||||
* @nameEN Content horizontal padding (SM)
|
||||
* @desc 控制内容元素水平内间距,适用于小屏幕设备。
|
||||
* @descEN Control the horizontal padding of content element, suitable for small screen devices.
|
||||
*/
|
||||
paddingContentHorizontalSM: number;
|
||||
/**
|
||||
* @nameZH 内容垂直内间距
|
||||
* @nameEN Content vertical padding
|
||||
* @desc 控制内容元素垂直内间距。
|
||||
* @descEN Control the vertical padding of content element.
|
||||
* @nameZH 内容垂直内间距(LG)
|
||||
* @nameEN Content vertical padding (LG)
|
||||
* @desc 控制内容元素垂直内间距,适用于大屏幕设备。
|
||||
* @descEN Control the vertical padding of content element, suitable for large screen devices.
|
||||
*/
|
||||
paddingContentVerticalLG: number;
|
||||
/**
|
||||
@ -187,90 +346,258 @@ export interface AliasToken extends MapToken {
|
||||
*/
|
||||
paddingContentVertical: number;
|
||||
/**
|
||||
* @nameZH 内容垂直内间距
|
||||
* @nameEN Content vertical padding
|
||||
* @desc 控制内容元素垂直内间距。
|
||||
* @descEN Control the vertical padding of content element.
|
||||
* @nameZH 内容垂直内间距(SM)
|
||||
* @nameEN Content vertical padding (SM)
|
||||
* @desc 控制内容元素垂直内间距,适用于小屏幕设备。
|
||||
* @descEN Control the vertical padding of content element, suitable for small screen devices.
|
||||
*/
|
||||
paddingContentVerticalSM: number;
|
||||
|
||||
// Margin
|
||||
/**
|
||||
* @desc 外间距
|
||||
* @descEN Margin size.
|
||||
* @nameZH 外边距 XXS
|
||||
* @nameEN Margin XXS
|
||||
* @desc 控制元素外边距,最小尺寸。
|
||||
* @descEN Control the margin of an element, with the smallest size.
|
||||
*/
|
||||
marginXXS: number;
|
||||
/**
|
||||
* @desc 外间距
|
||||
* @descEN Margin size.
|
||||
* @nameZH 外边距 XS
|
||||
* @nameEN Margin XS
|
||||
* @desc 控制元素外边距,小尺寸。
|
||||
* @descEN Control the margin of an element, with a small size.
|
||||
*/
|
||||
marginXS: number;
|
||||
/**
|
||||
* @desc 外间距
|
||||
* @descEN Margin size.
|
||||
* @nameZH 外边距 SM
|
||||
* @nameEN Margin SM
|
||||
* @desc 控制元素外边距,中小尺寸。
|
||||
* @descEN Control the margin of an element, with a medium-small size.
|
||||
*/
|
||||
marginSM: number;
|
||||
/**
|
||||
* @desc 外间距
|
||||
* @descEN Margin size.
|
||||
* @nameZH 外边距
|
||||
* @nameEN Margin
|
||||
* @desc 控制元素外边距,中等尺寸。
|
||||
* @descEN Control the margin of an element, with a medium size.
|
||||
*/
|
||||
margin: number;
|
||||
/**
|
||||
* @desc 外间距
|
||||
* @descEN Margin size.
|
||||
* @nameZH 外边距 MD
|
||||
* @nameEN Margin MD
|
||||
* @desc 控制元素外边距,中大尺寸。
|
||||
* @descEN Control the margin of an element, with a medium-large size.
|
||||
*/
|
||||
marginMD: number;
|
||||
/**
|
||||
* @desc 外间距
|
||||
* @descEN Margin size.
|
||||
* @nameZH 外边距 LG
|
||||
* @nameEN Margin LG
|
||||
* @desc 控制元素外边距,大尺寸。
|
||||
* @descEN Control the margin of an element, with a large size.
|
||||
*/
|
||||
marginLG: number;
|
||||
/**
|
||||
* @desc 外间距
|
||||
* @descEN Margin size.
|
||||
* @nameZH 外边距 XL
|
||||
* @nameEN Margin XL
|
||||
* @desc 控制元素外边距,超大尺寸。
|
||||
* @descEN Control the margin of an element, with an extra-large size.
|
||||
*/
|
||||
marginXL: number;
|
||||
/**
|
||||
* @desc 外间距
|
||||
* @descEN Margin size.
|
||||
* @nameZH 外边距 XXL
|
||||
* @nameEN Margin XXL
|
||||
* @desc 控制元素外边距,最大尺寸。
|
||||
* @descEN Control the margin of an element, with the largest size.
|
||||
*/
|
||||
marginXXL: number;
|
||||
|
||||
// =============== Legacy: should be remove ===============
|
||||
/**
|
||||
* @desc 加载状态透明度
|
||||
* @descEN Loading opacity
|
||||
* @nameZH 加载状态透明度
|
||||
* @nameEN Loading opacity
|
||||
* @desc 控制加载状态的透明度。
|
||||
* @descEN Control the opacity of the loading state.
|
||||
*/
|
||||
opacityLoading: number;
|
||||
|
||||
/**
|
||||
* @nameZH 一级阴影
|
||||
* @nameEN Box shadow
|
||||
* @desc 控制元素阴影样式。
|
||||
* @descEN Control the box shadow style of an element.
|
||||
*/
|
||||
boxShadow: string;
|
||||
/**
|
||||
* @nameZH 二级阴影
|
||||
* @nameEN Secondary box shadow
|
||||
* @desc 控制元素二级阴影样式。
|
||||
* @descEN Control the secondary box shadow style of an element.
|
||||
*/
|
||||
boxShadowSecondary: string;
|
||||
/**
|
||||
* @nameZH 三级阴影
|
||||
* @nameEN Tertiary box shadow
|
||||
* @desc 控制元素三级盒子阴影样式。
|
||||
* @descEN Control the tertiary box shadow style of an element.
|
||||
*/
|
||||
boxShadowTertiary: string;
|
||||
|
||||
/**
|
||||
* @nameZH 链接文本装饰
|
||||
* @nameEN Link text decoration
|
||||
* @desc 控制链接文本的装饰样式。
|
||||
* @descEN Control the text decoration style of a link.
|
||||
*/
|
||||
linkDecoration: React.CSSProperties['textDecoration'];
|
||||
/**
|
||||
* @nameZH 链接鼠标悬浮时文本装饰
|
||||
* @nameEN Link text decoration on mouse hover
|
||||
* @desc 控制链接鼠标悬浮时文本的装饰样式。
|
||||
* @descEN Control the text decoration style of a link on mouse hover.
|
||||
*/
|
||||
linkHoverDecoration: React.CSSProperties['textDecoration'];
|
||||
/**
|
||||
* @nameZH 链接聚焦时文本装饰
|
||||
* @nameEN Link text decoration on focus
|
||||
* @desc 控制链接聚焦时文本的装饰样式。
|
||||
* @descEN Control the text decoration style of a link on focus.
|
||||
*/
|
||||
linkFocusDecoration: React.CSSProperties['textDecoration'];
|
||||
|
||||
/**
|
||||
* @nameZH 控制水平内间距
|
||||
* @nameEN Control horizontal padding
|
||||
* @desc 控制元素水平内间距。
|
||||
* @descEN Control the horizontal padding of an element.
|
||||
*/
|
||||
controlPaddingHorizontal: number;
|
||||
/**
|
||||
* @nameZH 控制中小尺寸水平内间距
|
||||
* @nameEN Control horizontal padding with a small-medium size
|
||||
* @desc 控制元素中小尺寸水平内间距。
|
||||
* @descEN Control the horizontal padding of an element with a small-medium size.
|
||||
*/
|
||||
controlPaddingHorizontalSM: number;
|
||||
|
||||
// Media queries breakpoints
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 超小屏幕
|
||||
* @nameEN Screen width (pixels) - Extra small screens
|
||||
* @desc 控制超小屏幕的屏幕宽度。
|
||||
* @descEN Control the screen width of extra small screens.
|
||||
*/
|
||||
screenXS: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 超小屏幕最小值
|
||||
* @nameEN Screen width (pixels) - Extra small screens minimum value
|
||||
* @desc 控制超小屏幕的最小宽度。
|
||||
* @descEN Control the minimum width of extra small screens.
|
||||
*/
|
||||
screenXSMin: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 超小屏幕最大值
|
||||
* @nameEN Screen width (pixels) - Extra small screens maximum value
|
||||
* @desc 控制超小屏幕的最大宽度。
|
||||
* @descEN Control the maximum width of extra small screens.
|
||||
*/
|
||||
screenXSMax: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 小屏幕
|
||||
* @nameEN Screen width (pixels) - Small screens
|
||||
* @desc 控制小屏幕的屏幕宽度。
|
||||
* @descEN Control the screen width of small screens.
|
||||
*/
|
||||
screenSM: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 小屏幕最小值
|
||||
* @nameEN Screen width (pixels) - Small screens minimum value
|
||||
* @desc 控制小屏幕的最小宽度。
|
||||
* @descEN Control the minimum width of small screens.
|
||||
*/
|
||||
screenSMMin: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 小屏幕最大值
|
||||
* @nameEN Screen width (pixels) - Small screens maximum value
|
||||
* @desc 控制小屏幕的最大宽度。
|
||||
* @descEN Control the maximum width of small screens.
|
||||
*/
|
||||
screenSMMax: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 中等屏幕
|
||||
* @nameEN Screen width (pixels) - Medium screens
|
||||
* @desc 控制中等屏幕的屏幕宽度。
|
||||
* @descEN Control the screen width of medium screens.
|
||||
*/
|
||||
screenMD: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 中等屏幕最小值
|
||||
* @nameEN Screen width (pixels) - Medium screens minimum value
|
||||
* @desc 控制中等屏幕的最小宽度。
|
||||
* @descEN Control the minimum width of medium screens.
|
||||
*/
|
||||
screenMDMin: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 中等屏幕最大值
|
||||
* @nameEN Screen width (pixels) - Medium screens maximum value
|
||||
* @desc 控制中等屏幕的最大宽度。
|
||||
* @descEN Control the maximum width of medium screens.
|
||||
*/
|
||||
screenMDMax: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 大屏幕
|
||||
* @nameEN Screen width (pixels) - Large screens
|
||||
* @desc 控制大屏幕的屏幕宽度。
|
||||
* @descEN Control the screen width of large screens.
|
||||
*/
|
||||
screenLG: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 大屏幕最小值
|
||||
* @nameEN Screen width (pixels) - Large screens minimum value
|
||||
* @desc 控制大屏幕的最小宽度。
|
||||
* @descEN Control the minimum width of large screens.
|
||||
*/
|
||||
screenLGMin: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 大屏幕最大值
|
||||
* @nameEN Screen width (pixels) - Large screens maximum value
|
||||
* @desc 控制大屏幕的最大宽度。
|
||||
* @descEN Control the maximum width of large screens.
|
||||
*/
|
||||
screenLGMax: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 超大屏幕
|
||||
* @nameEN Screen width (pixels) - Extra large screens
|
||||
* @desc 控制超大屏幕的屏幕宽度。
|
||||
* @descEN Control the screen width of extra large screens.
|
||||
*/
|
||||
screenXL: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 超大屏幕最小值
|
||||
* @nameEN Screen width (pixels) - Extra large screens minimum value
|
||||
* @desc 控制超大屏幕的最小宽度。
|
||||
* @descEN Control the minimum width of extra large screens.
|
||||
*/
|
||||
screenXLMin: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 超大屏幕最大值
|
||||
* @nameEN Screen width (pixels) - Extra large screens maximum value
|
||||
* @desc 控制超大屏幕的最大宽度。
|
||||
* @descEN Control the maximum width of extra large screens.
|
||||
*/
|
||||
screenXLMax: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 超超大屏幕
|
||||
* @nameEN Screen width (pixels) - Extra extra large screens
|
||||
* @desc 控制超超大屏幕的屏幕宽度。
|
||||
* @descEN Control the screen width of extra extra large screens.
|
||||
*/
|
||||
screenXXL: number;
|
||||
/**
|
||||
* @nameZH 屏幕宽度(像素) - 超超大屏幕最小值
|
||||
* @nameEN Screen width (pixels) - Extra extra large screens minimum value
|
||||
* @desc 控制超超大屏幕的最小宽度。
|
||||
* @descEN Control the minimum width of extra extra large screens.
|
||||
*/
|
||||
screenXXLMin: number;
|
||||
|
||||
/**
|
||||
|
@ -114,12 +114,15 @@ export interface ColorNeutralMapToken {
|
||||
interface ColorPrimaryMapToken {
|
||||
/**
|
||||
* @nameZH 品牌主色
|
||||
* @desc 品牌色是体现产品特性和传播理念最直观的视觉元素之一,用于产品的主色调、主按钮、主图标、主文本等 */
|
||||
* @nameEN Primary color of the brand
|
||||
* @desc 品牌色是体现产品特性和传播理念最直观的视觉元素之一,用于产品的主色调、主按钮、主图标、主文本等
|
||||
* @descEN The brand color is one of the most intuitive visual elements that reflects product characteristics and communication concepts, and is used for the main color tone, main buttons, main icons, main text, etc. of the product.
|
||||
*/
|
||||
colorPrimary: string; // 6
|
||||
|
||||
/**
|
||||
* @nameZH 主色浅色背景色
|
||||
* @nameEN Light Background Color of Primary Color
|
||||
* @nameEN Light background color of primary color
|
||||
* @desc 主色浅色背景颜色,一般用于视觉层级较弱的选中状态。
|
||||
* @descEN Light background color of primary color, usually used for weak visual level selection state.
|
||||
*/
|
||||
@ -127,53 +130,65 @@ interface ColorPrimaryMapToken {
|
||||
|
||||
/**
|
||||
* @nameZH 主色浅色背景悬浮态
|
||||
* @nameEN Hover state of light background color of primary color
|
||||
* @desc 与主色浅色背景颜色相对应的悬浮态颜色。
|
||||
* @descEN The hover state color corresponding to the light background color of the primary color.
|
||||
*/
|
||||
colorPrimaryBgHover: string; // 2
|
||||
|
||||
/**
|
||||
* @nameZH 主色描边色
|
||||
* @desc 主色梯度下的描边用色,用在 Slider 等组件的描边上
|
||||
* @descEN The stroke color under the main color gradient, used on the stroke of components such as Slider
|
||||
* @nameEN Border color of primary color
|
||||
* @desc 主色梯度下的描边用色,用在 Slider 等组件的描边上。
|
||||
* @descEN The stroke color under the main color gradient, used on the stroke of components such as Slider.
|
||||
*/
|
||||
colorPrimaryBorder: string; // 3
|
||||
|
||||
/**
|
||||
* @nameZH 主色描边色悬浮态
|
||||
* @desc 主色梯度下的描边用色的悬浮态,Slider 、Button 等组件的描边 Hover 时会使用
|
||||
* @descEN The hover state of the stroke color under the main color gradient, which will be used when the stroke Hover of components such as Slider and Button
|
||||
* @nameEN Hover state of border color of primary color
|
||||
* @desc 主色梯度下的描边用色的悬浮态,Slider 、Button 等组件的描边 Hover 时会使用。
|
||||
* @descEN The hover state of the stroke color under the main color gradient, which will be used when the stroke Hover of components such as Slider and Button.
|
||||
*/
|
||||
colorPrimaryBorderHover: string; // 4
|
||||
|
||||
/**
|
||||
* @nameZH 主色悬浮态
|
||||
* @desc 主色梯度下的悬浮态
|
||||
* @descEN Suspended state under the main color gradient
|
||||
* @nameEN Hover state of primary color
|
||||
* @desc 主色梯度下的悬浮态。
|
||||
* @descEN Hover state under the main color gradient.
|
||||
*/
|
||||
colorPrimaryHover: string; // 5
|
||||
|
||||
/**
|
||||
* @nameZH 主色激活态
|
||||
* @desc 主色梯度下的深色激活态
|
||||
* @descEN Dark active states under dominant color gradient
|
||||
* @nameEN Active state of primary color
|
||||
* @desc 主色梯度下的深色激活态。
|
||||
* @descEN Dark active state under the main color gradient.
|
||||
*/
|
||||
colorPrimaryActive: string; // 7
|
||||
|
||||
/**
|
||||
* @nameZH 主色文本悬浮态
|
||||
* @desc 主色梯度下的文本悬浮态
|
||||
* @nameEN Hover state of text color of primary color
|
||||
* @desc 主色梯度下的文本悬浮态。
|
||||
* @descEN Hover state of text color under the main color gradient.
|
||||
*/
|
||||
colorPrimaryTextHover: string; // 8
|
||||
|
||||
/**
|
||||
* @nameZH 主色文本
|
||||
* @desc 主色梯度下的文本颜色
|
||||
* @nameEN Text color of primary color
|
||||
* @desc 主色梯度下的文本颜色。
|
||||
* @descEN Text color under the main color gradient.
|
||||
*/
|
||||
colorPrimaryText: string; // 9
|
||||
|
||||
/**
|
||||
* @nameZH 主色文本
|
||||
* @desc 主色梯度下的文本激活态
|
||||
* @nameZH 主色文本激活态
|
||||
* @nameEN Active state of text color of primary color
|
||||
* @desc 主色梯度下的文本激活态。
|
||||
* @descEN Active state of text color under the main color gradient.
|
||||
*/
|
||||
colorPrimaryTextActive: string; // 10
|
||||
}
|
||||
@ -197,49 +212,65 @@ interface ColorSuccessMapToken {
|
||||
|
||||
/**
|
||||
* @nameZH 成功色的描边色
|
||||
* @nameEN Border Color of Success Color
|
||||
* @desc 成功色的描边色,用于 Tag 和 Alert 的成功态描边色
|
||||
* @descEN Border color of success color, used for Tag and Alert success state border color
|
||||
*/
|
||||
colorSuccessBorder: string; // 3
|
||||
|
||||
/**
|
||||
* @nameZH 成功色的描边色悬浮态
|
||||
* @nameEN Hover State Color of Success Border
|
||||
* @desc 成功色的描边色悬浮态
|
||||
* @descEN Hover state color of success color border
|
||||
*/
|
||||
colorSuccessBorderHover: string; // 4
|
||||
|
||||
/**
|
||||
* @nameZH 成功色的深色悬浮态
|
||||
* @nameEN Hover State Color of Dark Success
|
||||
* @desc 成功色的深色悬浮态
|
||||
* @descEN Hover state color of dark success color
|
||||
*/
|
||||
colorSuccessHover: string; // 5
|
||||
|
||||
/**
|
||||
* @nameZH 成功色
|
||||
* @nameEN Success Color
|
||||
* @desc 默认的成功色,如 Result、Progress 等组件中都有使用该颜色
|
||||
* @descEN Default success color, used in components such as Result and Progress
|
||||
*/
|
||||
colorSuccess: string; // 6
|
||||
|
||||
/**
|
||||
* @nameZH 成功色的深色激活态
|
||||
* @nameEN Active State Color of Dark Success
|
||||
* @desc 成功色的深色激活态
|
||||
* @descEN Active state color of dark success color
|
||||
*/
|
||||
colorSuccessActive: string; // 7
|
||||
|
||||
/**
|
||||
* @nameZH 成功色的文本悬浮态
|
||||
* @nameEN Hover State Color of Success Text
|
||||
* @desc 成功色的文本悬浮态
|
||||
* @descEN Hover state color of success color text
|
||||
*/
|
||||
colorSuccessTextHover: string; // 8
|
||||
|
||||
/**
|
||||
* @nameZH 成功色的文本默认态
|
||||
* @nameEN Default State Color of Success Text
|
||||
* @desc 成功色的文本默认态
|
||||
* @descEN Default state color of success color text
|
||||
*/
|
||||
colorSuccessText: string; // 9
|
||||
|
||||
/**
|
||||
* @nameZH 成功色的文本激活态
|
||||
* @nameEN Active State Color of Success Text
|
||||
* @desc 成功色的文本激活态
|
||||
* @descEN Active state color of success color text
|
||||
*/
|
||||
colorSuccessTextActive: string; // 10
|
||||
}
|
||||
@ -247,60 +278,81 @@ interface ColorSuccessMapToken {
|
||||
interface ColorWarningMapToken {
|
||||
/**
|
||||
* @nameZH 警戒色的浅色背景颜色
|
||||
* @nameEN Warning background color
|
||||
* @desc 警戒色的浅色背景颜色
|
||||
* @descEN The background color of the warning state.
|
||||
*/
|
||||
colorWarningBg: string; // 1
|
||||
|
||||
/**
|
||||
* @nameZH 警戒色的浅色背景色悬浮态
|
||||
* @nameEN Warning background color hover state
|
||||
* @desc 警戒色的浅色背景色悬浮态
|
||||
* @descEN The hover state background color of the warning state.
|
||||
*/
|
||||
colorWarningBgHover: string; // 2
|
||||
|
||||
/**
|
||||
* @nameZH 警戒色的描边色
|
||||
* @nameEN Warning border color
|
||||
* @desc 警戒色的描边色
|
||||
* @descEN The border color of the warning state.
|
||||
*/
|
||||
colorWarningBorder: string; // 3
|
||||
|
||||
/**
|
||||
* @nameZH 警戒色的描边色悬浮态
|
||||
* @nameEN Warning border color hover state
|
||||
* @desc 警戒色的描边色悬浮态
|
||||
* @descEN The hover state border color of the warning state.
|
||||
*/
|
||||
colorWarningBorderHover: string; // 4
|
||||
|
||||
/**
|
||||
* @nameZH 警戒色的深色悬浮态
|
||||
* @nameEN Warning hover color
|
||||
* @desc 警戒色的深色悬浮态
|
||||
* @descEN The hover state of the warning color.
|
||||
*/
|
||||
colorWarningHover: string; // 5
|
||||
|
||||
/**
|
||||
* @nameZH 警戒色
|
||||
* @nameEN Warning color
|
||||
* @desc 最常用的警戒色,例如 Notification、 Alert等警告类组件或 Input 输入类等组件会使用该颜色
|
||||
* @descEN The most commonly used warning color, used for warning components such as Notification, Alert, or input components.
|
||||
*/
|
||||
colorWarning: string; // 6
|
||||
|
||||
/**
|
||||
* @nameZH 警戒色的深色激活态
|
||||
* @nameEN Warning active color
|
||||
* @desc 警戒色的深色激活态
|
||||
* @descEN The active state of the warning color.
|
||||
*/
|
||||
colorWarningActive: string; // 7
|
||||
|
||||
/**
|
||||
* @nameZH 警戒色的文本悬浮态
|
||||
* @nameEN Warning text hover state
|
||||
* @desc 警戒色的文本悬浮态
|
||||
* @descEN The hover state of the text in the warning color.
|
||||
*/
|
||||
colorWarningTextHover: string; // 8
|
||||
|
||||
/**
|
||||
* @nameZH 警戒色的文本默认态
|
||||
* @nameEN Warning text default state
|
||||
* @desc 警戒色的文本默认态
|
||||
* @descEN The default state of the text in the warning color.
|
||||
*/
|
||||
colorWarningText: string; // 9
|
||||
|
||||
/**
|
||||
* @nameZH 警戒色的文本激活态
|
||||
* @nameEN Warning text active state
|
||||
* @desc 警戒色的文本激活态
|
||||
* @descEN The active state of the text in the warning color.
|
||||
*/
|
||||
colorWarningTextActive: string; // 10
|
||||
}
|
||||
@ -308,53 +360,81 @@ interface ColorWarningMapToken {
|
||||
interface ColorInfoMapToken {
|
||||
/**
|
||||
* @nameZH 信息色的浅色背景颜色
|
||||
* @desc 信息色的浅色背景颜色
|
||||
* @nameEN Light background color of information color
|
||||
* @desc 信息色的浅色背景颜色。
|
||||
* @descEN Light background color of information color.
|
||||
*/
|
||||
colorInfoBg: string; // 1
|
||||
|
||||
/**
|
||||
* @nameZH 信息色的浅色背景色悬浮态
|
||||
* @desc 信息色的浅色背景色悬浮态
|
||||
* @nameEN Hover state of light background color of information color
|
||||
* @desc 信息色的浅色背景色悬浮态。
|
||||
* @descEN Hover state of light background color of information color.
|
||||
*/
|
||||
colorInfoBgHover: string; // 2
|
||||
|
||||
/**
|
||||
* @nameZH 信息色的描边色
|
||||
* @nameEN Border color of information color
|
||||
* @desc 信息色的描边色。
|
||||
* @descEN Border color of information color.
|
||||
*/
|
||||
colorInfoBorder: string; // 3
|
||||
|
||||
/**
|
||||
* @nameZH 信息色的描边色悬浮态
|
||||
* @nameEN Hover state of border color of information color
|
||||
* @desc 信息色的描边色悬浮态。
|
||||
* @descEN Hover state of border color of information color.
|
||||
*/
|
||||
colorInfoBorderHover: string; // 4
|
||||
|
||||
/**
|
||||
* @nameZH 信息色的深色悬浮态
|
||||
* @nameEN Hover state of dark color of information color
|
||||
* @desc 信息色的深色悬浮态。
|
||||
* @descEN Hover state of dark color of information color.
|
||||
*/
|
||||
colorInfoHover: string; // 5
|
||||
|
||||
/**
|
||||
* @nameZH 信息色
|
||||
* @nameEN Information color
|
||||
* @desc 信息色。
|
||||
* @descEN Information color.
|
||||
*/
|
||||
colorInfo: string; // 6
|
||||
|
||||
/**
|
||||
* @nameZH 信息色的深色激活态
|
||||
* @nameEN Active state of dark color of information color
|
||||
* @desc 信息色的深色激活态。
|
||||
* @descEN Active state of dark color of information color.
|
||||
*/
|
||||
colorInfoActive: string; // 7
|
||||
|
||||
/**
|
||||
* @nameZH 信息色的文本悬浮态
|
||||
* @nameEN Hover state of text color of information color
|
||||
* @desc 信息色的文本悬浮态。
|
||||
* @descEN Hover state of text color of information color.
|
||||
*/
|
||||
colorInfoTextHover: string; // 8
|
||||
|
||||
/**
|
||||
* @nameZH 信息色的文本默认态
|
||||
* @nameEN Default state of text color of information color
|
||||
* @desc 信息色的文本默认态。
|
||||
* @descEN Default state of text color of information color.
|
||||
*/
|
||||
colorInfoText: string; // 9
|
||||
|
||||
/**
|
||||
* @nameZH 信息色的文本激活态
|
||||
* @nameEN Active state of text color of information color
|
||||
* @desc 信息色的文本激活态。
|
||||
* @descEN Active state of text color of information color.
|
||||
*/
|
||||
colorInfoTextActive: string; // 10
|
||||
}
|
||||
@ -362,59 +442,81 @@ interface ColorInfoMapToken {
|
||||
interface ColorErrorMapToken {
|
||||
/**
|
||||
* @nameZH 错误色的浅色背景颜色
|
||||
* @nameEN Error background color
|
||||
* @desc 错误色的浅色背景颜色
|
||||
* @descEN Error background color
|
||||
* @descEN The background color of the error state.
|
||||
*/
|
||||
colorErrorBg: string; // 1
|
||||
|
||||
/**
|
||||
* @nameZH 错误色的浅色背景色悬浮态
|
||||
* @nameEN Error background color hover state
|
||||
* @desc 错误色的浅色背景色悬浮态
|
||||
* @descEN The hover state background color of the error state.
|
||||
*/
|
||||
colorErrorBgHover: string; // 2
|
||||
|
||||
/**
|
||||
* @nameZH 错误色的描边色
|
||||
* @nameEN Error border color
|
||||
* @desc 错误色的描边色
|
||||
* @descEN The border color of the error state.
|
||||
*/
|
||||
colorErrorBorder: string; // 3
|
||||
|
||||
/**
|
||||
* @nameZH 错误色的描边色悬浮态
|
||||
* @nameEN Error border color hover state
|
||||
* @desc 错误色的描边色悬浮态
|
||||
* @descEN The stroke color of the wrong color is suspended
|
||||
* @descEN The hover state border color of the error state.
|
||||
*/
|
||||
colorErrorBorderHover: string; // 4
|
||||
|
||||
/**
|
||||
* @nameZH 错误色的深色悬浮态
|
||||
* @nameEN Error hover color
|
||||
* @desc 错误色的深色悬浮态
|
||||
* @descEN Error hover color
|
||||
* @descEN The hover state of the error color.
|
||||
*/
|
||||
colorErrorHover: string; // 5
|
||||
|
||||
/**
|
||||
* @nameZH 错误色
|
||||
* @nameEN Error color
|
||||
* @desc 错误色
|
||||
* @descEN The color of the error state.
|
||||
*/
|
||||
colorError: string; // 6
|
||||
|
||||
/**
|
||||
* @nameZH 错误色的深色激活态
|
||||
* @nameEN Error active color
|
||||
* @desc 错误色的深色激活态
|
||||
* @descEN Error active color
|
||||
* @descEN The active state of the error color.
|
||||
*/
|
||||
colorErrorActive: string; // 7
|
||||
|
||||
/**
|
||||
* @nameZH 错误色的文本悬浮态
|
||||
* @nameEN Error text hover state
|
||||
* @desc 错误色的文本悬浮态
|
||||
* @descEN The hover state of the text in the error color.
|
||||
*/
|
||||
colorErrorTextHover: string; // 8
|
||||
|
||||
/**
|
||||
* @nameZH 错误色的文本默认态
|
||||
* @nameEN Error text default state
|
||||
* @desc 错误色的文本默认态
|
||||
* @descEN The default state of the text in the error color.
|
||||
*/
|
||||
colorErrorText: string; // 9
|
||||
|
||||
/**
|
||||
* @nameZH 错误色的文本激活态
|
||||
* @nameEN Error text active state
|
||||
* @desc 错误色的文本激活态
|
||||
* @descEN The active state of the text in the error color.
|
||||
*/
|
||||
colorErrorTextActive: string; // 10
|
||||
}
|
||||
|
@ -23,31 +23,41 @@ export interface FontMapToken {
|
||||
|
||||
/**
|
||||
* @nameZH 一级标题字号
|
||||
* @nameEN Font size of heading level 1
|
||||
* @desc H1 标签所使用的字号
|
||||
* @descEN Font size of h1 tag.
|
||||
* @default 38
|
||||
*/
|
||||
fontSizeHeading1: number;
|
||||
/**
|
||||
* @nameZH 二级标题字号
|
||||
* @nameEN Font size of heading level 2
|
||||
* @desc h2 标签所使用的字号
|
||||
* @descEN Font size of h2 tag.
|
||||
* @default 30
|
||||
*/
|
||||
fontSizeHeading2: number;
|
||||
/**
|
||||
* @nameZH 三级标题字号
|
||||
* @nameEN Font size of heading level 3
|
||||
* @desc h3 标签使用的字号
|
||||
* @descEN Font size of h3 tag.
|
||||
* @default 24
|
||||
*/
|
||||
fontSizeHeading3: number;
|
||||
/**
|
||||
* @nameZH 四级标题字号
|
||||
* @nameEN Font size of heading level 4
|
||||
* @desc h4 标签使用的字号
|
||||
* @descEN Font size of h4 tag.
|
||||
* @default 20
|
||||
*/
|
||||
fontSizeHeading4: number;
|
||||
/**
|
||||
* @nameZH 五级标题字号
|
||||
* @nameEN Font size of heading level 5
|
||||
* @desc h5 标签使用的字号
|
||||
* @descEN Font size of h5 tag.
|
||||
* @default 16
|
||||
*/
|
||||
fontSizeHeading5: number;
|
||||
@ -69,9 +79,44 @@ export interface FontMapToken {
|
||||
*/
|
||||
lineHeightSM: number;
|
||||
|
||||
/**
|
||||
* @nameZH 一级标题行高
|
||||
* @nameEN Line height of heading level 1
|
||||
* @desc H1 标签所使用的行高
|
||||
* @descEN Line height of h1 tag.
|
||||
* @default 1.4
|
||||
*/
|
||||
lineHeightHeading1: number;
|
||||
/**
|
||||
* @nameZH 二级标题行高
|
||||
* @nameEN Line height of heading level 2
|
||||
* @desc h2 标签所使用的行高
|
||||
* @descEN Line height of h2 tag.
|
||||
* @default 1.35
|
||||
*/
|
||||
lineHeightHeading2: number;
|
||||
/**
|
||||
* @nameZH 三级标题行高
|
||||
* @nameEN Line height of heading level 3
|
||||
* @desc h3 标签所使用的行高
|
||||
* @descEN Line height of h3 tag.
|
||||
* @default 1.3
|
||||
*/
|
||||
lineHeightHeading3: number;
|
||||
/**
|
||||
* @nameZH 四级标题行高
|
||||
* @nameEN Line height of heading level 4
|
||||
* @desc h4 标签所使用的行高
|
||||
* @descEN Line height of h4 tag.
|
||||
* @default 1.25
|
||||
*/
|
||||
lineHeightHeading4: number;
|
||||
/**
|
||||
* @nameZH 五级标题行高
|
||||
* @nameEN Line height of heading level 5
|
||||
* @desc h5 标签所使用的行高
|
||||
* @descEN Line height of h5 tag.
|
||||
* @default 1.2
|
||||
*/
|
||||
lineHeightHeading5: number;
|
||||
}
|
||||
|
@ -10,8 +10,9 @@ export interface StyleMapToken {
|
||||
|
||||
/**
|
||||
* @nameZH XS号圆角
|
||||
* @nameEN XS Border Radius
|
||||
* @desc XS号圆角,用于组件中的一些小圆角,如 Segmented 、Arrow 等一些内部圆角的组件样式中。
|
||||
* @descEN XS size border radius, used in some small border radius components, such as Segmented, Arrow and other components.
|
||||
* @descEN XS size border radius, used in some small border radius components, such as Segmented, Arrow and other components with small border radius.
|
||||
* @default 2
|
||||
*/
|
||||
borderRadiusXS: number;
|
||||
@ -32,6 +33,8 @@ export interface StyleMapToken {
|
||||
*/
|
||||
borderRadiusLG: number;
|
||||
/**
|
||||
* @nameZH 外部圆角
|
||||
* @nameEN Outer Border Radius
|
||||
* @default 4
|
||||
*/
|
||||
borderRadiusOuter: number;
|
||||
|
@ -1,6 +1,10 @@
|
||||
import classNames from 'classnames';
|
||||
import type { ChangeEvent, CSSProperties } from 'react';
|
||||
import React, { useCallback, useContext, useEffect, useMemo, useState } from 'react';
|
||||
import type { InputStatus } from '../_util/statusUtils';
|
||||
import { getMergedStatus, getStatusClassNames } from '../_util/statusUtils';
|
||||
import { groupDisabledKeysMap, groupKeysMap } from '../_util/transKeys';
|
||||
import warning from '../_util/warning';
|
||||
import type { ConfigConsumerProps } from '../config-provider';
|
||||
import { ConfigContext } from '../config-provider';
|
||||
import DefaultRenderEmpty from '../config-provider/defaultRenderEmpty';
|
||||
@ -8,10 +12,6 @@ import type { FormItemStatusContextProps } from '../form/context';
|
||||
import { FormItemInputContext } from '../form/context';
|
||||
import defaultLocale from '../locale/en_US';
|
||||
import useLocale from '../locale/useLocale';
|
||||
import type { InputStatus } from '../_util/statusUtils';
|
||||
import { getMergedStatus, getStatusClassNames } from '../_util/statusUtils';
|
||||
import { groupDisabledKeysMap, groupKeysMap } from '../_util/transKeys';
|
||||
import warning from '../_util/warning';
|
||||
import type { PaginationType } from './interface';
|
||||
import type { TransferListProps } from './list';
|
||||
import List from './list';
|
||||
@ -104,24 +104,6 @@ export interface TransferProps<RecordType> {
|
||||
status?: InputStatus;
|
||||
}
|
||||
|
||||
// interface TransferFCProps {
|
||||
// prefixCls: string;
|
||||
// className?: string;
|
||||
// rootClassName?: string;
|
||||
// style?: React.CSSProperties;
|
||||
// children: React.ReactNode;
|
||||
// }
|
||||
|
||||
// const TransferFC: React.FC<TransferFCProps> = (props) => {
|
||||
// const { prefixCls, className, rootClassName, style, children } = props;
|
||||
// const [wrapSSR, hashId] = useStyle(prefixCls);
|
||||
// return wrapSSR(
|
||||
// <div className={classNames(className, rootClassName, hashId)} style={style}>
|
||||
// {children}
|
||||
// </div>,
|
||||
// );
|
||||
// };
|
||||
|
||||
const Transfer = <RecordType extends TransferItem = TransferItem>(
|
||||
props: TransferProps<RecordType>,
|
||||
) => {
|
||||
|
@ -109,10 +109,10 @@ While the major version is being upgraded, some components are discarded, but th
|
||||
});
|
||||
```
|
||||
|
||||
During the conversion process, I discovered a magical phenomenon. In some cases, the DOM snapshot generated by the same case will be different, so I began to explore what has changed in React 18:
|
||||
|
||||
## Diff Mystery
|
||||
|
||||
During the conversion process, I discovered a magical phenomenon. In some cases, the DOM snapshot generated by the same case will be different, so I began to explore what has changed in React 18:
|
||||
|
||||
In the past, the `snapshot` comparison of `enzyme` was to convert the `enzyme object` into a serialized object through the `enzyme-to-json` plugin:
|
||||
|
||||
```js
|
||||
@ -214,7 +214,7 @@ exports[`debug exports modules correctly 1`] = `
|
||||
Consistent with the idea, then it is very simple. Then there is a high probability that the `render` of `React 18` will ignore empty elements. Let's do a simple experiment:
|
||||
|
||||
```tsx
|
||||
import React, { version, useRef, useEffect } from 'react';
|
||||
import React, { useEffect, useRef, version } from 'react';
|
||||
|
||||
const App: React.FC = () => {
|
||||
const holderRef = useRef<HTMLDivElement>(null);
|
||||
@ -251,7 +251,7 @@ You can find the relevant PR by following the map:
|
||||
|
||||
- https://github.com/facebook/react/pull/22807
|
||||
|
||||
![QQ20221206-204507](https://user-images.githubusercontent.com/49217418/205916780-1ef901df-f15d-453d-a3ce-54b87e045dad.png)
|
||||
![WX20230319-145539@2x](https://user-images.githubusercontent.com/49217418/226159376-497fd490-153e-4e88-92e2-29dda50b3426.png)
|
||||
|
||||
## a solution
|
||||
|
||||
|
@ -109,10 +109,10 @@ author: li-jia-nan,zombieJ
|
||||
});
|
||||
```
|
||||
|
||||
在转换过程中,发现了⼀个神奇的现象,有些情况下,同样的 case 生成的 DOM 快照会不一样,也因此开始探索 React 18 到底变化了什么:
|
||||
|
||||
## Diff 之谜
|
||||
|
||||
在转换过程中,发现了⼀个神奇的现象,有些情况下,同样的 case 生成的 DOM 快照会不一样,也因此开始探索 React 18 到底变化了什么:
|
||||
|
||||
过去 `enzyme` 的 `snapshot` 对⽐是通过 `enzyme-to-json` 插件将 `enzyme object` 转换成序列化对象:
|
||||
|
||||
```js
|
||||
@ -214,7 +214,7 @@ exports[`debug exports modules correctly 1`] = `
|
||||
和设想的⼀致,那么就很简单了。那么⼤概率就是 `React 18` 的 `render` 会忽略空元素。我们做⼀个简单的实验:
|
||||
|
||||
```tsx
|
||||
import React, { version, useRef, useEffect } from 'react';
|
||||
import React, { useEffect, useRef, version } from 'react';
|
||||
|
||||
const App: React.FC = () => {
|
||||
const holderRef = useRef<HTMLDivElement>(null);
|
||||
@ -251,7 +251,7 @@ export default App;
|
||||
|
||||
- https://github.com/facebook/react/pull/22807
|
||||
|
||||
![QQ20221206-204507](https://user-images.githubusercontent.com/49217418/205916780-1ef901df-f15d-453d-a3ce-54b87e045dad.png)
|
||||
![WX20230319-145539@2x](https://user-images.githubusercontent.com/49217418/226159376-497fd490-153e-4e88-92e2-29dda50b3426.png)
|
||||
|
||||
## ⼀个解法
|
||||
|
||||
|
@ -196,7 +196,7 @@
|
||||
"@types/warning": "^3.0.0",
|
||||
"@typescript-eslint/eslint-plugin": "^5.40.0",
|
||||
"@typescript-eslint/parser": "^5.40.0",
|
||||
"antd-img-crop": "^4.2.8",
|
||||
"antd-img-crop": "^4.9.0",
|
||||
"antd-style": "^2.0.2",
|
||||
"antd-token-previewer": "^1.1.0-21",
|
||||
"chalk": "^4.0.0",
|
||||
@ -278,7 +278,7 @@
|
||||
"size-limit": "^8.1.0",
|
||||
"stylelint": "^15.1.0",
|
||||
"stylelint-config-rational-order": "^0.1.2",
|
||||
"stylelint-config-standard": "^30.0.0",
|
||||
"stylelint-config-standard": "^31.0.0",
|
||||
"stylelint-prettier": "^3.0.0",
|
||||
"sylvanas": "^0.6.1",
|
||||
"terser": "^5.16.1",
|
||||
|
Loading…
Reference in New Issue
Block a user