Skip to content

Commit

Permalink
Merge branch 'main' into chore-keywords
Browse files Browse the repository at this point in the history
  • Loading branch information
JBR90 committed Nov 14, 2024
2 parents 4174816 + 05ccce6 commit 660e190
Show file tree
Hide file tree
Showing 5 changed files with 93 additions and 31 deletions.
2 changes: 1 addition & 1 deletion apps/nextjs/src/app/faqs/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -722,7 +722,7 @@ const FAQPage = () => {
the volume of requests that can be made, lessons, and resources
that can be generated. If you're reaching these limits,
we'd love to hear from you, and you can{" "}
<OakLink href="https://forms.gle/tHsYMZJR367zydsG8">
<OakLink href="https://share.hsforms.com/118hyngR-QSS0J7vZEVlRSgbvumd">
request a higher limit.
</OakLink>
</OakP>
Expand Down
9 changes: 8 additions & 1 deletion apps/nextjs/src/app/layout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import "@/app/theme-config.css";
import { Providers } from "@/components/AppComponents/Chat//providers";
import { AnalyticsProvider } from "@/components/ContextProviders/AnalyticsProvider";
import { CookieConsentProvider } from "@/components/ContextProviders/CookieConsentProvider";
import { FeatureFlagProvider } from "@/components/ContextProviders/FeatureFlagProvider";
import FontProvider from "@/components/ContextProviders/FontProvider";
import { GleapProvider } from "@/components/ContextProviders/GleapProvider";
import { WebDebuggerPosition } from "@/lib/avo/Avo";
Expand Down Expand Up @@ -118,7 +119,13 @@ export default async function RootLayout({
}}
bootstrappedFeatures={bootstrappedFeatures}
>
<GleapProvider>{children}</GleapProvider>
<GleapProvider>
<FeatureFlagProvider
bootstrappedFeatures={bootstrappedFeatures}
>
{children}
</FeatureFlagProvider>
</GleapProvider>
</AnalyticsProvider>
</CookieConsentProvider>
</Providers>
Expand Down
3 changes: 2 additions & 1 deletion apps/nextjs/src/components/ContextProviders/Demo.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,8 @@ export function DemoProvider({ children }: Readonly<DemoProviderProps>) {
isDemoUser,
appSessionsRemaining,
appSessionsPerMonth: DEMO_APP_SESSIONS_PER_30D,
contactHref: "mailto:[email protected]",
contactHref:
"https://share.hsforms.com/1R9ulYSNPQgqElEHde3KdhAbvumd",
isSharingEnabled,
}
: {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
"use client";

import type { ReactNode } from "react";
import {
useMemo,
createContext,
useContext,
useEffect,
useState,
useRef,
} from "react";

import { aiLogger } from "@oakai/logger";

import useAnalytics from "@/lib/analytics/useAnalytics";

const log = aiLogger("feature-flags");

export interface FeatureFlagContextProps {
bootstrappedFeatures: Record<string, string | boolean>;
}

const FeatureFlagContext = createContext<FeatureFlagContextProps>({
bootstrappedFeatures: {},
});

export interface FeatureFlagProviderProps {
children: ReactNode;
bootstrappedFeatures: Record<string, string | boolean>;
}

export const FeatureFlagProvider = ({
children,
bootstrappedFeatures,
}: FeatureFlagProviderProps) => {
const value = useMemo(
() => ({ bootstrappedFeatures }),
[bootstrappedFeatures],
);

return (
<FeatureFlagContext.Provider value={value}>
{children}
</FeatureFlagContext.Provider>
);
};

export const useClientSideFeatureFlag = (flag: string) => {
const context = useContext(FeatureFlagContext);

const { posthogAiBetaClient: posthog } = useAnalytics();
const hasLogged = useRef(false);

const [posthogFeatureFlag, setPosthogFeatureFlag] = useState<
boolean | string | undefined
>();

const bootstrappedFlag = context.bootstrappedFeatures[flag];

useEffect(() => {
return posthog.onFeatureFlags(() => {
const updatedValue = posthog.isFeatureEnabled(flag);
if (updatedValue !== bootstrappedFlag) {
log.info(`Updating ${flag} to ${updatedValue}`);
setPosthogFeatureFlag(updatedValue);
}
});
}, [posthog, flag, bootstrappedFlag]);

const isDebug = process.env.NEXT_PUBLIC_POSTHOG_DEBUG === "true";
if (isDebug) {
if (!hasLogged.current) {
hasLogged.current = true;
log.info(`Feature flag ${flag} is enabled in debug mode`);
}
return true;
}

// NOTE: This will flash from the bootstrapped value to the posthog value
// only on page load within 1 minute of toggling a flag
return posthogFeatureFlag ?? bootstrappedFlag ?? false;
};
28 changes: 0 additions & 28 deletions apps/nextjs/src/utils/useClientSideFeatureFlag.ts

This file was deleted.

0 comments on commit 660e190

Please sign in to comment.