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>
26 lines
839 B
TypeScript
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}</>;
|
|
}
|