row_loader.rs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. use crate::services::row::decode_cell_data;
  2. use flowy_error::FlowyResult;
  3. use flowy_grid_data_model::entities::{
  4. Cell, CellMeta, FieldMeta, GridBlock, GridBlockOrder, RepeatedGridBlock, Row, RowMeta, RowOrder,
  5. };
  6. use rayon::iter::{IntoParallelIterator, ParallelIterator};
  7. use std::borrow::Cow;
  8. use std::collections::HashMap;
  9. use std::sync::Arc;
  10. pub struct GridBlockSnapshot {
  11. pub(crate) block_id: String,
  12. pub row_metas: Vec<Arc<RowMeta>>,
  13. }
  14. pub(crate) fn group_row_orders(row_orders: Vec<RowOrder>) -> Vec<GridBlockOrder> {
  15. let mut map: HashMap<String, GridBlockOrder> = HashMap::new();
  16. row_orders.into_iter().for_each(|row_order| {
  17. // Memory Optimization: escape clone block_id
  18. let block_id = row_order.block_id.clone();
  19. map.entry(block_id)
  20. .or_insert_with(|| GridBlockOrder::new(&row_order.block_id))
  21. .row_orders
  22. .push(row_order);
  23. });
  24. map.into_values().collect::<Vec<_>>()
  25. }
  26. #[inline(always)]
  27. pub fn make_cell_by_field_id(
  28. field_map: &HashMap<&String, &FieldMeta>,
  29. field_id: String,
  30. cell_meta: CellMeta,
  31. ) -> Option<(String, Cell)> {
  32. let field_meta = field_map.get(&field_id)?;
  33. match decode_cell_data(cell_meta.data, field_meta) {
  34. Ok(content) => {
  35. let cell = Cell::new(&field_id, content);
  36. Some((field_id, cell))
  37. }
  38. Err(e) => {
  39. tracing::error!("{}", e);
  40. None
  41. }
  42. }
  43. }
  44. #[allow(dead_code)]
  45. pub fn make_cell(field_id: &str, field_meta: &FieldMeta, row_meta: &RowMeta) -> Option<Cell> {
  46. let cell_meta = row_meta.cells.get(field_id)?.clone();
  47. match decode_cell_data(cell_meta.data, field_meta) {
  48. Ok(content) => Some(Cell::new(field_id, content)),
  49. Err(e) => {
  50. tracing::error!("{}", e);
  51. None
  52. }
  53. }
  54. }
  55. pub(crate) fn make_row_orders_from_row_metas(row_metas: &[Arc<RowMeta>]) -> Vec<RowOrder> {
  56. row_metas.iter().map(RowOrder::from).collect::<Vec<_>>()
  57. }
  58. pub(crate) fn make_rows_from_row_metas(fields: &[FieldMeta], row_metas: &[Arc<RowMeta>]) -> Vec<Row> {
  59. let field_meta_map = fields
  60. .iter()
  61. .map(|field_meta| (&field_meta.id, field_meta))
  62. .collect::<HashMap<&String, &FieldMeta>>();
  63. let make_row = |row_meta: &Arc<RowMeta>| {
  64. let cell_by_field_id = row_meta
  65. .cells
  66. .clone()
  67. .into_par_iter()
  68. .flat_map(|(field_id, cell_meta)| make_cell_by_field_id(&field_meta_map, field_id, cell_meta))
  69. .collect::<HashMap<String, Cell>>();
  70. Row {
  71. id: row_meta.id.clone(),
  72. cell_by_field_id,
  73. height: row_meta.height,
  74. }
  75. };
  76. row_metas.iter().map(make_row).collect::<Vec<_>>()
  77. }
  78. pub(crate) fn make_grid_blocks(
  79. block_ids: Option<Vec<String>>,
  80. block_snapshots: Vec<GridBlockSnapshot>,
  81. ) -> FlowyResult<RepeatedGridBlock> {
  82. match block_ids {
  83. None => Ok(block_snapshots
  84. .into_iter()
  85. .map(|snapshot| {
  86. let row_orders = make_row_orders_from_row_metas(&snapshot.row_metas);
  87. GridBlock::new(&snapshot.block_id, row_orders)
  88. })
  89. .collect::<Vec<GridBlock>>()
  90. .into()),
  91. Some(block_ids) => {
  92. let block_meta_data_map: HashMap<&String, &Vec<Arc<RowMeta>>> = block_snapshots
  93. .iter()
  94. .map(|data| (&data.block_id, &data.row_metas))
  95. .collect();
  96. let mut grid_blocks = vec![];
  97. for block_id in block_ids {
  98. match block_meta_data_map.get(&block_id) {
  99. None => {}
  100. Some(row_metas) => {
  101. let row_orders = make_row_orders_from_row_metas(row_metas);
  102. grid_blocks.push(GridBlock::new(&block_id, row_orders));
  103. }
  104. }
  105. }
  106. Ok(grid_blocks.into())
  107. }
  108. }
  109. }