DeviceModal.vue 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. <template>
  2. <BasicModal v-bind="$attrs" @register="registerModal" :title="title" width="1000px" :showCancelBtn="false"
  3. :showOkBtn="false" :footer="null" :destroyOnClose="true" :mask-closable="false" @cancel="closeModalFn">
  4. <a-tabs v-if="props.showTab" v-model:activeKey="activeKey">
  5. <a-tab-pane key="1" tab="基本信息" force-render>
  6. <FormModal :deviceType="deviceType" :record="deviceData"
  7. @saveOrUpdate="(values) => emit('saveOrUpdate', values)" />
  8. </a-tab-pane>
  9. <!-- <a-tab-pane key="10" v-if="deviceType == 'fanlocal' || deviceType == 'fanmain'" tab="风机曲线" force-render>
  10. <FanLineModal :record="deviceData" />
  11. </a-tab-pane> -->
  12. <a-tab-pane key="11" tab="报表录入">
  13. <DeviceReportInfo v-if="activeKey == '11'" />
  14. </a-tab-pane>
  15. <a-tab-pane key="2" tab="点表关联">
  16. <PointTable :columns="pointColumns" :pointType="deviceData.strtype" :deviceId="deviceData.id" :valuetype="9"
  17. @save="savePointData" @delete="deletePointById" />
  18. </a-tab-pane>
  19. <a-tab-pane key="8" tab="虚拟点表配置">
  20. <PointTable :columns="simulationColumns" :pointType="deviceData.strtype" :deviceId="deviceData.id"
  21. :valuetype="4" @save="savePointData" @delete="deletePointById" />
  22. </a-tab-pane>
  23. <a-tab-pane key="3" tab="关联设备" v-if="deviceType == 'managesys'">
  24. <WorkFacePointTable :columns="linkColumns" :deviceId="deviceData.id" @save="savePointData"
  25. @delete="deletePointById" />
  26. </a-tab-pane>
  27. <a-tab-pane key="12" tab="关联报表" v-if="deviceType == 'managesys'">
  28. <WorkFaceReportTable :columns="reportColumns" :device="deviceData" />
  29. </a-tab-pane>
  30. <a-tab-pane v-if="deviceType == 'managesys'" key="4" tab="预警条目管理">
  31. <ManagerWarningDeviceTable v-if="activeKey == '4'" :deviceId="deviceData.id" />
  32. </a-tab-pane>
  33. <a-tab-pane key="5" :tab="deviceType !== 'managesys' ? '点位(报警)配置' : '配置预警设备'">
  34. <template v-if="activeKey == '5'">
  35. <WarningTable v-if="deviceType !== 'managesys'" :deviceId="deviceData.id" :pointType="deviceData.strtype" />
  36. <BackWindDeviceTable v-else :deviceId="deviceData.id" />
  37. </template>
  38. </a-tab-pane>
  39. <a-tab-pane v-if="deviceType == 'managesys'" key="6" tab="配置控制设备">
  40. <template v-if="activeKey == '6'">
  41. <WarningTable v-if="deviceType !== 'managesys'" :deviceId="deviceData.id" :pointType="deviceData.strtype" />
  42. <ManagerWarningTable v-else :deviceId="deviceData.id" />
  43. </template>
  44. </a-tab-pane>
  45. <a-tab-pane key="7" tab="摄像头配置">
  46. <EditRowTable :columns="cameraColumns" :list="cameraList" :params="{ deviceid: deviceData.id }"
  47. @saveOrUpdate="saveCameraData" @deleteById="deleteCameraById" :isAdd="true" />
  48. </a-tab-pane>
  49. <a-tab-pane key="9" :tab="'预案管理'">
  50. <AccidentPlanTable :deviceId="deviceData.id" />
  51. </a-tab-pane>
  52. <a-tab-pane v-if="deviceType == 'led'" key="10" :tab="'节目管理'">
  53. <LEDPlaylistTable :deviceId="deviceData.id" />
  54. </a-tab-pane>
  55. <a-tab-pane key="13" v-if="deviceType == 'gate'" :tab="'故障配置管理'">
  56. <FaultConfigTable :deviceId="deviceData.id"></FaultConfigTable>
  57. </a-tab-pane>
  58. <!-- <a-tab-pane key="9" tab="预警指标修改">
  59. <template v-if="activeKey == '9'">
  60. <editWarnTable></editWarnTable>
  61. </template>
  62. </a-tab-pane> -->
  63. </a-tabs>
  64. <FormModal v-else :record="record" @saveOrUpdate="(values) => emit('saveOrUpdate', values)" />
  65. </BasicModal>
  66. </template>
  67. <script lang="ts" setup>
  68. import { computed, unref, inject, reactive, ref, watch } from 'vue';
  69. import { BasicModal, useModalInner } from '/@/components/Modal';
  70. import EditRowTable from '../../comment/EditRowTable.vue';
  71. import PointTable from './pointTabel/PointTable.vue';
  72. import WarningTable from './warningTabel/index.vue';
  73. import ManagerWarningTable from './warningTabel/index1.vue';
  74. import ManagerWarningDeviceTable from './warningTabel/index2.vue';
  75. import BackWindDeviceTable from './warningTabel/index3.vue';
  76. import AccidentPlanTable from './warningTabel/index4.vue';
  77. import LEDPlaylistTable from './warningTabel/index5.vue';
  78. import WorkFacePointTable from './pointTabel/WorkFacePointTable.vue';
  79. import WorkFaceReportTable from './pointTabel/WorkFaceReportTable.vue';
  80. import DeviceReportInfo from './DeviceReportInfo.vue';
  81. import FaultConfigTable from './faultConfigTable/index.vue'
  82. // import editWarnTable from './editWarnTable/index.vue'
  83. import FanLineModal from './FanLineModal .vue';
  84. import FormModal from './FormModal.vue';
  85. import { cloneDeep } from 'lodash-es';
  86. import { columns as pointColumns, workFaceColumns, simulationColumns, reportColumns } from './pointTabel/point.data';
  87. import { saveOrUpdate as pointSaveOrUpdate, deleteById as pointDeleteById } from './pointTabel/point.api';
  88. import { columns as cameraColumns } from './cameraTabel/camera.data';
  89. import { list as cameraList, saveOrUpdate as cameraSaveOrUpdate, deleteById as cameraDeleteById } from './cameraTabel/camera.api';
  90. const props = defineProps({
  91. showTab: { type: Boolean, required: true },
  92. // deviceType: { type: String },
  93. });
  94. // 声明Emits
  95. const emit = defineEmits(['saveOrUpdate', 'register', 'closeModal']);
  96. const isUpdate = inject('isUpdate');
  97. const deviceData = inject('formData') as any;
  98. const deviceType = inject('deviceType') as any;
  99. const record = reactive({});
  100. const activeKey = ref('1');
  101. const linkColumns = ref<any[]>([]);
  102. //表单赋值
  103. const [registerModal, { setModalProps, closeModal }] = useModalInner(async (data) => {
  104. //重置表单
  105. setModalProps({ confirmLoading: false });
  106. Object.assign(deviceData, data.record);
  107. // 判断是否是关键阻力路线
  108. });
  109. //设置标题
  110. const title = computed(() => {
  111. if (!unref(isUpdate)) {
  112. if (deviceData.strname || deviceData.systemname) {
  113. return `新增(${deviceData.strname || deviceData.systemname})`;
  114. }
  115. return `新增`;
  116. } else {
  117. if (deviceData['strtype'] == 'sys_majorpath') {
  118. linkColumns.value = [
  119. ...workFaceColumns,
  120. ...[
  121. {
  122. title: '是否在关键通风路线上',
  123. width: 100,
  124. dataIndex: 'pathflag',
  125. edit: true,
  126. editComponent: 'Switch',
  127. editValueMap: (value) => {
  128. return value ? '是' : '否';
  129. },
  130. },
  131. {
  132. title: '传感器类型',
  133. width: 100,
  134. dataIndex: 'sensorType',
  135. edit: true,
  136. editComponent: 'Select',
  137. editComponentProps: {
  138. options: [
  139. {
  140. label: '多参',
  141. value: '1',
  142. },
  143. {
  144. label: '测风',
  145. value: '2',
  146. },
  147. ],
  148. },
  149. },
  150. {
  151. title: '风向',
  152. width: 100,
  153. dataIndex: 'winddir',
  154. edit: true,
  155. editComponent: 'Select',
  156. editComponentProps: {
  157. options: [
  158. {
  159. label: '进风',
  160. value: '1',
  161. },
  162. {
  163. label: '用风',
  164. value: '2',
  165. },
  166. {
  167. label: '回风',
  168. value: '3',
  169. },
  170. ],
  171. },
  172. },
  173. {
  174. title: '是否总风量',
  175. width: 100,
  176. dataIndex: 'windflag',
  177. edit: true,
  178. editComponent: 'Switch',
  179. editValueMap: (value) => {
  180. return value ? '是' : '否';
  181. },
  182. },
  183. {
  184. title: '路线名称',
  185. width: 100,
  186. dataIndex: 'des',
  187. edit: true,
  188. editComponent: 'Input',
  189. },
  190. {
  191. title: ' 阻力值',
  192. width: 100,
  193. dataIndex: 'testDrag',
  194. edit: true,
  195. editComponent: 'InputNumber',
  196. },
  197. ],
  198. ];
  199. } else {
  200. linkColumns.value = [...workFaceColumns];
  201. }
  202. if (deviceData.strname || deviceData.systemname) {
  203. return `编辑(${deviceData.strname || deviceData.systemname})`;
  204. }
  205. return `编辑`;
  206. }
  207. });
  208. const closeModalFn = () => {
  209. activeKey.value = '1';
  210. closeModal();
  211. emit('closeModal');
  212. };
  213. const savePointData = (data) => {
  214. const record = cloneDeep(data.editValueRefs);
  215. pointSaveOrUpdate(Object.assign(record, { id: data.id, deviceId: deviceData.id }), data.id);
  216. };
  217. const saveCameraData = (data: any, reload: Function) => {
  218. cameraSaveOrUpdate(Object.assign({ ...data }, { id: data.id, deviceid: deviceData.id }), data.id);
  219. };
  220. const deletePointById = (id, reload) => {
  221. pointDeleteById({ id: id }, reload);
  222. };
  223. const deleteCameraById = (id, reload) => {
  224. cameraDeleteById({ id: id }, reload);
  225. };
  226. </script>
  227. <style scoped lang="less">
  228. ::v-deep .suffix {
  229. height: 32px;
  230. line-height: 32px;
  231. margin-left: 5px;
  232. color: #fff;
  233. }
  234. </style>