mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
config user watch repo
This commit is contained in:
parent
6a02520f84
commit
033ea89bde
@ -9,6 +9,11 @@ export 'package:flowy_sdk/protobuf/flowy-user/errors.pb.dart';
|
|||||||
export 'package:flowy_sdk/protobuf/flowy-user/user_detail.pb.dart';
|
export 'package:flowy_sdk/protobuf/flowy-user/user_detail.pb.dart';
|
||||||
export 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
|
export 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
|
||||||
|
|
||||||
|
typedef UserCreateWorkspaceCallback = void Function(
|
||||||
|
Either<List<Workspace>, WorkspaceError> workspacesOrFailed);
|
||||||
|
typedef UserDeleteWorkspaceCallback = void Function(
|
||||||
|
Either<List<Workspace>, WorkspaceError> workspacesOrFailed);
|
||||||
|
|
||||||
abstract class IUser {
|
abstract class IUser {
|
||||||
UserDetail get user;
|
UserDetail get user;
|
||||||
Future<Either<UserDetail, UserError>> fetchUserDetail(String userId);
|
Future<Either<UserDetail, UserError>> fetchUserDetail(String userId);
|
||||||
@ -16,3 +21,11 @@ abstract class IUser {
|
|||||||
Future<Either<Unit, WorkspaceError>> deleteWorkspace(String workspaceId);
|
Future<Either<Unit, WorkspaceError>> deleteWorkspace(String workspaceId);
|
||||||
Future<Either<Unit, UserError>> signOut();
|
Future<Either<Unit, UserError>> signOut();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
abstract class IUserWatch {
|
||||||
|
void startWatching(
|
||||||
|
{UserCreateWorkspaceCallback? createWorkspaceCallback,
|
||||||
|
UserDeleteWorkspaceCallback? deleteWorkspaceCallback});
|
||||||
|
|
||||||
|
Future<void> stopWatching();
|
||||||
|
}
|
||||||
|
@ -55,6 +55,8 @@ class HomeDepsResolver {
|
|||||||
// User
|
// User
|
||||||
getIt.registerFactoryParam<IUser, UserDetail, void>(
|
getIt.registerFactoryParam<IUser, UserDetail, void>(
|
||||||
(user, _) => IUserImpl(repo: UserRepo(user: user)));
|
(user, _) => IUserImpl(repo: UserRepo(user: user)));
|
||||||
|
getIt.registerFactoryParam<IUserWatch, UserDetail, void>(
|
||||||
|
(user, _) => IUserWatchImpl(repo: UserWatchRepo(user: user)));
|
||||||
|
|
||||||
//Menu Bloc
|
//Menu Bloc
|
||||||
getIt.registerFactoryParam<MenuBloc, UserDetail, void>(
|
getIt.registerFactoryParam<MenuBloc, UserDetail, void>(
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import 'package:dartz/dartz.dart';
|
import 'package:dartz/dartz.dart';
|
||||||
|
|
||||||
import 'package:app_flowy/workspace/domain/i_user.dart';
|
import 'package:app_flowy/workspace/domain/i_user.dart';
|
||||||
import 'package:app_flowy/workspace/infrastructure/repos/user_repo.dart';
|
import 'package:app_flowy/workspace/infrastructure/repos/user_repo.dart';
|
||||||
export 'package:app_flowy/workspace/domain/i_user.dart';
|
export 'package:app_flowy/workspace/domain/i_user.dart';
|
||||||
@ -34,3 +33,23 @@ class IUserImpl extends IUser {
|
|||||||
return repo.fetchWorkspaces();
|
return repo.fetchWorkspaces();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class IUserWatchImpl extends IUserWatch {
|
||||||
|
UserWatchRepo repo;
|
||||||
|
IUserWatchImpl({
|
||||||
|
required this.repo,
|
||||||
|
});
|
||||||
|
@override
|
||||||
|
void startWatching(
|
||||||
|
{UserCreateWorkspaceCallback? createWorkspaceCallback,
|
||||||
|
UserDeleteWorkspaceCallback? deleteWorkspaceCallback}) {
|
||||||
|
repo.startWatching(
|
||||||
|
createWorkspace: createWorkspaceCallback,
|
||||||
|
deleteWorkspace: deleteWorkspaceCallback);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Future<void> stopWatching() async {
|
||||||
|
await repo.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1,9 +1,16 @@
|
|||||||
|
import 'dart:async';
|
||||||
|
|
||||||
import 'package:dartz/dartz.dart';
|
import 'package:dartz/dartz.dart';
|
||||||
import 'package:flowy_sdk/dispatch/dispatch.dart';
|
import 'package:flowy_sdk/dispatch/dispatch.dart';
|
||||||
|
import 'package:flowy_sdk/protobuf/flowy-observable/subject.pb.dart';
|
||||||
import 'package:flowy_sdk/protobuf/flowy-user/errors.pb.dart';
|
import 'package:flowy_sdk/protobuf/flowy-user/errors.pb.dart';
|
||||||
import 'package:flowy_sdk/protobuf/flowy-user/user_detail.pb.dart';
|
import 'package:flowy_sdk/protobuf/flowy-user/user_detail.pb.dart';
|
||||||
import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
|
import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
|
||||||
|
import 'package:flowy_sdk/protobuf/flowy-workspace/observable.pb.dart';
|
||||||
import 'package:flowy_sdk/protobuf/flowy-workspace/workspace_create.pb.dart';
|
import 'package:flowy_sdk/protobuf/flowy-workspace/workspace_create.pb.dart';
|
||||||
|
import 'package:flowy_sdk/rust_stream.dart';
|
||||||
|
|
||||||
|
import 'package:app_flowy/workspace/domain/i_user.dart';
|
||||||
|
|
||||||
class UserRepo {
|
class UserRepo {
|
||||||
final UserDetail user;
|
final UserDetail user;
|
||||||
@ -34,3 +41,66 @@ class UserRepo {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class UserWatchRepo {
|
||||||
|
StreamSubscription<ObservableSubject>? _subscription;
|
||||||
|
UserCreateWorkspaceCallback? _createWorkspace;
|
||||||
|
UserDeleteWorkspaceCallback? _deleteWorkspace;
|
||||||
|
late UserRepo _repo;
|
||||||
|
UserWatchRepo({
|
||||||
|
required UserDetail user,
|
||||||
|
}) {
|
||||||
|
_repo = UserRepo(user: user);
|
||||||
|
}
|
||||||
|
|
||||||
|
void startWatching(
|
||||||
|
{UserCreateWorkspaceCallback? createWorkspace,
|
||||||
|
UserDeleteWorkspaceCallback? deleteWorkspace}) {
|
||||||
|
_createWorkspace = createWorkspace;
|
||||||
|
_deleteWorkspace = deleteWorkspace;
|
||||||
|
_subscription = RustStreamReceiver.listen((observable) {
|
||||||
|
if (observable.subjectId != _repo.user.id) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final ty = WorkspaceObservable.valueOf(observable.ty);
|
||||||
|
if (ty != null) {
|
||||||
|
_handleObservableType(ty);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> close() async {
|
||||||
|
await _subscription?.cancel();
|
||||||
|
}
|
||||||
|
|
||||||
|
void _handleObservableType(WorkspaceObservable ty) {
|
||||||
|
switch (ty) {
|
||||||
|
case WorkspaceObservable.UserCreateWorkspace:
|
||||||
|
if (_createWorkspace == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
_repo.fetchWorkspaces().then((result) {
|
||||||
|
result.fold(
|
||||||
|
(workspaces) => _createWorkspace!(left(workspaces)),
|
||||||
|
(error) => _createWorkspace!(right(error)),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
case WorkspaceObservable.UserDeleteWorkspace:
|
||||||
|
if (_deleteWorkspace == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
_repo.fetchWorkspaces().then((result) {
|
||||||
|
result.fold(
|
||||||
|
(workspaces) => _deleteWorkspace!(left(workspaces)),
|
||||||
|
(error) => _deleteWorkspace!(right(error)),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user