mirror of
https://github.com/langgenius/dify.git
synced 2026-06-19 00:21:10 +08:00
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>
51 lines
1.2 KiB
TypeScript
51 lines
1.2 KiB
TypeScript
'use client'
|
|
|
|
import type { App } from '@/types/app'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { APP_LIST_GRID_CLASS_NAME } from './constants'
|
|
import { StarredAppCard } from './starred-app-card'
|
|
|
|
type StarredAppListProps = {
|
|
apps: App[]
|
|
isCurrentWorkspaceEditor: boolean
|
|
onRefresh?: () => void
|
|
}
|
|
|
|
function SectionDivider({ label }: { label: string }) {
|
|
return (
|
|
<div className="flex h-7 flex-col items-start px-8 pt-3">
|
|
<div className="flex h-4 w-full items-center">
|
|
<div className="system-xs-medium-uppercase text-text-tertiary uppercase">{label}</div>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export function StarredAppList({
|
|
apps,
|
|
isCurrentWorkspaceEditor,
|
|
onRefresh,
|
|
}: StarredAppListProps) {
|
|
const { t } = useTranslation()
|
|
|
|
if (apps.length === 0)
|
|
return null
|
|
|
|
return (
|
|
<>
|
|
<SectionDivider label={t('studio.starred', { ns: 'app' })} />
|
|
<div className={APP_LIST_GRID_CLASS_NAME}>
|
|
{apps.map(app => (
|
|
<StarredAppCard
|
|
key={app.id}
|
|
app={app}
|
|
isCurrentWorkspaceEditor={isCurrentWorkspaceEditor}
|
|
onRefresh={onRefresh}
|
|
/>
|
|
))}
|
|
</div>
|
|
<SectionDivider label={t('studio.allApps', { ns: 'app' })} />
|
|
</>
|
|
)
|
|
}
|