1
0
Fork 0
mirror of https://github.com/s-frick/effigenix.git synced 2026-03-28 15:49:35 +01:00
effigenix/frontend/apps/cli/src/hooks/useRecipes.ts
Sebastian Frick ec736cf294 feat(frontend): TUI-Screens für Rezept-Filter, Archivierung und Chargen-Einbuchung
Production: Rezeptliste mit Status-Filter (Draft/Active/Archived), Rezept
archivieren für aktive Rezepte, list() gibt RecipeSummaryDTO zurück.
Inventory: Charge einbuchen (AddBatch) mit neuem Stocks-Resource und Screens.
2026-02-19 22:54:56 +01:00

55 lines
1.5 KiB
TypeScript

import { useState, useCallback } from 'react';
import type { RecipeSummaryDTO, CreateRecipeRequest, RecipeStatus } from '@effigenix/api-client';
import { client } from '../utils/api-client.js';
interface RecipesState {
recipes: RecipeSummaryDTO[];
loading: boolean;
error: string | null;
}
function errorMessage(err: unknown): string {
return err instanceof Error ? err.message : 'Unbekannter Fehler';
}
export function useRecipes() {
const [state, setState] = useState<RecipesState>({
recipes: [],
loading: false,
error: null,
});
const fetchRecipes = useCallback(async (status?: RecipeStatus) => {
setState((s) => ({ ...s, loading: true, error: null }));
try {
const recipes = await client.recipes.list(status);
setState({ recipes, loading: false, error: null });
} catch (err) {
setState((s) => ({ ...s, loading: false, error: errorMessage(err) }));
}
}, []);
const createRecipe = useCallback(async (request: CreateRecipeRequest) => {
setState((s) => ({ ...s, loading: true, error: null }));
try {
const recipe = await client.recipes.create(request);
const recipes = await client.recipes.list();
setState({ recipes, loading: false, error: null });
return recipe;
} catch (err) {
setState((s) => ({ ...s, loading: false, error: errorMessage(err) }));
return null;
}
}, []);
const clearError = useCallback(() => {
setState((s) => ({ ...s, error: null }));
}, []);
return {
...state,
fetchRecipes,
createRecipe,
clearError,
};
}