* feat: event tracker helper * feat: track click events for `data-ph-element` * fix: handled click events * fix: handled name * chore: tracker element updates * chore: remove export * chore: tracker element type * chore: track element and event helper. * chore: minor improvements * chore: minor refactors * fix: workspace events * fix: added slug * fix: changes nomenclature * fix: nomenclature * chore: update event tracker helper types * fix: data id * refactor: cycle events (#7290) * chore: update event tracker helper types * refactor: cycle events * refactor: cycle events * refactor: cycle event tracker * chore: update tracker elements * chore: check for closest element with data-ph-element attribute --------- Co-authored-by: Prateek Shourya <prateekshourya@Prateeks-MacBook-Pro.local> * Refactor module events (#7291) * chore: update event tracker helper types * refactor: cycle events * refactor: cycle events * refactor: cycle event tracker * refactor: module tracker event and element * chore: update tracker element * chore: revert unnecessary changes --------- Co-authored-by: Prateek Shourya <prateekshourya@Prateeks-MacBook-Pro.local> * refactor: global views, product tour, notifications, onboarding, users and sidebar related events * chore: member tracker events (#7302) * chore: member-tracker-events * fix: constants * refactor: update event tracker constants * refactor: auth related event trackers (#7306) * Chore: state events (#7307) * chore: state events * fix: refactor * chore: project events (#7305) * chore: project-events * fix: refactor * fix: removed hardcoded values * fix: github redirection event * chore: project page tracker events (#7304) * added events for most page events * refactor: simplify lock button event handling in PageLockControl --------- Co-authored-by: Palanikannan M <akashmalinimurugu@gmail.com> Co-authored-by: M. Palanikannan <73993394+Palanikannan1437@users.noreply.github.com> * chore: minor cleanup and import fixes * refactor: added tracker elements for buttons (#7308) Co-authored-by: Prateek Shourya <prateekshourya29@gmail.com> * fix: event type * refactor: posthog group event * chore: removed instances of event tracker (#7309) * refactor: remove event tracker stores and hooks * refactor: remove event tracker store * fix: build errors * clean up event tracker payloads * fix: coderabbit suggestions --------- Co-authored-by: Prateek Shourya <prateekshourya@Prateeks-MacBook-Pro.local> Co-authored-by: Prateek Shourya <prateekshourya29@gmail.com> Co-authored-by: Palanikannan M <akashmalinimurugu@gmail.com> Co-authored-by: M. Palanikannan <73993394+Palanikannan1437@users.noreply.github.com> Co-authored-by: Vamsi Krishna <46787868+vamsikrishnamathala@users.noreply.github.com>
107 lines
3.8 KiB
TypeScript
107 lines
3.8 KiB
TypeScript
"use client";
|
|
|
|
import { FC, ReactNode, useEffect } from "react";
|
|
import { observer } from "mobx-react";
|
|
import dynamic from "next/dynamic";
|
|
import { useParams } from "next/navigation";
|
|
import posthog from "posthog-js";
|
|
import { PostHogProvider as PHProvider } from "posthog-js/react";
|
|
// constants
|
|
import { GROUP_WORKSPACE_TRACKER_EVENT } from "@plane/constants";
|
|
// helpers
|
|
import { getUserRole } from "@plane/utils";
|
|
// hooks
|
|
import { captureClick, joinEventGroup } from "@/helpers/event-tracker.helper";
|
|
import { useWorkspace, useUser, useInstance, useUserPermissions } from "@/hooks/store";
|
|
// dynamic imports
|
|
const PostHogPageView = dynamic(() => import("@/lib/posthog-view"), { ssr: false });
|
|
|
|
export interface IPosthogWrapper {
|
|
children: ReactNode;
|
|
}
|
|
|
|
const PostHogProvider: FC<IPosthogWrapper> = observer((props) => {
|
|
const { children } = props;
|
|
const { data: user } = useUser();
|
|
const { currentWorkspace } = useWorkspace();
|
|
const { instance } = useInstance();
|
|
const { workspaceSlug, projectId } = useParams();
|
|
const { getWorkspaceRoleByWorkspaceSlug, getProjectRoleByWorkspaceSlugAndProjectId } = useUserPermissions();
|
|
|
|
const currentProjectRole = getProjectRoleByWorkspaceSlugAndProjectId(
|
|
workspaceSlug?.toString(),
|
|
projectId?.toString()
|
|
);
|
|
const currentWorkspaceRole = getWorkspaceRoleByWorkspaceSlug(workspaceSlug?.toString());
|
|
const is_telemetry_enabled = instance?.is_telemetry_enabled || false;
|
|
const is_posthog_enabled =
|
|
process.env.NEXT_PUBLIC_POSTHOG_KEY && process.env.NEXT_PUBLIC_POSTHOG_HOST && is_telemetry_enabled;
|
|
|
|
useEffect(() => {
|
|
if (user) {
|
|
// Identify sends an event, so you want may want to limit how often you call it
|
|
posthog?.identify(user.email, {
|
|
id: user.id,
|
|
first_name: user.first_name,
|
|
last_name: user.last_name,
|
|
email: user.email,
|
|
workspace_role: currentWorkspaceRole ? getUserRole(currentWorkspaceRole) : undefined,
|
|
project_role: currentProjectRole ? getUserRole(currentProjectRole) : undefined,
|
|
});
|
|
if (currentWorkspace) {
|
|
joinEventGroup(GROUP_WORKSPACE_TRACKER_EVENT, currentWorkspace?.id, {
|
|
date: new Date().toDateString(),
|
|
workspace_id: currentWorkspace?.id,
|
|
});
|
|
}
|
|
}
|
|
}, [user, currentProjectRole, currentWorkspaceRole, currentWorkspace]);
|
|
|
|
useEffect(() => {
|
|
if (process.env.NEXT_PUBLIC_POSTHOG_KEY && process.env.NEXT_PUBLIC_POSTHOG_HOST) {
|
|
posthog.init(process.env.NEXT_PUBLIC_POSTHOG_KEY, {
|
|
api_host: "/ingest",
|
|
ui_host: process.env.NEXT_PUBLIC_POSTHOG_HOST,
|
|
debug: process.env.NEXT_PUBLIC_POSTHOG_DEBUG === "1", // Debug mode based on the environment variable
|
|
autocapture: false,
|
|
capture_pageview: false, // Disable automatic pageview capture, as we capture manually
|
|
capture_pageleave: true,
|
|
disable_session_recording: true,
|
|
});
|
|
}
|
|
}, []);
|
|
|
|
useEffect(() => {
|
|
const clickHandler = (event: MouseEvent) => {
|
|
const target = event.target as HTMLElement;
|
|
// Use closest to find the nearest parent element with data-ph-element attribute
|
|
const elementWithAttribute = target.closest("[data-ph-element]") as HTMLElement;
|
|
if (elementWithAttribute) {
|
|
const element = elementWithAttribute.getAttribute("data-ph-element");
|
|
if (element) {
|
|
captureClick({ elementName: element });
|
|
}
|
|
}
|
|
};
|
|
|
|
if (is_posthog_enabled) {
|
|
document.addEventListener("click", clickHandler);
|
|
}
|
|
|
|
return () => {
|
|
document.removeEventListener("click", clickHandler);
|
|
};
|
|
}, [is_posthog_enabled]);
|
|
|
|
if (is_posthog_enabled)
|
|
return (
|
|
<PHProvider client={posthog}>
|
|
<PostHogPageView />
|
|
{children}
|
|
</PHProvider>
|
|
);
|
|
|
|
return <>{children}</>;
|
|
});
|
|
|
|
export default PostHogProvider;
|