TaskAttrModelNumberDataSpecs.vue 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <!-- dataType:number 数组类型 -->
  2. <template>
  3. <el-form-item
  4. :rules="[{ required: true, message: '请选择单位' }]"
  5. label="单位"
  6. prop="extProperty.unit"
  7. >
  8. <el-select
  9. :model-value="extProperty.unit ? extProperty.unit : ''"
  10. filterable
  11. placeholder="请选择单位"
  12. class="w-1/1"
  13. @change="unitChange"
  14. >
  15. <el-option
  16. v-for="(item, index) in getStrDictOptions(DICT_TYPE.PMS_THING_MODEL_UNIT)"
  17. :key="index"
  18. :label="item.label"
  19. :value="item.label + '-' + item.value"
  20. />
  21. </el-select>
  22. </el-form-item>
  23. </template>
  24. <script lang="ts" setup>
  25. import { useVModel } from '@vueuse/core'
  26. import { DICT_TYPE, getStrDictOptions } from '@/utils/dict'
  27. import { DataSpecsNumberDataVO } from "@/views/pms/iotprojecttasktemplate/detail/config";
  28. /** 数值型的 dataSpecs 配置组件 */
  29. defineOptions({ name: 'TaskAttrModelNumberDataSpecs' })
  30. const props = defineProps<{ modelValue: any }>()
  31. const emits = defineEmits(['update:modelValue'])
  32. const dataSpecs = useVModel(props, 'modelValue', emits) as Ref<DataSpecsNumberDataVO>
  33. /** 单位发生变化时触发 */
  34. const unitChange = (UnitSpecs: string) => {
  35. // const [unitName, unit] = UnitSpecs.split('-')
  36. // dataSpecs.value.unitName = unitName
  37. // dataSpecs.value.unit = unit
  38. }
  39. /** 校验最小值 */
  40. const validateMin = (_: any, __: any, callback: any) => {
  41. const min = Number(dataSpecs.value.min)
  42. const max = Number(dataSpecs.value.max)
  43. if (isNaN(min)) {
  44. callback(new Error('请输入有效的数值'))
  45. return
  46. }
  47. if (max !== undefined && !isNaN(max) && min >= max) {
  48. callback(new Error('最小值必须小于最大值'))
  49. return
  50. }
  51. callback()
  52. }
  53. /** 校验最大值 */
  54. const validateMax = (_: any, __: any, callback: any) => {
  55. const min = Number(dataSpecs.value.min)
  56. const max = Number(dataSpecs.value.max)
  57. if (isNaN(max)) {
  58. callback(new Error('请输入有效的数值'))
  59. return
  60. }
  61. if (min !== undefined && !isNaN(min) && max <= min) {
  62. callback(new Error('最大值必须大于最小值'))
  63. return
  64. }
  65. callback()
  66. }
  67. /** 校验步长 */
  68. const validateStep = (_: any, __: any, callback: any) => {
  69. const step = Number(dataSpecs.value.step)
  70. if (isNaN(step)) {
  71. callback(new Error('请输入有效的数值'))
  72. return
  73. }
  74. if (step <= 0) {
  75. callback(new Error('步长必须大于0'))
  76. return
  77. }
  78. const min = Number(dataSpecs.value.min)
  79. const max = Number(dataSpecs.value.max)
  80. if (!isNaN(min) && !isNaN(max) && step > max - min) {
  81. callback(new Error('步长不能大于最大值和最小值的差值'))
  82. return
  83. }
  84. callback()
  85. }
  86. </script>
  87. <style lang="scss" scoped>
  88. :deep(.el-form-item) {
  89. .el-form-item {
  90. margin-bottom: 0;
  91. }
  92. }
  93. </style>