Version 3 of the kit: - Radix UI replaced with Base UI (using the Shadcn UI patterns) - next-intl replaces react-i18next - enhanceAction deprecated; usage moved to next-safe-action - main layout now wrapped with [locale] path segment - Teams only mode - Layout updates - Zod v4 - Next.js 16.2 - Typescript 6 - All other dependencies updated - Removed deprecated Edge CSRF - Dynamic Github Action runner
41 lines
964 B
TypeScript
41 lines
964 B
TypeScript
'use client';
|
|
|
|
import { useState } from 'react';
|
|
|
|
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
|
|
import type { AbstractIntlMessages } from 'next-intl';
|
|
|
|
import { I18nClientProvider } from '@kit/i18n/provider';
|
|
import { Toaster } from '@kit/ui/sonner';
|
|
|
|
export function RootProviders(
|
|
props: React.PropsWithChildren<{ messages: AbstractIntlMessages }>,
|
|
) {
|
|
return (
|
|
<I18nClientProvider locale="en" messages={props.messages}>
|
|
<ReactQueryProvider>{props.children}</ReactQueryProvider>
|
|
</I18nClientProvider>
|
|
);
|
|
}
|
|
|
|
function ReactQueryProvider(props: React.PropsWithChildren) {
|
|
const [queryClient] = useState(
|
|
() =>
|
|
new QueryClient({
|
|
defaultOptions: {
|
|
queries: {
|
|
staleTime: 60 * 1000,
|
|
},
|
|
},
|
|
}),
|
|
);
|
|
|
|
return (
|
|
<QueryClientProvider client={queryClient}>
|
|
{props.children}
|
|
|
|
<Toaster position="top-center" />
|
|
</QueryClientProvider>
|
|
);
|
|
}
|