Files
n8n-enterprise-unlocked/packages/frontend/editor-ui/src/composables/useCalloutHelpers.ts

72 lines
2.1 KiB
TypeScript

import { computed } from 'vue';
import { useRoute, useRouter } from 'vue-router';
import { useTelemetry } from '@/composables/useTelemetry';
import { useRootStore } from '@n8n/stores/useRootStore';
import { useUsersStore } from '@/stores/users.store';
import { VIEWS } from '@/constants';
import { getRagStarterWorkflowJson } from '@/utils/easyAiWorkflowUtils';
import { updateCurrentUserSettings } from '@/api/users';
import { useWorkflowsStore } from '@/stores/workflows.store';
export function useCalloutHelpers() {
const route = useRoute();
const router = useRouter();
const telemetry = useTelemetry();
const rootStore = useRootStore();
const workflowsStore = useWorkflowsStore();
const usersStore = useUsersStore();
const openRagStarterTemplate = (nodeType?: string) => {
telemetry.track('User clicked on RAG callout', {
node_type: nodeType ?? null,
});
const template = getRagStarterWorkflowJson();
const { href } = router.resolve({
name: VIEWS.TEMPLATE_IMPORT,
params: { id: template.meta.templateId },
query: { fromJson: 'true', parentFolderId: route.params.folderId },
});
window.open(href, '_blank');
};
const isRagStarterCalloutVisible = computed(() => {
const template = getRagStarterWorkflowJson();
const routeTemplateId = route.query.templateId;
const workflowObject = workflowsStore.workflowObject;
const workflow = workflowsStore.getWorkflowById(workflowObject.id); // @TODO Check if we actually need workflowObject here
// Hide the RAG starter callout if we're currently on the RAG starter template
if ((routeTemplateId ?? workflow?.meta?.templateId) === template.meta.templateId) {
return false;
}
return true;
});
const isCalloutDismissed = (callout: string) => {
return usersStore.isCalloutDismissed(callout);
};
const dismissCallout = async (callout: string) => {
usersStore.setCalloutDismissed(callout);
await updateCurrentUserSettings(rootStore.restApiContext, {
dismissedCallouts: {
...usersStore.currentUser?.settings?.dismissedCallouts,
[callout]: true,
},
});
};
return {
openRagStarterTemplate,
isRagStarterCalloutVisible,
isCalloutDismissed,
dismissCallout,
};
}