import React, {PureComponent} from 'react'; import autobind from 'autobind-decorator'; import ContentTypeDropdown from '../dropdowns/content-type-dropdown'; import MethodDropdown from '../dropdowns/method-dropdown'; import Modal from '../base/modal'; import ModalBody from '../base/modal-body'; import ModalHeader from '../base/modal-header'; import ModalFooter from '../base/modal-footer'; import {getContentTypeName, METHOD_GET, METHOD_HEAD, METHOD_OPTIONS, METHOD_DELETE} from '../../../common/constants'; import * as models from '../../../models/index'; import {trackEvent} from '../../../analytics/index'; @autobind class RequestCreateModal extends PureComponent { constructor (props) { super(props); this.state = { selectedContentType: null, selectedMethod: METHOD_GET, parentId: null }; } _setModalRef (n) { this.modal = n; } _setInputRef (n) { this._input = n; } async _handleSubmit (e) { e.preventDefault(); const {parentId, selectedContentType, selectedMethod} = this.state; const request = models.initModel(models.request.type, { parentId, name: this._input.value, method: selectedMethod }); const finalRequest = await models.request.updateMimeType( request, this._shouldNotHaveBody() ? null : selectedContentType, true, ); this._onComplete(finalRequest); this.hide(); } _handleChangeSelectedContentType (selectedContentType) { this.setState({selectedContentType}); trackEvent('Request Create', 'Content Type Change', selectedContentType); } _handleChangeSelectedMethod (selectedMethod) { this.setState({selectedMethod}); trackEvent('Request Create', 'Method Change', selectedMethod); } _shouldNotHaveBody () { const {selectedMethod} = this.state; return ( selectedMethod === METHOD_GET || selectedMethod === METHOD_HEAD || selectedMethod === METHOD_DELETE || selectedMethod === METHOD_OPTIONS ); } hide () { this.modal.hide(); } show ({parentId, onComplete}) { this.modal.show(); this._input.value = 'My Request'; this.setState({ parentId, selectedContentType: null, selectedMethod: METHOD_GET }); // Need to do this after render because modal focuses itself too setTimeout(() => { this._input.focus(); this._input.select(); }, 200); this._onComplete = onComplete; } render () { const {selectedContentType, selectedMethod} = this.state; return ( New Request
{!this._shouldNotHaveBody() && (
{getContentTypeName(selectedContentType) || 'No Body'} {' '}
)}
* Tip: paste Curl command into URL afterwards to import it
); } } RequestCreateModal.propTypes = {}; export default RequestCreateModal;