yapi/client/containers/Project/Interface/InterfaceList/View.js

356 lines
11 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import './View.scss'
import React, { Component } from 'react'
import { connect } from 'react-redux'
import PropTypes from 'prop-types'
import { Table } from 'antd'
const mockEditor = require('./mockEditor.js')
import { formatTime } from '../../../../common.js';
import ErrMsg from '../../../../components/ErrMsg/ErrMsg.js';
// import { Card } from 'antd'
// import { getMockUrl } from '../../reducer/modules/news.js'
@connect(state=>{
return {
curData: state.inter.curdata,
currProject: state.project.currProject
}
})
class View extends Component {
constructor(props) {
super(props);
this.state = {
init: true
}
}
static propTypes = {
curData: PropTypes.object,
currProject: PropTypes.object
}
req_body_form(req_body_type,req_body_form){
if(req_body_type === 'form'){
const columns = [{
title: '参数名称',
dataIndex: 'name',
key: 'name'
}, {
title: '参数类型',
dataIndex: 'type',
key: 'type'
},{
title: '是否必须',
dataIndex: 'required',
key: 'required'
}, {
title: '备注',
dataIndex: 'value',
key: 'value',
width: '45%'
}];
const dataSource = [];
if(req_body_form&&req_body_form.length){
req_body_form.map((item,i)=>{
dataSource.push({
key: i,
name: item.name,
value: item.desc,
required: item.required?"必须":"非必须",
type: item.type === "text"?"文本":"文件"
})
})
}
return <div style={{display:dataSource.length?"":"none"}} className="colBody">
<span className="colKey">请求Body</span>
<Table bordered size="small" pagination = {false} columns= {columns} dataSource = {dataSource} />
</div>
}else if(req_body_type === 'file'){
return <div style={{display:this.props.curData.req_body_other?"":"none"}} className="colBody">
<span className="colKey">请求Body</span>
<div>{this.props.curData.req_body_other}</div>
</div>
}else if(req_body_type === 'raw'){
return <div style={{display:this.props.curData.req_body_other?"":"none"}} className="colBody">
<span className="colKey">请求Body</span>
<div>{this.props.curData.req_body_other}</div>
</div>
}
}
res_body(res_body_type,res_body){
if(res_body_type === 'json'){
let h = this.countEnter(this.props.curData.req_body_other);
return <div style={{display:this.props.curData.res_body?"":"none"}} className="colBody">
<span className="colKey">返回Body</span>
<div id="vres_body_json" style={{ minHeight: h*16+20 }}></div>
</div>
}else if(res_body_type === 'raw'){
return <div style={{display:this.props.curData.res_body?"":"none"}} className="colBody">
<span className="colKey">返回Body</span>
<div>{res_body}</div>
</div>
}
}
req_query(query){
const columns = [{
title: '参数名称',
dataIndex: 'name',
key: 'name'
}, {
title: '是否必须',
dataIndex: 'required',
key: 'required'
}, {
title: '备注',
dataIndex: 'value',
key: 'value',
width: '45%'
}];
const dataSource = [];
if(query&&query.length){
query.map((item,i)=>{
dataSource.push({
key: i,
name: item.name,
value: item.desc,
required: item.required?"必须":"非必须"
})
})
}
return <Table bordered size="small" pagination = {false} columns= {columns} dataSource = {dataSource} />;
}
countEnter(str){
let i = 0;
let c = 0;
if(!str||!str.indexOf) return 0;
while(str.indexOf('\n',i)>-1){
i = str.indexOf('\n',i) + 2;
c++;
}
return c;
}
bindAceEditor(){
if(this.props.curData.req_body_type === "json"&&this.props.curData.title){
mockEditor({
container: 'vreq_body_json',
data: this.props.curData.req_body_other,
readOnly:true,
onChange: function () {}
})
}
if(this.props.curData.title&&this.props.curData.res_body_type === "json"){
mockEditor({
container: 'vres_body_json',
data: this.props.curData.res_body,
readOnly:true,
onChange: function () {}
})
}
}
componentDidMount(){
if(this.props.curData.title){
this.bindAceEditor.bind(this)();
}
if(!this.props.curData.title&&this.state.init){
this.setState({init: false});
}
}
componentDidUpdate(){
this.bindAceEditor.bind(this)();
}
componentWillUpdate(){
if(!this.props.curData.title&&this.state.init){
this.setState({init: false});
}
}
render () {
const dataSource = [];
if(this.props.curData.req_headers&&this.props.curData.req_headers.length){
this.props.curData.req_headers.map((item,i)=>{
dataSource.push({
key: i,
name: item.name,
required: item.required?"必须":"非必须",
value: item.value,
desc: item.desc
})
})
}
const req_dataSource = [];
if(this.props.curData.req_params&&this.props.curData.req_params.length){
this.props.curData.req_params.map((item,i)=>{
req_dataSource.push({
key: i,
name: item.name,
value: item.desc
})
})
}
const req_params_columns = [{
title: '参数名称',
dataIndex: 'name',
key: 'name'
},{
title: '备注',
dataIndex: 'value',
key: 'value'
}];
const columns = [{
title: '参数名称',
dataIndex: 'name',
key: 'name',
width: 2
}, {
title: '参数值',
dataIndex: 'value',
key: 'value',
width: 2
}, {
title: '是否必须',
dataIndex: 'required',
key: 'required',
width: 1
},{
title: '备注',
dataIndex: 'desc',
key: 'desc',
width: 4
}];
let status = {
undone: "未完成",
done: "完成"
}
let statusColor = {
undone: {
bac: "rgb(255, 85, 0)",
color: "white"
},
done:{
bac: "rgb(135, 208, 104)",
color: "white"
}
}
let methodColor = {
post: {
bac: "#d2eafb",
color: "#108ee9"
},
get: {
bac: "#cfefdf",
color: "#00a854"
},
put: {
bac: "#fff3cf",
color: "#ffbf00"
},
delete: {
bac: "#fcdbd9",
color: "#f04134"
},
head: {
bac: "#fff3cf",
color: "#ffbf00"
},
patch: {
bac: "#fff3cf",
color: "#ffbf00"
},
options: {
bac: "#fff3cf",
color: "#ffbf00"
}
}
methodColor = methodColor[this.props.curData.method?this.props.curData.method.toLowerCase():"get"];
statusColor = statusColor[this.props.curData.status?this.props.curData.status.toLowerCase():"undone"];
let h = this.countEnter(this.props.curData.req_body_other);
const aceEditor = <div style={{display:this.props.curData.req_body_other&&this.props.curData.req_body_type==="json"?"block":"none"}} className="colBody">
<span className="colKey">请求Body</span>
<div id="vreq_body_json" style={{ minHeight: h*16+20 }}></div>
</div>
if(!methodColor) methodColor = "get";
let res = <div className="caseContainer">
<div className="colName">
<span className="colKey">接口名</span>
<span className="colValue">{this.props.curData.title}</span>
</div>
<div className="colMethod">
<span className="colKey">请求方法</span>
<span style={{color:methodColor.color,backgroundColor:methodColor.bac}} className="colValue">{this.props.curData.method}</span>
</div>
<div className="colPath">
<span className="colKey">接口路径</span>
<span className="colValue">{this.props.currProject.basepath}{this.props.curData.path}</span>
</div>
<div className="colstatus">
<span className="colKey">状态</span>
<span style={{backgroundColor:statusColor.bac,color: statusColor.color}} className="colValue">{status[this.props.curData.status]}</span>
</div>
<div className="colAddTime">
<span className="colKey">创建时间</span>
<span className="colValue">{formatTime(this.props.curData.add_time)}</span>
</div>
<div className="colUpTime">
<span className="colKey">更新时间</span>
<span className="colValue">{formatTime(this.props.curData.up_time)}</span>
</div>
<div className="colMockUrl">
<span className="colKey">Mock地址</span>
<span className="colValue">{location.protocol + '//' + location.hostname + (location.port !== "" ? ":" + location.port : "") + `/mock/${this.props.currProject._id}${this.props.currProject.basepath}${this.props.curData.path}`}</span>
</div>
{this.props.curData.desc?<div className="colDesc">
<span className="colKey">接口描述</span>
<span className="colValue">{this.props.curData.desc}</span>
</div>:""}
{req_dataSource.length?<div className="colHeader">
<span className="colKey">路径参数</span>
<Table bordered size="small" pagination = {false} columns= {req_params_columns} dataSource = {req_dataSource} />
</div>:""}
{dataSource.length?<div className="colHeader">
<span className="colKey">请求Headers</span>
<Table bordered size="small" pagination = {false} columns= {columns} dataSource = {dataSource} />
</div>:""}
{this.props.curData.req_query&&this.props.curData.req_query.length?<div className="colQuery">
<span className="colKey">Query</span>
{this.req_query(this.props.curData.req_query)}
</div>:""}
{/*<div className="colreqBodyType">
<span className="colKey">请求Body类型</span>
<span className="colValue">{this.props.curData.req_body_type}</span>
</div>*/}
{ aceEditor }
{this.req_body_form(this.props.curData.req_body_type,this.props.curData.req_body_form)}
{/*<div className="colreqBodyType">
<span className="colKey">返回Body类型</span>
<span className="colValue">{this.props.curData.res_body_type}</span>
</div>*/}
{this.res_body(this.props.curData.res_body_type,this.props.curData.res_body)}
</div>;
if(!this.props.curData.title){
if(this.state.init){
res = <div></div>;
}else{
res = <ErrMsg type="noData" />;
}
}
return res;
}
}
export default View