import React, { useCallback } from 'react' import { useTranslation } from 'react-i18next' import produce from 'immer' import { Citations } from '@/app/components/base/icons/src/vender/features' import FeatureCard from '@/app/components/base/features/new-feature-panel/feature-card' import { useFeatures, useFeaturesStore } from '@/app/components/base/features/hooks' import type { OnFeaturesChange } from '@/app/components/base/features/types' import { FeatureEnum } from '@/app/components/base/features/types' type Props = { disabled?: boolean onChange?: OnFeaturesChange } const Citation = ({ disabled, onChange, }: Props) => { const { t } = useTranslation() const features = useFeatures(s => s.features) const featuresStore = useFeaturesStore() const handleChange = useCallback((type: FeatureEnum, enabled: boolean) => { const { features, setFeatures, } = featuresStore!.getState() const newFeatures = produce(features, (draft) => { draft[type] = { ...draft[type], enabled, } }) setFeatures(newFeatures) if (onChange) onChange(newFeatures) }, [featuresStore, onChange]) return ( } title={t('appDebug.feature.citation.title')} value={!!features.citation?.enabled} description={t('appDebug.feature.citation.description')!} onChange={state => handleChange(FeatureEnum.citation, state)} disabled={disabled} /> ) } export default Citation