2023-09-25 06:49:36 -07:00
|
|
|
<script setup lang="ts">
|
2023-11-28 03:15:08 -08:00
|
|
|
import { useLoadingService } from '@/composables/useLoadingService';
|
|
|
|
import { useI18n } from '@/composables/useI18n';
|
2023-09-25 06:49:36 -07:00
|
|
|
import { VIEWS } from '@/constants';
|
2023-11-28 03:15:08 -08:00
|
|
|
import { useTemplatesStore } from '@/stores/templates.store';
|
|
|
|
import { useWorkflowsStore } from '@/stores/workflows.store';
|
2023-09-25 06:49:36 -07:00
|
|
|
import { onMounted } from 'vue';
|
|
|
|
import { useRoute, useRouter } from 'vue-router';
|
|
|
|
|
|
|
|
const loadingService = useLoadingService();
|
|
|
|
const templateStore = useTemplatesStore();
|
2024-05-31 06:52:00 -07:00
|
|
|
const workflowsStore = useWorkflowsStore();
|
2023-09-25 06:49:36 -07:00
|
|
|
const router = useRouter();
|
|
|
|
const route = useRoute();
|
|
|
|
const i18n = useI18n();
|
|
|
|
|
|
|
|
const openWorkflowTemplate = async (templateId: string) => {
|
|
|
|
try {
|
|
|
|
loadingService.startLoading();
|
|
|
|
const template = await templateStore.getFixedWorkflowTemplate(templateId);
|
|
|
|
if (!template) {
|
|
|
|
throw new Error();
|
|
|
|
}
|
|
|
|
|
|
|
|
const name: string = i18n.baseText('onboarding.title', {
|
|
|
|
interpolate: { name: template.name },
|
|
|
|
});
|
|
|
|
|
2024-05-31 06:52:00 -07:00
|
|
|
const workflow = await workflowsStore.createNewWorkflow({
|
2023-09-25 06:49:36 -07:00
|
|
|
name,
|
|
|
|
connections: template.workflow.connections,
|
|
|
|
nodes: template.workflow.nodes,
|
|
|
|
pinData: template.workflow.pinData,
|
|
|
|
settings: template.workflow.settings,
|
|
|
|
meta: {
|
|
|
|
onboardingId: templateId,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
await router.replace({
|
|
|
|
name: VIEWS.WORKFLOW,
|
|
|
|
params: { name: workflow.id },
|
|
|
|
query: { onboardingId: templateId },
|
|
|
|
});
|
|
|
|
|
|
|
|
loadingService.stopLoading();
|
|
|
|
} catch (e) {
|
|
|
|
await router.replace({ name: VIEWS.NEW_WORKFLOW });
|
|
|
|
loadingService.stopLoading();
|
|
|
|
|
|
|
|
throw new Error(`Could not load onboarding template ${templateId}`); // sentry reporing
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
onMounted(async () => {
|
|
|
|
const templateId = route.params.id;
|
|
|
|
if (!templateId || typeof templateId !== 'string') {
|
|
|
|
await router.replace({ name: VIEWS.NEW_WORKFLOW });
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
await openWorkflowTemplate(templateId);
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<div></div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<style lang="scss" module></style>
|