智慧园区前端大屏
linwe
2024-11-08 0778b2d3fcaaade08b07a5c0fc1897f537ddb75d
风险源
4 files modified
208 ■■■■■ changed files
src/views/layout/components/scomponents/layersControl.vue 6 ●●●● patch | view | raw | blame | history
src/views/rs/components/box/dataContent.vue 190 ●●●●● patch | view | raw | blame | history
src/views/rs/components/box/publicContent.vue 2 ●●● patch | view | raw | blame | history
src/views/rs/components/leftContainer.vue 10 ●●●● patch | view | raw | blame | history
src/views/layout/components/scomponents/layersControl.vue
@@ -376,9 +376,9 @@
}
onMounted(() => {
  handleCheckChange(data.filter(i => i.id == '1'), {
    checkedKeys: ['1']
  })
  // handleCheckChange(data.filter(i => i.id == '1'), {
  //   checkedKeys: ['1']
  // })
})
onUnmounted(() => {
src/views/rs/components/box/dataContent.vue
@@ -9,17 +9,199 @@
 * Copyright (c) 2023 by ${git_name_email}, All Rights Reserved. 
-->
<script setup>
import publicContent from './publicContent.vue'
import publicContent from "./publicContent.vue";
import { getList } from "@/api/riskSource/riskSource";
import { reactive } from "vue";
const loading = ref(false);
const tableData = ref([]);
const pages = {
    page: 1,
    pageSize: 10,
    total: 0,
};
let data = reactive({
    companyInfo: {}
})
onMounted(() => {
    data.companyInfo = JSON.parse(localStorage.getItem('companyInfo'))
    getLists();
});
// 表格样式
const tableCellStyle = ({ row, column }) => {
    return { background: "#152851", color: "#fff" };
};
// 表格表头样式
const headerCellStyle = ({ }) => {
    return {
        background: "#152851",
        color: "#fff",
    };
};
// 搜索条件
const riskSource = reactive({
    name: "",
    ownership: ''
});
// 提交查询
const onSubmit = () => {
    pages.page = 1
    pages.pageSize = 13
    pages.total = 0
    console.log("submit!");
    getLists(riskSource);
};
// 分页树改变
const handleSizeChange = (val) => {
    pages.pageSize = val;
    getLists(riskSource);
}
// 分页改变
const handleCurrentChange = (val) => {
    pages.page = val;
    getLists(riskSource);
}
// 重置条件
const clearBtn = () => {
    riskSource.name = ''
    riskSource.ownership = ''
    pages.page = 1
    pages.pageSize = 13
    pages.total = 0
    getLists(riskSource);
}
// 查询分页数据
function getLists(param = {}) {
    param.current = pages.page;
    param.size = pages.pageSize;
    loading.value = true;
    getList(param)
        .then((res) => {
            const data = res.data.data;
            // data.records.forEach((element) => {
            //     if (element.ownership == 1) {
            //         element.ownership = "园区";
            //     } else {
            //         element.ownership = "企业";
            //     }
            // });
            tableData.value = data.records;
            pages.total = data.total;
            loading.value = false;
        })
        .catch((err) => {
            loading.value = false;
            console.log(err);
        });
}
</script>
<template>
    <public-content>
        <template #content>
            <div>
            <div class="search-box">
                <div class="search-form">
                    <el-form :inline="true" :model="riskSource" class="demo-form-inline">
                        <el-form-item label="" class="form-item-input">
                            <el-input v-model="riskSource.name" placeholder="请输入风险源" clearable style="width: 120px" />
                        </el-form-item>
                        <el-form-item class="transparent-select" label="">
                            <el-select v-model="riskSource.riskLevel" placeholder="请选择等级" clearable style="width: 120px">
                                <el-option label="一般" value="1" />
                                <el-option label="较大" value="2" />
                            </el-select>
                        </el-form-item>
                        <el-form-item class="search-btn">
                            <el-button type="primary" @click="onSubmit">查询</el-button>
                            <el-button type="primary" @click="clearBtn">重置</el-button>
                        </el-form-item>
                    </el-form>
                    <el-table :data="tableData" style="width: 100%" :header-cell-style="headerCellStyle"
                        :cell-style="tableCellStyle" v-loading="loading"
                        element-loading-background="rgba(122, 122, 122, 0.1)">
                        <el-table-column prop="firmName" label="单位名称" />
                        <el-table-column prop="riskLevelName" label="等级" width="100" />
                        <el-table-column show-overflow-tooltip fixed prop="name" label="风险源" />
                    </el-table>
                </div>
                <div class="el-page">
                    <el-pagination background layout="prev, pager, next" :page-size="pages.pageSize" :total="pages.total"
                        @size-change="handleSizeChange" @current-change="handleCurrentChange" />
                </div>
            </div>
        </template>
    </public-content>
</template>
<style lang="scss" scoped></style>
<style lang="scss" scoped>
.el-form-item__label {
    color: #fff !important;
}
.search-box {
    ::v-deep .el-table__body-wrapper {
        background-color: #152851;
    }
}
.search-form {}
/* 当表格没有数据时,修改表格的背景颜色 */
.el-table--empty .el-table__body {
    background-color: rgba(135, 158, 199, 0.3) !important;
    /* 你想要的背景颜色 */
}
.el-page {
    margin-top: 10px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 999;
}
.form-item-input {
    width: 160px;
    ::v-deep(.el-input) {
        width: 0;
        flex: 1;
        .el-input__wrapper {
            font-size: 16px;
            font-weight: 400;
            border-radius: 0;
            background: rgba(135, 158, 199, 0.3);
            box-shadow: inset 0px 3px 7px 0px rgba(42, 138, 236, 0.95);
            .el-input__inner {
                color: #BFD3E5;
            }
        }
    }
}
.search-btn {
    ::v-deep .el-button--primary {
        background-color: transparent;
        border-color: none;
        border: none;
        cursor: pointer;
        color: #edffff;
        background: rgba(135, 158, 199, 0.3);
        box-shadow: inset 0px 3px 7px 0px rgba(42, 138, 236, 0.95);
    }
}
</style>
src/views/rs/components/box/publicContent.vue
@@ -14,7 +14,7 @@
<template>
  <div class="content">
    <slot></slot>
    <slot name="content"></slot>
  </div>
</template>
src/views/rs/components/leftContainer.vue
@@ -19,7 +19,7 @@
    <div class="data box">
      <title-box>
        <template #titleName>
          数据概览
          风险源列表
        </template>
      </title-box>
      <div class="content-box">
@@ -27,7 +27,7 @@
      </div>
    </div>
    <div class="unit box">
    <!-- <div class="unit box">
      <title-box>
        <template #titleName>
          入住单位统计
@@ -36,9 +36,9 @@
      <div class="content-box">
        <unit-content></unit-content>
      </div>
    </div>
    </div> -->
    <div class="fire box">
    <!-- <div class="fire box">
      <title-box>
        <template #titleName>
          实时火警事件
@@ -47,7 +47,7 @@
      <div class="content-box">
        <fire-content></fire-content>
      </div>
    </div>
    </div> -->
  </div>
</template>