Newer
Older
smart-metering-front / src / views / system / process / addProcess.vue
<!-- 新建流程页面 -->
<script lang="ts" setup name="EditProcess">
import { onMounted, reactive, ref } from 'vue'
import type { FormInstance, FormRules } from 'element-plus'
import { useRoute, useRouter } from 'vue-router'
import type { Ref } from 'vue'
import setting from '../../setting.vue'
import type { IBusinessList, Iform } from './process'
import WorkFlow from '@/components/workFlow/workFlow.vue'
const emits = defineEmits(['close'])
const processSetting = ref()
const selectFormId = ref('') // formid
const $route = useRoute()
const getRowData = ref({}) as any
const ruleFormRef = ref<FormInstance>()
const form: Ref<Iform> = ref({
  number: '', // 编号
  name: '', // 名称
  business: '', // 关联业务
  formID: '', // formID
  desc: '', // 流程描述
  selectDecision: '', // 选择的决策
  rejectTo: '', // 可驳回至
  changeData: '', // 驳回修改数据
  isMessage: '', // 审批结果通知发起人
})
// 可选决策项
const decision = [
  {
    id: 'reject-refuse',
    title: '同意 驳回 拒绝',
  },
  {
    id: 'reject',
    title: '同意 驳回',
  },
  {
    id: 'refuse',
    title: '同意 拒绝',
  },
]
// 可驳回至
const reject = [
  {
    id: 'change',
    title: '单据修改',
  },
]
// 驳回修改数据
const rejectChangeData = [
  {
    id: 'all',
    title: '重新按流程走',
  },
  {
    id: 'part',
    title: '送至驳回节点',
  },
]
// 审批结果通知发起人
const messageData = [
  {
    id: 'yes',
    title: '是',
  },
  {
    id: 'no',
    title: '否',
  },
]
const rules = reactive<FormRules>({
  name: [
    {
      required: true,
      message: '流程名称不能为空',
      trigger: 'blur',
    },
  ],
  business: [
    {
      required: true,
      message: '关联业务不能为空',
      trigger: 'blur',
    },
  ],
  formID: [
    {
      required: true,
      message: 'formID不能为空',
      trigger: 'blur',
    },
  ],
  desc: [
    {
      required: true,
      message: '流程描述不能为空',
      trigger: 'blur',
    },
  ],
})

const $router = useRouter()
// 关闭
const close = () => {
  $router.back()
}
// 保存
const save = async (formEl: FormInstance | undefined) => {
  if (!formEl) { return }
  await formEl.validate((valid, fields) => {
    if (valid) {
      // 调setting组件的保存
      processSetting.value.saveSet()
    }
  })
}

// 选择决策项
const changeDecision = (value: string) => {
  form.value.selectDecision = value
}
const changeRejectTo = (value: string) => {
  form.value.rejectTo = value
}
const changeData = (value: string) => {
  form.value.changeData = value
}
const changeMessage = (value: string) => {
  form.value.isMessage = value
}

const createProcessSuccess = () => {
  close()
}
</script>

<template>
  <div class="edit-process">
    <app-container>
      <detail-page title="流程管理-新建">
        <template #btns>
          <el-button type="primary" @click="save(ruleFormRef)">
            保存
          </el-button>
          <el-button type="info" @click="close">
            关闭
          </el-button>
        </template>
        <el-form ref="ruleFormRef" :model="form" label-width="150px" :rules="rules">
          <el-row :gutter="24">
            <el-col :span="8">
              <el-form-item label="流程编号:">
                <el-input v-model="form.number" disabled placeholder="系统自动生成" />
              </el-form-item>
              <!-- <el-form-item label="可选决策项" prop="selectDecision">
                <el-select v-model="form.selectDecision" placeholder="请选择" @change="changeDecision">
                  <el-option
                    v-for="item in decision"
                    :key="item.id"
                    :label="item.title"
                    :value="item.id"
                  />
                </el-select>
              </el-form-item> -->
            </el-col>
            <el-col :span="8">
              <el-form-item label="流程名称:" prop="name">
                <el-input v-model="form.name" placeholder="请输入流程名称" />
              </el-form-item>

              <!-- <el-form-item v-if="form.selectDecision !== 'refuse'" label="可驳回至" prop="rejectTo">
                <el-select v-model="form.rejectTo" placeholder="请选择" @change="changeRejectTo">
                  <el-option
                    v-for="item in reject"
                    :key="item.id"
                    :label="item.title"
                    :value="item.id"
                  />
                </el-select>
              </el-form-item> -->
              <!-- <el-form-item label="审批结果通知发起人" prop="isMessage">
                <el-select v-model="form.isMessage" placeholder="请选择" @change="changeMessage">
                  <el-option
                    v-for="item in messageData"
                    :key="item.id"
                    :label="item.title"
                    :value="item.id"
                  />
                </el-select>
              </el-form-item> -->
            </el-col>
            <el-col :span="8">
              <el-form-item label="formID:" prop="formID">
                <el-input v-model="form.formID" placeholder="请输入formID" />
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="关联业务:" prop="business">
                <el-input v-model="form.business" placeholder="请输入关联业务" />
              </el-form-item>
              <!-- <el-form-item v-if="form.selectDecision !== 'refuse'" label="驳回修改数据" prop="changeData">
                <el-select v-model="form.changeData" placeholder="请选择" @change="changeData">
                  <el-option
                    v-for="item in rejectChangeData"
                    :key="item.id"
                    :label="item.title"
                    :value="item.id"
                  />
                </el-select>
              </el-form-item> -->
            </el-col>
            <el-col :span="16">
              <el-form-item label="流程描述" prop="desc">
                <el-input v-model="form.desc" type="textarea" autosize placeholder="请输入流程描述" />
              </el-form-item>
            </el-col>
          </el-row>
        </el-form>
      </detail-page>

      <detail-block title="流程配置" />
      <setting
        ref="processSetting"
        :is-add-process="true"
        :get-row-data="form"
        :select-form-id="selectFormId"
        @createProcessSuccess="createProcessSuccess"
      />
    </app-container>
  </div>
</template>

<style lang="scss" scoped>
  .edit-process {
    width: 100%;

    .title {
      margin: 0 0 20px;
      font-weight: 600;
    }

    .edit {
      width: 100%;
      padding: 12px;
      background-color: #fff;
      border-radius: 7px;
      margin: 0 0 20px;

      .button-area {
        width: 100%;
        display: flex;
        justify-content: flex-end;
        margin-bottom: 20px;
      }
    }

    .set {
      width: 100%;
      background-color: #fff;
      border-radius: 7px;
      margin: 20px 0;
    }
  }
</style>