trash_bloc.dart 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. import 'package:app_flowy/workspace/domain/i_trash.dart';
  2. import 'package:dartz/dartz.dart';
  3. import 'package:flowy_log/flowy_log.dart';
  4. import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
  5. import 'package:flowy_sdk/protobuf/flowy-workspace/trash_create.pb.dart';
  6. import 'package:flutter_bloc/flutter_bloc.dart';
  7. import 'package:freezed_annotation/freezed_annotation.dart';
  8. part 'trash_bloc.freezed.dart';
  9. class TrashBloc extends Bloc<TrashEvent, TrashState> {
  10. final ITrash iTrash;
  11. final ITrashListener listener;
  12. TrashBloc({required this.iTrash, required this.listener}) : super(TrashState.init());
  13. @override
  14. Stream<TrashState> mapEventToState(TrashEvent event) async* {
  15. yield* event.map(
  16. initial: (e) async* {
  17. listener.start(_listenTrashUpdated);
  18. final result = await iTrash.readTrash();
  19. yield result.fold(
  20. (objects) => state.copyWith(objects: objects, successOrFailure: left(unit)),
  21. (error) => state.copyWith(successOrFailure: right(error)),
  22. );
  23. },
  24. didReceiveTrash: (e) async* {
  25. yield state.copyWith(objects: e.trash);
  26. },
  27. putback: (e) async* {
  28. final result = await iTrash.putback(e.trashId);
  29. yield* _handleResult(result);
  30. },
  31. delete: (e) async* {
  32. final result = await iTrash.deleteViews([e.trashId]);
  33. yield* _handleResult(result);
  34. },
  35. deleteAll: (e) async* {
  36. final result = await iTrash.deleteAll();
  37. yield* _handleResult(result);
  38. },
  39. restoreAll: (e) async* {},
  40. );
  41. }
  42. Stream<TrashState> _handleResult(Either<dynamic, WorkspaceError> result) async* {
  43. yield result.fold(
  44. (l) => state.copyWith(successOrFailure: left(unit)),
  45. (error) => state.copyWith(successOrFailure: right(error)),
  46. );
  47. }
  48. void _listenTrashUpdated(Either<List<Trash>, WorkspaceError> trashOrFailed) {
  49. trashOrFailed.fold(
  50. (trash) {
  51. add(TrashEvent.didReceiveTrash(trash));
  52. },
  53. (error) {
  54. Log.error(error);
  55. },
  56. );
  57. }
  58. @override
  59. Future<void> close() async {
  60. await listener.stop();
  61. return super.close();
  62. }
  63. }
  64. @freezed
  65. class TrashEvent with _$TrashEvent {
  66. const factory TrashEvent.initial() = Initial;
  67. const factory TrashEvent.didReceiveTrash(List<Trash> trash) = ReceiveTrash;
  68. const factory TrashEvent.putback(String trashId) = Putback;
  69. const factory TrashEvent.delete(String trashId) = Delete;
  70. const factory TrashEvent.restoreAll() = RestoreAll;
  71. const factory TrashEvent.deleteAll() = DeleteAll;
  72. }
  73. @freezed
  74. class TrashState with _$TrashState {
  75. const factory TrashState({
  76. required List<Trash> objects,
  77. required Either<Unit, WorkspaceError> successOrFailure,
  78. }) = _TrashState;
  79. factory TrashState.init() => TrashState(
  80. objects: [],
  81. successOrFailure: left(unit),
  82. );
  83. }