mirror of
https://github.com/n8n-io/n8n.git
synced 2025-03-05 20:50:17 -08:00
74 lines
2 KiB
Vue
74 lines
2 KiB
Vue
<script lang="ts" setup>
|
|
import type { ITelemetrySettings } from '@n8n/api-types';
|
|
import { useRootStore } from '@/stores/root.store';
|
|
import { useSettingsStore } from '@/stores/settings.store';
|
|
import { useUsersStore } from '@/stores/users.store';
|
|
import { useProjectsStore } from '@/stores/projects.store';
|
|
import { computed, onMounted, watch, ref } from 'vue';
|
|
import { useTelemetry } from '@/composables/useTelemetry';
|
|
import { useRoute } from 'vue-router';
|
|
|
|
const isTelemetryInitialized = ref(false);
|
|
|
|
const rootStore = useRootStore();
|
|
const settingsStore = useSettingsStore();
|
|
const usersStore = useUsersStore();
|
|
const projectsStore = useProjectsStore();
|
|
const telemetryPlugin = useTelemetry();
|
|
const route = useRoute();
|
|
|
|
const currentUserId = computed((): string => {
|
|
return usersStore.currentUserId ?? '';
|
|
});
|
|
|
|
const isTelemetryEnabledOnRoute = computed((): boolean => {
|
|
const routeMeta = route.meta as { telemetry?: { disabled?: boolean } } | undefined;
|
|
return routeMeta?.telemetry ? !routeMeta.telemetry.disabled : true;
|
|
});
|
|
|
|
const telemetry = computed((): ITelemetrySettings => {
|
|
return settingsStore.telemetry;
|
|
});
|
|
|
|
const isTelemetryEnabled = computed((): boolean => {
|
|
return !!telemetry.value?.enabled;
|
|
});
|
|
|
|
const selfInstallSrc = computed((): string => {
|
|
return `https://n8n.io/self-install?instanceId=${rootStore.instanceId}&userId=${currentUserId.value}`;
|
|
});
|
|
|
|
watch(telemetry, () => {
|
|
init();
|
|
});
|
|
|
|
watch(isTelemetryEnabledOnRoute, (enabled) => {
|
|
if (enabled) {
|
|
init();
|
|
}
|
|
});
|
|
|
|
onMounted(() => {
|
|
init();
|
|
});
|
|
|
|
function init() {
|
|
if (isTelemetryInitialized.value || !isTelemetryEnabledOnRoute.value || !isTelemetryEnabled.value)
|
|
return;
|
|
|
|
telemetryPlugin.init(telemetry.value, {
|
|
instanceId: rootStore.instanceId,
|
|
userId: currentUserId.value,
|
|
projectId: projectsStore.personalProject?.id,
|
|
versionCli: rootStore.versionCli,
|
|
});
|
|
|
|
isTelemetryInitialized.value = true;
|
|
}
|
|
</script>
|
|
|
|
<template>
|
|
<iframe v-if="isTelemetryEnabled && currentUserId" v-show="false" :src="selfInstallSrc" />
|
|
<span v-else v-show="false" />
|
|
</template>
|