import { atom } from 'nanostores'; import type { NetlifyConnection } from '~/types/netlify'; import { logStore } from './logs'; import { toast } from 'react-toastify'; // Initialize with stored connection or defaults const storedConnection = typeof window !== 'undefined' ? localStorage.getItem('netlify_connection') : null; const initialConnection: NetlifyConnection = storedConnection ? JSON.parse(storedConnection) : { user: null, token: '', stats: undefined, }; export const netlifyConnection = atom(initialConnection); export const isConnecting = atom(false); export const isFetchingStats = atom(false); export const updateNetlifyConnection = (updates: Partial) => { const currentState = netlifyConnection.get(); const newState = { ...currentState, ...updates }; netlifyConnection.set(newState); // Persist to localStorage if (typeof window !== 'undefined') { localStorage.setItem('netlify_connection', JSON.stringify(newState)); } }; export async function fetchNetlifyStats(token: string) { try { isFetchingStats.set(true); const sitesResponse = await fetch('https://api.netlify.com/api/v1/sites', { headers: { Authorization: `Bearer ${token}`, 'Content-Type': 'application/json', }, }); if (!sitesResponse.ok) { throw new Error(`Failed to fetch sites: ${sitesResponse.status}`); } const sites = (await sitesResponse.json()) as any; const currentState = netlifyConnection.get(); updateNetlifyConnection({ ...currentState, stats: { sites, totalSites: sites.length, }, }); } catch (error) { console.error('Netlify API Error:', error); logStore.logError('Failed to fetch Netlify stats', { error }); toast.error('Failed to fetch Netlify statistics'); } finally { isFetchingStats.set(false); } }