index.vue 6.29 KB
<template>
  <div class="reportLog from-clues">
    <div class="from-clues-header">
      <el-form ref="form" :model="form" label-width="100px">
        <el-row class="marginbtm5">
          <el-col :span="6">
            <el-form-item label="不动产单元号">
              <el-input v-model="form.bdcdyh" class="width100" placeholder="不动产单元号"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="开始日期">
              <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="结束日期">
              <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="业务号">
              <el-input v-model="form.ywh" class="width100" placeholder="业务号"></el-input>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="6">
            <el-form-item label="响应结果">
              <el-select v-model="form.status" 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="行政区">
              <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="12" class="btnColRight">
            <el-button type="primary" @click="handleSubmit">查询结果</el-button>
          </el-col>
        </el-row>
      </el-form>
    </div>
    <div class="from-clues-content">
      <lb-table ref="table" :heightNum="300" :page-size="pageData.size" :current-page.sync="pageData.current"
        :total="pageData.total" @size-change="handleSizeChange" @p-current-change="handleCurrentChange"
        :column="tableData.columns" :data="tableData.data">
      </lb-table>
    </div>
    <!-- 编辑 -->
    <edit-dialog ref="editLog" :bsmSjsb="bsmSjsb" :diaData="diaData" />
  </div>
</template>

<script>
// 上报日志
import data from "./data"
import journal from '@/api/journal.js'
import tableMixin from '@/mixins/tableMixin.js'
import dataReporting from '@/api/dataReporting'
import editDialog from '@/components/dataDetails/edit-dialog.vue'
export default {
  name: "reportLog",
  mixins: [tableMixin],
  components: {
    editDialog,
  },
  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()
            );
          }
        }
      },
      bsmSjsb: '',
      diaData: [],
      form: {
        bdcdyh: '',
        startTime: '',
        endTime: '',
        ywh: '',
        status: '',
        pcode: '',
        currentPage: 1
      },
      tableData: {
        columns: [{
          label: '序号',
          type: 'index',
          width: '50',
          index: this.indexMethod,
        }].concat(data.columns()).concat([
          {
            label: "操作",
            headerAlign: 'center',
            align: 'right',
            render: (h, scope) => {
              return (
                <div>
                  <el-button
                    type="text"
                    size="mini"
                    icon="el-icon-edit"
                    style="margin-left: 10px"
                    onClick={() => { this.handleEdit(scope.$index, scope.row) }}
                  >
                    编辑
                  </el-button>
                </div>
              )
            }
          }
        ]),
        data: []
      },
      pageData: {
        total: 0,
        pageSize: 15,
        current: 1,
      },
      // 上报状态
      statusOptions: [
      ],
      // 行政区
      xzqOptions: [
        {
          value: '632321',
          label: '同仁县'
        },
        {
          value: '632322',
          label: '尖扎县'
        },
        {
          value: '632323',
          label: '泽库县'
        },
        {
          value: '632324',
          label: '河南县'
        }
      ]
    }
  },
  methods: {
    async featchData () {
      try {
        this.form = Object.assign(this.form, this.formData)
        let { result: { list, total, pages: pageSize, pageNum: current }
        } = await journal.querySjsbTask(this.form)
        if (this.$store.state.dictionaries.addDic) {
          this.tableData.data = list
          this.pageData = {
            pageSize,
            current,
            total
          }
        } else {
          this.featchData()
        }
      } catch (error) {
        this.message = error
      }
    },
    async handleEdit (index, row) {
      try {
        let { result: res, message } = await dataReporting.getQltFwFdcqYzByCondition(row.msgid)
        if (res != null) {
          this.diaData = res
          this.bsmSjsb = row.msgid
          this.$store.dispatch('business/setReportLogEdit')
          this.$refs.editLog.isShow()
        } else {
          this.$message(message)
        }
      } catch (error) {
        this.$alert(error, '提示', {
          confirmButtonText: '确定',
          type: 'error'
        })
      }
    }
  }
}
</script>
<style scoped lang="scss">
@import "~@/styles/public.scss";
@import "./index.scss";
</style>