index.vue 4.4 KB
<template>
  <div class="registerLog from-clues">
    <div class="registerLog-header from-clues-header">
      <el-form ref="form" :model="form" label-width="80px">
        <el-row>
          <el-col :span="5">
            <el-form-item label="行政区">
              <el-select v-model="form.areacode" filterable placeholder="请选择行政区">
                <!-- <el-option v-for="item in dicData['XZQ']" :key="item.DCODE" :label="item.DNAME" :value="item.DCODE">
                </el-option> -->
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="10">
            <el-form-item label="上报时间" class="reportingTime">
              <el-date-picker type="date" placeholder="选择开始日期" :picker-options="pickerOptionsStart" clearable
                v-model="form.startTime" value-format="yyyy-MM-dd"></el-date-picker>
              <span class="line">-</span>
              <el-date-picker placeholder="选择结束日期" clearable :picker-options="pickerOptionsEnd" v-model="form.endTime"
                value-format="yyyy-MM-dd">
              </el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="9" class="btnColRight">
            <el-button type="primary" @click="handleSubmit">查询结果</el-button>
          </el-col>
        </el-row>
      </el-form>
    </div>
    <div class="from-clues-content">
      <lb-table :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>
    <!-- 预览弹框 -->
    <dialogBox ref="dialog" isReset saveButton="关闭" divider title="XML报文">
      <div class="xmlMessage">
        {{ xml }}
      </div>
    </dialogBox>
  </div>
</template>

<script>
// 登簿日志
import data from "./data"
import journal from '@/api/journal.js'
import fromMixin from '@/mixins/fromMixin.js'
import tableMixin from '@/mixins/tableMixin.js'
export default {
  name: "registerLog",
  mixins: [fromMixin, tableMixin],
  data () {
    return {
      xml: '',
      form: {
        areacode: '',
        startTime: '',
        endTime: '',
        currentPage: 1
      },
      tableData: {
        columns: [{
          label: '序号',
          type: 'index',
          width: '50',
          index: this.indexMethod,
        }].concat(data.columns())
          .concat([
            {
              label: "XML报文",
              width: 130,
              render: (h, scope) => {
                return (
                  <div>
                    <el-button
                      type="text"
                      icon="el-icon-view"
                      onClick={() => { this.handlePreview(scope.$index, scope.row) }}
                    >
                      预览
                    </el-button>
                  </div>
                );
              },
            },
          ]),
        data: []
      },
      pageData: {
        total: 0,
        pageSize: 15,
        current: 1
      }
    }
  },
  // watch: {
  //   'dicData.XZQ': {
  //     handler (val, oldVal) {
  //       if (val.length == 1) {
  //         this.form.areacode = val[0].DCODE
  //       }
  //     },
  //     deep: true
  //   }
  // },
  // created () {
  //   if (this.dicData && this.dicData['XZQ'] && this.dicData['XZQ'].length == 1) {
  //     this.form.areacode = this.dicData.XZQ[0].DCODE
  //   }
  // },
  methods: {
    async featchData () {
      try {
        this.form = Object.assign(this.form, this.formData)
        let { list, total, pages: pageSize, pageNum: current
        } = await journal.queryAccessLogs(this.form)
        this.tableData.data = list
        this.pageData = {
          pageSize,
          current,
          total
        }
      } catch (error) {
        this.message = error
      }
    },
    async handlePreview (index, row) {
      try {
        let { result: res } = await journal.getXmlById(row.id)
        if (res != null) {
          this.xml = res
          this.$refs.dialog.isShow();
        } else {
          this.$message('报文为空')
        }
      } catch (error) {
        this.$alert(error, '提示', {
          confirmButtonText: '确定',
          type: 'error'
        })
      }
    }
  },
}
</script>
<style scoped lang="scss">
@import "~@/styles/public.scss";
@import "./index.scss";
</style>