fix(测试跟踪): 高级搜索后切换项目-搜索条件未重置

--bug=1025858 --user=宋天阳 【测试跟踪】测试计划-关联接口用例-高级搜索后切换项目-搜索条件未重置
https://www.tapd.cn/55049933/s/1369161
This commit is contained in:
song-tianyang 2023-05-05 19:34:57 +08:00 committed by 建国
parent f7e8e33148
commit e2ef163c03
3 changed files with 270 additions and 207 deletions

View File

@ -1,33 +1,34 @@
<template> <template>
<span> <span>
<slot name="header"></slot> <slot name="header"></slot>
<ms-search <ms-search v-if="resetOver" :condition.sync="condition" @search="search">
:condition.sync="condition"
@search="search">
</ms-search> </ms-search>
<ms-table :data="tableData" :select-node-ids="selectNodeIds" :condition="condition" :page-size="pageSize" <ms-table
:total="total" enableSelection @selectCountChange="selectCountChange" :data="tableData"
:screenHeight="screenHeight" :select-node-ids="selectNodeIds"
row-key="id" :condition="condition"
:reserve-option="true" :page-size="pageSize"
:page-refresh="pageRefresh" :total="total"
operator-width="170px" enableSelection
@order="initTable" @selectCountChange="selectCountChange"
@filter="search" :screenHeight="screenHeight"
ref="apitable"> row-key="id"
<ms-table-column :reserve-option="true"
prop="num" :page-refresh="pageRefresh"
label="ID" operator-width="170px"
min-width="80px" @order="initTable"
sortable> @filter="search"
ref="apitable"
>
<ms-table-column prop="num" label="ID" min-width="80px" sortable>
</ms-table-column> </ms-table-column>
<ms-table-column <ms-table-column
prop="name" prop="name"
:label="$t('api_test.definition.api_name')" :label="$t('api_test.definition.api_name')"
sortable sortable
width="120px"/> width="120px"
/>
<ms-table-column <ms-table-column
prop="method" prop="method"
@ -35,11 +36,17 @@
column-key="method" column-key="method"
:filters="methodFilters" :filters="methodFilters"
:label="getApiRequestTypeName" :label="getApiRequestTypeName"
width="120px"> width="120px"
>
<template v-slot:default="scope"> <template v-slot:default="scope">
<el-tag size="mini" <el-tag
:style="{'background-color': getColor(true, scope.row.method), border: getColor(true, scope.row.method)}" size="mini"
class="api-el-tag"> :style="{
'background-color': getColor(true, scope.row.method),
border: getColor(true, scope.row.method),
}"
class="api-el-tag"
>
{{ scope.row.method }} {{ scope.row.method }}
</el-tag> </el-tag>
</template> </template>
@ -51,57 +58,70 @@
:filters="userFilters" :filters="userFilters"
column-key="user_id" column-key="user_id"
:label="$t('api_test.definition.api_principal')" :label="$t('api_test.definition.api_principal')"
width="100px"/> width="100px"
/>
<ms-table-column <ms-table-column
prop="path" prop="path"
width="120px" width="120px"
:label="$t('api_test.definition.api_path')"/> :label="$t('api_test.definition.api_path')"
/>
<ms-table-column prop="tags" :label="$t('commons.tag')" width="120px" :show-overflow-tooltip="false"> <ms-table-column
<template v-slot:default="scope"> prop="tags"
<el-tooltip class="item" effect="dark" placement="top"> :label="$t('commons.tag')"
<div v-html="getTagToolTips(scope.row.tags)" slot="content"></div> width="120px"
<div class="oneLine"> :show-overflow-tooltip="false"
<ms-tag >
v-for="(itemName, index) in scope.row.tags" <template v-slot:default="scope">
:key="index" <el-tooltip class="item" effect="dark" placement="top">
type="success" <div v-html="getTagToolTips(scope.row.tags)" slot="content"></div>
effect="plain" <div class="oneLine">
:show-tooltip="scope.row.tags.length === 1 && itemName.length * 12 <= 100" <ms-tag
:content="itemName" v-for="(itemName, index) in scope.row.tags"
style="margin-left: 0px; margin-right: 2px" /> :key="index"
</div> type="success"
</el-tooltip> effect="plain"
</template> :show-tooltip="
scope.row.tags.length === 1 && itemName.length * 12 <= 100
"
:content="itemName"
style="margin-left: 0px; margin-right: 2px"
/>
</div>
</el-tooltip>
</template>
</ms-table-column> </ms-table-column>
<ms-table-column <ms-table-column
v-if="versionEnable" v-if="versionEnable"
:label="$t('project.version.name')" :label="$t('project.version.name')"
:filters="versionFilters" :filters="versionFilters"
min-width="100px" min-width="100px"
prop="versionId"> prop="versionId"
>
<template v-slot:default="scope"> <template v-slot:default="scope">
<span>{{ scope.row.versionName }}</span> <span>{{ scope.row.versionName }}</span>
</template> </template>
</ms-table-column> </ms-table-column>
<ms-table-column <ms-table-column
sortable="createTime" sortable="createTime"
width="160px" width="160px"
:label="$t('commons.create_time')" :label="$t('commons.create_time')"
prop="createTime"> prop="createTime"
<template v-slot:default="scope"> >
<span>{{ scope.row.createTime | datetimeFormat }}</span> <template v-slot:default="scope">
</template> <span>{{ scope.row.createTime | datetimeFormat }}</span>
</ms-table-column> </template>
</ms-table-column>
<ms-table-column <ms-table-column
width="160" width="160"
:label="$t('api_test.definition.api_last_time')" :label="$t('api_test.definition.api_last_time')"
sortable="custom" sortable="custom"
prop="updateTime"> prop="updateTime"
>
<template v-slot:default="scope"> <template v-slot:default="scope">
<span>{{ scope.row.updateTime | datetimeFormat }}</span> <span>{{ scope.row.updateTime | datetimeFormat }}</span>
</template> </template>
@ -110,18 +130,19 @@
<ms-table-column <ms-table-column
prop="caseTotal" prop="caseTotal"
width="80px" width="80px"
:label="$t('api_test.definition.api_case_number')"/> :label="$t('api_test.definition.api_case_number')"
/>
</ms-table> </ms-table>
<ms-table-pagination :change="pageChange" :current-page.sync="currentPage" :page-size.sync="pageSize" <ms-table-pagination
:total="total"/> :change="pageChange"
:current-page.sync="currentPage"
:page-size.sync="pageSize"
:total="total"
/>
</span> </span>
</template> </template>
<script> <script>
import MsTable from "../../../table/MsTable"; import MsTable from "../../../table/MsTable";
import MsTableColumn from "../../../table/MsTableColumn"; import MsTableColumn from "../../../table/MsTableColumn";
import MsTableOperator from "../../../MsTableOperator"; import MsTableOperator from "../../../MsTableOperator";
@ -131,15 +152,15 @@ import MsTag from "../../../MsTag";
import MsTableAdvSearchBar from "../../../search/MsTableAdvSearchBar"; import MsTableAdvSearchBar from "../../../search/MsTableAdvSearchBar";
import ShowMoreBtn from "../../../table/ShowMoreBtn"; import ShowMoreBtn from "../../../table/ShowMoreBtn";
import MsSearch from "../../../search/MsSearch"; import MsSearch from "../../../search/MsSearch";
import {API_METHOD_COLOUR} from "../../../../model/JsonData"; import { API_METHOD_COLOUR } from "../../../../model/JsonData";
import PriorityTableItem from "../PriorityTableItem"; import PriorityTableItem from "../PriorityTableItem";
import MsEnvironmentSelect from "./MsEnvironmentSelect"; import MsEnvironmentSelect from "./MsEnvironmentSelect";
import {getProtocolFilter} from "../api-definition"; import { getProtocolFilter } from "../api-definition";
import {getProjectMemberById} from "../../../../api/user"; import { getProjectMemberById } from "../../../../api/user";
import TableSelectCountBar from "../ext/TableSelectCountBar"; import TableSelectCountBar from "../ext/TableSelectCountBar";
import {hasLicense} from "../../../../utils/permission"; import { hasLicense } from "../../../../utils/permission";
import {isProjectVersionEnable} from "../../../../api/version"; import { isProjectVersionEnable } from "../../../../api/version";
export default { export default {
name: "ApiTableList", name: "ApiTableList",
@ -155,19 +176,17 @@ export default {
MsTable, MsTable,
MsTableColumn, MsTableColumn,
MsTableAdvSearchBar, MsTableAdvSearchBar,
MsSearch MsSearch,
}, },
data() { data() {
return { return {
moduleId: "", moduleId: "",
typeArr: [ typeArr: [{ id: "priority", name: this.$t("test_track.case.priority") }],
{id: 'priority', name: this.$t('test_track.case.priority')},
],
priorityFilters: [ priorityFilters: [
{text: 'P0', value: 'P0'}, { text: "P0", value: "P0" },
{text: 'P1', value: 'P1'}, { text: "P1", value: "P1" },
{text: 'P2', value: 'P2'}, { text: "P2", value: "P2" },
{text: 'P3', value: 'P3'} { text: "P3", value: "P3" },
], ],
methodColorMap: new Map(API_METHOD_COLOUR), methodColorMap: new Map(API_METHOD_COLOUR),
methodFilters: [], methodFilters: [],
@ -176,6 +195,7 @@ export default {
pageSize: 10, pageSize: 10,
versionEnable: false, versionEnable: false,
pageRefresh: false, pageRefresh: false,
resetOver: true,
}; };
}, },
props: { props: {
@ -190,9 +210,9 @@ export default {
screenHeight: { screenHeight: {
type: [Number, String], type: [Number, String],
default() { default() {
return 'calc(100vh - 400px)'; return "calc(100vh - 400px)";
} },
} },
}, },
created() { created() {
this.getUserFilter(); this.getUserFilter();
@ -215,9 +235,9 @@ export default {
}, },
mounted() { mounted() {
if (this.$refs.apitable) { if (this.$refs.apitable) {
this.$emit('setSelectRow', this.$refs.apitable.getSelectRows()); this.$emit("setSelectRow", this.$refs.apitable.getSelectRows());
} else { } else {
this.$emit('setSelectRow', new Set()); this.$emit("setSelectRow", new Set());
} }
if (this.$refs.apitable) { if (this.$refs.apitable) {
@ -226,20 +246,20 @@ export default {
}, },
computed: { computed: {
getApiRequestTypeName() { getApiRequestTypeName() {
if (this.currentProtocol === 'TCP') { if (this.currentProtocol === "TCP") {
return this.$t('api_test.definition.api_agreement'); return this.$t("api_test.definition.api_agreement");
} else { } else {
return this.$t('api_test.definition.api_type'); return this.$t("api_test.definition.api_type");
} }
}, },
}, },
methods: { methods: {
selectCountChange(value) { selectCountChange(value) {
this.$emit('selectCountChange', value) this.$emit("selectCountChange", value);
if (this.$refs.apitable) { if (this.$refs.apitable) {
this.$emit('setSelectRow', this.$refs.apitable.getSelectRows()); this.$emit("setSelectRow", this.$refs.apitable.getSelectRows());
} else { } else {
this.$emit('setSelectRow', new Set()); this.$emit("setSelectRow", new Set());
} }
}, },
getColor(flag, method) { getColor(flag, method) {
@ -261,21 +281,25 @@ export default {
}, },
initTable(data) { initTable(data) {
this.pageRefresh = data === "page"; this.pageRefresh = data === "page";
this.$emit('refreshTable'); this.$emit("refreshTable");
}, },
clear() { clear() {
if (this.$refs.apitable) { if (this.$refs.apitable) {
this.$refs.apitable.clear(); this.$refs.apitable.clear();
} }
this.resetOver = false;
this.$nextTick(() => {
this.resetOver = true;
});
}, },
checkVersionEnable() { checkVersionEnable() {
if (!this.projectId) { if (!this.projectId) {
return; return;
} }
if (hasLicense()) { if (hasLicense()) {
isProjectVersionEnable(this.projectId).then(res => { isProjectVersionEnable(this.projectId).then((res) => {
this.versionEnable = res.data; this.versionEnable = res.data;
}) });
} }
}, },
getUserFilter() { getUserFilter() {
@ -283,21 +307,21 @@ export default {
if (!this.projectId) { if (!this.projectId) {
return; return;
} }
getProjectMemberById(this.projectId).then(res => { getProjectMemberById(this.projectId).then((res) => {
this.userFilters = res.data.map(u => { this.userFilters = res.data.map((u) => {
return {text: u.name, value: u.id}; return { text: u.name, value: u.id };
}); });
}); });
}, },
getTagToolTips(tags) { getTagToolTips(tags) {
try { try {
let showTips = ''; let showTips = "";
tags.forEach((item) => { tags.forEach((item) => {
showTips += item + ','; showTips += item + ",";
}); });
return showTips.substr(0, showTips.length - 1); return showTips.substr(0, showTips.length - 1);
} catch (e) { } catch (e) {
return ''; return "";
} }
}, },
}, },
@ -305,10 +329,9 @@ export default {
</script> </script>
<style scoped> <style scoped>
.request-method { .request-method {
padding: 0 5px; padding: 0 5px;
color: #1E90FF; color: #1e90ff;
} }
.api-el-tag { .api-el-tag {
@ -331,5 +354,4 @@ export default {
white-space: nowrap; white-space: nowrap;
text-overflow: ellipsis; text-overflow: ellipsis;
} }
</style> </style>

View File

@ -2,45 +2,58 @@
<div v-loading="loading"> <div v-loading="loading">
<api-list-container <api-list-container
:is-api-list-enable="isApiListEnable" :is-api-list-enable="isApiListEnable"
@isApiListEnableChange="isApiListEnableChange"> @isApiListEnableChange="isApiListEnableChange"
>
<template> <template>
<slot name="version"></slot> <slot name="version"></slot>
</template> </template>
<ms-environment-select :project-id="projectId" :is-read-only="isReadOnly" <ms-environment-select
@setEnvironment="setEnvironment" ref="msEnvironmentSelect"/> :project-id="projectId"
:is-read-only="isReadOnly"
@setEnvironment="setEnvironment"
ref="msEnvironmentSelect"
/>
<ms-search <ms-search
:condition.sync="condition" :condition.sync="condition"
@search="initTable"> v-if="clearOver"
@search="initTable"
>
</ms-search> </ms-search>
<ms-table :data="tableData" :select-node-ids="selectNodeIds" :condition="condition" :page-size="pageSize" <ms-table
:total="total" enableSelection :data="tableData"
:screenHeight="screenHeight" :select-node-ids="selectNodeIds"
row-key="id" :condition="condition"
:reserve-option="true" :page-size="pageSize"
:page-refresh="pageRefresh" :total="total"
@refresh="initTable" enableSelection
@selectCountChange="selectCountChange" :screenHeight="screenHeight"
operator-width="170px" row-key="id"
ref="table"> :reserve-option="true"
:page-refresh="pageRefresh"
<ms-table-column @refresh="initTable"
prop="num" @selectCountChange="selectCountChange"
label="ID" operator-width="170px"
width="80px" ref="table"
sortable=true> >
<ms-table-column prop="num" label="ID" width="80px" sortable="true">
</ms-table-column> </ms-table-column>
<ms-table-column prop="name" width="160px" :label="$t('test_track.case.name')"/> <ms-table-column
prop="name"
width="160px"
:label="$t('test_track.case.name')"
/>
<ms-table-column <ms-table-column
prop="priority" prop="priority"
:filters="priorityFilters" :filters="priorityFilters"
column-key="priority" column-key="priority"
width="120px" width="120px"
:label="$t('test_track.case.priority')"> :label="$t('test_track.case.priority')"
>
<template v-slot:default="scope"> <template v-slot:default="scope">
<priority-table-item :value="scope.row.priority"/> <priority-table-item :value="scope.row.priority" />
</template> </template>
</ms-table-column> </ms-table-column>
@ -48,9 +61,15 @@
sortable="custom" sortable="custom"
prop="path" prop="path"
width="180px" width="180px"
:label="'API'+ $t('api_test.definition.api_path')"/> :label="'API' + $t('api_test.definition.api_path')"
/>
<ms-table-column prop="tags" width="120px" :label="$t('commons.tag')" :show-overflow-tooltip="false"> <ms-table-column
prop="tags"
width="120px"
:label="$t('commons.tag')"
:show-overflow-tooltip="false"
>
<template v-slot:default="scope"> <template v-slot:default="scope">
<el-tooltip class="item" effect="dark" placement="top"> <el-tooltip class="item" effect="dark" placement="top">
<div v-html="getTagToolTips(scope.row.tags)" slot="content"></div> <div v-html="getTagToolTips(scope.row.tags)" slot="content"></div>
@ -60,9 +79,12 @@
:key="index" :key="index"
type="success" type="success"
effect="plain" effect="plain"
:show-tooltip="scope.row.tags.length === 1 && itemName.length * 12 <= 100" :show-tooltip="
scope.row.tags.length === 1 && itemName.length * 12 <= 100
"
:content="itemName" :content="itemName"
style="margin-left: 0px; margin-right: 2px" /> style="margin-left: 0px; margin-right: 2px"
/>
</div> </div>
</el-tooltip> </el-tooltip>
</template> </template>
@ -73,21 +95,21 @@
:label="$t('project.version.name')" :label="$t('project.version.name')"
:filters="versionFilters" :filters="versionFilters"
min-width="100px" min-width="100px"
prop="versionId"> prop="versionId"
>
<template v-slot:default="scope"> <template v-slot:default="scope">
<span>{{ scope.row.versionName }}</span> <span>{{ scope.row.versionName }}</span>
</template> </template>
</ms-table-column> </ms-table-column>
<ms-table-column <ms-table-column prop="createUser" :label="$t('commons.create_user')" />
prop="createUser"
:label="$t('commons.create_user')"/>
<ms-table-column <ms-table-column
sortable="createTime" sortable="createTime"
width="160px" width="160px"
:label="$t('commons.create_time')" :label="$t('commons.create_time')"
prop="createTime"> prop="createTime"
>
<template v-slot:default="scope"> <template v-slot:default="scope">
<span>{{ scope.row.createTime | datetimeFormat }}</span> <span>{{ scope.row.createTime | datetimeFormat }}</span>
</template> </template>
@ -97,38 +119,45 @@
sortable="updateTime" sortable="updateTime"
width="160px" width="160px"
:label="$t('api_test.definition.api_last_time')" :label="$t('api_test.definition.api_last_time')"
prop="updateTime"> prop="updateTime"
>
<template v-slot:default="scope"> <template v-slot:default="scope">
<span>{{ scope.row.updateTime | datetimeFormat }}</span> <span>{{ scope.row.updateTime | datetimeFormat }}</span>
</template> </template>
</ms-table-column> </ms-table-column>
</ms-table> </ms-table>
<ms-table-pagination :change="pageChange" :current-page.sync="currentPage" :page-size.sync="pageSize" <ms-table-pagination
:total="total"/> :change="pageChange"
:current-page.sync="currentPage"
:page-size.sync="pageSize"
:total="total"
/>
</api-list-container> </api-list-container>
</div> </div>
</template> </template>
<script> <script>
import MsTable from "metersphere-frontend/src/components/table/MsTable"; import MsTable from "metersphere-frontend/src/components/table/MsTable";
import MsTableColumn from "metersphere-frontend/src/components/table/MsTableColumn"; import MsTableColumn from "metersphere-frontend/src/components/table/MsTableColumn";
import MsTablePagination from "metersphere-frontend/src/components/pagination/TablePagination"; import MsTablePagination from "metersphere-frontend/src/components/pagination/TablePagination";
import MsTag from "metersphere-frontend/src/components/MsTag"; import MsTag from "metersphere-frontend/src/components/MsTag";
import {API_METHOD_COLOUR, CASE_PRIORITY} from "metersphere-frontend/src/model/JsonData"; import {
API_METHOD_COLOUR,
CASE_PRIORITY,
} from "metersphere-frontend/src/model/JsonData";
import MsEnvironmentSelect from "metersphere-frontend/src/components/environment/snippet/ext/MsEnvironmentSelect"; import MsEnvironmentSelect from "metersphere-frontend/src/components/environment/snippet/ext/MsEnvironmentSelect";
import MsTableAdvSearchBar from "metersphere-frontend/src/components/search/MsTableAdvSearchBar"; import MsTableAdvSearchBar from "metersphere-frontend/src/components/search/MsTableAdvSearchBar";
import { import { TEST_PLAN_RELEVANCE_API_CASE_CONFIGS } from "metersphere-frontend/src/components/search/search-components";
TEST_PLAN_RELEVANCE_API_CASE_CONFIGS
} from "metersphere-frontend/src/components/search/search-components";
import MsSearch from "metersphere-frontend/src/components/search/MsSearch"; import MsSearch from "metersphere-frontend/src/components/search/MsSearch";
import ApiListContainer from "@/business/plan/view/comonents/api/ApiListContainer"; import ApiListContainer from "@/business/plan/view/comonents/api/ApiListContainer";
import {buildBatchParam, hasLicense, isProjectVersionEnable, parseTag} from "@/business/utils/sdk-utils"; import {
buildBatchParam,
hasLicense,
isProjectVersionEnable,
} from "@/business/utils/sdk-utils";
import PriorityTableItem from "@/business/common/tableItems/planview/PriorityTableItem"; import PriorityTableItem from "@/business/common/tableItems/planview/PriorityTableItem";
import {apiDefinitionGet} from "@/api/remote/api/api-definition"; import { apiDefinitionGet } from "@/api/remote/api/api-definition";
import {testPlanApiCaseRelevanceList} from "@/api/remote/plan/test-plan-api-case"; import { testPlanApiCaseRelevanceList } from "@/api/remote/plan/test-plan-api-case";
export default { export default {
name: "RelevanceCaseList", name: "RelevanceCaseList",
@ -141,37 +170,36 @@ export default {
MsTable, MsTable,
MsTableColumn, MsTableColumn,
MsSearch, MsSearch,
MsTableAdvSearchBar MsTableAdvSearchBar,
}, },
data() { data() {
return { return {
condition: { condition: {
components: TEST_PLAN_RELEVANCE_API_CASE_CONFIGS components: TEST_PLAN_RELEVANCE_API_CASE_CONFIGS,
}, },
selectCase: {}, selectCase: {},
loading: false, loading: false,
moduleId: "", moduleId: "",
typeArr: [ typeArr: [{ id: "priority", name: this.$t("test_track.case.priority") }],
{id: 'priority', name: this.$t('test_track.case.priority')},
],
priorityFilters: [ priorityFilters: [
{text: 'P0', value: 'P0'}, { text: "P0", value: "P0" },
{text: 'P1', value: 'P1'}, { text: "P1", value: "P1" },
{text: 'P2', value: 'P2'}, { text: "P2", value: "P2" },
{text: 'P3', value: 'P3'} { text: "P3", value: "P3" },
], ],
valueArr: { valueArr: {
priority: CASE_PRIORITY, priority: CASE_PRIORITY,
}, },
methodColorMap: new Map(API_METHOD_COLOUR), methodColorMap: new Map(API_METHOD_COLOUR),
screenHeight: 'calc(100vh - 400px)',// screenHeight: "calc(100vh - 400px)", //
tableData: [], tableData: [],
currentPage: 1, currentPage: 1,
clearOver: true,
pageSize: 10, pageSize: 10,
total: 0, total: 0,
environmentId: "", environmentId: "",
versionEnable: false, versionEnable: false,
pageRefresh: false pageRefresh: false,
}; };
}, },
props: { props: {
@ -189,7 +217,7 @@ export default {
}, },
isReadOnly: { isReadOnly: {
type: Boolean, type: Boolean,
default: false default: false,
}, },
projectId: String, projectId: String,
planId: String, planId: String,
@ -208,7 +236,7 @@ export default {
}, },
projectId() { projectId() {
this.condition = { this.condition = {
components: TEST_PLAN_RELEVANCE_API_CASE_CONFIGS components: TEST_PLAN_RELEVANCE_API_CASE_CONFIGS,
}; };
this.selectNodeIds.length = 0; this.selectNodeIds.length = 0;
this.initTable(); this.initTable();
@ -217,7 +245,7 @@ export default {
currentVersion() { currentVersion() {
this.condition.versionId = this.currentVersion; this.condition.versionId = this.currentVersion;
this.initTable(); this.initTable();
} },
}, },
computed: { computed: {
selectRows() { selectRows() {
@ -226,14 +254,14 @@ export default {
} else { } else {
return new Set(); return new Set();
} }
} },
}, },
methods: { methods: {
isApiListEnableChange(data) { isApiListEnableChange(data) {
this.$emit('isApiListEnableChange', data); this.$emit("isApiListEnableChange", data);
}, },
selectCountChange(data) { selectCountChange(data) {
this.$emit('selectCountChange', data); this.$emit("selectCountChange", data);
}, },
pageChange() { pageChange() {
this.initTable(null, "page"); this.initTable(null, "page");
@ -242,7 +270,7 @@ export default {
this.pageRefresh = data === "page"; this.pageRefresh = data === "page";
this.condition.status = ""; this.condition.status = "";
this.condition.moduleIds = this.selectNodeIds; this.condition.moduleIds = this.selectNodeIds;
if (projectId != null && typeof projectId === 'string') { if (projectId != null && typeof projectId === "string") {
this.condition.projectId = projectId; this.condition.projectId = projectId;
} else if (this.projectId != null) { } else if (this.projectId != null) {
this.condition.projectId = this.projectId; this.condition.projectId = this.projectId;
@ -252,22 +280,28 @@ export default {
} }
this.condition.planId = this.planId; this.condition.planId = this.planId;
this.loading = true; this.loading = true;
testPlanApiCaseRelevanceList({pageNum: this.currentPage, pageSize: this.pageSize}, this.condition) testPlanApiCaseRelevanceList(
.then(response => { { pageNum: this.currentPage, pageSize: this.pageSize },
this.loading = false; this.condition
this.total = response.data.itemCount; ).then((response) => {
this.tableData = response.data.listObject; this.loading = false;
this.tableData.forEach(item => { this.total = response.data.itemCount;
if (item.tags && item.tags.length > 0) { this.tableData = response.data.listObject;
item.tags = JSON.parse(item.tags); this.tableData.forEach((item) => {
} if (item.tags && item.tags.length > 0) {
}); item.tags = JSON.parse(item.tags);
}
}); });
});
}, },
clear() { clear() {
if (this.$refs.table) { if (this.$refs.table) {
this.$refs.table.clear(); this.$refs.table.clear();
} }
this.clearOver = false;
this.$nextTick(() => {
this.clearOver = true;
});
}, },
clearEnvAndSelect() { clearEnvAndSelect() {
this.environmentId = ""; this.environmentId = "";
@ -279,39 +313,43 @@ export default {
}, },
getTagToolTips(tags) { getTagToolTips(tags) {
try { try {
let showTips = ''; let showTips = "";
tags.forEach((item) => { tags.forEach((item) => {
showTips += item + ','; showTips += item + ",";
}); });
return showTips.substr(0, showTips.length - 1); return showTips.substr(0, showTips.length - 1);
} catch (e) { } catch (e) {
return ''; return "";
} }
}, },
showExecResult(row) { showExecResult(row) {
this.visible = false; this.visible = false;
this.$emit('showExecResult', row); this.$emit("showExecResult", row);
}, },
buildPagePath(path) { buildPagePath(path) {
return path + "/" + this.currentPage + "/" + this.pageSize; return path + "/" + this.currentPage + "/" + this.pageSize;
}, },
handleTestCase(testCase) { handleTestCase(testCase) {
apiDefinitionGet(testCase.apiDefinitionId) apiDefinitionGet(testCase.apiDefinitionId).then((response) => {
.then((response) => { let api = response.data;
let api = response.data; let selectApi = api;
let selectApi = api; let request = {};
let request = {}; if (
if (Object.prototype.toString.call(api.request).match(/\[object (\w+)\]/)[1].toLowerCase() === 'object') { Object.prototype.toString
request = api.request; .call(api.request)
} else { .match(/\[object (\w+)\]/)[1]
request = JSON.parse(api.request); .toLowerCase() === "object"
} ) {
if (!request.hashTree) { request = api.request;
request.hashTree = []; } else {
} request = JSON.parse(api.request);
selectApi.url = request.path; }
this.$refs.caseList.open(selectApi, testCase.id); if (!request.hashTree) {
}); request.hashTree = [];
}
selectApi.url = request.path;
this.$refs.caseList.open(selectApi, testCase.id);
});
}, },
setEnvironment(data) { setEnvironment(data) {
this.environmentId = data.id; this.environmentId = data.id;
@ -332,8 +370,8 @@ export default {
} else { } else {
param = batchParam; param = batchParam;
} }
param.ids = Array.from(sampleSelectRows).map(row => row.id); param.ids = Array.from(sampleSelectRows).map((row) => row.id);
let tableDataIds = Array.from(this.tableData).map(row => row.id); let tableDataIds = Array.from(this.tableData).map((row) => row.id);
param.ids.sort((a, b) => { param.ids.sort((a, b) => {
return tableDataIds.indexOf(a) - tableDataIds.indexOf(b); return tableDataIds.indexOf(a) - tableDataIds.indexOf(b);
}); });
@ -344,12 +382,11 @@ export default {
return; return;
} }
if (hasLicense()) { if (hasLicense()) {
isProjectVersionEnable(this.projectId) isProjectVersionEnable(this.projectId).then((response) => {
.then(response => { this.versionEnable = response.data;
this.versionEnable = response.data; });
});
} }
} },
}, },
}; };
</script> </script>
@ -362,7 +399,7 @@ export default {
.request-method { .request-method {
padding: 0 5px; padding: 0 5px;
color: #1E90FF; color: #1e90ff;
} }
.api-el-tag { .api-el-tag {
@ -385,5 +422,4 @@ export default {
white-space: nowrap; white-space: nowrap;
text-overflow: ellipsis; text-overflow: ellipsis;
} }
</style> </style>

View File

@ -26,6 +26,7 @@
<ms-search <ms-search
:base-search-tip="$t('api_test.definition.request.select_case')" :base-search-tip="$t('api_test.definition.request.select_case')"
:condition.sync="condition" :condition.sync="condition"
v-if="clearOver"
style="margin-top: 10px" style="margin-top: 10px"
@search="filterSearch" @search="filterSearch"
> >
@ -167,8 +168,7 @@
<script> <script>
import MsTableHeader from "metersphere-frontend/src/components/MsTableHeader"; import MsTableHeader from "metersphere-frontend/src/components/MsTableHeader";
import MsTablePagination from "metersphere-frontend/src/components/pagination/TablePagination"; import MsTablePagination from "metersphere-frontend/src/components/pagination/TablePagination";
import MsTag from "metersphere-frontend/src/components/MsTag"; import MsTag from "metersphere-frontend/src/components/MsTag"; // import MsApiReportDetail from "../../../../../api/automation/report/ApiReportDetail";
// import MsApiReportDetail from "../../../../../api/automation/report/ApiReportDetail";
import TestPlanScenarioListHeader from "./TestPlanScenarioListHeader"; import TestPlanScenarioListHeader from "./TestPlanScenarioListHeader";
import PriorityTableItem from "@/business/common/tableItems/planview/PriorityTableItem"; import PriorityTableItem from "@/business/common/tableItems/planview/PriorityTableItem";
import MsTableAdvSearchBar from "metersphere-frontend/src/components/search/MsTableAdvSearchBar"; import MsTableAdvSearchBar from "metersphere-frontend/src/components/search/MsTableAdvSearchBar";
@ -228,6 +228,7 @@ export default {
currentScenario: {}, currentScenario: {},
schedule: {}, schedule: {},
tableData: [], tableData: [],
clearOver: true,
currentPage: 1, currentPage: 1,
pageSize: 10, pageSize: 10,
total: 0, total: 0,
@ -320,6 +321,10 @@ export default {
}, },
clear() { clear() {
this.selectRows.clear(); this.selectRows.clear();
this.clearOver = false;
this.$nextTick(() => {
this.clearOver = true;
});
}, },
setProjectEnvMap(projectEnvMap) { setProjectEnvMap(projectEnvMap) {
this.projectEnvMap = projectEnvMap; this.projectEnvMap = projectEnvMap;