mirror of
https://github.com/StanGirard/quivr.git
synced 2025-01-06 03:04:42 +03:00
39 lines
1006 B
TypeScript
39 lines
1006 B
TypeScript
|
"use client"
|
||
|
import type { FeatureDefinition } from "@growthbook/growthbook";
|
||
|
import { GrowthBook, GrowthBookProvider } from "@growthbook/growthbook-react";
|
||
|
import axios from "axios";
|
||
|
import { useAsync } from "react-use";
|
||
|
|
||
|
|
||
|
const growthBook = new GrowthBook({
|
||
|
apiHost: "https://cdn.growthbook.io",
|
||
|
clientKey:process.env.NEXT_PUBLIC_GROWTHBOOK_CLIENT_KEY,
|
||
|
enableDevMode: true,
|
||
|
});
|
||
|
|
||
|
|
||
|
|
||
|
const unauthenticatedClient = axios.create();
|
||
|
|
||
|
export const FeatureFlagsProvider = ({
|
||
|
children,
|
||
|
}: {
|
||
|
children?: React.ReactNode;
|
||
|
}): JSX.Element => {
|
||
|
|
||
|
const growthBookUrl = process.env.NEXT_PUBLIC_GROWTHBOOK_URL;
|
||
|
|
||
|
useAsync(async () => {
|
||
|
if (growthBookUrl !== undefined) {
|
||
|
const growthBookInitResponse = await unauthenticatedClient.get<{
|
||
|
features: Record<string, FeatureDefinition>;
|
||
|
}>(growthBookUrl);
|
||
|
growthBook.setFeatures(growthBookInitResponse.data.features);
|
||
|
}
|
||
|
});
|
||
|
|
||
|
return (
|
||
|
<GrowthBookProvider growthbook={growthBook}>{children}</GrowthBookProvider>
|
||
|
);
|
||
|
};
|