1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- import 'package:app_flowy/workspace/domain/i_workspace.dart';
- import 'package:flowy_log/flowy_log.dart';
- import 'package:flowy_sdk/protobuf/flowy-workspace/app_create.pb.dart';
- import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
- import 'package:flutter/material.dart';
- import 'package:freezed_annotation/freezed_annotation.dart';
- import 'package:flutter_bloc/flutter_bloc.dart';
- import 'package:dartz/dartz.dart';
- part 'menu_watch.freezed.dart';
- class MenuWatchBloc extends Bloc<MenuWatchEvent, MenuWatchState> {
- final IWorkspaceWatch watch;
- MenuWatchBloc(this.watch) : super(const MenuWatchState.initial());
- @override
- Stream<MenuWatchState> mapEventToState(MenuWatchEvent event) async* {
- yield* event.map(
- started: (_) async* {
- watch.startWatching(
- addAppCallback: (appsOrFail) => _handleAppsOrFail(appsOrFail),
- );
- },
- appsReceived: (e) async* {
- yield e.appsOrFail.fold(
- (apps) => MenuWatchState.loadApps(apps),
- (error) => MenuWatchState.loadFail(error),
- );
- },
- );
- }
- @override
- Future<void> close() async {
- await watch.stopWatching();
- return super.close();
- }
- void _handleAppsOrFail(Either<List<App>, WorkspaceError> appsOrFail) {
- appsOrFail.fold(
- (apps) => add(MenuWatchEvent.appsReceived(left(apps))),
- (error) {
- Log.error(error);
- add(MenuWatchEvent.appsReceived(right(error)));
- },
- );
- }
- }
- @freezed
- class MenuWatchEvent with _$MenuWatchEvent {
- const factory MenuWatchEvent.started() = _Started;
- const factory MenuWatchEvent.appsReceived(
- Either<List<App>, WorkspaceError> appsOrFail) = AppsReceived;
- }
- @freezed
- class MenuWatchState with _$MenuWatchState {
- const factory MenuWatchState.initial() = _Initial;
- const factory MenuWatchState.loadApps(
- List<App> apps,
- ) = _LoadApps;
- const factory MenuWatchState.loadFail(
- WorkspaceError error,
- ) = _LoadFail;
- }
|