Riverpod Generator


Notifier with Riverpod Generator

Manual:

// counter.dart
import 'package:flutter_riverpod/flutter_riverpod.dart';

class Counter extends Notifier<int> {
  @override
  int build() {
    return 0;
  }

  void increment() {
    state++;
  }
}

final counterProvider = NotifierProvider<Counter, int>(Counter.new);

Generator:

import 'package:riverpod_annotation/riverpod_annotation.dart';

part 'counter.g.dart';

@riverpod
class Counter extends _$Counter {
  @override
  int build() {
    return 0;
  }

  void increment() {
    state++;
  }
}
dart run build_runner build or dart run build_runner watch

AsyncNotifier with Riverpod Generator

// 1. add the necessary imports
import 'dart:async';
import 'package:flutter_riverpod/flutter_riverpod.dart';

// 2. extend [AsyncNotifier]
class AuthController extends AsyncNotifier<void> {
  // 3. override the [build] method to return a [FutureOr]
  @override
  FutureOr<void> build() {
    // 4. return a value (or do nothing if the return type is void)
  }

  Future<void> signInAnonymously() async {
    // 5. read the repository using ref
    final authRepository = ref.read(authRepositoryProvider);
    // 6. set the loading state
    state = const AsyncLoading();
    // 7. sign in and update the state (data or error)
    state = await AsyncValue.guard(authRepository.signInAnonymously);
  }
}

final authControllerProvider = AsyncNotifierProvider<AuthController, void>(() {
  return AuthController();
});
// 1. import this
import 'package:riverpod_annotation/riverpod_annotation.dart';

// 2. declare a part file
part 'auth_controller.g.dart';

// 3. annotate
@riverpod
// 4. extend like this
class AuthController extends _$AuthController {
  // 5. override the [build] method to return a [FutureOr]
  @override
  FutureOr<void> build() {
    // 6. return a value (or do nothing if the return type is void)
  }

  Future<void> signInAnonymously() async {
    // 7. read the repository using ref
    final authRepository = ref.read(authRepositoryProvider);
    // 8. set the loading state
    state = const AsyncLoading();
    // 9. sign in and update the state (data or error)
    state = await AsyncValue.guard(authRepository.signInAnonymously);
  }
}
dart run build_runner build or dart run build_runner watch

Provider with Riverpod Generator

final fooProvider = Provider((ref) => 0);
part 'foo.g.dart';

@riverpod
int foo(FooRef ref) => 0;

Future(Stream)Provider with Riverpod Generator

final fooProvider = FutureProvider((ref) async {
  return 0;
});
part 'foo.g.dart';

@riverpod
Future<int> foo(FooRef ref) async {
  return 0;
}
#riverpod






你可能感興趣的文章

什麼是 Command Line (CLI)?

什麼是 Command Line (CLI)?

Git筆記 - 在本地端和Github傳遞repo

Git筆記 - 在本地端和Github傳遞repo

使用 node.js 寫出串接 API 的程式

使用 node.js 寫出串接 API 的程式






留言討論