Skip to content

Commit

Permalink
fix: add missing info for posthog (#1958)
Browse files Browse the repository at this point in the history
  • Loading branch information
nickytonline authored Oct 19, 2023
2 parents 8309e0a + f5137b7 commit eb073c0
Show file tree
Hide file tree
Showing 4 changed files with 83 additions and 44 deletions.
10 changes: 7 additions & 3 deletions components/molecules/FilterHeader/filter-header.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,24 +6,28 @@ import ContextThumbnail from "components/atoms/ContextThumbnail/context-thumbnai
import SuperativeSelector from "components/molecules/SuperlativeSelector/superlative-selector";

import useFilterOptions from "lib/hooks/useFilterOptions";
import { useAnalytics } from "lib/utils/analytics";
import { captureAnalytics } from "lib/utils/analytics";
import useFilterPrefetch from "lib/hooks/useFilterPrefetch";
import topicNameFormatting from "lib/utils/topic-name-formatting";
import FilterCardSelect from "components/molecules/FilterCardSelect/filter-card-select";
import getTopicThumbnail from "lib/utils/getTopicThumbnail";
import { interestsType } from "lib/utils/getInterestOptions";
import { getInterestOptions } from "lib/utils/getInterestOptions";
import useSupabaseAuth from "lib/hooks/useSupabaseAuth";
import { useFetchUser } from "lib/hooks/useFetchUser";

const HeaderFilter = () => {
const router = useRouter();
const { captureAnalytics } = useAnalytics();
const filterOptions = useFilterOptions();
const topicOptions = getInterestOptions();

const { filterValues } = useFilterPrefetch();
const { filterName, toolName, selectedFilter } = router.query;
const { user } = useSupabaseAuth();
const { data: userInfo } = useFetchUser(user?.user_metadata.user_name);

const filterBtnRouting = (filter: string) => {
captureAnalytics({ title: "Filters", property: "toolsFilter", value: `${filter} applied` });
captureAnalytics({ title: "Filters", property: "toolsFilter", value: `${filter} applied`, userInfo });
return router.push(`/${filterName}/${toolName}/filter/${filter.toLocaleLowerCase()}`);
};

Expand Down
17 changes: 13 additions & 4 deletions components/organisms/ToolsDisplay/tools-display.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
import React from "react";
import { useAnalytics } from "lib/utils/analytics";
import React, { useEffect } from "react";
import { captureAnalytics } from "lib/utils/analytics";
import useSession from "lib/hooks/useSession";
import useSupabaseAuth from "lib/hooks/useSupabaseAuth";
import { useFetchUser } from "lib/hooks/useFetchUser";
import Contributors from "../Contributors/contributors";
import Dashboard from "../Dashboard/dashboard";
import Reports from "../Reports/reports";
Expand All @@ -13,9 +15,16 @@ interface ToolProps {

const Tool = ({ tool, repositories }: ToolProps): JSX.Element => {
const { hasReports, waitlisted } = useSession();
const { captureAnalytics } = useAnalytics();
const { user } = useSupabaseAuth();
const { data: userInfo, isLoading } = useFetchUser(user?.user_metadata.user_name);

captureAnalytics({ title: "Tools Display", property: "tools", value: `${tool} selected` });
useEffect(() => {
if (isLoading) {
return;
}

captureAnalytics({ title: "Tools Display", property: "tools", value: `${tool} selected`, userInfo });
}, [tool, userInfo, isLoading]);

switch (tool) {
case "Dashboard":
Expand Down
38 changes: 20 additions & 18 deletions lib/utils/analytics.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import posthog from "posthog-js";
import useSupabaseAuth from "lib/hooks/useSupabaseAuth";

interface AnalyticEvent {
title: string;
property: string;
value: string;
userInfo: DbUser | undefined;
}

function initiateAnalytics() {
Expand All @@ -15,27 +15,29 @@ function initiateAnalytics() {
/**
* Captures an analytic event
*
* @param {string} title - The title of the event
* @param {string} property - The property of the event
* @param {string} value - The value of the event
* @param title - The title of the event
* @param property - The property of the event
* @param value - The value of the event
* @param userInfo - The user info for the currently logged in user. Undefined if no user is logged in.
*
*/
function useAnalytics() {
const { user } = useSupabaseAuth();
async function captureAnalytics({ title, property, value, userInfo }: AnalyticEvent) {
const analyticsObject: Record<string, string> = {};

analyticsObject[property] = value;

return {
captureAnalytics({ title, property, value }: AnalyticEvent) {
const analyticsObject: Record<string, string> = {};
// if a user is not logged in, Posthog will generate an anonymous ID
if (userInfo) {
let userProperties = {};

analyticsObject[property] = value;
const { company, coupon_code, is_open_sauced_member, is_onboarded, role } = userInfo;

// if a user is not logged in, Posthog will generate an anonymous ID
if (user) {
posthog.identify(user.user_metadata.sub);
}
// A pro user is anyone with a role of 50 or higher
userProperties = { company, coupon_code, is_open_sauced_member, is_onboarded, is_pro_user: role >= 50 };
posthog.identify(`${userInfo.id}`, userProperties);
}

posthog.capture(title, analyticsObject);
},
};
posthog.capture(title, analyticsObject);
}

export { initiateAnalytics, useAnalytics };
export { initiateAnalytics, captureAnalytics };
62 changes: 43 additions & 19 deletions pages/start.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,14 +25,15 @@ import Button from "components/atoms/Button/button";
import useSupabaseAuth from "lib/hooks/useSupabaseAuth";
import { setQueryParams } from "lib/utils/query-params";
import useSession from "lib/hooks/useSession";
import { useAnalytics } from "lib/utils/analytics";
import { captureAnalytics } from "lib/utils/analytics";

import useStore from "lib/store";
import { getInterestOptions } from "lib/utils/getInterestOptions";
import LanguagePill from "components/atoms/LanguagePill/LanguagePill";

import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from "components/atoms/Select/select";
import { timezones } from "lib/utils/timezones";
import { useFetchUser } from "lib/hooks/useFetchUser";

type handleLoginStep = () => void;
type stepKeys = "1" | "2" | "3";
Expand All @@ -45,13 +46,20 @@ interface LoginStep1Props {
}

const LoginStep1: React.FC<LoginStep1Props> = ({ user }) => {
const { captureAnalytics } = useAnalytics();
const { data: userInfo, isLoading } = useFetchUser(user?.user_metadata.user_name);

captureAnalytics({
title: "User Onboarding",
property: "onboardingStep1",
value: "visited",
});
useEffect(() => {
if (isLoading) {
return;
}

captureAnalytics({
title: "User Onboarding",
property: "onboardingStep1",
value: "visited",
userInfo,
});
}, [userInfo, isLoading]);

const router = useRouter();
const { onboarded } = useSession();
Expand Down Expand Up @@ -121,15 +129,23 @@ interface LoginStep2Props {
}

const LoginStep2: React.FC<LoginStep2Props> = ({ handleUpdateInterests: handleUpdateInterestsParent }) => {
const { captureAnalytics } = useAnalytics();
const [selectedInterests, setSelectedInterests] = useState<string[]>([]);
const interestArray = getInterestOptions();
const { user } = useSupabaseAuth();
const { data: userInfo, isLoading } = useFetchUser(user?.user_metadata.user_name);

captureAnalytics({
title: "User Onboarding",
property: "onboardingStep2",
value: "visited",
});
useEffect(() => {
if (isLoading) {
return;
}

captureAnalytics({
title: "User Onboarding",
property: "onboardingStep2",
value: "visited",
userInfo,
});
}, [userInfo, isLoading]);

const handleSelectInterest = (interest: string) => {
if (selectedInterests.length > 0 && selectedInterests.includes(interest)) {
Expand Down Expand Up @@ -186,13 +202,21 @@ interface LoginStep3Props {
}

const LoginStep3: React.FC<LoginStep3Props> = ({ interests, user }) => {
const { captureAnalytics } = useAnalytics();
const { data: userInfo, isLoading } = useFetchUser(user?.user_metadata.user_name);

useEffect(() => {
if (isLoading) {
return;
}

captureAnalytics({
title: "User Onboarding",
property: "onboardingStep3",
value: "visited",
userInfo,
});
}, [userInfo, isLoading]);

captureAnalytics({
title: "User Onboarding",
property: "onboardingStep3",
value: "visited",
});
const store = useStore();
const router = useRouter();
const { sessionToken } = useSupabaseAuth();
Expand Down

0 comments on commit eb073c0

Please sign in to comment.