editDialog.vue 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. <template>
  2. <div class="labApprovalFlow-container">
  3. <el-dialog v-model="state.isShowDialog" :width="800" draggable>
  4. <template #header>
  5. <div style="color: #fff">
  6. <el-icon size="16" style="margin-right: 3px; display: inline; vertical-align: middle"> <ele-Edit /> </el-icon>
  7. <span>{{ props.title }}</span>
  8. </div>
  9. </template>
  10. <el-form :model="state.ruleForm" ref="ruleFormRef" label-width="auto" :rules="rules">
  11. <el-tabs>
  12. <el-tab-pane label="基本信息">
  13. <el-row :gutter="35">
  14. <el-form-item v-show="false">
  15. <el-input v-model="state.ruleForm.id" />
  16. </el-form-item>
  17. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  18. <el-form-item label="编号" prop="code">
  19. <el-input v-model="state.ruleForm.code" placeholder="请输入编号" maxlength="32" show-word-limit clearable />
  20. </el-form-item>
  21. </el-col>
  22. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  23. <el-form-item label="名称" prop="name" :rules="[{ required: true, message: '名称不能为空', trigger: 'blur' }]">
  24. <el-input v-model="state.ruleForm.name" placeholder="请输入名称" maxlength="32" show-word-limit clearable />
  25. </el-form-item>
  26. </el-col>
  27. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  28. <el-form-item label="业务类型" prop="bizType">
  29. <el-select v-model="state.ruleForm.bizType" placeholder="请选择业务类型" clearable filterable style="width: 100%">
  30. <el-option v-for="bt in bizTypeOptions" :key="bt.code" :label="`${bt.name}(${bt.code})`" :value="bt.code" />
  31. </el-select>
  32. </el-form-item>
  33. </el-col>
  34. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  35. <el-form-item label="状态" prop="status" :rules="[{ required: true, message: '状态不能为空', trigger: 'blur' }]">
  36. <el-select v-model="state.ruleForm.status" placeholder="请选择" style="width: 100%">
  37. <el-option label="启用" :value="1" />
  38. <el-option label="禁用" :value="0" />
  39. </el-select>
  40. </el-form-item>
  41. </el-col>
  42. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  43. <el-form-item label="备注" prop="remark">
  44. <el-input v-model="state.ruleForm.remark" placeholder="请输入备注" type="textarea" maxlength="255" show-word-limit clearable />
  45. </el-form-item>
  46. </el-col>
  47. </el-row>
  48. </el-tab-pane>
  49. <el-tab-pane label="扩展信息">
  50. <el-row :gutter="35">
  51. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  52. <el-form-item label="表单" prop="formJson">
  53. <el-input v-model="state.ruleForm.formJson" placeholder="请输入表单" type="textarea" maxlength="4096" show-word-limit clearable />
  54. </el-form-item>
  55. </el-col>
  56. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  57. <el-form-item label="流程" prop="flowJson">
  58. <el-input v-model="state.ruleForm.flowJson" placeholder="请输入流程" type="textarea" maxlength="4096" show-word-limit clearable />
  59. </el-form-item>
  60. </el-col>
  61. </el-row>
  62. </el-tab-pane>
  63. </el-tabs>
  64. </el-form>
  65. <template #footer>
  66. <span class="dialog-footer">
  67. <el-button @click="cancel">取 消</el-button>
  68. <el-button type="primary" @click="submit">确 定</el-button>
  69. </span>
  70. </template>
  71. </el-dialog>
  72. </div>
  73. </template>
  74. <script setup lang="ts">
  75. import { reactive, ref, onMounted } from 'vue';
  76. import { ElMessage } from 'element-plus';
  77. import type { FormRules } from 'element-plus';
  78. import { getAPI } from '/@/utils/axios-utils';
  79. import { ApprovalFlowApi } from '/@/api-plugins/approvalFlow/api';
  80. import { getBizTypeList } from '../api';
  81. // 父级传递来的参数
  82. var props = defineProps({
  83. title: {
  84. type: String,
  85. default: '',
  86. },
  87. labStatus: {
  88. type: Array,
  89. default: () => [],
  90. },
  91. });
  92. // 父级传递来的函数,用于回调
  93. const emit = defineEmits(['reloadTable']);
  94. // 定义变量内容
  95. const ruleFormRef = ref();
  96. const state = reactive({
  97. loading: false,
  98. isShowDialog: false,
  99. ruleForm: {} as any,
  100. });
  101. const bizTypeOptions = ref<{ code: string; name: string; source: string }[]>([]);
  102. const loadBizTypes = async () => {
  103. try {
  104. const res = await getBizTypeList();
  105. bizTypeOptions.value = res.data?.result ?? [];
  106. } catch {}
  107. };
  108. onMounted(() => loadBizTypes());
  109. const rules = ref<FormRules>({
  110. name: [
  111. {
  112. pattern: /^(?!^[0-9].*$).*/,
  113. message: '不能以数字开头',
  114. trigger: 'blur',
  115. },
  116. ],
  117. });
  118. // 打开弹窗
  119. const openDialog = async (row: any) => {
  120. let rowData = JSON.parse(JSON.stringify(row));
  121. state.ruleForm = rowData.id ? (await getAPI(ApprovalFlowApi).apiApprovalFlowDetailGet(rowData.id)).data.result : rowData;
  122. state.isShowDialog = true;
  123. loadBizTypes();
  124. };
  125. // 关闭弹窗
  126. const closeDialog = () => {
  127. emit('reloadTable');
  128. state.isShowDialog = false;
  129. };
  130. // 取消
  131. const cancel = () => {
  132. state.isShowDialog = false;
  133. };
  134. // 提交
  135. const submit = async () => {
  136. ruleFormRef.value.validate(async (isValid: boolean, fields?: any) => {
  137. if (isValid) {
  138. if (state.ruleForm.id == undefined || state.ruleForm.id == null || state.ruleForm.id == 0) {
  139. await getAPI(ApprovalFlowApi).apiApprovalFlowAddPost(state.ruleForm);
  140. } else {
  141. await getAPI(ApprovalFlowApi).apiApprovalFlowUpdatePost(state.ruleForm);
  142. }
  143. closeDialog();
  144. } else {
  145. ElMessage({
  146. message: `表单有${Object.keys(fields).length}处验证失败,请修改后再提交`,
  147. type: 'error',
  148. });
  149. }
  150. });
  151. };
  152. // 将属性或者函数暴露给父组件
  153. defineExpose({ openDialog });
  154. </script>
  155. <style scoped lang="scss">
  156. :deep(.el-select),
  157. :deep(.el-input-number) {
  158. width: 100%;
  159. }
  160. </style>