48 lines
1.1 KiB
JavaScript
48 lines
1.1 KiB
JavaScript
"use client";
|
|
|
|
import { create } from "zustand";
|
|
|
|
const useProviderStore = create((set, get) => ({
|
|
providers: [],
|
|
loading: false,
|
|
error: null,
|
|
|
|
setProviders: (providers) => set({ providers }),
|
|
|
|
addProvider: (provider) =>
|
|
set((state) => ({ providers: [provider, ...state.providers] })),
|
|
|
|
updateProvider: (id, updates) =>
|
|
set((state) => ({
|
|
providers: state.providers.map((p) =>
|
|
p._id === id ? { ...p, ...updates } : p
|
|
),
|
|
})),
|
|
|
|
removeProvider: (id) =>
|
|
set((state) => ({
|
|
providers: state.providers.filter((p) => p._id !== id),
|
|
})),
|
|
|
|
setLoading: (loading) => set({ loading }),
|
|
|
|
setError: (error) => set({ error }),
|
|
|
|
fetchProviders: async () => {
|
|
set({ loading: true, error: null });
|
|
try {
|
|
const response = await fetch("/api/providers");
|
|
const data = await response.json();
|
|
if (response.ok) {
|
|
set({ providers: data.providers, loading: false });
|
|
} else {
|
|
set({ error: data.error, loading: false });
|
|
}
|
|
} catch (error) {
|
|
set({ error: "Failed to fetch providers", loading: false });
|
|
}
|
|
},
|
|
}));
|
|
|
|
export default useProviderStore;
|
|
|