diff --git a/frontend/src/api/modules/api-test/scenario.ts b/frontend/src/api/modules/api-test/scenario.ts index ad6414228f..ced0cc0e66 100644 --- a/frontend/src/api/modules/api-test/scenario.ts +++ b/frontend/src/api/modules/api-test/scenario.ts @@ -284,5 +284,5 @@ export function updateScenarioPro(id: string | number, priority: CaseLevel | und // 获取跨项目信息 export function getStepProjectInfo(id: string, type: ScenarioStepType) { - return MSR.get({ url: GetStepProjectInfoUrl, params: id, data: { resourceType: type } }); + return MSR.get({ url: `${GetStepProjectInfoUrl}/${id}`, params: { resourceType: type } }); } diff --git a/frontend/src/components/business/ms-tree/index.vue b/frontend/src/components/business/ms-tree/index.vue index dc71ef624a..5c1881ccb7 100644 --- a/frontend/src/components/business/ms-tree/index.vue +++ b/frontend/src/components/business/ms-tree/index.vue @@ -197,21 +197,6 @@ init(true); }); - const filterTreeData = ref([]); // 初始化时全量的树数据或在非搜索情况下更新后的全量树数据 - - watch( - () => data.value, - (val) => { - if (!props.keyword) { - filterTreeData.value = cloneDeep(val); - } - }, - { - deep: true, - immediate: true, - } - ); - /** * 根据关键字过滤树节点 * @param keyword 搜索关键字 @@ -240,6 +225,8 @@ return search(data.value); } + const filterTreeData = ref([]); // 初始化时全量的树数据或在非搜索情况下更新后的全量树数据 + // 防抖搜索 const updateDebouncedSearch = debounce(() => { if (props.keyword) { @@ -251,11 +238,26 @@ } }, props.searchDebounce); + watch( + () => data.value, + (val) => { + if (!props.keyword) { + filterTreeData.value = val; + } else { + updateDebouncedSearch(); + } + }, + { + deep: true, + immediate: true, + } + ); + watch( () => props.keyword, (val) => { if (!val) { - filterTreeData.value = cloneDeep(data.value); + filterTreeData.value = data.value; } else { updateDebouncedSearch(); } diff --git a/frontend/src/store/modules/user/index.ts b/frontend/src/store/modules/user/index.ts index 05c60030e7..f99e95ea5f 100644 --- a/frontend/src/store/modules/user/index.ts +++ b/frontend/src/store/modules/user/index.ts @@ -107,6 +107,7 @@ const useUserStore = defineStore('user', { appStore.setCurrentOrgId(res.lastOrganizationId || ''); appStore.setCurrentProjectId(res.lastProjectId || ''); this.setInfo(res); + this.initLocalConfig(); // 获取本地执行配置 } catch (err) { clearToken(); throw err; diff --git a/frontend/src/views/api-test/scenario/components/common/customApiDrawer.vue b/frontend/src/views/api-test/scenario/components/common/customApiDrawer.vue index 1084d54d3d..f8376b57f5 100644 --- a/frontend/src/views/api-test/scenario/components/common/customApiDrawer.vue +++ b/frontend/src/views/api-test/scenario/components/common/customApiDrawer.vue @@ -6,6 +6,7 @@ :show-continue="true" :footer="requestVModel.isNew === true" :ok-disabled="requestVModel.executeLoading || (isHttpProtocol && !requestVModel.url)" + show-full-screen @confirm="handleSave" @continue="handleContinue" @close="handleClose" @@ -23,21 +24,21 @@
+ + + {{ t('common.delete') }} +
(); @@ -446,7 +449,7 @@ // 注入祖先组件提供的属性 const scenarioId = inject('scenarioId'); const currentEnvConfig = inject>('currentEnvConfig'); - const hasLocalExec = inject>('isPriorityLocalExec'); + const hasLocalExec = inject>('hasLocalExec'); const isPriorityLocalExec = inject>('isPriorityLocalExec'); const visible = defineModel('visible', { required: true }); diff --git a/frontend/src/views/api-test/scenario/components/common/customCaseDrawer.vue b/frontend/src/views/api-test/scenario/components/common/customCaseDrawer.vue index fde28cf41f..c5cd2948f2 100644 --- a/frontend/src/views/api-test/scenario/components/common/customCaseDrawer.vue +++ b/frontend/src/views/api-test/scenario/components/common/customCaseDrawer.vue @@ -29,13 +29,13 @@
@@ -350,6 +350,7 @@ // 注入祖先组件提供的属性 const scenarioId = inject('scenarioId'); const isPriorityLocalExec = inject>('isPriorityLocalExec'); + const hasLocalExec = inject>('hasLocalExec'); const defaultApiParams: RequestParam = { name: '', @@ -620,8 +621,6 @@ } } - const hasLocalExec = ref(false); // 是否配置了api本地执行 - const pluginScriptMap = ref>({}); // 存储初始化过后的插件配置 const temporaryPluginFormMap: Record = {}; // 缓存插件表单,避免切换传入的 API 数据导致动态表单数据丢失 const pluginLoading = ref(false); diff --git a/frontend/src/views/api-test/scenario/components/step/stepNodeComposition/quoteContent.vue b/frontend/src/views/api-test/scenario/components/step/stepNodeComposition/quoteContent.vue index 6d7de16160..780c7119e1 100644 --- a/frontend/src/views/api-test/scenario/components/step/stepNodeComposition/quoteContent.vue +++ b/frontend/src/views/api-test/scenario/components/step/stepNodeComposition/quoteContent.vue @@ -13,20 +13,22 @@ > (); - + const loading = ref(false); async function handleVisibleChange(val: boolean) { - if (val && props.data.originProjectId) { - originProjectInfo.value = await getStepProjectInfo(props.data.resourceId || '', props.data.stepType); + try { + loading.value = true; + if (val && props.data.originProjectId) { + originProjectInfo.value = await getStepProjectInfo(props.data.resourceId || '', props.data.stepType); + } + } catch (error) { + // eslint-disable-next-line no-console + console.log(error); + } finally { + loading.value = false; } } diff --git a/frontend/src/views/api-test/scenario/components/step/stepTree.vue b/frontend/src/views/api-test/scenario/components/step/stepTree.vue index 53a751b93c..51fda01fa6 100644 --- a/frontend/src/views/api-test/scenario/components/step/stepTree.vue +++ b/frontend/src/views/api-test/scenario/components/step/stepTree.vue @@ -220,6 +220,7 @@ :permission-map="permissionMap" :steps="steps" @add-step="addCustomApiStep" + @delete-step="deleteStep(activeStep)" @apply-step="applyApiStep" @stop-debug="handleStopExecute(activeStep)" @execute="handleApiExecute" @@ -235,7 +236,7 @@ :step-responses="scenario.stepResponses" :permission-map="permissionMap" @apply-step="applyApiStep" - @delete-step="deleteCaseStep(activeStep)" + @delete-step="deleteStep(activeStep)" @stop-debug="handleStopExecute(activeStep)" @execute="(request, executeType) => handleApiExecute((request as unknown as RequestParam), executeType)" @replace="handleReplaceStep" @@ -1525,12 +1526,14 @@ /** * 删除 */ - function deleteCaseStep(step?: ScenarioStepItem) { + function deleteStep(step?: ScenarioStepItem) { if (step) { customCaseDrawerVisible.value = false; + customApiDrawerVisible.value = false; deleteNode(steps.value, step.uniqueId, 'uniqueId'); activeStep.value = undefined; scenario.value.unSaved = true; + Message.success(t('common.deleteSuccess')); } }