'use client' import { useContext, useEffect, useState } from 'react' import { Switch, Button } from '@janhq/uikit' import { FeatureToggleContext } from '@/context/FeatureToggle' import { useSettings } from '@/hooks/useSettings' const Advanced = () => { const { experimentalFeatureEnabed, setExperimentalFeatureEnabled } = useContext(FeatureToggleContext) const [gpuEnabled, setGpuEnabled] = useState(false) const { readSettings, saveSettings, validateSettings, setShowNotification } = useSettings() useEffect(() => { readSettings().then((settings) => { setGpuEnabled(settings.run_mode === 'gpu') }) }, []) return (
{/* CPU / GPU switching */}
NVidia GPU

Enable GPU acceleration for NVidia GPUs.

{ if (e === true) { saveSettings({ runMode: 'gpu' }) setGpuEnabled(true) setShowNotification(false) setTimeout(() => { validateSettings() }, 300) } else { saveSettings({ runMode: 'cpu' }) setGpuEnabled(false) } }} />
{/* Experimental */}
Experimental Mode

Enable experimental features that may be unstable tested.

{ if (e === true) { setExperimentalFeatureEnabled(true) } else { setExperimentalFeatureEnabled(false) } }} />
{window.electronAPI && (
Open App Directory

Open the directory where your app data, like conversation history and model configurations, is located.

)}
) } export default Advanced