index.vue 5.07 KB
<!-- 接入质量评价表 -->
<template>
  <div class="from-clues">
    <!-- 头部搜索 -->
    <div class="from-clues-header">
      <el-form ref="ruleForm" :model="form" label-width="100px">
        <el-form-item>
          <Breadcrumb />
        </el-form-item>
        <el-row class="mb-5">
          <el-col :span="6">
            <el-form-item label="接收日期" prop="startTime">
              <el-date-picker type="date" class="width100" placeholder="开始日期" :picker-options="pickerOptionsStart"
                clearable v-model="form.startTime" value-format="yyyy-MM-dd"></el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="至" prop="endTime" label-width="35px">
              <el-date-picker type="date" class="width100" placeholder="结束日期" :picker-options="pickerOptionsEnd" clearable
                v-model="form.endTime" value-format="yyyy-MM-dd" @change="endTimeChange"></el-date-picker>
            </el-form-item>
          </el-col>
          <!-- 按钮操作 -->
          <el-col :span="12" class="btnColRight">
            <el-form-item>
              <btn nativeType="cz" @click="handleResetForm">重置</btn>
              <btn nativeType="cx" @click="handleSearch">查询</btn>
              <download-excel class="export-excel-wrapper" :data="DetailsForm" :fields="json_fields" :header="title"
                name="需要导出的表格名字.xls">
                <btn nativeType="cx">导出</btn>
              </download-excel>
            </el-form-item>
          </el-col>
        </el-row>
      </el-form>
    </div>
    <!-- 列表区域 -->
    <div class="from-clues-content">
      <lb-table ref="table" :page-size="pageData.size" :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 data from "./data";
// 引入table混入方法
import tableMixin from "@/mixins/tableMixin.js";
//引入日期处理方法
import { timeFormat } from "@/utils/operation";
// 获取时间
import { getCurrentDate } from "@/utils/tools";
export default {
  name: "jsbwcx",
  mixins: [tableMixin],
  data () {
    return {
      pickerOptionsStart: {
        disabledDate: (time) => {
          let endDateVal = this.form.endTime;
          if (endDateVal) {
            return (
              time.getTime() >=
              new Date(endDateVal).getTime()
            );
          }
        },
      },
      pickerOptionsEnd: {
        disabledDate: (time) => {
          let beginDateVal = this.form.startTime;
          if (beginDateVal) {
            return (
              time.getTime() <
              new Date(beginDateVal).getTime()
            );
          }
        },
      },
      // 表格数据
      form: {
        startTime: "", // 开始日期
        endTime: "", // 结束日期
        currentPage: 1
      },
      // 校验规则
      rules: {
        startTime: [
          { required: true, message: "请选择开始日期", trigger: "change" },
        ],
        endTime: [
          { required: true, message: "请选择结束日期", trigger: "change" },
        ]
      },
      // 表格数据
      tableData: {
        // 表格头部
        columns: [
          {
            label: "序号",
            type: "index",
            width: "50",
            index: this.indexMethod,
          }
        ]
          .concat(data.columns()),
        data: [],
      },
      // 分页
      pageData: {
        total: 0,
        pageSize: 10,
        current: 1
      },
      // 表格导出
      title: "xx公司表格",
      json_fields: {
        "排查日期": 'date',
        "整改隐患内容": 'details',
        "整改措施": 'measure',
        "整改时限": 'timeLimit',
        "应急措施和预案": 'plan',
        "整改责任人": 'personInCharge',
        "填表人": 'preparer',
        "整改资金": 'fund',
        "整改完成情况": 'complete',
        "备注": 'remark',
      },
      DetailsForm: [
        {
          date: "2022-3-10",
          details: "卸油区过路灯损坏",
          measure: "更换灯泡",
          timeLimit: "2022-3-21",
          plan: "先使用充电灯代替,贴好安全提醒告示",
          personInCharge: "王xx",
          preparer: "王xx",
          fund: "20元",
          complete: "已完成整改",
          remark: "重新更换了灯泡",
        }
      ]
    }
  },
  created () {
    this.handleResetForm()
  },
  methods: {
    //截止日期变化
    endTimeChange (val) {
      this.form.endTime = timeFormat(new Date(val), true)
    },
    // 初始化数据
    featchData () { },
    // 重置
    handleResetForm () {
      this.form.startTime = getCurrentDate()
      this.form.endTime = getCurrentDate('time')
    }
  }
}
</script>
<style scoped lang="scss">
// 引入表单整体样式
@import "~@/styles/public.scss";
@import "../css/index.scss";
</style>