grid_setting_rev.rs 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. use crate::{FieldRevision, FieldTypeRevision, FilterRevision, GroupConfigurationRevision, SortRevision};
  2. use indexmap::IndexMap;
  3. use nanoid::nanoid;
  4. use serde::{Deserialize, Serialize};
  5. use std::fmt::Debug;
  6. use std::sync::Arc;
  7. pub fn gen_grid_filter_id() -> String {
  8. nanoid!(6)
  9. }
  10. pub fn gen_grid_group_id() -> String {
  11. nanoid!(6)
  12. }
  13. #[allow(dead_code)]
  14. pub fn gen_grid_sort_id() -> String {
  15. nanoid!(6)
  16. }
  17. pub type FilterConfiguration = Configuration<FilterRevision>;
  18. pub type GroupConfiguration = Configuration<GroupConfigurationRevision>;
  19. pub type SortConfiguration = Configuration<SortRevision>;
  20. #[derive(Debug, Clone, Serialize, Deserialize, Default)]
  21. #[serde(transparent)]
  22. pub struct Configuration<T>
  23. where
  24. T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
  25. {
  26. /// Key: field_id
  27. /// Value: this value contains key/value.
  28. /// Key: FieldType,
  29. /// Value: the corresponding objects.
  30. #[serde(with = "indexmap::serde_seq")]
  31. inner: IndexMap<String, ObjectIndexMap<T>>,
  32. }
  33. impl<T> Configuration<T>
  34. where
  35. T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
  36. {
  37. pub fn get_mut_objects(&mut self, field_id: &str, field_type: &FieldTypeRevision) -> Option<&mut Vec<Arc<T>>> {
  38. let value = self
  39. .inner
  40. .get_mut(field_id)
  41. .and_then(|object_map| object_map.get_mut(field_type));
  42. if value.is_none() {
  43. eprintln!("[Configuration] Can't find the {:?} with", std::any::type_name::<T>());
  44. }
  45. value
  46. }
  47. pub fn get_object(
  48. &self,
  49. field_id: &str,
  50. field_type: &FieldTypeRevision,
  51. predicate: impl Fn(&Arc<T>) -> bool,
  52. ) -> Option<Arc<T>> {
  53. let objects = self.get_objects(field_id, field_type)?;
  54. let index = objects.iter().position(predicate)?;
  55. objects.get(index).cloned()
  56. }
  57. pub fn get_mut_object(
  58. &mut self,
  59. field_id: &str,
  60. field_type: &FieldTypeRevision,
  61. predicate: impl Fn(&Arc<T>) -> bool,
  62. ) -> Option<&mut Arc<T>> {
  63. let objects = self.get_mut_objects(field_id, field_type)?;
  64. let index = objects.iter().position(predicate)?;
  65. objects.get_mut(index)
  66. }
  67. pub fn get_objects(&self, field_id: &str, field_type_rev: &FieldTypeRevision) -> Option<Vec<Arc<T>>> {
  68. self.inner
  69. .get(field_id)
  70. .and_then(|object_map| object_map.get(field_type_rev))
  71. .cloned()
  72. }
  73. pub fn get_objects_by_field_revs(&self, field_revs: &[Arc<FieldRevision>]) -> Vec<Arc<T>> {
  74. // Get the objects according to the FieldType, so we need iterate the field_revs.
  75. let objects = field_revs
  76. .iter()
  77. .flat_map(|field_rev| {
  78. let field_type = &field_rev.ty;
  79. let field_id = &field_rev.id;
  80. let object_rev_map = self.inner.get(field_id)?;
  81. let objects: Vec<Arc<T>> = object_rev_map.get(field_type)?.clone();
  82. Some(objects)
  83. })
  84. .flatten()
  85. .collect::<Vec<Arc<T>>>();
  86. objects
  87. }
  88. pub fn get_all_objects(&self) -> Vec<Arc<T>> {
  89. self.inner.values().flat_map(|map| map.all_objects()).collect()
  90. }
  91. /// add object to the end of the list
  92. pub fn add_object(&mut self, field_id: &str, field_type: &FieldTypeRevision, object: T) {
  93. let object_rev_map = self
  94. .inner
  95. .entry(field_id.to_string())
  96. .or_insert_with(ObjectIndexMap::<T>::new);
  97. object_rev_map
  98. .entry(field_type.to_owned())
  99. .or_insert_with(Vec::new)
  100. .push(Arc::new(object))
  101. }
  102. pub fn clear(&mut self) {
  103. self.inner.clear()
  104. }
  105. }
  106. #[derive(Debug, Clone, Serialize, Deserialize, Default)]
  107. #[serde(transparent)]
  108. pub struct ObjectIndexMap<T>
  109. where
  110. T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
  111. {
  112. #[serde(with = "indexmap::serde_seq")]
  113. pub object_by_field_type: IndexMap<FieldTypeRevision, Vec<Arc<T>>>,
  114. }
  115. impl<T> ObjectIndexMap<T>
  116. where
  117. T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
  118. {
  119. pub fn new() -> Self {
  120. ObjectIndexMap::default()
  121. }
  122. pub fn all_objects(&self) -> Vec<Arc<T>> {
  123. self.object_by_field_type.values().flatten().cloned().collect()
  124. }
  125. }
  126. impl<T> std::ops::Deref for ObjectIndexMap<T>
  127. where
  128. T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
  129. {
  130. type Target = IndexMap<FieldTypeRevision, Vec<Arc<T>>>;
  131. fn deref(&self) -> &Self::Target {
  132. &self.object_by_field_type
  133. }
  134. }
  135. impl<T> std::ops::DerefMut for ObjectIndexMap<T>
  136. where
  137. T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
  138. {
  139. fn deref_mut(&mut self) -> &mut Self::Target {
  140. &mut self.object_by_field_type
  141. }
  142. }