как вызвать класс из функции в реакции - PullRequest
0 голосов
/ 03 октября 2018

В основном, я пытаюсь вызвать модальный класс из ответа оси.Я хочу показать модальное всплывающее окно вместо предупреждений в приведенном ниже коде.Может кто-нибудь помочь, как вызвать модальный класс из функции перехватчика Axios?спасибо заранее

import React, { Component}  from 'react';
import axios from 'axios';
import Modals  from '../components/modalAlerts/modalalerts'
    const instance = axios.create({
        baseURL: 'http://someurl',
        timeout: 15000,
    }); 

    instance.defaults.headers.common['Authorization'] = //sequrity token will be here
    instance.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';

    instance.interceptors.request.use(function (config) {

        return config;
      }, function (error) {

        alert(error)
        return Promise.reject(error);
      });
    instance.interceptors.response.use(function (config) {

        return config;
      }, function (error) {
        console.log(error)
        if(error.response){
            if(error.response.status === 401||error.response.status === 403 ){
                localStorage.clear()
                alert(error.response.data.message)
            }else if(error.response.status === 404){
                console.log("404")
            }else if(error.response.status === 400){
               alert(error.response.data.message)
            }else{
                alert("something went wrong. Please try after sometime..!")
            }
        }else{
            alert("server not found")
        }

        return Promise.reject(error);
      });
    export default instance;

здесь мой файл modalalerts.js есть некоторые изменения в рендере, я изменю его позже (например, добавьте еще несколько полей, таких как статус, иметь больше фильтров)

    import React, { Component } from 'react';
import { Button, Card, CardBody, CardHeader, Col, Modal, ModalBody, ModalFooter, ModalHeader, Row } from 'reactstrap';

class Modals extends Component {
    constructor(props) {
        super(props);
        this.state = {
            modal: true,
        }    
        this.toggle = this.toggle.bind(this);
    }

    toggle() {
        this.setState({
            modal: !this.state.modal,
        });
    }

    render() {
        return (
            <div className="animated fadeIn">
                <Row>
                    <Col>
                        <Modal isOpen={this.state.modal} toggle={this.toggle} className={this.props.className}>
                            <ModalHeader toggle={this.toggle}>{this.props.apistatus == 1? "Success" : "Error"}</ModalHeader>
                            <ModalBody>
                                {this.props.apistatus == 1? "Form updated successfully" : this.props.errormsg}
                            </ModalBody>
                            <ModalFooter>
                                <Button color="primary" onClick={this.toggle}>OK</Button>{' '}
                                {/* <Button color="secondary" onClick={this.toggle}>Cancel</Button> */}
                            </ModalFooter>
                        </Modal>       
                    </Col>
                </Row>
            </div>
        );
    }
}

export default Modals;
...