Как показать Тайм-аут на 25000 мс, если API не предоставляет данные с использованием избыточности? - PullRequest
2 голосов
/ 28 февраля 2020

Я новичок в реакции и редукции. Я реализовал выборку API с использованием избыточности, но не уверен, куда мне поместить код для Timeout, если API не дает данные за определенное время. все работает нормально, я тоже получаю данные ... единственное, что я застрял, это как показать тайм-аут. Есть ли способ сделать это? Заранее спасибо:)

редуктор. js

export const GET_REPOS = 'my-awesome-app/repos/LOAD';
export const GET_REPOS_SUCCESS = 'my-awesome-app/repos/LOAD_SUCCESS';
export const GET_REPOS_FAIL = 'my-awesome-app/repos/LOAD_FAIL';


const initialState = {
  repos: [],
  loading: false,
  error: null
};


export default function reducer(state = initialState , action) {
  switch (action.type) {
    case GET_REPOS:
      return { ...state, loading: true };
    case GET_REPOS_SUCCESS:
      return { ...state, loading: false, repos: action.payload.data };
    case GET_REPOS_FAIL:
      return {
        ...state,
        loading: false,
        error: 'Error while fetching repositories',
      };
    default:
      return state;
  }
}

export function listRepos(photos) {
  return {
    type: GET_REPOS,
    payload: {
      request: {
        url: `photos/`
      }
    }
  };
}

export function listThumb(albumId) {
  return {
    type: GET_REPOS,
    payload: {
      request: {
        url: `photos?albumId=${albumId}`
      }
    }
  };
}

home. js

import React, { Component } from 'react';
import { ActivityIndicator } from 'react-native-paper';
import { View, Text, FlatList, StyleSheet, TouchableOpacity } from 'react-native';
import { connect } from 'react-redux';
import styles from '../HomeComponent/style';
import { Ionicons } from '@expo/vector-icons';
import { listRepos } from '../../../reducer';
import ErrorAlert from '../../common/ErrorAlertComponent/errorAlert';


class Home extends Component {
  componentDidMount() {
    this.props.listRepos('');
  }

  FlatListItemSeparator = () => (
    <View style={styles.flatListItemSeparator} />
  )

  renderItem = ({ item }) => (

    <View style={styles.listRowContainer}>

      <TouchableOpacity onPress={() => this.props.navigation.navigate('ThumbnailViewScreen', {
        albumID: item.id,
      })} style={styles.listRow}>
        <View style={styles.listTextNavVIew}>
          <Text style={styles.albumTitle}> {item.title} </Text>
          <Ionicons name='md-arrow-dropright' style={styles.detailArrow} />
        </View>
      </TouchableOpacity>

    </View>
  );
  render() {
    const { error, loading, products } = this.props;

    if (error) {
      return <ErrorAlert />;
    }

    if (loading) {
      return (
        <View style={{ flex: 1, paddingTop: 30 }}>
            <ActivityIndicator animating={true} size='large' />
        </View>
      );
    }
    const { repos } = this.props;
    return (
      <View style={styles.MainContainer} >
        <FlatList
          styles={styles.container}
          data={repos}
          renderItem={this.renderItem}
          ItemSeparatorComponent={this.FlatListItemSeparator}

        />
      </View>
    );
  }
}

const mapStateToProps = state => {
  let storedRepositories = state.repos.map(repo => ({ key: repo.id.toString(), ...repo }));
  return {
    repos: storedRepositories, 
    loading: state.loading,
    error: state.error
  };
};

const mapDispatchToProps = {
  listRepos
};

export default connect(mapStateToProps, mapDispatchToProps)(Home);

1 Ответ

1 голос
/ 29 февраля 2020

Сначала вы должны создать точку входа для своего топора ios. Например:

import axios from 'axios/index';

const api = axios.create({
  baseURL: 'site.com',
  timeout: 25000,
});

export default api;

И импортируйте его там, где вы делаете вызовы API:

import api from 'yourDirectory';

И используйте эту точку входа:

api.get(url)

Если время запроса слишком велико длинный топор ios выдает timeout ошибка после 25000мс

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...