icode-hooks 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +65 -0
- package/dist/icode-hooks.js +1 -0
- package/es/createUpdateEffect/index.d.ts +4 -0
- package/es/createUpdateEffect/index.js +22 -0
- package/es/index.d.ts +9 -0
- package/es/index.js +9 -0
- package/es/useBoolean/index.d.ts +8 -0
- package/es/useBoolean/index.js +27 -0
- package/es/useCreation/index.d.ts +2 -0
- package/es/useCreation/index.js +21 -0
- package/es/useLatest/index.d.ts +3 -0
- package/es/useLatest/index.js +7 -0
- package/es/useMemoizedFn/index.d.ts +3 -0
- package/es/useMemoizedFn/index.js +31 -0
- package/es/useMount/index.d.ts +2 -0
- package/es/useMount/index.js +15 -0
- package/es/usePrescription/api.d.ts +7 -0
- package/es/usePrescription/api.js +17 -0
- package/es/usePrescription/index.d.ts +36 -0
- package/es/usePrescription/index.js +119 -0
- package/es/usePrescription/types.d.ts +15 -0
- package/es/usePrescription/types.js +1 -0
- package/es/useRequest/index.d.ts +4 -0
- package/es/useRequest/index.js +4 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/cancel.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/cancel.js +56 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/default.d.ts +6 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/default.js +30 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/lifeCycle.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/lifeCycle.js +55 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/manualRun.d.ts +7 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/manualRun.js +53 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/manualRunAsync.d.ts +7 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/manualRunAsync.js +67 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/mutate.d.ts +6 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/mutate.js +68 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/params.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/params.js +44 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/refresh.d.ts +6 -0
- package/es/useRequest/routes-doc/use-request/demos/basic/refresh.js +35 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/cacheKey.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/cacheKey.js +41 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/clearCache.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/clearCache.js +80 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/params.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/params.js +65 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/setCache.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/setCache.js +48 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/share.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/share.js +37 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/staleTime.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/cache/staleTime.js +43 -0
- package/es/useRequest/routes-doc/use-request/demos/debounce/debounce.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/debounce/debounce.js +41 -0
- package/es/useRequest/routes-doc/use-request/demos/index/default.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/index/default.js +23 -0
- package/es/useRequest/routes-doc/use-request/demos/index/manual.d.ts +7 -0
- package/es/useRequest/routes-doc/use-request/demos/index/manual.js +50 -0
- package/es/useRequest/routes-doc/use-request/demos/loadingDelay/loadingDelay.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/loadingDelay/loadingDelay.js +29 -0
- package/es/useRequest/routes-doc/use-request/demos/polling/polling.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/polling/polling.js +31 -0
- package/es/useRequest/routes-doc/use-request/demos/polling/pollingError.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/polling/pollingError.js +37 -0
- package/es/useRequest/routes-doc/use-request/demos/ready/manualReady.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/ready/manualReady.js +36 -0
- package/es/useRequest/routes-doc/use-request/demos/ready/ready.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/ready/ready.js +28 -0
- package/es/useRequest/routes-doc/use-request/demos/refresh/refreshDeps.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/refresh/refreshDeps.js +60 -0
- package/es/useRequest/routes-doc/use-request/demos/refreshOnWindowFocus/refreshOnWindowFocus.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/refreshOnWindowFocus/refreshOnWindowFocus.js +18 -0
- package/es/useRequest/routes-doc/use-request/demos/retry/retry.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/retry/retry.js +42 -0
- package/es/useRequest/routes-doc/use-request/demos/throttle/throttle.d.ts +3 -0
- package/es/useRequest/routes-doc/use-request/demos/throttle/throttle.js +41 -0
- package/es/useRequest/src/Fetch.d.ts +20 -0
- package/es/useRequest/src/Fetch.js +161 -0
- package/es/useRequest/src/plugins/useAutoRunPlugin.d.ts +3 -0
- package/es/useRequest/src/plugins/useAutoRunPlugin.js +56 -0
- package/es/useRequest/src/plugins/useCachePlugin.d.ts +3 -0
- package/es/useRequest/src/plugins/useCachePlugin.js +143 -0
- package/es/useRequest/src/plugins/useDebouncePlugin.d.ts +3 -0
- package/es/useRequest/src/plugins/useDebouncePlugin.js +61 -0
- package/es/useRequest/src/plugins/useLoadingDelayPlugin.d.ts +3 -0
- package/es/useRequest/src/plugins/useLoadingDelayPlugin.js +40 -0
- package/es/useRequest/src/plugins/usePollingPlugin.d.ts +3 -0
- package/es/useRequest/src/plugins/usePollingPlugin.js +65 -0
- package/es/useRequest/src/plugins/useRefreshOnWindowFocusPlugin.d.ts +3 -0
- package/es/useRequest/src/plugins/useRefreshOnWindowFocusPlugin.js +30 -0
- package/es/useRequest/src/plugins/useRetryPlugin.d.ts +3 -0
- package/es/useRequest/src/plugins/useRetryPlugin.js +45 -0
- package/es/useRequest/src/plugins/useThrottlePlugin.d.ts +3 -0
- package/es/useRequest/src/plugins/useThrottlePlugin.js +53 -0
- package/es/useRequest/src/types.d.ts +73 -0
- package/es/useRequest/src/types.js +1 -0
- package/es/useRequest/src/useRequest.d.ts +3 -0
- package/es/useRequest/src/useRequest.js +14 -0
- package/es/useRequest/src/useRequestImplement.d.ts +5 -0
- package/es/useRequest/src/useRequestImplement.js +72 -0
- package/es/useRequest/src/utils/cache.d.ts +14 -0
- package/es/useRequest/src/utils/cache.js +32 -0
- package/es/useRequest/src/utils/cachePromise.d.ts +4 -0
- package/es/useRequest/src/utils/cachePromise.js +17 -0
- package/es/useRequest/src/utils/cacheSubscribe.d.ts +4 -0
- package/es/useRequest/src/utils/cacheSubscribe.js +19 -0
- package/es/useRequest/src/utils/isDocumentVisible.d.ts +1 -0
- package/es/useRequest/src/utils/isDocumentVisible.js +7 -0
- package/es/useRequest/src/utils/isOnline.d.ts +1 -0
- package/es/useRequest/src/utils/isOnline.js +7 -0
- package/es/useRequest/src/utils/limit.d.ts +1 -0
- package/es/useRequest/src/utils/limit.js +17 -0
- package/es/useRequest/src/utils/subscribeFocus.d.ts +3 -0
- package/es/useRequest/src/utils/subscribeFocus.js +27 -0
- package/es/useRequest/src/utils/subscribeReVisible.d.ts +3 -0
- package/es/useRequest/src/utils/subscribeReVisible.js +21 -0
- package/es/useToggle/index.d.ts +10 -0
- package/es/useToggle/index.js +41 -0
- package/es/useUnmount/index.d.ts +2 -0
- package/es/useUnmount/index.js +17 -0
- package/es/useUpdate/index.d.ts +2 -0
- package/es/useUpdate/index.js +10 -0
- package/es/useUpdateEffect/index.d.ts +3 -0
- package/es/useUpdateEffect/index.js +3 -0
- package/es/utils/createEffectWithTarget.d.ts +4 -0
- package/es/utils/createEffectWithTarget.js +48 -0
- package/es/utils/depsAreSame.d.ts +2 -0
- package/es/utils/depsAreSame.js +8 -0
- package/es/utils/depsEqual.d.ts +2 -0
- package/es/utils/depsEqual.js +11 -0
- package/es/utils/domTarget.d.ts +6 -0
- package/es/utils/domTarget.js +20 -0
- package/es/utils/getDocumentOrShadow.d.ts +3 -0
- package/es/utils/getDocumentOrShadow.js +28 -0
- package/es/utils/index.d.ts +6 -0
- package/es/utils/index.js +18 -0
- package/es/utils/isAppleDevice.d.ts +2 -0
- package/es/utils/isAppleDevice.js +3 -0
- package/es/utils/isBrowser.d.ts +2 -0
- package/es/utils/isBrowser.js +2 -0
- package/es/utils/isDev.d.ts +2 -0
- package/es/utils/isDev.js +3 -0
- package/es/utils/lodash-polyfill.d.ts +2 -0
- package/es/utils/lodash-polyfill.js +11 -0
- package/es/utils/testingHelpers.d.ts +2 -0
- package/es/utils/testingHelpers.js +19 -0
- package/es/utils/tests.d.ts +4 -0
- package/es/utils/tests.js +12 -0
- package/es/utils/useDeepCompareWithTarget.d.ts +4 -0
- package/es/utils/useDeepCompareWithTarget.js +14 -0
- package/es/utils/useEffectWithTarget.d.ts +2 -0
- package/es/utils/useEffectWithTarget.js +5 -0
- package/es/utils/useIsomorphicLayoutEffectWithTarget.d.ts +2 -0
- package/es/utils/useIsomorphicLayoutEffectWithTarget.js +5 -0
- package/es/utils/useLayoutEffectWithTarget.d.ts +2 -0
- package/es/utils/useLayoutEffectWithTarget.js +4 -0
- package/lib/createUpdateEffect/index.d.ts +4 -0
- package/lib/createUpdateEffect/index.js +28 -0
- package/lib/index.d.ts +9 -0
- package/lib/index.js +69 -0
- package/lib/useBoolean/index.d.ts +8 -0
- package/lib/useBoolean/index.js +33 -0
- package/lib/useCreation/index.d.ts +2 -0
- package/lib/useCreation/index.js +28 -0
- package/lib/useLatest/index.d.ts +3 -0
- package/lib/useLatest/index.js +13 -0
- package/lib/useMemoizedFn/index.d.ts +3 -0
- package/lib/useMemoizedFn/index.js +40 -0
- package/lib/useMount/index.d.ts +2 -0
- package/lib/useMount/index.js +23 -0
- package/lib/usePrescription/api.d.ts +7 -0
- package/lib/usePrescription/api.js +23 -0
- package/lib/usePrescription/index.d.ts +36 -0
- package/lib/usePrescription/index.js +127 -0
- package/lib/usePrescription/types.d.ts +15 -0
- package/lib/usePrescription/types.js +5 -0
- package/lib/useRequest/index.d.ts +4 -0
- package/lib/useRequest/index.js +16 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/cancel.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/cancel.js +65 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/default.d.ts +6 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/default.js +38 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/lifeCycle.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/lifeCycle.js +64 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/manualRun.d.ts +7 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/manualRun.js +63 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/manualRunAsync.d.ts +7 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/manualRunAsync.js +77 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/mutate.d.ts +6 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/mutate.js +78 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/params.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/params.js +53 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/refresh.d.ts +6 -0
- package/lib/useRequest/routes-doc/use-request/demos/basic/refresh.js +45 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/cacheKey.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/cacheKey.js +48 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/clearCache.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/clearCache.js +87 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/params.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/params.js +74 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/setCache.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/setCache.js +55 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/share.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/share.js +44 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/staleTime.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/cache/staleTime.js +50 -0
- package/lib/useRequest/routes-doc/use-request/demos/debounce/debounce.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/debounce/debounce.js +48 -0
- package/lib/useRequest/routes-doc/use-request/demos/index/default.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/index/default.js +30 -0
- package/lib/useRequest/routes-doc/use-request/demos/index/manual.d.ts +7 -0
- package/lib/useRequest/routes-doc/use-request/demos/index/manual.js +60 -0
- package/lib/useRequest/routes-doc/use-request/demos/loadingDelay/loadingDelay.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/loadingDelay/loadingDelay.js +36 -0
- package/lib/useRequest/routes-doc/use-request/demos/polling/polling.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/polling/polling.js +38 -0
- package/lib/useRequest/routes-doc/use-request/demos/polling/pollingError.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/polling/pollingError.js +44 -0
- package/lib/useRequest/routes-doc/use-request/demos/ready/manualReady.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/ready/manualReady.js +43 -0
- package/lib/useRequest/routes-doc/use-request/demos/ready/ready.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/ready/ready.js +35 -0
- package/lib/useRequest/routes-doc/use-request/demos/refresh/refreshDeps.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/refresh/refreshDeps.js +69 -0
- package/lib/useRequest/routes-doc/use-request/demos/refreshOnWindowFocus/refreshOnWindowFocus.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/refreshOnWindowFocus/refreshOnWindowFocus.js +25 -0
- package/lib/useRequest/routes-doc/use-request/demos/retry/retry.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/retry/retry.js +51 -0
- package/lib/useRequest/routes-doc/use-request/demos/throttle/throttle.d.ts +3 -0
- package/lib/useRequest/routes-doc/use-request/demos/throttle/throttle.js +48 -0
- package/lib/useRequest/src/Fetch.d.ts +20 -0
- package/lib/useRequest/src/Fetch.js +168 -0
- package/lib/useRequest/src/plugins/useAutoRunPlugin.d.ts +3 -0
- package/lib/useRequest/src/plugins/useAutoRunPlugin.js +63 -0
- package/lib/useRequest/src/plugins/useCachePlugin.d.ts +3 -0
- package/lib/useRequest/src/plugins/useCachePlugin.js +150 -0
- package/lib/useRequest/src/plugins/useDebouncePlugin.d.ts +3 -0
- package/lib/useRequest/src/plugins/useDebouncePlugin.js +67 -0
- package/lib/useRequest/src/plugins/useLoadingDelayPlugin.d.ts +3 -0
- package/lib/useRequest/src/plugins/useLoadingDelayPlugin.js +46 -0
- package/lib/useRequest/src/plugins/usePollingPlugin.d.ts +3 -0
- package/lib/useRequest/src/plugins/usePollingPlugin.js +72 -0
- package/lib/useRequest/src/plugins/useRefreshOnWindowFocusPlugin.d.ts +3 -0
- package/lib/useRequest/src/plugins/useRefreshOnWindowFocusPlugin.js +37 -0
- package/lib/useRequest/src/plugins/useRetryPlugin.d.ts +3 -0
- package/lib/useRequest/src/plugins/useRetryPlugin.js +51 -0
- package/lib/useRequest/src/plugins/useThrottlePlugin.d.ts +3 -0
- package/lib/useRequest/src/plugins/useThrottlePlugin.js +59 -0
- package/lib/useRequest/src/types.d.ts +73 -0
- package/lib/useRequest/src/types.js +5 -0
- package/lib/useRequest/src/useRequest.d.ts +3 -0
- package/lib/useRequest/src/useRequest.js +21 -0
- package/lib/useRequest/src/useRequestImplement.d.ts +5 -0
- package/lib/useRequest/src/useRequestImplement.js +80 -0
- package/lib/useRequest/src/utils/cache.d.ts +14 -0
- package/lib/useRequest/src/utils/cache.js +37 -0
- package/lib/useRequest/src/utils/cachePromise.d.ts +4 -0
- package/lib/useRequest/src/utils/cachePromise.js +22 -0
- package/lib/useRequest/src/utils/cacheSubscribe.d.ts +4 -0
- package/lib/useRequest/src/utils/cacheSubscribe.js +24 -0
- package/lib/useRequest/src/utils/isDocumentVisible.d.ts +1 -0
- package/lib/useRequest/src/utils/isDocumentVisible.js +14 -0
- package/lib/useRequest/src/utils/isOnline.d.ts +1 -0
- package/lib/useRequest/src/utils/isOnline.js +14 -0
- package/lib/useRequest/src/utils/limit.d.ts +1 -0
- package/lib/useRequest/src/utils/limit.js +23 -0
- package/lib/useRequest/src/utils/subscribeFocus.d.ts +3 -0
- package/lib/useRequest/src/utils/subscribeFocus.js +35 -0
- package/lib/useRequest/src/utils/subscribeReVisible.d.ts +3 -0
- package/lib/useRequest/src/utils/subscribeReVisible.js +28 -0
- package/lib/useToggle/index.d.ts +10 -0
- package/lib/useToggle/index.js +47 -0
- package/lib/useUnmount/index.d.ts +2 -0
- package/lib/useUnmount/index.js +25 -0
- package/lib/useUpdate/index.d.ts +2 -0
- package/lib/useUpdate/index.js +16 -0
- package/lib/useUpdateEffect/index.d.ts +3 -0
- package/lib/useUpdateEffect/index.js +9 -0
- package/lib/utils/createEffectWithTarget.d.ts +4 -0
- package/lib/utils/createEffectWithTarget.js +55 -0
- package/lib/utils/depsAreSame.d.ts +2 -0
- package/lib/utils/depsAreSame.js +14 -0
- package/lib/utils/depsEqual.d.ts +2 -0
- package/lib/utils/depsEqual.js +17 -0
- package/lib/utils/domTarget.d.ts +6 -0
- package/lib/utils/domTarget.js +27 -0
- package/lib/utils/getDocumentOrShadow.d.ts +3 -0
- package/lib/utils/getDocumentOrShadow.js +34 -0
- package/lib/utils/index.d.ts +6 -0
- package/lib/utils/index.js +26 -0
- package/lib/utils/isAppleDevice.d.ts +2 -0
- package/lib/utils/isAppleDevice.js +9 -0
- package/lib/utils/isBrowser.d.ts +2 -0
- package/lib/utils/isBrowser.js +8 -0
- package/lib/utils/isDev.d.ts +2 -0
- package/lib/utils/isDev.js +9 -0
- package/lib/utils/lodash-polyfill.d.ts +2 -0
- package/lib/utils/lodash-polyfill.js +23 -0
- package/lib/utils/testingHelpers.d.ts +2 -0
- package/lib/utils/testingHelpers.js +26 -0
- package/lib/utils/tests.d.ts +4 -0
- package/lib/utils/tests.js +30 -0
- package/lib/utils/useDeepCompareWithTarget.d.ts +4 -0
- package/lib/utils/useDeepCompareWithTarget.js +21 -0
- package/lib/utils/useEffectWithTarget.d.ts +2 -0
- package/lib/utils/useEffectWithTarget.js +12 -0
- package/lib/utils/useIsomorphicLayoutEffectWithTarget.d.ts +2 -0
- package/lib/utils/useIsomorphicLayoutEffectWithTarget.js +12 -0
- package/lib/utils/useLayoutEffectWithTarget.d.ts +2 -0
- package/lib/utils/useLayoutEffectWithTarget.js +11 -0
- package/package.json +28 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = void 0;
|
|
8
|
+
var _index = _interopRequireDefault(require("../../../../index"));
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
var _mockjs = _interopRequireDefault(require("mockjs"));
|
|
11
|
+
function getUsername() {
|
|
12
|
+
console.log('polling getUsername');
|
|
13
|
+
return new Promise(function (resolve) {
|
|
14
|
+
setTimeout(function () {
|
|
15
|
+
resolve(_mockjs["default"].mock('@name'));
|
|
16
|
+
}, 1000);
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
var _default = exports["default"] = function _default() {
|
|
20
|
+
var _a = (0, _index["default"])(getUsername, {
|
|
21
|
+
pollingInterval: 1000,
|
|
22
|
+
pollingWhenHidden: false
|
|
23
|
+
}),
|
|
24
|
+
data = _a.data,
|
|
25
|
+
loading = _a.loading,
|
|
26
|
+
run = _a.run,
|
|
27
|
+
cancel = _a.cancel;
|
|
28
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("p", null, "Username: ", loading ? 'Loading' : data), /*#__PURE__*/_react["default"].createElement("button", {
|
|
29
|
+
type: "button",
|
|
30
|
+
onClick: run
|
|
31
|
+
}, "start"), /*#__PURE__*/_react["default"].createElement("button", {
|
|
32
|
+
type: "button",
|
|
33
|
+
onClick: cancel,
|
|
34
|
+
style: {
|
|
35
|
+
marginLeft: 16
|
|
36
|
+
}
|
|
37
|
+
}, "stop"));
|
|
38
|
+
};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = void 0;
|
|
8
|
+
var _index = _interopRequireDefault(require("../../../../index"));
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
var _mockjs = _interopRequireDefault(require("mockjs"));
|
|
11
|
+
var _antd = require("antd");
|
|
12
|
+
function getUsername() {
|
|
13
|
+
console.log('polling getUsername Error');
|
|
14
|
+
return new Promise(function (resolve, reject) {
|
|
15
|
+
setTimeout(function () {
|
|
16
|
+
reject(new Error(_mockjs["default"].mock('@name')));
|
|
17
|
+
}, 1000);
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
var _default = exports["default"] = function _default() {
|
|
21
|
+
var _a = (0, _index["default"])(getUsername, {
|
|
22
|
+
pollingInterval: 1000,
|
|
23
|
+
pollingWhenHidden: false,
|
|
24
|
+
pollingErrorRetryCount: 3,
|
|
25
|
+
manual: true,
|
|
26
|
+
onError: function onError(error) {
|
|
27
|
+
_antd.message.error(error.message);
|
|
28
|
+
}
|
|
29
|
+
}),
|
|
30
|
+
data = _a.data,
|
|
31
|
+
loading = _a.loading,
|
|
32
|
+
run = _a.run,
|
|
33
|
+
cancel = _a.cancel;
|
|
34
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("p", null, "Username: ", loading ? 'Loading' : data), /*#__PURE__*/_react["default"].createElement("button", {
|
|
35
|
+
type: "button",
|
|
36
|
+
onClick: run
|
|
37
|
+
}, "start"), /*#__PURE__*/_react["default"].createElement("button", {
|
|
38
|
+
type: "button",
|
|
39
|
+
onClick: cancel,
|
|
40
|
+
style: {
|
|
41
|
+
marginLeft: 16
|
|
42
|
+
}
|
|
43
|
+
}, "stop"));
|
|
44
|
+
};
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = void 0;
|
|
8
|
+
var _tslib = require("tslib");
|
|
9
|
+
var _index = _interopRequireDefault(require("../../../../index"));
|
|
10
|
+
var _useToggle = _interopRequireDefault(require("../../../../../useToggle"));
|
|
11
|
+
var _mockjs = _interopRequireDefault(require("mockjs"));
|
|
12
|
+
var _react = _interopRequireDefault(require("react"));
|
|
13
|
+
function getUsername() {
|
|
14
|
+
return new Promise(function (resolve) {
|
|
15
|
+
setTimeout(function () {
|
|
16
|
+
resolve(_mockjs["default"].mock('@name'));
|
|
17
|
+
}, 1000);
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
var _default = exports["default"] = function _default() {
|
|
21
|
+
var _a = (0, _tslib.__read)((0, _useToggle["default"])(false), 2),
|
|
22
|
+
ready = _a[0],
|
|
23
|
+
toggle = _a[1].toggle;
|
|
24
|
+
var _b = (0, _index["default"])(getUsername, {
|
|
25
|
+
ready: ready,
|
|
26
|
+
manual: true
|
|
27
|
+
}),
|
|
28
|
+
data = _b.data,
|
|
29
|
+
loading = _b.loading,
|
|
30
|
+
run = _b.run;
|
|
31
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("p", null, "Ready: ", JSON.stringify(ready), /*#__PURE__*/_react["default"].createElement("button", {
|
|
32
|
+
onClick: toggle,
|
|
33
|
+
style: {
|
|
34
|
+
marginLeft: 16
|
|
35
|
+
}
|
|
36
|
+
}, "Toggle Ready")), /*#__PURE__*/_react["default"].createElement("p", null, "Username: ", loading ? 'Loading' : data, /*#__PURE__*/_react["default"].createElement("button", {
|
|
37
|
+
type: "button",
|
|
38
|
+
onClick: run,
|
|
39
|
+
style: {
|
|
40
|
+
marginLeft: 16
|
|
41
|
+
}
|
|
42
|
+
}, "run")));
|
|
43
|
+
};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = void 0;
|
|
8
|
+
var _tslib = require("tslib");
|
|
9
|
+
var _index = _interopRequireDefault(require("../../../../index"));
|
|
10
|
+
var _useToggle = _interopRequireDefault(require("../../../../../useToggle"));
|
|
11
|
+
var _mockjs = _interopRequireDefault(require("mockjs"));
|
|
12
|
+
var _react = _interopRequireDefault(require("react"));
|
|
13
|
+
function getUsername() {
|
|
14
|
+
return new Promise(function (resolve) {
|
|
15
|
+
setTimeout(function () {
|
|
16
|
+
resolve(_mockjs["default"].mock('@name'));
|
|
17
|
+
}, 1000);
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
var _default = exports["default"] = function _default() {
|
|
21
|
+
var _a = (0, _tslib.__read)((0, _useToggle["default"])(false), 2),
|
|
22
|
+
ready = _a[0],
|
|
23
|
+
toggle = _a[1].toggle;
|
|
24
|
+
var _b = (0, _index["default"])(getUsername, {
|
|
25
|
+
ready: ready
|
|
26
|
+
}),
|
|
27
|
+
data = _b.data,
|
|
28
|
+
loading = _b.loading;
|
|
29
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("p", null, "Ready: ", JSON.stringify(ready), /*#__PURE__*/_react["default"].createElement("button", {
|
|
30
|
+
onClick: toggle,
|
|
31
|
+
style: {
|
|
32
|
+
marginLeft: 16
|
|
33
|
+
}
|
|
34
|
+
}, "Toggle Ready")), /*#__PURE__*/_react["default"].createElement("p", null, "Username: ", loading ? 'Loading' : data));
|
|
35
|
+
};
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
var _tslib = require("tslib");
|
|
10
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
11
|
+
var _index = _interopRequireDefault(require("../../../../index"));
|
|
12
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
|
|
13
|
+
var userSchool = function userSchool(id) {
|
|
14
|
+
switch (id) {
|
|
15
|
+
case '1':
|
|
16
|
+
return 'Tsinghua University';
|
|
17
|
+
case '2':
|
|
18
|
+
return 'Beijing University';
|
|
19
|
+
case '3':
|
|
20
|
+
return 'Zhejiang University';
|
|
21
|
+
default:
|
|
22
|
+
return '';
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
function getUserSchool(userId) {
|
|
26
|
+
return (0, _tslib.__awaiter)(this, void 0, void 0, function () {
|
|
27
|
+
return (0, _tslib.__generator)(this, function (_a) {
|
|
28
|
+
return [2 /*return*/, new Promise(function (resolve) {
|
|
29
|
+
setTimeout(function () {
|
|
30
|
+
resolve(userSchool(userId));
|
|
31
|
+
}, 1000);
|
|
32
|
+
})];
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
var _default = exports["default"] = function _default() {
|
|
37
|
+
var _a = (0, _tslib.__read)((0, _react.useState)('1'), 2),
|
|
38
|
+
userId = _a[0],
|
|
39
|
+
setUserId = _a[1];
|
|
40
|
+
var _b = (0, _index["default"])(function () {
|
|
41
|
+
return getUserSchool(userId);
|
|
42
|
+
}, {
|
|
43
|
+
refreshDeps: [userId],
|
|
44
|
+
defaultParams: [userId]
|
|
45
|
+
}),
|
|
46
|
+
data = _b.data,
|
|
47
|
+
loading = _b.loading;
|
|
48
|
+
// const { run, loading, data } = useRequest(getUserSchool, {
|
|
49
|
+
// defaultParams: [userId],
|
|
50
|
+
// refreshDeps: [userId],
|
|
51
|
+
// refreshDepsAction: () => run(userId),
|
|
52
|
+
// });
|
|
53
|
+
return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("select", {
|
|
54
|
+
onChange: function onChange(e) {
|
|
55
|
+
return setUserId(e.target.value);
|
|
56
|
+
},
|
|
57
|
+
value: userId,
|
|
58
|
+
style: {
|
|
59
|
+
marginBottom: 16,
|
|
60
|
+
width: 120
|
|
61
|
+
}
|
|
62
|
+
}, /*#__PURE__*/_react["default"].createElement("option", {
|
|
63
|
+
value: "1"
|
|
64
|
+
}, "user 1"), /*#__PURE__*/_react["default"].createElement("option", {
|
|
65
|
+
value: "2"
|
|
66
|
+
}, "user 2"), /*#__PURE__*/_react["default"].createElement("option", {
|
|
67
|
+
value: "3"
|
|
68
|
+
}, "user 3")), /*#__PURE__*/_react["default"].createElement("p", null, "School: ", loading ? 'Loading' : data));
|
|
69
|
+
};
|
package/lib/useRequest/routes-doc/use-request/demos/refreshOnWindowFocus/refreshOnWindowFocus.js
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = void 0;
|
|
8
|
+
var _mockjs = _interopRequireDefault(require("mockjs"));
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
var _index = _interopRequireDefault(require("../../../../index"));
|
|
11
|
+
function getUsername() {
|
|
12
|
+
return new Promise(function (resolve) {
|
|
13
|
+
setTimeout(function () {
|
|
14
|
+
resolve(_mockjs["default"].mock('@name'));
|
|
15
|
+
}, 1000);
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
var _default = exports["default"] = function _default() {
|
|
19
|
+
var _a = (0, _index["default"])(getUsername, {
|
|
20
|
+
refreshOnWindowFocus: true
|
|
21
|
+
}),
|
|
22
|
+
data = _a.data,
|
|
23
|
+
loading = _a.loading;
|
|
24
|
+
return /*#__PURE__*/_react["default"].createElement("div", null, "Username: ", loading ? 'Loading' : data);
|
|
25
|
+
};
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
var _tslib = require("tslib");
|
|
10
|
+
var _index = _interopRequireDefault(require("../../../../index"));
|
|
11
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
12
|
+
var _antd = require("antd");
|
|
13
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
|
|
14
|
+
function editUsername(username) {
|
|
15
|
+
return new Promise(function (resolve, reject) {
|
|
16
|
+
setTimeout(function () {
|
|
17
|
+
reject(new Error('Failed to modify username'));
|
|
18
|
+
}, 1000);
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
var _default = exports["default"] = function _default() {
|
|
22
|
+
var _a = (0, _tslib.__read)((0, _react.useState)(''), 2),
|
|
23
|
+
state = _a[0],
|
|
24
|
+
setState = _a[1];
|
|
25
|
+
var _b = (0, _index["default"])(editUsername, {
|
|
26
|
+
retryCount: 3,
|
|
27
|
+
manual: true,
|
|
28
|
+
onError: function onError(error) {
|
|
29
|
+
_antd.message.error(error.message);
|
|
30
|
+
}
|
|
31
|
+
}),
|
|
32
|
+
loading = _b.loading,
|
|
33
|
+
run = _b.run;
|
|
34
|
+
return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("input", {
|
|
35
|
+
onChange: function onChange(e) {
|
|
36
|
+
return setState(e.target.value);
|
|
37
|
+
},
|
|
38
|
+
value: state,
|
|
39
|
+
placeholder: "Please enter username",
|
|
40
|
+
style: {
|
|
41
|
+
width: 240,
|
|
42
|
+
marginRight: 16
|
|
43
|
+
}
|
|
44
|
+
}), /*#__PURE__*/_react["default"].createElement("button", {
|
|
45
|
+
disabled: loading,
|
|
46
|
+
type: "button",
|
|
47
|
+
onClick: function onClick() {
|
|
48
|
+
return run(state);
|
|
49
|
+
}
|
|
50
|
+
}, loading ? 'Loading' : 'Edit'));
|
|
51
|
+
};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = void 0;
|
|
8
|
+
var _tslib = require("tslib");
|
|
9
|
+
var _index = _interopRequireDefault(require("../../../../index"));
|
|
10
|
+
var _mockjs = _interopRequireDefault(require("mockjs"));
|
|
11
|
+
var _react = _interopRequireDefault(require("react"));
|
|
12
|
+
function getEmail(search) {
|
|
13
|
+
return (0, _tslib.__awaiter)(this, void 0, void 0, function () {
|
|
14
|
+
return (0, _tslib.__generator)(this, function (_a) {
|
|
15
|
+
console.log('throttle getEmail', search);
|
|
16
|
+
return [2 /*return*/, new Promise(function (resolve) {
|
|
17
|
+
setTimeout(function () {
|
|
18
|
+
resolve(_mockjs["default"].mock({
|
|
19
|
+
'data|5': ['@email']
|
|
20
|
+
}).data);
|
|
21
|
+
}, 300);
|
|
22
|
+
})];
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
var _default = exports["default"] = function _default() {
|
|
27
|
+
var _a = (0, _index["default"])(getEmail, {
|
|
28
|
+
throttleWait: 1000,
|
|
29
|
+
manual: true
|
|
30
|
+
}),
|
|
31
|
+
data = _a.data,
|
|
32
|
+
loading = _a.loading,
|
|
33
|
+
run = _a.run;
|
|
34
|
+
return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("input", {
|
|
35
|
+
placeholder: "Search Emails",
|
|
36
|
+
onChange: function onChange(e) {
|
|
37
|
+
return run(e.target.value);
|
|
38
|
+
}
|
|
39
|
+
}), loading ? /*#__PURE__*/_react["default"].createElement("p", null, "loading") : /*#__PURE__*/_react["default"].createElement("ul", {
|
|
40
|
+
style: {
|
|
41
|
+
marginTop: 8
|
|
42
|
+
}
|
|
43
|
+
}, data === null || data === void 0 ? void 0 : data.map(function (i) {
|
|
44
|
+
return /*#__PURE__*/_react["default"].createElement("li", {
|
|
45
|
+
key: i
|
|
46
|
+
}, i);
|
|
47
|
+
})));
|
|
48
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { MutableRefObject } from 'react';
|
|
2
|
+
import type { FetchState, Options, PluginReturn, Service, Subscribe } from './types';
|
|
3
|
+
export default class Fetch<TData, TParams extends any[]> {
|
|
4
|
+
serviceRef: MutableRefObject<Service<TData, TParams>>;
|
|
5
|
+
options: Options<TData, TParams>;
|
|
6
|
+
subscribe: Subscribe;
|
|
7
|
+
initState: Partial<FetchState<TData, TParams>>;
|
|
8
|
+
pluginImpls: PluginReturn<TData, TParams>[];
|
|
9
|
+
count: number;
|
|
10
|
+
state: FetchState<TData, TParams>;
|
|
11
|
+
constructor(serviceRef: MutableRefObject<Service<TData, TParams>>, options: Options<TData, TParams>, subscribe: Subscribe, initState?: Partial<FetchState<TData, TParams>>);
|
|
12
|
+
setState(s?: Partial<FetchState<TData, TParams>>): void;
|
|
13
|
+
runPluginHandler(event: keyof PluginReturn<TData, TParams>, ...rest: any[]): any;
|
|
14
|
+
runAsync(...params: TParams): Promise<TData>;
|
|
15
|
+
run(...params: TParams): void;
|
|
16
|
+
cancel(): void;
|
|
17
|
+
refresh(): void;
|
|
18
|
+
refreshAsync(): Promise<TData>;
|
|
19
|
+
mutate(data?: TData | ((oldData?: TData) => TData | undefined)): void;
|
|
20
|
+
}
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports["default"] = void 0;
|
|
7
|
+
var _tslib = require("tslib");
|
|
8
|
+
var _utils = require("../../utils");
|
|
9
|
+
/* eslint-disable @typescript-eslint/no-parameter-properties */
|
|
10
|
+
|
|
11
|
+
var Fetch = /** @class */function () {
|
|
12
|
+
function Fetch(serviceRef, options, subscribe, initState) {
|
|
13
|
+
if (initState === void 0) {
|
|
14
|
+
initState = {};
|
|
15
|
+
}
|
|
16
|
+
this.serviceRef = serviceRef;
|
|
17
|
+
this.options = options;
|
|
18
|
+
this.subscribe = subscribe;
|
|
19
|
+
this.initState = initState;
|
|
20
|
+
this.count = 0;
|
|
21
|
+
this.state = {
|
|
22
|
+
loading: false,
|
|
23
|
+
params: undefined,
|
|
24
|
+
data: undefined,
|
|
25
|
+
error: undefined
|
|
26
|
+
};
|
|
27
|
+
this.state = (0, _tslib.__assign)((0, _tslib.__assign)((0, _tslib.__assign)({}, this.state), {
|
|
28
|
+
loading: !options.manual
|
|
29
|
+
}), initState);
|
|
30
|
+
}
|
|
31
|
+
Fetch.prototype.setState = function (s) {
|
|
32
|
+
if (s === void 0) {
|
|
33
|
+
s = {};
|
|
34
|
+
}
|
|
35
|
+
this.state = (0, _tslib.__assign)((0, _tslib.__assign)({}, this.state), s);
|
|
36
|
+
this.subscribe();
|
|
37
|
+
};
|
|
38
|
+
//「同一生命周期点,依次问所有插件,再把它们返回的东西合并成一份」
|
|
39
|
+
Fetch.prototype.runPluginHandler = function (event) {
|
|
40
|
+
var rest = [];
|
|
41
|
+
for (var _i = 1; _i < arguments.length; _i++) {
|
|
42
|
+
rest[_i - 1] = arguments[_i];
|
|
43
|
+
}
|
|
44
|
+
// @ts-ignore
|
|
45
|
+
var r = this.pluginImpls.map(function (i) {
|
|
46
|
+
var _a;
|
|
47
|
+
return (_a = i[event]) === null || _a === void 0 ? void 0 : _a.call.apply(_a, (0, _tslib.__spreadArray)([i], (0, _tslib.__read)(rest), false));
|
|
48
|
+
}).filter(Boolean);
|
|
49
|
+
return r.reduce(function (acc, cur) {
|
|
50
|
+
return Object.assign(acc, cur);
|
|
51
|
+
}, {});
|
|
52
|
+
};
|
|
53
|
+
Fetch.prototype.runAsync = function () {
|
|
54
|
+
var params = [];
|
|
55
|
+
for (var _i = 0; _i < arguments.length; _i++) {
|
|
56
|
+
params[_i] = arguments[_i];
|
|
57
|
+
}
|
|
58
|
+
return (0, _tslib.__awaiter)(this, void 0, void 0, function () {
|
|
59
|
+
var currentCount, _a, _b, stopNow, _c, returnNow, state, servicePromise, res, error_1;
|
|
60
|
+
var _d;
|
|
61
|
+
var _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
|
|
62
|
+
return (0, _tslib.__generator)(this, function (_q) {
|
|
63
|
+
switch (_q.label) {
|
|
64
|
+
case 0:
|
|
65
|
+
this.count += 1;
|
|
66
|
+
currentCount = this.count;
|
|
67
|
+
_a = this.runPluginHandler('onBefore', params), _b = _a.stopNow, stopNow = _b === void 0 ? false : _b, _c = _a.returnNow, returnNow = _c === void 0 ? false : _c, state = (0, _tslib.__rest)(_a, ["stopNow", "returnNow"]);
|
|
68
|
+
// stop request
|
|
69
|
+
if (stopNow) {
|
|
70
|
+
return [2 /*return*/, new Promise(function () {})];
|
|
71
|
+
}
|
|
72
|
+
this.setState((0, _tslib.__assign)({
|
|
73
|
+
loading: true,
|
|
74
|
+
params: params
|
|
75
|
+
}, state));
|
|
76
|
+
// return now 缓存场景下,直接返回缓存数据
|
|
77
|
+
if (returnNow) {
|
|
78
|
+
return [2 /*return*/, Promise.resolve(state.data)];
|
|
79
|
+
}
|
|
80
|
+
(_f = (_e = this.options).onBefore) === null || _f === void 0 ? void 0 : _f.call(_e, params);
|
|
81
|
+
_q.label = 1;
|
|
82
|
+
case 1:
|
|
83
|
+
_q.trys.push([1, 3,, 4]);
|
|
84
|
+
servicePromise = this.runPluginHandler('onRequest', this.serviceRef.current, params).servicePromise;
|
|
85
|
+
if (!servicePromise) {
|
|
86
|
+
servicePromise = (_d = this.serviceRef).current.apply(_d, (0, _tslib.__spreadArray)([], (0, _tslib.__read)(params), false));
|
|
87
|
+
}
|
|
88
|
+
console.log('servicePromise', servicePromise);
|
|
89
|
+
return [4 /*yield*/, servicePromise];
|
|
90
|
+
case 2:
|
|
91
|
+
res = _q.sent();
|
|
92
|
+
if (currentCount !== this.count) {
|
|
93
|
+
// prevent run.then when request is canceled
|
|
94
|
+
return [2 /*return*/, new Promise(function () {})];
|
|
95
|
+
}
|
|
96
|
+
// const formattedResult = this.options.formatResultRef.current ? this.options.formatResultRef.current(res) : res;
|
|
97
|
+
this.setState({
|
|
98
|
+
data: res,
|
|
99
|
+
error: undefined,
|
|
100
|
+
loading: false
|
|
101
|
+
});
|
|
102
|
+
(_h = (_g = this.options).onSuccess) === null || _h === void 0 ? void 0 : _h.call(_g, res, params);
|
|
103
|
+
this.runPluginHandler('onSuccess', res, params);
|
|
104
|
+
(_k = (_j = this.options).onFinally) === null || _k === void 0 ? void 0 : _k.call(_j, params, res, undefined);
|
|
105
|
+
if (currentCount === this.count) {
|
|
106
|
+
this.runPluginHandler('onFinally', params, res, undefined);
|
|
107
|
+
}
|
|
108
|
+
return [2 /*return*/, res];
|
|
109
|
+
case 3:
|
|
110
|
+
error_1 = _q.sent();
|
|
111
|
+
if (currentCount !== this.count) {
|
|
112
|
+
// prevent run.then when request is canceled
|
|
113
|
+
return [2 /*return*/, new Promise(function () {})];
|
|
114
|
+
}
|
|
115
|
+
this.setState({
|
|
116
|
+
error: error_1,
|
|
117
|
+
loading: false
|
|
118
|
+
});
|
|
119
|
+
(_m = (_l = this.options).onError) === null || _m === void 0 ? void 0 : _m.call(_l, error_1, params);
|
|
120
|
+
this.runPluginHandler('onError', error_1, params);
|
|
121
|
+
(_p = (_o = this.options).onFinally) === null || _p === void 0 ? void 0 : _p.call(_o, params, undefined, error_1);
|
|
122
|
+
if (currentCount === this.count) {
|
|
123
|
+
this.runPluginHandler('onFinally', params, undefined, error_1);
|
|
124
|
+
}
|
|
125
|
+
throw error_1;
|
|
126
|
+
case 4:
|
|
127
|
+
return [2 /*return*/];
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
};
|
|
132
|
+
Fetch.prototype.run = function () {
|
|
133
|
+
var _this = this;
|
|
134
|
+
var params = [];
|
|
135
|
+
for (var _i = 0; _i < arguments.length; _i++) {
|
|
136
|
+
params[_i] = arguments[_i];
|
|
137
|
+
}
|
|
138
|
+
this.runAsync.apply(this, (0, _tslib.__spreadArray)([], (0, _tslib.__read)(params), false))["catch"](function (error) {
|
|
139
|
+
if (!_this.options.onError) {
|
|
140
|
+
console.error(error);
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
};
|
|
144
|
+
Fetch.prototype.cancel = function () {
|
|
145
|
+
this.count += 1;
|
|
146
|
+
this.setState({
|
|
147
|
+
loading: false
|
|
148
|
+
});
|
|
149
|
+
this.runPluginHandler('onCancel');
|
|
150
|
+
};
|
|
151
|
+
Fetch.prototype.refresh = function () {
|
|
152
|
+
// @ts-ignore
|
|
153
|
+
this.run.apply(this, (0, _tslib.__spreadArray)([], (0, _tslib.__read)(this.state.params || []), false));
|
|
154
|
+
};
|
|
155
|
+
Fetch.prototype.refreshAsync = function () {
|
|
156
|
+
// @ts-ignore
|
|
157
|
+
return this.runAsync.apply(this, (0, _tslib.__spreadArray)([], (0, _tslib.__read)(this.state.params || []), false));
|
|
158
|
+
};
|
|
159
|
+
Fetch.prototype.mutate = function (data) {
|
|
160
|
+
var targetData = (0, _utils.isFunction)(data) ? data(this.state.data) : data;
|
|
161
|
+
this.runPluginHandler('onMutate', targetData);
|
|
162
|
+
this.setState({
|
|
163
|
+
data: targetData
|
|
164
|
+
});
|
|
165
|
+
};
|
|
166
|
+
return Fetch;
|
|
167
|
+
}();
|
|
168
|
+
var _default = exports["default"] = Fetch;
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = void 0;
|
|
8
|
+
var _tslib = require("tslib");
|
|
9
|
+
var _react = require("react");
|
|
10
|
+
var _useUpdateEffect = _interopRequireDefault(require("../../../useUpdateEffect"));
|
|
11
|
+
// 自动请求插件
|
|
12
|
+
var useAutoRunPlugin = function useAutoRunPlugin(fetchInstance, _a) {
|
|
13
|
+
var manual = _a.manual,
|
|
14
|
+
_b = _a.ready,
|
|
15
|
+
ready = _b === void 0 ? true : _b,
|
|
16
|
+
_c = _a.defaultParams,
|
|
17
|
+
defaultParams = _c === void 0 ? [] : _c,
|
|
18
|
+
_d = _a.refreshDeps,
|
|
19
|
+
refreshDeps = _d === void 0 ? [] : _d,
|
|
20
|
+
refreshDepsAction = _a.refreshDepsAction;
|
|
21
|
+
var hasAutoRun = (0, _react.useRef)(false);
|
|
22
|
+
hasAutoRun.current = false;
|
|
23
|
+
(0, _useUpdateEffect["default"])(function () {
|
|
24
|
+
if (!manual && ready) {
|
|
25
|
+
hasAutoRun.current = true;
|
|
26
|
+
fetchInstance.run.apply(fetchInstance, (0, _tslib.__spreadArray)([], (0, _tslib.__read)(defaultParams), false));
|
|
27
|
+
}
|
|
28
|
+
}, [ready]);
|
|
29
|
+
(0, _useUpdateEffect["default"])(function () {
|
|
30
|
+
if (hasAutoRun.current) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
if (!manual) {
|
|
34
|
+
hasAutoRun.current = true;
|
|
35
|
+
console.log('refreshDeps', refreshDeps, refreshDepsAction);
|
|
36
|
+
if (refreshDepsAction) {
|
|
37
|
+
refreshDepsAction();
|
|
38
|
+
} else {
|
|
39
|
+
fetchInstance.refresh();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}, (0, _tslib.__spreadArray)([], (0, _tslib.__read)(refreshDeps), false));
|
|
43
|
+
return {
|
|
44
|
+
onBefore: function onBefore() {
|
|
45
|
+
if (!ready) {
|
|
46
|
+
//ready == false | undefined 不请求
|
|
47
|
+
return {
|
|
48
|
+
stopNow: true
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
};
|
|
54
|
+
useAutoRunPlugin.onInit = function (_a) {
|
|
55
|
+
var _b = _a.ready,
|
|
56
|
+
ready = _b === void 0 ? true : _b,
|
|
57
|
+
manual = _a.manual;
|
|
58
|
+
// 自动请求插件初始化时,设置 loading 状态 ready = true 自动请求
|
|
59
|
+
return {
|
|
60
|
+
loading: !manual && ready
|
|
61
|
+
};
|
|
62
|
+
};
|
|
63
|
+
var _default = exports["default"] = useAutoRunPlugin;
|