mirror of
https://github.com/langgenius/dify.git
synced 2024-11-16 11:42:29 +08:00
86 lines
1.9 KiB
TypeScript
86 lines
1.9 KiB
TypeScript
'use client'
|
|
import type { FC } from 'react'
|
|
import React, { useState } from 'react'
|
|
import s from './style.module.css'
|
|
import cn from '@/utils/classnames'
|
|
import ImagePreview from '@/app/components/base/image-uploader/image-preview'
|
|
|
|
type Props = {
|
|
srcs: string[]
|
|
}
|
|
|
|
const getWidthStyle = (imgNum: number) => {
|
|
if (imgNum === 1) {
|
|
return {
|
|
maxWidth: '100%',
|
|
}
|
|
}
|
|
|
|
if (imgNum === 2 || imgNum === 4) {
|
|
return {
|
|
width: 'calc(50% - 4px)',
|
|
}
|
|
}
|
|
|
|
return {
|
|
width: 'calc(33.3333% - 5.3333px)',
|
|
}
|
|
}
|
|
|
|
const ImageGallery: FC<Props> = ({
|
|
srcs,
|
|
}) => {
|
|
const [imagePreviewUrl, setImagePreviewUrl] = useState('')
|
|
|
|
const imgNum = srcs.length
|
|
const imgStyle = getWidthStyle(imgNum)
|
|
return (
|
|
<div className={cn(s[`img-${imgNum}`], 'flex flex-wrap')}>
|
|
{/* TODO: support preview */}
|
|
{srcs.map((src, index) => (
|
|
// eslint-disable-next-line @next/next/no-img-element
|
|
<img
|
|
key={index}
|
|
className={s.item}
|
|
style={imgStyle}
|
|
src={src}
|
|
alt=''
|
|
onClick={() => setImagePreviewUrl(src)}
|
|
onError={e => e.currentTarget.remove()}
|
|
/>
|
|
))}
|
|
{
|
|
imagePreviewUrl && (
|
|
<ImagePreview
|
|
url={imagePreviewUrl}
|
|
onCancel={() => setImagePreviewUrl('')}
|
|
/>
|
|
)
|
|
}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default React.memo(ImageGallery)
|
|
|
|
export const ImageGalleryTest = () => {
|
|
const imgGallerySrcs = (() => {
|
|
const srcs = []
|
|
for (let i = 0; i < 6; i++)
|
|
// srcs.push('https://placekitten.com/640/360')
|
|
// srcs.push('https://placekitten.com/360/640')
|
|
srcs.push('https://placekitten.com/360/360')
|
|
|
|
return srcs
|
|
})()
|
|
return (
|
|
<div className='space-y-2'>
|
|
{imgGallerySrcs.map((_, index) => (
|
|
<div key={index} className='p-4 pb-2 rounded-lg bg-[#D1E9FF80]'>
|
|
<ImageGallery srcs={imgGallerySrcs.slice(0, index + 1)} />
|
|
</div>
|
|
))}
|
|
</div>
|
|
)
|
|
}
|