index.vue 6.83 KB
<template>
  <!-- 监控日志 -->
  <div class="jktjDetail from-clues">
    <!-- 头部搜索 -->
    <div class="from-clues-header">
      <el-form ref="form" :model="form" label-width="100px">
        <Breadcrumb />
        <el-row class="mb-5">
          <el-col :span="4">
            <el-form-item label="行政区" class="d-flex">
              <el-select
                v-model="
                  $store.state.user.userInfo.grade === 'county'
                    ? (form.qxdm = $store.state.user.userInfo.areaCode)
                    : form.qxdm
                "
                class="width100"
                clearable
                placeholder="行政区"
                :disabled="$store.state.user.userInfo.grade === 'county'"
              >
                <el-option
                  v-for="item in dicData['A20']"
                  :key="item.DCODE"
                  :label="item.DNAME"
                  :value="item.DCODE"
                >
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="4">
            <el-form-item label="开始日期" class="d-flex">
              <el-date-picker
                class="width100"
                :clearable="false"
                type="date"
                placeholder="开始日期"
                :picker-options="pickerOptionsStart"
                v-model="form.startDate"
                value-format="yyyy-MM-dd HH:mm:ss"
              ></el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="4">
            <el-form-item label="结束日期" class="d-flex">
              <el-date-picker
                class="width100"
                :clearable="false"
                type="date"
                placeholder="结束日期"
                :picker-options="pickerOptionsEnd"
                v-model="form.endDate"
                value-format="yyyy-MM-dd HH:mm:ss"
                @change="endTimeChange"
              ></el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="3">
            <el-form-item label="抵押总金额:" style="color: white;">
              <span>{{totalData.DYJE}}万元</span>
            </el-form-item>
          </el-col>
          <el-col :span="3">
            <el-form-item label="抵押总面积:"  style="color: white;">
              <span>{{totalData.DYMJ}}</span>
            </el-form-item>
          </el-col>
          <!-- 操作按钮 -->
          <el-col :span="6" class="btnColRight">
            <btn nativeType="cz" @click="resetForm">重置</btn>
            <btn nativeType="cx" @click="featchData">查询</btn>
          </el-col>
        </el-row>
      </el-form>
    </div>
    <!-- 图表 -->
    <div class="from-clues-content">
      <lb-table
        ref="table"
        :page-size="pageData.pageSize"
        :current-page.sync="pageData.current"
        :total="tableData.total"
        @size-change="handleSizeChange"
        @p-current-change="handleCurrentChange"
        :column="tableData.columns"
        :data="tableData.data"
      >
      </lb-table>
    </div>
  </div>
</template>
<script>
import { mapGetters } from "vuex";
import { getFirstDayOfSeason, timeFormat } from "@/utils/operation";
// 引入表格头部数据
import data from "./data";
// 引入table混入方法
import tableMixin from "@/mixins/tableMixin.js";
import bdcdj from "@/api/bdcdj";
import business from "@/api/business";
export default {
  name: "jktj",
  mixins: [tableMixin],
  data() {
    return {
      // 分页
      pageData: {
        total: 0,
        pageSize: 10,
        current: 1,
      },
      pickerOptionsStart: {
        disabledDate: (time) => {
          let endDateVal = this.form.endDate;
          if (endDateVal) {
            return time.getTime() >= new Date(endDateVal).getTime();
          }
        },
      },
      pickerOptionsEnd: {
        disabledDate: (time) => {
          let beginDateVal = this.form.startDate;
          if (beginDateVal) {
            return time.getTime() < new Date(beginDateVal).getTime();
          }
        },
      },
      // 搜索表单
      valueTime: "",
      tableData: {
        // 表格头部
        columns: [
          {
            label: "序号",
            type: "index",
            width: "50",
            index: this.indexMethod,
          },
        ].concat(data.columns()),
        // 表格列表数据
        total: 0,
        data: [],
      },
      // 搜索表单
      form: {
        startDate: getFirstDayOfSeason(),
        endDate: timeFormat(new Date(), true),
        qxdm: "",
        sfgd: "1",
      },
      chartData: [],
      totalData: { DYMJ: 0, DYJE: 0 },
    };
  },
  mounted() {
    // 查询业务量
    this.featchData();
  },
  computed: {
    ...mapGetters(["dicData"]),
  },
  methods: {
    /**
     * @description: handleSizeChange
     * @param {*} val
     * @author:
     */
    handleSizeChange(val) {
      this.formData.pageSize = val;
      this.featchData();
    },
    /**
     * @description: 截止日期变化
     * @param {*} val
     * @author: renchao
     */
    endTimeChange(val) {
      this.form.endDate = timeFormat(new Date(val), true);
    },
    /**
     * @description: handleSearch
     * @author:
     */
    handleSearch() {
      this.form.currentPage = 1;
      this.tableData.data = [];
      if (this.featchData) {
        this.featchData();
      }
    },
    /**
     * @description: handleCurrentChange
     * @param {*} val
     * @author:
     */
    handleCurrentChange(val) {
      this.form.currentPage = val;
      //this.featchData()
    },
    async featchData() {
      let { result: res } = await business.diya(this.form);
      res.list.forEach((it) => {
        if (it.DJSJ !== undefined && typeof it.DJSJ !== "") {
          it.DJSJ = it.DJSJ.slice(0, 19);
          it.DJSJ = it.DJSJ.replace("T", " ");
        }
        if (it.MJDW !== undefined && typeof it.MJDW === "string") {
          let mjdws = this.dicData["A7"].filter(
            (item) => item.DCODE === it.MJDW.trim()
          );
          it.MJDWMC = mjdws.length > 0 ? mjdws[0].DNAME : "";
        }
        if (it.JEDW !== undefined && typeof it.JEDW === "string") {
          let jedws = this.dicData["A57"].filter(
            (item) => item.DCODE === it.JEDW.trim()
          );
          it.JEDWMC = jedws.length > 0 ? jedws[0].DNAME : "";
        }
      });
      this.tableData.data = res.list;
      this.pageData.current = res.pageNum;
      this.pageData.pageSize = res.pageSize;
      this.tableData.total = res.total;

      let { result: dyTotal } = await business.getDyaqTotol(this.form);
      this.totalData = dyTotal[0];
    },
  },
};
</script>
<style scoped lang="scss">
.jktjDetail {
  flex-direction: column;

  .rows {
    margin-left: 100px;
  }

  .center {
    line-height: 50vh;
    text-align: center;
    color: #b6b5b5;
  }
}
</style>