jsy-app/pages/work/operation-log/index.vue

155 lines
4.5 KiB
Vue
Raw Normal View History

2024-12-02 16:49:48 +08:00
<template>
2024-12-20 17:25:13 +08:00
<z-paging ref="paging" @query="queryList" v-model="dataList" :default-page-size="queryParams.pageSize"
:auto-show-system-loading="true" empty-view-text="抱歉,暂时还没有相关数据!">
<template #top>
<custom-nav-bar :left="true" title="操作日志"></custom-nav-bar>
2025-01-13 18:30:46 +08:00
<view class="search">
2025-01-16 12:41:23 +08:00
<u-search v-model="queryParams.searchValue" @search="queryList" shape="square"/>
2024-12-20 17:25:13 +08:00
</view>
</template>
2025-01-13 18:30:46 +08:00
<view class="card" v-for="item in dataList">
<uni-collapse>
<uni-collapse-item title-border="none" :border="false" :show-arrow="false" :open="true">
<template v-slot:title>
<view class="cards-title">
<view>
<view class="text">
<view>出水口{{ item.woName}}</view>
</view>
</view>
<view class="title-r">
<uni-tag v-hasPermi="['system:land:edit']" class="bg-green" :circle="true" text="发送成功" />
</view>
</view>
</template>
<view class="content">
<view class="cards-content">
<view class="txt-list" @click="openStepPop(item)">
<view class="left">
<view><text>设备名称</text><text>{{ item.operSubject}}</text></view>
<view><text>执行内容</text><text>{{ item.operContent}}</text></view>
<view><text>操作人员</text><text>{{ item.operUser}}</text></view>
<view><text>操作时间</text><text>{{ item.occurTime}}</text></view>
</view>
<view class="right">
<view class="iconfont icon-you">
</view>
</view>
</view>
</view>
2024-12-20 17:25:13 +08:00
</view>
2025-01-13 18:30:46 +08:00
</uni-collapse-item>
</uni-collapse>
</view>
<!--
<view style="display: flex; align-items: center; justify-content: space-between;">
2024-12-20 17:25:13 +08:00
<view style="margin-right: 5px;" v-hasPermi="['system:land:edit']">
2024-12-25 15:52:18 +08:00
<u-button type="primary" plain plainFill>
{{ item.operResult}}
</u-button>
2024-12-20 17:25:13 +08:00
</view>
</view>
2025-01-13 18:30:46 +08:00
-->
2024-12-20 17:25:13 +08:00
</z-paging>
2024-12-02 16:49:48 +08:00
2024-12-20 17:25:13 +08:00
<!-- 图层弹出 -->
2024-12-24 11:48:02 +08:00
<u-popup mode="center" :show="openPop" @close="openPop = false">
2025-01-06 17:44:48 +08:00
<view class="popup-content" style="width: 70vw;" :style="`height:${this.stepList.length * 45}px`">
2024-12-24 11:51:23 +08:00
<u-steps direction="column" :current="stepCurrent">
2024-12-24 11:48:02 +08:00
<u-steps-item v-for="item in this.stepList" :title="item.title" :desc="item.description"></u-steps-item>
2024-12-20 17:25:13 +08:00
</u-steps>
</view>
</u-popup>
</template>
2024-12-02 16:49:48 +08:00
<script>
2024-12-20 19:13:48 +08:00
import * as userlog from "@/api/iotlog/userlog.js"
2024-12-20 17:25:13 +08:00
export default {
data() {
return {
dataList: [],
queryParams: {
pageNum: 1,
pageSize: 20,
logType: 1, //1:设备,2:系统
landId: -1, //地块id
operType: "control", //控制
operSource: 1, //用户
searchValue: "", //出水口设备code
},
2024-12-24 11:48:02 +08:00
openPop: false,
2024-12-24 11:51:23 +08:00
stepCurrent: 0,
2024-12-24 11:48:02 +08:00
stepList: [],
2024-12-20 17:25:13 +08:00
}
},
2024-12-20 18:30:41 +08:00
onLoad(par) {
if (par.queryParams) {
let queryParams = JSON.parse(par.queryParams);
this.queryParams = Object.assign(this.queryParams, queryParams)
} else {
2025-01-06 12:15:57 +08:00
if (getApp().ijs.land) {
this.queryParams.landId = getApp().ijs.land.id;
2024-12-20 18:30:41 +08:00
}
2024-12-20 17:25:13 +08:00
}
},
onShow() {},
mounted() {},
methods: {
queryList(pageNo, pageSize) {
this.queryParams.pageNum = pageNo;
2024-12-20 19:13:48 +08:00
userlog.getlist(this.queryParams).then(res => {
2024-12-20 17:25:13 +08:00
this.$refs.paging.completeByTotal(res.rows, res.total);
});
},
2024-12-24 11:48:02 +08:00
async openStepPop(item) {
let stepList = userlog.getSeqlistTemp();
2024-12-24 11:51:23 +08:00
let stepCurrent = 0;
2024-12-24 11:48:02 +08:00
this.stepList = [];
userlog.getSeqlist({
2024-12-20 19:13:48 +08:00
traceId: item.traceId
2024-12-24 11:48:02 +08:00
}).then(response => {
if (response.rows.length) {
response.rows.forEach(item => {
2025-01-06 18:03:14 +08:00
if (item.eventType > stepCurrent) {
if (item.eventType == 9) {
stepList.splice(stepCurrent, 0, {
title: '中断',
description: item.occurTime,
status: 'success'
});
} else {
2025-01-06 17:44:48 +08:00
stepCurrent = item.eventType;
stepList[stepCurrent - 1].description = item.occurTime;
stepList[stepCurrent - 1].status = 'success';
2025-01-06 18:03:14 +08:00
if (item.eventType == 5 && stepList[3].status == "") {
stepList[3].description = item.occurTime;
stepList[3].status = 'success';
}
2025-01-06 17:44:48 +08:00
}
2024-12-24 11:51:23 +08:00
}
2024-12-24 11:48:02 +08:00
});
}
this.stepList = stepList;
2024-12-24 11:51:23 +08:00
this.stepCurrent = stepCurrent;
2024-12-24 11:48:02 +08:00
this.openPop = true;
2024-12-20 19:13:48 +08:00
});
2024-12-20 17:25:13 +08:00
},
// 数据排序
compareDataNew(file1) {
return function(b, a) {
if (b[file1] < a[file1]) {
return -1;
} else if (b[file1] > a[file1]) {
return 1;
}
}
},
}
}
2024-12-02 16:49:48 +08:00
</script>
2025-01-13 18:30:46 +08:00
<style lang="scss" scoped>
.popup-content{padding: 10px;}
.u-search{padding: 10px;}
2024-12-02 16:49:48 +08:00
</style>