trash_bloc.dart 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. import 'package:dartz/dartz.dart';
  2. import 'package:appflowy_backend/log.dart';
  3. import 'package:appflowy_backend/protobuf/flowy-folder2/trash.pb.dart';
  4. import 'package:appflowy_backend/protobuf/flowy-error/errors.pb.dart';
  5. import 'package:flutter_bloc/flutter_bloc.dart';
  6. import 'package:freezed_annotation/freezed_annotation.dart';
  7. import 'package:appflowy/plugins/trash/application/trash_service.dart';
  8. import 'package:appflowy/plugins/trash/application/trash_listener.dart';
  9. part 'trash_bloc.freezed.dart';
  10. class TrashBloc extends Bloc<TrashEvent, TrashState> {
  11. final TrashService _service;
  12. final TrashListener _listener;
  13. TrashBloc()
  14. : _service = TrashService(),
  15. _listener = TrashListener(),
  16. super(TrashState.init()) {
  17. on<TrashEvent>((event, emit) async {
  18. await event.map(
  19. initial: (e) async {
  20. _listener.start(trashUpdated: _listenTrashUpdated);
  21. final result = await _service.readTrash();
  22. emit(
  23. result.fold(
  24. (object) => state.copyWith(
  25. objects: object.items,
  26. successOrFailure: left(unit),
  27. ),
  28. (error) => state.copyWith(successOrFailure: right(error)),
  29. ),
  30. );
  31. },
  32. didReceiveTrash: (e) async {
  33. emit(state.copyWith(objects: e.trash));
  34. },
  35. putback: (e) async {
  36. final result = await _service.putback(e.trashId);
  37. await _handleResult(result, emit);
  38. },
  39. delete: (e) async {
  40. final result = await _service.deleteViews([e.trash.id]);
  41. await _handleResult(result, emit);
  42. },
  43. deleteAll: (e) async {
  44. final result = await _service.deleteAll();
  45. await _handleResult(result, emit);
  46. },
  47. restoreAll: (e) async {
  48. final result = await _service.restoreAll();
  49. await _handleResult(result, emit);
  50. },
  51. );
  52. });
  53. }
  54. Future<void> _handleResult(
  55. Either<dynamic, FlowyError> result,
  56. Emitter<TrashState> emit,
  57. ) async {
  58. emit(
  59. result.fold(
  60. (l) => state.copyWith(successOrFailure: left(unit)),
  61. (error) => state.copyWith(successOrFailure: right(error)),
  62. ),
  63. );
  64. }
  65. void _listenTrashUpdated(Either<List<TrashPB>, FlowyError> trashOrFailed) {
  66. trashOrFailed.fold(
  67. (trash) {
  68. add(TrashEvent.didReceiveTrash(trash));
  69. },
  70. (error) {
  71. Log.error(error);
  72. },
  73. );
  74. }
  75. @override
  76. Future<void> close() async {
  77. await _listener.close();
  78. return super.close();
  79. }
  80. }
  81. @freezed
  82. class TrashEvent with _$TrashEvent {
  83. const factory TrashEvent.initial() = Initial;
  84. const factory TrashEvent.didReceiveTrash(List<TrashPB> trash) = ReceiveTrash;
  85. const factory TrashEvent.putback(String trashId) = Putback;
  86. const factory TrashEvent.delete(TrashPB trash) = Delete;
  87. const factory TrashEvent.restoreAll() = RestoreAll;
  88. const factory TrashEvent.deleteAll() = DeleteAll;
  89. }
  90. @freezed
  91. class TrashState with _$TrashState {
  92. const factory TrashState({
  93. required List<TrashPB> objects,
  94. required Either<Unit, FlowyError> successOrFailure,
  95. }) = _TrashState;
  96. factory TrashState.init() => TrashState(
  97. objects: [],
  98. successOrFailure: left(unit),
  99. );
  100. }