Newer
Older
smart-metering-front / src / views / system / process / editProcess.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 { Iform, dictType } from './process'
import WorkFlow from '@/components/workFlow/workFlow.vue'
import { getDictByCode } from '@/api/system/dict'

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: '', // 流程描述
  decisionItem: '', // 可选决策项 1同意驳回拒绝2同意驳回3同意拒绝
  noticeStarter: '', // 审批结果是否通知发起人
})
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',
    },
  ],
  decisionItem: [
    {
      required: true,
      message: '可选决策项不能为空',
      trigger: 'change',
    },
  ],
  noticeStarter: [
    {
      required: true,
      message: '审批结果是否通知发起人不能为空',
      trigger: 'change',
    },
  ],
})
const decisionItemList = ref<dictType[]>([]) // 可选决策项
const noticeStarterList = ref<dictType[]>([]) // 可选决策项
const $router = useRouter()
// 关闭
const close = () => {
  $router.back()
}
// 获取字典值
async function getDict() {
  // 可选决策项
  const response = await getDictByCode('decisionItem')
  decisionItemList.value = response.data

  // 审批结果是否通知发起人
  const res = await getDictByCode('noticeStarter')
  noticeStarterList.value = res.data
}
getDict()

// 保存
const save = async (formEl: FormInstance | undefined) => {
  if (!formEl) { return }
  await formEl.validate((valid, fields) => {
    if (valid) {
      window.sessionStorage.setItem('decisionItem', `${form.value.decisionItem}`)
      window.sessionStorage.setItem('noticeStarter', `${form.value.noticeStarter}`)
      // 调保存接口
      getRowData.value.name = form.value.name // 流程名称
      getRowData.value.business = form.value.business // 关联业务
      getRowData.value.desc = form.value.desc // 流程名称
      getRowData.value.formDesc = form.value.desc // 流程名称
      console.log('999999999999999', getRowData.value)
      processSetting.value.saveSet('edit', getRowData.value)
    }
    else {
      console.log('error submit!', fields)
    }
  })
}

// 监听可选决策项、是否通知发起人获取到数据了
const getNotice = () => {
  if (window.sessionStorage.getItem('decisionItem')) { // 可选决策项
    form.value.decisionItem = window.sessionStorage.getItem('decisionItem')!
  }
  if (window.sessionStorage.getItem('noticeStarter')) { // 是否通知发起人
    form.value.noticeStarter = window.sessionStorage.getItem('noticeStarter')!
  }
}

onMounted(() => {
  const rowData: any = $route.query.rowData
  getRowData.value = JSON.parse(rowData)
  selectFormId.value = getRowData.value.formId
  form.value.formID = getRowData.value.formId
  form.value.number = getRowData.value.number
  form.value.name = getRowData.value.name
  form.value.business = getRowData.value.business
  form.value.desc = getRowData.value.describe
})
</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="180px" :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-col>
            <el-col :span="8">
              <el-form-item label="流程名称:" prop="name">
                <el-input v-model="form.name" placeholder="请输入流程名称" />
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="formID:" prop="formID">
                <el-input v-model="form.formID" placeholder="请输入formID" disabled />
              </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-col>
            <el-col :span="8">
              <el-form-item label="可选决策项:" prop="decisionItem">
                <el-select
                  v-model="form.decisionItem"
                  clearable
                  placeholder="请选择可选决策项"
                  size="default"
                  style="width: 100%;"
                >
                  <el-option
                    v-for="item in decisionItemList"
                    :key="item.value"
                    :label="item.name"
                    :value="item.value"
                  />
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="审批结果是否通知发起人:" prop="noticeStarter">
                <el-select
                  v-model="form.noticeStarter"
                  clearable
                  placeholder="请选择是否通知发起人"
                  size="default"
                  style="width: 100%;"
                >
                  <el-option
                    v-for="item in noticeStarterList"
                    :key="item.value"
                    :label="item.name"
                    :value="item.value"
                  />
                </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" :get-row-data="getRowData" :select-form-id="selectFormId" @notice="getNotice" />
    </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>