fix(接口定义): #1007602 API文档查阅问题、Mock匹配到了SQL请求的问题
API文档查阅问题、Mock匹配到了SQL请求的问题
This commit is contained in:
parent
0209ea07d0
commit
9340caaab9
|
@ -1474,7 +1474,7 @@ public class ApiDefinitionService {
|
||||||
return new ArrayList<>();
|
return new ArrayList<>();
|
||||||
} else {
|
} else {
|
||||||
ApiDefinitionExample example = new ApiDefinitionExample();
|
ApiDefinitionExample example = new ApiDefinitionExample();
|
||||||
example.createCriteria().andMethodEqualTo(method).andProjectIdEqualTo(projectId);
|
example.createCriteria().andMethodEqualTo(method).andProjectIdEqualTo(projectId).andStatusNotEqualTo("Trash").andProtocolEqualTo("HTTP");
|
||||||
List<ApiDefinition> apiList = apiDefinitionMapper.selectByExample(example);
|
List<ApiDefinition> apiList = apiDefinitionMapper.selectByExample(example);
|
||||||
|
|
||||||
List<String> apiIdList = new ArrayList<>();
|
List<String> apiIdList = new ArrayList<>();
|
||||||
|
@ -1489,6 +1489,9 @@ public class ApiDefinitionService {
|
||||||
}
|
}
|
||||||
for (ApiDefinition api : apiList) {
|
for (ApiDefinition api : apiList) {
|
||||||
String path = api.getPath();
|
String path = api.getPath();
|
||||||
|
if(StringUtils.isEmpty(path)){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (path.startsWith("/")) {
|
if (path.startsWith("/")) {
|
||||||
path = path.substring(1);
|
path = path.substring(1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
<template>
|
<template>
|
||||||
<div>
|
<div>
|
||||||
<el-container v-loading="isLoading">
|
<el-container v-loading="isLoading">
|
||||||
<el-main style="padding-top: 0px;padding-bottom: 0px">
|
<el-main style="padding-top: 0px;padding-bottom: 0px" >
|
||||||
|
<!-- 筛选条件 -->
|
||||||
<el-row v-if="sharePage" style="margin-top: 10px">
|
<el-row v-if="sharePage" style="margin-top: 10px">
|
||||||
<el-select size="small" :placeholder="$t('api_test.definition.document.order')"
|
<el-select size="small" :placeholder="$t('api_test.definition.document.order')"
|
||||||
v-model="apiSearch.orderCondition" style="float: right;width: 180px;margin-right: 5px"
|
v-model="apiSearch.orderCondition" style="float: right;width: 180px;margin-right: 5px"
|
||||||
|
@ -75,250 +76,10 @@
|
||||||
:project-id="projectId" :share-url="batchShareUrl"
|
:project-id="projectId" :share-url="batchShareUrl"
|
||||||
style="float: right;margin: 6px;font-size: 17px"/>
|
style="float: right;margin: 6px;font-size: 17px"/>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
<el-divider></el-divider>
|
<el-divider></el-divider>
|
||||||
<div ref="apiDocInfoDiv" @scroll="handleScroll">
|
<!-- 展示区域 -->
|
||||||
<div v-for="(apiInfo) in apiShowArray" :key="apiInfo.id" ref="apiDocInfoDivItem">
|
<div ref="apiDocInfoDiv" @scroll="handleScroll" style="overflow: auto">
|
||||||
<div style="font-size: 17px">
|
<api-information v-for="(apiInfo) in apiShowArray" :key="apiInfo.id" :api-info="apiInfo" :project-id="projectId" ref="apiDocInfoDivItem"/>
|
||||||
<el-popover
|
|
||||||
v-if="projectId"
|
|
||||||
placement="right"
|
|
||||||
width="260"
|
|
||||||
@show="shareApiDocument('false')">
|
|
||||||
<p>{{ shareUrl }}</p>
|
|
||||||
<div style="text-align: right; margin: 0">
|
|
||||||
<el-button type="primary" size="mini"
|
|
||||||
v-clipboard:copy="shareUrl">{{ $t("commons.copy") }}
|
|
||||||
</el-button>
|
|
||||||
</div>
|
|
||||||
<i class="el-icon-share" slot="reference" style="margin-right: 10px;cursor: pointer"></i>
|
|
||||||
</el-popover>
|
|
||||||
{{ apiInfo.name }}
|
|
||||||
<span class="apiStatusTag">
|
|
||||||
<api-status :value="apiInfo.status"/>
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
<!--api请求信息-->
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="tip">
|
|
||||||
{{ $t('api_test.definition.document.request_info') }}
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="simpleFontClass">
|
|
||||||
<el-tag size="medium"
|
|
||||||
:style="{'background-color': getColor(true,apiInfo.method), border: getColor(true,apiInfo.method),borderRadius:'0px', marginRight:'20px',color:'white'}">
|
|
||||||
{{ apiInfo.method }}
|
|
||||||
</el-tag>
|
|
||||||
{{ apiInfo.uri }}
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
<!--api请求头-->
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="blackFontClass">
|
|
||||||
{{ $t('api_test.definition.document.request_head') }}:
|
|
||||||
<div v-if="getJsonArr(apiInfo.requestHead).length==0">
|
|
||||||
<div class="simpleFontClass" style="margin-top: 10px">
|
|
||||||
{{ $t('api_test.definition.document.data_set.none') }}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div v-else>
|
|
||||||
<el-table border :show-header="false"
|
|
||||||
:data="getJsonArr(apiInfo.requestHead)" class="test-content document-table">
|
|
||||||
<el-table-column prop="name"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="value"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.value')"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
</el-table>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
<!--URL参数-->
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="blackFontClass">
|
|
||||||
URL{{ $t('api_test.definition.document.request_param') }}:
|
|
||||||
<div v-if="getJsonArr(apiInfo.urlParams).length==0">
|
|
||||||
<div class="simpleFontClass" style="margin-top: 10px">
|
|
||||||
{{ $t('api_test.definition.document.data_set.none') }}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div v-else>
|
|
||||||
<el-table border
|
|
||||||
:data="getJsonArr(apiInfo.urlParams)" class="test-content document-table">
|
|
||||||
<el-table-column prop="name"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
|
||||||
min-width="120px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="required"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.is_required')"
|
|
||||||
:formatter="formatBoolean"
|
|
||||||
min-width="80px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="value"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.value')"
|
|
||||||
min-width="120px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="description"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.desc')"
|
|
||||||
min-width="280px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
</el-table>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
<!--api请求体 以及表格-->
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="blackFontClass">
|
|
||||||
{{ $t('api_test.definition.document.request_body') }}
|
|
||||||
</div>
|
|
||||||
<div class="smallFontClass">
|
|
||||||
{{ $t('api_test.definition.document.table_coloum.type') }}:{{ apiInfo.requestBodyParamType }}
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<el-table border v-if="formParamTypes.includes(apiInfo.requestBodyParamType)"
|
|
||||||
:data="getJsonArr(apiInfo.requestBodyFormData)"
|
|
||||||
class="test-content document-table">
|
|
||||||
<el-table-column prop="name"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
|
||||||
min-width="120px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="contentType"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.type')"
|
|
||||||
min-width="120px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="description"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.desc')"
|
|
||||||
min-width="280px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="required"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.is_required')"
|
|
||||||
:formatter="formatBoolean"
|
|
||||||
min-width="80px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="value"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.default_value')"
|
|
||||||
min-width="120px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
</el-table>
|
|
||||||
<div v-else-if="apiInfo.requestBodyParamType == 'JSON-SCHEMA'" style="margin-left: 10px">
|
|
||||||
<ms-json-code-edit :show-preview="false" :body="apiInfo.jsonSchemaBody" ref="jsonCodeEdit"/>
|
|
||||||
</div>
|
|
||||||
<div v-else-if="formatRowDataToJsonSchema(apiInfo,'request') " style="margin-left: 10px">
|
|
||||||
<ms-json-code-edit :show-preview="false" :body="apiInfo.requestJsonSchema" ref="jsonCodeEdit"/>
|
|
||||||
</div>
|
|
||||||
<div v-else class="showDataDiv">
|
|
||||||
<br/>
|
|
||||||
<p style="margin: 0px 20px;"
|
|
||||||
v-html="formatRowData(apiInfo.requestBodyParamType,apiInfo.requestBodyStrutureData)">
|
|
||||||
</p>
|
|
||||||
<br/>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
<!--范例展示-->
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="blackFontClass">
|
|
||||||
{{ $t('api_test.definition.document.example_presentation') }}
|
|
||||||
</div>
|
|
||||||
<div class="showDataDiv">
|
|
||||||
<br/>
|
|
||||||
<p style="margin: 0px 20px;"
|
|
||||||
v-html="genPreviewData(apiInfo.requestPreviewData)">
|
|
||||||
</p>
|
|
||||||
<br/>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
<!--响应信息-->
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="tip">
|
|
||||||
{{ $t('api_test.definition.document.response_info') }}
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
|
|
||||||
</el-row>
|
|
||||||
<!--响应头-->
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="blackFontClass">
|
|
||||||
{{ $t('api_test.definition.document.response_head') }}:
|
|
||||||
<el-table border :show-header="false"
|
|
||||||
:data="getJsonArr(apiInfo.responseHead)" class="test-content document-table">
|
|
||||||
<el-table-column prop="name"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="value"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.value')"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
</el-table>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
<!--响应体-->
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="blackFontClass">
|
|
||||||
{{ $t('api_test.definition.document.response_body') }}
|
|
||||||
</div>
|
|
||||||
<div class="smallFontClass">
|
|
||||||
{{ $t('api_test.definition.document.table_coloum.type') }}:{{ apiInfo.responseBodyParamType }}
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<el-table border v-if="formParamTypes.includes(apiInfo.responseBodyParamType)"
|
|
||||||
:data="getJsonArr(apiInfo.responseBodyFormData)"
|
|
||||||
class="test-content document-table">
|
|
||||||
<el-table-column prop="name"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
|
||||||
min-width="120px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="contentType"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.type')"
|
|
||||||
min-width="120px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="description"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.desc')"
|
|
||||||
min-width="280px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="required"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.is_required')"
|
|
||||||
:formatter="formatBoolean"
|
|
||||||
min-width="80px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="value"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.default_value')"
|
|
||||||
min-width="120px"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
</el-table>
|
|
||||||
<div v-else-if="apiInfo.responseBodyParamType == 'JSON-SCHEMA'" style="margin-left: 10px">
|
|
||||||
<ms-json-code-edit :show-preview="false" :body="apiInfo.jsonSchemaResponseBody" ref="jsonCodeEdit"/>
|
|
||||||
</div>
|
|
||||||
<div v-else-if="formatRowDataToJsonSchema(apiInfo,'response') " style="margin-left: 10px">
|
|
||||||
<ms-json-code-edit :show-preview="false" :body="apiInfo.responseJsonSchema" ref="jsonCodeEdit"/>
|
|
||||||
</div>
|
|
||||||
<div v-else class="showDataDiv">
|
|
||||||
<br/>
|
|
||||||
<p style="margin: 0px 20px;"
|
|
||||||
v-html="formatRowData(apiInfo.responseBodyParamType,apiInfo.responseBodyStrutureData)">
|
|
||||||
</p>
|
|
||||||
<br/>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
<!--响应状态码-->
|
|
||||||
<el-row class="apiInfoRow">
|
|
||||||
<div class="blackFontClass">
|
|
||||||
{{ $t('api_test.definition.document.response_code') }}:
|
|
||||||
<el-table border :show-header="false"
|
|
||||||
:data="getJsonArr(apiInfo.responseCode)" class="test-content document-table">
|
|
||||||
<el-table-column prop="name"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.name')"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
<el-table-column prop="value"
|
|
||||||
:label="$t('api_test.definition.document.table_coloum.value')"
|
|
||||||
show-overflow-tooltip/>
|
|
||||||
</el-table>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</el-main>
|
</el-main>
|
||||||
<!-- 右侧列表 -->
|
<!-- 右侧列表 -->
|
||||||
|
@ -344,7 +105,7 @@ import {calculate} from "@/business/components/api/definition/model/ApiTestModel
|
||||||
import MsJsonCodeEdit from "@/business/components/common/json-schema/JsonSchemaEditor";
|
import MsJsonCodeEdit from "@/business/components/common/json-schema/JsonSchemaEditor";
|
||||||
import Api from "@/business/components/api/router";
|
import Api from "@/business/components/api/router";
|
||||||
import {generateApiDocumentShareInfo} from "@/network/share";
|
import {generateApiDocumentShareInfo} from "@/network/share";
|
||||||
import Convert from "@/business/components/common/json-schema/convert/convert";
|
import ApiInformation from "@/business/components/api/definition/components/document/components/ApiInformation";
|
||||||
|
|
||||||
const requireComponent = require.context('@/business/components/xpack/', true, /\.vue$/);
|
const requireComponent = require.context('@/business/components/xpack/', true, /\.vue$/);
|
||||||
const apiDocumentBatchShare = (requireComponent != null && requireComponent.keys().length) > 0 ? requireComponent("./share/ApiDocumentBatchShare.vue") : {};
|
const apiDocumentBatchShare = (requireComponent != null && requireComponent.keys().length) > 0 ? requireComponent("./share/ApiDocumentBatchShare.vue") : {};
|
||||||
|
@ -354,7 +115,7 @@ export default {
|
||||||
components: {
|
components: {
|
||||||
Api,
|
Api,
|
||||||
MsJsonCodeEdit,
|
MsJsonCodeEdit,
|
||||||
ApiStatus, MsCodeEdit,
|
ApiStatus, MsCodeEdit, ApiInformation,
|
||||||
"ApiDocumentBatchShare": apiDocumentBatchShare.default
|
"ApiDocumentBatchShare": apiDocumentBatchShare.default
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
|
@ -458,34 +219,8 @@ export default {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
formatRowDataToJsonSchema(api, jsonType) {
|
|
||||||
if (jsonType === 'request' && api.requestBodyStrutureData) {
|
|
||||||
try {
|
|
||||||
JSON.parse(api.requestBodyStrutureData);
|
|
||||||
api.requestJsonSchema = {'raw': api.requestBodyStrutureData};
|
|
||||||
return true;
|
|
||||||
} catch (e) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
} else if (jsonType === 'response' && api.responseBodyStrutureData) {
|
|
||||||
try {
|
|
||||||
JSON.parse(api.responseBodyStrutureData);
|
|
||||||
api.responseJsonSchema = {'raw': api.responseBodyStrutureData};
|
|
||||||
return true;
|
|
||||||
} catch (e) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
formatRowData(dataType, data) {
|
|
||||||
var returnData = data;
|
|
||||||
if (data) {
|
|
||||||
returnData = "<xmp>" + returnData + "</xmp>";
|
|
||||||
}
|
|
||||||
return returnData;
|
|
||||||
},
|
|
||||||
changeFixed(clientHeight) {
|
changeFixed(clientHeight) {
|
||||||
if (this.$refs.apiDocInfoDiv) {
|
if (this.$refs.apiDocInfoDiv) {
|
||||||
let countPageHeight = 210;
|
let countPageHeight = 210;
|
||||||
|
@ -618,91 +353,6 @@ export default {
|
||||||
//检查数据
|
//检查数据
|
||||||
this.checkApiInfoNode(this.apiStepIndex, true);
|
this.checkApiInfoNode(this.apiStepIndex, true);
|
||||||
},
|
},
|
||||||
getColor(enable, method) {
|
|
||||||
return this.methodColorMap.get(method);
|
|
||||||
},
|
|
||||||
formatBoolean(row, column, cellValue) {
|
|
||||||
var ret = ''; //你想在页面展示的值
|
|
||||||
if (cellValue) {
|
|
||||||
ret = "是"; //根据自己的需求设定
|
|
||||||
} else {
|
|
||||||
ret = "否";
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
},
|
|
||||||
getJsonArr(jsonString) {
|
|
||||||
let returnJsonArr = [];
|
|
||||||
if (jsonString == '无' || jsonString == null) {
|
|
||||||
return returnJsonArr;
|
|
||||||
}
|
|
||||||
|
|
||||||
let jsonArr = JSON.parse(jsonString);
|
|
||||||
//遍历,把必填项空的数据去掉
|
|
||||||
for (var index = 0; index < jsonArr.length; index++) {
|
|
||||||
var item = jsonArr[index];
|
|
||||||
if (item.name != "" && item.name != null) {
|
|
||||||
returnJsonArr.push(item);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return returnJsonArr;
|
|
||||||
},
|
|
||||||
//构建预览数据
|
|
||||||
genPreviewData(previewData) {
|
|
||||||
if (previewData != null && previewData != '') {
|
|
||||||
let showDataObj = {};
|
|
||||||
for (var key in previewData) {
|
|
||||||
// showDataObj.set(key,previewData[key]);
|
|
||||||
let value = previewData[key];
|
|
||||||
if (typeof (value) == 'string') {
|
|
||||||
if (value.indexOf("@") >= 0) {
|
|
||||||
value = this.showPreview(value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
showDataObj[key] = value;
|
|
||||||
}
|
|
||||||
showDataObj = JSON.stringify(showDataObj);
|
|
||||||
previewData = formatJson(showDataObj);
|
|
||||||
}
|
|
||||||
return previewData;
|
|
||||||
},
|
|
||||||
showPreview(itemValue) {
|
|
||||||
// 找到变量本身
|
|
||||||
if (!itemValue) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let index = itemValue.indexOf("|");
|
|
||||||
if (index > -1) {
|
|
||||||
itemValue = itemValue.substring(0, index).trim();
|
|
||||||
}
|
|
||||||
|
|
||||||
this.mockVariableFuncs.forEach(f => {
|
|
||||||
if (!f.name) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
itemValue += "|" + f.name;
|
|
||||||
if (f.params) {
|
|
||||||
itemValue += ":" + f.params.map(p => p.value).join(",");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
itemValue = calculate(itemValue);
|
|
||||||
return itemValue;
|
|
||||||
},
|
|
||||||
onCopySuccess: function (e) {
|
|
||||||
if (this.apiStepIndex < this.apiInfoArray.length) {
|
|
||||||
this.apiInfoArray[this.apiStepIndex].sharePopoverVisible = false;
|
|
||||||
}
|
|
||||||
this.$message({
|
|
||||||
message: this.$t('commons.copy_success'),
|
|
||||||
type: 'success'
|
|
||||||
});
|
|
||||||
},
|
|
||||||
onCopyError: function (e) {
|
|
||||||
if (this.apiStepIndex < this.apiInfoArray.length) {
|
|
||||||
this.apiInfoArray[this.apiStepIndex].sharePopoverVisible = false;
|
|
||||||
}
|
|
||||||
this.$message.error(this.$t('api_report.error'));
|
|
||||||
},
|
|
||||||
handleScroll() {
|
handleScroll() {
|
||||||
if (!this.clickStepFlag && this.$refs.apiDocInfoDiv) {
|
if (!this.clickStepFlag && this.$refs.apiDocInfoDiv) {
|
||||||
//apiDocInfoDiv的总高度,是(每个item的高度+20)数量
|
//apiDocInfoDiv的总高度,是(每个item的高度+20)数量
|
||||||
|
@ -717,7 +367,7 @@ export default {
|
||||||
//判断移动到了第几个元素. 公式: 移动过的高度+页面显示高度-第index子元素的高度(含20px)>0 的 index最大值
|
//判断移动到了第几个元素. 公式: 移动过的高度+页面显示高度-第index子元素的高度(含20px)>0 的 index最大值
|
||||||
if (scrolledHeigh > 0) {
|
if (scrolledHeigh > 0) {
|
||||||
lastIndex = index;
|
lastIndex = index;
|
||||||
let itemHeight = this.$refs.apiDocInfoDivItem[index].offsetHeight + 10;
|
let itemHeight = this.$refs.apiDocInfoDivItem[index].getHeight() + 10;
|
||||||
scrolledHeigh = scrolledHeigh - itemHeight;
|
scrolledHeigh = scrolledHeigh - itemHeight;
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
|
@ -726,9 +376,8 @@ export default {
|
||||||
|
|
||||||
if (lastIndex < this.currentApiIndexInApiShowArray) {
|
if (lastIndex < this.currentApiIndexInApiShowArray) {
|
||||||
//上移
|
//上移
|
||||||
// if(this.needAsyncSelect){
|
//进行判断:是否还需要为apiShowArray(已经查出来的api数据集) 增加数据。 由于在当前数据前后最多展现2条数据,
|
||||||
//进行判断:是否还需要为apiShowArray 增加数据。 由于在当前数据前后最多展现2条数据,
|
//若 apiStepIndex-1- 2 < apiInfoArray(已经查出来的api数据集),需要添加数据
|
||||||
//可得: apiStepIndex-1- 2 < apiInfoArray,需要添加数据
|
|
||||||
let dataIndex = this.apiStepIndex - 3;
|
let dataIndex = this.apiStepIndex - 3;
|
||||||
if (dataIndex >= 0) {
|
if (dataIndex >= 0) {
|
||||||
let apiInfo = this.apiInfoArray[dataIndex];
|
let apiInfo = this.apiInfoArray[dataIndex];
|
||||||
|
@ -785,7 +434,7 @@ export default {
|
||||||
this.currentApiIndexInApiShowArray++;
|
this.currentApiIndexInApiShowArray++;
|
||||||
} else {
|
} else {
|
||||||
this.apiShowArray.shift();
|
this.apiShowArray.shift();
|
||||||
let itemHeight = this.$refs.apiDocInfoDivItem[0].offsetHeight + 10;
|
let itemHeight = this.$refs.apiDocInfoDivItem[0].getHeight() + 10;
|
||||||
if (this.$refs.apiDocInfoDiv && this.$refs.apiDocInfoDiv.scrollTop) {
|
if (this.$refs.apiDocInfoDiv && this.$refs.apiDocInfoDiv.scrollTop) {
|
||||||
this.$refs.apiDocInfoDiv.scrollTop = (apiDocDivScrollTop - itemHeight);
|
this.$refs.apiDocInfoDiv.scrollTop = (apiDocDivScrollTop - itemHeight);
|
||||||
}
|
}
|
||||||
|
@ -805,7 +454,7 @@ export default {
|
||||||
let itemHeightCount = 0;
|
let itemHeightCount = 0;
|
||||||
if (this.currentApiIndexInApiShowArray > 0) {
|
if (this.currentApiIndexInApiShowArray > 0) {
|
||||||
for (let i = 0; i <= this.currentApiIndexInApiShowArray - 1; i++) {
|
for (let i = 0; i <= this.currentApiIndexInApiShowArray - 1; i++) {
|
||||||
let itemHeight = this.$refs.apiDocInfoDivItem[i].offsetHeight + 10;
|
let itemHeight = this.$refs.apiDocInfoDivItem[i].getHeight() + 10;
|
||||||
itemHeightCount += itemHeight;
|
itemHeightCount += itemHeight;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,580 @@
|
||||||
|
<template>
|
||||||
|
<div ref="baseDiv">
|
||||||
|
<div style="font-size: 17px">
|
||||||
|
<el-popover
|
||||||
|
v-if="projectId"
|
||||||
|
placement="right"
|
||||||
|
width="260"
|
||||||
|
@show="shareApiDocument('false')">
|
||||||
|
<p>{{ shareUrl }}</p>
|
||||||
|
<div style="text-align: right; margin: 0">
|
||||||
|
<el-button type="primary" size="mini"
|
||||||
|
v-clipboard:copy="shareUrl">{{ $t("commons.copy") }}
|
||||||
|
</el-button>
|
||||||
|
</div>
|
||||||
|
<i class="el-icon-share" slot="reference" style="margin-right: 10px;cursor: pointer"></i>
|
||||||
|
</el-popover>
|
||||||
|
{{ apiInfo.name }}
|
||||||
|
<span class="apiStatusTag">
|
||||||
|
<api-status :value="apiInfo.status"/>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<!--api请求信息-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="tip">
|
||||||
|
{{ $t('api_test.definition.document.request_info') }}
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="simpleFontClass">
|
||||||
|
<el-tag size="medium"
|
||||||
|
:style="{'background-color': getColor(true,apiInfo.method), border: getColor(true,apiInfo.method),borderRadius:'0px', marginRight:'20px',color:'white'}">
|
||||||
|
{{ apiInfo.method }}
|
||||||
|
</el-tag>
|
||||||
|
{{ apiInfo.uri }}
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--api请求头-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.request_head') }}:
|
||||||
|
<div v-if="getJsonArr(apiInfo.requestHead).length==0">
|
||||||
|
<div class="simpleFontClass" style="margin-top: 10px">
|
||||||
|
{{ $t('api_test.definition.document.data_set.none') }}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<el-table border :show-header="false"
|
||||||
|
:data="getJsonArr(apiInfo.requestHead)" class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.value')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--URL参数-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
URL{{ $t('api_test.definition.document.request_param') }}:
|
||||||
|
<div v-if="getJsonArr(apiInfo.urlParams).length==0">
|
||||||
|
<div class="simpleFontClass" style="margin-top: 10px">
|
||||||
|
{{ $t('api_test.definition.document.data_set.none') }}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<el-table border
|
||||||
|
:data="getJsonArr(apiInfo.urlParams)" class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="required"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.is_required')"
|
||||||
|
:formatter="formatBoolean"
|
||||||
|
min-width="80px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.value')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="description"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.desc')"
|
||||||
|
min-width="280px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--api请求体 以及表格-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.request_body') }}
|
||||||
|
</div>
|
||||||
|
<div class="smallFontClass">
|
||||||
|
{{ $t('api_test.definition.document.table_coloum.type') }}:{{ apiInfo.requestBodyParamType }}
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<el-table border v-if="formParamTypes.includes(apiInfo.requestBodyParamType)"
|
||||||
|
:data="getJsonArr(apiInfo.requestBodyFormData)"
|
||||||
|
class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="contentType"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.type')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="description"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.desc')"
|
||||||
|
min-width="280px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="required"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.is_required')"
|
||||||
|
:formatter="formatBoolean"
|
||||||
|
min-width="80px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.default_value')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
<div v-else-if="apiInfo.requestBodyParamType == 'JSON-SCHEMA'" style="margin-left: 10px">
|
||||||
|
<ms-json-code-edit :show-preview="false" :body="apiInfo.jsonSchemaBody" ref="jsonCodeEdit"/>
|
||||||
|
</div>
|
||||||
|
<div v-else-if="formatRowDataToJsonSchema(apiInfo,'request') " style="margin-left: 10px">
|
||||||
|
<ms-json-code-edit :show-preview="false" :body="apiInfo.requestJsonSchema" ref="jsonCodeEdit"/>
|
||||||
|
</div>
|
||||||
|
<div v-else class="showDataDiv">
|
||||||
|
<br/>
|
||||||
|
<p style="margin: 0px 20px;"
|
||||||
|
v-html="formatRowData(apiInfo.requestBodyParamType,apiInfo.requestBodyStrutureData)">
|
||||||
|
</p>
|
||||||
|
<br/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--范例展示-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.example_presentation') }}
|
||||||
|
</div>
|
||||||
|
<div class="showDataDiv">
|
||||||
|
<br/>
|
||||||
|
<p style="margin: 0px 20px;"
|
||||||
|
v-html="genPreviewData(apiInfo.requestPreviewData)">
|
||||||
|
</p>
|
||||||
|
<br/>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--响应信息-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="tip">
|
||||||
|
{{ $t('api_test.definition.document.response_info') }}
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
|
||||||
|
</el-row>
|
||||||
|
<!--响应头-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.response_head') }}:
|
||||||
|
<el-table border :show-header="false"
|
||||||
|
:data="getJsonArr(apiInfo.responseHead)" class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.value')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--响应体-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.response_body') }}
|
||||||
|
</div>
|
||||||
|
<div class="smallFontClass">
|
||||||
|
{{ $t('api_test.definition.document.table_coloum.type') }}:{{ apiInfo.responseBodyParamType }}
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<el-table border v-if="formParamTypes.includes(apiInfo.responseBodyParamType)"
|
||||||
|
:data="getJsonArr(apiInfo.responseBodyFormData)"
|
||||||
|
class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="contentType"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.type')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="description"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.desc')"
|
||||||
|
min-width="280px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="required"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.is_required')"
|
||||||
|
:formatter="formatBoolean"
|
||||||
|
min-width="80px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.default_value')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
<div v-else-if="apiInfo.responseBodyParamType == 'JSON-SCHEMA'" style="margin-left: 10px">
|
||||||
|
<ms-json-code-edit :show-preview="false" :body="apiInfo.jsonSchemaResponseBody" ref="jsonCodeEdit"/>
|
||||||
|
</div>
|
||||||
|
<div v-else-if="formatRowDataToJsonSchema(apiInfo,'response') " style="margin-left: 10px">
|
||||||
|
<ms-json-code-edit :show-preview="false" :body="apiInfo.responseJsonSchema" ref="jsonCodeEdit"/>
|
||||||
|
</div>
|
||||||
|
<div v-else class="showDataDiv">
|
||||||
|
<br/>
|
||||||
|
<p style="margin: 0px 20px;"
|
||||||
|
v-html="formatRowData(apiInfo.responseBodyParamType,apiInfo.responseBodyStrutureData)">
|
||||||
|
</p>
|
||||||
|
<br/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--响应状态码-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.response_code') }}:
|
||||||
|
<el-table border :show-header="false"
|
||||||
|
:data="getJsonArr(apiInfo.responseCode)" class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.value')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import {API_METHOD_COLOUR} from "@/business/components/api/definition/model/JsonData";
|
||||||
|
import MsCodeEdit from "@/business/components/common/components/MsCodeEdit";
|
||||||
|
import {formatJson,} from "@/common/js/format-utils";
|
||||||
|
import ApiStatus from "@/business/components/api/definition/components/list/ApiStatus";
|
||||||
|
import {calculate} from "@/business/components/api/definition/model/ApiTestModel";
|
||||||
|
import MsJsonCodeEdit from "@/business/components/common/json-schema/JsonSchemaEditor";
|
||||||
|
import Api from "@/business/components/api/router";
|
||||||
|
import {generateApiDocumentShareInfo} from "@/network/share";
|
||||||
|
import Convert from "@/business/components/common/json-schema/convert/convert";
|
||||||
|
|
||||||
|
const requireComponent = require.context('@/business/components/xpack/', true, /\.vue$/);
|
||||||
|
const apiDocumentBatchShare = (requireComponent != null && requireComponent.keys().length) > 0 ? requireComponent("./share/ApiDocumentBatchShare.vue") : {};
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: "ApiInformation",
|
||||||
|
components: {
|
||||||
|
Api,
|
||||||
|
MsJsonCodeEdit,
|
||||||
|
ApiStatus, MsCodeEdit,
|
||||||
|
"ApiDocumentBatchShare": apiDocumentBatchShare.default
|
||||||
|
},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
shareUrl: "",
|
||||||
|
batchShareUrl: "",
|
||||||
|
apiStepIndex: 0,
|
||||||
|
apiInfoArray: [],
|
||||||
|
modes: ['text', 'json', 'xml', 'html'],
|
||||||
|
formParamTypes: ['form-data', 'x-www-from-urlencoded', 'BINARY'],
|
||||||
|
mockVariableFuncs: [],
|
||||||
|
apiSearch: {
|
||||||
|
name: "",
|
||||||
|
type: "ALL",
|
||||||
|
orderCondition: "createTimeDesc",
|
||||||
|
},
|
||||||
|
apiInfoBaseObj: {
|
||||||
|
selectedFlag: false,
|
||||||
|
method: "无",
|
||||||
|
uri: "无",
|
||||||
|
name: "无",
|
||||||
|
id: "",
|
||||||
|
requestHead: "无",
|
||||||
|
urlParams: "无",
|
||||||
|
requestBodyParamType: "无",
|
||||||
|
requestBodyFormData: '[]',
|
||||||
|
requestBodyStrutureData: "",
|
||||||
|
sharePopoverVisible: false,
|
||||||
|
jsonSchemaBody: {},
|
||||||
|
JsonSchemaResponseBody: {},
|
||||||
|
responseHead: "无",
|
||||||
|
responseBody: "",
|
||||||
|
responseBodyParamType: "无",
|
||||||
|
responseBodyFormData: "无",
|
||||||
|
responseBodyStrutureData: "无",
|
||||||
|
responseCode: "无",
|
||||||
|
},
|
||||||
|
methodColorMap: new Map(API_METHOD_COLOUR),
|
||||||
|
maxCompnentSize: 5, //浏览器最多渲染的api信息体数量
|
||||||
|
apiShowArray: [],//浏览器要渲染的api信息集合
|
||||||
|
needAsyncSelect: false, //是否需要异步查询api详细数据做展现。只有本次要展示的数据总量大于maxCompnentSize时为true
|
||||||
|
currentApiIndexInApiShowArray: 0,//当前主要展示的api信息在apiShowArray的索引
|
||||||
|
clickStepFlag: false,
|
||||||
|
};
|
||||||
|
},
|
||||||
|
props: {
|
||||||
|
projectId: String,
|
||||||
|
apiInfo:Object
|
||||||
|
},
|
||||||
|
activated() {
|
||||||
|
},
|
||||||
|
created: function () {
|
||||||
|
if (requireComponent != null && JSON.stringify(apiDocumentBatchShare) != '{}') {
|
||||||
|
this.showXpackCompnent = true;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted() {
|
||||||
|
},
|
||||||
|
computed: {},
|
||||||
|
watch: {
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getId(){
|
||||||
|
return this.apiInfo.id;
|
||||||
|
},
|
||||||
|
getHeight(){
|
||||||
|
return this.$refs.baseDiv.offsetHeight;
|
||||||
|
},
|
||||||
|
formatRowDataToJsonSchema(api, jsonType) {
|
||||||
|
if (jsonType === 'request' && api.requestBodyStrutureData) {
|
||||||
|
try {
|
||||||
|
let bodyStructData = JSON.parse(api.requestBodyStrutureData);
|
||||||
|
api.requestJsonSchema = {'raw': bodyStructData};
|
||||||
|
return true;
|
||||||
|
} catch (e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else if (jsonType === 'response' && api.responseBodyStrutureData) {
|
||||||
|
try {
|
||||||
|
JSON.parse(api.responseBodyStrutureData);
|
||||||
|
api.responseJsonSchema = {'raw': api.responseBodyStrutureData};
|
||||||
|
return true;
|
||||||
|
} catch (e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
formatRowData(dataType, data) {
|
||||||
|
var returnData = data;
|
||||||
|
if (data) {
|
||||||
|
returnData = "<xmp>" + returnData + "</xmp>";
|
||||||
|
}
|
||||||
|
return returnData;
|
||||||
|
},
|
||||||
|
shareApiDocument(isBatchShare) {
|
||||||
|
this.shareUrl = "";
|
||||||
|
this.batchShareUrl = "";
|
||||||
|
let shareIdArr = [];
|
||||||
|
let shareType = "Single";
|
||||||
|
if (isBatchShare == 'true') {
|
||||||
|
this.apiInfoArray.forEach(f => {
|
||||||
|
if (!f.id) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
shareIdArr.push(f.id);
|
||||||
|
});
|
||||||
|
shareType = "Batch";
|
||||||
|
} else {
|
||||||
|
// shareIdArr.push(this.apiInfoArray[this.apiStepIndex].id);
|
||||||
|
shareIdArr.push(this.apiInfo.id);
|
||||||
|
}
|
||||||
|
let genShareInfoParam = {};
|
||||||
|
genShareInfoParam.shareApiIdList = shareIdArr;
|
||||||
|
genShareInfoParam.shareType = shareType;
|
||||||
|
|
||||||
|
generateApiDocumentShareInfo(genShareInfoParam, (data) => {
|
||||||
|
let thisHost = window.location.host;
|
||||||
|
if (shareType == "Batch") {
|
||||||
|
this.batchShareUrl = thisHost + "/document" + data.shareUrl;
|
||||||
|
} else {
|
||||||
|
this.shareUrl = thisHost + "/document" + data.shareUrl;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
getColor(enable, method) {
|
||||||
|
return this.methodColorMap.get(method);
|
||||||
|
},
|
||||||
|
formatBoolean(row, column, cellValue) {
|
||||||
|
var ret = ''; //你想在页面展示的值
|
||||||
|
if (cellValue) {
|
||||||
|
ret = "是"; //根据自己的需求设定
|
||||||
|
} else {
|
||||||
|
ret = "否";
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
},
|
||||||
|
getJsonArr(jsonString) {
|
||||||
|
let returnJsonArr = [];
|
||||||
|
if (jsonString == '无' || jsonString == null) {
|
||||||
|
return returnJsonArr;
|
||||||
|
}
|
||||||
|
|
||||||
|
let jsonArr = JSON.parse(jsonString);
|
||||||
|
//遍历,把必填项空的数据去掉
|
||||||
|
for (var index = 0; index < jsonArr.length; index++) {
|
||||||
|
var item = jsonArr[index];
|
||||||
|
if (item.name != "" && item.name != null) {
|
||||||
|
returnJsonArr.push(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return returnJsonArr;
|
||||||
|
},
|
||||||
|
//构建预览数据
|
||||||
|
genPreviewData(previewData) {
|
||||||
|
if (previewData != null && previewData != '') {
|
||||||
|
let showDataObj = {};
|
||||||
|
for (var key in previewData) {
|
||||||
|
// showDataObj.set(key,previewData[key]);
|
||||||
|
let value = previewData[key];
|
||||||
|
if (typeof (value) == 'string') {
|
||||||
|
if (value.indexOf("@") >= 0) {
|
||||||
|
value = this.showPreview(value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
showDataObj[key] = value;
|
||||||
|
}
|
||||||
|
showDataObj = JSON.stringify(showDataObj);
|
||||||
|
previewData = formatJson(showDataObj);
|
||||||
|
}
|
||||||
|
return previewData;
|
||||||
|
},
|
||||||
|
showPreview(itemValue) {
|
||||||
|
// 找到变量本身
|
||||||
|
if (!itemValue) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
let index = itemValue.indexOf("|");
|
||||||
|
if (index > -1) {
|
||||||
|
itemValue = itemValue.substring(0, index).trim();
|
||||||
|
}
|
||||||
|
|
||||||
|
this.mockVariableFuncs.forEach(f => {
|
||||||
|
if (!f.name) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
itemValue += "|" + f.name;
|
||||||
|
if (f.params) {
|
||||||
|
itemValue += ":" + f.params.map(p => p.value).join(",");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
itemValue = calculate(itemValue);
|
||||||
|
return itemValue;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.simpleFontClass {
|
||||||
|
font-weight: normal;
|
||||||
|
font-size: 14px;
|
||||||
|
margin-left: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.blackFontClass {
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.smallFontClass {
|
||||||
|
font-size: 13px;
|
||||||
|
margin: 20px 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apiInfoRow {
|
||||||
|
margin: 10px 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apiInfoRow.el-row {
|
||||||
|
margin: 10px 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apiStatusTag {
|
||||||
|
margin: 10px 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.showDataDiv {
|
||||||
|
background-color: #F5F7F9;
|
||||||
|
margin: 10px 10px;
|
||||||
|
max-height: 300px;
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
步骤条中,已经完成后的节点样式和里面a标签的样式
|
||||||
|
*/
|
||||||
|
|
||||||
|
/deep/ .el-step {
|
||||||
|
flex-basis: 40px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/deep/ .el-step__head.is-finish {
|
||||||
|
color: #C0C4CC;
|
||||||
|
border-color: #C0C4CC;
|
||||||
|
}
|
||||||
|
|
||||||
|
/deep/ .el-step__title.is-finish /deep/ .el-link.el-link--default {
|
||||||
|
color: #C0C4CC;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
步骤条中,当前节点样式和当前a标签的样式
|
||||||
|
*/
|
||||||
|
/deep/ .el-step__head {
|
||||||
|
width: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/deep/ .el-step__head.is-process {
|
||||||
|
color: #783887;
|
||||||
|
border-color: #783887;
|
||||||
|
width: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/deep/ .el-step__title.is-process .el-link.el-link--default.is-underline {
|
||||||
|
color: #783887;
|
||||||
|
}
|
||||||
|
|
||||||
|
/deep/ .el-link--inner {
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/deep/ .el-step__icon-inner {
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/deep/ .el-step.is-vertical .el-step__line {
|
||||||
|
left: 9px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/deep/ .el-step__icon {
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table {
|
||||||
|
margin: 10px 10px;
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table /deep/ .el-table__row {
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: initial;
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table /deep/ .has-gutter {
|
||||||
|
font-size: 12px;
|
||||||
|
color: #404040;
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table /deep/ td {
|
||||||
|
border-right: 0px solid #EBEEF5
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table /deep/ th {
|
||||||
|
background-color: #FAFAFA;
|
||||||
|
border-right: 0px solid #EBEEF5
|
||||||
|
}
|
||||||
|
|
||||||
|
.el-divider--horizontal {
|
||||||
|
margin: 12px 0;
|
||||||
|
}
|
||||||
|
</style>
|
Loading…
Reference in New Issue