From 9abc61a310042a051ccdd6b147355b33f482bf32 Mon Sep 17 00:00:00 2001 From: LittleSheep Date: Sun, 25 May 2025 12:22:56 +0800 Subject: [PATCH] :bug: Fix post listing with pubName not filtered correctly --- lib/widgets/post/post_list.dart | 15 +-- lib/widgets/post/post_list.g.dart | 180 +++++++++++++++++++++++++++--- 2 files changed, 173 insertions(+), 22 deletions(-) diff --git a/lib/widgets/post/post_list.dart b/lib/widgets/post/post_list.dart index 9ad4897..6fa0745 100644 --- a/lib/widgets/post/post_list.dart +++ b/lib/widgets/post/post_list.dart @@ -14,12 +14,13 @@ class PostListNotifier extends _$PostListNotifier with CursorPagingNotifierMixin { static const int _pageSize = 20; - PostListNotifier({this.pubName}); - - final String? pubName; + String? pubName; @override - Future> build() => fetch(cursor: null); + Future> build(String? pubName) { + this.pubName = pubName; + return fetch(cursor: null); + } @override Future> fetch({required String? cursor}) async { @@ -55,9 +56,9 @@ class SliverPostList extends HookConsumerWidget { @override Widget build(BuildContext context, WidgetRef ref) { return PagingHelperSliverView( - provider: postListNotifierProvider, - futureRefreshable: postListNotifierProvider.future, - notifierRefreshable: postListNotifierProvider.notifier, + provider: postListNotifierProvider(pubName), + futureRefreshable: postListNotifierProvider(pubName).future, + notifierRefreshable: postListNotifierProvider(pubName).notifier, contentBuilder: (data, widgetCount, endItemView) => SliverList.builder( itemCount: widgetCount, diff --git a/lib/widgets/post/post_list.g.dart b/lib/widgets/post/post_list.g.dart index 245921d..0422d7d 100644 --- a/lib/widgets/post/post_list.g.dart +++ b/lib/widgets/post/post_list.g.dart @@ -6,24 +6,174 @@ part of 'post_list.dart'; // RiverpodGenerator // ************************************************************************** -String _$postListNotifierHash() => r'88aab109f36c7489c336fea522bffafa10869253'; +String _$postListNotifierHash() => r'6568b7a5afad71551009d9bc7af26afb4b07c9e5'; + +/// Copied from Dart SDK +class _SystemHash { + _SystemHash._(); + + static int combine(int hash, int value) { + // ignore: parameter_assignments + hash = 0x1fffffff & (hash + value); + // ignore: parameter_assignments + hash = 0x1fffffff & (hash + ((0x0007ffff & hash) << 10)); + return hash ^ (hash >> 6); + } + + static int finish(int hash) { + // ignore: parameter_assignments + hash = 0x1fffffff & (hash + ((0x03ffffff & hash) << 3)); + // ignore: parameter_assignments + hash = hash ^ (hash >> 11); + return 0x1fffffff & (hash + ((0x00003fff & hash) << 15)); + } +} + +abstract class _$PostListNotifier + extends BuildlessAutoDisposeAsyncNotifier> { + late final String? pubName; + + FutureOr> build(String? pubName); +} /// See also [PostListNotifier]. @ProviderFor(PostListNotifier) -final postListNotifierProvider = AutoDisposeAsyncNotifierProvider< - PostListNotifier, - CursorPagingData ->.internal( - PostListNotifier.new, - name: r'postListNotifierProvider', - debugGetCreateSourceHash: - const bool.fromEnvironment('dart.vm.product') - ? null - : _$postListNotifierHash, - dependencies: null, - allTransitiveDependencies: null, -); +const postListNotifierProvider = PostListNotifierFamily(); + +/// See also [PostListNotifier]. +class PostListNotifierFamily + extends Family>> { + /// See also [PostListNotifier]. + const PostListNotifierFamily(); + + /// See also [PostListNotifier]. + PostListNotifierProvider call(String? pubName) { + return PostListNotifierProvider(pubName); + } + + @override + PostListNotifierProvider getProviderOverride( + covariant PostListNotifierProvider provider, + ) { + return call(provider.pubName); + } + + static const Iterable? _dependencies = null; + + @override + Iterable? get dependencies => _dependencies; + + static const Iterable? _allTransitiveDependencies = null; + + @override + Iterable? get allTransitiveDependencies => + _allTransitiveDependencies; + + @override + String? get name => r'postListNotifierProvider'; +} + +/// See also [PostListNotifier]. +class PostListNotifierProvider + extends + AutoDisposeAsyncNotifierProviderImpl< + PostListNotifier, + CursorPagingData + > { + /// See also [PostListNotifier]. + PostListNotifierProvider(String? pubName) + : this._internal( + () => PostListNotifier()..pubName = pubName, + from: postListNotifierProvider, + name: r'postListNotifierProvider', + debugGetCreateSourceHash: + const bool.fromEnvironment('dart.vm.product') + ? null + : _$postListNotifierHash, + dependencies: PostListNotifierFamily._dependencies, + allTransitiveDependencies: + PostListNotifierFamily._allTransitiveDependencies, + pubName: pubName, + ); + + PostListNotifierProvider._internal( + super._createNotifier, { + required super.name, + required super.dependencies, + required super.allTransitiveDependencies, + required super.debugGetCreateSourceHash, + required super.from, + required this.pubName, + }) : super.internal(); + + final String? pubName; + + @override + FutureOr> runNotifierBuild( + covariant PostListNotifier notifier, + ) { + return notifier.build(pubName); + } + + @override + Override overrideWith(PostListNotifier Function() create) { + return ProviderOverride( + origin: this, + override: PostListNotifierProvider._internal( + () => create()..pubName = pubName, + from: from, + name: null, + dependencies: null, + allTransitiveDependencies: null, + debugGetCreateSourceHash: null, + pubName: pubName, + ), + ); + } + + @override + AutoDisposeAsyncNotifierProviderElement< + PostListNotifier, + CursorPagingData + > + createElement() { + return _PostListNotifierProviderElement(this); + } + + @override + bool operator ==(Object other) { + return other is PostListNotifierProvider && other.pubName == pubName; + } + + @override + int get hashCode { + var hash = _SystemHash.combine(0, runtimeType.hashCode); + hash = _SystemHash.combine(hash, pubName.hashCode); + + return _SystemHash.finish(hash); + } +} + +@Deprecated('Will be removed in 3.0. Use Ref instead') +// ignore: unused_element +mixin PostListNotifierRef + on AutoDisposeAsyncNotifierProviderRef> { + /// The parameter `pubName` of this provider. + String? get pubName; +} + +class _PostListNotifierProviderElement + extends + AutoDisposeAsyncNotifierProviderElement< + PostListNotifier, + CursorPagingData + > + with PostListNotifierRef { + _PostListNotifierProviderElement(super.provider); + + @override + String? get pubName => (origin as PostListNotifierProvider).pubName; +} -typedef _$PostListNotifier = AutoDisposeAsyncNotifier>; // ignore_for_file: type=lint // ignore_for_file: subtype_of_sealed_class, invalid_use_of_internal_member, invalid_use_of_visible_for_testing_member, deprecated_member_use_from_same_package