消毒机设备
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

209 lines
5.6 KiB

2 weeks ago
2 weeks ago
2 weeks ago
2 weeks ago
2 weeks ago
2 weeks ago
2 weeks ago
2 weeks ago
2 weeks ago
2 weeks ago
2 weeks ago
  1. <script lang="ts" setup>
  2. import { formulaNameMap } from 'libs/constant'
  3. import { cloneDeep } from 'lodash'
  4. import { ref, watchEffect } from 'vue'
  5. import { FtMessage } from '@/libs/message'
  6. import { compareJSON, convertValuesToInt } from '@/libs/utils'
  7. import { useFormulaStore } from '@/stores/formulaStore'
  8. const props = defineProps<{
  9. editable: boolean
  10. }>()
  11. const formulaStore = useFormulaStore()
  12. /**
  13. * 当前表单数据
  14. * 不同模式下有不同的初始值
  15. * - home: 当前选中的配方
  16. * - setting: 默认配方信息
  17. * - formula: 当前选中的配方或默认配方
  18. */
  19. const formData = ref<Record<string, any>>({
  20. ...formulaStore.defaultFormulaInfo,
  21. })
  22. /**
  23. * 标签单位映射表用于显示各参数的单位
  24. */
  25. const labelUnitMap: Record<string, any> = formulaStore.labelUnitMap
  26. /**
  27. * 配方配置列表
  28. */
  29. const formulaConfigList = ref(formulaStore.formulaConfigList)
  30. /**
  31. * 组件挂载时注册方法供父组件调用
  32. */
  33. watchEffect(() => {
  34. formData.value = cloneDeep(formulaStore.defaultFormulaInfo)
  35. formData.value = convertValuesToInt(formData.value)
  36. })
  37. /**
  38. * 处理表单提交
  39. * 根据不同的type属性值执行不同的保存逻辑
  40. */
  41. const handleSubmit = () => {
  42. // 修改默认值
  43. const diff = compareJSON(formulaStore.defaultFormulaInfo, formData.value)
  44. const diffKeys = Object.keys(diff)
  45. if (diffKeys.length) {
  46. Promise.all(
  47. diffKeys.map(async (key) => {
  48. await formulaStore.setSettingFormulaConfig(key, diff[key].newVal || diff[key].obj2)
  49. }),
  50. )
  51. FtMessage.success('配方修改成功')
  52. }
  53. formulaStore.getFormualDefaultData()
  54. }
  55. const size = 'default'
  56. const validatePass = (rule: any, value: any, callback: any, config: Formula.FormulaConfig) => {
  57. if (!value && value !== 0 && value !== '0') {
  58. callback(new Error('此为必填项'))
  59. }
  60. else if (config.val_type === 'int' || config.val_type === 'float') {
  61. const temp = Number(value)
  62. if (temp < config.val_lower_limit || temp > config.val_upper_limit) {
  63. callback(new Error(`输入范围为${config.val_lower_limit}-${config.val_upper_limit}`))
  64. }
  65. }
  66. callback()
  67. }
  68. </script>
  69. <template>
  70. <div class="formula-form">
  71. <el-form
  72. :disabled="!props.editable"
  73. :model="formData"
  74. label-width="auto"
  75. label-position="right"
  76. :size="size"
  77. inline
  78. >
  79. <el-form-item
  80. v-for="item in formulaConfigList.filter((data) => data.is_visible_in_setting_page)"
  81. :key="item.setting_id"
  82. :label="formulaNameMap[item.setting_id]"
  83. style="width: 50%"
  84. :prop="item.setting_id"
  85. :rules="[
  86. {
  87. required: true,
  88. validator: (rule, value, callback) => validatePass(rule, value, callback, item),
  89. trigger: 'blur',
  90. },
  91. ]"
  92. >
  93. <template v-if="item.val_type === 'int'">
  94. <el-input
  95. v-model.number="formData[item.setting_id]"
  96. v-prevent-keyboard
  97. style="width: 80%"
  98. type="number"
  99. :name="item.setting_id"
  100. :controls="false"
  101. :disabled="!props.editable"
  102. >
  103. <template v-if="labelUnitMap[item.setting_id]" #append>
  104. {{ labelUnitMap[item.setting_id] }}
  105. </template>
  106. </el-input>
  107. </template>
  108. <template v-if="item.val_type === 'float'">
  109. <el-input
  110. v-model.number="formData[item.setting_id]"
  111. v-prevent-keyboard
  112. style="width: 80%"
  113. type="number"
  114. :name="item.setting_id"
  115. :controls="false"
  116. :disabled="!props.editable"
  117. >
  118. <template v-if="labelUnitMap[item.setting_id]" #append>
  119. {{ labelUnitMap[item.setting_id] }}
  120. </template>
  121. </el-input>
  122. </template>
  123. <template v-else-if="item.val_type === 'enum'">
  124. <el-select
  125. v-model="formData[item.setting_id]"
  126. v-prevent-keyboard
  127. style="width: 80%;height:40px"
  128. placeholder="请选择"
  129. readonly
  130. >
  131. <el-option v-for="log in item.enums" :key="log" :label="log" :value="log" />
  132. </el-select>
  133. </template>
  134. </el-form-item>
  135. </el-form>
  136. <div :style="{ marginLeft: '33%' }">
  137. <slot name="formulaBtn">
  138. <div class="default-btn">
  139. <el-button v-if="editable" type="primary" class="config-btn" @click="handleSubmit">
  140. 确定
  141. </el-button>
  142. </div>
  143. </slot>
  144. </div>
  145. </div>
  146. </template>
  147. <style lang="scss" scoped>
  148. .formula-form {
  149. font-size: 20px !important;
  150. padding: 5px;
  151. padding-left: 15px;
  152. align-items: center;
  153. .default-btn {
  154. margin-top: 1rem;
  155. }
  156. .config-btn {
  157. height: 3rem;
  158. width: 8rem;
  159. }
  160. }
  161. .formula-form-item {
  162. display: grid;
  163. grid-template-columns: 1fr 1fr;
  164. }
  165. .formData-input-config {
  166. width: 10vw;
  167. }
  168. :deep(.el-input__inner) {
  169. text-align: left;
  170. height: 40px;
  171. }
  172. :deep(.el-form-item) {
  173. margin-right: 0;
  174. align-items: center;
  175. }
  176. /* 进入动画的初始状态 */
  177. .slide-right-enter-from {
  178. transform: translateX(100%);
  179. }
  180. /* 进入动画的结束状态(也可以理解为激活状态) */
  181. .slide-right-enter-to {
  182. transform: translateX(0);
  183. }
  184. /* 进入动画的过渡曲线等 */
  185. .slide-right-enter-active {
  186. transition: transform 0.3s ease-in-out;
  187. }
  188. /* 离开动画的初始状态(激活状态) */
  189. .slide-right-leave-from {
  190. transform: translateX(0);
  191. }
  192. /* 离开动画的结束状态 */
  193. .slide-right-leave-to {
  194. transform: translateX(100%);
  195. }
  196. /* 离开动画的过渡曲线等 */
  197. .slide-right-leave-active {
  198. transition: transform 0.3s ease-in-out;
  199. }
  200. </style>