198 lines
5.9 KiB
JavaScript
198 lines
5.9 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.prepareComponentToken = exports.default = void 0;
|
|
var _cssinjs = require("@ant-design/cssinjs");
|
|
var _style = require("../../style");
|
|
var _internal = require("../../theme/internal");
|
|
const genBorderedStyle = token => {
|
|
const {
|
|
componentCls,
|
|
labelBg
|
|
} = token;
|
|
return {
|
|
[`&${componentCls}-bordered`]: {
|
|
[`> ${componentCls}-view`]: {
|
|
overflow: 'hidden',
|
|
border: `${(0, _cssinjs.unit)(token.lineWidth)} ${token.lineType} ${token.colorSplit}`,
|
|
'> table': {
|
|
tableLayout: 'auto'
|
|
},
|
|
[`${componentCls}-row`]: {
|
|
borderBottom: `${(0, _cssinjs.unit)(token.lineWidth)} ${token.lineType} ${token.colorSplit}`,
|
|
'&:last-child': {
|
|
borderBottom: 'none'
|
|
},
|
|
[`> ${componentCls}-item-label, > ${componentCls}-item-content`]: {
|
|
padding: `${(0, _cssinjs.unit)(token.padding)} ${(0, _cssinjs.unit)(token.paddingLG)}`,
|
|
borderInlineEnd: `${(0, _cssinjs.unit)(token.lineWidth)} ${token.lineType} ${token.colorSplit}`,
|
|
'&:last-child': {
|
|
borderInlineEnd: 'none'
|
|
}
|
|
},
|
|
[`> ${componentCls}-item-label`]: {
|
|
color: token.colorTextSecondary,
|
|
backgroundColor: labelBg,
|
|
'&::after': {
|
|
display: 'none'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
[`&${componentCls}-middle`]: {
|
|
[`${componentCls}-row`]: {
|
|
[`> ${componentCls}-item-label, > ${componentCls}-item-content`]: {
|
|
padding: `${(0, _cssinjs.unit)(token.paddingSM)} ${(0, _cssinjs.unit)(token.paddingLG)}`
|
|
}
|
|
}
|
|
},
|
|
[`&${componentCls}-small`]: {
|
|
[`${componentCls}-row`]: {
|
|
[`> ${componentCls}-item-label, > ${componentCls}-item-content`]: {
|
|
padding: `${(0, _cssinjs.unit)(token.paddingXS)} ${(0, _cssinjs.unit)(token.padding)}`
|
|
}
|
|
}
|
|
}
|
|
}
|
|
};
|
|
};
|
|
const genDescriptionStyles = token => {
|
|
const {
|
|
componentCls,
|
|
extraColor,
|
|
itemPaddingBottom,
|
|
itemPaddingEnd,
|
|
colonMarginRight,
|
|
colonMarginLeft,
|
|
titleMarginBottom
|
|
} = token;
|
|
return {
|
|
[componentCls]: Object.assign(Object.assign(Object.assign({}, (0, _style.resetComponent)(token)), genBorderedStyle(token)), {
|
|
'&-rtl': {
|
|
direction: 'rtl'
|
|
},
|
|
[`${componentCls}-header`]: {
|
|
display: 'flex',
|
|
alignItems: 'center',
|
|
marginBottom: titleMarginBottom
|
|
},
|
|
[`${componentCls}-title`]: Object.assign(Object.assign({}, _style.textEllipsis), {
|
|
flex: 'auto',
|
|
color: token.titleColor,
|
|
fontWeight: token.fontWeightStrong,
|
|
fontSize: token.fontSizeLG,
|
|
lineHeight: token.lineHeightLG
|
|
}),
|
|
[`${componentCls}-extra`]: {
|
|
marginInlineStart: 'auto',
|
|
color: extraColor,
|
|
fontSize: token.fontSize
|
|
},
|
|
[`${componentCls}-view`]: {
|
|
width: '100%',
|
|
borderRadius: token.borderRadiusLG,
|
|
table: {
|
|
width: '100%',
|
|
tableLayout: 'fixed',
|
|
borderCollapse: 'collapse'
|
|
}
|
|
},
|
|
[`${componentCls}-row`]: {
|
|
'> th, > td': {
|
|
paddingBottom: itemPaddingBottom,
|
|
paddingInlineEnd: itemPaddingEnd
|
|
},
|
|
'> th:last-child, > td:last-child': {
|
|
paddingInlineEnd: 0
|
|
},
|
|
'&:last-child': {
|
|
borderBottom: 'none',
|
|
'> th, > td': {
|
|
paddingBottom: 0
|
|
}
|
|
}
|
|
},
|
|
[`${componentCls}-item-label`]: {
|
|
color: token.colorTextTertiary,
|
|
fontWeight: 'normal',
|
|
fontSize: token.fontSize,
|
|
lineHeight: token.lineHeight,
|
|
textAlign: 'start',
|
|
'&::after': {
|
|
content: '":"',
|
|
position: 'relative',
|
|
top: -0.5,
|
|
// magic for position
|
|
marginInline: `${(0, _cssinjs.unit)(colonMarginLeft)} ${(0, _cssinjs.unit)(colonMarginRight)}`
|
|
},
|
|
[`&${componentCls}-item-no-colon::after`]: {
|
|
content: '""'
|
|
}
|
|
},
|
|
[`${componentCls}-item-no-label`]: {
|
|
'&::after': {
|
|
margin: 0,
|
|
content: '""'
|
|
}
|
|
},
|
|
[`${componentCls}-item-content`]: {
|
|
display: 'table-cell',
|
|
flex: 1,
|
|
color: token.contentColor,
|
|
fontSize: token.fontSize,
|
|
lineHeight: token.lineHeight,
|
|
wordBreak: 'break-word',
|
|
overflowWrap: 'break-word'
|
|
},
|
|
[`${componentCls}-item`]: {
|
|
paddingBottom: 0,
|
|
verticalAlign: 'top',
|
|
'&-container': {
|
|
display: 'flex',
|
|
[`${componentCls}-item-label`]: {
|
|
display: 'inline-flex',
|
|
alignItems: 'baseline'
|
|
},
|
|
[`${componentCls}-item-content`]: {
|
|
display: 'inline-flex',
|
|
alignItems: 'baseline',
|
|
minWidth: 0
|
|
}
|
|
}
|
|
},
|
|
'&-middle': {
|
|
[`${componentCls}-row`]: {
|
|
'> th, > td': {
|
|
paddingBottom: token.paddingSM
|
|
}
|
|
}
|
|
},
|
|
'&-small': {
|
|
[`${componentCls}-row`]: {
|
|
'> th, > td': {
|
|
paddingBottom: token.paddingXS
|
|
}
|
|
}
|
|
}
|
|
})
|
|
};
|
|
};
|
|
const prepareComponentToken = token => ({
|
|
labelBg: token.colorFillAlter,
|
|
titleColor: token.colorText,
|
|
titleMarginBottom: token.fontSizeSM * token.lineHeightSM,
|
|
itemPaddingBottom: token.padding,
|
|
itemPaddingEnd: token.padding,
|
|
colonMarginRight: token.marginXS,
|
|
colonMarginLeft: token.marginXXS / 2,
|
|
contentColor: token.colorText,
|
|
extraColor: token.colorText
|
|
});
|
|
// ============================== Export ==============================
|
|
exports.prepareComponentToken = prepareComponentToken;
|
|
var _default = exports.default = (0, _internal.genStyleHooks)('Descriptions', token => {
|
|
const descriptionToken = (0, _internal.mergeToken)(token, {});
|
|
return genDescriptionStyles(descriptionToken);
|
|
}, prepareComponentToken); |