style(环境设置): 优化环境编辑页面

--bug=1008085 --user=刘瑞斌 [环境管理]-创建环境时页面显示优化-输入框左右对齐 https://www.tapd.cn/55049933/s/1070605
This commit is contained in:
CaptainB 2021-11-19 16:42:31 +08:00 committed by 刘瑞斌
parent bc02c38758
commit 9971385089
2 changed files with 300 additions and 297 deletions

View File

@ -1,10 +1,7 @@
<template> <template>
<div> <div>
<el-form :model="commonConfig" :rules="rules" ref="commonConfig" :disabled="isReadOnly"> <el-form :model="commonConfig" :rules="rules" ref="commonConfig" :disabled="isReadOnly" label-width="30px">
<span>{{$t('api_test.environment.globalVariable')}}</span>
<ms-api-scenario-variables :show-copy="false" :items="commonConfig.variables"/> <ms-api-scenario-variables :show-copy="false" :items="commonConfig.variables"/>
<el-form-item> <el-form-item>
<el-switch v-model="commonConfig.enableHost" active-text="Hosts"/> <el-switch v-model="commonConfig.enableHost" active-text="Hosts"/>
</el-form-item> </el-form-item>
@ -14,7 +11,9 @@
<span style="margin-left: 30px">{{$t('api_test.environment.response_timeout')}}:</span> <span style="margin-left: 30px">{{$t('api_test.environment.response_timeout')}}:</span>
<el-input-number style="margin-left: 20px" v-model="commonConfig.responseTimeout">{{$t('api_test.environment.globalVariable')}}</el-input-number> <el-input-number style="margin-left: 20px" v-model="commonConfig.responseTimeout">{{$t('api_test.environment.globalVariable')}}</el-input-number>
</el-form-item> </el-form-item>
<ms-api-host-table v-if="commonConfig.enableHost" :hostTable="commonConfig.hosts" ref="refHostTable"/> <el-form-item>
<ms-api-host-table v-if="commonConfig.enableHost" :hostTable="commonConfig.hosts" ref="refHostTable"/>
</el-form-item>
</el-form> </el-form>
</div> </div>
</template> </template>

View File

@ -3,7 +3,8 @@
<el-card class="table-card" v-loading="result.loading"> <el-card class="table-card" v-loading="result.loading">
<!-- 表头 --> <!-- 表头 -->
<template v-slot:header> <template v-slot:header>
<ms-table-header :create-permission="['WORKSPACE_PROJECT_ENVIRONMENT:READ+CREATE']" :title="$t('api_test.environment.environment_list')" :create-tip="btnTips" <ms-table-header :create-permission="['WORKSPACE_PROJECT_ENVIRONMENT:READ+CREATE']"
:title="$t('api_test.environment.environment_list')" :create-tip="btnTips"
:condition.sync="condition" @search="search" @create="createEnv"> :condition.sync="condition" @search="search" @create="createEnv">
<template v-slot:button> <template v-slot:button>
<ms-table-button v-permission="['WORKSPACE_PROJECT_ENVIRONMENT:READ+IMPORT']" icon="el-icon-box" <ms-table-button v-permission="['WORKSPACE_PROJECT_ENVIRONMENT:READ+IMPORT']" icon="el-icon-box"
@ -55,14 +56,13 @@
<!-- 创建编辑复制环境时的对话框 --> <!-- 创建编辑复制环境时的对话框 -->
<el-dialog :visible.sync="dialogVisible" :close-on-click-modal="false" :title="dialogTitle" width="66%"> <el-dialog :visible.sync="dialogVisible" :close-on-click-modal="false" :title="dialogTitle" width="66%">
<div class="project-item"> <el-form label-width="80px" :rules="rules">
<span> <el-form-item class="project-item" prop="currentProjectId" :label="$t('project.select')">
{{$t('project.select')}} <el-select @change="handleProjectChange" v-model="currentProjectId" filterable clearable>
</span> <el-option v-for="item in projectList" :key="item.id" :label="item.name" :value="item.id"></el-option>
<el-select style="width: 50%" @change="handleProjectChange" v-model="currentProjectId" filterable clearable> </el-select>
<el-option v-for="item in projectList" :key="item.id" :label="item.name" :value="item.id"></el-option> </el-form-item>
</el-select> </el-form>
</div>
<environment-edit :environment="currentEnvironment" ref="environmentEdit" @close="close" <environment-edit :environment="currentEnvironment" ref="environmentEdit" @close="close"
:project-id="currentProjectId" @refreshAfterSave="refresh"> :project-id="currentProjectId" @refreshAfterSave="refresh">
</environment-edit> </environment-edit>
@ -73,17 +73,18 @@
<el-table :data="conditions"> <el-table :data="conditions">
<el-table-column prop="socket" :label="$t('load_test.domain')" show-overflow-tooltip width="180"> <el-table-column prop="socket" :label="$t('load_test.domain')" show-overflow-tooltip width="180">
<template v-slot:default="{row}"> <template v-slot:default="{row}">
{{getUrl(row)}} {{ getUrl(row) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="type" :label="$t('api_test.environment.condition_enable')" show-overflow-tooltip min-width="100px"> <el-table-column prop="type" :label="$t('api_test.environment.condition_enable')" show-overflow-tooltip
min-width="100px">
<template v-slot:default="{row}"> <template v-slot:default="{row}">
{{getName(row)}} {{ getName(row) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="details" show-overflow-tooltip min-width="120px" :label="$t('api_test.value')"> <el-table-column prop="details" show-overflow-tooltip min-width="120px" :label="$t('api_test.value')">
<template v-slot:default="{row}"> <template v-slot:default="{row}">
{{getDetails(row)}} {{ getDetails(row) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="createTime" show-overflow-tooltip min-width="120px" :label="$t('commons.create_time')"> <el-table-column prop="createTime" show-overflow-tooltip min-width="120px" :label="$t('commons.create_time')">
@ -93,319 +94,322 @@
</el-table-column> </el-table-column>
</el-table> </el-table>
<span slot="footer" class="dialog-footer"> <span slot="footer" class="dialog-footer">
<el-button @click="domainVisible = false" size="mini">{{$t('commons.cancel')}}</el-button> <el-button @click="domainVisible = false" size="mini">{{ $t('commons.cancel') }}</el-button>
<el-button type="primary" @click="domainVisible = false" size="mini">{{$t('commons.confirm')}}</el-button> <el-button type="primary" @click="domainVisible = false" size="mini">{{ $t('commons.confirm') }}</el-button>
</span> </span>
</el-dialog> </el-dialog>
</div> </div>
</template> </template>
<script> <script>
import MsTableHeader from "@/business/components/common/components/MsTableHeader"; import MsTableHeader from "@/business/components/common/components/MsTableHeader";
import MsTableButton from "@/business/components/common/components/MsTableButton"; import MsTableButton from "@/business/components/common/components/MsTableButton";
import MsTableOperator from "@/business/components/common/components/MsTableOperator"; import MsTableOperator from "@/business/components/common/components/MsTableOperator";
import MsTableOperatorButton from "@/business/components/common/components/MsTableOperatorButton"; import MsTableOperatorButton from "@/business/components/common/components/MsTableOperatorButton";
import MsTablePagination from "@/business/components/common/pagination/TablePagination"; import MsTablePagination from "@/business/components/common/pagination/TablePagination";
import ApiEnvironmentConfig from "@/business/components/api/test/components/ApiEnvironmentConfig"; import ApiEnvironmentConfig from "@/business/components/api/test/components/ApiEnvironmentConfig";
import {Environment, parseEnvironment} from "@/business/components/api/test/model/EnvironmentModel"; import {Environment, parseEnvironment} from "@/business/components/api/test/model/EnvironmentModel";
import EnvironmentEdit from "@/business/components/api/test/components/environment/EnvironmentEdit"; import EnvironmentEdit from "@/business/components/api/test/components/environment/EnvironmentEdit";
import MsAsideItem from "@/business/components/common/components/MsAsideItem"; import MsAsideItem from "@/business/components/common/components/MsAsideItem";
import MsAsideContainer from "@/business/components/common/components/MsAsideContainer"; import MsAsideContainer from "@/business/components/common/components/MsAsideContainer";
import ProjectSwitch from "@/business/components/common/head/ProjectSwitch"; import ProjectSwitch from "@/business/components/common/head/ProjectSwitch";
import SearchList from "@/business/components/common/head/SearchList"; import SearchList from "@/business/components/common/head/SearchList";
import {downloadFile} from "@/common/js/utils"; import {downloadFile} from "@/common/js/utils";
import EnvironmentImport from "@/business/components/project/menu/EnvironmentImport"; import EnvironmentImport from "@/business/components/project/menu/EnvironmentImport";
export default { export default {
name: "EnvironmentList", name: "EnvironmentList",
components: { components: {
EnvironmentImport, EnvironmentImport,
SearchList, SearchList,
ProjectSwitch, ProjectSwitch,
MsAsideContainer, MsAsideContainer,
MsAsideItem, MsAsideItem,
EnvironmentEdit, EnvironmentEdit,
ApiEnvironmentConfig, ApiEnvironmentConfig,
MsTablePagination, MsTableOperatorButton, MsTableOperator, MsTableButton, MsTableHeader MsTablePagination, MsTableOperatorButton, MsTableOperator, MsTableButton, MsTableHeader
},
data() {
return {
btnTips: this.$t('api_test.environment.create'),
projectList: [],
condition: {}, //
environments: [],
currentEnvironment: new Environment(),
result: {},
dialogVisible: false,
idNameMap: new Map(),
dialogTitle: '',
currentProjectId: '', //id
selectRows: [],
isTesterPermission: false,
domainVisible: false,
conditions: [],
currentPage: 1,
pageSize: 10,
total: 0,
projectIds: [], //id
projectFilters: [],
screenHeight: 'calc(100vh - 195px)',
rules: {
currentProjectId: [
{required: true, message: "", trigger: 'blur'},
],
}
};
},
created() {
},
activated() {
this.list();
},
watch: {
//projectId
currentProjectId() {
// el-select''''projectId使
if (this.currentProjectId === '') {
this.currentEnvironment.projectId = null;
} else {
this.currentEnvironment.projectId = this.currentProjectId;
}
}
},
methods: {
showInfo(row) {
const config = JSON.parse(row.config);
this.conditions = config.httpConfig.conditions;
this.domainVisible = true;
}, },
data() { getName(row) {
return { switch (row.type) {
btnTips: this.$t('api_test.environment.create'), case "NONE":
projectList: [], return this.$t("api_test.definition.document.data_set.none");
condition: {}, // case "MODULE":
environments: [], return this.$t("test_track.module.module");
currentEnvironment: new Environment(), case "PATH":
result: {}, return this.$t("api_test.definition.api_path");
dialogVisible: false,
idNameMap: new Map(),
dialogTitle: '',
currentProjectId: '', //id
selectRows: [],
isTesterPermission: false,
domainVisible: false,
conditions: [],
currentPage: 1,
pageSize: 10,
total: 0,
projectIds: [], //id
projectFilters: [],
screenHeight: 'calc(100vh - 195px)',
} }
}, },
created() { getUrl(row) {
return row.protocol + "://" + row.socket;
}, },
getDetails(row) {
activated() { if (row && row.type === "MODULE") {
if (row.details && row.details instanceof Array) {
let value = "";
row.details.forEach((item) => {
value += item.name + ",";
});
if (value.endsWith(",")) {
value = value.substr(0, value.length - 1);
}
return value;
}
} else if (row && row.type === "PATH" && row.details.length > 0 && row.details[0].name) {
return row.details[0].value === "equals" ? this.$t("commons.adv_search.operators.equals") + row.details[0].name : this.$t("api_test.request.assertions.contains") + row.details[0].name;
} else {
return "";
}
},
list() {
if (!this.projectList || this.projectList.length === 0) { //
this.$get("/project/listAll", (response) => {
this.projectList = response.data; //,
this.projectList.forEach(project => {
this.idNameMap.set(project.id, project.name);
this.projectIds.push(project.id);
this.projectFilters.push({
text: project.name,
value: project.id,
});
});
this.getEnvironments();
});
} else {
this.getEnvironments();
}
},
getEnvironments(projectIds) {
this.environments = [];
if (projectIds && projectIds.length > 0) {
this.condition.projectIds = projectIds;
} else {
this.condition.projectIds = this.projectIds;
}
let url = '/api/environment/list/' + this.currentPage + '/' + this.pageSize;
this.result = this.$post(url, this.condition, response => {
this.environments = response.data.listObject;
this.total = response.data.itemCount;
});
},
createEnv() {
this.currentProjectId = '';
this.dialogTitle = this.$t('api_test.environment.create');
this.dialogVisible = true;
this.currentEnvironment = new Environment();
},
search() {
this.list(); this.list();
}, },
editEnv(environment) {
watch: { this.dialogTitle = this.$t('api_test.environment.config_environment');
//projectId this.currentProjectId = environment.projectId;
currentProjectId() { const temEnv = {};
// el-select''''projectId使 Object.assign(temEnv, environment);
if (this.currentProjectId === '') { parseEnvironment(temEnv); //parseEnvironment
this.currentEnvironment.projectId = null; this.currentEnvironment = temEnv;
} else { this.dialogVisible = true;
this.currentEnvironment.projectId = this.currentProjectId;
}
}
}, },
methods: { copyEnv(environment) {
showInfo(row) { this.currentProjectId = environment.projectId; //
const config = JSON.parse(row.config); this.dialogTitle = this.$t('api_test.environment.copy_environment');
this.conditions = config.httpConfig.conditions; const temEnv = {};
this.domainVisible = true; Object.assign(temEnv, environment);
}, parseEnvironment(temEnv); //parseEnvironment
getName(row) { let newEnvironment = new Environment(temEnv);
switch (row.type) { newEnvironment.id = null;
case "NONE": newEnvironment.name = this.getNoRepeatName(newEnvironment.name);
return this.$t("api_test.definition.document.data_set.none"); this.dialogVisible = true;
case "MODULE": this.currentEnvironment = newEnvironment;
return this.$t("test_track.module.module");
case "PATH": },
return this.$t("api_test.definition.api_path"); deleteEnv(environment) {
if (environment.id) {
this.$confirm(this.$t('commons.confirm_delete') + environment.name, {
confirmButtonText: this.$t('commons.confirm'),
cancelButtonText: this.$t('commons.cancel'),
type: "warning"
}).then(() => {
this.result = this.$get('/api/environment/delete/' + environment.id, () => {
this.$success(this.$t('commons.delete_success'));
this.list();
});
}).catch(() => {
this.$info(this.$t('commons.delete_cancelled'));
});
}
},
getNoRepeatName(name) {
for (let i in this.environments) {
if (this.environments[i].name === name) {
return this.getNoRepeatName(name + ' copy');
} }
}, }
getUrl(row) { return name;
return row.protocol + "://" + row.socket; },
},
getDetails(row) { //
if (row && row.type === "MODULE") { filter(filters) {
if (row.details && row.details instanceof Array) { this.getEnvironments(filters.projectId);
let value = ""; },
row.details.forEach((item) => {
value += item.name + ","; //
close() {
this.dialogVisible = false;
this.$refs.environmentEdit.clearValidate();
},
refresh() {
this.list();
},
handleSelectionChange(value) {
this.selectRows = value;
},
importJSON() {
this.$refs.envImport.open();
},
exportJSON() {
if (this.selectRows.length < 1) {
this.$warning(this.$t('api_test.environment.select_environment'));
return;
}
//idprojectId
const envs = JSON.parse(JSON.stringify(this.selectRows));
envs.map(env => { //idprojectId
if (env.config) { //config
let tempConfig = JSON.parse(env.config);
if (tempConfig.httpConfig.conditions && tempConfig.httpConfig.conditions.length > 0) {
tempConfig.httpConfig.conditions = tempConfig.httpConfig.conditions.filter(condition => { //
return condition.type !== 'MODULE';
}); });
if (value.endsWith(",")) { env.config = JSON.stringify(tempConfig);
value = value.substr(0, value.length - 1); }
} }
return value; delete env.id;
delete env.projectId;
});
downloadFile('MS_' + envs.length + '_Environments.json', JSON.stringify(envs));
},
handleProjectChange() { //,
this.currentEnvironment.config.httpConfig.conditions = [];
},
parseDomainName(environment) { //
if (environment.config) {
const config = JSON.parse(environment.config);
if (config.httpConfig && !config.httpConfig.conditions) {
if (config.httpConfig.protocol && config.httpConfig.domain) {
return config.httpConfig.protocol + "://" + config.httpConfig.domain;
} }
} else if (row && row.type === "PATH" && row.details.length > 0 && row.details[0].name) {
return row.details[0].value === "equals" ? this.$t("commons.adv_search.operators.equals") + row.details[0].name : this.$t("api_test.request.assertions.contains") + row.details[0].name;
} else {
return ""; return "";
}
},
list() {
if (!this.projectList || this.projectList.length === 0) { //
this.$get("/project/listAll", (response) => {
this.projectList = response.data; //,
this.projectList.forEach(project => {
this.idNameMap.set(project.id, project.name);
this.projectIds.push(project.id);
this.projectFilters.push({
text: project.name,
value: project.id,
})
});
this.getEnvironments();
})
} else { } else {
this.getEnvironments() if (config.httpConfig.conditions.length === 1) {
} let obj = config.httpConfig.conditions[0];
}, if (obj.protocol && obj.domain) {
getEnvironments(projectIds){ return obj.protocol + "://" + obj.domain;
this.environments = [];
if (projectIds && projectIds.length > 0) {
this.condition.projectIds = projectIds;
} else {
this.condition.projectIds = this.projectIds;
}
let url = '/api/environment/list/' + this.currentPage + '/' + this.pageSize;
this.result = this.$post(url, this.condition, response => {
this.environments = response.data.listObject;
this.total = response.data.itemCount;
})
},
createEnv() {
this.currentProjectId = '';
this.dialogTitle = this.$t('api_test.environment.create');
this.dialogVisible = true;
this.currentEnvironment = new Environment();
},
search() {
this.list()
},
editEnv(environment) {
this.dialogTitle = this.$t('api_test.environment.config_environment');
this.currentProjectId = environment.projectId;
const temEnv = {};
Object.assign(temEnv, environment);
parseEnvironment(temEnv); //parseEnvironment
this.currentEnvironment = temEnv;
this.dialogVisible = true;
},
copyEnv(environment) {
this.currentProjectId = environment.projectId; //
this.dialogTitle = this.$t('api_test.environment.copy_environment');
const temEnv = {};
Object.assign(temEnv, environment);
parseEnvironment(temEnv); //parseEnvironment
let newEnvironment = new Environment(temEnv);
newEnvironment.id = null;
newEnvironment.name = this.getNoRepeatName(newEnvironment.name);
this.dialogVisible = true;
this.currentEnvironment = newEnvironment;
},
deleteEnv(environment) {
if (environment.id) {
this.$confirm(this.$t('commons.confirm_delete') + environment.name, {
confirmButtonText: this.$t('commons.confirm'),
cancelButtonText: this.$t('commons.cancel'),
type: "warning"
}).then(() => {
this.result = this.$get('/api/environment/delete/' + environment.id, () => {
this.$success(this.$t('commons.delete_success'));
this.list();
});
}).catch(() => {
this.$info(this.$t('commons.delete_cancelled'));
})
}
},
getNoRepeatName(name) {
for (let i in this.environments) {
if (this.environments[i].name === name) {
return this.getNoRepeatName(name + ' copy');
}
}
return name;
},
//
filter(filters) {
this.getEnvironments(filters.projectId)
},
//
close() {
this.dialogVisible = false;
this.$refs.environmentEdit.clearValidate();
},
refresh() {
this.list();
},
handleSelectionChange(value) {
this.selectRows = value;
},
importJSON() {
this.$refs.envImport.open();
},
exportJSON() {
if (this.selectRows.length < 1) {
this.$warning(this.$t('api_test.environment.select_environment'));
return;
}
//idprojectId
const envs = JSON.parse(JSON.stringify(this.selectRows));
envs.map(env => { //idprojectId
if (env.config){ //config
let tempConfig = JSON.parse(env.config);
if (tempConfig.httpConfig.conditions && tempConfig.httpConfig.conditions.length > 0) {
tempConfig.httpConfig.conditions = tempConfig.httpConfig.conditions.filter(condition => { //
return condition.type !== 'MODULE';
});
env.config = JSON.stringify(tempConfig);
} }
} } else if (config.httpConfig.conditions.length > 1) {
delete env.id; return "SHOW_INFO";
delete env.projectId;
})
downloadFile('MS_' + envs.length + '_Environments.json', JSON.stringify(envs));
},
handleProjectChange() { //,
this.currentEnvironment.config.httpConfig.conditions = [];
},
parseDomainName(environment) { //
if (environment.config) {
const config = JSON.parse(environment.config);
if (config.httpConfig && !config.httpConfig.conditions) {
if (config.httpConfig.protocol && config.httpConfig.domain) {
return config.httpConfig.protocol + "://" + config.httpConfig.domain;
}
return "";
} else { } else {
if (config.httpConfig.conditions.length === 1) { return "";
let obj = config.httpConfig.conditions[0];
if (obj.protocol && obj.domain) {
return obj.protocol + "://" + obj.domain;
}
} else if (config.httpConfig.conditions.length > 1) {
return "SHOW_INFO";
}
else {
return "";
}
} }
} else { //config,protocoldomain
return environment.protocol + '://' + environment.domain;
} }
} else { //config,protocoldomain
return environment.protocol + '://' + environment.domain;
} }
}
}, },
};
}
</script> </script>
<style scoped> <style scoped>
.item-bar { .item-bar {
width: 100%; width: 100%;
background: #F9F9F9; background: #F9F9F9;
padding: 5px 10px; padding: 5px 10px;
box-sizing: border-box; box-sizing: border-box;
border: solid 1px #e6e6e6; border: solid 1px #e6e6e6;
} }
.item-selected { .item-selected {
background: #ECF5FF; background: #ECF5FF;
border-left: solid #409EFF 5px; border-left: solid #409EFF 5px;
} }
.item-selected .item-right { .item-selected .item-right {
visibility: visible; visibility: visible;
} }
.environment-edit { .environment-edit {
margin-left: 0; margin-left: 0;
width: 100%; width: 100%;
border: 0; border: 0;
} }
.project-item { .project-item {
padding-left: 10px; padding-left: 10px;
padding-right: 20px; padding-right: 10px;
} }
.project-item .el-select { .project-item .el-select {
margin-top: 15px; width: 100%;
} }
</style> </style>