| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 | 'use client'import { useTranslation } from 'react-i18next'import s from './index.module.css'import classNames from '@/utils/classnames'import type { DataSet } from '@/models/datasets'const itemClass = `  w-full sm:w-[234px] p-3 rounded-xl bg-gray-25 border border-gray-100 cursor-pointer`const radioClass = `  w-4 h-4 border-[2px] border-gray-200 rounded-full`type IIndexMethodRadioProps = {  value?: DataSet['indexing_technique']  onChange: (v?: DataSet['indexing_technique']) => void  disable?: boolean  itemClassName?: string}const IndexMethodRadio = ({  value,  onChange,  disable,  itemClassName,}: IIndexMethodRadioProps) => {  const { t } = useTranslation()  const options = [    {      key: 'high_quality',      text: t('datasetSettings.form.indexMethodHighQuality'),      desc: t('datasetSettings.form.indexMethodHighQualityTip'),      icon: 'high-quality',    },    {      key: 'economy',      text: t('datasetSettings.form.indexMethodEconomy'),      desc: t('datasetSettings.form.indexMethodEconomyTip'),      icon: 'economy',    },  ]  return (    <div className={classNames(s.wrapper, 'flex justify-between w-full flex-wrap gap-y-2')}>      {        options.map(option => (          <div            key={option.key}            className={classNames(              itemClass,              itemClassName,              s.item,              option.key === value && s['item-active'],              disable && s.disable,            )}            onClick={() => {              if (!disable)                onChange(option.key as DataSet['indexing_technique'])            }}          >            <div className='flex items-center mb-1'>              <div className={classNames(s.icon, s[`${option.icon}-icon`])} />              <div className='grow text-sm text-gray-900'>{option.text}</div>              <div className={classNames(radioClass, s.radio)} />            </div>            <div className='pl-9 text-xs text-gray-500 leading-[18px]'>{option.desc}</div>          </div>        ))      }    </div>  )}export default IndexMethodRadio
 |