兰宝车间质量管理系统-前端
gssong
2024-04-06 9f73ea2d329abd721afd0213fb5803aad723f667
update 优化表单绑定逻辑,移除流程定义配置表单,添加模型复制
已修改7个文件
166 ■■■■■ 文件已修改
src/api/workflow/model/index.ts 13 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/workflow/task/types.ts 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/workflow/workflowCommon/index.ts 24 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/workflow/workflowCommon/types.ts 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/Process/submitVerify.vue 13 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/workflow/model/index.vue 43 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/workflow/processDefinition/index.vue 70 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/workflow/model/index.ts
@@ -89,3 +89,16 @@
    method: 'post'
  });
};
/**
 * 复制模型
 * @param data
 * @returns {*}
 */
export const copyModel = (data: ModelForm): AxiosPromise<void> => {
  return request({
    url: '/workflow/model/copyModel',
    method: 'post',
    data: data
  });
};
src/api/workflow/task/types.ts
@@ -40,7 +40,6 @@
  multiInstance?: boolean;
  businessKey?: string;
  wfNodeConfigVo?: NodeConfigVO;
  wfDefinitionConfigVo?: DefinitionConfigVO;
}
export interface VariableVo {
src/api/workflow/workflowCommon/index.ts
@@ -22,28 +22,8 @@
                    taskId: routerJumpVo.taskId
                }
            });
        }else if (routerJumpVo.wfDefinitionConfigVo && routerJumpVo.wfDefinitionConfigVo.wfFormManageVo && routerJumpVo.wfDefinitionConfigVo.wfFormManageVo.formType === 'static') {
            proxy.$tab.closePage(proxy.$route);
            proxy.$router.push({
                path: `${routerJumpVo.wfDefinitionConfigVo.wfFormManageVo.router}`,
                query: {
                    id: routerJumpVo.businessKey,
                    type: routerJumpVo.type,
                    taskId: routerJumpVo.taskId
                }
            });
        }else if (routerJumpVo.wfDefinitionConfigVo && routerJumpVo.wfDefinitionConfigVo.wfFormManageVo && routerJumpVo.wfDefinitionConfigVo.wfFormManageVo.formType === 'dynamic') {
            proxy.$tab.closePage(proxy.$route);
            proxy.$router.push({
                path: `${routerJumpVo.wfDefinitionConfigVo.wfFormManageVo.router}`,
                query: {
                    id: routerJumpVo.businessKey,
                    type: routerJumpVo.type,
                    taskId: routerJumpVo.taskId
                }
            });
        } else {
            proxy?.$modal.msgError('请到流程定义菜单配置路由!');
        }else {
            proxy?.$modal.msgError('请到模型配置菜单!');
        }
    }
}
src/api/workflow/workflowCommon/types.ts
@@ -1,8 +1,6 @@
import { NodeConfigVO } from '@/api/workflow/nodeConfig/types';
import { DefinitionConfigVO } from '@/api/workflow/definitionConfig/types';
export interface RouterJumpVo {
    wfDefinitionConfigVo: DefinitionConfigVO;
    wfNodeConfigVo: NodeConfigVO;
    businessKey: string;
    taskId: string;
src/components/Process/submitVerify.vue
@@ -209,10 +209,15 @@
  await proxy?.$modal.confirm('是否确认提交?');
  loading.value = true;
  buttonLoading.value = true;
  await completeTask(form.value).finally(() => (loading.value = false));
  dialog.visible = false;
  emits('submitCallback');
  proxy?.$modal.msgSuccess('操作成功');
  try {
    await completeTask(form.value);
    dialog.visible = false;
    emits('submitCallback');
    proxy?.$modal.msgSuccess('操作成功');
  }finally {
    loading.value = false
    buttonLoading.value = false
  }
};
/** 驳回弹窗打开 */
src/views/workflow/model/index.vue
@@ -59,7 +59,7 @@
          <el-table border v-loading="loading" :data="modelList" @selection-change="handleSelectionChange">
            <el-table-column type="selection" width="55" align="center" />
            <el-table-column fixed align="center" type="index" label="序号" width="50"></el-table-column>
            <el-table-column fixed align="center" type="index" label="序号" width="80"></el-table-column>
            <el-table-column align="center" :show-overflow-tooltip="true" prop="name" label="模型名称" width="200"></el-table-column>
            <el-table-column align="center" prop="key" label="模型KEY"></el-table-column>
            <el-table-column align="center" prop="version" label="版本号" width="90">
@@ -68,7 +68,7 @@
            <el-table-column align="center" prop="metaInfo" label="备注说明" min-width="130"></el-table-column>
            <el-table-column align="center" :show-overflow-tooltip="true" prop="createTime" label="创建时间" width="160"></el-table-column>
            <el-table-column align="center" :show-overflow-tooltip="true" prop="lastUpdateTime" label="更新时间" width="160"></el-table-column>
            <el-table-column fixed="right" label="操作" align="center" width="150" class-name="small-padding fixed-width">
            <el-table-column fixed="right" label="操作" align="center" width="170" class-name="small-padding fixed-width">
              <template #default="scope">
                <el-row :gutter="10" class="mb8">
                  <el-col :span="1.5">
@@ -82,6 +82,11 @@
                  <el-col :span="1.5">
                    <el-button link type="primary" size="small" icon="ScaleToOriginal" @click="clickDeploy(scope.row.id, scope.row.key)">
                      流程部署
                    </el-button>
                  </el-col>
                  <el-col :span="1.5">
                    <el-button link type="primary" size="small" icon="CopyDocument" @click="handleCopy(scope.row)">
                      复制模型
                    </el-button>
                  </el-col>
                </el-row>
@@ -105,10 +110,10 @@
    <el-dialog v-model="dialog.visible" :title="dialog.title" width="650px" append-to-body :close-on-click-modal="false">
      <el-form ref="formRef" :model="form" :rules="rules" label-width="100px">
        <el-form-item label="模型名称:" prop="name">
          <el-input v-model="form.name" :disabled="ids && ids.length > 0" maxlength="20" show-word-limit />
          <el-input v-model="form.name" :disabled="ids && ids.length > 0 && billType === 'update'" maxlength="20" show-word-limit />
        </el-form-item>
        <el-form-item label="模型KEY:" prop="key">
          <el-input v-model="form.key" :disabled="ids && ids.length > 0" maxlength="20" show-word-limit />
          <el-input v-model="form.key" :disabled="ids && ids.length > 0 && billType === 'update'" maxlength="20" show-word-limit />
        </el-form-item>
        <el-form-item label="流程分类" prop="categoryCode">
          <el-tree-select
@@ -139,6 +144,7 @@
import { listModel, addModel, delModel, modelDeploy, getInfo, update } from '@/api/workflow/model';
import { ModelQuery, ModelForm, ModelVO } from '@/api/workflow/model/types';
import { listCategory } from '@/api/workflow/category';
import { copyModel } from '@/api/workflow/model/index';
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
@@ -163,7 +169,7 @@
const modelList = ref<ModelVO[]>([]);
const categoryOptions = ref<CategoryOption[]>([]);
const categoryName = ref('');
const modelId = ref<string>('');
const billType = ref<string>('');
const dialog = reactive<DialogOption>({
  visible: false,
@@ -268,14 +274,18 @@
  await getList();
  proxy?.$modal.msgSuccess('部署成功');
};
//新增打开
const handleAdd = () => {
  billType.value = 'add';
  ids.value = [];
  getTreeselect();
  form.value = { ...initFormData };
  dialog.visible = true;
  dialog.title = '新增模型';
};
//修改打开
const handleUpdate = () => {
  billType.value = 'update';
  dialog.title = '修改模型';
  nextTick(async () => {
    await getTreeselect();
@@ -286,20 +296,35 @@
  });
};
//复制打开
const handleCopy = (row?: ModelVO) => {
  billType.value = 'copy';
  dialog.title = '复制模型';
  nextTick(async () => {
    await getTreeselect();
    form.value = { ...initFormData };
    form.value.id = row.id
    dialog.visible = true;
  });
};
/** 提交按钮 */
const submitForm = () => {
  formRef.value.validate(async (valid: boolean) => {
    if (valid) {
      buttonLoading.value = true;
      if (ids.value && ids.value.length > 0) {
      if('copy' === billType.value){
        await copyModel(form.value);
        proxy?.$modal.msgSuccess('操作成功');
      }else if(ids.value && ids.value.length > 0 && 'update' === billType.value){
        form.value.id = ids.value[0];
        await update(form.value);
        proxy?.$modal.msgSuccess('新增成功');
      } else {
        proxy?.$modal.msgSuccess('操作成功');
      }else {
        initXml(form.value.key, form.value.name);
        form.value.xml = xml.value;
        await addModel(form.value);
        proxy?.$modal.msgSuccess('新增成功');
        proxy?.$modal.msgSuccess('操作成功');
      }
      dialog.visible = false;
      await getList();
src/views/workflow/processDefinition/index.vue
@@ -108,7 +108,6 @@
                      <template #dropdown>
                        <el-dropdown-menu>
                          <el-dropdown-item @click="getProcessDefinitionHitoryList(scope.row.id, scope.row.key)">历史版本</el-dropdown-item>
                          <el-dropdown-item @click="handleFormOpen(scope.row)">表单配置</el-dropdown-item>
                        </el-dropdown-menu>
                      </template>
                    </el-dropdown>
@@ -211,38 +210,10 @@
              <el-col :span="1.5">
                <el-button link type="primary" icon="Sort" size="small" @click="handleConvertToModel(scope.row)"> 转换模型 </el-button>
              </el-col>
              <el-col :span="1.5">
                <el-button link type="primary" icon="Setting" size="small" @click="handleFormOpen(scope.row)"> 表单配置 </el-button>
              </el-col>
            </el-row>
          </template>
        </el-table-column>
      </el-table>
    </el-dialog>
    <!-- 表单配置 -->
    <el-dialog v-model="formDialog.visible" :title="formDialog.title" width="650px" append-to-body :close-on-click-modal="false">
      <el-form :model="definitionConfigForm" label-width="auto">
        <el-form-item label="流程KEY">
          <el-input v-model="definitionConfigForm.processKey" disabled/>
        </el-form-item>
        <el-form-item label="表单" prop="formId">
          <el-select v-model="definitionConfigForm.formId" clearable filterable placeholder="请选择表单"  style="width: 260px" >
            <el-option  v-for="item in formManageList"  :key="item.id"  :label="item.formTypeName+':'+item.formName" :value="item.id" />
          </el-select>
        </el-form-item>
        <el-form-item label="备注">
          <el-input v-model="definitionConfigForm.remark" type="textarea" resize="none"/>
        </el-form-item>
      </el-form>
      <template #footer>
        <div class="dialog-footer">
          <el-button @click="formDialog.visible = false">取消</el-button>
          <el-button type="primary" @click="handlerSaveForm">
            保存
          </el-button>
        </div>
      </template>
    </el-dialog>
  </div>
</template>
@@ -260,15 +231,10 @@
} from '@/api/workflow/processDefinition';
import ProcessPreview from './components/processPreview.vue';
import { listCategory } from '@/api/workflow/category';
import { getByDefId,saveOrUpdate } from '@/api/workflow/definitionConfig';
import { CategoryVO } from '@/api/workflow/category/types';
import { ProcessDefinitionQuery, ProcessDefinitionVO } from '@/api/workflow/processDefinition/types';
import { definitionConfigForm } from '@/api/workflow/definitionConfig/types';
import { UploadRequestOptions } from 'element-plus';
import { FormManageVO } from '@/api/workflow/formManage/types';
import { selectListFormManage } from '@/api/workflow/formManage';
const formManageList = ref<FormManageVO[]>([]);
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
const previewRef = ref<InstanceType<typeof ProcessPreview>>();
@@ -295,7 +261,6 @@
const categoryName = ref('');
/** 部署文件分类选择 */
const selectCategory = ref();
const definitionConfigForm = ref<definitionConfigForm>({});
const uploadDialog = reactive<DialogOption>({
  visible: false,
@@ -305,11 +270,6 @@
const processDefinitionDialog = reactive<DialogOption>({
  visible: false,
  title: '历史版本'
});
const formDialog = reactive<DialogOption>({
  visible: false,
  title: '表单配置'
});
// 查询参数
@@ -476,34 +436,4 @@
    });
  return;
};
//打开表单配置
const handleFormOpen = async (row: ProcessDefinitionVO) => {
  listFormManage()
   formDialog.visible = true
   definitionConfigForm.value.processKey = row.key
   definitionConfigForm.value.definitionId = row.id
   const resp = await getByDefId(row.id)
   if(resp.data){
    definitionConfigForm.value = resp.data
   }else{
    definitionConfigForm.value.formId = undefined
    definitionConfigForm.value.remark = undefined
   }
}
//保存表单
const handlerSaveForm = async () => {
  await proxy?.$modal.confirm('是否确认保存?');
  saveOrUpdate(definitionConfigForm.value).then(resp=>{
    if(resp.code === 200){
      proxy?.$modal.msgSuccess('操作成功');
      formDialog.visible = false
      getList();
    }
  })
}
//表单列表
const listFormManage = async () => {
  const res = await selectListFormManage();
  formManageList.value = res.data;
}
</script>