grid_setting_rev.rs 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. use crate::revision::{FieldRevision, FieldTypeRevision};
  2. use indexmap::IndexMap;
  3. use nanoid::nanoid;
  4. use serde::{Deserialize, Serialize};
  5. use serde_repr::*;
  6. use std::collections::HashMap;
  7. use std::sync::Arc;
  8. pub fn gen_grid_filter_id() -> String {
  9. nanoid!(6)
  10. }
  11. pub fn gen_grid_group_id() -> String {
  12. nanoid!(6)
  13. }
  14. pub fn gen_grid_sort_id() -> String {
  15. nanoid!(6)
  16. }
  17. /// Each layout contains multiple key/value.
  18. /// Key: field_id
  19. /// Value: this value also contains key/value.
  20. /// Key: FieldType,
  21. /// Value: the corresponding filter.
  22. ///
  23. /// This overall struct is described below:
  24. /// GridSettingRevision
  25. /// layout:
  26. /// field_id:
  27. /// FieldType: GridFilterRevision
  28. /// FieldType: GridFilterRevision
  29. /// field_id:
  30. /// FieldType: GridFilterRevision
  31. /// FieldType: GridFilterRevision
  32. /// layout:
  33. /// field_id:
  34. /// FieldType: GridFilterRevision
  35. /// FieldType: GridFilterRevision
  36. ///
  37. /// Group and sorts will be the same structure as filters.
  38. #[derive(Debug, Clone, Serialize, Deserialize, Default, Eq, PartialEq)]
  39. pub struct GridSettingRevision {
  40. pub layout: GridLayoutRevision,
  41. #[serde(with = "indexmap::serde_seq")]
  42. filters: IndexMap<GridLayoutRevision, IndexMap<String, GridFilterRevisionMap>>,
  43. #[serde(skip, with = "indexmap::serde_seq")]
  44. pub groups: IndexMap<GridLayoutRevision, Vec<GridGroupRevision>>,
  45. #[serde(skip, with = "indexmap::serde_seq")]
  46. pub sorts: IndexMap<GridLayoutRevision, Vec<GridSortRevision>>,
  47. }
  48. pub type FiltersByFieldId = HashMap<String, Vec<Arc<GridFilterRevision>>>;
  49. pub type GroupsByFieldId = HashMap<String, Vec<Arc<GridGroupRevision>>>;
  50. pub type SortsByFieldId = HashMap<String, Vec<Arc<GridSortRevision>>>;
  51. impl GridSettingRevision {
  52. pub fn get_all_group(&self) -> Option<GroupsByFieldId> {
  53. None
  54. }
  55. pub fn get_all_sort(&self) -> Option<SortsByFieldId> {
  56. None
  57. }
  58. /// Return the Filters of the current layout
  59. pub fn get_all_filter(&self, field_revs: &[Arc<FieldRevision>]) -> Option<FiltersByFieldId> {
  60. let layout = &self.layout;
  61. // Acquire the read lock of the filters.
  62. let filter_rev_map_by_field_id = self.filters.get(layout)?;
  63. // Get the filters according to the FieldType, so we need iterate the field_revs.
  64. let filters_by_field_id = field_revs
  65. .iter()
  66. .flat_map(|field_rev| {
  67. let field_type = &field_rev.field_type_rev;
  68. let field_id = &field_rev.id;
  69. let filter_rev_map: &GridFilterRevisionMap = filter_rev_map_by_field_id.get(field_id)?;
  70. let filters: Vec<Arc<GridFilterRevision>> = filter_rev_map.get(field_type)?.clone();
  71. Some((field_rev.id.clone(), filters))
  72. })
  73. .collect::<FiltersByFieldId>();
  74. Some(filters_by_field_id)
  75. }
  76. #[allow(dead_code)]
  77. fn get_filter_rev_map(&self, layout: &GridLayoutRevision, field_id: &str) -> Option<&GridFilterRevisionMap> {
  78. let filter_rev_map_by_field_id = self.filters.get(layout)?;
  79. filter_rev_map_by_field_id.get(field_id)
  80. }
  81. pub fn get_mut_filters(
  82. &mut self,
  83. layout: &GridLayoutRevision,
  84. field_id: &str,
  85. field_type: &FieldTypeRevision,
  86. ) -> Option<&mut Vec<Arc<GridFilterRevision>>> {
  87. self.filters
  88. .get_mut(layout)
  89. .and_then(|filter_rev_map_by_field_id| filter_rev_map_by_field_id.get_mut(field_id))
  90. .and_then(|filter_rev_map| filter_rev_map.get_mut(field_type))
  91. }
  92. pub fn get_filters(
  93. &self,
  94. layout: &GridLayoutRevision,
  95. field_id: &str,
  96. field_type_rev: &FieldTypeRevision,
  97. ) -> Option<Vec<Arc<GridFilterRevision>>> {
  98. self.filters
  99. .get(layout)
  100. .and_then(|filter_rev_map_by_field_id| filter_rev_map_by_field_id.get(field_id))
  101. .and_then(|filter_rev_map| filter_rev_map.get(field_type_rev))
  102. .cloned()
  103. }
  104. pub fn insert_filter(
  105. &mut self,
  106. layout: &GridLayoutRevision,
  107. field_id: &str,
  108. field_type: &FieldTypeRevision,
  109. filter_rev: GridFilterRevision,
  110. ) {
  111. let filter_rev_map_by_field_id = self.filters.entry(layout.clone()).or_insert_with(IndexMap::new);
  112. let filter_rev_map = filter_rev_map_by_field_id
  113. .entry(field_id.to_string())
  114. .or_insert_with(GridFilterRevisionMap::new);
  115. filter_rev_map
  116. .entry(field_type.to_owned())
  117. .or_insert_with(Vec::new)
  118. .push(Arc::new(filter_rev))
  119. }
  120. }
  121. #[derive(Debug, Clone, Serialize, Deserialize, Default, Eq, PartialEq)]
  122. #[serde(transparent)]
  123. pub struct GridFilterRevisionMap {
  124. #[serde(with = "indexmap::serde_seq")]
  125. pub filter_by_field_type: IndexMap<FieldTypeRevision, Vec<Arc<GridFilterRevision>>>,
  126. }
  127. impl GridFilterRevisionMap {
  128. pub fn new() -> Self {
  129. GridFilterRevisionMap::default()
  130. }
  131. }
  132. impl std::ops::Deref for GridFilterRevisionMap {
  133. type Target = IndexMap<FieldTypeRevision, Vec<Arc<GridFilterRevision>>>;
  134. fn deref(&self) -> &Self::Target {
  135. &self.filter_by_field_type
  136. }
  137. }
  138. impl std::ops::DerefMut for GridFilterRevisionMap {
  139. fn deref_mut(&mut self) -> &mut Self::Target {
  140. &mut self.filter_by_field_type
  141. }
  142. }
  143. #[derive(Debug, PartialEq, Eq, Hash, Clone, Serialize_repr, Deserialize_repr)]
  144. #[repr(u8)]
  145. pub enum GridLayoutRevision {
  146. Table = 0,
  147. Board = 1,
  148. }
  149. impl ToString for GridLayoutRevision {
  150. fn to_string(&self) -> String {
  151. let layout_rev = self.clone() as u8;
  152. layout_rev.to_string()
  153. }
  154. }
  155. impl std::default::Default for GridLayoutRevision {
  156. fn default() -> Self {
  157. GridLayoutRevision::Table
  158. }
  159. }
  160. #[derive(Debug, Clone, Serialize, Deserialize, Default, PartialEq, Eq, Hash)]
  161. pub struct GridFilterRevision {
  162. pub id: String,
  163. pub field_id: String,
  164. pub condition: u8,
  165. pub content: Option<String>,
  166. }
  167. #[derive(Debug, Clone, Serialize, Deserialize, Default, PartialEq, Eq)]
  168. pub struct GridGroupRevision {
  169. pub id: String,
  170. pub field_id: Option<String>,
  171. pub sub_field_id: Option<String>,
  172. }
  173. #[derive(Debug, Clone, Serialize, Deserialize, Default, PartialEq, Eq)]
  174. pub struct GridSortRevision {
  175. pub id: String,
  176. pub field_id: Option<String>,
  177. }