dify/web/app/components/plugins/reference-setting-modal/auto-update-setting/plugins-selected.tsx
Jingyi 9b74df21d0
feat(web): refine onboarding UI (#37433)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: yyh <yuanyouhuilyz@gmail.com>
Co-authored-by: Joel <iamjoel007@gmail.com>
Co-authored-by: hjlarry <hjlarry@163.com>
Co-authored-by: fatelei <fatelei@gmail.com>
Co-authored-by: Asuka Minato <i@asukaminato.eu.org>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Xiyuan Chen <52963600+GareArc@users.noreply.github.com>
Co-authored-by: gigglewang <gigglewang@dify.ai>
Co-authored-by: Yunlu Wen <yunlu.wen@dify.ai>
Co-authored-by: chariri <w@chariri.moe>
Co-authored-by: Evan <2869018789@qq.com>
Co-authored-by: yyh <92089059+lyzno1@users.noreply.github.com>
2026-06-15 08:47:15 +00:00

35 lines
1004 B
TypeScript

'use client'
import type { FC } from 'react'
import { cn } from '@langgenius/dify-ui/cn'
import * as React from 'react'
import Icon from '@/app/components/plugins/card/base/card-icon'
import { MARKETPLACE_API_PREFIX } from '@/config'
const MAX_DISPLAY_COUNT = 14
type Props = Readonly<{
className?: string
plugins: string[]
}>
const PluginsSelected: FC<Props> = ({
className,
plugins,
}) => {
const displayPlugins = plugins.slice(0, MAX_DISPLAY_COUNT)
const hiddenPluginsCount = plugins.length - displayPlugins.length
return (
<div className={cn('flex min-w-0 items-center overflow-hidden', className)}>
{displayPlugins.map(plugin => (
<Icon key={plugin} size="tiny" src={`${MARKETPLACE_API_PREFIX}/plugins/${plugin}/icon`} />
))}
{hiddenPluginsCount > 0 && (
<div className="shrink-0 system-xs-medium text-text-tertiary">
+
{hiddenPluginsCount}
</div>
)}
</div>
)
}
export default React.memo(PluginsSelected)