<script lang="ts" setup>
|
import { markRaw, onMounted, reactive, toRefs } from 'vue';
|
import { useRoute, useRouter } from 'vue-router';
|
|
import { useMessage } from '@jnpf/hooks';
|
|
import { useTabs } from '@vben/hooks';
|
|
import { getConfigData } from '#/api/onlineDev/visualDev';
|
import { getFlowStartFormId } from '#/api/workFlow/template';
|
import { useBaseStore } from '#/store';
|
|
import Form from './form/index.vue';
|
import List from './list/index.vue';
|
|
interface State {
|
currentView: any;
|
showPage: boolean;
|
isPreview: boolean;
|
isDataManage: boolean;
|
previewType: string;
|
modelId: string;
|
flowId: string;
|
enableFlow: number;
|
config: any;
|
}
|
|
defineOptions({ name: 'DynamicModel' });
|
|
const { createMessage } = useMessage();
|
const baseStore = useBaseStore();
|
const { closeCurrentTab } = useTabs();
|
const state = reactive<State>({
|
currentView: '',
|
showPage: false,
|
isPreview: false,
|
isDataManage: false,
|
previewType: '',
|
modelId: '',
|
flowId: '',
|
enableFlow: 0,
|
config: {},
|
});
|
const { currentView, showPage, isPreview, isDataManage, modelId, config } = toRefs(state);
|
const router = useRouter();
|
|
async function init() {
|
const route = useRoute();
|
await baseStore.getDictionaryAll();
|
state.isPreview = (route.query.isPreview as unknown as boolean) || false;
|
state.isDataManage = (route.query.isDataManage as unknown as boolean) || false;
|
if (state.isPreview || state.isDataManage) {
|
if (state.isPreview) {
|
state.previewType = (route.query.previewType as string) || '';
|
}
|
getConfig(route.query.id);
|
return;
|
}
|
state.enableFlow = route.meta.type === 9 ? 1 : 0;
|
if (!state.enableFlow) return getConfig(route.meta.relationId);
|
getModelId(route.meta.relationId);
|
}
|
function getModelId(flowId) {
|
state.flowId = flowId;
|
getFlowStartFormId(flowId)
|
.then((res) => {
|
if (!res?.data || !res?.data.formId) return;
|
getConfig(res.data.formId);
|
})
|
.catch(() => {
|
closeCurrentTab();
|
router.replace('/404');
|
});
|
}
|
function getConfig(modelId) {
|
if (!modelId) return;
|
state.modelId = modelId;
|
getConfigData(state.modelId, { type: state.previewType }).then((res) => {
|
if (res.code !== 200 || !res.data) {
|
closeCurrentTab();
|
router.replace('/404');
|
createMessage.error(res.msg || '请求出错,请重试');
|
return;
|
}
|
state.config = res.data;
|
state.config.id = state.config.id || state.modelId;
|
if (state.enableFlow) {
|
state.config.enableFlow = state.enableFlow;
|
state.config.flowId = state.flowId;
|
}
|
state.currentView = res.data.webType == '1' ? markRaw(Form) : markRaw(List);
|
state.showPage = true;
|
});
|
}
|
|
onMounted(() => {
|
init();
|
});
|
</script>
|
<template>
|
<component :is="currentView" :config="config" :model-id="modelId" :is-preview="isPreview" :is-data-manage="isDataManage" v-if="showPage" />
|
</template>
|