event_handler.rs 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562
  1. use crate::entities::*;
  2. use crate::manager::DatabaseManager;
  3. use crate::services::cell::{FromCellString, ToCellChangesetString, TypeCellData};
  4. use crate::services::field::{
  5. default_type_option_builder_from_type, select_type_option_from_field_rev,
  6. type_option_builder_from_json_str, DateCellChangeset, DateChangesetPB, SelectOptionCellChangeset,
  7. SelectOptionCellChangesetPB, SelectOptionCellChangesetParams, SelectOptionCellDataPB,
  8. SelectOptionChangeset, SelectOptionChangesetPB, SelectOptionIds, SelectOptionPB,
  9. };
  10. use crate::services::row::make_row_from_row_rev;
  11. use database_model::FieldRevision;
  12. use flowy_error::{ErrorCode, FlowyError, FlowyResult};
  13. use lib_dispatch::prelude::{data_result, AFPluginData, AFPluginState, DataResult};
  14. use std::sync::Arc;
  15. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  16. pub(crate) async fn get_database_data_handler(
  17. data: AFPluginData<DatabaseViewIdPB>,
  18. manager: AFPluginState<Arc<DatabaseManager>>,
  19. ) -> DataResult<DatabasePB, FlowyError> {
  20. let database_id: DatabaseViewIdPB = data.into_inner();
  21. let editor = manager.open_database(database_id.as_ref()).await?;
  22. let database = editor.get_database(database_id.as_ref()).await?;
  23. data_result(database)
  24. }
  25. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  26. pub(crate) async fn get_database_setting_handler(
  27. data: AFPluginData<DatabaseViewIdPB>,
  28. manager: AFPluginState<Arc<DatabaseManager>>,
  29. ) -> DataResult<DatabaseViewSettingPB, FlowyError> {
  30. let database_id: DatabaseViewIdPB = data.into_inner();
  31. let editor = manager.open_database(database_id).await?;
  32. let database_setting = editor.get_setting().await?;
  33. data_result(database_setting)
  34. }
  35. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  36. pub(crate) async fn update_database_setting_handler(
  37. data: AFPluginData<DatabaseSettingChangesetPB>,
  38. manager: AFPluginState<Arc<DatabaseManager>>,
  39. ) -> Result<(), FlowyError> {
  40. let params: DatabaseSettingChangesetParams = data.into_inner().try_into()?;
  41. let editor = manager.get_database_editor(&params.view_id).await?;
  42. if let Some(insert_params) = params.insert_group {
  43. editor.insert_group(insert_params).await?;
  44. }
  45. if let Some(delete_params) = params.delete_group {
  46. editor.delete_group(delete_params).await?;
  47. }
  48. if let Some(alter_filter) = params.insert_filter {
  49. editor.create_or_update_filter(alter_filter).await?;
  50. }
  51. if let Some(delete_filter) = params.delete_filter {
  52. editor.delete_filter(delete_filter).await?;
  53. }
  54. if let Some(alter_sort) = params.alert_sort {
  55. let _ = editor.create_or_update_sort(alter_sort).await?;
  56. }
  57. if let Some(delete_sort) = params.delete_sort {
  58. editor.delete_sort(delete_sort).await?;
  59. }
  60. Ok(())
  61. }
  62. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  63. pub(crate) async fn get_all_filters_handler(
  64. data: AFPluginData<DatabaseViewIdPB>,
  65. manager: AFPluginState<Arc<DatabaseManager>>,
  66. ) -> DataResult<RepeatedFilterPB, FlowyError> {
  67. let database_id: DatabaseViewIdPB = data.into_inner();
  68. let editor = manager.open_database(database_id).await?;
  69. let filters = RepeatedFilterPB {
  70. items: editor.get_all_filters().await?,
  71. };
  72. data_result(filters)
  73. }
  74. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  75. pub(crate) async fn get_all_sorts_handler(
  76. data: AFPluginData<DatabaseViewIdPB>,
  77. manager: AFPluginState<Arc<DatabaseManager>>,
  78. ) -> DataResult<RepeatedSortPB, FlowyError> {
  79. let database_id: DatabaseViewIdPB = data.into_inner();
  80. let editor = manager.open_database(database_id.as_ref()).await?;
  81. let sorts = RepeatedSortPB {
  82. items: editor.get_all_sorts(database_id.as_ref()).await?,
  83. };
  84. data_result(sorts)
  85. }
  86. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  87. pub(crate) async fn delete_all_sorts_handler(
  88. data: AFPluginData<DatabaseViewIdPB>,
  89. manager: AFPluginState<Arc<DatabaseManager>>,
  90. ) -> Result<(), FlowyError> {
  91. let database_id: DatabaseViewIdPB = data.into_inner();
  92. let editor = manager.open_database(database_id.as_ref()).await?;
  93. editor.delete_all_sorts(database_id.as_ref()).await?;
  94. Ok(())
  95. }
  96. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  97. pub(crate) async fn get_fields_handler(
  98. data: AFPluginData<GetFieldPayloadPB>,
  99. manager: AFPluginState<Arc<DatabaseManager>>,
  100. ) -> DataResult<RepeatedFieldPB, FlowyError> {
  101. let params: GetFieldParams = data.into_inner().try_into()?;
  102. let editor = manager.get_database_editor(&params.view_id).await?;
  103. let field_revs = editor.get_field_revs(params.field_ids).await?;
  104. let repeated_field: RepeatedFieldPB = field_revs
  105. .into_iter()
  106. .map(FieldPB::from)
  107. .collect::<Vec<_>>()
  108. .into();
  109. data_result(repeated_field)
  110. }
  111. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  112. pub(crate) async fn update_field_handler(
  113. data: AFPluginData<FieldChangesetPB>,
  114. manager: AFPluginState<Arc<DatabaseManager>>,
  115. ) -> Result<(), FlowyError> {
  116. let changeset: FieldChangesetParams = data.into_inner().try_into()?;
  117. let editor = manager.get_database_editor(&changeset.database_id).await?;
  118. editor.update_field(changeset).await?;
  119. Ok(())
  120. }
  121. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  122. pub(crate) async fn update_field_type_option_handler(
  123. data: AFPluginData<TypeOptionChangesetPB>,
  124. manager: AFPluginState<Arc<DatabaseManager>>,
  125. ) -> Result<(), FlowyError> {
  126. let params: TypeOptionChangesetParams = data.into_inner().try_into()?;
  127. let editor = manager.get_database_editor(&params.view_id).await?;
  128. let old_field_rev = editor.get_field_rev(&params.field_id).await;
  129. editor
  130. .update_field_type_option(&params.field_id, params.type_option_data, old_field_rev)
  131. .await?;
  132. Ok(())
  133. }
  134. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  135. pub(crate) async fn delete_field_handler(
  136. data: AFPluginData<DeleteFieldPayloadPB>,
  137. manager: AFPluginState<Arc<DatabaseManager>>,
  138. ) -> Result<(), FlowyError> {
  139. let params: FieldIdParams = data.into_inner().try_into()?;
  140. let editor = manager.get_database_editor(&params.view_id).await?;
  141. editor.delete_field(&params.field_id).await?;
  142. Ok(())
  143. }
  144. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  145. pub(crate) async fn switch_to_field_handler(
  146. data: AFPluginData<UpdateFieldTypePayloadPB>,
  147. manager: AFPluginState<Arc<DatabaseManager>>,
  148. ) -> Result<(), FlowyError> {
  149. let params: EditFieldParams = data.into_inner().try_into()?;
  150. let editor = manager.get_database_editor(&params.view_id).await?;
  151. let old_field_rev = editor.get_field_rev(&params.field_id).await;
  152. editor
  153. .switch_to_field_type(&params.field_id, &params.field_type)
  154. .await?;
  155. // Get the field_rev with field_id, if it doesn't exist, we create the default FieldRevision from the FieldType.
  156. let new_field_rev = editor
  157. .get_field_rev(&params.field_id)
  158. .await
  159. .unwrap_or(Arc::new(editor.next_field_rev(&params.field_type).await?));
  160. // Update the type-option data after the field type has been changed
  161. let type_option_data = get_type_option_data(&new_field_rev, &params.field_type).await?;
  162. editor
  163. .update_field_type_option(&new_field_rev.id, type_option_data, old_field_rev)
  164. .await?;
  165. Ok(())
  166. }
  167. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  168. pub(crate) async fn duplicate_field_handler(
  169. data: AFPluginData<DuplicateFieldPayloadPB>,
  170. manager: AFPluginState<Arc<DatabaseManager>>,
  171. ) -> Result<(), FlowyError> {
  172. let params: FieldIdParams = data.into_inner().try_into()?;
  173. let editor = manager.get_database_editor(&params.view_id).await?;
  174. editor.duplicate_field(&params.field_id).await?;
  175. Ok(())
  176. }
  177. /// Return the FieldTypeOptionData if the Field exists otherwise return record not found error.
  178. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  179. pub(crate) async fn get_field_type_option_data_handler(
  180. data: AFPluginData<TypeOptionPathPB>,
  181. manager: AFPluginState<Arc<DatabaseManager>>,
  182. ) -> DataResult<TypeOptionPB, FlowyError> {
  183. let params: TypeOptionPathParams = data.into_inner().try_into()?;
  184. let editor = manager.get_database_editor(&params.view_id).await?;
  185. match editor.get_field_rev(&params.field_id).await {
  186. None => Err(FlowyError::record_not_found()),
  187. Some(field_rev) => {
  188. let field_type = field_rev.ty.into();
  189. let type_option_data = get_type_option_data(&field_rev, &field_type).await?;
  190. let data = TypeOptionPB {
  191. view_id: params.view_id,
  192. field: field_rev.into(),
  193. type_option_data,
  194. };
  195. data_result(data)
  196. },
  197. }
  198. }
  199. /// Create FieldMeta and save it. Return the FieldTypeOptionData.
  200. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  201. pub(crate) async fn create_field_type_option_data_handler(
  202. data: AFPluginData<CreateFieldPayloadPB>,
  203. manager: AFPluginState<Arc<DatabaseManager>>,
  204. ) -> DataResult<TypeOptionPB, FlowyError> {
  205. let params: CreateFieldParams = data.into_inner().try_into()?;
  206. let editor = manager.get_database_editor(&params.view_id).await?;
  207. let field_rev = editor
  208. .create_new_field_rev_with_type_option(&params.field_type, params.type_option_data)
  209. .await?;
  210. let field_type: FieldType = field_rev.ty.into();
  211. let type_option_data = get_type_option_data(&field_rev, &field_type).await?;
  212. data_result(TypeOptionPB {
  213. view_id: params.view_id,
  214. field: field_rev.into(),
  215. type_option_data,
  216. })
  217. }
  218. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  219. pub(crate) async fn move_field_handler(
  220. data: AFPluginData<MoveFieldPayloadPB>,
  221. manager: AFPluginState<Arc<DatabaseManager>>,
  222. ) -> Result<(), FlowyError> {
  223. let params: MoveFieldParams = data.into_inner().try_into()?;
  224. let editor = manager.get_database_editor(&params.view_id).await?;
  225. editor.move_field(params).await?;
  226. Ok(())
  227. }
  228. /// The [FieldRevision] contains multiple data, each of them belongs to a specific FieldType.
  229. async fn get_type_option_data(
  230. field_rev: &FieldRevision,
  231. field_type: &FieldType,
  232. ) -> FlowyResult<Vec<u8>> {
  233. let s = field_rev
  234. .get_type_option_str(field_type)
  235. .map(|value| value.to_owned())
  236. .unwrap_or_else(|| {
  237. default_type_option_builder_from_type(field_type)
  238. .serializer()
  239. .json_str()
  240. });
  241. let field_type: FieldType = field_rev.ty.into();
  242. let builder = type_option_builder_from_json_str(&s, &field_type);
  243. let type_option_data = builder.serializer().protobuf_bytes().to_vec();
  244. Ok(type_option_data)
  245. }
  246. // #[tracing::instrument(level = "debug", skip(data, manager), err)]
  247. pub(crate) async fn get_row_handler(
  248. data: AFPluginData<RowIdPB>,
  249. manager: AFPluginState<Arc<DatabaseManager>>,
  250. ) -> DataResult<OptionalRowPB, FlowyError> {
  251. let params: RowIdParams = data.into_inner().try_into()?;
  252. let editor = manager.get_database_editor(&params.view_id).await?;
  253. let row = editor
  254. .get_row_rev(&params.row_id)
  255. .await?
  256. .map(make_row_from_row_rev);
  257. data_result(OptionalRowPB { row })
  258. }
  259. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  260. pub(crate) async fn delete_row_handler(
  261. data: AFPluginData<RowIdPB>,
  262. manager: AFPluginState<Arc<DatabaseManager>>,
  263. ) -> Result<(), FlowyError> {
  264. let params: RowIdParams = data.into_inner().try_into()?;
  265. let editor = manager.get_database_editor(&params.view_id).await?;
  266. editor.delete_row(&params.row_id).await?;
  267. Ok(())
  268. }
  269. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  270. pub(crate) async fn duplicate_row_handler(
  271. data: AFPluginData<RowIdPB>,
  272. manager: AFPluginState<Arc<DatabaseManager>>,
  273. ) -> Result<(), FlowyError> {
  274. let params: RowIdParams = data.into_inner().try_into()?;
  275. let editor = manager.get_database_editor(&params.view_id).await?;
  276. editor.duplicate_row(&params.row_id).await?;
  277. Ok(())
  278. }
  279. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  280. pub(crate) async fn move_row_handler(
  281. data: AFPluginData<MoveRowPayloadPB>,
  282. manager: AFPluginState<Arc<DatabaseManager>>,
  283. ) -> Result<(), FlowyError> {
  284. let params: MoveRowParams = data.into_inner().try_into()?;
  285. let editor = manager.get_database_editor(&params.view_id).await?;
  286. editor.move_row(params).await?;
  287. Ok(())
  288. }
  289. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  290. pub(crate) async fn create_table_row_handler(
  291. data: AFPluginData<CreateRowPayloadPB>,
  292. manager: AFPluginState<Arc<DatabaseManager>>,
  293. ) -> DataResult<RowPB, FlowyError> {
  294. let params: CreateRowParams = data.into_inner().try_into()?;
  295. let editor = manager.get_database_editor(params.view_id.as_ref()).await?;
  296. let row = editor.create_row(params).await?;
  297. data_result(row)
  298. }
  299. #[tracing::instrument(level = "trace", skip_all, err)]
  300. pub(crate) async fn get_cell_handler(
  301. data: AFPluginData<CellIdPB>,
  302. manager: AFPluginState<Arc<DatabaseManager>>,
  303. ) -> DataResult<CellPB, FlowyError> {
  304. let params: CellIdParams = data.into_inner().try_into()?;
  305. let editor = manager.get_database_editor(&params.database_id).await?;
  306. match editor.get_cell(&params).await {
  307. None => data_result(CellPB::empty(&params.field_id, &params.row_id)),
  308. Some(cell) => data_result(cell),
  309. }
  310. }
  311. #[tracing::instrument(level = "trace", skip_all, err)]
  312. pub(crate) async fn update_cell_handler(
  313. data: AFPluginData<CellChangesetPB>,
  314. manager: AFPluginState<Arc<DatabaseManager>>,
  315. ) -> Result<(), FlowyError> {
  316. let changeset: CellChangesetPB = data.into_inner();
  317. let editor = manager.get_database_editor(&changeset.database_id).await?;
  318. editor
  319. .update_cell_with_changeset(
  320. &changeset.row_id,
  321. &changeset.field_id,
  322. changeset.type_cell_data,
  323. )
  324. .await?;
  325. Ok(())
  326. }
  327. #[tracing::instrument(level = "trace", skip_all, err)]
  328. pub(crate) async fn new_select_option_handler(
  329. data: AFPluginData<CreateSelectOptionPayloadPB>,
  330. manager: AFPluginState<Arc<DatabaseManager>>,
  331. ) -> DataResult<SelectOptionPB, FlowyError> {
  332. let params: CreateSelectOptionParams = data.into_inner().try_into()?;
  333. let editor = manager.get_database_editor(&params.database_id).await?;
  334. match editor.get_field_rev(&params.field_id).await {
  335. None => Err(ErrorCode::InvalidData.into()),
  336. Some(field_rev) => {
  337. let type_option = select_type_option_from_field_rev(&field_rev)?;
  338. let select_option = type_option.create_option(&params.option_name);
  339. data_result(select_option)
  340. },
  341. }
  342. }
  343. #[tracing::instrument(level = "trace", skip_all, err)]
  344. pub(crate) async fn update_select_option_handler(
  345. data: AFPluginData<SelectOptionChangesetPB>,
  346. manager: AFPluginState<Arc<DatabaseManager>>,
  347. ) -> Result<(), FlowyError> {
  348. let changeset: SelectOptionChangeset = data.into_inner().try_into()?;
  349. let editor = manager
  350. .get_database_editor(&changeset.cell_path.database_id)
  351. .await?;
  352. let field_id = changeset.cell_path.field_id.clone();
  353. let (tx, rx) = tokio::sync::oneshot::channel();
  354. editor
  355. .modify_field_rev(&field_id, |field_rev| {
  356. let mut type_option = select_type_option_from_field_rev(field_rev)?;
  357. let mut cell_changeset_str = None;
  358. let mut is_changed = None;
  359. for option in changeset.insert_options {
  360. cell_changeset_str = Some(
  361. SelectOptionCellChangeset::from_insert_option_id(&option.id).to_cell_changeset_str(),
  362. );
  363. type_option.insert_option(option);
  364. is_changed = Some(());
  365. }
  366. for option in changeset.update_options {
  367. type_option.insert_option(option);
  368. is_changed = Some(());
  369. }
  370. for option in changeset.delete_options {
  371. cell_changeset_str = Some(
  372. SelectOptionCellChangeset::from_delete_option_id(&option.id).to_cell_changeset_str(),
  373. );
  374. type_option.delete_option(option);
  375. is_changed = Some(());
  376. }
  377. if is_changed.is_some() {
  378. field_rev.insert_type_option(&*type_option);
  379. }
  380. let _ = tx.send(cell_changeset_str);
  381. Ok(is_changed)
  382. })
  383. .await?;
  384. if let Ok(Some(cell_changeset_str)) = rx.await {
  385. match editor
  386. .update_cell_with_changeset(
  387. &changeset.cell_path.row_id,
  388. &changeset.cell_path.field_id,
  389. cell_changeset_str,
  390. )
  391. .await
  392. {
  393. Ok(_) => {},
  394. Err(e) => tracing::error!("{}", e),
  395. }
  396. }
  397. Ok(())
  398. }
  399. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  400. pub(crate) async fn get_select_option_handler(
  401. data: AFPluginData<CellIdPB>,
  402. manager: AFPluginState<Arc<DatabaseManager>>,
  403. ) -> DataResult<SelectOptionCellDataPB, FlowyError> {
  404. let params: CellIdParams = data.into_inner().try_into()?;
  405. let editor = manager.get_database_editor(&params.database_id).await?;
  406. match editor.get_field_rev(&params.field_id).await {
  407. None => {
  408. tracing::error!(
  409. "Can't find the select option field with id: {}",
  410. params.field_id
  411. );
  412. data_result(SelectOptionCellDataPB::default())
  413. },
  414. Some(field_rev) => {
  415. //
  416. let cell_rev = editor
  417. .get_cell_rev(&params.row_id, &params.field_id)
  418. .await?;
  419. let type_option = select_type_option_from_field_rev(&field_rev)?;
  420. let type_cell_data: TypeCellData = match cell_rev {
  421. None => TypeCellData {
  422. cell_str: "".to_string(),
  423. field_type: field_rev.ty.into(),
  424. },
  425. Some(cell_rev) => cell_rev.try_into()?,
  426. };
  427. let ids = SelectOptionIds::from_cell_str(&type_cell_data.cell_str)?;
  428. let selected_options = type_option.get_selected_options(ids);
  429. data_result(selected_options)
  430. },
  431. }
  432. }
  433. #[tracing::instrument(level = "trace", skip_all, err)]
  434. pub(crate) async fn update_select_option_cell_handler(
  435. data: AFPluginData<SelectOptionCellChangesetPB>,
  436. manager: AFPluginState<Arc<DatabaseManager>>,
  437. ) -> Result<(), FlowyError> {
  438. let params: SelectOptionCellChangesetParams = data.into_inner().try_into()?;
  439. let editor = manager
  440. .get_database_editor(&params.cell_identifier.database_id)
  441. .await?;
  442. let changeset = SelectOptionCellChangeset {
  443. insert_option_ids: params.insert_option_ids,
  444. delete_option_ids: params.delete_option_ids,
  445. };
  446. editor
  447. .update_cell_with_changeset(
  448. &params.cell_identifier.row_id,
  449. &params.cell_identifier.field_id,
  450. changeset,
  451. )
  452. .await?;
  453. Ok(())
  454. }
  455. #[tracing::instrument(level = "trace", skip_all, err)]
  456. pub(crate) async fn update_date_cell_handler(
  457. data: AFPluginData<DateChangesetPB>,
  458. manager: AFPluginState<Arc<DatabaseManager>>,
  459. ) -> Result<(), FlowyError> {
  460. let data = data.into_inner();
  461. let cell_path: CellIdParams = data.cell_path.try_into()?;
  462. let cell_changeset = DateCellChangeset {
  463. date: data.date,
  464. time: data.time,
  465. is_utc: data.is_utc,
  466. };
  467. let editor = manager.get_database_editor(&cell_path.database_id).await?;
  468. editor
  469. .update_cell(cell_path.row_id, cell_path.field_id, cell_changeset)
  470. .await?;
  471. Ok(())
  472. }
  473. #[tracing::instrument(level = "trace", skip_all, err)]
  474. pub(crate) async fn get_groups_handler(
  475. data: AFPluginData<DatabaseViewIdPB>,
  476. manager: AFPluginState<Arc<DatabaseManager>>,
  477. ) -> DataResult<RepeatedGroupPB, FlowyError> {
  478. let params: DatabaseViewIdPB = data.into_inner();
  479. let editor = manager.get_database_editor(&params.value).await?;
  480. let group = editor.load_groups().await?;
  481. data_result(group)
  482. }
  483. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  484. pub(crate) async fn create_board_card_handler(
  485. data: AFPluginData<CreateBoardCardPayloadPB>,
  486. manager: AFPluginState<Arc<DatabaseManager>>,
  487. ) -> DataResult<RowPB, FlowyError> {
  488. let params: CreateRowParams = data.into_inner().try_into()?;
  489. let editor = manager.get_database_editor(params.view_id.as_ref()).await?;
  490. let row = editor.create_row(params).await?;
  491. data_result(row)
  492. }
  493. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  494. pub(crate) async fn move_group_handler(
  495. data: AFPluginData<MoveGroupPayloadPB>,
  496. manager: AFPluginState<Arc<DatabaseManager>>,
  497. ) -> FlowyResult<()> {
  498. let params: MoveGroupParams = data.into_inner().try_into()?;
  499. let editor = manager.get_database_editor(params.view_id.as_ref()).await?;
  500. editor.move_group(params).await?;
  501. Ok(())
  502. }
  503. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  504. pub(crate) async fn move_group_row_handler(
  505. data: AFPluginData<MoveGroupRowPayloadPB>,
  506. manager: AFPluginState<Arc<DatabaseManager>>,
  507. ) -> FlowyResult<()> {
  508. let params: MoveGroupRowParams = data.into_inner().try_into()?;
  509. let editor = manager.get_database_editor(params.view_id.as_ref()).await?;
  510. editor.move_group_row(params).await?;
  511. Ok(())
  512. }