• wangxl's avatar
    444 · 2764e4ab
    wangxl authored
    2764e4ab
Index.vue 4.81 KB
<template>
  <div class="app-content">
    <a-form :form="form" :model="searchForm" layout="inline" class="search_form">
      <a-form-item>
        <a-button type="primary" class="search_input" style="margin-right: 10px;" @click="createBatch">添加</a-button>
        <a-button type="primary" @click="search">刷新</a-button>
      </a-form-item>
    </a-form>
    <a-table :dataSource="tableData" :columns="columns" rowKey="id" :pagination="false" :loading="loading" bordered>
      <template slot="option" slot-scope="record">
        <a-button type="link" size="small" @click="recordClick(record,'edit')">修改</a-button>&nbsp;
        <a-button type="link" size="small" @click="recordClick(record,'delete')">删除</a-button>
      </template>
    </a-table>
    <a-pagination v-if="pagination.total > 0" :total="pagination.total" show-size-changer show-quick-jumper v-model="pagination.pageIndex" :page-size="pagination.pageSize" :page-size-options="pagination.pageSizeOptions" @showSizeChange="showSizeChange" @change="change" :showTotal="() => `共 ${pagination.total} 条`" />
    <a-modal :visible="visibleEdit" v-model="visibleEdit" :title="'添加/修改'" :footer="null" :maskClosable="false" :dialog-style="{ top: '15%' }" :width="800" destroyOnClose>
      <batch-edit v-model="id" @close="closeWindow" ref="childEdit" />
    </a-modal>
  </div>
</template>

<script>
import { getType } from '@/views/utils/auth'
import batchEdit from '@/views/timeSet/batch/components/batchEdit'
import moment from 'moment'
import { isEmptyParams} from "@/views/utils/common"
export default {
  name: 'batchSet',
  components: { batchEdit },
  data () {
    return {
      searchForm: { projType: getType(), timeType: 1, },
      form: this.$form.createForm(this, { name: 'advanced_search' }),
      tableData: [],
      columns: [
        { key: '1', title: '申报年度', dataIndex: 'year', align: 'center' },
        { key: '2', title: '批次', dataIndex: 'batch', align: 'center' },
        { key: '3', title: '项目申报时间', dataIndex: 'reportStart', colSpan: 2, ellipsis: true },
        { key: '4', title: '项目申报时间', dataIndex: 'reportEnd', colSpan: 0, ellipsis: true },
        { key: '5', title: '审核时间', dataIndex: 'auditStart', colSpan: 2, ellipsis: true },
        { key: '6', title: '审核时间', dataIndex: 'auditEnd', colSpan: 0, ellipsis: true },
        { key: '11', title: '专家评审时间', dataIndex: 'expertStart', colSpan: 2, ellipsis: true },
        { key: '12', title: '专家评审时间', dataIndex: 'expertEnd', colSpan: 0, ellipsis: true },
        { key: '13', title: '备注', dataIndex: 'remark', align: 'center', ellipsis: true },
        { key: '14', title: '操作', scopedSlots: { customRender: 'option' }, align: 'center', fixed: 'right', width: 120, },
      ],
      pagination: { pageIndex: 1, pageSize: this.$defaultPageSize, total: 0, pageSizeOptions: this.$defaultPageSizeOptions, },
      // 弹窗标志
      visibleEdit: false,
      id: null,
      loading: false,
    }
  },
  created () {
    this.getListByPage()
  },
  computed: {

  },
  methods: {
    moment,
    getListByPage () {
      this.loading = true
      let pars = isEmptyParams(this.searchForm)
      let par = { ...pars, pageIndex: this.pagination.pageIndex, pageSize: this.pagination.pageSize }
      this.$api.batch.getListByPage(par).then(({ data = {} }) => {
        if (data) {
          const { dataList = [], total = 0 } = data
          this.tableData = dataList
          this.pagination.total = total
          this.loading = false
        }
      }).catch(() => { this.loading = false })
    },
    search () {
      this.pagination.pageIndex = 1
      this.getListByPage()
    },
    reset () {
      this.pagination.pageIndex = 1
      this.getListByPage()
    },
    change () {
      this.getListByPage()
    },
    showSizeChange (current, pageSize) {
      this.pagination.pageIndex = current
      this.pagination.pageSize = pageSize
      this.getListByPage()
    },
    createBatch () {
      this.id = null
      this.visibleEdit = true
    },
    recordClick (record, type) {
      if (type === 'edit') {
        this.id = record.id
        this.visibleEdit = true
      } else if (type === 'delete') {
        let self = this
        this.$confirm({
          title: '',
          content: '确定要删除该批次?',
          okText: '确定',
          okType: 'danger',
          cancelText: '取消',
          onOk () {
            let pars = { id: record.id }
            self.$api.batch.deleteBatch(pars).then(({ data = {} }) => {
              if (data) {
                self.getListByPage()
              }
            })
          },
          onCancel () {
          },
        })
      }
    },
    closeWindow () {
      this.visibleEdit = false
      this.getListByPage()
    }
  },
  watch: {
    $route () {

    }
  }
}
</script>