event_handler.rs 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477
  1. use crate::entities::*;
  2. use crate::manager::GridManager;
  3. use crate::services::cell::AnyCellData;
  4. use crate::services::field::{
  5. default_type_option_builder_from_type, select_option_operation, type_option_builder_from_json_str,
  6. DateChangesetParams, DateChangesetPayloadPB, SelectOptionCellChangeset, SelectOptionCellChangesetParams,
  7. SelectOptionCellChangesetPayloadPB, SelectOptionCellDataPB, SelectOptionChangeset, SelectOptionChangesetPayloadPB,
  8. SelectOptionPB,
  9. };
  10. use crate::services::row::make_row_from_row_rev;
  11. use flowy_error::{ErrorCode, FlowyError, FlowyResult};
  12. use flowy_grid_data_model::revision::FieldRevision;
  13. use lib_dispatch::prelude::{data_result, AppData, Data, DataResult};
  14. use std::sync::Arc;
  15. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  16. pub(crate) async fn get_grid_handler(
  17. data: Data<GridIdPB>,
  18. manager: AppData<Arc<GridManager>>,
  19. ) -> DataResult<GridPB, FlowyError> {
  20. let grid_id: GridIdPB = data.into_inner();
  21. let editor = manager.open_grid(grid_id).await?;
  22. let grid = editor.get_grid_data().await?;
  23. data_result(grid)
  24. }
  25. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  26. pub(crate) async fn get_grid_setting_handler(
  27. data: Data<GridIdPB>,
  28. manager: AppData<Arc<GridManager>>,
  29. ) -> DataResult<GridSettingPB, FlowyError> {
  30. let grid_id: GridIdPB = data.into_inner();
  31. let editor = manager.open_grid(grid_id).await?;
  32. let grid_setting = editor.get_grid_setting().await?;
  33. data_result(grid_setting)
  34. }
  35. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  36. pub(crate) async fn update_grid_setting_handler(
  37. data: Data<GridSettingChangesetPayloadPB>,
  38. manager: AppData<Arc<GridManager>>,
  39. ) -> Result<(), FlowyError> {
  40. let params: GridSettingChangesetParams = data.into_inner().try_into()?;
  41. let editor = manager.get_grid_editor(&params.grid_id)?;
  42. if let Some(insert_params) = params.insert_group {
  43. let _ = editor.insert_group(insert_params).await?;
  44. }
  45. if let Some(delete_params) = params.delete_group {
  46. let _ = editor.delete_group(delete_params).await?;
  47. }
  48. if let Some(create_filter) = params.insert_filter {
  49. let _ = editor.create_filter(create_filter).await?;
  50. }
  51. if let Some(delete_filter) = params.delete_filter {
  52. let _ = editor.delete_filter(delete_filter).await?;
  53. }
  54. Ok(())
  55. }
  56. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  57. pub(crate) async fn get_grid_blocks_handler(
  58. data: Data<QueryBlocksPayloadPB>,
  59. manager: AppData<Arc<GridManager>>,
  60. ) -> DataResult<RepeatedBlockPB, FlowyError> {
  61. let params: QueryGridBlocksParams = data.into_inner().try_into()?;
  62. let editor = manager.get_grid_editor(&params.grid_id)?;
  63. let repeated_grid_block = editor.get_blocks(Some(params.block_ids)).await?;
  64. data_result(repeated_grid_block)
  65. }
  66. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  67. pub(crate) async fn get_fields_handler(
  68. data: Data<QueryFieldPayloadPB>,
  69. manager: AppData<Arc<GridManager>>,
  70. ) -> DataResult<RepeatedFieldPB, FlowyError> {
  71. let params: QueryFieldParams = data.into_inner().try_into()?;
  72. let editor = manager.get_grid_editor(&params.grid_id)?;
  73. let field_orders = params
  74. .field_ids
  75. .items
  76. .into_iter()
  77. .map(|field_order| field_order.field_id)
  78. .collect();
  79. let field_revs = editor.get_field_revs(Some(field_orders)).await?;
  80. let repeated_field: RepeatedFieldPB = field_revs.into_iter().map(FieldPB::from).collect::<Vec<_>>().into();
  81. data_result(repeated_field)
  82. }
  83. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  84. pub(crate) async fn update_field_handler(
  85. data: Data<FieldChangesetPayloadPB>,
  86. manager: AppData<Arc<GridManager>>,
  87. ) -> Result<(), FlowyError> {
  88. let changeset: FieldChangesetParams = data.into_inner().try_into()?;
  89. let editor = manager.get_grid_editor(&changeset.grid_id)?;
  90. let _ = editor.update_field(changeset).await?;
  91. Ok(())
  92. }
  93. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  94. pub(crate) async fn insert_field_handler(
  95. data: Data<InsertFieldPayloadPB>,
  96. manager: AppData<Arc<GridManager>>,
  97. ) -> Result<(), FlowyError> {
  98. let params: InsertFieldParams = data.into_inner().try_into()?;
  99. let editor = manager.get_grid_editor(&params.grid_id)?;
  100. let _ = editor.insert_field(params).await?;
  101. Ok(())
  102. }
  103. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  104. pub(crate) async fn update_field_type_option_handler(
  105. data: Data<UpdateFieldTypeOptionPayloadPB>,
  106. manager: AppData<Arc<GridManager>>,
  107. ) -> Result<(), FlowyError> {
  108. let params: UpdateFieldTypeOptionParams = data.into_inner().try_into()?;
  109. let editor = manager.get_grid_editor(&params.grid_id)?;
  110. let _ = editor
  111. .update_field_type_option(&params.grid_id, &params.field_id, params.type_option_data)
  112. .await?;
  113. Ok(())
  114. }
  115. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  116. pub(crate) async fn delete_field_handler(
  117. data: Data<DeleteFieldPayloadPB>,
  118. manager: AppData<Arc<GridManager>>,
  119. ) -> Result<(), FlowyError> {
  120. let params: FieldIdParams = data.into_inner().try_into()?;
  121. let editor = manager.get_grid_editor(&params.grid_id)?;
  122. let _ = editor.delete_field(&params.field_id).await?;
  123. Ok(())
  124. }
  125. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  126. pub(crate) async fn switch_to_field_handler(
  127. data: Data<EditFieldPayloadPB>,
  128. manager: AppData<Arc<GridManager>>,
  129. ) -> DataResult<FieldTypeOptionDataPB, FlowyError> {
  130. let params: EditFieldParams = data.into_inner().try_into()?;
  131. let editor = manager.get_grid_editor(&params.grid_id)?;
  132. editor
  133. .switch_to_field_type(&params.field_id, &params.field_type)
  134. .await?;
  135. // Get the FieldMeta with field_id, if it doesn't exist, we create the default FieldMeta from the FieldType.
  136. let field_rev = editor
  137. .get_field_rev(&params.field_id)
  138. .await
  139. .unwrap_or(Arc::new(editor.next_field_rev(&params.field_type).await?));
  140. let type_option_data = get_type_option_data(&field_rev, &params.field_type).await?;
  141. let data = FieldTypeOptionDataPB {
  142. grid_id: params.grid_id,
  143. field: field_rev.into(),
  144. type_option_data,
  145. };
  146. data_result(data)
  147. }
  148. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  149. pub(crate) async fn duplicate_field_handler(
  150. data: Data<DuplicateFieldPayloadPB>,
  151. manager: AppData<Arc<GridManager>>,
  152. ) -> Result<(), FlowyError> {
  153. let params: FieldIdParams = data.into_inner().try_into()?;
  154. let editor = manager.get_grid_editor(&params.grid_id)?;
  155. let _ = editor.duplicate_field(&params.field_id).await?;
  156. Ok(())
  157. }
  158. /// Return the FieldTypeOptionData if the Field exists otherwise return record not found error.
  159. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  160. pub(crate) async fn get_field_type_option_data_handler(
  161. data: Data<FieldTypeOptionIdPB>,
  162. manager: AppData<Arc<GridManager>>,
  163. ) -> DataResult<FieldTypeOptionDataPB, FlowyError> {
  164. let params: FieldTypeOptionIdParams = data.into_inner().try_into()?;
  165. let editor = manager.get_grid_editor(&params.grid_id)?;
  166. match editor.get_field_rev(&params.field_id).await {
  167. None => Err(FlowyError::record_not_found()),
  168. Some(field_rev) => {
  169. let field_type = field_rev.ty.into();
  170. let type_option_data = get_type_option_data(&field_rev, &field_type).await?;
  171. let data = FieldTypeOptionDataPB {
  172. grid_id: params.grid_id,
  173. field: field_rev.into(),
  174. type_option_data,
  175. };
  176. data_result(data)
  177. }
  178. }
  179. }
  180. /// Create FieldMeta and save it. Return the FieldTypeOptionData.
  181. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  182. pub(crate) async fn create_field_type_option_data_handler(
  183. data: Data<CreateFieldPayloadPB>,
  184. manager: AppData<Arc<GridManager>>,
  185. ) -> DataResult<FieldTypeOptionDataPB, FlowyError> {
  186. let params: CreateFieldParams = data.into_inner().try_into()?;
  187. let editor = manager.get_grid_editor(&params.grid_id)?;
  188. let field_rev = editor.create_next_field_rev(&params.field_type).await?;
  189. let field_type: FieldType = field_rev.ty.into();
  190. let type_option_data = get_type_option_data(&field_rev, &field_type).await?;
  191. data_result(FieldTypeOptionDataPB {
  192. grid_id: params.grid_id,
  193. field: field_rev.into(),
  194. type_option_data,
  195. })
  196. }
  197. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  198. pub(crate) async fn move_field_handler(
  199. data: Data<MoveFieldPayloadPB>,
  200. manager: AppData<Arc<GridManager>>,
  201. ) -> Result<(), FlowyError> {
  202. let params: MoveFieldParams = data.into_inner().try_into()?;
  203. let editor = manager.get_grid_editor(&params.grid_id)?;
  204. let _ = editor.move_field(params).await?;
  205. Ok(())
  206. }
  207. /// The FieldMeta contains multiple data, each of them belongs to a specific FieldType.
  208. async fn get_type_option_data(field_rev: &FieldRevision, field_type: &FieldType) -> FlowyResult<Vec<u8>> {
  209. let s = field_rev.get_type_option_str(field_type).unwrap_or_else(|| {
  210. default_type_option_builder_from_type(field_type)
  211. .data_format()
  212. .json_str()
  213. });
  214. let field_type: FieldType = field_rev.ty.into();
  215. let builder = type_option_builder_from_json_str(&s, &field_type);
  216. let type_option_data = builder.data_format().protobuf_bytes().to_vec();
  217. Ok(type_option_data)
  218. }
  219. // #[tracing::instrument(level = "debug", skip(data, manager), err)]
  220. pub(crate) async fn get_row_handler(
  221. data: Data<RowIdPB>,
  222. manager: AppData<Arc<GridManager>>,
  223. ) -> DataResult<OptionalRowPB, FlowyError> {
  224. let params: RowIdParams = data.into_inner().try_into()?;
  225. let editor = manager.get_grid_editor(&params.grid_id)?;
  226. let row = editor.get_row_rev(&params.row_id).await?.map(make_row_from_row_rev);
  227. data_result(OptionalRowPB { row })
  228. }
  229. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  230. pub(crate) async fn delete_row_handler(
  231. data: Data<RowIdPB>,
  232. manager: AppData<Arc<GridManager>>,
  233. ) -> Result<(), FlowyError> {
  234. let params: RowIdParams = data.into_inner().try_into()?;
  235. let editor = manager.get_grid_editor(&params.grid_id)?;
  236. let _ = editor.delete_row(&params.row_id).await?;
  237. Ok(())
  238. }
  239. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  240. pub(crate) async fn duplicate_row_handler(
  241. data: Data<RowIdPB>,
  242. manager: AppData<Arc<GridManager>>,
  243. ) -> Result<(), FlowyError> {
  244. let params: RowIdParams = data.into_inner().try_into()?;
  245. let editor = manager.get_grid_editor(&params.grid_id)?;
  246. let _ = editor.duplicate_row(&params.row_id).await?;
  247. Ok(())
  248. }
  249. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  250. pub(crate) async fn move_row_handler(
  251. data: Data<MoveRowPayloadPB>,
  252. manager: AppData<Arc<GridManager>>,
  253. ) -> Result<(), FlowyError> {
  254. let params: MoveRowParams = data.into_inner().try_into()?;
  255. let editor = manager.get_grid_editor(&params.view_id)?;
  256. let _ = editor.move_row(params).await?;
  257. Ok(())
  258. }
  259. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  260. pub(crate) async fn create_table_row_handler(
  261. data: Data<CreateTableRowPayloadPB>,
  262. manager: AppData<Arc<GridManager>>,
  263. ) -> DataResult<RowPB, FlowyError> {
  264. let params: CreateRowParams = data.into_inner().try_into()?;
  265. let editor = manager.get_grid_editor(params.grid_id.as_ref())?;
  266. let row = editor.create_row(params).await?;
  267. data_result(row)
  268. }
  269. #[tracing::instrument(level = "trace", skip_all, err)]
  270. pub(crate) async fn get_cell_handler(
  271. data: Data<GridCellIdPB>,
  272. manager: AppData<Arc<GridManager>>,
  273. ) -> DataResult<GridCellPB, FlowyError> {
  274. let params: GridCellIdParams = data.into_inner().try_into()?;
  275. let editor = manager.get_grid_editor(&params.grid_id)?;
  276. match editor.get_cell(&params).await {
  277. None => data_result(GridCellPB::empty(&params.field_id)),
  278. Some(cell) => data_result(cell),
  279. }
  280. }
  281. #[tracing::instrument(level = "trace", skip_all, err)]
  282. pub(crate) async fn update_cell_handler(
  283. data: Data<CellChangesetPB>,
  284. manager: AppData<Arc<GridManager>>,
  285. ) -> Result<(), FlowyError> {
  286. let changeset: CellChangesetPB = data.into_inner();
  287. let editor = manager.get_grid_editor(&changeset.grid_id)?;
  288. let _ = editor.update_cell(changeset).await?;
  289. Ok(())
  290. }
  291. #[tracing::instrument(level = "trace", skip_all, err)]
  292. pub(crate) async fn new_select_option_handler(
  293. data: Data<CreateSelectOptionPayloadPB>,
  294. manager: AppData<Arc<GridManager>>,
  295. ) -> DataResult<SelectOptionPB, FlowyError> {
  296. let params: CreateSelectOptionParams = data.into_inner().try_into()?;
  297. let editor = manager.get_grid_editor(&params.grid_id)?;
  298. match editor.get_field_rev(&params.field_id).await {
  299. None => Err(ErrorCode::InvalidData.into()),
  300. Some(field_rev) => {
  301. let type_option = select_option_operation(&field_rev)?;
  302. let select_option = type_option.create_option(&params.option_name);
  303. data_result(select_option)
  304. }
  305. }
  306. }
  307. #[tracing::instrument(level = "trace", skip_all, err)]
  308. pub(crate) async fn update_select_option_handler(
  309. data: Data<SelectOptionChangesetPayloadPB>,
  310. manager: AppData<Arc<GridManager>>,
  311. ) -> Result<(), FlowyError> {
  312. let changeset: SelectOptionChangeset = data.into_inner().try_into()?;
  313. let editor = manager.get_grid_editor(&changeset.cell_identifier.grid_id)?;
  314. if let Some(mut field_rev) = editor.get_field_rev(&changeset.cell_identifier.field_id).await {
  315. let mut_field_rev = Arc::make_mut(&mut field_rev);
  316. let mut type_option = select_option_operation(mut_field_rev)?;
  317. let mut cell_content_changeset = None;
  318. if let Some(option) = changeset.insert_option {
  319. cell_content_changeset = Some(SelectOptionCellChangeset::from_insert(&option.id).to_str());
  320. type_option.insert_option(option);
  321. }
  322. if let Some(option) = changeset.update_option {
  323. type_option.insert_option(option);
  324. }
  325. if let Some(option) = changeset.delete_option {
  326. cell_content_changeset = Some(SelectOptionCellChangeset::from_delete(&option.id).to_str());
  327. type_option.delete_option(option);
  328. }
  329. mut_field_rev.insert_type_option(&*type_option);
  330. let _ = editor.replace_field(field_rev).await?;
  331. if let Some(cell_content_changeset) = cell_content_changeset {
  332. let changeset = CellChangesetPB {
  333. grid_id: changeset.cell_identifier.grid_id,
  334. row_id: changeset.cell_identifier.row_id,
  335. field_id: changeset.cell_identifier.field_id,
  336. content: cell_content_changeset,
  337. };
  338. let _ = editor.update_cell(changeset).await?;
  339. }
  340. }
  341. Ok(())
  342. }
  343. #[tracing::instrument(level = "trace", skip(data, manager), err)]
  344. pub(crate) async fn get_select_option_handler(
  345. data: Data<GridCellIdPB>,
  346. manager: AppData<Arc<GridManager>>,
  347. ) -> DataResult<SelectOptionCellDataPB, FlowyError> {
  348. let params: GridCellIdParams = data.into_inner().try_into()?;
  349. let editor = manager.get_grid_editor(&params.grid_id)?;
  350. match editor.get_field_rev(&params.field_id).await {
  351. None => {
  352. tracing::error!("Can't find the select option field with id: {}", params.field_id);
  353. data_result(SelectOptionCellDataPB::default())
  354. }
  355. Some(field_rev) => {
  356. //
  357. let cell_rev = editor.get_cell_rev(&params.row_id, &params.field_id).await?;
  358. let type_option = select_option_operation(&field_rev)?;
  359. let any_cell_data: AnyCellData = match cell_rev {
  360. None => AnyCellData {
  361. data: "".to_string(),
  362. field_type: field_rev.ty.into(),
  363. },
  364. Some(cell_rev) => cell_rev.try_into()?,
  365. };
  366. let option_context = type_option.selected_select_option(any_cell_data.into());
  367. data_result(option_context)
  368. }
  369. }
  370. }
  371. #[tracing::instrument(level = "trace", skip_all, err)]
  372. pub(crate) async fn update_select_option_cell_handler(
  373. data: Data<SelectOptionCellChangesetPayloadPB>,
  374. manager: AppData<Arc<GridManager>>,
  375. ) -> Result<(), FlowyError> {
  376. let params: SelectOptionCellChangesetParams = data.into_inner().try_into()?;
  377. let editor = manager.get_grid_editor(&params.cell_identifier.grid_id)?;
  378. let _ = editor.update_cell(params.into()).await?;
  379. Ok(())
  380. }
  381. #[tracing::instrument(level = "trace", skip_all, err)]
  382. pub(crate) async fn update_date_cell_handler(
  383. data: Data<DateChangesetPayloadPB>,
  384. manager: AppData<Arc<GridManager>>,
  385. ) -> Result<(), FlowyError> {
  386. let params: DateChangesetParams = data.into_inner().try_into()?;
  387. let editor = manager.get_grid_editor(&params.cell_identifier.grid_id)?;
  388. let _ = editor.update_cell(params.into()).await?;
  389. Ok(())
  390. }
  391. #[tracing::instrument(level = "trace", skip_all, err)]
  392. pub(crate) async fn get_groups_handler(
  393. data: Data<GridIdPB>,
  394. manager: AppData<Arc<GridManager>>,
  395. ) -> DataResult<RepeatedGridGroupPB, FlowyError> {
  396. let params: GridIdPB = data.into_inner();
  397. let editor = manager.get_grid_editor(&params.value)?;
  398. let group = editor.load_groups().await?;
  399. data_result(group)
  400. }
  401. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  402. pub(crate) async fn create_board_card_handler(
  403. data: Data<CreateBoardCardPayloadPB>,
  404. manager: AppData<Arc<GridManager>>,
  405. ) -> DataResult<RowPB, FlowyError> {
  406. let params: CreateRowParams = data.into_inner().try_into()?;
  407. let editor = manager.get_grid_editor(params.grid_id.as_ref())?;
  408. let row = editor.create_row(params).await?;
  409. data_result(row)
  410. }
  411. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  412. pub(crate) async fn move_group_handler(
  413. data: Data<MoveGroupPayloadPB>,
  414. manager: AppData<Arc<GridManager>>,
  415. ) -> FlowyResult<()> {
  416. let params: MoveGroupParams = data.into_inner().try_into()?;
  417. let editor = manager.get_grid_editor(params.view_id.as_ref())?;
  418. let _ = editor.move_group(params).await?;
  419. Ok(())
  420. }
  421. #[tracing::instrument(level = "debug", skip(data, manager), err)]
  422. pub(crate) async fn move_group_row_handler(
  423. data: Data<MoveGroupRowPayloadPB>,
  424. manager: AppData<Arc<GridManager>>,
  425. ) -> FlowyResult<()> {
  426. let params: MoveGroupRowParams = data.into_inner().try_into()?;
  427. let editor = manager.get_grid_editor(params.view_id.as_ref())?;
  428. let _ = editor.move_group_row(params).await?;
  429. Ok(())
  430. }