Browse Source

chore: Optimizing Microservices

master
wangxiang 2 years ago
parent
commit
54bf58c035
No known key found for this signature in database
GPG Key ID: 1BA7946AB6B232E4
  1. 35
      src/views/workflow/extension/form/helper/WorkflowFormDesign.vue

35
src/views/workflow/extension/form/helper/WorkflowFormDesign.vue

@ -6,7 +6,6 @@
:showCancelBtn="false" :showCancelBtn="false"
:showOkBtn="false" :showOkBtn="false"
@register="registerModal" @register="registerModal"
@visible-change="handleVisibleChange"
> >
<div id="formDesign"/> <div id="formDesign"/>
<template #centerFooter> <template #centerFooter>
@ -17,7 +16,7 @@
</BasicModal> </BasicModal>
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
import { reactive } from 'vue'; import { reactive, onBeforeUnmount } from 'vue';
import { BasicModal, ModalProps, useModalInner } from '/@/components/Modal'; import { BasicModal, ModalProps, useModalInner } from '/@/components/Modal';
import { loadMicroApp, MicroApp } from 'qiankun'; import { loadMicroApp, MicroApp } from 'qiankun';
import { getSubDefineProps } from '/@/qiankun/state'; import { getSubDefineProps } from '/@/qiankun/state';
@ -54,18 +53,20 @@
const emit = defineEmits(['success', 'register']); const emit = defineEmits(['success', 'register']);
const microAppStore = useMicroAppStore(); const microAppStore = useMicroAppStore();
const [registerModal, { setModalProps, closeModal, changeLoading }] = useModalInner(async (data: BoxPayload = { _tag: '' }) => { const [registerModal, { setModalProps, closeModal, changeLoading }] = useModalInner(async (data: BoxPayload = { _tag: '' }) => {
changeLoading(); if (!state.formDesignApp || state.formDesignApp.getStatus() === 'NOT_MOUNTED') {
state.formDesignApp = loadMicroApp(Object.assign({} , apps.find(item => item.name == 'form-design'), { changeLoading();
container: '#formDesign', state.formDesignApp = loadMicroApp(Object.assign({} , apps.find(item => item.name == 'form-design'), {
props: { container: '#formDesign',
...getSubDefineProps(), props: {
// props ...getSubDefineProps(),
[GlStateEnum.FORM_DESIGN_APP_PROPS_KEY]: formDesignProps // props
} [GlStateEnum.FORM_DESIGN_APP_PROPS_KEY]: formDesignProps
}), { sandbox: { experimentalStyleIsolation: true }}); }
state.formDesignApp.mountPromise.then(() => { }), { sandbox: { experimentalStyleIsolation: true }});
changeLoading(false); state.formDesignApp.mountPromise.then(() => {
}); changeLoading(false);
});
}
// //
formDesignProps.options = {}; formDesignProps.options = {};
const id = data.id; const id = data.id;
@ -78,9 +79,9 @@
setModalProps(props); setModalProps(props);
}); });
function handleVisibleChange(visible: boolean) { onBeforeUnmount(() => {
!visible && state.formDesignApp?.unmount(); state.formDesignApp?.getStatus() === 'MOUNTED' && state.formDesignApp.unmount();
} });
/** 处理弹出框提交 */ /** 处理弹出框提交 */
async function handleSubmitForm(status: string) { async function handleSubmitForm(status: string) {

Loading…
Cancel
Save