dify/web/features/deployments/list/new-instance-card.tsx
Stephen Zhou 75bfb58cd9
tweaks
2026-05-12 09:15:07 +08:00

75 lines
2.3 KiB
TypeScript

'use client'
import { cn } from '@langgenius/dify-ui/cn'
import { useState } from 'react'
import { useTranslation } from 'react-i18next'
import { CreateInstanceModal } from '../components/create-instance-modal'
function NewInstanceAction({ icon, label, disabled, onClick }: {
icon: string
label: string
disabled?: boolean
onClick?: () => void
}) {
const { t } = useTranslation('deployments')
return (
<button
type="button"
onClick={disabled ? undefined : onClick}
disabled={disabled}
title={disabled ? t('newInstance.comingSoon') : undefined}
className={cn(
'flex h-8 w-full items-center gap-2 rounded-lg px-6 text-left system-sm-medium text-text-tertiary hover:bg-state-base-hover hover:text-text-secondary',
disabled
? 'cursor-not-allowed opacity-50 hover:bg-transparent hover:text-text-tertiary'
: 'cursor-pointer',
)}
>
<span aria-hidden className={cn('size-4 shrink-0', icon)} />
<span className="min-w-0 flex-1 truncate">{label}</span>
{disabled && (
<span className="shrink-0 rounded-md bg-state-base-hover px-1.5 system-2xs-medium text-text-tertiary">
{t('newInstance.comingSoon')}
</span>
)}
</button>
)
}
function CreateFromStudioAction() {
const { t } = useTranslation('deployments')
const [createModalOpen, setCreateModalOpen] = useState(false)
return (
<>
<NewInstanceAction
icon="i-ri-stack-line"
label={t('newInstance.fromStudio')}
onClick={() => setCreateModalOpen(true)}
/>
<CreateInstanceModal open={createModalOpen} onOpenChange={setCreateModalOpen} />
</>
)
}
export function NewInstanceCard() {
const { t } = useTranslation('deployments')
return (
<div className="relative col-span-1 inline-flex h-40 flex-col justify-between rounded-xl border border-components-card-border bg-components-card-bg">
<div className="flex grow flex-col gap-1 rounded-t-xl p-2">
<div className="px-6 pt-2 pb-1 text-xs/[18px] font-medium text-text-tertiary">
{t('newInstance.title')}
</div>
<CreateFromStudioAction />
<NewInstanceAction
icon="i-ri-file-code-line"
label={t('newInstance.importDSL')}
disabled
/>
</div>
</div>
)
}