| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 | 
							- import 'package:appflowy/user/application/user_listener.dart';
 
- import 'package:flowy_infra/time/duration.dart';
 
- import 'package:appflowy_backend/log.dart';
 
- import 'package:appflowy_backend/protobuf/flowy-error/code.pb.dart';
 
- import 'package:appflowy_backend/protobuf/flowy-error/errors.pb.dart';
 
- import 'package:appflowy_backend/protobuf/flowy-folder/view.pb.dart';
 
- import 'package:appflowy_backend/protobuf/flowy-folder/workspace.pb.dart'
 
-     show WorkspaceSettingPB;
 
- import 'package:appflowy_backend/protobuf/flowy-user/user_profile.pb.dart';
 
- import 'package:flutter_bloc/flutter_bloc.dart';
 
- import 'package:freezed_annotation/freezed_annotation.dart';
 
- import 'package:dartz/dartz.dart';
 
- part 'home_bloc.freezed.dart';
 
- class HomeBloc extends Bloc<HomeEvent, HomeState> {
 
-   final UserWorkspaceListener _listener;
 
-   HomeBloc(
 
-     UserProfilePB user,
 
-     WorkspaceSettingPB workspaceSetting,
 
-   )   : _listener = UserWorkspaceListener(userProfile: user),
 
-         super(HomeState.initial(workspaceSetting)) {
 
-     on<HomeEvent>(
 
-       (event, emit) async {
 
-         await event.map(
 
-           initial: (_Initial value) {
 
-             Future.delayed(const Duration(milliseconds: 300), () {
 
-               if (!isClosed) {
 
-                 add(HomeEvent.didReceiveWorkspaceSetting(workspaceSetting));
 
-               }
 
-             });
 
-             _listener.start(
 
-               onAuthChanged: (result) => _authDidChanged(result),
 
-               onSettingUpdated: (result) {
 
-                 result.fold(
 
-                   (setting) =>
 
-                       add(HomeEvent.didReceiveWorkspaceSetting(setting)),
 
-                   (r) => Log.error(r),
 
-                 );
 
-               },
 
-             );
 
-           },
 
-           showLoading: (e) async {
 
-             emit(state.copyWith(isLoading: e.isLoading));
 
-           },
 
-           didReceiveWorkspaceSetting: (_DidReceiveWorkspaceSetting value) {
 
-             final latestView = workspaceSetting.hasLatestView()
 
-                 ? workspaceSetting.latestView
 
-                 : state.latestView;
 
-             emit(
 
-               state.copyWith(
 
-                 workspaceSetting: value.setting,
 
-                 latestView: latestView,
 
-               ),
 
-             );
 
-           },
 
-           unauthorized: (_Unauthorized value) {
 
-             emit(state.copyWith(unauthorized: true));
 
-           },
 
-         );
 
-       },
 
-     );
 
-   }
 
-   @override
 
-   Future<void> close() async {
 
-     await _listener.stop();
 
-     return super.close();
 
-   }
 
-   void _authDidChanged(Either<Unit, FlowyError> errorOrNothing) {
 
-     errorOrNothing.fold((_) {}, (error) {
 
-       if (error.code == ErrorCode.UserUnauthorized.value) {
 
-         add(HomeEvent.unauthorized(error.msg));
 
-       }
 
-     });
 
-   }
 
- }
 
- enum MenuResizeType {
 
-   slide,
 
-   drag,
 
- }
 
- extension MenuResizeTypeExtension on MenuResizeType {
 
-   Duration duration() {
 
-     switch (this) {
 
-       case MenuResizeType.drag:
 
-         return 30.milliseconds;
 
-       case MenuResizeType.slide:
 
-         return 350.milliseconds;
 
-     }
 
-   }
 
- }
 
- @freezed
 
- class HomeEvent with _$HomeEvent {
 
-   const factory HomeEvent.initial() = _Initial;
 
-   const factory HomeEvent.showLoading(bool isLoading) = _ShowLoading;
 
-   const factory HomeEvent.didReceiveWorkspaceSetting(
 
-     WorkspaceSettingPB setting,
 
-   ) = _DidReceiveWorkspaceSetting;
 
-   const factory HomeEvent.unauthorized(String msg) = _Unauthorized;
 
- }
 
- @freezed
 
- class HomeState with _$HomeState {
 
-   const factory HomeState({
 
-     required bool isLoading,
 
-     required WorkspaceSettingPB workspaceSetting,
 
-     ViewPB? latestView,
 
-     required bool unauthorized,
 
-   }) = _HomeState;
 
-   factory HomeState.initial(WorkspaceSettingPB workspaceSetting) => HomeState(
 
-         isLoading: false,
 
-         workspaceSetting: workspaceSetting,
 
-         latestView: null,
 
-         unauthorized: false,
 
-       );
 
- }
 
 
  |