grid_bloc.dart 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. import 'dart:async';
  2. import 'package:dartz/dartz.dart';
  3. import 'package:flowy_sdk/log.dart';
  4. import 'package:flowy_sdk/protobuf/flowy-error/errors.pb.dart';
  5. import 'package:flowy_sdk/protobuf/flowy-folder-data-model/view.pb.dart';
  6. import 'package:flowy_sdk/protobuf/flowy-grid-data-model/protobuf.dart';
  7. import 'package:flutter_bloc/flutter_bloc.dart';
  8. import 'package:freezed_annotation/freezed_annotation.dart';
  9. import 'data.dart';
  10. import 'grid_listener.dart';
  11. import 'grid_service.dart';
  12. part 'grid_bloc.freezed.dart';
  13. class GridBloc extends Bloc<GridEvent, GridState> {
  14. final GridService service;
  15. final View view;
  16. final GridListener listener;
  17. Grid? _grid;
  18. List<Field>? _fields;
  19. GridBloc({required this.view, required this.service, required this.listener}) : super(GridState.initial()) {
  20. on<GridEvent>(
  21. (event, emit) async {
  22. await event.map(
  23. initial: (InitialGrid value) async {
  24. await _startGridListening();
  25. await _loadGrid(emit);
  26. await _loadFields(emit);
  27. await _loadGridInfo(emit);
  28. },
  29. createRow: (_CreateRow value) {
  30. service.createRow(gridId: view.id);
  31. },
  32. delete: (_Delete value) {},
  33. rename: (_Rename value) {},
  34. updateDesc: (_Desc value) {},
  35. );
  36. },
  37. );
  38. }
  39. @override
  40. Future<void> close() async {
  41. await listener.close();
  42. return super.close();
  43. }
  44. Future<void> _startGridListening() async {
  45. listener.createRowNotifier.addPublishListener((result) {
  46. result.fold((row) {
  47. //
  48. Log.info("$row");
  49. }, (err) => null);
  50. });
  51. listener.deleteRowNotifier.addPublishListener((result) {
  52. result.fold((l) => null, (r) => null);
  53. });
  54. listener.start();
  55. }
  56. Future<void> _loadGrid(Emitter<GridState> emit) async {
  57. final result = await service.openGrid(gridId: view.id);
  58. result.fold(
  59. (grid) {
  60. _grid = grid;
  61. },
  62. (err) {
  63. emit(state.copyWith(loadingState: GridLoadingState.finish(right(err))));
  64. },
  65. );
  66. }
  67. Future<void> _loadFields(Emitter<GridState> emit) async {
  68. if (_grid != null) {
  69. final result = await service.getFields(gridId: _grid!.id, fieldOrders: _grid!.fieldOrders);
  70. result.fold(
  71. (fields) {
  72. _fields = fields.items;
  73. },
  74. (err) {
  75. emit(state.copyWith(loadingState: GridLoadingState.finish(right(err))));
  76. },
  77. );
  78. }
  79. }
  80. Future<void> _loadGridInfo(Emitter<GridState> emit) async {
  81. final grid = _grid;
  82. if (grid != null && _fields != null) {
  83. final result = await service.getRows(gridId: grid.id, rowOrders: grid.rowOrders);
  84. result.fold((repeatedRow) {
  85. final rows = repeatedRow.items;
  86. final gridInfo = GridInfo(gridId: grid.id, rows: rows, fields: _fields!);
  87. emit(
  88. state.copyWith(loadingState: GridLoadingState.finish(left(unit)), gridInfo: some(left(gridInfo))),
  89. );
  90. }, (err) {
  91. emit(
  92. state.copyWith(loadingState: GridLoadingState.finish(right(err)), gridInfo: none()),
  93. );
  94. });
  95. }
  96. }
  97. }
  98. @freezed
  99. abstract class GridEvent with _$GridEvent {
  100. const factory GridEvent.initial() = InitialGrid;
  101. const factory GridEvent.rename(String gridId, String name) = _Rename;
  102. const factory GridEvent.updateDesc(String gridId, String desc) = _Desc;
  103. const factory GridEvent.delete(String gridId) = _Delete;
  104. const factory GridEvent.createRow() = _CreateRow;
  105. }
  106. @freezed
  107. abstract class GridState with _$GridState {
  108. const factory GridState({
  109. required GridLoadingState loadingState,
  110. required Option<Either<GridInfo, FlowyError>> gridInfo,
  111. }) = _GridState;
  112. factory GridState.initial() => GridState(
  113. loadingState: const _Loading(),
  114. gridInfo: none(),
  115. );
  116. }
  117. @freezed
  118. class GridLoadingState with _$GridLoadingState {
  119. const factory GridLoadingState.loading() = _Loading;
  120. const factory GridLoadingState.finish(Either<Unit, FlowyError> successOrFail) = _Finish;
  121. }