You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
109 lines
3.8 KiB
109 lines
3.8 KiB
/* |
|
* Licensed to the Apache Software Foundation (ASF) under one or more |
|
* contributor license agreements. See the NOTICE file distributed with |
|
* this work for additional information regarding copyright ownership. |
|
* The ASF licenses this file to You under the Apache License, Version 2.0 |
|
* (the "License"); you may not use this file except in compliance with |
|
* the License. You may obtain a copy of the License at |
|
* |
|
* http://www.apache.org/licenses/LICENSE-2.0 |
|
* |
|
* Unless required by applicable law or agreed to in writing, software |
|
* distributed under the License is distributed on an "AS IS" BASIS, |
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
* See the License for the specific language governing permissions and |
|
* limitations under the License. |
|
*/ |
|
<template> |
|
<div class="list-model"> |
|
<div class="table-box"> |
|
<el-table :data="list" size="mini" style="width: 100%" row-class-name="rows-tenant"> |
|
<el-table-column type="index" :label="$t('#')" width="50"></el-table-column> |
|
<el-table-column prop="tenantCode" :label="$t('OS Tenant Code')" min-width="100"></el-table-column> |
|
<el-table-column :label="$t('Description')" min-width="100"> |
|
<template slot-scope="scope"> |
|
<span>{{scope.row.description | filterNull}}</span> |
|
</template> |
|
</el-table-column> |
|
<el-table-column prop="queueName" :label="$t('Queue')" min-width="80"></el-table-column> |
|
<el-table-column :label="$t('Create Time')" min-width="120"> |
|
<template slot-scope="scope"> |
|
<span>{{scope.row.createTime | formatDate}}</span> |
|
</template> |
|
</el-table-column> |
|
<el-table-column :label="$t('Update Time')" min-width="120"> |
|
<template slot-scope="scope"> |
|
<span>{{scope.row.updateTime | formatDate}}</span> |
|
</template> |
|
</el-table-column> |
|
<el-table-column :label="$t('Operation')" width="100"> |
|
<template slot-scope="scope"> |
|
<el-tooltip :content="$t('Edit')" placement="top"> |
|
<el-button type="primary" size="mini" icon="el-icon-edit-outline" @click="_edit(scope.row)" circle></el-button> |
|
</el-tooltip> |
|
<el-tooltip :content="$t('Delete')" placement="top"> |
|
<el-button type="danger" size="mini" icon="el-icon-delete" circle></el-button> |
|
<el-popconfirm |
|
:confirmButtonText="$t('Confirm')" |
|
:cancelButtonText="$t('Cancel')" |
|
icon="el-icon-info" |
|
iconColor="red" |
|
:title="$t('Delete?')" |
|
@onConfirm="_delete(scope.row,scope.row.id)" |
|
> |
|
<el-button type="danger" size="mini" icon="el-icon-delete" circle slot="reference" class="delete"></el-button> |
|
</el-popconfirm> |
|
</el-tooltip> |
|
</template> |
|
</el-table-column> |
|
</el-table> |
|
</div> |
|
</div> |
|
</template> |
|
<script> |
|
import { mapActions } from 'vuex' |
|
|
|
export default { |
|
name: 'tenement-list', |
|
data () { |
|
return { |
|
list: [] |
|
} |
|
}, |
|
props: { |
|
tenementList: Array, |
|
pageNo: Number, |
|
pageSize: Number |
|
}, |
|
methods: { |
|
...mapActions('security', ['deleteQueue']), |
|
_delete (item, i) { |
|
this.deleteQueue({ |
|
id: item.id |
|
}).then(res => { |
|
this.$emit('on-update') |
|
this.$message.success(res.msg) |
|
}).catch(e => { |
|
this.$message.error(e.msg || '') |
|
}) |
|
}, |
|
_edit (item) { |
|
this.$emit('on-edit', item) |
|
} |
|
}, |
|
watch: { |
|
tenementList (a) { |
|
this.list = [] |
|
setTimeout(() => { |
|
this.list = a |
|
}) |
|
} |
|
}, |
|
created () { |
|
this.list = this.tenementList |
|
}, |
|
mounted () { |
|
}, |
|
components: { } |
|
} |
|
</script>
|
|
|