2023-12-11 14:45:07 +00:00
|
|
|
import { action, makeObservable, observable } from "mobx";
|
|
|
|
import posthog from "posthog-js";
|
|
|
|
// stores
|
|
|
|
import { RootStore } from "../root.store";
|
|
|
|
|
|
|
|
export interface IEventTrackerStore {
|
|
|
|
trackElement: string;
|
|
|
|
setTrackElement: (element: string) => void;
|
|
|
|
postHogEventTracker: (
|
|
|
|
eventName: string,
|
|
|
|
payload: object | [] | null,
|
2023-12-12 10:20:14 +00:00
|
|
|
group?: { isGrouping: boolean | null; groupType: string | null; groupId: string | null } | null
|
2023-12-11 14:45:07 +00:00
|
|
|
) => void;
|
|
|
|
}
|
|
|
|
|
|
|
|
export class EventTrackerStore implements IEventTrackerStore {
|
|
|
|
trackElement: string = "";
|
|
|
|
rootStore;
|
|
|
|
constructor(_rootStore: RootStore) {
|
|
|
|
makeObservable(this, {
|
|
|
|
trackElement: observable,
|
|
|
|
setTrackElement: action,
|
|
|
|
postHogEventTracker: action,
|
|
|
|
});
|
|
|
|
this.rootStore = _rootStore;
|
|
|
|
}
|
|
|
|
|
|
|
|
setTrackElement = (element: string) => {
|
|
|
|
this.trackElement = element;
|
|
|
|
};
|
|
|
|
|
|
|
|
postHogEventTracker = (
|
|
|
|
eventName: string,
|
|
|
|
payload: object | [] | null,
|
2023-12-12 10:20:14 +00:00
|
|
|
group?: { isGrouping: boolean | null; groupType: string | null; groupId: string | null } | null
|
2023-12-11 14:45:07 +00:00
|
|
|
) => {
|
|
|
|
try {
|
2023-12-12 10:20:14 +00:00
|
|
|
const currentWorkspaceDetails = this.rootStore.workspace.currentWorkspace;
|
|
|
|
const currentProjectDetails = this.rootStore.project.projects.currentProjectDetails;
|
|
|
|
|
2023-12-11 14:45:07 +00:00
|
|
|
let extras: any = {
|
2023-12-12 10:20:14 +00:00
|
|
|
workspace_name: currentWorkspaceDetails?.name ?? "",
|
|
|
|
workspace_id: currentWorkspaceDetails?.id ?? "",
|
|
|
|
workspace_slug: currentWorkspaceDetails?.slug ?? "",
|
|
|
|
project_name: currentProjectDetails?.name ?? "",
|
|
|
|
project_id: currentProjectDetails?.id ?? "",
|
|
|
|
project_identifier: currentProjectDetails?.identifier ?? "",
|
2023-12-11 14:45:07 +00:00
|
|
|
};
|
|
|
|
if (["PROJECT_CREATED", "PROJECT_UPDATED"].includes(eventName)) {
|
|
|
|
const project_details: any = payload as object;
|
|
|
|
extras = {
|
|
|
|
...extras,
|
|
|
|
project_name: project_details?.name ?? "",
|
|
|
|
project_id: project_details?.id ?? "",
|
|
|
|
project_identifier: project_details?.identifier ?? "",
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
if (group && group!.isGrouping === true) {
|
2023-12-12 10:20:14 +00:00
|
|
|
posthog?.group(group!.groupType!, group!.groupId!, {
|
2023-12-11 14:45:07 +00:00
|
|
|
date: new Date(),
|
2023-12-12 10:20:14 +00:00
|
|
|
workspace_id: group!.groupId,
|
2023-12-11 14:45:07 +00:00
|
|
|
});
|
|
|
|
posthog?.capture(eventName, {
|
|
|
|
...payload,
|
|
|
|
extras: extras,
|
|
|
|
element: this.trackElement ?? "",
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
posthog?.capture(eventName, {
|
|
|
|
...payload,
|
|
|
|
extras: extras,
|
|
|
|
element: this.trackElement ?? "",
|
|
|
|
});
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
this.setTrackElement("");
|
|
|
|
};
|
|
|
|
}
|