use nohash_hasher::IntSet;
use re_log_types::EntityPath;
use re_types::ViewClassIdentifier;
use re_viewer_context::ViewerContext;
use crate::{view_kind::SpatialViewKind, visualizers::SpatialViewVisualizerData};
pub fn default_visualized_entities_for_visualizer_kind(
ctx: &ViewerContext<'_>,
view_class_identifier: ViewClassIdentifier,
visualizer_kind: SpatialViewKind,
) -> IntSet<EntityPath> {
re_tracing::profile_function!();
ctx.view_class_registry
.new_visualizer_collection(view_class_identifier)
.iter_with_identifiers()
.filter_map(|(id, visualizer)| {
let data = visualizer
.data()?
.downcast_ref::<SpatialViewVisualizerData>()?;
if data.preferred_view_kind == Some(visualizer_kind) {
let indicator_matching = ctx.indicated_entities_per_visualizer.get(&id)?;
let applicable = ctx.applicable_entities_per_visualizer.get(&id)?;
Some(indicator_matching.intersection(applicable))
} else {
None
}
})
.flatten()
.cloned()
.collect()
}