eight
2024-11-25 c6421e15ecc9df14dbb2f29ab76a73ce7aa7f603
src/views/ecg/devmanage/DeviceForm.vue
@@ -1,22 +1,43 @@
<template>
  <Dialog :title="dialogTitle" v-model="dialogVisible">
    <el-form
      ref="formRef"
      :model="formData"
      :rules="formRules"
      label-width="100px"
      v-loading="formLoading"
        ref="formRef"
        :model="formData"
        :rules="formRules"
        label-width="100px"
        v-loading="formLoading"
    >
      <el-form-item label="设备编号" prop="devId">
        <el-input v-model="formData.devId" placeholder="请输入设备编号" />
      <el-form-item label="采购日期" prop="purchaseDate">
        <el-date-picker
            v-model="formData.purchaseDate"
            type="date"
            value-format="x"
            placeholder="选择采购日期"
        />
      </el-form-item>
      <el-form-item label="设备固有编号" prop="devId">
        <el-input v-model="formData.devCodeIntrinsic" placeholder="请输入设备固有编号" />
      </el-form-item>
      <el-form-item label="设备医院编号" prop="devId">
        <el-input v-model="formData.devCodeHosp" placeholder="请输入设备医院编号" />
      </el-form-item>
      <el-form-item label="设备科室编号" prop="devId">
        <el-input v-model="formData.devCodeDept" placeholder="请输入设备科室编号" />
      </el-form-item>
      <el-form-item label="分类名" prop="category">
        <el-input v-model="formData.category" placeholder="请输入分类名" />
        <el-select v-model="formData.category" placeholder="请选择分类名" @change="categoryChanged">
          <el-option
              v-for="dict in categoryOptions"
              :key="dict.value as string"
              :label="dict.label"
              :value="dict.value"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="品牌" prop="brand">
        <el-select v-model="formData.brand" placeholder="请输入品牌">
        <el-select v-model="formData.brand" placeholder="请选择品牌" @change="brandChanged">
          <el-option
              v-for="dict in getIntDictOptions(DICT_TYPE.ECG_DEV_BRAND)"
              v-for="dict in brandOptions"
              :key="dict.value"
              :label="dict.label"
              :value="dict.value"
@@ -24,15 +45,27 @@
        </el-select>
      </el-form-item>
      <el-form-item label="型号" prop="model">
        <el-input v-model="formData.model" placeholder="请输入型号" />
        <el-select v-model="formData.model" placeholder="请选择型号">
          <el-option
              v-for="dict in modelOptions"
              :key="dict.value"
              :label="dict.label"
              :value="dict.value"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="采购日期" prop="purchaseDate">
        <el-date-picker
          v-model="formData.purchaseDate"
          type="date"
          value-format="x"
          placeholder="选择采购日期"
        />
      <el-form-item v-if="formType !== 'create'" label="状态" prop="state">
        <el-radio-group v-if="formType === 'devState'" v-model="formData.state">
          <el-radio key="0" :value="0"> 空闲中 </el-radio>
          <el-radio key="5" :value="5"> 已领取 </el-radio>
          <el-radio key="10" :value="10"> 已装机 </el-radio>
          <el-radio key="20" :value="20"> 已遗失 </el-radio>
          <el-radio key="30" :value="30"> 待维修 </el-radio>
          <el-radio key="30" :value="40"> 维修中 </el-radio>
          <el-radio key="40" :value="50"> 已报废 </el-radio>
        </el-radio-group>
        <span v-else>{{tranlateDevState(formData.state)}}</span>
      </el-form-item>
    </el-form>
    <template #footer>
@@ -42,8 +75,8 @@
  </Dialog>
</template>
<script setup lang="ts">
import { DeviceApi, DeviceVO } from '@/api/ecg/devmanage'
import {DICT_TYPE, getIntDictOptions} from "@/utils/dict";
import {getStrDictOptions, DICT_TYPE, DictDataType} from '@/utils/dict'
import {DeviceApi, DeviceVO, DevModelApi, OptionsVO} from '@/api/ecg/devmanage'
/** 设备 表单 */
defineOptions({ name: 'DeviceForm' })
@@ -55,19 +88,18 @@
const dialogTitle = ref('') // 弹窗的标题
const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
const formType = ref('') // 表单的类型:create - 新增;update - 修改
const formData = ref({
  id: undefined,
  devId: undefined,
  category: undefined,
  brand: undefined,
  model: undefined,
  purchaseDate: undefined
const formData = ref<DeviceVO>({
  id: 0,
  purchaseDate: new Date().getTime(),
  devCodeIntrinsic: '',
  devCodeHosp: '',
  devCodeDept: '',
  category: '',
  brand: '',
  model: '',
  lost: 0,
})
const formRules = reactive({
  devId: [{ required: true, message: '设备编号不能为空', trigger: 'blur' }],
  category: [{ required: true, message: '分类名不能为空', trigger: 'blur' }],
  brand: [{ required: true, message: '品牌不能为空', trigger: 'blur' }],
  model: [{ required: true, message: '型号不能为空', trigger: 'blur' }]
})
const formRef = ref() // 表单 Ref
@@ -77,13 +109,23 @@
  dialogTitle.value = t('action.' + type)
  formType.value = type
  resetForm()
  // 修改时,设置数据
  if (id) {
    formLoading.value = true
    try {
      formData.value = await DeviceApi.getDevice(id)
      const bandData = await DevModelApi.getBrandOption(formData.value.category!)
      brandOptions.value = bandData
      const modelData = await DevModelApi.getModelOption(formData.value.category!, formData.value.brand!)
      modelOptions.value = modelData
    } finally {
      formLoading.value = false
    }
  } else {  // 新增时
    if (categoryOptions.value.length !== 0) {
      formData.value.category = categoryOptions.value[0].value as string
      categoryChanged()
    }
  }
}
@@ -101,9 +143,12 @@
    if (formType.value === 'create') {
      await DeviceApi.createDevice(data)
      message.success(t('common.createSuccess'))
    } else {
    } else if (formType.value === 'update') {
      await DeviceApi.updateDevice(data)
      message.success(t('common.updateSuccess'))
    } else {
      await DeviceApi.updateDeviceState(data)
      message.success(t('common.updateStateSuccess'))
    }
    dialogVisible.value = false
    // 发送操作成功的事件
@@ -116,13 +161,49 @@
/** 重置表单 */
const resetForm = () => {
  formData.value = {
    id: undefined,
    devId: undefined,
    category: undefined,
    brand: undefined,
    model: undefined,
    purchaseDate: undefined
    id: 0,
    purchaseDate: new Date().getTime(),
    devId: '',
    category: '',
    brand: '',
    model: ''
  }
  formRef.value?.resetFields()
}
const categoryOptions = ref<DictDataType[]>([])
const brandOptions = ref<OptionsVO[]>([])
const modelOptions = ref<OptionsVO[]>([])
const categoryChanged = async () => {
  const data = await DevModelApi.getBrandOption(formData.value.category!)
  brandOptions.value = data
  formData.value.brand = brandOptions.value.length === 0 ? "" : brandOptions.value[0].value
  brandChanged()
}
const brandChanged = async () => {
  const data = await DevModelApi.getModelOption(formData.value.category!, formData.value.brand!)
  modelOptions.value = data
  formData.value.model = modelOptions.value.length === 0 ? "" : modelOptions.value[0].value
}
const tranlateDevState = (state) => {
  if (state === 0) return "空闲";
  else if (state=== 5) return "已领用";
  else if (state=== 10) return "已装机";
  else if (state=== 20) return "已遗失";
  else if (state=== 30) return "待维修";
  else if (state=== 40) return "维修中";
  else if (state=== 50) return "已报废";
}
onMounted( async () => {
  console.info("onMount DeviceForm...")
  const data = await getStrDictOptions(DICT_TYPE.ECG_DEV_CATEGORY)
  categoryOptions.value = data
})
</script>