198 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			198 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<!--
 | 
						|
 * @Author: zwq
 | 
						|
 * @Date: 2020-12-29 15:41:11
 | 
						|
 * @LastEditors: fzq
 | 
						|
 * @LastEditTime: 2022-03-03 16:35:32
 | 
						|
 * @Description:
 | 
						|
-->
 | 
						|
<template>
 | 
						|
  <div class="app-container">
 | 
						|
    <head-form
 | 
						|
      :placeholder-name="placeholderName"
 | 
						|
      :key-name="keyName"
 | 
						|
      @getDataList="getList"
 | 
						|
      @add="addNew"
 | 
						|
    />
 | 
						|
    <base-table
 | 
						|
      :page="listQuery.current"
 | 
						|
      :limit="listQuery.size"
 | 
						|
      :table-config="tableProps"
 | 
						|
      :table-data="list"
 | 
						|
      :is-loading="listLoading"
 | 
						|
    >
 | 
						|
      <method-btn
 | 
						|
        slot="handleBtn"
 | 
						|
        :width="trueWidth"
 | 
						|
        :method-list="tableBtn"
 | 
						|
        @clickBtn="handleClick"
 | 
						|
      />
 | 
						|
    </base-table>
 | 
						|
    <pagination
 | 
						|
      v-show="total > 0"
 | 
						|
      :total="total"
 | 
						|
      :page.sync="listQuery.current"
 | 
						|
      :limit.sync="listQuery.size"
 | 
						|
      @pagination="getList()"
 | 
						|
    />
 | 
						|
  </div>
 | 
						|
</template>
 | 
						|
 | 
						|
<script>import i18n from '@/lang'
 | 
						|
import { cacheList, cacheDelete } from '@/api/basicData/Cache/cache'
 | 
						|
import HeadForm from '@/components/basicData/HeadForm'
 | 
						|
import BaseTable from '@/components/BaseTable'
 | 
						|
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
 | 
						|
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
 | 
						|
import { timeFormatter } from '@/filters'
 | 
						|
 | 
						|
/**
 | 
						|
 * 表格表头配置项 TypeScript接口注释
 | 
						|
 * tableConfig<ConfigItem> = []
 | 
						|
 *
 | 
						|
 * Interface ConfigItem = {
 | 
						|
 *  prop: string,
 | 
						|
 *  label: string,
 | 
						|
 *  width: string,
 | 
						|
 *  align: string,
 | 
						|
 *  subcomponent: function,
 | 
						|
 *  filter: function
 | 
						|
 * }
 | 
						|
 *
 | 
						|
 *
 | 
						|
 */
 | 
						|
 | 
						|
const tableBtn = [
 | 
						|
  {
 | 
						|
    type: 'edit',
 | 
						|
    btnName: 'btn.edit'
 | 
						|
  },
 | 
						|
  {
 | 
						|
    type: 'delete',
 | 
						|
    btnName: 'btn.delete'
 | 
						|
  },
 | 
						|
  {
 | 
						|
    type: 'detail',
 | 
						|
    btnName: 'btn.detail'
 | 
						|
  }
 | 
						|
]
 | 
						|
const tableProps = [
 | 
						|
  {
 | 
						|
    prop: 'createTime',
 | 
						|
    label: i18n.t('module.basicData.factory.createTime'),
 | 
						|
    filter: timeFormatter,
 | 
						|
    align: 'center'
 | 
						|
  },
 | 
						|
  {
 | 
						|
    prop: 'tareaName',
 | 
						|
    label: i18n.t('module.basicData.cache.CacheName'),
 | 
						|
    align: 'center'
 | 
						|
  },
 | 
						|
  {
 | 
						|
    prop: 'code',
 | 
						|
    label: i18n.t('module.basicData.cache.CacheCode'),
 | 
						|
    align: 'center'
 | 
						|
  },
 | 
						|
  {
 | 
						|
    prop: 'enName',
 | 
						|
    label: i18n.t('module.basicData.visual.EnglishName'),
 | 
						|
    align: 'center'
 | 
						|
  }
 | 
						|
]
 | 
						|
 | 
						|
export default {
 | 
						|
  name: 'Cache',
 | 
						|
  components: { Pagination, BaseTable, MethodBtn, HeadForm },
 | 
						|
  filters: {
 | 
						|
    statusFilter(status) {
 | 
						|
      const statusMap = {
 | 
						|
        published: 'success',
 | 
						|
        draft: 'info',
 | 
						|
        deleted: 'danger'
 | 
						|
      }
 | 
						|
      return statusMap[status]
 | 
						|
    }
 | 
						|
  },
 | 
						|
  data() {
 | 
						|
    return {
 | 
						|
      keyName: i18n.t('module.basicData.visual.keyword'),
 | 
						|
      placeholderName: this.$t('module.basicData.cache.CacheName') + this.$t('module.basicData.visual.Or') + this.$t('module.basicData.cache.CacheCode'),
 | 
						|
      tableBtn,
 | 
						|
      trueWidth: 240,
 | 
						|
      tableProps,
 | 
						|
      list: [],
 | 
						|
      total: 0,
 | 
						|
      listLoading: true,
 | 
						|
      listQuery: {
 | 
						|
        current: 1,
 | 
						|
        size: 10
 | 
						|
      }
 | 
						|
    }
 | 
						|
  },
 | 
						|
  created() {
 | 
						|
    this.getList()
 | 
						|
  },
 | 
						|
  methods: {
 | 
						|
    handleClick(raw) {
 | 
						|
      if (raw.type === 'delete') {
 | 
						|
        this.$confirm(`${this.$t('module.basicData.visual.TipsBefore')}[${raw.data.name}]?`, this.$t('module.basicData.visual.Tips'), {
 | 
						|
          confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
 | 
						|
          cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
 | 
						|
          type: 'warning'
 | 
						|
        }).then(() => {
 | 
						|
          cacheDelete(raw.data.id).then(response => {
 | 
						|
            this.$message({
 | 
						|
              message: this.$t('module.basicData.visual.success'),
 | 
						|
              type: 'success',
 | 
						|
              duration: 1500,
 | 
						|
              onClose: () => {
 | 
						|
                this.getList()
 | 
						|
              }
 | 
						|
            })
 | 
						|
          })
 | 
						|
        }).catch(() => {})
 | 
						|
      } else if (raw.type === 'edit') {
 | 
						|
        this.addNew(raw.data.id)
 | 
						|
      } else {
 | 
						|
        this.addNew(raw.data.id, true)
 | 
						|
      }
 | 
						|
    },
 | 
						|
    getList(key) {
 | 
						|
      this.listLoading = true
 | 
						|
      this.listQuery.tareaName = key
 | 
						|
      this.listQuery.code = key
 | 
						|
      console.log(this.listQuery)
 | 
						|
      cacheList(this.listQuery).then(response => {
 | 
						|
        if (response.data.records) {
 | 
						|
          this.list = response.data.records
 | 
						|
        } else {
 | 
						|
          this.list.splice(0, this.list.length)
 | 
						|
        }
 | 
						|
        this.total = response.data.total
 | 
						|
        this.listLoading = false
 | 
						|
      })
 | 
						|
    },
 | 
						|
    // 新增 / 修改
 | 
						|
    addNew(id, isdetail) {
 | 
						|
      this.$router.push({
 | 
						|
        name: 'cacheAdd',
 | 
						|
        query: {
 | 
						|
          id: id,
 | 
						|
          isdetail: isdetail
 | 
						|
        }
 | 
						|
      })
 | 
						|
    }
 | 
						|
  }
 | 
						|
}
 | 
						|
</script>
 | 
						|
 | 
						|
<style scoped>
 | 
						|
.edit-input {
 | 
						|
  padding-right: 100px;
 | 
						|
}
 | 
						|
.cancel-btn {
 | 
						|
  position: absolute;
 | 
						|
  right: 15px;
 | 
						|
  top: 10px;
 | 
						|
}
 | 
						|
</style>
 |