Files
dify/web/app/components/plugins/marketplace/empty/index.tsx
yyh af7d5e60b4 feat(ui): scaffold @langgenius/dify-ui and migrate design tokens (#35256)
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
2026-04-15 13:11:20 +00:00

63 lines
2.0 KiB
TypeScript

'use client'
import { useTranslation } from '#i18n'
import { cn } from '@langgenius/dify-ui/cn'
import { Group } from '@/app/components/base/icons/src/vender/other'
import Line from './line'
type Props = {
text?: string
lightCard?: boolean
className?: string
}
const Empty = ({
text,
lightCard,
className,
}: Props) => {
const { t } = useTranslation()
return (
<div
className={cn('relative flex h-0 grow flex-wrap overflow-hidden p-2', className)}
>
{
Array.from({ length: 16 }).map((_, index) => (
<div
key={index}
className={cn(
'mr-3 mb-3 h-[144px] w-[calc((100%-36px)/4)] rounded-xl bg-background-section-burn',
index % 4 === 3 && 'mr-0',
index > 11 && 'mb-0',
lightCard && 'bg-background-default-lighter opacity-75',
)}
>
</div>
))
}
{
!lightCard && (
<div
className="absolute inset-0 z-1 bg-marketplace-plugin-empty"
>
</div>
)
}
<div className="absolute top-1/2 left-1/2 z-2 flex -translate-x-1/2 -translate-y-1/2 flex-col items-center">
<div className="relative mb-3 flex h-14 w-14 items-center justify-center rounded-xl border border-dashed border-divider-deep bg-components-card-bg shadow-lg">
<Group className="h-5 w-5 text-text-primary" />
<Line className="absolute top-1/2 -right-px -translate-y-1/2" />
<Line className="absolute top-1/2 -left-px -translate-y-1/2" />
<Line className="absolute top-0 left-1/2 -translate-x-1/2 -translate-y-1/2 rotate-90" />
<Line className="absolute top-full left-1/2 -translate-x-1/2 -translate-y-1/2 rotate-90" />
</div>
<div className="text-center system-md-regular text-text-tertiary">
{text || t('marketplace.noPluginFound', { ns: 'plugin' })}
</div>
</div>
</div>
)
}
export default Empty