Files
eladmin-web/src/views/mnt/serverDeploy/index.vue
2019-11-19 11:42:54 +08:00

184 lines
4.9 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<template>
<div class="app-container">
<!--工具栏-->
<div class="head-container">
<!-- 搜索 -->
<el-input
v-model="query.value"
clearable
placeholder="输入搜索内容"
style="width: 200px"
class="filter-item"
@keyup.enter.native="toQuery"
/>
<el-select
v-model="query.type"
clearable
placeholder="类型"
class="filter-item"
style="width: 130px"
>
<el-option
v-for="item in queryTypeOptions"
:key="item.key"
:label="item.display_name"
:value="item.key"
/>
</el-select>
<el-button
class="filter-item"
size="mini"
type="success"
icon="el-icon-search"
@click="toQuery"
>搜索</el-button>
<!-- 新增 -->
<div style="display: inline-block;margin: 0px 2px">
<el-button
v-permission="['admin','serverDeploy:add']"
class="filter-item"
size="mini"
type="primary"
icon="el-icon-plus"
@click="add"
>新增</el-button>
</div>
</div>
<!--表单组件-->
<eForm ref="form" :is-add="isAdd" :account-list="accountList" />
<!--表格渲染-->
<el-table v-loading="loading" :data="data" size="small" style="width: 100%">
<el-table-column prop="id" label="服务器IP" />
<el-table-column :formatter="accountTranslate" prop="accountId" label="服务器账号" />
<el-table-column
v-if="checkPermission(['admin','serverDeploy:edit','serverDeploy:del'])"
label="操作"
width="150px"
align="center"
>
<template slot-scope="scope">
<el-button
v-permission="['admin','serverDeploy:edit']"
size="mini"
type="primary"
icon="el-icon-edit"
@click="edit(scope.row)"
/>
<el-popover
v-permission="['admin','serverDeploy:del']"
:ref="scope.row.id"
placement="top"
width="180"
>
<p>确定删除本条数据吗</p>
<div style="text-align: right; margin: 0">
<el-button size="mini" type="text" @click="$refs[scope.row.id].doClose()">取消</el-button>
<el-button
:loading="delLoading"
type="primary"
size="mini"
@click="subDelete(scope.row.id)"
>确定</el-button>
</div>
<el-button slot="reference" type="danger" icon="el-icon-delete" size="mini" />
</el-popover>
</template>
</el-table-column>
</el-table>
<!--分页组件-->
<el-pagination
:total="total"
:current-page="page + 1"
style="margin-top: 8px"
layout="total, prev, pager, next, sizes"
@size-change="sizeChange"
@current-change="pageChange"
/>
</div>
</template>
<script>
import checkPermission from '@/utils/permission'
import initData from '@/mixins/initData'
import { del } from '@/api/serverDeploy'
import { queryServerAccount } from '@/api/serverAccount'
import eForm from './form'
export default {
components: { eForm },
mixins: [initData],
data() {
return {
delLoading: false,
queryTypeOptions: [{ key: 'id', display_name: '服务器IP' }],
accountList: [],
accountMap: {}
}
},
created() {
this.$nextTick(() => {
this.init()
})
},
methods: {
checkPermission,
async beforeInit() {
this.url = 'api/serverDeploy'
const sort = 'id,desc'
this.params = { page: this.page, size: this.size, sort: sort }
const query = this.query
const type = query.type
const value = query.value
await queryServerAccount({}).then(res => {
this.accountList = res.content
this.accountList.forEach(({ id, name }) => {
this.accountMap[id] = name
})
})
if (type && value) {
this.params[type] = value
}
return true
},
accountTranslate(row, column) {
return this.accountMap[row.accountId]
},
subDelete(id) {
this.delLoading = true
del(id)
.then(res => {
this.delLoading = false
this.$refs[id].doClose()
this.dleChangePage()
this.init()
this.$notify({
title: '删除成功',
type: 'success',
duration: 2500
})
})
.catch(err => {
this.delLoading = false
this.$refs[id].doClose()
console.log(err.response.data.message)
})
},
add() {
this.isAdd = true
this.$refs.form.dialog = true
},
edit(data) {
this.isAdd = false
const _this = this.$refs.form
_this.form = {
id: data.id,
accountId: data.accountId
}
_this.dialog = true
}
}
}
</script>
<style scoped>
</style>