config workspace and app repo callback

This commit is contained in:
appflowy 2021-07-21 17:05:51 +08:00
parent 892526c2f9
commit a529a3bf43
17 changed files with 331 additions and 155 deletions

View File

@ -1,5 +1,5 @@
import 'dart:async'; import 'dart:async';
import 'package:app_flowy/home/domain/i_app.dart'; import 'package:app_flowy/home/domain/i_workspace.dart';
import 'package:app_flowy/home/domain/page_context.dart'; import 'package:app_flowy/home/domain/page_context.dart';
import 'package:dartz/dartz.dart'; import 'package:dartz/dartz.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart'; import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
@ -11,8 +11,8 @@ part 'menu_state.dart';
part 'menu_bloc.freezed.dart'; part 'menu_bloc.freezed.dart';
class MenuBloc extends Bloc<MenuEvent, MenuState> { class MenuBloc extends Bloc<MenuEvent, MenuState> {
final IApp iAppImpl; final IWorkspace iWorkspaceImpl;
MenuBloc(this.iAppImpl) : super(MenuState.initial()); MenuBloc(this.iWorkspaceImpl) : super(MenuState.initial());
@override @override
Stream<MenuState> mapEventToState( Stream<MenuState> mapEventToState(
@ -37,7 +37,7 @@ class MenuBloc extends Bloc<MenuEvent, MenuState> {
} }
Stream<MenuState> _performActionOnCreateApp(_CreateApp event) async* { Stream<MenuState> _performActionOnCreateApp(_CreateApp event) async* {
await iAppImpl await iWorkspaceImpl
.createApp(name: event.name, desc: event.desc) .createApp(name: event.name, desc: event.desc)
.then((result) async* { .then((result) async* {
result.fold( result.fold(

View File

@ -2,12 +2,6 @@ import 'package:flowy_sdk/protobuf/flowy-workspace/protobuf.dart';
import 'package:dartz/dartz.dart'; import 'package:dartz/dartz.dart';
abstract class IApp { abstract class IApp {
Future<Either<App, WorkspaceError>> createApp(
{required String name, String? desc});
Future<Either<List<App>, WorkspaceError>> getApps(
{required String workspaceId});
Future<Either<List<View>, WorkspaceError>> getViews({required String appId}); Future<Either<List<View>, WorkspaceError>> getViews({required String appId});
Future<Either<View, WorkspaceError>> createView( Future<Either<View, WorkspaceError>> createView(

View File

@ -0,0 +1,10 @@
import 'package:flowy_sdk/protobuf/flowy-workspace/protobuf.dart';
import 'package:dartz/dartz.dart';
abstract class IWorkspace {
Future<Either<App, WorkspaceError>> createApp(
{required String name, String? desc});
Future<Either<List<App>, WorkspaceError>> getApps(
{required String workspaceId});
}

View File

@ -1,65 +0,0 @@
import 'package:dartz/dartz.dart';
import 'package:flowy_sdk/dispatch/dispatch.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/app_create.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/app_query.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/view_create.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/view_create.pbenum.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/workspace_query.pb.dart';
class AppRepository {
Future<Either<App, WorkspaceError>> createApp(String appName, String desc) {
return WorkspaceEventGetCurWorkspace().send().then((result) {
return result.fold(
(workspace) {
final request = CreateAppRequest.create()
..name = appName
..workspaceId = workspace.id
..desc = desc;
return WorkspaceEventCreateApp(request).send();
},
(error) {
return right(error);
},
);
});
}
Future<Either<List<App>, WorkspaceError>> getApps(
{required String workspaceId}) {
final request = QueryWorkspaceRequest.create()
..workspaceId = workspaceId
..readApps = true;
return WorkspaceEventGetWorkspace(request).send().then((result) {
return result.fold(
(workspace) => left(workspace.apps.items),
(error) => right(error),
);
});
}
Future<Either<List<View>, WorkspaceError>> getViews({required String appId}) {
final request = QueryAppRequest.create()
..appId = appId
..readViews = true;
return WorkspaceEventGetApp(request).send().then((result) {
return result.fold(
(app) => left(app.views.items),
(error) => right(error),
);
});
}
Future<Either<View, WorkspaceError>> createView(
String appId, String name, String desc, ViewTypeIdentifier viewType) {
final request = CreateViewRequest.create()
..appId = appId
..name = name
..desc = desc
..viewType = viewType;
return WorkspaceEventCreateView(request).send();
}
}

View File

@ -1,16 +1,24 @@
import 'package:app_flowy/home/application/menu/menu_bloc.dart'; import 'package:app_flowy/home/application/menu/menu_bloc.dart';
import 'package:app_flowy/home/infrastructure/app_repo.dart';
import 'package:app_flowy/home/infrastructure/i_app_impl.dart'; import 'package:app_flowy/home/infrastructure/i_app_impl.dart';
import 'package:app_flowy/home/infrastructure/i_workspace_impl.dart';
import 'package:app_flowy/home/infrastructure/repos/app_repo.dart';
import 'package:app_flowy/home/infrastructure/repos/workspace_repo.dart';
import 'package:get_it/get_it.dart'; import 'package:get_it/get_it.dart';
class HomeDepsResolver { class HomeDepsResolver {
static Future<void> resolve(GetIt getIt) async { static Future<void> resolve(GetIt getIt) async {
getIt.registerLazySingleton<AppRepository>(() => AppRepository()); getIt.registerLazySingleton<WorkspaceRepository>(
() => WorkspaceRepository());
getIt.registerFactoryParam<AppRepository, String, void>(
(appId, _) => AppRepository(appId: appId));
//Interface implementation //Interface implementation
getIt.registerFactory<IApp>(() => IAppImpl(repo: getIt<AppRepository>())); getIt.registerFactory<IApp>(() => IAppImpl(repo: getIt<AppRepository>()));
getIt.registerFactory<IWorkspace>(
() => IWorkspaceImpl(repo: getIt<WorkspaceRepository>()));
//Bloc //Bloc
getIt.registerFactory<MenuBloc>(() => MenuBloc(getIt<IApp>())); getIt.registerFactory<MenuBloc>(() => MenuBloc(getIt<IWorkspace>()));
} }
} }

View File

@ -1,8 +1,7 @@
import 'package:app_flowy/home/infrastructure/repos/app_repo.dart';
import 'package:dartz/dartz.dart'; import 'package:dartz/dartz.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/app_create.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart'; import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
import 'package:app_flowy/home/domain/i_app.dart'; import 'package:app_flowy/home/domain/i_app.dart';
import 'package:app_flowy/home/infrastructure/app_repo.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/view_create.pb.dart'; import 'package:flowy_sdk/protobuf/flowy-workspace/view_create.pb.dart';
export 'package:app_flowy/home/domain/i_app.dart'; export 'package:app_flowy/home/domain/i_app.dart';
@ -13,18 +12,6 @@ class IAppImpl extends IApp {
required this.repo, required this.repo,
}); });
@override
Future<Either<App, WorkspaceError>> createApp(
{required String name, String? desc}) {
return repo.createApp(name, desc ?? "");
}
@override
Future<Either<List<App>, WorkspaceError>> getApps(
{required String workspaceId}) {
return repo.getApps(workspaceId: workspaceId);
}
@override @override
Future<Either<List<View>, WorkspaceError>> getViews({required String appId}) { Future<Either<List<View>, WorkspaceError>> getViews({required String appId}) {
return repo.getViews(appId: appId); return repo.getViews(appId: appId);

View File

@ -0,0 +1,26 @@
import 'package:app_flowy/home/domain/i_workspace.dart';
import 'package:app_flowy/home/infrastructure/repos/workspace_repo.dart';
import 'package:dartz/dartz.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/app_create.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
export 'package:app_flowy/home/domain/i_workspace.dart';
class IWorkspaceImpl extends IWorkspace {
WorkspaceRepository repo;
IWorkspaceImpl({
required this.repo,
});
@override
Future<Either<App, WorkspaceError>> createApp(
{required String name, String? desc}) {
return repo.createApp(name, desc ?? "");
}
@override
Future<Either<List<App>, WorkspaceError>> getApps(
{required String workspaceId}) {
return repo.getApps(workspaceId: workspaceId);
}
}

View File

@ -0,0 +1,107 @@
import 'dart:async';
import 'package:dartz/dartz.dart';
import 'package:flowy_infra/flowy_logger.dart';
import 'package:flowy_sdk/dispatch/dispatch.dart';
import 'package:flowy_sdk/protobuf/flowy-observable/subject.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/app_create.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/app_query.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/view_create.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/view_create.pbenum.dart';
import 'package:flowy_sdk/rust_stream.dart';
typedef AppUpdatedCallback = void Function(String name, String desc);
typedef ViewUpdatedCallback = void Function(List<View> views);
class AppRepository {
StreamSubscription<ObservableSubject>? _subscription;
ViewUpdatedCallback? _viewUpdatedCallback;
AppUpdatedCallback? _appUpdatedCallback;
String appId;
AppRepository({
required this.appId,
});
Future<Either<App, WorkspaceError>> getAppDesc() {
final request = QueryAppRequest.create()
..appId = appId
..readViews = false;
return WorkspaceEventGetApp(request).send();
}
Future<Either<View, WorkspaceError>> createView(
String appId, String name, String desc, ViewTypeIdentifier viewType) {
final request = CreateViewRequest.create()
..appId = appId
..name = name
..desc = desc
..viewType = viewType;
return WorkspaceEventCreateView(request).send();
}
Future<Either<List<View>, WorkspaceError>> getViews({required String appId}) {
final request = QueryAppRequest.create()
..appId = appId
..readViews = true;
return WorkspaceEventGetApp(request).send().then((result) {
return result.fold(
(app) => left(app.views.items),
(error) => right(error),
);
});
}
void startWatching(
{ViewUpdatedCallback? viewUpdatedCallback,
AppUpdatedCallback? appUpdatedCallback}) {
_viewUpdatedCallback = viewUpdatedCallback;
_appUpdatedCallback = appUpdatedCallback;
_subscription = RustStreamReceiver.listen((observable) {
if (observable.subjectId != appId) {
return;
}
final ty = WorkspaceObservableType.valueOf(observable.ty);
if (ty != null) {
_handleObservableType(ty);
}
});
}
void _handleObservableType(WorkspaceObservableType ty) {
switch (ty) {
case WorkspaceObservableType.ViewUpdated:
if (_viewUpdatedCallback == null) {
return;
}
getViews(appId: appId).then((result) {
result.fold(
(views) => _viewUpdatedCallback!(views),
(error) => Log.error(error),
);
});
break;
case WorkspaceObservableType.AppDescUpdated:
if (_appUpdatedCallback == null) {
return;
}
getAppDesc().then((result) {
result.fold(
(app) => _appUpdatedCallback!(app.name, app.desc),
(error) => Log.error(error),
);
});
break;
default:
break;
}
}
Future<void> close() async {
await _subscription?.cancel();
}
}

View File

@ -0,0 +1,89 @@
import 'dart:async';
import 'package:dartz/dartz.dart';
import 'package:flowy_infra/flowy_logger.dart';
import 'package:flowy_sdk/dispatch/dispatch.dart';
import 'package:flowy_sdk/protobuf/flowy-observable/subject.pb.dart';
import 'package:flowy_sdk/protobuf/flowy-workspace/app_create.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_query.pb.dart';
import 'package:flowy_sdk/rust_stream.dart';
typedef AppUpdatedCallback = void Function(List<App> apps);
class WorkspaceRepository {
StreamSubscription<ObservableSubject>? _subscription;
AppUpdatedCallback? _appUpdatedCallback;
String workspaceId;
WorkspaceRepository({
required this.workspaceId,
});
Future<Either<App, WorkspaceError>> createApp(String appName, String desc) {
return WorkspaceEventGetCurWorkspace().send().then((result) {
return result.fold(
(workspace) {
final request = CreateAppRequest.create()
..name = appName
..workspaceId = workspace.id
..desc = desc;
return WorkspaceEventCreateApp(request).send();
},
(error) {
return right(error);
},
);
});
}
Future<Either<List<App>, WorkspaceError>> getApps(
{required String workspaceId}) {
final request = QueryWorkspaceRequest.create()
..workspaceId = workspaceId
..readApps = true;
return WorkspaceEventGetWorkspace(request).send().then((result) {
return result.fold(
(workspace) => left(workspace.apps.items),
(error) => right(error),
);
});
}
void startWatching({AppUpdatedCallback? appUpdatedCallback}) {
_appUpdatedCallback = appUpdatedCallback;
_subscription = RustStreamReceiver.listen((observable) {
if (observable.subjectId != workspaceId) {
return;
}
final ty = WorkspaceObservableType.valueOf(observable.ty);
if (ty != null) {
_handleObservableType(ty);
}
});
}
void _handleObservableType(WorkspaceObservableType ty) {
switch (ty) {
case WorkspaceObservableType.WorkspaceUpdated:
if (_appUpdatedCallback == null) {
return;
}
getApps(workspaceId: workspaceId).then((result) {
result.fold(
(apps) => _appUpdatedCallback!(apps),
(error) => Log.error(error),
);
});
break;
default:
break;
}
}
Future<void> close() async {
await _subscription?.cancel();
}
}

View File

@ -9,20 +9,24 @@
import 'dart:core' as $core; import 'dart:core' as $core;
import 'package:protobuf/protobuf.dart' as $pb; import 'package:protobuf/protobuf.dart' as $pb;
class ObservableType extends $pb.ProtobufEnum { class WorkspaceObservableType extends $pb.ProtobufEnum {
static const ObservableType Unknown = ObservableType._(0, const $core.bool.fromEnvironment('protobuf.omit_enum_names') ? '' : 'Unknown'); static const WorkspaceObservableType Unknown = WorkspaceObservableType._(0, const $core.bool.fromEnvironment('protobuf.omit_enum_names') ? '' : 'Unknown');
static const ObservableType WorkspaceDidUpdate = ObservableType._(10, const $core.bool.fromEnvironment('protobuf.omit_enum_names') ? '' : 'WorkspaceDidUpdate'); static const WorkspaceObservableType WorkspaceUpdated = WorkspaceObservableType._(10, const $core.bool.fromEnvironment('protobuf.omit_enum_names') ? '' : 'WorkspaceUpdated');
static const ObservableType AppDidUpdate = ObservableType._(11, const $core.bool.fromEnvironment('protobuf.omit_enum_names') ? '' : 'AppDidUpdate'); static const WorkspaceObservableType AppDescUpdated = WorkspaceObservableType._(20, const $core.bool.fromEnvironment('protobuf.omit_enum_names') ? '' : 'AppDescUpdated');
static const WorkspaceObservableType AppViewsUpdated = WorkspaceObservableType._(21, const $core.bool.fromEnvironment('protobuf.omit_enum_names') ? '' : 'AppViewsUpdated');
static const WorkspaceObservableType ViewUpdated = WorkspaceObservableType._(30, const $core.bool.fromEnvironment('protobuf.omit_enum_names') ? '' : 'ViewUpdated');
static const $core.List<ObservableType> values = <ObservableType> [ static const $core.List<WorkspaceObservableType> values = <WorkspaceObservableType> [
Unknown, Unknown,
WorkspaceDidUpdate, WorkspaceUpdated,
AppDidUpdate, AppDescUpdated,
AppViewsUpdated,
ViewUpdated,
]; ];
static final $core.Map<$core.int, ObservableType> _byValue = $pb.ProtobufEnum.initByValue(values); static final $core.Map<$core.int, WorkspaceObservableType> _byValue = $pb.ProtobufEnum.initByValue(values);
static ObservableType? valueOf($core.int value) => _byValue[value]; static WorkspaceObservableType? valueOf($core.int value) => _byValue[value];
const ObservableType._($core.int v, $core.String n) : super(v, n); const WorkspaceObservableType._($core.int v, $core.String n) : super(v, n);
} }

View File

@ -8,15 +8,17 @@
import 'dart:core' as $core; import 'dart:core' as $core;
import 'dart:convert' as $convert; import 'dart:convert' as $convert;
import 'dart:typed_data' as $typed_data; import 'dart:typed_data' as $typed_data;
@$core.Deprecated('Use observableTypeDescriptor instead') @$core.Deprecated('Use workspaceObservableTypeDescriptor instead')
const ObservableType$json = const { const WorkspaceObservableType$json = const {
'1': 'ObservableType', '1': 'WorkspaceObservableType',
'2': const [ '2': const [
const {'1': 'Unknown', '2': 0}, const {'1': 'Unknown', '2': 0},
const {'1': 'WorkspaceDidUpdate', '2': 10}, const {'1': 'WorkspaceUpdated', '2': 10},
const {'1': 'AppDidUpdate', '2': 11}, const {'1': 'AppDescUpdated', '2': 20},
const {'1': 'AppViewsUpdated', '2': 21},
const {'1': 'ViewUpdated', '2': 30},
], ],
}; };
/// Descriptor for `ObservableType`. Decode as a `google.protobuf.EnumDescriptorProto`. /// Descriptor for `WorkspaceObservableType`. Decode as a `google.protobuf.EnumDescriptorProto`.
final $typed_data.Uint8List observableTypeDescriptor = $convert.base64Decode('Cg5PYnNlcnZhYmxlVHlwZRILCgdVbmtub3duEAASFgoSV29ya3NwYWNlRGlkVXBkYXRlEAoSEAoMQXBwRGlkVXBkYXRlEAs='); final $typed_data.Uint8List workspaceObservableTypeDescriptor = $convert.base64Decode('ChdXb3Jrc3BhY2VPYnNlcnZhYmxlVHlwZRILCgdVbmtub3duEAASFAoQV29ya3NwYWNlVXBkYXRlZBAKEhIKDkFwcERlc2NVcGRhdGVkEBQSEwoPQXBwVmlld3NVcGRhdGVkEBUSDwoLVmlld1VwZGF0ZWQQHg==');

View File

@ -46,7 +46,7 @@ pub fn category_from_str(type_str: &str) -> TypeCategory {
"ViewTypeIdentifier" "ViewTypeIdentifier"
| "WorkspaceEvent" | "WorkspaceEvent"
| "WorkspaceErrorCode" | "WorkspaceErrorCode"
| "ObservableType" | "WorkspaceObservableType"
| "FFIStatusCode" | "FFIStatusCode"
| "UserStatus" | "UserStatus"
| "UserEvent" | "UserEvent"

View File

@ -1,3 +1,3 @@
proto_crates = ["src/entities"] proto_crates = ["src/entities"]
event_files = [""] event_files = []

View File

@ -4,25 +4,26 @@ use flowy_observable::{dart::RustStreamSender, entities::ObservableSubject};
const OBSERVABLE_CATEGORY: &'static str = "Workspace"; const OBSERVABLE_CATEGORY: &'static str = "Workspace";
#[derive(ProtoBuf_Enum, Debug)] #[derive(ProtoBuf_Enum, Debug)]
pub(crate) enum ObservableType { pub(crate) enum WorkspaceObservableType {
Unknown = 0, Unknown = 0,
WorkspaceUpdated = 10,
WorkspaceDidUpdate = 10, AppDescUpdated = 20,
AppDidUpdate = 11, AppViewsUpdated = 21,
ViewUpdated = 30,
} }
impl std::default::Default for ObservableType { impl std::default::Default for WorkspaceObservableType {
fn default() -> Self { ObservableType::Unknown } fn default() -> Self { WorkspaceObservableType::Unknown }
} }
pub(crate) struct ObservableSender { pub(crate) struct ObservableSender {
ty: ObservableType, ty: WorkspaceObservableType,
subject_id: String, subject_id: String,
payload: Option<Vec<u8>>, payload: Option<Vec<u8>>,
} }
impl ObservableSender { impl ObservableSender {
pub(crate) fn new(subject_id: &str, ty: ObservableType) -> Self { pub(crate) fn new(subject_id: &str, ty: WorkspaceObservableType) -> Self {
Self { Self {
subject_id: subject_id.to_owned(), subject_id: subject_id.to_owned(),
ty, ty,
@ -59,11 +60,11 @@ impl ObservableSender {
} }
} }
pub(crate) fn send_observable(id: &str, ty: ObservableType) { pub(crate) fn send_observable(id: &str, ty: WorkspaceObservableType) {
ObservableSender::new(id, ty).send(); ObservableSender::new(id, ty).send();
} }
pub(crate) fn send_observable_with_payload<T>(id: &str, ty: ObservableType, payload: T) pub(crate) fn send_observable_with_payload<T>(id: &str, ty: WorkspaceObservableType, payload: T)
where where
T: ToBytes, T: ToBytes,
{ {

View File

@ -24,31 +24,37 @@
// const _PROTOBUF_VERSION_CHECK: () = ::protobuf::VERSION_2_22_1; // const _PROTOBUF_VERSION_CHECK: () = ::protobuf::VERSION_2_22_1;
#[derive(Clone,PartialEq,Eq,Debug,Hash)] #[derive(Clone,PartialEq,Eq,Debug,Hash)]
pub enum ObservableType { pub enum WorkspaceObservableType {
Unknown = 0, Unknown = 0,
WorkspaceDidUpdate = 10, WorkspaceUpdated = 10,
AppDidUpdate = 11, AppDescUpdated = 20,
AppViewsUpdated = 21,
ViewUpdated = 30,
} }
impl ::protobuf::ProtobufEnum for ObservableType { impl ::protobuf::ProtobufEnum for WorkspaceObservableType {
fn value(&self) -> i32 { fn value(&self) -> i32 {
*self as i32 *self as i32
} }
fn from_i32(value: i32) -> ::std::option::Option<ObservableType> { fn from_i32(value: i32) -> ::std::option::Option<WorkspaceObservableType> {
match value { match value {
0 => ::std::option::Option::Some(ObservableType::Unknown), 0 => ::std::option::Option::Some(WorkspaceObservableType::Unknown),
10 => ::std::option::Option::Some(ObservableType::WorkspaceDidUpdate), 10 => ::std::option::Option::Some(WorkspaceObservableType::WorkspaceUpdated),
11 => ::std::option::Option::Some(ObservableType::AppDidUpdate), 20 => ::std::option::Option::Some(WorkspaceObservableType::AppDescUpdated),
21 => ::std::option::Option::Some(WorkspaceObservableType::AppViewsUpdated),
30 => ::std::option::Option::Some(WorkspaceObservableType::ViewUpdated),
_ => ::std::option::Option::None _ => ::std::option::Option::None
} }
} }
fn values() -> &'static [Self] { fn values() -> &'static [Self] {
static values: &'static [ObservableType] = &[ static values: &'static [WorkspaceObservableType] = &[
ObservableType::Unknown, WorkspaceObservableType::Unknown,
ObservableType::WorkspaceDidUpdate, WorkspaceObservableType::WorkspaceUpdated,
ObservableType::AppDidUpdate, WorkspaceObservableType::AppDescUpdated,
WorkspaceObservableType::AppViewsUpdated,
WorkspaceObservableType::ViewUpdated,
]; ];
values values
} }
@ -56,38 +62,43 @@ impl ::protobuf::ProtobufEnum for ObservableType {
fn enum_descriptor_static() -> &'static ::protobuf::reflect::EnumDescriptor { fn enum_descriptor_static() -> &'static ::protobuf::reflect::EnumDescriptor {
static descriptor: ::protobuf::rt::LazyV2<::protobuf::reflect::EnumDescriptor> = ::protobuf::rt::LazyV2::INIT; static descriptor: ::protobuf::rt::LazyV2<::protobuf::reflect::EnumDescriptor> = ::protobuf::rt::LazyV2::INIT;
descriptor.get(|| { descriptor.get(|| {
::protobuf::reflect::EnumDescriptor::new_pb_name::<ObservableType>("ObservableType", file_descriptor_proto()) ::protobuf::reflect::EnumDescriptor::new_pb_name::<WorkspaceObservableType>("WorkspaceObservableType", file_descriptor_proto())
}) })
} }
} }
impl ::std::marker::Copy for ObservableType { impl ::std::marker::Copy for WorkspaceObservableType {
} }
impl ::std::default::Default for ObservableType { impl ::std::default::Default for WorkspaceObservableType {
fn default() -> Self { fn default() -> Self {
ObservableType::Unknown WorkspaceObservableType::Unknown
} }
} }
impl ::protobuf::reflect::ProtobufValue for ObservableType { impl ::protobuf::reflect::ProtobufValue for WorkspaceObservableType {
fn as_ref(&self) -> ::protobuf::reflect::ReflectValueRef { fn as_ref(&self) -> ::protobuf::reflect::ReflectValueRef {
::protobuf::reflect::ReflectValueRef::Enum(::protobuf::ProtobufEnum::descriptor(self)) ::protobuf::reflect::ReflectValueRef::Enum(::protobuf::ProtobufEnum::descriptor(self))
} }
} }
static file_descriptor_proto_data: &'static [u8] = b"\ static file_descriptor_proto_data: &'static [u8] = b"\
\n\x10observable.proto*G\n\x0eObservableType\x12\x0b\n\x07Unknown\x10\0\ \n\x10observable.proto*v\n\x17WorkspaceObservableType\x12\x0b\n\x07Unkno\
\x12\x16\n\x12WorkspaceDidUpdate\x10\n\x12\x10\n\x0cAppDidUpdate\x10\x0b\ wn\x10\0\x12\x14\n\x10WorkspaceUpdated\x10\n\x12\x12\n\x0eAppDescUpdated\
J\xa5\x01\n\x06\x12\x04\0\0\x06\x01\n\x08\n\x01\x0c\x12\x03\0\0\x12\n\n\ \x10\x14\x12\x13\n\x0fAppViewsUpdated\x10\x15\x12\x0f\n\x0bViewUpdated\
\n\x02\x05\0\x12\x04\x02\0\x06\x01\n\n\n\x03\x05\0\x01\x12\x03\x02\x05\ \x10\x1eJ\xf7\x01\n\x06\x12\x04\0\0\x08\x01\n\x08\n\x01\x0c\x12\x03\0\0\
\x13\n\x0b\n\x04\x05\0\x02\0\x12\x03\x03\x04\x10\n\x0c\n\x05\x05\0\x02\0\ \x12\n\n\n\x02\x05\0\x12\x04\x02\0\x08\x01\n\n\n\x03\x05\0\x01\x12\x03\
\x01\x12\x03\x03\x04\x0b\n\x0c\n\x05\x05\0\x02\0\x02\x12\x03\x03\x0e\x0f\ \x02\x05\x1c\n\x0b\n\x04\x05\0\x02\0\x12\x03\x03\x04\x10\n\x0c\n\x05\x05\
\n\x0b\n\x04\x05\0\x02\x01\x12\x03\x04\x04\x1c\n\x0c\n\x05\x05\0\x02\x01\ \0\x02\0\x01\x12\x03\x03\x04\x0b\n\x0c\n\x05\x05\0\x02\0\x02\x12\x03\x03\
\x01\x12\x03\x04\x04\x16\n\x0c\n\x05\x05\0\x02\x01\x02\x12\x03\x04\x19\ \x0e\x0f\n\x0b\n\x04\x05\0\x02\x01\x12\x03\x04\x04\x1a\n\x0c\n\x05\x05\0\
\x1b\n\x0b\n\x04\x05\0\x02\x02\x12\x03\x05\x04\x16\n\x0c\n\x05\x05\0\x02\ \x02\x01\x01\x12\x03\x04\x04\x14\n\x0c\n\x05\x05\0\x02\x01\x02\x12\x03\
\x02\x01\x12\x03\x05\x04\x10\n\x0c\n\x05\x05\0\x02\x02\x02\x12\x03\x05\ \x04\x17\x19\n\x0b\n\x04\x05\0\x02\x02\x12\x03\x05\x04\x18\n\x0c\n\x05\
\x13\x15b\x06proto3\ \x05\0\x02\x02\x01\x12\x03\x05\x04\x12\n\x0c\n\x05\x05\0\x02\x02\x02\x12\
\x03\x05\x15\x17\n\x0b\n\x04\x05\0\x02\x03\x12\x03\x06\x04\x19\n\x0c\n\
\x05\x05\0\x02\x03\x01\x12\x03\x06\x04\x13\n\x0c\n\x05\x05\0\x02\x03\x02\
\x12\x03\x06\x16\x18\n\x0b\n\x04\x05\0\x02\x04\x12\x03\x07\x04\x15\n\x0c\
\n\x05\x05\0\x02\x04\x01\x12\x03\x07\x04\x0f\n\x0c\n\x05\x05\0\x02\x04\
\x02\x12\x03\x07\x12\x14b\x06proto3\
"; ";
static file_descriptor_proto_lazy: ::protobuf::rt::LazyV2<::protobuf::descriptor::FileDescriptorProto> = ::protobuf::rt::LazyV2::INIT; static file_descriptor_proto_lazy: ::protobuf::rt::LazyV2<::protobuf::descriptor::FileDescriptorProto> = ::protobuf::rt::LazyV2::INIT;

View File

@ -1,7 +1,9 @@
syntax = "proto3"; syntax = "proto3";
enum ObservableType { enum WorkspaceObservableType {
Unknown = 0; Unknown = 0;
WorkspaceDidUpdate = 10; WorkspaceUpdated = 10;
AppDidUpdate = 11; AppDescUpdated = 20;
AppViewsUpdated = 21;
ViewUpdated = 30;
} }

View File

@ -36,7 +36,7 @@ impl AppController {
let app_table = AppTable::new(params); let app_table = AppTable::new(params);
let app: App = app_table.clone().into(); let app: App = app_table.clone().into();
let _ = self.sql.write_app_table(app_table)?; let _ = self.sql.write_app_table(app_table)?;
send_observable(&app.workspace_id, ObservableType::WorkspaceDidUpdate); send_observable(&app.workspace_id, WorkspaceObservableType::WorkspaceUpdated);
Ok(app) Ok(app)
} }
@ -49,7 +49,7 @@ impl AppController {
let changeset = AppTableChangeset::new(params); let changeset = AppTableChangeset::new(params);
let app_id = changeset.id.clone(); let app_id = changeset.id.clone();
let _ = self.sql.update_app_table(changeset)?; let _ = self.sql.update_app_table(changeset)?;
send_observable(&app_id, ObservableType::AppDidUpdate); send_observable(&app_id, WorkspaceObservableType::AppDescUpdated);
Ok(()) Ok(())
} }