spotube/lib/hooks/controllers/use_auto_scroll_controller.dart
Kingkor Roy Tirtho 6673e5a8a8
feat: improved caching based on riverpod (#1343)
* feat: add riverpod based favorite album provider

* feat: add album is saved, new releases and tracks providers

* feat: add artist related providers

* feat: add all categories providers

* feat: add lyrics provider

* feat: add playlist related providers

* feat: add search provider

* feat: add view and spotify friends provider

* feat: add playlist create and update and favorite handlers

* feat: use providers in home screen

* chore: fix dart lint issues

* feat: use new providers for playlist and albums screen

* feat: use providers in artist page

* feat: use providers on library page

* feat: use provider for playlist and album card and heart button

* feat: use provider in search page

* feat: use providers in generate playlist

* feat: use provider in lyrics screen

* feat: use provider for create playlist

* feat: use provider in add track dialog

* feat: use providers in remaining pages and remove fl_query

* fix: remove direct access to provider.value

* fix: glitching when loading

* fix: user album loading next page indicator

* feat: make many provider autoDispose after 5 minutes of no usage

* fix: ignore episodes in tracks
2024-03-20 23:38:39 +06:00

85 lines
2.4 KiB
Dart

import 'package:flutter/material.dart';
import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:scroll_to_index/scroll_to_index.dart';
/// Creates [AutoScrollController] that will be disposed automatically.
///
/// See also:
/// - [AutoScrollController]
AutoScrollController useAutoScrollController({
double initialScrollOffset = 0.0,
bool keepScrollOffset = true,
String? debugLabel,
Axis? axis,
AutoScrollController? copyTagsFrom,
double? suggestedRowHeight,
Rect Function() viewportBoundaryGetter = defaultViewportBoundaryGetter,
List<Object?>? keys,
}) {
return use(
_AutoScrollControllerHook(
initialScrollOffset: initialScrollOffset,
keepScrollOffset: keepScrollOffset,
debugLabel: debugLabel,
axis: axis,
copyTagsFrom: copyTagsFrom,
suggestedRowHeight: suggestedRowHeight,
viewportBoundaryGetter: viewportBoundaryGetter,
keys: keys,
),
);
}
class _AutoScrollControllerHook extends Hook<AutoScrollController> {
const _AutoScrollControllerHook({
required this.initialScrollOffset,
required this.keepScrollOffset,
required this.viewportBoundaryGetter,
this.axis,
this.copyTagsFrom,
this.suggestedRowHeight,
this.debugLabel,
super.keys,
});
final double initialScrollOffset;
final bool keepScrollOffset;
final String? debugLabel;
final Axis? axis;
final AutoScrollController? copyTagsFrom;
final double? suggestedRowHeight;
final Rect Function() viewportBoundaryGetter;
@override
HookState<AutoScrollController, Hook<AutoScrollController>> createState() =>
_AutoScrollControllerHookState();
}
class _AutoScrollControllerHookState
extends HookState<AutoScrollController, _AutoScrollControllerHook> {
late final AutoScrollController controller;
@override
void initHook() {
super.initHook();
controller = AutoScrollController(
initialScrollOffset: hook.initialScrollOffset,
keepScrollOffset: hook.keepScrollOffset,
debugLabel: hook.debugLabel,
axis: hook.axis,
copyTagsFrom: hook.copyTagsFrom,
suggestedRowHeight: hook.suggestedRowHeight,
viewportBoundaryGetter: hook.viewportBoundaryGetter,
);
}
@override
AutoScrollController build(BuildContext context) => controller;
@override
void dispose() => controller.dispose();
@override
String get debugLabel => 'useAutoScrollController';
}