* Integrate PostHog - Part 1: Groundwork (#3753) * Integrate PostHog - Part 2: Event capture (#3779) * Integrate PostHog - Part 3: Session recordings (#3789) * Integrate PostHog - Part 4: Experiments (#3825) * Finalize PostHog integration (#3866) * 📦 Update `package-lock.json` * 🐛 Account for absent PH hooks file * ✨ Create new env `EXTERNAL_FRONTEND_HOOKS_FILES` * ⚡ Adjust env used for injecting PostHog * 🐛 Switch to semicolon delimiter * ⚡ Simplify to `externalFrontendHookPath` * Refactor FE hooks flow (#3884) * Add env var for session recordings * inject frontend hooks even when telemetry is off * allow multiple hooks files * cr * 🐛 Handle missing ref errors * 🔥 Remove outdated `continue` * 🎨 Change one-liners to blocks * 📦 Update `package-lock.json` Co-authored-by: Ahsan Virani <ahsan.virani@gmail.com>
71 lines
1.4 KiB
Vue
71 lines
1.4 KiB
Vue
<template>
|
|
<fragment></fragment>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import Vue from 'vue';
|
|
import mixins from 'vue-typed-mixins';
|
|
|
|
import { mapGetters } from 'vuex';
|
|
import { externalHooks } from './mixins/externalHooks';
|
|
|
|
export default mixins(externalHooks).extend({
|
|
name: 'Telemetry',
|
|
data() {
|
|
return {
|
|
isTelemetryInitialized: false,
|
|
};
|
|
},
|
|
computed: {
|
|
...mapGetters('settings', ['telemetry']),
|
|
...mapGetters('users', ['currentUserId']),
|
|
...mapGetters(['instanceId']),
|
|
isTelemetryEnabledOnRoute(): boolean {
|
|
return this.$route.meta && this.$route.meta.telemetry ? !this.$route.meta.telemetry.disabled: true;
|
|
},
|
|
},
|
|
mounted() {
|
|
this.init();
|
|
},
|
|
methods: {
|
|
init() {
|
|
if (this.isTelemetryInitialized || !this.isTelemetryEnabledOnRoute) return;
|
|
|
|
const telemetrySettings = this.telemetry;
|
|
|
|
if (!telemetrySettings || !telemetrySettings.enabled) {
|
|
return;
|
|
}
|
|
|
|
this.$telemetry.init(
|
|
telemetrySettings,
|
|
{
|
|
instanceId: this.instanceId,
|
|
userId: this.currentUserId,
|
|
store: this.$store,
|
|
},
|
|
);
|
|
|
|
this.isTelemetryInitialized = true;
|
|
},
|
|
},
|
|
watch: {
|
|
telemetry() {
|
|
this.init();
|
|
},
|
|
currentUserId(userId) {
|
|
this.$telemetry.identify(this.instanceId, userId);
|
|
this.$externalHooks().run('telemetry.currentUserIdChanged', {
|
|
instanceId: this.instanceId,
|
|
userId,
|
|
});
|
|
},
|
|
isTelemetryEnabledOnRoute(enabled) {
|
|
if (enabled) {
|
|
this.init();
|
|
}
|
|
},
|
|
},
|
|
});
|
|
</script>
|