grid_editor.rs 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. #![allow(clippy::all)]
  2. #![allow(dead_code)]
  3. #![allow(unused_imports)]
  4. use bytes::Bytes;
  5. use flowy_grid::entities::*;
  6. use flowy_grid::services::field::SelectOption;
  7. use flowy_grid::services::field::*;
  8. use flowy_grid::services::grid_editor::{GridPadBuilder, GridRevisionEditor};
  9. use flowy_grid::services::row::{CreateRowRevisionPayload, RowRevisionBuilder};
  10. use flowy_grid::services::setting::GridSettingChangesetBuilder;
  11. use flowy_grid_data_model::revision::*;
  12. use flowy_revision::REVISION_WRITE_INTERVAL_IN_MILLIS;
  13. use flowy_sync::client_grid::GridBuilder;
  14. use flowy_sync::entities::grid::{
  15. CreateGridFilterParams, DeleteFilterParams, FieldChangesetParams, GridSettingChangesetParams,
  16. };
  17. use flowy_test::helper::ViewTest;
  18. use flowy_test::FlowySDKTest;
  19. use std::collections::HashMap;
  20. use std::sync::Arc;
  21. use std::time::Duration;
  22. use strum::EnumCount;
  23. use strum::IntoEnumIterator;
  24. use tokio::time::sleep;
  25. pub struct GridEditorTest {
  26. pub sdk: FlowySDKTest,
  27. pub grid_id: String,
  28. pub editor: Arc<GridRevisionEditor>,
  29. pub field_revs: Vec<Arc<FieldRevision>>,
  30. pub block_meta_revs: Vec<Arc<GridBlockMetaRevision>>,
  31. pub row_revs: Vec<Arc<RowRevision>>,
  32. pub field_count: usize,
  33. pub row_order_by_row_id: HashMap<String, RowInfo>,
  34. }
  35. impl GridEditorTest {
  36. pub async fn new() -> Self {
  37. let sdk = FlowySDKTest::default();
  38. let _ = sdk.init_user().await;
  39. let build_context = make_test_grid();
  40. let view_data: Bytes = build_context.into();
  41. let test = ViewTest::new_grid_view(&sdk, view_data.to_vec()).await;
  42. let editor = sdk.grid_manager.open_grid(&test.view.id).await.unwrap();
  43. let field_revs = editor.get_field_revs(None).await.unwrap();
  44. let block_meta_revs = editor.get_block_meta_revs().await.unwrap();
  45. let row_revs = editor.grid_block_snapshots(None).await.unwrap().pop().unwrap().row_revs;
  46. assert_eq!(block_meta_revs.len(), 1);
  47. // It seems like you should add the field in the make_test_grid() function.
  48. // Because we assert the initialize count of the fields is equal to FieldType::COUNT.
  49. assert_eq!(field_revs.len(), FieldType::COUNT);
  50. let grid_id = test.view.id;
  51. Self {
  52. sdk,
  53. grid_id,
  54. editor,
  55. field_revs,
  56. block_meta_revs,
  57. row_revs,
  58. field_count: FieldType::COUNT,
  59. row_order_by_row_id: HashMap::default(),
  60. }
  61. }
  62. pub async fn get_row_revs(&self) -> Vec<Arc<RowRevision>> {
  63. self.editor
  64. .grid_block_snapshots(None)
  65. .await
  66. .unwrap()
  67. .pop()
  68. .unwrap()
  69. .row_revs
  70. }
  71. pub async fn grid_filters(&self) -> Vec<GridFilter> {
  72. let layout_type = GridLayoutType::Table;
  73. self.editor.get_grid_filter(&layout_type).await.unwrap()
  74. }
  75. pub fn get_field_rev(&self, field_type: FieldType) -> &Arc<FieldRevision> {
  76. self.field_revs
  77. .iter()
  78. .filter(|field_rev| {
  79. let t_field_type: FieldType = field_rev.field_type_rev.into();
  80. t_field_type == field_type
  81. })
  82. .collect::<Vec<_>>()
  83. .pop()
  84. .unwrap()
  85. }
  86. pub fn block_id(&self) -> &str {
  87. &self.block_meta_revs.last().unwrap().block_id
  88. }
  89. }
  90. pub const GOOGLE: &str = "Google";
  91. pub const FACEBOOK: &str = "Facebook";
  92. pub const TWITTER: &str = "Twitter";
  93. pub const COMPLETED: &str = "Completed";
  94. pub const PLANNED: &str = "Planned";
  95. pub const PAUSED: &str = "Paused";
  96. // This grid is assumed to contain all the Fields.
  97. fn make_test_grid() -> BuildGridContext {
  98. let mut grid_builder = GridBuilder::new();
  99. // Iterate through the FieldType to create the corresponding Field.
  100. for field_type in FieldType::iter() {
  101. let field_type: FieldType = field_type;
  102. // The
  103. match field_type {
  104. FieldType::RichText => {
  105. let text_field = FieldBuilder::new(RichTextTypeOptionBuilder::default())
  106. .name("Name")
  107. .visibility(true)
  108. .build();
  109. grid_builder.add_field(text_field);
  110. }
  111. FieldType::Number => {
  112. // Number
  113. let number = NumberTypeOptionBuilder::default().set_format(NumberFormat::USD);
  114. let number_field = FieldBuilder::new(number).name("Price").visibility(true).build();
  115. grid_builder.add_field(number_field);
  116. }
  117. FieldType::DateTime => {
  118. // Date
  119. let date = DateTypeOptionBuilder::default()
  120. .date_format(DateFormat::US)
  121. .time_format(TimeFormat::TwentyFourHour);
  122. let date_field = FieldBuilder::new(date).name("Time").visibility(true).build();
  123. grid_builder.add_field(date_field);
  124. }
  125. FieldType::SingleSelect => {
  126. // Single Select
  127. let single_select = SingleSelectTypeOptionBuilder::default()
  128. .option(SelectOption::new(COMPLETED))
  129. .option(SelectOption::new(PLANNED))
  130. .option(SelectOption::new(PAUSED));
  131. let single_select_field = FieldBuilder::new(single_select).name("Status").visibility(true).build();
  132. grid_builder.add_field(single_select_field);
  133. }
  134. FieldType::MultiSelect => {
  135. // MultiSelect
  136. let multi_select = MultiSelectTypeOptionBuilder::default()
  137. .option(SelectOption::new(GOOGLE))
  138. .option(SelectOption::new(FACEBOOK))
  139. .option(SelectOption::new(TWITTER));
  140. let multi_select_field = FieldBuilder::new(multi_select)
  141. .name("Platform")
  142. .visibility(true)
  143. .build();
  144. grid_builder.add_field(multi_select_field);
  145. }
  146. FieldType::Checkbox => {
  147. // Checkbox
  148. let checkbox = CheckboxTypeOptionBuilder::default();
  149. let checkbox_field = FieldBuilder::new(checkbox).name("is done").visibility(true).build();
  150. grid_builder.add_field(checkbox_field);
  151. }
  152. FieldType::URL => {
  153. // URL
  154. let url = URLTypeOptionBuilder::default();
  155. let url_field = FieldBuilder::new(url).name("link").visibility(true).build();
  156. grid_builder.add_field(url_field);
  157. }
  158. }
  159. }
  160. // We have many assumptions base on the number of the rows, so do not change the number of the loop.
  161. for _i in 0..10 {
  162. for field_type in FieldType::iter() {
  163. let field_type: FieldType = field_type;
  164. // let mut row_builder = RowRevisionBuilder::new()
  165. match field_type {
  166. FieldType::RichText => {}
  167. FieldType::Number => {}
  168. FieldType::DateTime => {}
  169. FieldType::SingleSelect => {}
  170. FieldType::MultiSelect => {}
  171. FieldType::Checkbox => {}
  172. FieldType::URL => {}
  173. }
  174. }
  175. }
  176. // assert_eq!(row_revs.len(), 10);
  177. // .add_empty_row()
  178. // .add_empty_row()
  179. // .add_empty_row()
  180. grid_builder.build()
  181. }