use_request 0.3.0
use_request: ^0.3.0 copied to clipboard
A Flutter useRequest-style async request management library based on dio, flutter_hooks, and Riverpod.
0.3.0 #
- Fix:
RequestCache新增 LRU 淘汰策略(默认最大 256 条),防止长时间运行导致内存无限增长(Bug 10)。 - Fix:
CacheCoordinator修正 SWR 语义——只配cacheTime不配staleTime时,缓存始终后台刷新(Bug 13)。 - Fix: 轮询与分页(
loadMoreParams)同时使用时,轮询优先使用defaultParams刷新首页,避免覆盖已累积的分页数据(Bug 15)。 - Feat:
RequestCache.removeWhere()支持按模式批量清除缓存(如key.startsWith('user-'))。 - Fix:
UseRequestState.copyWith新增clearParams/clearHasMore标志位(Bug 1)。 - Fix:
defaultParams仅在首次 build 时初始化,不再覆盖用户手动参数(Bug 2)。 - Fix:
PaginationHelpers.pageParams通过内部计数器正确追踪页码(Bug 3)。 - Fix:
UseRequestMixin.initUseRequest新增onStateChange回调以触发宿主 Widget 重建(Bug 4)。 - Fix:
loadMore()在hasMore == false时拒绝发起新请求(Bug 5)。 - Fix: 所有生命周期回调(onSuccess/onError/onFinally)包裹 try-catch,异常不再中断请求流程(Bug 6)。
- Fix:
bindPendingRequest补充 onSuccess/onError/onFinally 回调(Bug 7)。 - Fix:
UseRequestBuilder引入serviceKey机制,避免闭包引用变化导致无限重建(Bug 8)。 - Fix:
refreshAsync安全类型检查,非空 TParams 场景下回退到defaultParams(Bug 9)。 - Fix:
cancel()取消所有 key 的进行中请求,而非仅最后一个(Bug 11)。 - Fix:
AppFocusManager不再将inactive状态视为 blur(Bug 12)。 - Docs:
onBefore在loadMore场景下不触发的行为已补充文档说明(Bug 14)。
0.0.13 #
- Fix: clear both
loadingandloadingMoreon cancel, and make Hook/Riverpod consistently support no-params requests across auto-run,refreshDeps, polling, focus refresh, and reconnect refresh. - Fix: remove duplicate Riverpod auto requests when
refreshDepsandreadyreplay overlap, and letUseRequestBuilder/UseRequestMixinrender notifier state on the first frame instead of a synthetic empty state. - Fix: harden scheduler and cache utilities, including correct
Debouncer.maxWait, non-cancelling leading debounce futures, correctThrottlerbehavior forleading:false, cancellable retry backoff, pending-cache overwrite safety, andUseRequestOptions.copyWith()explicit null clearing. - Test: add Hook, Riverpod, debounce, throttle, retry, cache, and options contract tests for the above edge cases.
0.0.12 #
- Fix: hydrate fresh cache into Hook and Riverpod state on the first frame, so pages that remount can render cached data immediately instead of flashing default values before auto requests run.
0.0.11 #
- Fix: pending cache subscribers now receive the in-flight result in both Hook and Riverpod implementations, instead of reusing the Future without updating local state.
0.0.10 #
- Fix:
refreshDepsnow triggers auto refresh even when last/default params isnull(no-params service), aligning with ahooks.
0.0.9 #
- Fix: refreshDeps change detection now survives list reuse/mutation by hashing deps and copying snapshots.
- Fix: refreshDeps changes while
ready=falseare replayed onceready=true(Hook + Riverpod). - Fix: Riverpod refreshDeps initial trigger actually fires (no pre-seeded deps).
0.0.8 #
- Fix: allow
refresh()to reuse a previousnullparams entry instead of throwing (both Hook and Riverpod).
0.0.7 #
- Example: add an inline Quick Start snippet in
example/lib/main.dartso pub.dev can render a meaningful Example tab.
0.0.6 #
- Align docs with implementation: make
UseRequestOptionstimeouts effective whenTParams=HttpRequestConfig. - Add
uploadFile/downloadFilealiases toDioHttpAdapterto match README examples. - Unify
readysemantics between Hook and Riverpod (ready=false gates auto/polling, manual run still works). - Fix example widget test to reflect the current demo app.
0.0.5 #
- Optimize auto-request logic: allow auto-trigger when
defaultParamsis null (providedmanualis false). - Docs: add minimalist usage example (Zero Configuration).
0.0.4 #
- Reformat source to satisfy
dart formatand static analysis. - Upgrade dependencies to latest supported versions (
flutter_hooks,flutter_riverpod), keeping Riverpod v3 compatibility via legacy API.
0.0.2 #
- Implement active-key single-state semantics for
fetchKey(stale key results no longer update state). - Fix
Debouncerso new calls cancel previous pending futures instead of leaving them hanging. - Align Hook and Riverpod behaviors (retry callbacks, polling control, cancel semantics, cache consistency).
- Improve polling lifecycle: ready/manual gating, visibility pause/resume on Web, and optional
pollingRetryIntervalauto-restore. - Rework
DioHttpAdapter.requestto support per-request timeouts and merged headers/query. - Enhance example demos (interactive polling controls, sidebar scroll fix, JSONPlaceholder PUT/PATCH safe id).
- Docs/metadata: add bilingual README, pub badges, topics, and Flutter CI workflow.
0.0.1 #
- Initial release.