import { unit } from '@ant-design/cssinjs'; import type { UploadToken } from '.'; import { clearFix, textEllipsis } from '../../style'; import type { GenerateStyle } from '../../theme/internal'; const genListStyle: GenerateStyle = (token) => { const { componentCls, antCls, iconCls, fontSize, lineHeight, calc } = token; const itemCls = `${componentCls}-list-item`; const actionsCls = `${itemCls}-actions`; const actionCls = `${itemCls}-action`; const listItemHeightSM = token.fontHeightSM; return { [`${componentCls}-wrapper`]: { [`${componentCls}-list`]: { ...clearFix(), lineHeight: token.lineHeight, [itemCls]: { position: 'relative', height: calc(token.lineHeight).mul(fontSize).equal(), marginTop: token.marginXS, fontSize, display: 'flex', alignItems: 'center', transition: `background-color ${token.motionDurationSlow}`, '&:hover': { backgroundColor: token.controlItemBgHover, }, [`${itemCls}-name`]: { ...textEllipsis, padding: `0 ${unit(token.paddingXS)}`, lineHeight, flex: 'auto', transition: `all ${token.motionDurationSlow}`, }, [actionsCls]: { [actionCls]: { opacity: 0, }, [`${actionCls}${antCls}-btn-sm`]: { height: listItemHeightSM, border: 0, lineHeight: 1, // FIXME: should not override small button '> span': { transform: 'scale(1)', }, }, [` ${actionCls}:focus-visible, &.picture ${actionCls} `]: { opacity: 1, }, [iconCls]: { color: token.actionsColor, transition: `all ${token.motionDurationSlow}`, }, [`&:hover ${iconCls}`]: { color: token.colorText, }, }, [`${componentCls}-icon ${iconCls}`]: { color: token.colorTextDescription, fontSize, }, [`${itemCls}-progress`]: { position: 'absolute', bottom: token.calc(token.uploadProgressOffset).mul(-1).equal(), width: '100%', paddingInlineStart: calc(fontSize).add(token.paddingXS).equal(), fontSize, lineHeight: 0, pointerEvents: 'none', '> div': { margin: 0, }, }, }, [`${itemCls}:hover ${actionCls}`]: { opacity: 1, color: token.colorText, }, [`${itemCls}-error`]: { color: token.colorError, [`${itemCls}-name, ${componentCls}-icon ${iconCls}`]: { color: token.colorError, }, [actionsCls]: { [`${iconCls}, ${iconCls}:hover`]: { color: token.colorError, }, [actionCls]: { opacity: 1, }, }, }, [`${componentCls}-list-item-container`]: { transition: `opacity ${token.motionDurationSlow}, height ${token.motionDurationSlow}`, // For smooth removing animation '&::before': { display: 'table', width: 0, height: 0, content: '""', }, }, }, }, }; }; export default genListStyle;