calendar_mock_data.rs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. use crate::database::database_editor::TestRowBuilder;
  2. use collab_database::database::{gen_database_id, gen_database_view_id, DatabaseData};
  3. use collab_database::views::{DatabaseLayout, DatabaseView, LayoutSetting, LayoutSettings};
  4. use flowy_database2::entities::FieldType;
  5. use flowy_database2::services::field::{FieldBuilder, MultiSelectTypeOption};
  6. use flowy_database2::services::setting::CalendarLayoutSetting;
  7. use strum::IntoEnumIterator;
  8. // Calendar unit test mock data
  9. pub fn make_test_calendar() -> DatabaseData {
  10. let mut fields = vec![];
  11. let mut rows = vec![];
  12. // text
  13. let text_field = FieldBuilder::from_field_type(FieldType::RichText)
  14. .name("Name")
  15. .visibility(true)
  16. .primary(true)
  17. .build();
  18. fields.push(text_field);
  19. // date
  20. let date_field = FieldBuilder::from_field_type(FieldType::DateTime)
  21. .name("Date")
  22. .visibility(true)
  23. .build();
  24. let date_field_id = date_field.id.clone();
  25. fields.push(date_field);
  26. // multi select
  27. let type_option = MultiSelectTypeOption::default();
  28. let multi_select_field = FieldBuilder::new(FieldType::MultiSelect, type_option)
  29. .name("Tags")
  30. .visibility(true)
  31. .build();
  32. fields.push(multi_select_field);
  33. let calendar_setting: LayoutSetting = CalendarLayoutSetting::new(date_field_id).into();
  34. for i in 0..5 {
  35. let mut row_builder = TestRowBuilder::new(i.into(), fields.clone());
  36. match i {
  37. 0 => {
  38. for field_type in FieldType::iter() {
  39. match field_type {
  40. FieldType::RichText => row_builder.insert_text_cell("A"),
  41. FieldType::DateTime => row_builder.insert_date_cell("1678090778"),
  42. _ => "".to_owned(),
  43. };
  44. }
  45. },
  46. 1 => {
  47. for field_type in FieldType::iter() {
  48. match field_type {
  49. FieldType::RichText => row_builder.insert_text_cell("B"),
  50. FieldType::DateTime => row_builder.insert_date_cell("1677917978"),
  51. _ => "".to_owned(),
  52. };
  53. }
  54. },
  55. 2 => {
  56. for field_type in FieldType::iter() {
  57. match field_type {
  58. FieldType::RichText => row_builder.insert_text_cell("C"),
  59. FieldType::DateTime => row_builder.insert_date_cell("1679213978"),
  60. _ => "".to_owned(),
  61. };
  62. }
  63. },
  64. 3 => {
  65. for field_type in FieldType::iter() {
  66. match field_type {
  67. FieldType::RichText => row_builder.insert_text_cell("D"),
  68. FieldType::DateTime => row_builder.insert_date_cell("1678695578"),
  69. _ => "".to_owned(),
  70. };
  71. }
  72. },
  73. 4 => {
  74. for field_type in FieldType::iter() {
  75. match field_type {
  76. FieldType::RichText => row_builder.insert_text_cell("E"),
  77. FieldType::DateTime => row_builder.insert_date_cell("1678695578"),
  78. _ => "".to_owned(),
  79. };
  80. }
  81. },
  82. _ => {},
  83. }
  84. let row = row_builder.build();
  85. rows.push(row);
  86. }
  87. let mut layout_settings = LayoutSettings::new();
  88. layout_settings.insert(DatabaseLayout::Calendar, calendar_setting);
  89. let view = DatabaseView {
  90. id: gen_database_view_id(),
  91. database_id: gen_database_id(),
  92. name: "".to_string(),
  93. layout: DatabaseLayout::Calendar,
  94. layout_settings,
  95. filters: vec![],
  96. group_settings: vec![],
  97. sorts: vec![],
  98. row_orders: vec![],
  99. field_orders: vec![],
  100. created_at: 0,
  101. modified_at: 0,
  102. };
  103. DatabaseData { view, fields, rows }
  104. }