Khởi tạo ban đầu
This commit is contained in:
26
state/use-fish.ts
Normal file
26
state/use-fish.ts
Normal file
@@ -0,0 +1,26 @@
|
||||
import { queryFish } from "@/controller/FishController";
|
||||
import { create } from "zustand";
|
||||
|
||||
type Fish = {
|
||||
fishSpecies: Model.FishSpeciesResponse[] | null;
|
||||
getFishSpecies: () => Promise<void>;
|
||||
error: string | null;
|
||||
loading?: boolean;
|
||||
};
|
||||
|
||||
export const useFishes = create<Fish>((set) => ({
|
||||
fishSpecies: null,
|
||||
getFishSpecies: async () => {
|
||||
try {
|
||||
const response = await queryFish();
|
||||
console.log("Fish fetching API: ", response.data.length);
|
||||
|
||||
set({ fishSpecies: response.data, loading: false });
|
||||
} catch (error) {
|
||||
console.error("Error when fetch fish: ", error);
|
||||
set({ error: "Failed to fetch fish data", loading: false });
|
||||
set({ fishSpecies: null });
|
||||
}
|
||||
},
|
||||
error: null,
|
||||
}));
|
||||
Reference in New Issue
Block a user