api-client/helpers/fb/analytics.ts

108 lines
2.7 KiB
TypeScript
Raw Normal View History

2021-08-29 05:19:10 +00:00
import {
Analytics,
getAnalytics,
logEvent,
setAnalyticsCollectionEnabled,
setUserId,
setUserProperties,
} from "firebase/analytics"
import { authEvents$ } from "./auth"
import {
HoppAccentColor,
HoppBgColor,
settings$,
settingsStore,
} from "~/newstore/settings"
2021-08-29 05:19:10 +00:00
let analytics: Analytics | null = null
type SettingsCustomDimensions = {
usesProxy: boolean
usesExtension: boolean
syncCollections: boolean
syncEnvironments: boolean
syncHistory: boolean
2021-07-06 12:30:48 +00:00
usesBg: HoppBgColor
usesAccent: HoppAccentColor
2021-07-07 01:00:49 +00:00
usesTelemetry: boolean
}
type HoppRequestEvent =
| {
platform: "rest" | "graphql-query" | "graphql-schema"
strategy: "normal" | "proxy" | "extension"
}
| { platform: "wss" | "sse" | "socketio" | "mqtt" }
export function initAnalytics() {
2021-08-29 05:19:10 +00:00
analytics = getAnalytics()
initLoginListeners()
initSettingsListeners()
}
function initLoginListeners() {
authEvents$.subscribe((ev) => {
if (ev.event === "login") {
2021-08-29 05:19:10 +00:00
if (settingsStore.value.TELEMETRY_ENABLED && analytics) {
setUserId(analytics, ev.user.uid)
2021-08-29 05:19:10 +00:00
logEvent(analytics, "login", {
method: ev.user.providerData[0]?.providerId, // Assume the first provider is the login provider
})
}
} else if (ev.event === "logout") {
2021-08-29 05:19:10 +00:00
if (settingsStore.value.TELEMETRY_ENABLED && analytics) {
logEvent(analytics, "logout")
}
}
})
}
function initSettingsListeners() {
// Keep track of the telemetry status
let telemetryStatus = settingsStore.value.TELEMETRY_ENABLED
settings$.subscribe((settings) => {
2021-07-06 12:30:48 +00:00
const conf: SettingsCustomDimensions = {
usesProxy: settings.PROXY_ENABLED,
usesExtension: settings.EXTENSIONS_ENABLED,
syncCollections: settings.syncCollections,
syncEnvironments: settings.syncEnvironments,
syncHistory: settings.syncHistory,
2021-07-06 12:30:48 +00:00
usesAccent: settings.THEME_COLOR,
usesBg: settings.BG_COLOR,
2021-07-07 01:00:49 +00:00
usesTelemetry: settings.TELEMETRY_ENABLED,
2021-07-06 12:30:48 +00:00
}
// User toggled telemetry mode to off or to on
if (
2021-08-29 05:19:10 +00:00
((telemetryStatus && !settings.TELEMETRY_ENABLED) ||
settings.TELEMETRY_ENABLED) &&
analytics
) {
2021-08-29 05:19:10 +00:00
setUserProperties(analytics, conf)
}
telemetryStatus = settings.TELEMETRY_ENABLED
2021-08-29 05:19:10 +00:00
if (analytics) setAnalyticsCollectionEnabled(analytics, telemetryStatus)
})
2021-08-29 05:19:10 +00:00
if (analytics) setAnalyticsCollectionEnabled(analytics, telemetryStatus)
}
export function logHoppRequestRunToAnalytics(ev: HoppRequestEvent) {
2021-08-29 05:19:10 +00:00
if (settingsStore.value.TELEMETRY_ENABLED && analytics) {
logEvent(analytics, "hopp-request", ev)
}
}
2021-07-09 03:39:07 +00:00
export function logPageView(pagePath: string) {
2021-08-29 05:19:10 +00:00
if (settingsStore.value.TELEMETRY_ENABLED && analytics) {
logEvent(analytics, "page_view", {
2021-07-09 03:39:07 +00:00
page_path: pagePath,
})
}
}