import React, { useEffect, useState } from 'react' import { adminApi } from '../../api/client' import { useTranslation } from '../../i18n' import { useSettingsStore } from '../../store/settingsStore' import { useToast } from '../shared/Toast' import { Puzzle, ListChecks, Wallet, FileText, CalendarDays, Globe, Briefcase } from 'lucide-react' const ICON_MAP = { ListChecks, Wallet, FileText, CalendarDays, Puzzle, Globe, Briefcase, } function AddonIcon({ name, size = 20 }) { const Icon = ICON_MAP[name] || Puzzle return } export default function AddonManager() { const { t } = useTranslation() const dm = useSettingsStore(s => s.settings.dark_mode) const dark = dm === true || dm === 'dark' || (dm === 'auto' && window.matchMedia('(prefers-color-scheme: dark)').matches) const toast = useToast() const [addons, setAddons] = useState([]) const [loading, setLoading] = useState(true) useEffect(() => { loadAddons() }, []) const loadAddons = async () => { setLoading(true) try { const data = await adminApi.addons() setAddons(data.addons) } catch (err) { toast.error(t('admin.addons.toast.error')) } finally { setLoading(false) } } const handleToggle = async (addon) => { const newEnabled = !addon.enabled // Optimistic update setAddons(prev => prev.map(a => a.id === addon.id ? { ...a, enabled: newEnabled } : a)) try { await adminApi.updateAddon(addon.id, { enabled: newEnabled }) window.dispatchEvent(new Event('addons-changed')) toast.success(t('admin.addons.toast.updated')) } catch (err) { // Rollback setAddons(prev => prev.map(a => a.id === addon.id ? { ...a, enabled: !newEnabled } : a)) toast.error(t('admin.addons.toast.error')) } } const tripAddons = addons.filter(a => a.type === 'trip') const globalAddons = addons.filter(a => a.type === 'global') if (loading) { return (
) } return (
{/* Header */}

{t('admin.addons.title')}

{t('admin.addons.subtitleBefore')}NOMAD{t('admin.addons.subtitleAfter')}

{addons.length === 0 ? (
{t('admin.addons.noAddons')}
) : (
{/* Trip Addons */} {tripAddons.length > 0 && (
{t('admin.addons.type.trip')} — {t('admin.addons.tripHint')}
{tripAddons.map(addon => ( ))}
)} {/* Global Addons */} {globalAddons.length > 0 && (
{t('admin.addons.type.global')} — {t('admin.addons.globalHint')}
{globalAddons.map(addon => ( ))}
)}
)}
) } function AddonRow({ addon, onToggle, t }) { const isComingSoon = false return (
{/* Icon */}
{/* Info */}
{addon.name} {isComingSoon && ( Coming Soon )} {addon.type === 'global' ? t('admin.addons.type.global') : t('admin.addons.type.trip')}

{addon.description}

{/* Toggle */}
{isComingSoon ? t('admin.addons.disabled') : addon.enabled ? t('admin.addons.enabled') : t('admin.addons.disabled')}
) }