grid_editor.rs 11 KB

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