trash_bloc.dart 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. import 'package:dartz/dartz.dart';
  2. import 'package:flowy_sdk/log.dart';
  3. import 'package:flowy_sdk/protobuf/flowy-folder/trash.pb.dart';
  4. import 'package:flowy_sdk/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:app_flowy/plugins/trash/application/trash_service.dart';
  8. import 'package:app_flowy/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(initial: (e) async {
  19. _listener.start(trashUpdated: _listenTrashUpdated);
  20. final result = await _service.readTrash();
  21. emit(result.fold(
  22. (object) => state.copyWith(
  23. objects: object.items, successOrFailure: left(unit)),
  24. (error) => state.copyWith(successOrFailure: right(error)),
  25. ));
  26. }, didReceiveTrash: (e) async {
  27. emit(state.copyWith(objects: e.trash));
  28. }, putback: (e) async {
  29. final result = await _service.putback(e.trashId);
  30. await _handleResult(result, emit);
  31. }, delete: (e) async {
  32. final result =
  33. await _service.deleteViews([Tuple2(e.trash.id, e.trash.ty)]);
  34. await _handleResult(result, emit);
  35. }, deleteAll: (e) async {
  36. final result = await _service.deleteAll();
  37. await _handleResult(result, emit);
  38. }, restoreAll: (e) async {
  39. final result = await _service.restoreAll();
  40. await _handleResult(result, emit);
  41. });
  42. });
  43. }
  44. Future<void> _handleResult(
  45. Either<dynamic, FlowyError> result, Emitter<TrashState> emit) async {
  46. emit(result.fold(
  47. (l) => state.copyWith(successOrFailure: left(unit)),
  48. (error) => state.copyWith(successOrFailure: right(error)),
  49. ));
  50. }
  51. void _listenTrashUpdated(Either<List<TrashPB>, FlowyError> trashOrFailed) {
  52. trashOrFailed.fold(
  53. (trash) {
  54. add(TrashEvent.didReceiveTrash(trash));
  55. },
  56. (error) {
  57. Log.error(error);
  58. },
  59. );
  60. }
  61. @override
  62. Future<void> close() async {
  63. await _listener.close();
  64. return super.close();
  65. }
  66. }
  67. @freezed
  68. class TrashEvent with _$TrashEvent {
  69. const factory TrashEvent.initial() = Initial;
  70. const factory TrashEvent.didReceiveTrash(List<TrashPB> trash) = ReceiveTrash;
  71. const factory TrashEvent.putback(String trashId) = Putback;
  72. const factory TrashEvent.delete(TrashPB trash) = Delete;
  73. const factory TrashEvent.restoreAll() = RestoreAll;
  74. const factory TrashEvent.deleteAll() = DeleteAll;
  75. }
  76. @freezed
  77. class TrashState with _$TrashState {
  78. const factory TrashState({
  79. required List<TrashPB> objects,
  80. required Either<Unit, FlowyError> successOrFailure,
  81. }) = _TrashState;
  82. factory TrashState.init() => TrashState(
  83. objects: [],
  84. successOrFailure: left(unit),
  85. );
  86. }