|
|
@@ -54,269 +54,264 @@
|
|
|
</template>
|
|
|
|
|
|
<script setup lang="ts">
|
|
|
- import { ref, onMounted } from 'vue';
|
|
|
- import { BasicTable, useTable } from '/@/components/Table';
|
|
|
- import { Tabs, TabPane } from 'ant-design-vue';
|
|
|
- import MiniBoard from '/@/components/Configurable/detail/MiniBoard.vue';
|
|
|
- import { SvgIcon } from '/@/components/Icon';
|
|
|
- // 引入模拟数据
|
|
|
- import { boardData, columns, searchFormSchema, minesData, historicalMinesData } from './overlimitAlarm.data';
|
|
|
- import { getMineData, getProvinceAlarm, getGoafData, getProvinceAlarmHistory, getProvinceAlarmNum } from './overlimit.api';
|
|
|
+import { ref, onMounted } from 'vue';
|
|
|
+import { BasicTable, useTable } from '/@/components/Table';
|
|
|
+import { Tabs, TabPane } from 'ant-design-vue';
|
|
|
+import MiniBoard from '/@/components/Configurable/detail/MiniBoard.vue';
|
|
|
+import { SvgIcon } from '/@/components/Icon';
|
|
|
+// 引入模拟数据
|
|
|
+import { boardData, columns, searchFormSchema, minesData, historicalMinesData } from './overlimitAlarm.data';
|
|
|
+import { getMineData, getProvinceAlarm, getGoafData, getProvinceAlarmHistory, getProvinceAlarmNum } from './overlimit.api';
|
|
|
|
|
|
- // 激活的Tab页签
|
|
|
- const activeTab = ref('realtime');
|
|
|
- const visibleModal = ref(false);
|
|
|
- //煤矿列表数据
|
|
|
- const deviceOptions = ref([]);
|
|
|
- const goafOptions = ref([]);
|
|
|
- const mineCode = ref('');
|
|
|
- const goafId = ref('');
|
|
|
- const boardData = ref([
|
|
|
- {
|
|
|
- label: '存在风险情况数量',
|
|
|
- value: '',
|
|
|
- },
|
|
|
- {
|
|
|
- label: '低风险',
|
|
|
- value: '',
|
|
|
- },
|
|
|
- {
|
|
|
- label: '一般风险',
|
|
|
- value: '',
|
|
|
- },
|
|
|
- {
|
|
|
- label: '较高风险',
|
|
|
- value: '',
|
|
|
- },
|
|
|
- {
|
|
|
- label: '高风险',
|
|
|
- value: '',
|
|
|
- },
|
|
|
- ]);
|
|
|
- const minesData = ref([]);
|
|
|
- // 注册实时数据表格
|
|
|
- const [registerTable] = useTable({
|
|
|
- dataSource: minesData,
|
|
|
- columns,
|
|
|
- api: getProvinceAlarm,
|
|
|
- formConfig: {
|
|
|
- labelWidth: 120,
|
|
|
- schemas: [
|
|
|
- {
|
|
|
- label: '煤矿名称',
|
|
|
- field: 'mineCode', // 对应组件的value.mineCode(最终传给Table的查询参数)
|
|
|
- component: 'MineCascader', // 自定义组件名
|
|
|
- colProps: { span: 6 },
|
|
|
- rules: [],
|
|
|
- },
|
|
|
- ],
|
|
|
- showAdvancedButton: false,
|
|
|
- schemaGroupNames: ['常规查询'],
|
|
|
- },
|
|
|
- pagination: true,
|
|
|
- striped: true,
|
|
|
- useSearchForm: true,
|
|
|
- bordered: true,
|
|
|
- showIndexColumn: false,
|
|
|
- actionColumn: {
|
|
|
- width: 120,
|
|
|
- title: '详情',
|
|
|
- dataIndex: 'action',
|
|
|
- slots: { customRender: 'action' },
|
|
|
- fixed: undefined,
|
|
|
- },
|
|
|
- });
|
|
|
+// 激活的Tab页签
|
|
|
+const activeTab = ref('realtime');
|
|
|
+const visibleModal = ref(false);
|
|
|
+//煤矿列表数据
|
|
|
+const deviceOptions = ref([]);
|
|
|
+const goafOptions = ref([]);
|
|
|
+const mineCode = ref('');
|
|
|
+const goafId = ref('');
|
|
|
+const boardData = ref([
|
|
|
+ {
|
|
|
+ label: '存在风险情况数量',
|
|
|
+ value: '',
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '低风险',
|
|
|
+ value: '',
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '一般风险',
|
|
|
+ value: '',
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '较高风险',
|
|
|
+ value: '',
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '高风险',
|
|
|
+ value: '',
|
|
|
+ },
|
|
|
+]);
|
|
|
+const minesData = ref([]);
|
|
|
+// 注册实时数据表格
|
|
|
+const [registerTable] = useTable({
|
|
|
+ dataSource: minesData,
|
|
|
+ columns,
|
|
|
+ api: getProvinceAlarm,
|
|
|
+ formConfig: {
|
|
|
+ labelWidth: 120,
|
|
|
+ schemas: [
|
|
|
+ {
|
|
|
+ label: '煤矿名称',
|
|
|
+ field: 'mineCode', // 对应组件的value.mineCode(最终传给Table的查询参数)
|
|
|
+ component: 'MineCascader', // 自定义组件名
|
|
|
+ colProps: { span: 6 },
|
|
|
+ rules: [],
|
|
|
+ },
|
|
|
+ ],
|
|
|
+ showAdvancedButton: false,
|
|
|
+ schemaGroupNames: ['常规查询'],
|
|
|
+ },
|
|
|
+ pagination: true,
|
|
|
+ striped: true,
|
|
|
+ useSearchForm: true,
|
|
|
+ bordered: true,
|
|
|
+ showIndexColumn: false,
|
|
|
+ actionColumn: {
|
|
|
+ width: 120,
|
|
|
+ title: '详情',
|
|
|
+ dataIndex: 'action',
|
|
|
+ slots: { customRender: 'action' },
|
|
|
+ fixed: undefined,
|
|
|
+ },
|
|
|
+});
|
|
|
|
|
|
- // 注册历史数据表格
|
|
|
- const [registerHistoryTable] = useTable({
|
|
|
- dataSource: historicalMinesData,
|
|
|
- columns,
|
|
|
- api: getProvinceAlarmHistory,
|
|
|
- formConfig: {
|
|
|
- labelWidth: 120,
|
|
|
- schemas: [
|
|
|
- {
|
|
|
- label: '开始时间',
|
|
|
- field: 'startTime',
|
|
|
- component: 'DatePicker',
|
|
|
- componentProps: {
|
|
|
- showTime: true,
|
|
|
- // valueFormat: 'YYYY-MM-DD HH:mm:ss',
|
|
|
- placeholder: '请选择开始时间',
|
|
|
- },
|
|
|
- colProps: { span: 6 }, // 占比可根据布局调整
|
|
|
- rules: [{ required: true, message: '请选择开始时间' }],
|
|
|
+// 注册历史数据表格
|
|
|
+const [registerHistoryTable] = useTable({
|
|
|
+ dataSource: historicalMinesData,
|
|
|
+ columns,
|
|
|
+ api: getProvinceAlarmHistory,
|
|
|
+ formConfig: {
|
|
|
+ labelWidth: 120,
|
|
|
+ schemas: [
|
|
|
+ {
|
|
|
+ label: '开始时间',
|
|
|
+ field: 'startTime',
|
|
|
+ component: 'DatePicker',
|
|
|
+ componentProps: {
|
|
|
+ showTime: true,
|
|
|
+ // valueFormat: 'YYYY-MM-DD HH:mm:ss',
|
|
|
+ placeholder: '请选择开始时间',
|
|
|
},
|
|
|
- {
|
|
|
- label: '结束时间',
|
|
|
- field: 'endTime',
|
|
|
- component: 'DatePicker',
|
|
|
- componentProps: {
|
|
|
- showTime: true,
|
|
|
- // valueFormat: 'YYYY-MM-DD HH:mm:ss',
|
|
|
- placeholder: '请选择结束时间',
|
|
|
- },
|
|
|
- colProps: { span: 6 },
|
|
|
- rules: [{ required: true, message: '请选择结束时间' }],
|
|
|
+ colProps: { span: 6 }, // 占比可根据布局调整
|
|
|
+ rules: [{ required: true, message: '请选择开始时间' }],
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '结束时间',
|
|
|
+ field: 'endTime',
|
|
|
+ component: 'DatePicker',
|
|
|
+ componentProps: {
|
|
|
+ showTime: true,
|
|
|
+ // valueFormat: 'YYYY-MM-DD HH:mm:ss',
|
|
|
+ placeholder: '请选择结束时间',
|
|
|
},
|
|
|
- {
|
|
|
- label: '煤矿名称',
|
|
|
- field: 'mineCode', // 对应组件的value.mineCode(最终传给Table的查询参数)
|
|
|
- component: 'MineCascader', // 自定义组件名
|
|
|
- componentProps: {
|
|
|
- onChange: async (e, option) => {
|
|
|
- mineCode.value = e;
|
|
|
- await getGoafDataList(e);
|
|
|
- },
|
|
|
+ colProps: { span: 6 },
|
|
|
+ rules: [{ required: true, message: '请选择结束时间' }],
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '煤矿名称',
|
|
|
+ field: 'mineCode', // 对应组件的value.mineCode(最终传给Table的查询参数)
|
|
|
+ component: 'MineCascader', // 自定义组件名
|
|
|
+ componentProps: {
|
|
|
+ onChange: async (e, option) => {
|
|
|
+ mineCode.value = e;
|
|
|
+ await getGoafDataList(e);
|
|
|
},
|
|
|
- colProps: { span: 6 },
|
|
|
- rules: [],
|
|
|
},
|
|
|
- {
|
|
|
- label: '采空区查询',
|
|
|
- field: 'goafId',
|
|
|
- component: 'Select',
|
|
|
- defaultValue: goafOptions.value[0] ? goafOptions.value[0]['value'] : '',
|
|
|
- componentProps: {
|
|
|
- showSearch: true,
|
|
|
- filterOption: (input: string, option: any) => {
|
|
|
- return option.label.toLowerCase().indexOf(input.toLowerCase()) >= 0;
|
|
|
- },
|
|
|
- options: goafOptions,
|
|
|
- onChange: async (e, option) => {
|
|
|
- goafId.value = e;
|
|
|
- },
|
|
|
- },
|
|
|
- colProps: {
|
|
|
- span: 6,
|
|
|
+ colProps: { span: 6 },
|
|
|
+ rules: [],
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '采空区查询',
|
|
|
+ field: 'goafId',
|
|
|
+ component: 'Select',
|
|
|
+ componentProps: {
|
|
|
+ options: goafOptions,
|
|
|
+ onChange: async (e, option) => {
|
|
|
+ goafId.value = e;
|
|
|
},
|
|
|
},
|
|
|
- {
|
|
|
- field: 'alarmFiled',
|
|
|
- label: '预警字段',
|
|
|
- component: 'Select',
|
|
|
- componentProps: {
|
|
|
- options: [
|
|
|
- { label: '甲烷', value: 'ch4Val' },
|
|
|
- { label: '氧气', value: 'o2Val' },
|
|
|
- { label: '一氧化碳', value: 'coVal' },
|
|
|
- { label: '二氧化碳', value: 'co2Val' },
|
|
|
- { label: '乙烯', value: 'c2h4Val' },
|
|
|
- { label: '乙炔', value: 'c2h2Val' },
|
|
|
- { label: '压差', value: 'sourcePressure' },
|
|
|
- { label: '温度', value: 'temperature' },
|
|
|
- ],
|
|
|
- },
|
|
|
- colProps: { span: 6 },
|
|
|
+ colProps: {
|
|
|
+ span: 6,
|
|
|
},
|
|
|
- ],
|
|
|
- showAdvancedButton: false,
|
|
|
- schemaGroupNames: ['常规查询'],
|
|
|
- },
|
|
|
- pagination: true,
|
|
|
- striped: true,
|
|
|
- useSearchForm: true,
|
|
|
- bordered: true,
|
|
|
- showIndexColumn: false,
|
|
|
- actionColumn: {
|
|
|
- width: 60,
|
|
|
- title: '操作',
|
|
|
- dataIndex: 'action',
|
|
|
- slots: { customRender: 'action' },
|
|
|
- fixed: undefined,
|
|
|
- },
|
|
|
- });
|
|
|
+ },
|
|
|
+ {
|
|
|
+ field: 'alarmFiled',
|
|
|
+ label: '预警字段',
|
|
|
+ component: 'Select',
|
|
|
+ componentProps: {
|
|
|
+ options: [
|
|
|
+ { label: '甲烷', value: 'ch4Val' },
|
|
|
+ { label: '氧气', value: 'o2Val' },
|
|
|
+ { label: '一氧化碳', value: 'coVal' },
|
|
|
+ { label: '二氧化碳', value: 'co2Val' },
|
|
|
+ { label: '乙烯', value: 'c2h4Val' },
|
|
|
+ { label: '乙炔', value: 'c2h2Val' },
|
|
|
+ { label: '压差', value: 'sourcePressure' },
|
|
|
+ { label: '温度', value: 'temperature' },
|
|
|
+ ],
|
|
|
+ },
|
|
|
+ colProps: { span: 6 },
|
|
|
+ },
|
|
|
+ ],
|
|
|
+ showAdvancedButton: false,
|
|
|
+ schemaGroupNames: ['常规查询'],
|
|
|
+ },
|
|
|
+ pagination: true,
|
|
|
+ striped: true,
|
|
|
+ useSearchForm: true,
|
|
|
+ bordered: true,
|
|
|
+ showIndexColumn: false,
|
|
|
+ actionColumn: {
|
|
|
+ width: 60,
|
|
|
+ title: '操作',
|
|
|
+ dataIndex: 'action',
|
|
|
+ slots: { customRender: 'action' },
|
|
|
+ fixed: undefined,
|
|
|
+ },
|
|
|
+});
|
|
|
|
|
|
- // 弹窗引用
|
|
|
- const realtimeModalRef = ref(null);
|
|
|
- const historyModalRef = ref(null);
|
|
|
+// 弹窗引用
|
|
|
+const realtimeModalRef = ref(null);
|
|
|
+const historyModalRef = ref(null);
|
|
|
|
|
|
- // 打开弹窗方法(区分实时/历史)
|
|
|
- const openModal = (record, type) => {
|
|
|
- if (type === 'realtime') {
|
|
|
- // 可向实时弹窗传递当前记录数据
|
|
|
- realtimeModalRef.value?.showModal(record);
|
|
|
- } else if (type === 'detail') {
|
|
|
- visibleModal.value = true;
|
|
|
- } else {
|
|
|
- // 可向历史弹窗传递当前记录数据
|
|
|
- historyModalRef.value?.showModal(record);
|
|
|
- }
|
|
|
- };
|
|
|
- const handleOkEdit = () => {
|
|
|
- visibleModal.value = false;
|
|
|
- };
|
|
|
- const handleCancelEdit = () => {
|
|
|
- visibleModal.value = false;
|
|
|
- };
|
|
|
- async function fetchAlarmData(id) {
|
|
|
- const params = {
|
|
|
- alarmType: 'unsealAlarm',
|
|
|
- mineId: id,
|
|
|
- pageNo: 1,
|
|
|
- pageSize: 50,
|
|
|
- };
|
|
|
- const result = await getProvinceAlarm(params);
|
|
|
- minesData.value = result.records;
|
|
|
+// 打开弹窗方法(区分实时/历史)
|
|
|
+const openModal = (record, type) => {
|
|
|
+ if (type === 'realtime') {
|
|
|
+ // 可向实时弹窗传递当前记录数据
|
|
|
+ realtimeModalRef.value?.showModal(record);
|
|
|
+ } else if (type === 'detail') {
|
|
|
+ visibleModal.value = true;
|
|
|
+ } else {
|
|
|
+ // 可向历史弹窗传递当前记录数据
|
|
|
+ historyModalRef.value?.showModal(record);
|
|
|
}
|
|
|
- const getMineDataList = async () => {
|
|
|
- const params = {
|
|
|
- pageNo: 1,
|
|
|
- pageSize: 50,
|
|
|
- };
|
|
|
- const response = await getMineData(params);
|
|
|
- deviceOptions.value = response.records.map((item, index) => {
|
|
|
- return {
|
|
|
- label: item['mineName'],
|
|
|
- value: item['mineCode'],
|
|
|
- };
|
|
|
- });
|
|
|
+};
|
|
|
+const handleOkEdit = () => {
|
|
|
+ visibleModal.value = false;
|
|
|
+};
|
|
|
+const handleCancelEdit = () => {
|
|
|
+ visibleModal.value = false;
|
|
|
+};
|
|
|
+async function fetchAlarmData(id) {
|
|
|
+ const params = {
|
|
|
+ alarmType: 'unsealAlarm',
|
|
|
+ mineId: id,
|
|
|
+ pageNo: 1,
|
|
|
+ pageSize: 50,
|
|
|
};
|
|
|
- const getGoafDataList = async (mineId) => {
|
|
|
- const params = {
|
|
|
- mineCode: mineId,
|
|
|
+ const result = await getProvinceAlarm(params);
|
|
|
+ minesData.value = result.records;
|
|
|
+}
|
|
|
+const getMineDataList = async () => {
|
|
|
+ const params = {
|
|
|
+ pageNo: 1,
|
|
|
+ pageSize: 50,
|
|
|
+ };
|
|
|
+ const response = await getMineData(params);
|
|
|
+ deviceOptions.value = response.records.map((item, index) => {
|
|
|
+ return {
|
|
|
+ label: item['mineName'],
|
|
|
+ value: item['mineCode'],
|
|
|
};
|
|
|
- const response = await getGoafData(params);
|
|
|
- goafOptions.value = response.map((item, index) => {
|
|
|
- return {
|
|
|
- label: item['devicePos'],
|
|
|
- value: item['deviceCode'],
|
|
|
- };
|
|
|
- });
|
|
|
+ });
|
|
|
+};
|
|
|
+const getGoafDataList = async (mineId) => {
|
|
|
+ const params = {
|
|
|
+ mineCode: mineId,
|
|
|
};
|
|
|
- async function getAlarmTotalData() {
|
|
|
- const params = {
|
|
|
- alarmType: 'overLimitAlarm',
|
|
|
+ const response = await getGoafData(params);
|
|
|
+ goafOptions.value = response.map((item, index) => {
|
|
|
+ return {
|
|
|
+ label: item['devicePos'],
|
|
|
+ value: item['deviceCode'],
|
|
|
};
|
|
|
- const result = await getProvinceAlarmNum(params);
|
|
|
- boardData.value[1].value = result.alarmLevel1;
|
|
|
- boardData.value[2].value = result.alarmLevel2;
|
|
|
- boardData.value[3].value = result.alarmLevel3;
|
|
|
- boardData.value[4].value = result.alarmLevel4;
|
|
|
- boardData.value[0].value = result.alarmLevel1 + result.alarmLevel2 + result.alarmLevel3 + result.alarmLevel4;
|
|
|
- }
|
|
|
- onMounted(() => {
|
|
|
- // 页面挂载时的逻辑
|
|
|
- getMineDataList();
|
|
|
- getAlarmTotalData();
|
|
|
});
|
|
|
+};
|
|
|
+async function getAlarmTotalData() {
|
|
|
+ const params = {
|
|
|
+ alarmType: 'overLimitAlarm',
|
|
|
+ };
|
|
|
+ const result = await getProvinceAlarmNum(params);
|
|
|
+ boardData.value[1].value = result.alarmLevel1;
|
|
|
+ boardData.value[2].value = result.alarmLevel2;
|
|
|
+ boardData.value[3].value = result.alarmLevel3;
|
|
|
+ boardData.value[4].value = result.alarmLevel4;
|
|
|
+ boardData.value[0].value = result.alarmLevel1 + result.alarmLevel2 + result.alarmLevel3 + result.alarmLevel4;
|
|
|
+}
|
|
|
+onMounted(() => {
|
|
|
+ // 页面挂载时的逻辑
|
|
|
+ getMineDataList();
|
|
|
+ getAlarmTotalData();
|
|
|
+});
|
|
|
</script>
|
|
|
|
|
|
<style lang="less" scoped>
|
|
|
- .board-info {
|
|
|
- display: grid;
|
|
|
- grid-template-columns: repeat(5, auto); /* 3列:改5则为5列 */
|
|
|
- gap: auto;
|
|
|
- justify-content: start;
|
|
|
- flex-wrap: wrap;
|
|
|
- box-sizing: border-box;
|
|
|
- background-color: @white;
|
|
|
- padding: 10px;
|
|
|
- gap: 100px;
|
|
|
- // margin: 0 10px;
|
|
|
- margin-bottom: 5px;
|
|
|
- }
|
|
|
- .board-item {
|
|
|
- box-sizing: border-box;
|
|
|
- }
|
|
|
+.board-info {
|
|
|
+ display: grid;
|
|
|
+ grid-template-columns: repeat(5, auto); /* 3列:改5则为5列 */
|
|
|
+ gap: auto;
|
|
|
+ justify-content: start;
|
|
|
+ flex-wrap: wrap;
|
|
|
+ box-sizing: border-box;
|
|
|
+ background-color: @white;
|
|
|
+ padding: 10px;
|
|
|
+ gap: 100px;
|
|
|
+ // margin: 0 10px;
|
|
|
+ margin-bottom: 5px;
|
|
|
+}
|
|
|
+.board-item {
|
|
|
+ box-sizing: border-box;
|
|
|
+}
|
|
|
</style>
|