style(接口测试): 定义预览-编辑器复制前置在切换左侧&代码编辑器样式
This commit is contained in:
parent
fb6c1923c5
commit
dd2f6500ff
|
@ -488,6 +488,7 @@
|
||||||
|
|
||||||
/** radio **/
|
/** radio **/
|
||||||
.arco-radio-group-button {
|
.arco-radio-group-button {
|
||||||
|
padding: 2px;
|
||||||
.arco-radio-button-content {
|
.arco-radio-button-content {
|
||||||
@apply break-keep;
|
@apply break-keep;
|
||||||
}
|
}
|
||||||
|
@ -496,6 +497,7 @@
|
||||||
.arco-radio-button {
|
.arco-radio-button {
|
||||||
@apply bg-transparent;
|
@apply bg-transparent;
|
||||||
|
|
||||||
|
margin: 0;
|
||||||
line-height: 20px;
|
line-height: 20px;
|
||||||
}
|
}
|
||||||
.arco-radio-checked {
|
.arco-radio-checked {
|
||||||
|
|
|
@ -56,7 +56,7 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- 这里的 32px 是顶部标题的 32px -->
|
<!-- 这里的 32px 是顶部标题的 32px -->
|
||||||
<div class="flex w-full flex-1 flex-row rounded-[var(--border-radius-small)]">
|
<div class="flex w-full flex-1 flex-row overflow-hidden rounded-[var(--border-radius-small)]">
|
||||||
<div
|
<div
|
||||||
ref="codeContainerRef"
|
ref="codeContainerRef"
|
||||||
:class="['ms-code-editor', isFullScreen ? 'ms-code-editor-full-screen' : '', currentTheme]"
|
:class="['ms-code-editor', isFullScreen ? 'ms-code-editor-full-screen' : '', currentTheme]"
|
||||||
|
|
|
@ -32,10 +32,24 @@
|
||||||
<div v-if="previewDetail.headers.length > 0" class="detail-item">
|
<div v-if="previewDetail.headers.length > 0" class="detail-item">
|
||||||
<div class="detail-item-title">
|
<div class="detail-item-title">
|
||||||
<div class="detail-item-title-text">{{ t('apiTestManagement.requestHeader') }}</div>
|
<div class="detail-item-title-text">{{ t('apiTestManagement.requestHeader') }}</div>
|
||||||
<a-radio-group v-model:model-value="headerShowType" type="button" size="mini">
|
<div class="detail-item-title-right">
|
||||||
<a-radio value="table">Table</a-radio>
|
<a-button
|
||||||
<a-radio value="raw">Raw</a-radio>
|
v-show="headerShowType === 'raw'"
|
||||||
</a-radio-group>
|
type="outline"
|
||||||
|
class="arco-btn-outline--secondary mr-[12px] p-[0_8px]"
|
||||||
|
size="small"
|
||||||
|
@click="copyScript(headerRawCode)"
|
||||||
|
>
|
||||||
|
<template #icon>
|
||||||
|
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" />
|
||||||
|
</template>
|
||||||
|
{{ t('common.copy') }}
|
||||||
|
</a-button>
|
||||||
|
<a-radio-group v-model:model-value="headerShowType" type="button" size="mini">
|
||||||
|
<a-radio value="table">Table</a-radio>
|
||||||
|
<a-radio value="raw">Raw</a-radio>
|
||||||
|
</a-radio-group>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<MsFormTable
|
<MsFormTable
|
||||||
v-show="headerShowType === 'table'"
|
v-show="headerShowType === 'table'"
|
||||||
|
@ -51,29 +65,30 @@
|
||||||
:show-full-screen="false"
|
:show-full-screen="false"
|
||||||
:show-theme-change="false"
|
:show-theme-change="false"
|
||||||
read-only
|
read-only
|
||||||
>
|
/>
|
||||||
<template #rightTitle>
|
|
||||||
<a-button
|
|
||||||
type="outline"
|
|
||||||
class="arco-btn-outline--secondary p-[0_8px]"
|
|
||||||
size="mini"
|
|
||||||
@click="copyScript(headerRawCode)"
|
|
||||||
>
|
|
||||||
<template #icon>
|
|
||||||
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" size="12" />
|
|
||||||
</template>
|
|
||||||
</a-button>
|
|
||||||
</template>
|
|
||||||
</MsCodeEditor>
|
|
||||||
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
||||||
</div>
|
</div>
|
||||||
<div v-if="previewDetail.query.length > 0" class="detail-item">
|
<div v-if="previewDetail.query.length > 0" class="detail-item">
|
||||||
<div class="detail-item-title">
|
<div class="detail-item-title">
|
||||||
<div class="detail-item-title-text">Query</div>
|
<div class="detail-item-title-text">Query</div>
|
||||||
<a-radio-group v-model:model-value="queryShowType" type="button" size="mini">
|
<div class="detail-item-title-right">
|
||||||
<a-radio value="table">Table</a-radio>
|
<a-button
|
||||||
<a-radio value="raw">Raw</a-radio>
|
v-show="queryShowType === 'raw'"
|
||||||
</a-radio-group>
|
type="outline"
|
||||||
|
class="arco-btn-outline--secondary mr-[12px] p-[0_8px]"
|
||||||
|
size="small"
|
||||||
|
@click="copyScript(queryRawCode)"
|
||||||
|
>
|
||||||
|
<template #icon>
|
||||||
|
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" />
|
||||||
|
</template>
|
||||||
|
{{ t('common.copy') }}
|
||||||
|
</a-button>
|
||||||
|
<a-radio-group v-model:model-value="queryShowType" type="button" size="mini">
|
||||||
|
<a-radio value="table">Table</a-radio>
|
||||||
|
<a-radio value="raw">Raw</a-radio>
|
||||||
|
</a-radio-group>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<MsFormTable
|
<MsFormTable
|
||||||
v-show="queryShowType === 'table'"
|
v-show="queryShowType === 'table'"
|
||||||
|
@ -91,29 +106,30 @@
|
||||||
:show-full-screen="false"
|
:show-full-screen="false"
|
||||||
:show-theme-change="false"
|
:show-theme-change="false"
|
||||||
read-only
|
read-only
|
||||||
>
|
/>
|
||||||
<template #rightTitle>
|
|
||||||
<a-button
|
|
||||||
type="outline"
|
|
||||||
class="arco-btn-outline--secondary p-[0_8px]"
|
|
||||||
size="mini"
|
|
||||||
@click="copyScript(queryRawCode)"
|
|
||||||
>
|
|
||||||
<template #icon>
|
|
||||||
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" size="12" />
|
|
||||||
</template>
|
|
||||||
</a-button>
|
|
||||||
</template>
|
|
||||||
</MsCodeEditor>
|
|
||||||
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
||||||
</div>
|
</div>
|
||||||
<div v-if="previewDetail.rest.length > 0" class="detail-item">
|
<div v-if="previewDetail.rest.length > 0" class="detail-item">
|
||||||
<div class="detail-item-title">
|
<div class="detail-item-title">
|
||||||
<div class="detail-item-title-text">REST</div>
|
<div class="detail-item-title-text">REST</div>
|
||||||
<a-radio-group v-model:model-value="restShowType" type="button" size="mini">
|
<div class="detail-item-title-right">
|
||||||
<a-radio value="table">Table</a-radio>
|
<a-button
|
||||||
<a-radio value="raw">Raw</a-radio>
|
v-show="restShowType === 'raw'"
|
||||||
</a-radio-group>
|
type="outline"
|
||||||
|
class="arco-btn-outline--secondary mr-[12px] p-[0_8px]"
|
||||||
|
size="small"
|
||||||
|
@click="copyScript(restRawCode)"
|
||||||
|
>
|
||||||
|
<template #icon>
|
||||||
|
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" />
|
||||||
|
</template>
|
||||||
|
{{ t('common.copy') }}
|
||||||
|
</a-button>
|
||||||
|
<a-radio-group v-model:model-value="restShowType" type="button" size="mini">
|
||||||
|
<a-radio value="table">Table</a-radio>
|
||||||
|
<a-radio value="raw">Raw</a-radio>
|
||||||
|
</a-radio-group>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<MsFormTable
|
<MsFormTable
|
||||||
v-show="restShowType === 'table'"
|
v-show="restShowType === 'table'"
|
||||||
|
@ -131,20 +147,7 @@
|
||||||
:show-full-screen="false"
|
:show-full-screen="false"
|
||||||
:show-theme-change="false"
|
:show-theme-change="false"
|
||||||
read-only
|
read-only
|
||||||
>
|
/>
|
||||||
<template #rightTitle>
|
|
||||||
<a-button
|
|
||||||
type="outline"
|
|
||||||
class="arco-btn-outline--secondary p-[0_8px]"
|
|
||||||
size="mini"
|
|
||||||
@click="copyScript(restRawCode)"
|
|
||||||
>
|
|
||||||
<template #icon>
|
|
||||||
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" size="12" />
|
|
||||||
</template>
|
|
||||||
</a-button>
|
|
||||||
</template>
|
|
||||||
</MsCodeEditor>
|
|
||||||
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
||||||
</div>
|
</div>
|
||||||
<div v-if="previewDetail.body.bodyType !== RequestBodyFormat.NONE" class="detail-item">
|
<div v-if="previewDetail.body.bodyType !== RequestBodyFormat.NONE" class="detail-item">
|
||||||
|
@ -152,15 +155,30 @@
|
||||||
<div class="detail-item-title-text">
|
<div class="detail-item-title-text">
|
||||||
{{ `${t('apiTestManagement.requestBody')}-${previewDetail.body.bodyType}` }}
|
{{ `${t('apiTestManagement.requestBody')}-${previewDetail.body.bodyType}` }}
|
||||||
</div>
|
</div>
|
||||||
<a-radio-group
|
<div v-if="previewDetail.body.bodyType === RequestBodyFormat.JSON" class="detail-item-title-right">
|
||||||
v-if="previewDetail.body.bodyType === RequestBodyFormat.JSON && !props.isCase"
|
<a-button
|
||||||
v-model:model-value="bodyShowType"
|
v-show="bodyShowType === 'json' || props.isCase"
|
||||||
type="button"
|
type="outline"
|
||||||
size="mini"
|
class="arco-btn-outline--secondary p-[0_8px]"
|
||||||
>
|
size="small"
|
||||||
<a-radio value="schema">Schema</a-radio>
|
@click="copyScript(bodyCode)"
|
||||||
<a-radio value="json">JSON</a-radio>
|
>
|
||||||
</a-radio-group>
|
<template #icon>
|
||||||
|
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" />
|
||||||
|
</template>
|
||||||
|
{{ t('common.copy') }}
|
||||||
|
</a-button>
|
||||||
|
<a-radio-group
|
||||||
|
v-if="!props.isCase"
|
||||||
|
v-model:model-value="bodyShowType"
|
||||||
|
type="button"
|
||||||
|
size="mini"
|
||||||
|
class="ml-[12px]"
|
||||||
|
>
|
||||||
|
<a-radio value="schema">Schema</a-radio>
|
||||||
|
<a-radio value="json">JSON</a-radio>
|
||||||
|
</a-radio-group>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- <div
|
<!-- <div
|
||||||
v-if="previewDetail.body.bodyType === RequestBodyFormat.NONE"
|
v-if="previewDetail.body.bodyType === RequestBodyFormat.NONE"
|
||||||
|
@ -203,20 +221,7 @@
|
||||||
:show-full-screen="false"
|
:show-full-screen="false"
|
||||||
:show-theme-change="false"
|
:show-theme-change="false"
|
||||||
read-only
|
read-only
|
||||||
>
|
/>
|
||||||
<template #rightTitle>
|
|
||||||
<a-button
|
|
||||||
type="outline"
|
|
||||||
class="arco-btn-outline--secondary p-[0_8px]"
|
|
||||||
size="mini"
|
|
||||||
@click="copyScript(bodyCode)"
|
|
||||||
>
|
|
||||||
<template #icon>
|
|
||||||
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" size="12" />
|
|
||||||
</template>
|
|
||||||
</a-button>
|
|
||||||
</template>
|
|
||||||
</MsCodeEditor>
|
|
||||||
</template>
|
</template>
|
||||||
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
||||||
</div>
|
</div>
|
||||||
|
@ -224,10 +229,24 @@
|
||||||
<div v-else class="detail-item">
|
<div v-else class="detail-item">
|
||||||
<div class="detail-item-title">
|
<div class="detail-item-title">
|
||||||
<div class="detail-item-title-text">{{ t('apiTestManagement.requestData') }}</div>
|
<div class="detail-item-title-text">{{ t('apiTestManagement.requestData') }}</div>
|
||||||
<a-radio-group v-model:model-value="pluginShowType" type="button" size="mini">
|
<div class="detail-item-title-right">
|
||||||
<a-radio value="table">Table</a-radio>
|
<a-button
|
||||||
<a-radio value="raw">Raw</a-radio>
|
v-show="pluginShowType === 'raw'"
|
||||||
</a-radio-group>
|
type="outline"
|
||||||
|
class="arco-btn-outline--secondary mr-[12px] p-[0_8px]"
|
||||||
|
size="small"
|
||||||
|
@click="copyScript(pluginRawCode)"
|
||||||
|
>
|
||||||
|
<template #icon>
|
||||||
|
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" />
|
||||||
|
</template>
|
||||||
|
{{ t('common.copy') }}
|
||||||
|
</a-button>
|
||||||
|
<a-radio-group v-model:model-value="pluginShowType" type="button" size="mini">
|
||||||
|
<a-radio value="table">Table</a-radio>
|
||||||
|
<a-radio value="raw">Raw</a-radio>
|
||||||
|
</a-radio-group>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<MsFormTable
|
<MsFormTable
|
||||||
v-show="pluginShowType === 'table'"
|
v-show="pluginShowType === 'table'"
|
||||||
|
@ -243,20 +262,7 @@
|
||||||
:show-full-screen="false"
|
:show-full-screen="false"
|
||||||
:show-theme-change="false"
|
:show-theme-change="false"
|
||||||
read-only
|
read-only
|
||||||
>
|
/>
|
||||||
<template #rightTitle>
|
|
||||||
<a-button
|
|
||||||
type="outline"
|
|
||||||
class="arco-btn-outline--secondary p-[0_8px]"
|
|
||||||
size="mini"
|
|
||||||
@click="copyScript(pluginRawCode)"
|
|
||||||
>
|
|
||||||
<template #icon>
|
|
||||||
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" size="12" />
|
|
||||||
</template>
|
|
||||||
</a-button>
|
|
||||||
</template>
|
|
||||||
</MsCodeEditor>
|
|
||||||
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
<a-divider type="dashed" :margin="0" class="!mt-[16px] border-[var(--color-text-n8)]" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -304,32 +310,55 @@
|
||||||
<div class="detail-item-title-text">
|
<div class="detail-item-title-text">
|
||||||
{{ `${t('apiTestDebug.responseBody')}-${activeResponse?.body.bodyType}` }}
|
{{ `${t('apiTestDebug.responseBody')}-${activeResponse?.body.bodyType}` }}
|
||||||
</div>
|
</div>
|
||||||
<div v-if="activeResponse?.body.bodyType === ResponseBodyFormat.JSON" class="flex items-center gap-[8px]">
|
<div class="detail-item-title-right">
|
||||||
<MsButton
|
<a-button
|
||||||
type="text"
|
v-show="
|
||||||
class="!mr-0"
|
!(
|
||||||
:class="
|
activeResponse?.body.bodyType === ResponseBodyFormat.BINARY ||
|
||||||
activeResponse.body.jsonBody.enableJsonSchema
|
(activeResponse?.body.bodyType === ResponseBodyFormat.JSON &&
|
||||||
? 'font-medium !text-[rgb(var(--primary-5))]'
|
activeResponse.body.jsonBody.enableJsonSchema)
|
||||||
: '!text-[var(--color-text-4)]'
|
)
|
||||||
"
|
"
|
||||||
@click="handleChangeJsonType('Schema')"
|
type="outline"
|
||||||
|
class="arco-btn-outline--secondary p-[0_8px]"
|
||||||
|
size="small"
|
||||||
|
@click="copyScript(responseCode || '')"
|
||||||
>
|
>
|
||||||
Schema
|
<template #icon>
|
||||||
</MsButton>
|
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" />
|
||||||
<a-divider :margin="0" direction="vertical"></a-divider>
|
</template>
|
||||||
<MsButton
|
{{ t('common.copy') }}
|
||||||
type="text"
|
</a-button>
|
||||||
class="!mr-0"
|
<div
|
||||||
:class="
|
v-if="activeResponse?.body.bodyType === ResponseBodyFormat.JSON"
|
||||||
!activeResponse.body.jsonBody.enableJsonSchema
|
class="ml-[12px] flex items-center gap-[8px]"
|
||||||
? 'font-medium !text-[rgb(var(--primary-5))]'
|
|
||||||
: '!text-[var(--color-text-4)]'
|
|
||||||
"
|
|
||||||
@click="handleChangeJsonType('Json')"
|
|
||||||
>
|
>
|
||||||
Json
|
<MsButton
|
||||||
</MsButton>
|
type="text"
|
||||||
|
class="!mr-0"
|
||||||
|
:class="
|
||||||
|
activeResponse.body.jsonBody.enableJsonSchema
|
||||||
|
? 'font-medium !text-[rgb(var(--primary-5))]'
|
||||||
|
: '!text-[var(--color-text-4)]'
|
||||||
|
"
|
||||||
|
@click="handleChangeJsonType('Schema')"
|
||||||
|
>
|
||||||
|
Schema
|
||||||
|
</MsButton>
|
||||||
|
<a-divider :margin="0" direction="vertical"></a-divider>
|
||||||
|
<MsButton
|
||||||
|
type="text"
|
||||||
|
class="!mr-0"
|
||||||
|
:class="
|
||||||
|
!activeResponse.body.jsonBody.enableJsonSchema
|
||||||
|
? 'font-medium !text-[rgb(var(--primary-5))]'
|
||||||
|
: '!text-[var(--color-text-4)]'
|
||||||
|
"
|
||||||
|
@click="handleChangeJsonType('Json')"
|
||||||
|
>
|
||||||
|
Json
|
||||||
|
</MsButton>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<MsFormTable
|
<MsFormTable
|
||||||
|
@ -354,20 +383,7 @@
|
||||||
:show-full-screen="false"
|
:show-full-screen="false"
|
||||||
:show-theme-change="false"
|
:show-theme-change="false"
|
||||||
read-only
|
read-only
|
||||||
>
|
/>
|
||||||
<template #rightTitle>
|
|
||||||
<a-button
|
|
||||||
type="outline"
|
|
||||||
class="arco-btn-outline--secondary p-[0_8px]"
|
|
||||||
size="mini"
|
|
||||||
@click="copyScript(responseCode || '')"
|
|
||||||
>
|
|
||||||
<template #icon>
|
|
||||||
<MsIcon type="icon-icon_copy_outlined" class="text-var(--color-text-4)" size="12" />
|
|
||||||
</template>
|
|
||||||
</a-button>
|
|
||||||
</template>
|
|
||||||
</MsCodeEditor>
|
|
||||||
</div>
|
</div>
|
||||||
<div v-if="activeResponse?.headers && activeResponse?.headers.length > 0" class="detail-item">
|
<div v-if="activeResponse?.headers && activeResponse?.headers.length > 0" class="detail-item">
|
||||||
<div class="detail-item-title">
|
<div class="detail-item-title">
|
||||||
|
@ -935,6 +951,12 @@
|
||||||
|
|
||||||
color: var(--color-text-1);
|
color: var(--color-text-1);
|
||||||
}
|
}
|
||||||
|
.detail-item-title-right {
|
||||||
|
@apply flex items-center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
:deep(.ms-code-editor-container) {
|
||||||
|
padding: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.response-tab {
|
.response-tab {
|
||||||
|
|
Loading…
Reference in New Issue