mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-15 08:59:15 +08:00
273 lines
7.2 KiB
TypeScript
273 lines
7.2 KiB
TypeScript
import { unit } from '@ant-design/cssinjs';
|
||
import type { CSSInterpolation } from '@ant-design/cssinjs';
|
||
|
||
import type { MenuToken } from '.';
|
||
import { genFocusOutline } from '../../style';
|
||
|
||
const accessibilityFocus = (token: MenuToken) => ({
|
||
...genFocusOutline(token),
|
||
});
|
||
|
||
const getThemeStyle = (token: MenuToken, themeSuffix: string): CSSInterpolation => {
|
||
const {
|
||
componentCls,
|
||
itemColor,
|
||
itemSelectedColor,
|
||
groupTitleColor,
|
||
itemBg,
|
||
subMenuItemBg,
|
||
itemSelectedBg,
|
||
activeBarHeight,
|
||
activeBarWidth,
|
||
activeBarBorderWidth,
|
||
motionDurationSlow,
|
||
motionEaseInOut,
|
||
motionEaseOut,
|
||
itemPaddingInline,
|
||
motionDurationMid,
|
||
itemHoverColor,
|
||
lineType,
|
||
colorSplit,
|
||
|
||
// Disabled
|
||
itemDisabledColor,
|
||
|
||
// Danger
|
||
dangerItemColor,
|
||
dangerItemHoverColor,
|
||
dangerItemSelectedColor,
|
||
dangerItemActiveBg,
|
||
dangerItemSelectedBg,
|
||
// Bg
|
||
popupBg,
|
||
itemHoverBg,
|
||
itemActiveBg,
|
||
menuSubMenuBg,
|
||
|
||
// Horizontal
|
||
horizontalItemSelectedColor,
|
||
horizontalItemSelectedBg,
|
||
horizontalItemBorderRadius,
|
||
horizontalItemHoverBg,
|
||
} = token;
|
||
|
||
return {
|
||
[`${componentCls}-${themeSuffix}, ${componentCls}-${themeSuffix} > ${componentCls}`]: {
|
||
color: itemColor,
|
||
background: itemBg,
|
||
|
||
[`&${componentCls}-root:focus-visible`]: {
|
||
...accessibilityFocus(token),
|
||
},
|
||
|
||
// ======================== Item ========================
|
||
[`${componentCls}-item-group-title`]: {
|
||
color: groupTitleColor,
|
||
},
|
||
|
||
[`${componentCls}-submenu-selected`]: {
|
||
[`> ${componentCls}-submenu-title`]: {
|
||
color: itemSelectedColor,
|
||
},
|
||
},
|
||
|
||
// Disabled
|
||
[`${componentCls}-item-disabled, ${componentCls}-submenu-disabled`]: {
|
||
color: `${itemDisabledColor} !important`,
|
||
},
|
||
|
||
// Hover
|
||
[`${componentCls}-item:not(${componentCls}-item-selected):not(${componentCls}-submenu-selected)`]:
|
||
{
|
||
[`&:hover, > ${componentCls}-submenu-title:hover`]: {
|
||
color: itemHoverColor,
|
||
},
|
||
},
|
||
|
||
[`&:not(${componentCls}-horizontal)`]: {
|
||
[`${componentCls}-item:not(${componentCls}-item-selected)`]: {
|
||
'&:hover': {
|
||
backgroundColor: itemHoverBg,
|
||
},
|
||
|
||
'&:active': {
|
||
backgroundColor: itemActiveBg,
|
||
},
|
||
},
|
||
|
||
[`${componentCls}-submenu-title`]: {
|
||
'&:hover': {
|
||
backgroundColor: itemHoverBg,
|
||
},
|
||
|
||
'&:active': {
|
||
backgroundColor: itemActiveBg,
|
||
},
|
||
},
|
||
},
|
||
|
||
// Danger - only Item has
|
||
[`${componentCls}-item-danger`]: {
|
||
color: dangerItemColor,
|
||
|
||
[`&${componentCls}-item:hover`]: {
|
||
[`&:not(${componentCls}-item-selected):not(${componentCls}-submenu-selected)`]: {
|
||
color: dangerItemHoverColor,
|
||
},
|
||
},
|
||
|
||
[`&${componentCls}-item:active`]: {
|
||
background: dangerItemActiveBg,
|
||
},
|
||
},
|
||
|
||
[`${componentCls}-item a`]: {
|
||
'&, &:hover': {
|
||
color: 'inherit',
|
||
},
|
||
},
|
||
|
||
[`${componentCls}-item-selected`]: {
|
||
color: itemSelectedColor,
|
||
|
||
// Danger
|
||
[`&${componentCls}-item-danger`]: {
|
||
color: dangerItemSelectedColor,
|
||
},
|
||
|
||
[`a, a:hover`]: {
|
||
color: 'inherit',
|
||
},
|
||
},
|
||
|
||
[`& ${componentCls}-item-selected`]: {
|
||
backgroundColor: itemSelectedBg,
|
||
|
||
// Danger
|
||
[`&${componentCls}-item-danger`]: {
|
||
backgroundColor: dangerItemSelectedBg,
|
||
},
|
||
},
|
||
|
||
[`${componentCls}-item, ${componentCls}-submenu-title`]: {
|
||
[`&:not(${componentCls}-item-disabled):focus-visible`]: {
|
||
...accessibilityFocus(token),
|
||
},
|
||
},
|
||
|
||
[`&${componentCls}-submenu > ${componentCls}`]: {
|
||
backgroundColor: menuSubMenuBg,
|
||
},
|
||
|
||
// ===== 设置浮层的颜色 =======
|
||
// !dark 模式会被popupBg 会被rest 为 darkPopupBg
|
||
[`&${componentCls}-popup > ${componentCls}`]: {
|
||
backgroundColor: popupBg,
|
||
},
|
||
|
||
[`&${componentCls}-submenu-popup > ${componentCls}`]: {
|
||
backgroundColor: popupBg,
|
||
},
|
||
// ===== 设置浮层的颜色 end =======
|
||
|
||
// ====================== Horizontal ======================
|
||
[`&${componentCls}-horizontal`]: {
|
||
...(themeSuffix === 'dark'
|
||
? {
|
||
borderBottom: 0,
|
||
}
|
||
: {}),
|
||
|
||
[`> ${componentCls}-item, > ${componentCls}-submenu`]: {
|
||
top: activeBarBorderWidth,
|
||
marginTop: token.calc(activeBarBorderWidth).mul(-1).equal(),
|
||
marginBottom: 0,
|
||
borderRadius: horizontalItemBorderRadius,
|
||
|
||
'&::after': {
|
||
position: 'absolute',
|
||
insetInline: itemPaddingInline,
|
||
bottom: 0,
|
||
borderBottom: `${unit(activeBarHeight)} solid transparent`,
|
||
transition: `border-color ${motionDurationSlow} ${motionEaseInOut}`,
|
||
content: '""',
|
||
},
|
||
|
||
[`&:hover, &-active, &-open`]: {
|
||
background: horizontalItemHoverBg,
|
||
'&::after': {
|
||
borderBottomWidth: activeBarHeight,
|
||
borderBottomColor: horizontalItemSelectedColor,
|
||
},
|
||
},
|
||
[`&-selected`]: {
|
||
color: horizontalItemSelectedColor,
|
||
backgroundColor: horizontalItemSelectedBg,
|
||
'&:hover': {
|
||
backgroundColor: horizontalItemSelectedBg,
|
||
},
|
||
'&::after': {
|
||
borderBottomWidth: activeBarHeight,
|
||
borderBottomColor: horizontalItemSelectedColor,
|
||
},
|
||
},
|
||
},
|
||
},
|
||
|
||
// ================== Inline & Vertical ===================
|
||
//
|
||
[`&${componentCls}-root`]: {
|
||
[`&${componentCls}-inline, &${componentCls}-vertical`]: {
|
||
borderInlineEnd: `${unit(activeBarBorderWidth)} ${lineType} ${colorSplit}`,
|
||
},
|
||
},
|
||
|
||
// ======================== Inline ========================
|
||
[`&${componentCls}-inline`]: {
|
||
// Sub
|
||
[`${componentCls}-sub${componentCls}-inline`]: {
|
||
background: subMenuItemBg,
|
||
},
|
||
|
||
[`${componentCls}-item`]: {
|
||
position: 'relative',
|
||
|
||
'&::after': {
|
||
position: 'absolute',
|
||
insetBlock: 0,
|
||
insetInlineEnd: 0,
|
||
borderInlineEnd: `${unit(activeBarWidth)} solid ${itemSelectedColor}`,
|
||
transform: 'scaleY(0.0001)',
|
||
opacity: 0,
|
||
transition: [
|
||
`transform ${motionDurationMid} ${motionEaseOut}`,
|
||
`opacity ${motionDurationMid} ${motionEaseOut}`,
|
||
].join(','),
|
||
content: '""',
|
||
},
|
||
|
||
// Danger
|
||
[`&${componentCls}-item-danger`]: {
|
||
'&::after': {
|
||
borderInlineEndColor: dangerItemSelectedColor,
|
||
},
|
||
},
|
||
},
|
||
|
||
[`${componentCls}-selected, ${componentCls}-item-selected`]: {
|
||
'&::after': {
|
||
transform: 'scaleY(1)',
|
||
opacity: 1,
|
||
transition: [
|
||
`transform ${motionDurationMid} ${motionEaseInOut}`,
|
||
`opacity ${motionDurationMid} ${motionEaseInOut}`,
|
||
].join(','),
|
||
},
|
||
},
|
||
},
|
||
},
|
||
};
|
||
};
|
||
|
||
export default getThemeStyle;
|