cloneDialog.vue 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. <template>
  2. <!-- 克隆 -->
  3. <el-dialog v-model="cloneDialog" title="变量克隆" width="30rem" @close="close">
  4. <div class="dialogOne">
  5. <el-form :model="form" :rules="rules" ref="ruleForm" label-width="150px" class="demo-ruleForm">
  6. <el-form-item label="克隆设备对象:" prop="deviceCode">
  7. <span>{{ form.deviceCode }}</span>
  8. </el-form-item>
  9. <el-form-item label="变量克隆至:" prop="cloneRadio">
  10. <el-radio-group v-model="form.type" size="medium">
  11. <el-radio :label="1">新设备</el-radio>
  12. <el-radio :label="2">已有设备(仅克隆变量)</el-radio>
  13. </el-radio-group>
  14. </el-form-item>
  15. <el-form-item label="设备名:" prop="cloneInputName" v-if="form.type == 1">
  16. <el-input v-model="form.cloneInputName" placeholder="请输入设备名" clearable />
  17. </el-form-item>
  18. <el-form-item label="设备编号:" prop="cloneInputCode" v-if="form.type == 1">
  19. <el-input v-model="form.cloneInputCode" placeholder="请输入设备编号" clearable />
  20. </el-form-item>
  21. <el-form-item label="选择站点:" v-if="form.type != 1">
  22. <el-select v-model="store.state.siteId" @change="select_deviceList()" placeholder="请选择" clearable filterable>
  23. <el-option v-for="item in store.state.siteList" :key="item.id" :label="item.siteName"
  24. :value="item.id"></el-option>
  25. </el-select>
  26. </el-form-item>
  27. <el-form-item label="选择设备:" v-if="form.type != 1">
  28. <el-select filterable v-model="form.oldDeviceCode" placeholder="请选择所需克隆设备(可输入)">
  29. <el-option v-for="list in deviceList" :key="list" :label="list.deviceName"
  30. :value="list.deviceCode"></el-option>
  31. </el-select>
  32. </el-form-item>
  33. </el-form>
  34. <!-- <div class="content">
  35. <span>*</span>
  36. 模拟量:
  37. <el-input class="inputer" v-model="cloneInputModel" placeholder="请输入模拟量" clearable />
  38. 状态量:
  39. <el-input class="inputer" v-model="cloneInputState" placeholder="请输入状态量" clearable />
  40. </div> -->
  41. </div>
  42. <template #footer>
  43. <span class="dialog-footer">
  44. <!-- <el-checkbox v-model="cloneChecked" label="连续克隆模式" style="margin-right: 10px"></el-checkbox> -->
  45. <el-button @click="cloneDialog = false">取消</el-button>
  46. <el-button type="primary" @click="clone()">确定</el-button>
  47. </span>
  48. </template>
  49. </el-dialog>
  50. </template>
  51. <script setup>
  52. /*----------------------------------依赖引入-----------------------------------*/
  53. import { useStore } from 'vuex'
  54. import { ref, onMounted, watch, getCurrentInstance, watchEffect } from 'vue'
  55. import { ElMessage } from 'element-plus'
  56. /*----------------------------------接口引入-----------------------------------*/
  57. import * as api from '@/api/deviceManage/powerEquip/communicateEquip'
  58. /*----------------------------------组件引入-----------------------------------*/
  59. /*----------------------------------store引入-----------------------------------*/
  60. /*----------------------------------公共方法引入-----------------------------------*/
  61. /*----------------------------------公共变量-----------------------------------*/
  62. const store = useStore()
  63. const props = defineProps({}) //数据双向绑定
  64. const emit = defineEmits(['handleSelect']);
  65. const { proxy } = getCurrentInstance();
  66. /*----------------------------------变量声明-----------------------------------*/
  67. const cloneDialog = ref(false) //克隆弹窗控制
  68. const form = ref({
  69. type: 1,
  70. cloneInputName: '',
  71. cloneInputCode: '',
  72. oldDeviceCode: '',
  73. })
  74. const rules = {
  75. cloneInputCode: [
  76. { required: true, message: '设备名不能为空', trigger: 'blur', },
  77. { min: 5, max: 25, message: '设备名长度不能小于5大于25', trigger: 'blur', },
  78. ],
  79. cloneInputName: [
  80. { required: true, message: '设备编号不能为空', trigger: 'blur', },
  81. { min: 5, max: 25, message: '设备编号长度不能小于5大于25', trigger: 'blur', },
  82. ],
  83. }
  84. const cloneChecked = ref(false) //克隆复选框控制
  85. const cloneInputModel = ref('') //克隆input模拟量
  86. const cloneInputState = ref('') //克隆input状态量
  87. const ruleForm = ref(null)
  88. const deviceList = ref([])
  89. const clone = () => {
  90. let list = {}
  91. if (form.value.type == 1) {
  92. list = {
  93. type: form.value.type,
  94. oldDeviceCode: form.value.deviceCode,
  95. newDeviceCode: form.value.cloneInputCode,
  96. deviceName: form.value.cloneInputName,
  97. }
  98. } else {
  99. list = {
  100. type: form.value.type,
  101. newDeviceCode: form.value.oldDeviceCode,
  102. oldDeviceCode: form.value.deviceCode,
  103. }
  104. }
  105. proxy.$refs["ruleForm"].validate((valid) => {
  106. if (valid) {
  107. api.variableCloning(list).then((requset) => {
  108. if (requset.status === 'SUCCESS') {
  109. ElMessage.success({
  110. message: '克隆成功',
  111. type: 'success',
  112. })
  113. close()
  114. emit('handleSelect', false)
  115. } else {
  116. ElMessage.error(requset.msg)
  117. }
  118. })
  119. } else {
  120. console.log('error submit!!')
  121. return false
  122. }
  123. })
  124. }
  125. //open
  126. function openDialog(item) {
  127. form.value = item.dialogArray
  128. cloneDialog.value = true
  129. select_deviceList()
  130. }
  131. //弹窗关闭
  132. function close() {
  133. proxy.$refs["ruleForm"].resetFields()
  134. form.value.cloneInputName = ''
  135. form.value.cloneInputCode = ''
  136. form.value.oldDeviceCode = ''
  137. cloneDialog.value = false
  138. }
  139. function select_deviceList() {
  140. api
  141. .deviceList({
  142. siteId: store.state.siteId,
  143. })
  144. .then((requset) => {
  145. if (requset.status === 'SUCCESS') {
  146. deviceList.value = requset.data
  147. for (var i = deviceList.value.length - 1; i >= 0; i--) {
  148. if (deviceList.value[i].id == form.value.id) deviceList.value.splice(i, 1)
  149. }
  150. } else {
  151. ElMessage.error(requset.msg)
  152. }
  153. })
  154. }
  155. // 暴露变量
  156. defineExpose({
  157. openDialog,
  158. });
  159. </script>