first commit
This commit is contained in:
485
frontend/node_modules/antd/lib/button/style/index.js
generated
vendored
Normal file
485
frontend/node_modules/antd/lib/button/style/index.js
generated
vendored
Normal file
@@ -0,0 +1,485 @@
|
||||
"use strict";
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
var _cssinjs = require("@ant-design/cssinjs");
|
||||
var _style = require("../../style");
|
||||
var _interface = require("../../theme/interface");
|
||||
var _internal = require("../../theme/internal");
|
||||
var _group = _interopRequireDefault(require("./group"));
|
||||
var _token = require("./token");
|
||||
// ============================== Shared ==============================
|
||||
const genSharedButtonStyle = token => {
|
||||
const {
|
||||
componentCls,
|
||||
iconCls,
|
||||
fontWeight,
|
||||
opacityLoading,
|
||||
motionDurationSlow,
|
||||
motionEaseInOut,
|
||||
iconGap,
|
||||
calc
|
||||
} = token;
|
||||
return {
|
||||
[componentCls]: {
|
||||
outline: 'none',
|
||||
position: 'relative',
|
||||
display: 'inline-flex',
|
||||
gap: iconGap,
|
||||
alignItems: 'center',
|
||||
justifyContent: 'center',
|
||||
fontWeight,
|
||||
whiteSpace: 'nowrap',
|
||||
textAlign: 'center',
|
||||
backgroundImage: 'none',
|
||||
background: 'transparent',
|
||||
border: `${(0, _cssinjs.unit)(token.lineWidth)} ${token.lineType} transparent`,
|
||||
cursor: 'pointer',
|
||||
transition: `all ${token.motionDurationMid} ${token.motionEaseInOut}`,
|
||||
userSelect: 'none',
|
||||
touchAction: 'manipulation',
|
||||
color: token.colorText,
|
||||
'&:disabled > *': {
|
||||
pointerEvents: 'none'
|
||||
},
|
||||
// https://github.com/ant-design/ant-design/issues/51380
|
||||
[`${componentCls}-icon > svg`]: (0, _style.resetIcon)(),
|
||||
'> a': {
|
||||
color: 'currentColor'
|
||||
},
|
||||
'&:not(:disabled)': (0, _style.genFocusStyle)(token),
|
||||
[`&${componentCls}-two-chinese-chars::first-letter`]: {
|
||||
letterSpacing: '0.34em'
|
||||
},
|
||||
[`&${componentCls}-two-chinese-chars > *:not(${iconCls})`]: {
|
||||
marginInlineEnd: '-0.34em',
|
||||
letterSpacing: '0.34em'
|
||||
},
|
||||
[`&${componentCls}-icon-only`]: {
|
||||
paddingInline: 0,
|
||||
// make `btn-icon-only` not too narrow
|
||||
[`&${componentCls}-compact-item`]: {
|
||||
flex: 'none'
|
||||
}
|
||||
},
|
||||
// Loading
|
||||
[`&${componentCls}-loading`]: {
|
||||
opacity: opacityLoading,
|
||||
cursor: 'default'
|
||||
},
|
||||
[`${componentCls}-loading-icon`]: {
|
||||
transition: ['width', 'opacity', 'margin'].map(transition => `${transition} ${motionDurationSlow} ${motionEaseInOut}`).join(',')
|
||||
},
|
||||
// iconPosition
|
||||
[`&:not(${componentCls}-icon-end)`]: {
|
||||
[`${componentCls}-loading-icon-motion`]: {
|
||||
'&-appear-start, &-enter-start': {
|
||||
marginInlineEnd: calc(iconGap).mul(-1).equal()
|
||||
},
|
||||
'&-appear-active, &-enter-active': {
|
||||
marginInlineEnd: 0
|
||||
},
|
||||
'&-leave-start': {
|
||||
marginInlineEnd: 0
|
||||
},
|
||||
'&-leave-active': {
|
||||
marginInlineEnd: calc(iconGap).mul(-1).equal()
|
||||
}
|
||||
}
|
||||
},
|
||||
'&-icon-end': {
|
||||
flexDirection: 'row-reverse',
|
||||
[`${componentCls}-loading-icon-motion`]: {
|
||||
'&-appear-start, &-enter-start': {
|
||||
marginInlineStart: calc(iconGap).mul(-1).equal()
|
||||
},
|
||||
'&-appear-active, &-enter-active': {
|
||||
marginInlineStart: 0
|
||||
},
|
||||
'&-leave-start': {
|
||||
marginInlineStart: 0
|
||||
},
|
||||
'&-leave-active': {
|
||||
marginInlineStart: calc(iconGap).mul(-1).equal()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
};
|
||||
const genHoverActiveButtonStyle = (btnCls, hoverStyle, activeStyle) => ({
|
||||
[`&:not(:disabled):not(${btnCls}-disabled)`]: {
|
||||
'&:hover': hoverStyle,
|
||||
'&:active': activeStyle
|
||||
}
|
||||
});
|
||||
// ============================== Shape ===============================
|
||||
const genCircleButtonStyle = token => ({
|
||||
minWidth: token.controlHeight,
|
||||
paddingInline: 0,
|
||||
borderRadius: '50%'
|
||||
});
|
||||
const genDisabledStyle = token => ({
|
||||
cursor: 'not-allowed',
|
||||
borderColor: token.borderColorDisabled,
|
||||
color: token.colorTextDisabled,
|
||||
background: token.colorBgContainerDisabled,
|
||||
boxShadow: 'none'
|
||||
});
|
||||
const genGhostButtonStyle = (btnCls, background, textColor, borderColor, textColorDisabled, borderColorDisabled, hoverStyle, activeStyle) => ({
|
||||
[`&${btnCls}-background-ghost`]: Object.assign(Object.assign({
|
||||
color: textColor || undefined,
|
||||
background,
|
||||
borderColor: borderColor || undefined,
|
||||
boxShadow: 'none'
|
||||
}, genHoverActiveButtonStyle(btnCls, Object.assign({
|
||||
background
|
||||
}, hoverStyle), Object.assign({
|
||||
background
|
||||
}, activeStyle))), {
|
||||
'&:disabled': {
|
||||
cursor: 'not-allowed',
|
||||
color: textColorDisabled || undefined,
|
||||
borderColor: borderColorDisabled || undefined
|
||||
}
|
||||
})
|
||||
});
|
||||
const genSolidDisabledButtonStyle = token => ({
|
||||
[`&:disabled, &${token.componentCls}-disabled`]: Object.assign({}, genDisabledStyle(token))
|
||||
});
|
||||
const genPureDisabledButtonStyle = token => ({
|
||||
[`&:disabled, &${token.componentCls}-disabled`]: {
|
||||
cursor: 'not-allowed',
|
||||
color: token.colorTextDisabled
|
||||
}
|
||||
});
|
||||
// ============================== Variant =============================
|
||||
const genVariantButtonStyle = (token, hoverStyle, activeStyle, variant) => {
|
||||
const isPureDisabled = variant && ['link', 'text'].includes(variant);
|
||||
const genDisabledButtonStyle = isPureDisabled ? genPureDisabledButtonStyle : genSolidDisabledButtonStyle;
|
||||
return Object.assign(Object.assign({}, genDisabledButtonStyle(token)), genHoverActiveButtonStyle(token.componentCls, hoverStyle, activeStyle));
|
||||
};
|
||||
const genSolidButtonStyle = (token, textColor, background, hoverStyle, activeStyle) => ({
|
||||
[`&${token.componentCls}-variant-solid`]: Object.assign({
|
||||
color: textColor,
|
||||
background
|
||||
}, genVariantButtonStyle(token, hoverStyle, activeStyle))
|
||||
});
|
||||
const genOutlinedDashedButtonStyle = (token, borderColor, background, hoverStyle, activeStyle) => ({
|
||||
[`&${token.componentCls}-variant-outlined, &${token.componentCls}-variant-dashed`]: Object.assign({
|
||||
borderColor,
|
||||
background
|
||||
}, genVariantButtonStyle(token, hoverStyle, activeStyle))
|
||||
});
|
||||
const genDashedButtonStyle = token => ({
|
||||
[`&${token.componentCls}-variant-dashed`]: {
|
||||
borderStyle: 'dashed'
|
||||
}
|
||||
});
|
||||
const genFilledButtonStyle = (token, background, hoverStyle, activeStyle) => ({
|
||||
[`&${token.componentCls}-variant-filled`]: Object.assign({
|
||||
boxShadow: 'none',
|
||||
background
|
||||
}, genVariantButtonStyle(token, hoverStyle, activeStyle))
|
||||
});
|
||||
const genTextLinkButtonStyle = (token, textColor, variant, hoverStyle, activeStyle) => ({
|
||||
[`&${token.componentCls}-variant-${variant}`]: Object.assign({
|
||||
color: textColor,
|
||||
boxShadow: 'none'
|
||||
}, genVariantButtonStyle(token, hoverStyle, activeStyle, variant))
|
||||
});
|
||||
// =============================== Color ==============================
|
||||
const genPresetColorStyle = token => {
|
||||
const {
|
||||
componentCls
|
||||
} = token;
|
||||
return _interface.PresetColors.reduce((prev, colorKey) => {
|
||||
const darkColor = token[`${colorKey}6`];
|
||||
const lightColor = token[`${colorKey}1`];
|
||||
const hoverColor = token[`${colorKey}5`];
|
||||
const lightHoverColor = token[`${colorKey}2`];
|
||||
const lightBorderColor = token[`${colorKey}3`];
|
||||
const activeColor = token[`${colorKey}7`];
|
||||
return Object.assign(Object.assign({}, prev), {
|
||||
[`&${componentCls}-color-${colorKey}`]: Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({
|
||||
color: darkColor,
|
||||
boxShadow: token[`${colorKey}ShadowColor`]
|
||||
}, genSolidButtonStyle(token, token.colorTextLightSolid, darkColor, {
|
||||
background: hoverColor
|
||||
}, {
|
||||
background: activeColor
|
||||
})), genOutlinedDashedButtonStyle(token, darkColor, token.colorBgContainer, {
|
||||
color: hoverColor,
|
||||
borderColor: hoverColor,
|
||||
background: token.colorBgContainer
|
||||
}, {
|
||||
color: activeColor,
|
||||
borderColor: activeColor,
|
||||
background: token.colorBgContainer
|
||||
})), genDashedButtonStyle(token)), genFilledButtonStyle(token, lightColor, {
|
||||
color: darkColor,
|
||||
background: lightHoverColor
|
||||
}, {
|
||||
color: darkColor,
|
||||
background: lightBorderColor
|
||||
})), genTextLinkButtonStyle(token, darkColor, 'link', {
|
||||
color: hoverColor
|
||||
}, {
|
||||
color: activeColor
|
||||
})), genTextLinkButtonStyle(token, darkColor, 'text', {
|
||||
color: hoverColor,
|
||||
background: lightColor
|
||||
}, {
|
||||
color: activeColor,
|
||||
background: lightBorderColor
|
||||
}))
|
||||
});
|
||||
}, {});
|
||||
};
|
||||
const genDefaultButtonStyle = token => Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({
|
||||
color: token.defaultColor,
|
||||
boxShadow: token.defaultShadow
|
||||
}, genSolidButtonStyle(token, token.solidTextColor, token.colorBgSolid, {
|
||||
color: token.solidTextColor,
|
||||
background: token.colorBgSolidHover
|
||||
}, {
|
||||
color: token.solidTextColor,
|
||||
background: token.colorBgSolidActive
|
||||
})), genDashedButtonStyle(token)), genFilledButtonStyle(token, token.colorFillTertiary, {
|
||||
color: token.defaultColor,
|
||||
background: token.colorFillSecondary
|
||||
}, {
|
||||
color: token.defaultColor,
|
||||
background: token.colorFill
|
||||
})), genGhostButtonStyle(token.componentCls, token.ghostBg, token.defaultGhostColor, token.defaultGhostBorderColor, token.colorTextDisabled, token.colorBorder)), genTextLinkButtonStyle(token, token.textTextColor, 'link', {
|
||||
color: token.colorLinkHover,
|
||||
background: token.linkHoverBg
|
||||
}, {
|
||||
color: token.colorLinkActive
|
||||
}));
|
||||
const genPrimaryButtonStyle = token => Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({
|
||||
color: token.colorPrimary,
|
||||
boxShadow: token.primaryShadow
|
||||
}, genOutlinedDashedButtonStyle(token, token.colorPrimary, token.colorBgContainer, {
|
||||
color: token.colorPrimaryTextHover,
|
||||
borderColor: token.colorPrimaryHover,
|
||||
background: token.colorBgContainer
|
||||
}, {
|
||||
color: token.colorPrimaryTextActive,
|
||||
borderColor: token.colorPrimaryActive,
|
||||
background: token.colorBgContainer
|
||||
})), genDashedButtonStyle(token)), genFilledButtonStyle(token, token.colorPrimaryBg, {
|
||||
color: token.colorPrimary,
|
||||
background: token.colorPrimaryBgHover
|
||||
}, {
|
||||
color: token.colorPrimary,
|
||||
background: token.colorPrimaryBorder
|
||||
})), genTextLinkButtonStyle(token, token.colorPrimaryText, 'text', {
|
||||
color: token.colorPrimaryTextHover,
|
||||
background: token.colorPrimaryBg
|
||||
}, {
|
||||
color: token.colorPrimaryTextActive,
|
||||
background: token.colorPrimaryBorder
|
||||
})), genTextLinkButtonStyle(token, token.colorPrimaryText, 'link', {
|
||||
color: token.colorPrimaryTextHover,
|
||||
background: token.linkHoverBg
|
||||
}, {
|
||||
color: token.colorPrimaryTextActive
|
||||
})), genGhostButtonStyle(token.componentCls, token.ghostBg, token.colorPrimary, token.colorPrimary, token.colorTextDisabled, token.colorBorder, {
|
||||
color: token.colorPrimaryHover,
|
||||
borderColor: token.colorPrimaryHover
|
||||
}, {
|
||||
color: token.colorPrimaryActive,
|
||||
borderColor: token.colorPrimaryActive
|
||||
}));
|
||||
const genDangerousStyle = token => Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({
|
||||
color: token.colorError,
|
||||
boxShadow: token.dangerShadow
|
||||
}, genSolidButtonStyle(token, token.dangerColor, token.colorError, {
|
||||
background: token.colorErrorHover
|
||||
}, {
|
||||
background: token.colorErrorActive
|
||||
})), genOutlinedDashedButtonStyle(token, token.colorError, token.colorBgContainer, {
|
||||
color: token.colorErrorHover,
|
||||
borderColor: token.colorErrorBorderHover
|
||||
}, {
|
||||
color: token.colorErrorActive,
|
||||
borderColor: token.colorErrorActive
|
||||
})), genDashedButtonStyle(token)), genFilledButtonStyle(token, token.colorErrorBg, {
|
||||
color: token.colorError,
|
||||
background: token.colorErrorBgFilledHover
|
||||
}, {
|
||||
color: token.colorError,
|
||||
background: token.colorErrorBgActive
|
||||
})), genTextLinkButtonStyle(token, token.colorError, 'text', {
|
||||
color: token.colorErrorHover,
|
||||
background: token.colorErrorBg
|
||||
}, {
|
||||
color: token.colorErrorHover,
|
||||
background: token.colorErrorBgActive
|
||||
})), genTextLinkButtonStyle(token, token.colorError, 'link', {
|
||||
color: token.colorErrorHover
|
||||
}, {
|
||||
color: token.colorErrorActive
|
||||
})), genGhostButtonStyle(token.componentCls, token.ghostBg, token.colorError, token.colorError, token.colorTextDisabled, token.colorBorder, {
|
||||
color: token.colorErrorHover,
|
||||
borderColor: token.colorErrorHover
|
||||
}, {
|
||||
color: token.colorErrorActive,
|
||||
borderColor: token.colorErrorActive
|
||||
}));
|
||||
const genLinkStyle = token => Object.assign(Object.assign({}, genTextLinkButtonStyle(token, token.colorLink, 'link', {
|
||||
color: token.colorLinkHover
|
||||
}, {
|
||||
color: token.colorLinkActive
|
||||
})), genGhostButtonStyle(token.componentCls, token.ghostBg, token.colorInfo, token.colorInfo, token.colorTextDisabled, token.colorBorder, {
|
||||
color: token.colorInfoHover,
|
||||
borderColor: token.colorInfoHover
|
||||
}, {
|
||||
color: token.colorInfoActive,
|
||||
borderColor: token.colorInfoActive
|
||||
}));
|
||||
const genColorButtonStyle = token => {
|
||||
const {
|
||||
componentCls
|
||||
} = token;
|
||||
return Object.assign({
|
||||
[`${componentCls}-color-default`]: genDefaultButtonStyle(token),
|
||||
[`${componentCls}-color-primary`]: genPrimaryButtonStyle(token),
|
||||
[`${componentCls}-color-dangerous`]: genDangerousStyle(token),
|
||||
[`${componentCls}-color-link`]: genLinkStyle(token)
|
||||
}, genPresetColorStyle(token));
|
||||
};
|
||||
// =========== Compatible with versions earlier than 5.21.0 ===========
|
||||
const genCompatibleButtonStyle = token => Object.assign(Object.assign(Object.assign(Object.assign({}, genOutlinedDashedButtonStyle(token, token.defaultBorderColor, token.defaultBg, {
|
||||
color: token.defaultHoverColor,
|
||||
borderColor: token.defaultHoverBorderColor,
|
||||
background: token.defaultHoverBg
|
||||
}, {
|
||||
color: token.defaultActiveColor,
|
||||
borderColor: token.defaultActiveBorderColor,
|
||||
background: token.defaultActiveBg
|
||||
})), genTextLinkButtonStyle(token, token.textTextColor, 'text', {
|
||||
color: token.textTextHoverColor,
|
||||
background: token.textHoverBg
|
||||
}, {
|
||||
color: token.textTextActiveColor,
|
||||
background: token.colorBgTextActive
|
||||
})), genSolidButtonStyle(token, token.primaryColor, token.colorPrimary, {
|
||||
background: token.colorPrimaryHover,
|
||||
color: token.primaryColor
|
||||
}, {
|
||||
background: token.colorPrimaryActive,
|
||||
color: token.primaryColor
|
||||
})), genTextLinkButtonStyle(token, token.colorLink, 'link', {
|
||||
color: token.colorLinkHover,
|
||||
background: token.linkHoverBg
|
||||
}, {
|
||||
color: token.colorLinkActive
|
||||
}));
|
||||
// =============================== Size ===============================
|
||||
const genButtonStyle = (token, prefixCls = '') => {
|
||||
const {
|
||||
componentCls,
|
||||
controlHeight,
|
||||
fontSize,
|
||||
borderRadius,
|
||||
buttonPaddingHorizontal,
|
||||
iconCls,
|
||||
buttonPaddingVertical,
|
||||
buttonIconOnlyFontSize
|
||||
} = token;
|
||||
return [{
|
||||
[prefixCls]: {
|
||||
fontSize,
|
||||
height: controlHeight,
|
||||
padding: `${(0, _cssinjs.unit)(buttonPaddingVertical)} ${(0, _cssinjs.unit)(buttonPaddingHorizontal)}`,
|
||||
borderRadius,
|
||||
[`&${componentCls}-icon-only`]: {
|
||||
width: controlHeight,
|
||||
[iconCls]: {
|
||||
fontSize: buttonIconOnlyFontSize
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
// Shape - patch prefixCls again to override solid border radius style
|
||||
{
|
||||
[`${componentCls}${componentCls}-circle${prefixCls}`]: genCircleButtonStyle(token)
|
||||
}, {
|
||||
[`${componentCls}${componentCls}-round${prefixCls}`]: {
|
||||
borderRadius: token.controlHeight,
|
||||
[`&:not(${componentCls}-icon-only)`]: {
|
||||
paddingInline: token.buttonPaddingHorizontal
|
||||
}
|
||||
}
|
||||
}];
|
||||
};
|
||||
const genSizeBaseButtonStyle = token => {
|
||||
const baseToken = (0, _internal.mergeToken)(token, {
|
||||
fontSize: token.contentFontSize
|
||||
});
|
||||
return genButtonStyle(baseToken, token.componentCls);
|
||||
};
|
||||
const genSizeSmallButtonStyle = token => {
|
||||
const smallToken = (0, _internal.mergeToken)(token, {
|
||||
controlHeight: token.controlHeightSM,
|
||||
fontSize: token.contentFontSizeSM,
|
||||
padding: token.paddingXS,
|
||||
buttonPaddingHorizontal: token.paddingInlineSM,
|
||||
buttonPaddingVertical: 0,
|
||||
borderRadius: token.borderRadiusSM,
|
||||
buttonIconOnlyFontSize: token.onlyIconSizeSM
|
||||
});
|
||||
return genButtonStyle(smallToken, `${token.componentCls}-sm`);
|
||||
};
|
||||
const genSizeLargeButtonStyle = token => {
|
||||
const largeToken = (0, _internal.mergeToken)(token, {
|
||||
controlHeight: token.controlHeightLG,
|
||||
fontSize: token.contentFontSizeLG,
|
||||
buttonPaddingHorizontal: token.paddingInlineLG,
|
||||
buttonPaddingVertical: 0,
|
||||
borderRadius: token.borderRadiusLG,
|
||||
buttonIconOnlyFontSize: token.onlyIconSizeLG
|
||||
});
|
||||
return genButtonStyle(largeToken, `${token.componentCls}-lg`);
|
||||
};
|
||||
const genBlockButtonStyle = token => {
|
||||
const {
|
||||
componentCls
|
||||
} = token;
|
||||
return {
|
||||
[componentCls]: {
|
||||
[`&${componentCls}-block`]: {
|
||||
width: '100%'
|
||||
}
|
||||
}
|
||||
};
|
||||
};
|
||||
// ============================== Export ==============================
|
||||
var _default = exports.default = (0, _internal.genStyleHooks)('Button', token => {
|
||||
const buttonToken = (0, _token.prepareToken)(token);
|
||||
return [
|
||||
// Shared
|
||||
genSharedButtonStyle(buttonToken),
|
||||
// Size
|
||||
genSizeBaseButtonStyle(buttonToken), genSizeSmallButtonStyle(buttonToken), genSizeLargeButtonStyle(buttonToken),
|
||||
// Block
|
||||
genBlockButtonStyle(buttonToken),
|
||||
// Color
|
||||
genColorButtonStyle(buttonToken),
|
||||
// https://github.com/ant-design/ant-design/issues/50969
|
||||
genCompatibleButtonStyle(buttonToken),
|
||||
// Button Group
|
||||
(0, _group.default)(buttonToken)];
|
||||
}, _token.prepareComponentToken, {
|
||||
unitless: {
|
||||
fontWeight: true,
|
||||
contentLineHeight: true,
|
||||
contentLineHeightSM: true,
|
||||
contentLineHeightLG: true
|
||||
}
|
||||
});
|
||||
Reference in New Issue
Block a user