import { useEffect } from 'react'; import PageMeta from '../../components/common/PageMeta'; import { useToast } from '../../components/ui/toast/ToastContainer'; import { useSettingsStore } from '../../store/settingsStore'; import { MODULES } from '../../config/modules.config'; import { Card } from '../../components/ui/card'; import Switch from '../../components/form/switch/Switch'; export default function ModuleSettings() { const toast = useToast(); const { moduleEnableSettings, loadModuleEnableSettings, updateModuleEnableSettings, loading, } = useSettingsStore(); useEffect(() => { loadModuleEnableSettings(); }, [loadModuleEnableSettings]); const handleToggle = async (moduleName: string, enabled: boolean) => { try { const enabledKey = `${moduleName}_enabled` as keyof typeof moduleEnableSettings; await updateModuleEnableSettings({ [enabledKey]: enabled, } as any); toast.success(`${MODULES[moduleName]?.name || moduleName} ${enabled ? 'enabled' : 'disabled'}`); } catch (error: any) { toast.error(`Failed to update module: ${error.message}`); } }; const getModuleEnabled = (moduleName: string): boolean => { if (!moduleEnableSettings) return true; // Default to enabled const enabledKey = `${moduleName}_enabled` as keyof typeof moduleEnableSettings; return moduleEnableSettings[enabledKey] !== false; }; return (

Module Settings

Enable or disable modules for your account

{loading ? (
Loading...
) : (
{Object.entries(MODULES).map(([key, module]) => (
{module.icon}

{module.name}

{module.description && (

{module.description}

)}
{getModuleEnabled(key) ? 'Enabled' : 'Disabled'} handleToggle(key, enabled)} />
))}
)}
); }