123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310 |
- import { unit } from '@ant-design/cssinjs';
- import { FastColor } from '@ant-design/fast-color';
- import { genModalMaskStyle } from '../../modal/style';
- import { textEllipsis } from '../../style';
- import { initFadeMotion, initZoomMotion } from '../../style/motion';
- import { genStyleHooks, mergeToken } from '../../theme/internal';
- export const genBoxStyle = position => ({
- position: position || 'absolute',
- inset: 0
- });
- export const genImageMaskStyle = token => {
- const {
- iconCls,
- motionDurationSlow,
- paddingXXS,
- marginXXS,
- prefixCls,
- colorTextLightSolid
- } = token;
- return {
- position: 'absolute',
- inset: 0,
- display: 'flex',
- alignItems: 'center',
- justifyContent: 'center',
- color: colorTextLightSolid,
- background: new FastColor('#000').setA(0.5).toRgbString(),
- cursor: 'pointer',
- opacity: 0,
- transition: `opacity ${motionDurationSlow}`,
- [`.${prefixCls}-mask-info`]: Object.assign(Object.assign({}, textEllipsis), {
- padding: `0 ${unit(paddingXXS)}`,
- [iconCls]: {
- marginInlineEnd: marginXXS,
- svg: {
- verticalAlign: 'baseline'
- }
- }
- })
- };
- };
- export const genPreviewOperationsStyle = token => {
- const {
- previewCls,
- modalMaskBg,
- paddingSM,
- marginXL,
- margin,
- paddingLG,
- previewOperationColorDisabled,
- previewOperationHoverColor,
- motionDurationSlow,
- iconCls,
- colorTextLightSolid
- } = token;
- const operationBg = new FastColor(modalMaskBg).setA(0.1);
- const operationBgHover = operationBg.clone().setA(0.2);
- return {
- [`${previewCls}-footer`]: {
- position: 'fixed',
- bottom: marginXL,
- left: {
- _skip_check_: true,
- value: '50%'
- },
- display: 'flex',
- flexDirection: 'column',
- alignItems: 'center',
- color: token.previewOperationColor,
- transform: 'translateX(-50%)'
- },
- [`${previewCls}-progress`]: {
- marginBottom: margin
- },
- [`${previewCls}-close`]: {
- position: 'fixed',
- top: marginXL,
- right: {
- _skip_check_: true,
- value: marginXL
- },
- display: 'flex',
- color: colorTextLightSolid,
- backgroundColor: operationBg.toRgbString(),
- borderRadius: '50%',
- padding: paddingSM,
- outline: 0,
- border: 0,
- cursor: 'pointer',
- transition: `all ${motionDurationSlow}`,
- '&:hover': {
- backgroundColor: operationBgHover.toRgbString()
- },
- [`& > ${iconCls}`]: {
- fontSize: token.previewOperationSize
- }
- },
- [`${previewCls}-operations`]: {
- display: 'flex',
- alignItems: 'center',
- padding: `0 ${unit(paddingLG)}`,
- backgroundColor: operationBg.toRgbString(),
- borderRadius: 100,
- '&-operation': {
- marginInlineStart: paddingSM,
- padding: paddingSM,
- cursor: 'pointer',
- transition: `all ${motionDurationSlow}`,
- userSelect: 'none',
- [`&:not(${previewCls}-operations-operation-disabled):hover > ${iconCls}`]: {
- color: previewOperationHoverColor
- },
- '&-disabled': {
- color: previewOperationColorDisabled,
- cursor: 'not-allowed'
- },
- '&:first-of-type': {
- marginInlineStart: 0
- },
- [`& > ${iconCls}`]: {
- fontSize: token.previewOperationSize
- }
- }
- }
- };
- };
- export const genPreviewSwitchStyle = token => {
- const {
- modalMaskBg,
- iconCls,
- previewOperationColorDisabled,
- previewCls,
- zIndexPopup,
- motionDurationSlow
- } = token;
- const operationBg = new FastColor(modalMaskBg).setA(0.1);
- const operationBgHover = operationBg.clone().setA(0.2);
- return {
- [`${previewCls}-switch-left, ${previewCls}-switch-right`]: {
- position: 'fixed',
- insetBlockStart: '50%',
- zIndex: token.calc(zIndexPopup).add(1).equal(),
- display: 'flex',
- alignItems: 'center',
- justifyContent: 'center',
- width: token.imagePreviewSwitchSize,
- height: token.imagePreviewSwitchSize,
- marginTop: token.calc(token.imagePreviewSwitchSize).mul(-1).div(2).equal(),
- color: token.previewOperationColor,
- background: operationBg.toRgbString(),
- borderRadius: '50%',
- transform: `translateY(-50%)`,
- cursor: 'pointer',
- transition: `all ${motionDurationSlow}`,
- userSelect: 'none',
- '&:hover': {
- background: operationBgHover.toRgbString()
- },
- '&-disabled': {
- '&, &:hover': {
- color: previewOperationColorDisabled,
- background: 'transparent',
- cursor: 'not-allowed',
- [`> ${iconCls}`]: {
- cursor: 'not-allowed'
- }
- }
- },
- [`> ${iconCls}`]: {
- fontSize: token.previewOperationSize
- }
- },
- [`${previewCls}-switch-left`]: {
- insetInlineStart: token.marginSM
- },
- [`${previewCls}-switch-right`]: {
- insetInlineEnd: token.marginSM
- }
- };
- };
- export const genImagePreviewStyle = token => {
- const {
- motionEaseOut,
- previewCls,
- motionDurationSlow,
- componentCls
- } = token;
- return [{
- [`${componentCls}-preview-root`]: {
- [previewCls]: {
- height: '100%',
- textAlign: 'center',
- pointerEvents: 'none'
- },
- [`${previewCls}-body`]: Object.assign(Object.assign({}, genBoxStyle()), {
- overflow: 'hidden'
- }),
- [`${previewCls}-img`]: {
- maxWidth: '100%',
- maxHeight: '70%',
- verticalAlign: 'middle',
- transform: 'scale3d(1, 1, 1)',
- cursor: 'grab',
- transition: `transform ${motionDurationSlow} ${motionEaseOut} 0s`,
- userSelect: 'none',
- '&-wrapper': Object.assign(Object.assign({}, genBoxStyle()), {
- transition: `transform ${motionDurationSlow} ${motionEaseOut} 0s`,
- // https://github.com/ant-design/ant-design/issues/39913
- // TailwindCSS will reset img default style.
- // Let's set back.
- display: 'flex',
- justifyContent: 'center',
- alignItems: 'center',
- '& > *': {
- pointerEvents: 'auto'
- },
- '&::before': {
- display: 'inline-block',
- width: 1,
- height: '50%',
- marginInlineEnd: -1,
- content: '""'
- }
- })
- },
- [`${previewCls}-moving`]: {
- [`${previewCls}-preview-img`]: {
- cursor: 'grabbing',
- '&-wrapper': {
- transitionDuration: '0s'
- }
- }
- }
- }
- },
- // Override
- {
- [`${componentCls}-preview-root`]: {
- [`${previewCls}-wrap`]: {
- zIndex: token.zIndexPopup
- }
- }
- },
- // Preview operations & switch
- {
- [`${componentCls}-preview-operations-wrapper`]: {
- position: 'fixed',
- zIndex: token.calc(token.zIndexPopup).add(1).equal()
- },
- '&': [genPreviewOperationsStyle(token), genPreviewSwitchStyle(token)]
- }];
- };
- const genImageStyle = token => {
- const {
- componentCls
- } = token;
- return {
- // ============================== image ==============================
- [componentCls]: {
- position: 'relative',
- display: 'inline-block',
- [`${componentCls}-img`]: {
- width: '100%',
- height: 'auto',
- verticalAlign: 'middle'
- },
- [`${componentCls}-img-placeholder`]: {
- backgroundColor: token.colorBgContainerDisabled,
- backgroundImage: "url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHZpZXdCb3g9IjAgMCAxNiAxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMTQuNSAyLjVoLTEzQS41LjUgMCAwIDAgMSAzdjEwYS41LjUgMCAwIDAgLjUuNWgxM2EuNS41IDAgMCAwIC41LS41VjNhLjUuNSAwIDAgMC0uNS0uNXpNNS4yODEgNC43NWExIDEgMCAwIDEgMCAyIDEgMSAwIDAgMSAwLTJ6bTguMDMgNi44M2EuMTI3LjEyNyAwIDAgMS0uMDgxLjAzSDIuNzY5YS4xMjUuMTI1IDAgMCAxLS4wOTYtLjIwN2wyLjY2MS0zLjE1NmEuMTI2LjEyNiAwIDAgMSAuMTc3LS4wMTZsLjAxNi4wMTZMNy4wOCAxMC4wOWwyLjQ3LTIuOTNhLjEyNi4xMjYgMCAwIDEgLjE3Ny0uMDE2bC4wMTUuMDE2IDMuNTg4IDQuMjQ0YS4xMjcuMTI3IDAgMCAxLS4wMi4xNzV6IiBmaWxsPSIjOEM4QzhDIiBmaWxsLXJ1bGU9Im5vbnplcm8iLz48L3N2Zz4=')",
- backgroundRepeat: 'no-repeat',
- backgroundPosition: 'center center',
- backgroundSize: '30%'
- },
- [`${componentCls}-mask`]: Object.assign({}, genImageMaskStyle(token)),
- [`${componentCls}-mask:hover`]: {
- opacity: 1
- },
- [`${componentCls}-placeholder`]: Object.assign({}, genBoxStyle())
- }
- };
- };
- const genPreviewMotion = token => {
- const {
- previewCls
- } = token;
- return {
- [`${previewCls}-root`]: initZoomMotion(token, 'zoom'),
- '&': initFadeMotion(token, true)
- };
- };
- // ============================== Export ==============================
- export const prepareComponentToken = token => ({
- zIndexPopup: token.zIndexPopupBase + 80,
- previewOperationColor: new FastColor(token.colorTextLightSolid).setA(0.65).toRgbString(),
- previewOperationHoverColor: new FastColor(token.colorTextLightSolid).setA(0.85).toRgbString(),
- previewOperationColorDisabled: new FastColor(token.colorTextLightSolid).setA(0.25).toRgbString(),
- previewOperationSize: token.fontSizeIcon * 1.5 // FIXME: fontSizeIconLG
- });
- export default genStyleHooks('Image', token => {
- const previewCls = `${token.componentCls}-preview`;
- const imageToken = mergeToken(token, {
- previewCls,
- modalMaskBg: new FastColor('#000').setA(0.45).toRgbString(),
- // FIXME: Shared Token
- imagePreviewSwitchSize: token.controlHeightLG
- });
- return [genImageStyle(imageToken), genImagePreviewStyle(imageToken), genModalMaskStyle(mergeToken(imageToken, {
- componentCls: previewCls
- })), genPreviewMotion(imageToken)];
- }, prepareComponentToken);
|