Grapevine_Disease_Detection/VinEye/src/contexts/ToastContext.tsx
Yanis 720dd34fdd add MyPlantsScreen + ScanDetailScreen + enriched admin + API mobile + project summary
Mobile:
- Replace LibraryScreen with MyPlantsScreen (date-grouped scan list, swipe actions, search, pull-to-refresh)
- Add ScanDetailScreen (immersive hero, confidence bar, cepage card, share/delete)
- Add DiseaseDetailScreen + GuideDetailScreen (hero pattern, animated entry)
- Add useScanDetail, useHistory (useCallback fix), dateGrouping utility
- Connect diseases/guides to admin API with cache + offline fallback
- Add NetworkContext, ToastContext, Skeleton loading components
- Extend ScanRecord type (isFavorite, location)
- Full i18n FR/EN for all new screens

Admin (vineye-admin):
- Enrich Disease/Guide Prisma schema (timeline, conditions, actions, sections)
- Enriched disease-form (7 sections) + guide-form (structured sections editor)
- Add mobile public API endpoints (diseases, guides by slug)
- Add Prisma migration + enriched seed data
- UI polish: sidebar, login, layout updates

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-09 03:19:39 +02:00

26 lines
839 B
TypeScript

import { useEffect, useRef } from "react";
import { toast } from "sonner-native";
import { useNetwork } from "@/contexts/NetworkContext";
// Auto-show offline/online toasts based on network status
export function NetworkToastWatcher({ children }: { children: React.ReactNode }) {
const { isConnected } = useNetwork();
const prevConnected = useRef(true);
useEffect(() => {
if (!isConnected && prevConnected.current) {
toast.error("Mode hors-ligne", {
description: "Les donnees en cache seront utilisees",
duration: Infinity,
id: "offline",
});
} else if (isConnected && !prevConnected.current) {
toast.dismiss("offline");
toast.success("Connexion retablie", { duration: 2500 });
}
prevConnected.current = isConnected;
}, [isConnected]);
return <>{children}</>;
}