import React, { Component } from 'react' import PropTypes from 'prop-types' import { connect } from 'react-redux' import { Button, Input, Select } from 'antd' import { autobind } from 'core-decorators'; import crossRequest from 'cross-request'; import { withRouter } from 'react-router'; import URL from 'url'; import { } from '../../../actions/group.js' import './InterfaceTest.scss' const { TextArea } = Input; const InputGroup = Input.Group; const Option = Select.Option; @connect( state => ({ reqParams: state.addInterface.reqParams, method: state.addInterface.method, url: state.addInterface.url, seqGroup: state.addInterface.seqGroup, interfaceName: state.addInterface.interfaceName, interfaceProject: state.addInterface.project }), { } ) @withRouter export default class InterfaceTest extends Component { static propTypes = { reqParams: PropTypes.string, method: PropTypes.string, url: PropTypes.string, interfaceName: PropTypes.string, seqGroup: PropTypes.array, match: PropTypes.object, interfaceProject: PropTypes.object } state = { res: '', header: {} } constructor(props) { super(props) } componentWillMount() { } @autobind testInterface() { const { method, url, seqGroup, interfaceProject } = this.props; const { prd_host, basepath, protocol } = interfaceProject; const reqParams = JSON.parse(this.props.reqParams); const query = {}; if (method === 'GET') { Object.keys(reqParams).forEach(key => { const value = typeof reqParams[key] === 'object' ? JSON.stringify(reqParams) : reqParams.toString(); query[key] = value; }) } const headers = {} seqGroup.forEach((headerItem) => { if (headerItem.name) { headers[headerItem.name] = headerItem.value; } }) const href = URL.format({ protocol: protocol || 'http', host: prd_host, pathname: (basepath + url).replace(/\/+/g, '/'), query }); crossRequest({ url: href, method, headers, data: { a:1 }, success: (res, header) => { this.setState({res}) console.log(header) } }) } render () { const { method, url, seqGroup, interfaceName, interfaceProject } = this.props; const { prd_host, basepath, protocol, env } = interfaceProject; const reqParams = JSON.parse(this.props.reqParams); const pathname = (basepath + url).replace(/\/+/g, '/'); const domains = [{name: 'prd', domain: protocol + '://' + prd_host}]; env.forEach(item => { domains.push({name: item.name, domain: item.domain}); }) const query = {}; if (method === 'GET') { Object.keys(reqParams).forEach(key => { const value = typeof reqParams[key] === 'object' ? JSON.stringify(reqParams[key]) : reqParams[key].toString(); query[key] = value; }) } const search = URL.format({ query }); return (