mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-22 17:13:27 +08:00
2b947d0480
* feat: site previewImage * feat: site previewImage * feat: use image * feat: update doc * feat: delete align="right" * feat: update doc * feat: delete css * feat: update doc * feat: delete align="right" * feat: update doc
107 lines
2.9 KiB
TypeScript
107 lines
2.9 KiB
TypeScript
import React from 'react';
|
|
import classNames from 'classnames';
|
|
import { Image } from 'antd';
|
|
import toArray from 'rc-util/lib/Children/toArray';
|
|
|
|
interface ImagePreviewProps {
|
|
children: React.ReactNode[];
|
|
}
|
|
|
|
function isGood(className: string): boolean {
|
|
return /\bgood\b/i.test(className);
|
|
}
|
|
|
|
function isBad(className: string): boolean {
|
|
return /\bbad\b/i.test(className);
|
|
}
|
|
|
|
function isInline(className: string): boolean {
|
|
return /\binline\b/i.test(className);
|
|
}
|
|
|
|
function isGoodBadImg(imgMeta: any): boolean {
|
|
return imgMeta.isGood || imgMeta.isBad;
|
|
}
|
|
|
|
function isCompareImg(imgMeta: any): boolean {
|
|
return isGoodBadImg(imgMeta) || imgMeta.inline;
|
|
}
|
|
|
|
const ImagePreview: React.FC<ImagePreviewProps> = (props) => {
|
|
const { children } = props;
|
|
const imgs = toArray(children).filter((ele) => ele.type === 'img');
|
|
|
|
const imgsMeta = imgs.map((img) => {
|
|
const { alt, description, src, className } = img.props;
|
|
return {
|
|
className,
|
|
alt,
|
|
description,
|
|
src,
|
|
isGood: isGood(className),
|
|
isBad: isBad(className),
|
|
inline: isInline(className),
|
|
};
|
|
});
|
|
|
|
const imagesList = imgsMeta.map<React.ReactNode>((meta, index) => {
|
|
const metaCopy = { ...meta };
|
|
delete metaCopy.description;
|
|
delete metaCopy.isGood;
|
|
delete metaCopy.isBad;
|
|
return (
|
|
<div key={index}>
|
|
<div className="image-modal-container">
|
|
<img {...metaCopy} src={meta.src} alt={meta.alt} />
|
|
</div>
|
|
</div>
|
|
);
|
|
});
|
|
|
|
const comparable =
|
|
(imgs.length === 2 && imgsMeta.every(isCompareImg)) ||
|
|
(imgs.length >= 2 && imgsMeta.every(isGoodBadImg));
|
|
|
|
const style: React.CSSProperties = comparable
|
|
? { width: `${(100 / imgs.length).toFixed(3)}%` }
|
|
: {};
|
|
|
|
const hasCarousel = imgs.length > 1 && !comparable;
|
|
const previewClassName = classNames({
|
|
'preview-image-boxes': true,
|
|
clearfix: true,
|
|
'preview-image-boxes-compare': comparable,
|
|
'preview-image-boxes-with-carousel': hasCarousel,
|
|
});
|
|
|
|
return (
|
|
<div className={previewClassName}>
|
|
{imagesList.map((_, index) => {
|
|
if (!comparable && index !== 0) {
|
|
return null;
|
|
}
|
|
const coverMeta = imgsMeta[index];
|
|
const imageWrapperClassName = classNames('preview-image-wrapper', {
|
|
good: coverMeta.isGood,
|
|
bad: coverMeta.isBad,
|
|
});
|
|
|
|
return (
|
|
<div className="preview-image-box" style={style} key={index}>
|
|
<div className={imageWrapperClassName}>
|
|
<Image className={coverMeta.className} src={coverMeta.src} alt={coverMeta.alt} />
|
|
</div>
|
|
<div className="preview-image-title">{coverMeta.alt}</div>
|
|
<div
|
|
className="preview-image-description"
|
|
dangerouslySetInnerHTML={{ __html: coverMeta.description }}
|
|
/>
|
|
</div>
|
|
);
|
|
})}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default ImagePreview;
|