Необработанный отказ (TypeError): api.getUser не является функцией - PullRequest
0 голосов
/ 30 июня 2018

Я создаю приложение React, и оно использует Axios. Проблема в том, что это работало в течение последнего месяца, а теперь вдруг перестало работать. Эта ошибка не имеет смысла для меня, потому что она ранее работала.

Состояние ошибки Unhandled Rejection (TypeError): api.getUser is not a function

Вот файл, содержащий axios, api.js:

import axios from 'axios';
import key from './keys';
import URL from './url';

export function login() {
  let url = URL + '/helix/login/';

  return axios.get(url, {headers: {'Api-Key': key}}).then(res => {
    window.location = res.data.authorization_url;
  });
}

export function authLogin(data) {
  let url = URL + '/helix/socialauth/login/';

  return axios.post(url, data, {headers: {'Api-Key': key}}).then(res => res);
}

export function consent(data, header) {
  let url = URL + '/user/profile/';

  return axios.put(url, data, {headers: header}).then(res => res);
}

export function getUser(header) {
  let url = URL + '/user/profile/';

  return axios.get(url, {headers: header}).then(res => res);
}

export function updateUser(data, header) {
  let url = URL + '/user/profile/';

  return axios.put(url, data, {headers: header}).then(res => res);
}

export function getAcct(header) {
  let url = URL + '/helix/account/';

  return axios.get(url, {headers: header}).then(res => res);
}

export function getTraits(header) {
  let url = URL + '/genomics/traits/summary/';

  return axios.get(url, {headers: header}).then(res => res);
}

export function getTraitDetails(header, id) {
  let url = URL + '/genomics/traits/' + id + '/';

  return axios.get(url, {headers: header}).then(res => res);
}

export function getCancers(header) {
  let url = URL + '/genomics/explore/';

  return axios.get(url, {headers: header}).then(res => res);
}

export function getGenomics(header) {
  let url = URL + '/genomics/home/';

  return axios.get(url, {headers: header}).then(res => res);
}

export default {login, authLogin, consent, getUser, updateUser, getAcct, getTraits, getTraitDetails, getCancers, getGenomics};

Вот файл, который использует эти файлы, он является частью Context API из React 14, UserContext.js:

import React from 'react';
import moment from 'moment';

// Utilities
import apikey from '../config/keys';
import history from '../config/history';

const api = require('../config/api');

// Create a context with default values
export const UserContext = React.createContext({
  first_name: null,
  last_name: null,
  email: null,
  birthday: null,
  gender: null,
  access_token: null,
  helix_user_id: null,
  uuid: null,
  key: null,
  status: 'register',
  loading: false,
  accepted_terms: false,
  delivery_date: null,
  data_available: false,
  kit_processing: false,
  kit_registered: false,
  traits_processed: false,
  ldt_status: null,
  userVisits: 0,
  cancer_groups: null,
  userTraits: [],
  userVariants: false,
  pos_trait_details: null,
  pos_trait_user: null,
  pos_trait_modules: null,
});

// This is the consumer of the values (state)
export const UserConsumer = UserContext.Consumer;

// Create a provider (wrapper that handles the logic)
// This also allows communication to context and update
// state values throughout app with user info
export class UserProvider extends React.Component {
  constructor(props) {
    super(props);

    this.state = {
      first_name: null,
      last_name: null,
      email: null,
      birthday: null,
      gender: null,
      access_token: null,
      helix_user_id: null,
      uuid: null,
      key: null,
      status: 'register',
      loading: false,
      accepted_terms: false,
      data_available: false,
      delivery_date: null,
      kit_processing: false,
      kit_registered: false,
      traits_processed: false,
      ldt_status: null,
      userVisits: 0,
      cancer_groups: [],
      userTraits: [],
      userVariants: false,
      pos_trait_details: [],
      pos_trait_user: null,
      pos_trait_modules_0: null,
      pos_trait_modules_1: null,
      pos_trait_modules_2: null,
      pos_trait_modules_3: null,
      pos_trait_modules_4: null,
      pos_trait_modules_5: null,
      pos_trait_modules_6: null,
    };

    this.get = this.get.bind(this);
    this.update = this.update.bind(this);
    this.updateConsent = this.updateConsent.bind(this);
    this.getAccount = this.getAccount.bind(this);
    this.logout = this.logout.bind(this);
    this.checkUserVisits = this.checkUserVisits.bind(this);
    this.getTraits = this.getTraits.bind(this);
    this.checkLastVisit = this.checkLastVisit.bind(this);
    this.getTraitDetails = this.getTraitDetails.bind(this);
  }

  componentDidMount() {
    let revisit = localStorage.getItem('giraffeToken');
    let test = 'state';
    let location = window.location.href;

    if(revisit !== null) {
      this.checkLastVisit(revisit);
    }

    if(revisit === null &&
      (location.includes('dashboard')
      || location.includes('profile')
      || location.includes('register')
      || location.includes('consent')
      || location.includes('gene')
      || location.includes('results-prep'))) {
      this.setState({loading: true});

      localStorage.removeItem('giraffeDate');
      localStorage.removeItem('giraffeKey');
      localStorage.removeItem('giraffeStatus');
      localStorage.removeItem('giraffeToken');

      setTimeout(() => {
        this.setState({loading:false});
      }, 1000);

      history.push('/');

      window.location.reload();
    }

    if(location.includes(test)) {
      this.setState({loading: true});
      let queryParams = location.split('?')[1];
      let params = queryParams.split('&');
      let pair = null;
      let code;
      let state;

      params.forEach(param => {
        pair = param.split('=');
        if(pair[0] === 'code') {
          code = pair[1];
        }
        if(pair[0] === 'state') {
          state = pair[1];
        }
      });

      let data = {code: code, state: state};

      api.authLogin(data).then(({data: {account, key, status}}) => {
        this.setState({
          key: key,
          first_name: account.first_name,
          last_name: account.last_name,
          email: account.email,
          access_token: account.access_token,
          helix_user_id: account.helix_user_id,
          uuid: account.uuid,
          status: status,
          loading: false
        });

        let header = {
          'Api-Key': apikey,
          'Authorization': 'Token ' + key
        };

        api.getUser(header).then(({data: {birthday, gender}}) => {
          this.setState({
            birthday: birthday,
            gender: gender,
          });
        });

        api.getCancers(header).then(({data: {cancer_groups}}) => {
          this.setState({
            cancer_groups: cancer_groups,
            loading: false
          })
        });

        api.getGenomics(header).then((data) => {
          console.log(data)
        })

        let d = moment().format('x');
        localStorage.setItem('giraffeToken', account.access_token);
        localStorage.setItem('giraffeKey', key);
        localStorage.setItem('giraffeDate', d);
        localStorage.setItem('giraffeStatus', status);

        history.push('/profile');
      });
    }

  }

  shouldComponentUpdate(nextProps, nextState) {
    return true;
  }

  get() {
    api.login();
  }

  update() {
    let data = {

    };

    let header = {
      'Api-Key': apikey,
      'Authorization': 'Token ' + this.state.key
    };

    api.updateUser(data, header);
  }

  updateConsent() {
    let data = {
      accepted_terms: true
    };

    let header = {
      'Api-Key': apikey,
      'Authorization': 'Token ' + this.state.key
    };

    api.consent(data, header).then(({data: {accepted_terms}}) => {
      this.setState({
        accepted_terms: accepted_terms,
        status: 'login',
        loading: true
      });

      setTimeout(() => {
        this.setState({loading: false});
        history.push('/profile');
      }, 1000);
    });
  }

  getAccount() {
    this.setState({loading: true});

    let header = {
      'Api-Key': apikey,
      'Authorization': 'Token ' + this.state.key
    };

    api.getAcct(header).then(({data: {status: {data_available, kit_processing, kit_registered, traits_processed, ldt_status, delivery_date}}}) => {
      this.setState({
        delivery_date: delivery_date,
        data_available: data_available,
        kit_processing: kit_processing,
        kit_registered: kit_registered,
        traits_processed: traits_processed,
        ldt_status: ldt_status,
      });

      this.checkUserVisits();
    });

    this.setState({loading: false});
  }

  checkUserVisits() {
    if(this.state.data_available && this.state.kit_registered && this.state.kit_processing && this.state.traits_processed) {
      let visits = localStorage.getItem('visits');


      if(visits === null || visits === undefined) {
        localStorage.setItem('visits', 0);
      }

      else if(visits === '0') {
        let visit = parseInt(visits, 10);
        localStorage.setItem('visits', (visit + 1));
        this.setState({userVisits: (visit + 1)});
      }
    }
  }

  checkLastVisit(revisit) {
    let lastLogin = parseInt(localStorage.getItem('giraffeDate'), 10);
    let token = localStorage.getItem('giraffeKey');
    let giraffeStatus = localStorage.getItem('giraffeStatus');
    let now = moment();

    if(now.diff(lastLogin, 'days') >= 1) {
      this.setState({loading: true});

      localStorage.removeItem('giraffeDate');
      localStorage.removeItem('giraffeKey');
      localStorage.removeItem('giraffeStatus');
      localStorage.removeItem('giraffeToken');

      setTimeout(() => {
        this.setState({loading:false});
      }, 1000);

      history.push('/');

      window.location.reload();
    }
    else {
      this.setState({loading: true});

      let header = {
        'Api-Key': apikey,
        'Authorization': 'Token ' + token
      };

      api.getAcct(header).then(({data, data: {first_name, last_name, email, helix_user_id, uuid, status}}) => {
        this.setState({
          access_token: localStorage.getItem('giraffeToken'),
          key: token,
          first_name: first_name,
          last_name: last_name,
          email: email,
          helix_user_id: helix_user_id,
          uuid: uuid,
          status: giraffeStatus,
          delivery_date: status.delivery_date,
          data_available: status.data_available,
          kit_processing: status.kit_processing,
          kit_registered: status.kit_registered,
          traits_processed: status.traits_processed,
          ldt_status: status.ldt_status,
          userVisits: parseInt(localStorage.getItem('visits'), 10)
        });
      }).catch((err) => {
        console.log('acct err: ', err);
        this.setState({loading: true});

        localStorage.removeItem('giraffeDate');
        localStorage.removeItem('giraffeKey');
        localStorage.removeItem('giraffeStatus');
        localStorage.removeItem('giraffeToken');
        localStorage.removeItem('visits');

        setTimeout(() => {
          this.setState({loading:false});
        }, 1000);

        history.push('/');

        window.location.reload();
      });

      api.getUser(header).then(({data: {birthday, gender}}) => {
        this.setState({
          birthday: birthday,
          gender: gender,
        });
      });

      api.getTraits(header).then(({data}) => {
        let variant = data.filter(item => item.user_trait.genotype_sum > 0);
        if(variant.length > 0) {
          this.setState({
            userTraits: data,
            userVariants: true
          });
        }
        else {
          this.setState({
            userTraits: []
          });
        }
      }).catch((err) => {
        console.log('traits error: ', err);
        this.setState({loading: true});

        localStorage.removeItem('giraffeDate');
        localStorage.removeItem('giraffeKey');
        localStorage.removeItem('giraffeStatus');
        localStorage.removeItem('giraffeToken');
        localStorage.removeItem('visits');

        setTimeout(() => {
          this.setState({loading:false});
        }, 1000);

        history.push('/');

        window.location.reload();
      });

      api.getCancers(header).then(({data: {cancer_groups}}) => {
        this.setState({
          cancer_groups: cancer_groups
        })
      });

      setTimeout(() => {
        history.push('/profile');
        this.setState({loading: false});
      }, 1000);
    }
  }

  getTraits() {
    this.setState({loading: true});
    // Get user results and based on results show the appropriate dashboard
    let header = {
      'Api-Key': apikey,
      'Authorization': 'Token ' + this.state.key
    };

    api.getTraits(header).then(({data}) => {
      let variant = data.filter(item => item.user_trait.genotype_sum > 0);
      if(variant.length > 0) {
        this.setState({
          userTraits: data,
          userVariants: true
        });
      }
      else {
        this.setState({
          userTraits: []
        });
      }

    });

    setTimeout(() => {
      this.setState({loading: false});
    }, 1000);
  }

  logout() {
    this.setState({loading: true});

    localStorage.removeItem('giraffeDate');
    localStorage.removeItem('giraffeKey');
    localStorage.removeItem('giraffeStatus');
    localStorage.removeItem('giraffeToken');

    setTimeout(() => {
      this.setState({loading:false});
    }, 1000);

    history.push('/');

    window.location.reload();
  }

  getTraitDetails(id) {
    let header = {
      'Api-Key': apikey,
      'Authorization': 'Token ' + this.state.key
    };

    api.getTraitDetails(header, id).then(({data: {modules, user_trait, trait}}) => {
      this.setState({
        pos_trait_details: trait,
        pos_trait_user: user_trait,
        pos_trait_modules: modules
      });

      for(let i = 0; i < modules.length; i ++) {

        let name = 'pos_trait_modules_' + i;
        let age_groups = 'pos_trait_modules_' + i + '_age_groups';
        let body = 'pos_trait_modules_' + i + '_body';
        let icon = 'pos_trait_modules_' + i + '_icon';
        let image = 'pos_trait_modules_' + i + '_image';
        let item_type = 'pos_trait_modules_' + i + '_item_type';
        let title = 'pos_trait_modules_' + i + '_title';
        let url = 'pos_trait_modules_' + i + '_url';
        let url_title = 'pos_trait_modules_' + i + '_url_title';
        let items = 'pos_trait_modules_' + i + '_items';

        // console.log(Object.values(modules[i])[0]);

        if(Object.values(modules[i])[0] !== null) {
          this.setState({
            [name]: Object.values(modules[i])[0],
            [age_groups]: Object.values(modules[i])[0].age_groups,
            [body]: Object.values(modules[i])[0].body,
            [icon]: Object.values(modules[i])[0].icon,
            [image]: Object.values(modules[i])[0].image,
            [item_type]: Object.values(modules[i])[0].item_type,
            [title]: Object.values(modules[i])[0].title,
            [url]: Object.values(modules[i])[0].url,
            [url_title]: Object.values(modules[i])[0].url_title,
            [items]: Object.values(modules[i])[0].items
          });
        }
      }

    });
  }

  render() {
    return (
      <UserContext.Provider
        value={{user: this.state,
          get: this.get,
          update: this.update,
          updateConsent: this.updateConsent,
          getAccount: this.getAccount,
          logout: this.logout,
          getTraits: this.getTraits,
          getTraitDetails: this.getTraitDetails
        }}
        >
        {this.props.children}
      </UserContext.Provider>
    );
  }
}

Я провел последний час, пытаясь выяснить проблему, но безрезультатно. Любая помощь будет оценена.

Я посмотрел, как происходит экспорт или происходит что-то еще, но не смог ничего найти.

Спасибо

1 Ответ

0 голосов
/ 30 июня 2018

Попробуйте, измените требование от:

const api = require('../config/api');

Кому:

import * as api from '../config/api'

Если это не сработает, поставьте это console.log(api) сразу после этой строки, это может быть проблемой с версией вашего babel.

...