智慧园区前端大屏
zrj
2024-11-01 a16a77ae24b40fe8a333e6284f6a39b48cf71d11
新增救援队伍列表展示
4 files modified
1 files added
195 ■■■■■ changed files
src/api/rescueTeam/rescueTeam.js 22 ●●●●● patch | view | raw | blame | history
src/views/rt/components/box/dataContent.vue 163 ●●●●● patch | view | raw | blame | history
src/views/rt/components/box/publicContent.vue 2 ●●● patch | view | raw | blame | history
src/views/rt/components/leftContainer.vue 6 ●●●● patch | view | raw | blame | history
src/views/rt/index.vue 2 ●●● patch | view | raw | blame | history
src/api/rescueTeam/rescueTeam.js
New file
@@ -0,0 +1,22 @@
import request from 'utils/http'
export const getDetail = (params) => {
    const url = `/yw/rescueTeam/getDetail`;
    return request({
        url,
        method: 'get',
        params,
    });
};
export const getList = (params) => {
    const url = `/yw/rescueTeam/page`;
    return request({
        url,
        method: 'get',
        params,
    });
};
src/views/rt/components/box/dataContent.vue
@@ -9,17 +9,162 @@
 * 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/rescueTeam/rescueTeam";
import { reactive } from "vue";
const loading = ref(false);
const tableData = ref([]);
const pages = {
  page: 1,
  pageSize: 13,
  total: 0,
};
onMounted(() => {
  getLists();
});
// 表格样式
const tableCellStyle = ({ row, column }) => {
  return { background: "#152851", color: "#fff" };
};
// 表格表头样式
const headerCellStyle = ({}) => {
  return {
    background: "#152851",
    color: "#fff",
  };
};
// 搜索条件
const formInline = reactive({
  perInCha: "",
  type:''
});
// 提交查询
const onSubmit = () => {
  console.log("submit!");
  getLists(formInline);
};
// 分页树改变
const handleSizeChange = (val) => {
  pages.pageSize = val;
  getLists(formInline);
}
// 分页改变
const handleCurrentChange = (val) => {
  pages.page = val;
  getLists(formInline);
}
// 重置条件
const clearBtn = ()=>{
  formInline.perInCha = ''
  formInline.type = ''
  pages.page = 1
  pages.pageSize=13
  pages.total= 0
  getLists(formInline);
}
// 查询分页数据
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.firmId) {
          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>
        </template>
    </public-content>
  <public-content>
    <template #content>
      <div>
        <el-form :inline="true" :model="formInline" class="demo-form-inline">
          <el-form-item label="姓名">
            <el-input
              v-model="formInline.perInCha"
              placeholder="请输入姓名"
              clearable
              style="width: 120px"
            />
          </el-form-item>
          <el-form-item label="归属">
            <el-select
              v-model="formInline.type"
              placeholder="请选择"
              clearable
              style="width: 120px"
            >
              <el-option label="园区" value="1" />
              <el-option label="企业" value="2" />
            </el-select>
          </el-form-item>
          <el-form-item>
            <el-button type="primary" @click="onSubmit">查询</el-button>
            <el-button type="" @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"
        >
          <el-table-column fixed prop="perInCha" label="责任人姓名" />
          <el-table-column prop="perInChaPho" label="联系电话" />
          <!-- <el-table-column prop="firmName" label="单位名称" /> -->
          <el-table-column prop="ownership" label="归属" width="100" />
        </el-table>
        <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;
}
/* 当表格没有数据时,修改表格的背景颜色 */
.el-table--empty .el-table__body {
  background-color: #19284e !important; /* 你想要的背景颜色 */
}
.el-page {
  margin-top: 10px;
  width: 100%;
  display: flex;
  align-items: center;
  // margin-bottom:10px;
}
</style>
src/views/rt/components/box/publicContent.vue
@@ -14,7 +14,7 @@
<template>
  <div class="content">
    <slot></slot>
    <slot name="content"></slot>
  </div>
</template>
src/views/rt/components/leftContainer.vue
@@ -19,13 +19,13 @@
    <div class="data box">
      <title-box>
        <template #titleName>
          数据概览2
          救援队伍信息
        </template>
      </title-box>
      <data-content></data-content>
    </div>
    <div class="unit box">
    <!-- <div class="unit box">
      <title-box>
        <template #titleName>
          入住单位统计
@@ -41,7 +41,7 @@
        </template>
      </title-box>
      <fire-content></fire-content>
    </div>
    </div> -->
  </div>
</template>
src/views/rt/index.vue
@@ -17,7 +17,7 @@
    <div class="container page-container">
        <left-container></left-container>
        <right-container></right-container>
        <!-- <right-container></right-container> -->
    </div>
</template>