UNPKG

@ahooksjs/use-request

Version:

React Hooks for fetching, caching and updating asynchronous data

185 lines (141 loc) 4.61 kB
var __assign = this && this.__assign || function () { __assign = Object.assign || function (t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) { if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } } return t; }; return __assign.apply(this, arguments); }; var __rest = this && this.__rest || function (s, e) { var t = {}; for (var p in s) { if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; } if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; var __read = this && this.__read || function (o, n) { var m = typeof Symbol === "function" && o[Symbol.iterator]; if (!m) return o; var i = m.call(o), r, ar = [], e; try { while ((n === void 0 || n-- > 0) && !(r = i.next()).done) { ar.push(r.value); } } catch (error) { e = { error: error }; } finally { try { if (r && !r.done && (m = i["return"])) m.call(i); } finally { if (e) throw e.error; } } return ar; }; var __spread = this && this.__spread || function () { for (var ar = [], i = 0; i < arguments.length; i++) { ar = ar.concat(__read(arguments[i])); } return ar; }; /* eslint-disable react-hooks/rules-of-hooks */ import { useRef, useContext } from 'react'; import useAsync from './useAsync'; import useLoadMore from './useLoadMore'; import usePaginated from './usePaginated'; import ConfigContext from './configContext'; function useRequest(service, options) { if (options === void 0) { options = {}; } var contextConfig = useContext(ConfigContext); var finalOptions = __assign(__assign({}, contextConfig), options); var paginated = finalOptions.paginated, loadMore = finalOptions.loadMore, requestMethod = finalOptions.requestMethod; var paginatedRef = useRef(paginated); var loadMoreRef = useRef(loadMore); if (paginatedRef.current !== paginated) { throw Error('You should not modify the paginated of options'); } if (loadMoreRef.current !== loadMore) { throw Error('You should not modify the loadMore of options'); } paginatedRef.current = paginated; loadMoreRef.current = loadMore; // @ts-ignore var fetchProxy = function fetchProxy() { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } // @ts-ignore return fetch.apply(void 0, __spread(args)).then(function (res) { if (res.ok) { return res.json(); } throw new Error(res.statusText); }); }; var finalRequestMethod = requestMethod || fetchProxy; var promiseService; switch (typeof service) { case 'string': promiseService = function promiseService() { return finalRequestMethod(service); }; break; case 'object': var url_1 = service.url, rest_1 = __rest(service, ["url"]); promiseService = function promiseService() { return requestMethod ? requestMethod(service) : fetchProxy(url_1, rest_1); }; break; default: promiseService = function promiseService() { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } return new Promise(function (resolve, reject) { var s = service.apply(void 0, __spread(args)); var fn = s; if (!s.then) { switch (typeof s) { case 'string': fn = finalRequestMethod(s); break; case 'object': var url_2 = s.url, rest_2 = __rest(s, ["url"]); fn = requestMethod ? requestMethod(s) : fetchProxy(url_2, rest_2); break; } } fn.then(resolve)["catch"](reject); }); }; } if (loadMore) { return useLoadMore(promiseService, finalOptions); } if (paginated) { return usePaginated(promiseService, finalOptions); } return useAsync(promiseService, finalOptions); } var UseRequestProvider = ConfigContext.Provider; // UseAPIProvider 已经废弃,此处为了兼容 umijs 插件 plugin-request var UseAPIProvider = UseRequestProvider; export { useAsync, usePaginated, useLoadMore, UseRequestProvider, UseAPIProvider }; export default useRequest;