refactor: Api Keys 前端页面修改
This commit is contained in:
parent
759fd8cadd
commit
a435a5194d
|
@ -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>
|
||||||
|
|
Loading…
Reference in New Issue