index.vue 7.54 KB
<template>
  <!-- 接收报文查询 -->
  <div class="reportLog from-clues">
    <!-- 头部搜索 -->
    <div class="from-clues-header">
      <el-form ref="ruleForm" :model="form" label-width="100px">
        <el-row class="marginbtm5">
          <el-col :span="6">
            <el-form-item label="行政区" prop="pcode">
              <el-select v-model="form.pcode" class="width100" clearable placeholder="行政区">
                <el-option v-for="item in xzqOptions" :key="item.value" :label="item.label" :value="item.value">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <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">
              <el-date-picker type="date" class="width100" placeholder="结束日期" :picker-options="pickerOptionsEnd"
                clearable v-model="form.endTime" value-format="yyyy-MM-dd"></el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="不动产单元号" prop="bdcdyh">
              <el-input v-model="form.bdcdyh" class="width100" placeholder="不动产单元号"></el-input>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row class="mt-10">
          <el-col :span="6">
            <el-form-item label="业务名称" prop="ywmc">
              <el-select v-model="form.ywmc" class="width100" clearable placeholder="业务名称">
                <el-option v-for="item in statusOptions" :key="item.value" :label="item.label" :value="item.value">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="检查结果" prop="jcjg">
              <el-select v-model="form.jcjg" class="width100" clearable placeholder="检查结果">
                <el-option v-for="item in []" :key="item.value" :label="item.label" :value="item.value">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="入库结果" prop="rkjg">
              <el-select v-model="form.rkjg" class="width100" clearable placeholder="入库结果">
                <el-option v-for="item in []" :key="item.value" :label="item.label" :value="item.value">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <!-- 按钮操作 -->
          <el-col :span="6" class="btnColRight">
            <el-form-item>
              <btn nativeType="cz" @click="resetForm('ruleForm')">重置</btn>
              <btn nativeType="cx" click="handleSubmit">查询</btn>
              <btn nativeType="sb">入库</btn>
            </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 { getDataReportPage } from "@/api/sbbwcx.js";
export default {
  name: "jsbwcx",
  mixins: [tableMixin],
  data() {
    return {
      // 开始结束日期限制
      pickerOptionsStart: {
        disabledDate: (time) => {
          if (this.form.endTime) {
            return time.getTime() >= new Date(this.form.endTime).getTime();
          }
        },
      },
      // 结束日期限制
      pickerOptionsEnd: {
        disabledDate: (time) => {
          if (this.form.startTime) {
            return time.getTime() <= new Date(this.form.startTime).getTime();
          }
        },
      },
      // 表格数据
      form: {
        pcode: "", // 行政区
        startTime: "", // 开始日期
        endTime: "", // 结束日期
        bdcdyh: "", // 不动产单元号
        ywmc: "", // 业务名称
        jcjg: "", // 检查结果
        rkjg: "", //入库结果
        currentPage: 1,
      },
      // 校验规则
      rules: {
        pcode: [{ required: true, message: "请选择行政区", trigger: "change" }],
        startTime: [
          { required: true, message: "请选择开始日期", trigger: "change" },
        ],
        endTime: [
          { required: true, message: "请选择结束日期", trigger: "change" },
        ],
        bdcdyh: [
          { required: true, message: "不动产单元号", trigger: "change" },
        ],
        ywmc: [{ required: true, message: "业务名称", trigger: "change" }],
        jcjg: [{ required: true, message: "检查结果", trigger: "change" }],
        rkjg: [{ required: true, message: "入库结果", trigger: "change" }],
      },
      // 表格数据
      tableData: {
        // 表格头部
        columns: [
          {
            label: "序号",
            type: "index",
            width: "50",
            index: this.indexMethod,
          },          
        ]
          .concat(data.columns())
          .concat([
            {
              label: "操作",
              width: "160",
              render: (h, scope) => {
                return (
                  <div>
                    <el-button
                      type="primary"
                      onClick={() => {
                        this.handleEdit(scope.row);
                      }}
                    >
                      详情
                    </el-button>
                    <el-button type="primary">结果</el-button>
                  </div>
                );
              },
            },
          ]),
        // 表格列表数据
         total: 0,
        data: [{}],
      },
      // 分页
      pageData: {
        total: 0,
        pageSize: 15,
        current: 1,
      },
      // 业务名称
      statusOptions: [],
      // 行政区
      xzqOptions: [
        {
          value: "632321",
          label: "同仁县",
        },
        {
          value: "632322",
          label: "尖扎县",
        },
        {
          value: "632323",
          label: "泽库县",
        },
        {
          value: "632324",
          label: "河南县",
        },
      ],
    };
  },
  methods: {
    // 初始化数据
    queryClick() {
      getDataReportPage({ ...this.form, ...this.pageData }).then((res) => {
        if (res.code === 200) {
          let { total, records } = res.result;
          this.tableData.total = total;
          this.tableData.data = records ? records : [];
        }
      });
    },
    // 重置
    resetForm() {
      this.$refs.ruleForm.resetFields();
    },
    featchData() {
      this.queryClick();
    },
    // 详情
    handleEdit() {
      this.$popupDialog(
        "业务报文",
        "components/JsonEditor/index",
        {},
        "50%",
        "320px"
      );
    },
  },
};
</script>
<style scoped lang="scss">
// 引入表单整体样式
@import "~@/styles/public.scss";
// 引入当前css
@import "./index.scss";
</style>