app_service.dart 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. import 'dart:async';
  2. import 'dart:convert';
  3. import 'package:appflowy_backend/protobuf/flowy-folder/workspace.pb.dart';
  4. import 'package:dartz/dartz.dart';
  5. import 'package:appflowy_backend/dispatch/dispatch.dart';
  6. import 'package:appflowy_backend/protobuf/flowy-error/errors.pb.dart';
  7. import 'package:appflowy_backend/protobuf/flowy-folder/app.pb.dart';
  8. import 'package:appflowy_backend/protobuf/flowy-folder/view.pb.dart';
  9. class AppService {
  10. Future<Either<AppPB, FlowyError>> readApp({required String appId}) {
  11. final payload = AppIdPB.create()..value = appId;
  12. return FolderEventReadApp(payload).send();
  13. }
  14. Future<Either<ViewPB, FlowyError>> createView({
  15. required String appId,
  16. required String name,
  17. String? desc,
  18. required ViewDataFormatPB dataFormatType,
  19. required ViewLayoutTypePB layoutType,
  20. /// The initial data should be the JSON of the doucment
  21. /// For example: {"document":{"type":"editor","children":[]}}
  22. String? initialData,
  23. }) {
  24. final payload = CreateViewPayloadPB.create()
  25. ..belongToId = appId
  26. ..name = name
  27. ..desc = desc ?? ""
  28. ..dataFormat = dataFormatType
  29. ..layout = layoutType
  30. ..initialData = utf8.encode(
  31. initialData ?? "",
  32. );
  33. return FolderEventCreateView(payload).send();
  34. }
  35. Future<Either<List<ViewPB>, FlowyError>> getViews({required String appId}) {
  36. final payload = AppIdPB.create()..value = appId;
  37. return FolderEventReadApp(payload).send().then((result) {
  38. return result.fold(
  39. (app) => left(app.belongings.items),
  40. (error) => right(error),
  41. );
  42. });
  43. }
  44. Future<Either<Unit, FlowyError>> delete({required String appId}) {
  45. final request = AppIdPB.create()..value = appId;
  46. return FolderEventDeleteApp(request).send();
  47. }
  48. Future<Either<Unit, FlowyError>> deleteView({required String viewId}) {
  49. final request = RepeatedViewIdPB.create()..items.add(viewId);
  50. return FolderEventDeleteView(request).send();
  51. }
  52. Future<Either<Unit, FlowyError>> updateApp(
  53. {required String appId, String? name}) {
  54. UpdateAppPayloadPB payload = UpdateAppPayloadPB.create()..appId = appId;
  55. if (name != null) {
  56. payload.name = name;
  57. }
  58. return FolderEventUpdateApp(payload).send();
  59. }
  60. Future<Either<Unit, FlowyError>> moveView({
  61. required String viewId,
  62. required int fromIndex,
  63. required int toIndex,
  64. }) {
  65. final payload = MoveFolderItemPayloadPB.create()
  66. ..itemId = viewId
  67. ..from = fromIndex
  68. ..to = toIndex
  69. ..ty = MoveFolderItemType.MoveView;
  70. return FolderEventMoveItem(payload).send();
  71. }
  72. Future<List<Tuple2<AppPB, List<ViewPB>>>> fetchViews(
  73. ViewLayoutTypePB layoutType) async {
  74. final result = <Tuple2<AppPB, List<ViewPB>>>[];
  75. return FolderEventReadCurrentWorkspace().send().then((value) async {
  76. final workspaces = value.getLeftOrNull<WorkspaceSettingPB>();
  77. if (workspaces != null) {
  78. final apps = workspaces.workspace.apps.items;
  79. for (var app in apps) {
  80. final views = await getViews(appId: app.id).then(
  81. (value) => value
  82. .getLeftOrNull<List<ViewPB>>()
  83. ?.where((e) => e.layout == layoutType)
  84. .toList(),
  85. );
  86. if (views != null && views.isNotEmpty) {
  87. result.add(Tuple2(app, views));
  88. }
  89. }
  90. }
  91. return result;
  92. });
  93. }
  94. Future<Either<ViewPB, FlowyError>> getView(
  95. String appID,
  96. String viewID,
  97. ) async {
  98. final payload = AppIdPB.create()..value = appID;
  99. return FolderEventReadApp(payload).send().then((result) {
  100. return result.fold(
  101. (app) => left(
  102. app.belongings.items.firstWhere((e) => e.id == viewID),
  103. ),
  104. (error) => right(error),
  105. );
  106. });
  107. }
  108. }
  109. extension AppFlowy on Either {
  110. T? getLeftOrNull<T>() {
  111. if (isLeft()) {
  112. final result = fold<T?>((l) => l, (r) => null);
  113. return result;
  114. }
  115. return null;
  116. }
  117. }