From fe6e055a1510fdc32fee2e2b8af32b8f0dfa9c7b Mon Sep 17 00:00:00 2001 From: song_xiao_lin <63901989+song-xiao-lin@users.noreply.github.com> Date: Fri, 27 Dec 2024 15:58:53 +0800 Subject: [PATCH] Song/feat/mitm has params adjust (#2251) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * feat: mitm带参弹窗改为抽屉 * style: 样式调整 --- .../JsonFormWrapper/JsonFormWrapper.tsx | 2 +- .../mitm/MITMYakScriptLoader.module.scss | 2 - .../src/pages/mitm/MITMYakScriptLoader.tsx | 118 +++++++++++------- 3 files changed, 73 insertions(+), 49 deletions(-) diff --git a/app/renderer/src/main/src/components/JsonFormWrapper/JsonFormWrapper.tsx b/app/renderer/src/main/src/components/JsonFormWrapper/JsonFormWrapper.tsx index 0b1e2d8efc..36da732269 100644 --- a/app/renderer/src/main/src/components/JsonFormWrapper/JsonFormWrapper.tsx +++ b/app/renderer/src/main/src/components/JsonFormWrapper/JsonFormWrapper.tsx @@ -119,7 +119,7 @@ export const JsonFormWrapper: React.FC = React.memo((props useEffect(() => { // 当外部 value 变化时更新内部状态 - setFormData(value) + value && setFormData(value) }, [value]) // const UploadFolderPath = useMemoizedFn((props: FieldProps) => { diff --git a/app/renderer/src/main/src/pages/mitm/MITMYakScriptLoader.module.scss b/app/renderer/src/main/src/pages/mitm/MITMYakScriptLoader.module.scss index 318dab6a8c..6dc4adedb1 100644 --- a/app/renderer/src/main/src/pages/mitm/MITMYakScriptLoader.module.scss +++ b/app/renderer/src/main/src/pages/mitm/MITMYakScriptLoader.module.scss @@ -92,9 +92,7 @@ } .mitm-params-set { - max-height: 700px; margin: 15px 10px; - overflow: auto; :global { .json-schema-row-form { padding: 0px 16px; diff --git a/app/renderer/src/main/src/pages/mitm/MITMYakScriptLoader.tsx b/app/renderer/src/main/src/pages/mitm/MITMYakScriptLoader.tsx index af51644165..6445a077ed 100644 --- a/app/renderer/src/main/src/pages/mitm/MITMYakScriptLoader.tsx +++ b/app/renderer/src/main/src/pages/mitm/MITMYakScriptLoader.tsx @@ -1,5 +1,5 @@ import React, {ForwardedRef, useEffect, useImperativeHandle, useMemo, useRef, useState} from "react" -import {Card, Col, Form, Typography, Row, Statistic, Tooltip} from "antd" +import {Card, Col, Form, Typography, Row, Statistic, Tooltip, Space} from "antd" import {YakExecutorParam} from "../invoker/YakExecutorParams" import {StatusCardProps} from "../yakitStore/viewers/base" import {YakScript} from "../invoker/schema" @@ -34,7 +34,9 @@ import {SolidDotsverticalIcon, SolidLightningboltIcon} from "@/assets/icon/solid import {YakitMenuItemProps} from "@/components/yakitUI/YakitMenu/YakitMenu" import {YakitPopover} from "@/components/yakitUI/YakitPopover/YakitPopover" import {YakEditor} from "@/utils/editors" -import { getJsonSchemaListResult } from "@/components/JsonFormWrapper/JsonFormWrapper" +import {getJsonSchemaListResult} from "@/components/JsonFormWrapper/JsonFormWrapper" +import {showYakitDrawer} from "@/components/yakitUI/YakitDrawer/YakitDrawer" +import {YakitButton} from "@/components/yakitUI/YakitButton/YakitButton" const {Text} = Typography const {ipcRenderer} = window.require("electron") @@ -102,24 +104,61 @@ export const MITMYakScriptLoader = React.memo((p: MITMYakScriptLoaderProps) => { submitFlag: boolean ) => { if (requiredParams.length || groupParams.length) { - let m = showYakitModal({ + let m = showYakitDrawer({ title: ( -
- 参数设置: - - {`${i.ScriptName}`} - +
+
+ 参数设置: + + {`${i.ScriptName}`} + +
+ + { + m.destroy() + }} + > + 取消 + + { + if (mitmHasParamsPluginFormRef.current) { + mitmHasParamsPluginFormRef.current.onSubmit().then((values) => { + if (values) { + const saveParams: CustomPluginExecuteFormValue = {...values} + const saveParasmArr: YakExecutorParam[] = [] + Object.keys(saveParams).forEach((key) => { + if (saveParams[key] !== false) { + saveParasmArr.push({Key: key, Value: saveParams[key]}) + } + }) + setRemoteValue( + "mitm_has_params_" + i.ScriptName, + JSON.stringify(saveParasmArr) + ) + if (submitFlag) { + clearMITMPluginCache() + onSubmitYakScriptId(script.Id, saveParasmArr) + setTempShowPluginHistory && setTempShowPluginHistory(i.ScriptName) + } + m.destroy() + } + }) + } + }} + > + 确定 + +
), - width: 600, - closable: true, - centered: true, - maskClosable: false, content: (
{ />
), - onOkText: "确定", - onOk: () => { - if (mitmHasParamsPluginFormRef.current) { - mitmHasParamsPluginFormRef.current.onSubmit().then((values) => { - if (values) { - const saveParams: CustomPluginExecuteFormValue = {...values} - const saveParasmArr: YakExecutorParam[] = [] - Object.keys(saveParams).forEach((key) => { - if (saveParams[key] !== false) { - saveParasmArr.push({Key: key, Value: saveParams[key]}) - } - }) - setRemoteValue("mitm_has_params_" + i.ScriptName, JSON.stringify(saveParasmArr)) - if (submitFlag) { - clearMITMPluginCache() - onSubmitYakScriptId(script.Id, saveParasmArr) - setTempShowPluginHistory && setTempShowPluginHistory(i.ScriptName) - } - m.destroy() - } - }) - } - }, - onCancel: () => { + width: "40%", + placement: "left", + mask: true, + closable: false, + onClose: () => { m.destroy() } }) @@ -468,7 +488,7 @@ const MitmHasParamsForm = React.forwardRef((props: MitmHasParamsFormProps, ref) const {initFormValue, requiredParams, groupParams} = props const [form] = Form.useForm() const jsonSchemaListRef = useRef<{ - [key: string]: any; + [key: string]: any }>({}) useImperativeHandle( @@ -485,12 +505,12 @@ const MitmHasParamsForm = React.forwardRef((props: MitmHasParamsFormProps, ref) form.validateFields() .then((values) => { const result = getJsonSchemaListResult(jsonSchemaListRef.current) - if(result.jsonSchemaError.length>0) { + if (result.jsonSchemaError.length > 0) { failed(`jsonSchema校验失败`) return } - result.jsonSchemaSuccess.forEach((item)=>{ - values[item.key] = JSON.stringify(item.value) + result.jsonSchemaSuccess.forEach((item) => { + values[item.key] = JSON.stringify(item.value) }) resolve(values) }) @@ -508,7 +528,13 @@ const MitmHasParamsForm = React.forwardRef((props: MitmHasParamsFormProps, ref) wrapperCol={{span: 16}} initialValues={initFormValue} > - + )