mirror of
https://github.com/DeveloLongScript/MHSF.git
synced 2026-05-07 20:35:06 -05:00
feat(www): clerk + posthog
This commit is contained in:
parent
68e46b8eea
commit
b50040dfa5
@ -33,6 +33,7 @@ import { usePathname, useSearchParams } from "next/navigation";
|
|||||||
import { useEffect, Suspense } from "react";
|
import { useEffect, Suspense } from "react";
|
||||||
import { usePostHog } from "posthog-js/react";
|
import { usePostHog } from "posthog-js/react";
|
||||||
|
|
||||||
|
import { useAuth, useUser } from '@clerk/nextjs'
|
||||||
import posthog from "posthog-js";
|
import posthog from "posthog-js";
|
||||||
import { PostHogProvider as PHProvider } from "posthog-js/react";
|
import { PostHogProvider as PHProvider } from "posthog-js/react";
|
||||||
|
|
||||||
@ -43,6 +44,7 @@ export function PostHogProvider({ children }: { children: React.ReactNode }) {
|
|||||||
ui_host: "https://us.posthog.com",
|
ui_host: "https://us.posthog.com",
|
||||||
person_profiles: "identified_only", // or 'always' to create profiles for anonymous users as well
|
person_profiles: "identified_only", // or 'always' to create profiles for anonymous users as well
|
||||||
capture_pageview: false, // Disable automatic pageview capture, as we capture manually
|
capture_pageview: false, // Disable automatic pageview capture, as we capture manually
|
||||||
|
capture_pageleave: true
|
||||||
});
|
});
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
@ -58,6 +60,8 @@ function PostHogPageView() {
|
|||||||
const pathname = usePathname();
|
const pathname = usePathname();
|
||||||
const searchParams = useSearchParams();
|
const searchParams = useSearchParams();
|
||||||
const posthog = usePostHog();
|
const posthog = usePostHog();
|
||||||
|
const { isSignedIn, userId } = useAuth()
|
||||||
|
const { user } = useUser()
|
||||||
|
|
||||||
// Track pageviews
|
// Track pageviews
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
@ -71,6 +75,15 @@ function PostHogPageView() {
|
|||||||
}
|
}
|
||||||
}, [pathname, searchParams, posthog]);
|
}, [pathname, searchParams, posthog]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (isSignedIn && userId && user && !posthog._isIdentified()) {
|
||||||
|
posthog.identify(userId, {
|
||||||
|
email: user.primaryEmailAddress?.emailAddress,
|
||||||
|
username: user.username,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}, [posthog, user])
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user