refactor: Api Keys 前端页面修改

This commit is contained in:
Captain.B 2020-08-19 11:46:01 +08:00
parent 759fd8cadd
commit a435a5194d
1 changed files with 129 additions and 70 deletions

View File

@ -9,17 +9,29 @@
<el-row type="flex" justify="space-between" align="middle"> <el-row type="flex" justify="space-between" align="middle">
<el-button @click="createApiKey()" plain type="el-icon-question" icon="el-icon-circle-plus-outline" <el-button @click="createApiKey()" plain type="el-icon-question" icon="el-icon-circle-plus-outline"
size="mini"> size="mini">
{{$t('commons.create')}} {{ $t('commons.create') }}
</el-button> </el-button>
</el-row> </el-row>
</div> </div>
</template> </template>
<el-table border class="adjust-table" :data="tableData" style="width: 100%"> <el-table border class="adjust-table" :data="tableData" style="width: 100%">
<el-table-column prop="accessKey" label="Access Key"/> <el-table-column prop="accessKey" label="Access Key">
<template v-slot:default="scope">
<div class="variable-combine">
<div class="variable">{{ scope.row.accessKey }}</div>
<div>
<el-tooltip :content="$t('api_test.copied')" manual v-model="scope.row.visible" placement="top"
:visible-arrow="false">
<i class="el-icon-copy-document copy" @click="copy(scope.row, 'accessKey')"/>
</el-tooltip>
</div>
</div>
</template>
</el-table-column>
<el-table-column prop="secretKey" label="Secret Key"> <el-table-column prop="secretKey" label="Secret Key">
<template v-slot:default="scope"> <template v-slot:default="scope">
<el-link type="info" @click="showSecretKey(scope.row)">{{$t('commons.show')}}</el-link> <el-link type="primary" @click="showSecretKey(scope.row)">{{ $t('commons.show') }}</el-link>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="status" :label="$t('commons.status')"> <el-table-column prop="status" :label="$t('commons.status')">
@ -46,87 +58,134 @@
</el-table-column> </el-table-column>
</el-table> </el-table>
</el-card> </el-card>
<el-dialog title="Secret Key" :visible.sync="apiKeysVisible">
<div class="variable">
{{ currentRow.secretKey }}
<el-tooltip :content="$t('api_test.copied')" manual v-model="currentRow.visible2" placement="top"
:visible-arrow="false">
<i class="el-icon-copy-document copy" @click="copy(currentRow, 'secretKey')"/>
</el-tooltip>
</div>
</el-dialog>
</div> </div>
</template> </template>
<script> <script>
import MsDialogFooter from "../../common/components/MsDialogFooter"; import MsDialogFooter from "../../common/components/MsDialogFooter";
import {getCurrentUser} from "../../../../common/js/utils"; import {getCurrentUser} from "../../../../common/js/utils";
import MsTableOperatorButton from "../../common/components/MsTableOperatorButton"; import MsTableOperatorButton from "../../common/components/MsTableOperatorButton";
import MsTableHeader from "../../common/components/MsTableHeader"; import MsTableHeader from "../../common/components/MsTableHeader";
export default { export default {
name: "MsApiKeys", name: "MsApiKeys",
components: {MsDialogFooter, MsTableOperatorButton, MsTableHeader}, components: {MsDialogFooter, MsTableOperatorButton, MsTableHeader},
data() { data() {
return { return {
result: {}, result: {},
updateVisible: false, updateVisible: false,
editPasswordVisible: false, editPasswordVisible: false,
apiKeysVisible: false, apiKeysVisible: false,
condition: {}, condition: {},
tableData: [], tableData: [],
} currentRow: {},
}
},
activated() {
this.search();
},
methods: {
currentUser: () => {
return getCurrentUser();
}, },
search() {
activated() { this.result = this.$get("/user/key/info", response => {
this.search(); this.tableData = response.data;
this.tableData.forEach(d => d.show = false);
}
)
}, },
deleteApiKey(row) {
methods: { this.$confirm(this.$t('user.apikey_delete_confirm'), '', {
currentUser: () => { confirmButtonText: this.$t('commons.confirm'),
return getCurrentUser(); cancelButtonText: this.$t('commons.cancel'),
}, type: 'warning'
search() { }).then(() => {
this.result = this.$get("/user/key/info", response => { this.result = this.$get("/user/key/delete/" + row.id, response => {
this.tableData = response.data; this.$success(this.$t('commons.delete_success'));
this.tableData.forEach(d => d.show = false);
}
)
},
deleteApiKey(row) {
this.$confirm(this.$t('user.apikey_delete_confirm'), '', {
confirmButtonText: this.$t('commons.confirm'),
cancelButtonText: this.$t('commons.cancel'),
type: 'warning'
}).then(() => {
this.result = this.$get("/user/key/delete/" + row.id, response => {
this.$success(this.$t('commons.delete_success'));
this.search();
})
}).catch(() => {
this.$info(this.$t('commons.delete_cancel'));
});
},
createApiKey() {
this.result = this.$get("/user/key/generate", response => {
this.$success(this.$t('commons.save_success'));
this.search(); this.search();
}) })
}, }).catch(() => {
this.$info(this.$t('commons.delete_cancel'));
});
changeSwitch(row) { },
if (row.status === 'ACTIVE') {
this.result = this.$get("/user/key/active/" + row.id, response => { createApiKey() {
this.$success(this.$t('commons.save_success')); this.result = this.$get("/user/key/generate", response => {
}); this.$success(this.$t('commons.save_success'));
} this.search();
if (row.status === 'DISABLED') { })
this.result = this.$get("/user/key/disable/" + row.id, response => { },
this.$success(this.$t('commons.save_success'));
}); changeSwitch(row) {
} if (row.status === 'ACTIVE') {
}, this.result = this.$get("/user/key/active/" + row.id, response => {
showSecretKey(row) { this.$success(this.$t('commons.save_success'));
this.$alert(row.secretKey, 'Secret Key'); });
} }
} if (row.status === 'DISABLED') {
this.result = this.$get("/user/key/disable/" + row.id, response => {
this.$success(this.$t('commons.save_success'));
});
}
},
showSecretKey(row) {
this.apiKeysVisible = true;
this.currentRow = row;
},
copy(row, key) {
let input = document.createElement("input");
document.body.appendChild(input);
input.value = row[key];
input.select();
if (input.setSelectionRange) {
input.setSelectionRange(0, input.value.length);
}
document.execCommand("copy");
document.body.removeChild(input);
row.visible = true;
setTimeout(() => {
row.visible = false;
}, 1000);
},
} }
}
</script> </script>
<style scoped> <style scoped>
.variable-combine {
color: #7F7F7F;
line-height: 32px;
position: absolute;
top: 10px;
margin-right: -20px;
display: flex;
align-items: center;
}
.variable {
display: inline-block;
margin-right: 10px;
overflow-x: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.copy {
font-size: 14px;
cursor: pointer;
color: #1E90FF;
}
</style> </style>