123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 |
- use crate::{
- FieldRevision, FieldTypeRevision, FilterRevision, GroupConfigurationRevision, SortRevision,
- };
- use indexmap::IndexMap;
- use nanoid::nanoid;
- use serde::{Deserialize, Serialize};
- use std::fmt::Debug;
- use std::sync::Arc;
- pub fn gen_database_filter_id() -> String {
- nanoid!(6)
- }
- pub fn gen_database_group_id() -> String {
- nanoid!(6)
- }
- pub fn gen_database_sort_id() -> String {
- nanoid!(6)
- }
- pub type FilterConfiguration = Configuration<FilterRevision>;
- pub type GroupConfiguration = Configuration<GroupConfigurationRevision>;
- pub type SortConfiguration = Configuration<SortRevision>;
- #[derive(Debug, Clone, Serialize, Deserialize, Default)]
- #[serde(transparent)]
- pub struct Configuration<T>
- where
- T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
- {
- /// Key: field_id
- /// Value: this value contains key/value.
- /// Key: FieldType,
- /// Value: the corresponding objects.
- #[serde(with = "indexmap::serde_seq")]
- inner: IndexMap<String, ObjectIndexMap<T>>,
- }
- impl<T> Configuration<T>
- where
- T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
- {
- pub fn get_mut_objects(
- &mut self,
- field_id: &str,
- field_type: &FieldTypeRevision,
- ) -> Option<&mut Vec<Arc<T>>> {
- let value = self
- .inner
- .get_mut(field_id)
- .and_then(|object_map| object_map.get_mut(field_type));
- if value.is_none() {
- eprintln!(
- "[Configuration] Can't find the {:?} with",
- std::any::type_name::<T>()
- );
- }
- value
- }
- pub fn get_object(
- &self,
- field_id: &str,
- field_type: &FieldTypeRevision,
- predicate: impl Fn(&Arc<T>) -> bool,
- ) -> Option<Arc<T>> {
- let objects = self.get_objects(field_id, field_type)?;
- let index = objects.iter().position(predicate)?;
- objects.get(index).cloned()
- }
- pub fn get_mut_object(
- &mut self,
- field_id: &str,
- field_type: &FieldTypeRevision,
- predicate: impl Fn(&Arc<T>) -> bool,
- ) -> Option<&mut Arc<T>> {
- let objects = self.get_mut_objects(field_id, field_type)?;
- let index = objects.iter().position(predicate)?;
- objects.get_mut(index)
- }
- pub fn get_objects(
- &self,
- field_id: &str,
- field_type_rev: &FieldTypeRevision,
- ) -> Option<Vec<Arc<T>>> {
- self
- .inner
- .get(field_id)
- .and_then(|object_map| object_map.get(field_type_rev))
- .cloned()
- }
- pub fn get_objects_by_field_revs(&self, field_revs: &[Arc<FieldRevision>]) -> Vec<Arc<T>> {
- // Get the objects according to the FieldType, so we need iterate the field_revs.
- let objects = field_revs
- .iter()
- .flat_map(|field_rev| {
- let field_type = &field_rev.ty;
- let field_id = &field_rev.id;
- let object_rev_map = self.inner.get(field_id)?;
- let objects: Vec<Arc<T>> = object_rev_map.get(field_type)?.clone();
- Some(objects)
- })
- .flatten()
- .collect::<Vec<Arc<T>>>();
- objects
- }
- pub fn get_all_objects(&self) -> Vec<Arc<T>> {
- self
- .inner
- .values()
- .flat_map(|map| map.all_objects())
- .collect()
- }
- /// add object to the end of the list
- pub fn add_object(&mut self, field_id: &str, field_type: &FieldTypeRevision, object: T) {
- let object_rev_map = self
- .inner
- .entry(field_id.to_string())
- .or_insert_with(ObjectIndexMap::<T>::new);
- object_rev_map
- .entry(field_type.to_owned())
- .or_insert_with(Vec::new)
- .push(Arc::new(object))
- }
- pub fn clear(&mut self) {
- self.inner.clear()
- }
- }
- #[derive(Debug, Clone, Serialize, Deserialize, Default)]
- #[serde(transparent)]
- pub struct ObjectIndexMap<T>
- where
- T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
- {
- #[serde(with = "indexmap::serde_seq")]
- pub object_by_field_type: IndexMap<FieldTypeRevision, Vec<Arc<T>>>,
- }
- impl<T> ObjectIndexMap<T>
- where
- T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
- {
- pub fn new() -> Self {
- ObjectIndexMap::default()
- }
- pub fn all_objects(&self) -> Vec<Arc<T>> {
- self
- .object_by_field_type
- .values()
- .flatten()
- .cloned()
- .collect()
- }
- }
- impl<T> std::ops::Deref for ObjectIndexMap<T>
- where
- T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
- {
- type Target = IndexMap<FieldTypeRevision, Vec<Arc<T>>>;
- fn deref(&self) -> &Self::Target {
- &self.object_by_field_type
- }
- }
- impl<T> std::ops::DerefMut for ObjectIndexMap<T>
- where
- T: Debug + Clone + Default + serde::Serialize + serde::de::DeserializeOwned + 'static,
- {
- fn deref_mut(&mut self) -> &mut Self::Target {
- &mut self.object_by_field_type
- }
- }
|