zhanghua
2023-12-04 e6443cf405d4e950abe35a29e6c133d097fc1ad5
src/views/intelligentPatrol/statistics/unlawful/point/index.vue
@@ -13,6 +13,7 @@
            start-placeholder="开始日期"
            end-placeholder="结束日期"
            :picker-options="pickerOptions"
            value-format="yyyy-MM-dd HH:mm:ss"
          >
          </el-date-picker>
        </div>
@@ -40,8 +41,11 @@
      <div class="main-content">
        <!-- 数据展示 -->
        <el-table
          border
          stripe
          ref="multipleTable"
          :header-cell-style="{
            background: '#F5F5F5',
            'font-weight': '650',
            'line-height': '45px',
          }"
@@ -53,6 +57,10 @@
          <el-table-column prop="name" label="点位名称" min-width="10">
          </el-table-column>
          <el-table-column prop="count" label="事件总数" min-width="5">
            <template slot-scope="scope">
              <el-button type="text" @click="seachTotalEvents(scope.row.id)">{{scope.row.count}}</el-button>
            </template>
          </el-table-column>
          <el-table-column prop="ratio" label="占比" min-width="5">
          </el-table-column>
@@ -92,16 +100,137 @@
          </el-pagination>
        </div>
      </div>
      <el-dialog
          title="事件总数"
          :visible.sync="dialogVisibleEvent"
          width="80%"
          :before-close="handClose">
        <el-table
            border
            stripe
            ref="multipleTable"
            :header-cell-style="{
                        background: '#F5F5F5',
                        'font-weight': '650',
                        'line-height': '45px'
                    }"
            :data="gridData"
            style="width: 100%"
            :row-class-name="tableRowClassName"
        >
          <el-table-column
              prop="code"
              label="事件编号"
              min-width="18"
          >
          </el-table-column>
          <el-table-column
              prop="eventSource"
              label="问题来源"
              min-width="8"
          >
            <template slot-scope="scope">
                            <span>{{
                                scope.row.eventSource === 2
                                    ? '网格巡查'
                                    : '视频巡查'
                              }}</span>
            </template>
          </el-table-column>
          <el-table-column
              :prop="mystatus === 1 ? 'category' : 'category'"
              :label="mystatus === 1 ? '大类名称' : '违建类别'"
              :min-width="mystatus === 1 ? '10' : '15'"
          >
          </el-table-column>
          <el-table-column
              :prop="mystatus === 1 ? 'type' : 'site'"
              :label="mystatus === 1 ? '小类名称' : '违建地点'"
              min-width="10"
          >
          </el-table-column>
          <el-table-column
              :prop="mystatus === 1 ? 'site' : ''"
              :label="
                            mystatus === 1 ? '报警点位' : '违法建筑长、宽、高'
                        "
              :min-width="mystatus === 1 ? '10' : '20'"
              show-overflow-tooltip
          >
            <template slot-scope="scope">
              <div v-if="mystatus === 2">
                                <span>{{
                                    scope.row.buildingLength +
                                    '米' +
                                    '、' +
                                    scope.row.buildingWidth +
                                    '米' +
                                    '、' +
                                    scope.row.buildingHigh +
                                    '米'
                                  }}</span>
              </div>
              <div v-else>{{ scope.row.site }}</div>
            </template>
          </el-table-column>
          <el-table-column
              :prop="mystatus === 1 ? 'street' : 'buildingArea'"
              :label="mystatus === 1 ? '所属区域' : '违法建筑面积'"
              min-width="12"
          >
          </el-table-column>
          <el-table-column
              prop="alarmTime"
              label="报警时间"
              min-width="15"
              v-if="mystatus === 1"
          >
            <template slot-scope="scope">
              <span>{{ filterTime(scope.row.alarmTime) }}</span>
            </template>
          </el-table-column>
          <el-table-column
              :prop="mystatus === 1 ? 'continueTime' : 'materials'"
              :label="mystatus === 1 ? '持续时间' : '违法建筑材料'"
              min-width="12"
          >
          </el-table-column>
        </el-table>
        <div >
          <el-pagination
              background
              :current-page="currentPages"
              layout="prev, pager, next"
              :total="totalNums"
              :page-size="pageSizes"
              @current-change="changeCurrentPages"
          >
          </el-pagination>
        </div>
      </el-dialog>
    </main>
  </div>
</template>
  <script>
import { createNamespacedHelpers } from "vuex";
import helper from "@/utils/mydate";
import basecase from "@/api/operate/basecase";
const { mapActions } = createNamespacedHelpers("statistics");
export default {
  data() {
    return {
      seachID:'',
      dialogVisibleEvent:false,
      mystatus:1,
      totalNums:1,
      pageSizes:10,
      currentPages:1,
      gridData:[],
      pickerOptions: {
        shortcuts: [
          {
@@ -146,37 +275,75 @@
  },
  methods: {
    ...mapActions(["searchByPoint"]),
    changeCurrentPages(page){
      this.currentPages = page;
      this.seachTotalEvents(this.seachID)
    },
    handClose(){
      this.dialogVisibleEvent=false
    },
// 处理时间
    filterTime(time) {
      return helper(time);
    },
    seachTotalEvents(id){
      this.seachID=id
      this.dialogVisibleEvent = true
      console.log(this.value2)
      let params ={
        type:1,
        videoId:id,
        current: this.currentPages,
        size: this.pageSizes,
      }
      params.startTime = this.value2[0]||''
      params.endTime = this.value2[1]||''
      basecase.baseCasePoolList(params).then(res=>{
        console.log(res)
        this.gridData =res.records
        this.pageSizes =res.size
        this.currentPages =res.current
        this.totalNums = res.total
      })
    },
    handleExport(e) {
      this.$axios({
        method: 'post',
        url: `sccg/intelligentPatrol/statistics/export/unlawful`,
        responseType: 'arraybuffer'
      })
        .then(res => {
          let time = new Date()
            let deathdate =time.toLocaleDateString()
            const blob = new Blob([res.data], {
              type: "application/vnd.ms-excel;charset=utf-8",
            });
            debugger
            if (window.navigator.msSaveBlob) {
              window.navigator.msSaveBlob(blob, deathdate+"按点位统计" + ".xlsx");
            } else {
              const url = window.URL.createObjectURL(blob);
              const link = document.createElement("a");
              link.style.display = "none";
              link.href = url;
              link.download = deathdate+"按点位统计" + ".xlsx";
              document.body.appendChild(link);
              link.click();
              document.body.removeChild(link);
            }
            this.$message.success('操作成功');
        })
        method: "post",
        // url: `sccg/intelligentPatrol/statistics/export/unlawful`,
        url: `sccg/intelligentPatrol/statistics/export/unlawful/site`,
        responseType: "arraybuffer",
        data: {
          beginTime: this.value2[0],
          endTime: this.value2[1],
        },
      }).then((res) => {
        let time = new Date();
        let deathdate = time.toLocaleDateString();
        const blob = new Blob([res.data], {
          type: "application/vnd.ms-excel;charset=utf-8",
        });
        if (window.navigator.msSaveBlob) {
          window.navigator.msSaveBlob(blob, deathdate + "按点位统计" + ".xlsx");
        } else {
          const url = window.URL.createObjectURL(blob);
          const link = document.createElement("a");
          link.style.display = "none";
          link.href = url;
          link.download = deathdate + "按点位统计" + ".xlsx";
          document.body.appendChild(link);
          link.click();
          document.body.removeChild(link);
        }
        this.$message.success("操作成功");
      });
    },
    setTableDataHandle(e) {},
    resetTableData(e) {},
    setTableDataHandle(e) {
      this.setTableData();
    },
    resetTableData(e) {
      this.value2 = "";
      this.setTableData();
    },
    // 设置表格斑马纹
    tableRowClassName({ row, rowIndex }) {
      if ((rowIndex + 1) % 2 == 0) {
@@ -192,11 +359,11 @@
      this.searchByPoint({
        currentPage,
        pageSize,
        beginTime:'2022-05-01 00:00:00',
        endTime:'2022-09-01 00:00:00'
        beginTime: this.value2[0],
        endTime: this.value2[1],
      }).then((res) => {
          this.list = res.records;
          this.totalNum = res.total;
        this.list = res.records;
        this.totalNum = res.total;
      });
    },
    // 当前页改变触发事件
@@ -220,15 +387,15 @@
  <style lang="scss" scoped>
.list {
  text-align: left;
  margin: 10px 20px;
  padding: 10px 20px;
  color: #4b9bb7;
  border: 1px solid #ccc;
  header {
    background-color: white;
    border: 1pox solid #fff;
    .header-content {
      padding: 0 40px;
      //padding: 0 40px;
      display: flex;
      line-height: 100px;
      justify-content: space-between;
@@ -346,11 +513,11 @@
      }
    }
    // &::v-deep .warning-row {
      // background-color: #06122c;
    // background-color: #06122c;
    // }
    // &::v-deep .success-row {
      // background-color: #071f39;
    // background-color: #071f39;
    // }
    .operationBox {
@@ -365,7 +532,7 @@
      // font-size: 10px;
      .operation {
        display: flex;
        color: var(--operation-color);
        .line {
          padding: 0 5px;
        }
@@ -377,4 +544,4 @@
    }
  }
}
</style>
</style>