mirror of
https://github.com/langgenius/dify.git
synced 2026-04-12 04:26:29 +08:00
Signed-off-by: edvatar <88481784+toroleapinc@users.noreply.github.com> Signed-off-by: -LAN- <laipz8200@outlook.com> Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: majiayu000 <1835304752@qq.com> Co-authored-by: Poojan <poojan@infocusp.com> Co-authored-by: sahil-infocusp <73810410+sahil-infocusp@users.noreply.github.com> Co-authored-by: 非法操作 <hjlarry@163.com> Co-authored-by: Pandaaaa906 <ye.pandaaaa906@gmail.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> Co-authored-by: heyszt <270985384@qq.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Ijas <ijas.ahmd.ap@gmail.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: 木之本澪 <kinomotomiovo@gmail.com> Co-authored-by: KinomotoMio <200703522+KinomotoMio@users.noreply.github.com> Co-authored-by: 不做了睡大觉 <64798754+stakeswky@users.noreply.github.com> Co-authored-by: User <user@example.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: edvatar <88481784+toroleapinc@users.noreply.github.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: Leilei <138381132+Inlei@users.noreply.github.com> Co-authored-by: HaKu <104669497+haku-ink@users.noreply.github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: wangxiaolei <fatelei@gmail.com> Co-authored-by: Varun Chawla <34209028+veeceey@users.noreply.github.com> Co-authored-by: Stephen Zhou <38493346+hyoban@users.noreply.github.com> Co-authored-by: yyh <yuanyouhuilyz@gmail.com> Co-authored-by: yyh <92089059+lyzno1@users.noreply.github.com> Co-authored-by: tda <95275462+tda1017@users.noreply.github.com> Co-authored-by: root <root@DESKTOP-KQLO90N> Co-authored-by: Sisyphus <clio-agent@sisyphuslabs.ai> Co-authored-by: Niels Kaspers <153818647+nielskaspers@users.noreply.github.com> Co-authored-by: hj24 <mambahj24@gmail.com> Co-authored-by: Tyson Cung <45380903+tysoncung@users.noreply.github.com> Co-authored-by: Stephen Zhou <hi@hyoban.cc> Co-authored-by: FFXN <31929997+FFXN@users.noreply.github.com> Co-authored-by: slegarraga <64795732+slegarraga@users.noreply.github.com> Co-authored-by: 99 <wh2099@pm.me> Co-authored-by: Br1an <932039080@qq.com> Co-authored-by: L1nSn0w <l1nsn0w@qq.com> Co-authored-by: Yunlu Wen <yunlu.wen@dify.ai> Co-authored-by: akkoaya <151345394+akkoaya@users.noreply.github.com> Co-authored-by: 盐粒 Yanli <yanli@dify.ai> Co-authored-by: lif <1835304752@qq.com> Co-authored-by: weiguang li <codingpunk@gmail.com> Co-authored-by: Copilot <198982749+Copilot@users.noreply.github.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: HanWenbo <124024253+hwb96@users.noreply.github.com> Co-authored-by: Coding On Star <447357187@qq.com> Co-authored-by: CodingOnStar <hanxujiang@dify.com> Co-authored-by: Stable Genius <stablegenius043@gmail.com> Co-authored-by: Stable Genius <259448942+stablegenius49@users.noreply.github.com> Co-authored-by: ふるい <46769295+Echo0ff@users.noreply.github.com> Co-authored-by: Xiyuan Chen <52963600+GareArc@users.noreply.github.com>
91 lines
2.1 KiB
TypeScript
91 lines
2.1 KiB
TypeScript
'use client'
|
|
import type { FC } from 'react'
|
|
import * as React from 'react'
|
|
import { useState } from 'react'
|
|
import ImagePreview from '@/app/components/base/image-uploader/image-preview'
|
|
import { cn } from '@/utils/classnames'
|
|
import s from './style.module.css'
|
|
|
|
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')} data-testid="image-gallery">
|
|
{srcs.map((src, index) => (
|
|
!src
|
|
? null
|
|
: (
|
|
<img
|
|
key={index}
|
|
className={s.item}
|
|
style={imgStyle}
|
|
src={src}
|
|
alt=""
|
|
data-testid="gallery-image" // Added for testing
|
|
onClick={() => setImagePreviewUrl(src)}
|
|
onError={e => e.currentTarget.remove()}
|
|
/>
|
|
)
|
|
))}
|
|
{
|
|
imagePreviewUrl && (
|
|
<ImagePreview
|
|
url={imagePreviewUrl}
|
|
onCancel={() => setImagePreviewUrl('')}
|
|
title=""
|
|
/>
|
|
)
|
|
}
|
|
</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="rounded-lg bg-[#D1E9FF80] p-4 pb-2">
|
|
<ImageGallery srcs={imgGallerySrcs.slice(0, index + 1)} />
|
|
</div>
|
|
))}
|
|
</div>
|
|
)
|
|
}
|