dify/web/app/components/workflow/nodes/llm/components/resolution-picker.tsx
Stephen Zhou 6ca066983d
chore: auto fix for tailwind rules (#35332)
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
2026-04-16 17:11:06 +00:00

46 lines
1.3 KiB
TypeScript

'use client'
import type { FC } from 'react'
import * as React from 'react'
import { useCallback } from 'react'
import { useTranslation } from 'react-i18next'
import OptionCard from '@/app/components/workflow/nodes/_base/components/option-card'
import { Resolution } from '@/types/app'
const i18nPrefix = 'nodes.llm'
type Props = {
value: Resolution
onChange: (value: Resolution) => void
}
const ResolutionPicker: FC<Props> = ({
value,
onChange,
}) => {
const { t } = useTranslation()
const handleOnChange = useCallback((value: Resolution) => {
return () => {
onChange(value)
}
}, [onChange])
return (
<div className="flex items-center justify-between">
<div className="mr-2 text-xs font-medium text-text-secondary uppercase">{t(`${i18nPrefix}.resolution.name`, { ns: 'workflow' })}</div>
<div className="flex items-center space-x-1">
<OptionCard
title={t(`${i18nPrefix}.resolution.high`, { ns: 'workflow' })}
onSelect={handleOnChange(Resolution.high)}
selected={value === Resolution.high}
/>
<OptionCard
title={t(`${i18nPrefix}.resolution.low`, { ns: 'workflow' })}
onSelect={handleOnChange(Resolution.low)}
selected={value === Resolution.low}
/>
</div>
</div>
)
}
export default React.memo(ResolutionPicker)