import { defineStore } from 'pinia'; import { computed, ref } from 'vue'; import type { EnvironmentVariable } from '@/Interface'; import * as environmentsApi from '@/api/environments.ee'; import { useRootStore } from '@/stores/n8nRoot.store'; export const useEnvironmentsStore = defineStore('environments', () => { const rootStore = useRootStore(); const variables = ref([]); async function fetchAllVariables() { const data = await environmentsApi.getVariables(rootStore.getRestApiContext); variables.value = data; return data; } async function createVariable(variable: Omit) { const data = await environmentsApi.createVariable(rootStore.getRestApiContext, variable); variables.value.unshift(data); return data; } async function updateVariable(variable: EnvironmentVariable) { const data = await environmentsApi.updateVariable(rootStore.getRestApiContext, variable); variables.value = variables.value.map((v) => (v.id === data.id ? data : v)); return data; } async function deleteVariable(variable: EnvironmentVariable) { const data = await environmentsApi.deleteVariable(rootStore.getRestApiContext, { id: variable.id, }); variables.value = variables.value.filter((v) => v.id !== variable.id); return data; } const variablesAsObject = computed(() => variables.value.reduce>((acc, variable) => { acc[variable.key] = variable.value; return acc; }, {}), ); return { variables, variablesAsObject, fetchAllVariables, createVariable, updateVariable, deleteVariable, }; }); export default useEnvironmentsStore;