diff --git a/frontend/src/business/components/api/automation/scenario/EditApiScenario.vue b/frontend/src/business/components/api/automation/scenario/EditApiScenario.vue index facbe14a16..d92cdd4c7d 100644 --- a/frontend/src/business/components/api/automation/scenario/EditApiScenario.vue +++ b/frontend/src/business/components/api/automation/scenario/EditApiScenario.vue @@ -105,7 +105,7 @@ -
+
@@ -144,9 +144,11 @@ :project-list="projectList" ref="envPopover"/> - {{ $t('api_test.request.debug') }} - + + {{ $t('api_test.request.debug') }} + + @@ -158,8 +160,9 @@
+ -
+
@@ -279,7 +282,14 @@ import { import {parseEnvironment} from "../../definition/model/EnvironmentModel"; import {ELEMENT_TYPE, ELEMENTS} from "./Setting"; import MsApiCustomize from "./ApiCustomize"; -import {getUUID, objToStrMap, strMapToObj, handleCtrlSEvent, getCurrentProjectID} from "@/common/js/utils"; +import { + getUUID, + objToStrMap, + strMapToObj, + handleCtrlSEvent, + getCurrentProjectID, + handleCtrlREvent +} from "@/common/js/utils"; import ApiEnvironmentConfig from "@/business/components/api/test/components/ApiEnvironmentConfig"; import MsInputTag from "./MsInputTag"; import MsRun from "./DebugRun"; @@ -392,7 +402,8 @@ export default { stepEnable: true, envResult: { loading: false - } + }, + isTop: false, } }, created() { @@ -403,8 +414,11 @@ export default { this.getWsProjects(); this.getMaintainerOptions(); this.getApiScenario(); - this.addListener(); // 添加 ctrl s 监听 - + }, + mounted() { + this.$nextTick(() => { + this.addListener(); + }); }, directives: {OutsideClick}, computed: { @@ -561,14 +575,20 @@ export default { }, addListener() { document.addEventListener("keydown", this.createCtrlSHandle); - // document.addEventListener("keydown", (even => handleCtrlSEvent(even, this.$refs.httpApi.saveApi))); + document.addEventListener("keydown", this.createCtrlRHandle); + document.addEventListener("scroll", this.handleScroll, true); }, removeListener() { document.removeEventListener("keydown", this.createCtrlSHandle); + document.removeEventListener("keydown", this.createCtrlRHandle); + document.removeEventListener("scroll", this.handleScroll); }, createCtrlSHandle(event) { handleCtrlSEvent(event, this.editScenario); }, + createCtrlRHandle(event) { + handleCtrlREvent(event, this.runDebug); + }, getIdx(index) { return index - 0.33 }, @@ -870,7 +890,7 @@ export default { }, runDebug() { /*触发执行操作*/ - this.$refs['currentScenario'].validate((valid) => { + this.$refs.currentScenario.validate((valid) => { if (valid) { let definition = JSON.parse(JSON.stringify(this.currentScenario)); definition.hashTree = this.scenarioDefinition; @@ -1252,6 +1272,17 @@ export default { disableAll() { this.stepEnable = false; this.stepNode(); + }, + handleScroll() { + let stepInfo = this.$refs.stepInfo; + let debugHeader = this.$refs.debugHeader; + let originWidth = debugHeader.clientWidth; + if (stepInfo.getBoundingClientRect().top <= 178) { + this.isTop = true; + debugHeader.style.width = originWidth + 'px'; + } else { + this.isTop = false; + } } } } @@ -1421,4 +1452,11 @@ export default { .ms-open-btn-left { margin-left: 35px; } + +.is-top { + position: fixed; + top: 125px; + background: white; + z-index: 999; +} diff --git a/frontend/src/business/components/track/plan/view/comonents/functional/FunctionalTestCaseList.vue b/frontend/src/business/components/track/plan/view/comonents/functional/FunctionalTestCaseList.vue index 6ba4123c77..139beab7d3 100644 --- a/frontend/src/business/components/track/plan/view/comonents/functional/FunctionalTestCaseList.vue +++ b/frontend/src/business/components/track/plan/view/comonents/functional/FunctionalTestCaseList.vue @@ -73,7 +73,7 @@