From 9c86b477fb149cd11356598f9756f024a3ece432 Mon Sep 17 00:00:00 2001 From: Elliott Slaughter Date: Tue, 27 Aug 2024 16:05:52 -0700 Subject: [PATCH] Add color to each field (#60) --- src/app.rs | 45 ++++++++++++++++++++++++++++++++------------- src/data.rs | 2 +- src/main.rs | 7 ++++++- src/merge_data.rs | 2 +- 4 files changed, 40 insertions(+), 16 deletions(-) diff --git a/src/app.rs b/src/app.rs index fea764e..3f599fd 100644 --- a/src/app.rs +++ b/src/app.rs @@ -744,9 +744,14 @@ impl Slot { if cx.debug { ui.label(format!("Item UID: {}", item_meta.item_uid.0)); } - for (field_id, field) in &item_meta.fields { + for (field_id, field, color) in &item_meta.fields { let name = config.field_schema.get_name(*field_id).unwrap(); - ui.label(format!("{}", FieldWithName(name, field))); + let text = format!("{}", FieldWithName(name, field)); + if let Some(color) = color { + ui.label(RichText::new(text).color(*color)); + } else { + ui.label(text); + } } ui.label("(Click to show details.)"); }); @@ -1266,7 +1271,7 @@ impl SearchState { let field = self.search_field; if field == self.title_field { self.is_string_match(&item.title) - } else if let Some((_, value)) = item.fields.iter().find(|(x, _)| *x == field) { + } else if let Some((_, value, _)) = item.fields.iter().find(|(x, _, _)| *x == field) { self.is_field_match(value) } else { false @@ -2339,16 +2344,25 @@ impl ProfApp { fn render_field_as_ui( field: &Field, + color: Option, mode: ItemLinkNavigationMode, ui: &mut egui::Ui, ) -> Option<(ItemLocator, Interval)> { let mut result = None; let label = |ui: &mut egui::Ui, v| { - ui.add(egui::Label::new(v).wrap(true)); + if let Some(color) = color { + ui.add(egui::Label::new(RichText::new(v).color(color)).wrap(true)); + } else { + ui.add(egui::Label::new(v).wrap(true)); + } }; let label_button = |ui: &mut egui::Ui, v, b| { label(ui, v); - ui.button(b).clicked() + if let Some(color) = color { + ui.button(RichText::new(b).color(color)).clicked() + } else { + ui.button(b).clicked() + } }; match field { Field::I64(value) => label(ui, &format!("{value}")), @@ -2376,7 +2390,7 @@ impl ProfApp { ui.vertical(|ui| { for f in fields { ui.horizontal(|ui| { - if let Some(x) = Self::render_field_as_ui(f, mode, ui) { + if let Some(x) = Self::render_field_as_ui(f, color, mode, ui) { result = Some(x); } }); @@ -2411,7 +2425,7 @@ impl ProfApp { .column(Column::auto()) .column(Column::remainder()) .body(|mut body| { - let mut show_row = |k: &str, field: &Field| { + let mut show_row = |k: &str, field: &Field, color: Option| { // We need to manually work out the height of the labels // so that the table knows how large to make each row. let width = body.widths()[1]; @@ -2422,10 +2436,15 @@ impl ProfApp { body.row(height, |mut row| { row.col(|ui| { - ui.strong(k); + if let Some(color) = color { + ui.label(RichText::new(k).color(color).strong()); + } else { + ui.strong(k); + } }); row.col(|ui| { - if let Some(x) = Self::render_field_as_ui(field, cx.item_link_mode, ui) + if let Some(x) = + Self::render_field_as_ui(field, color, cx.item_link_mode, ui) { result = Some(x); } @@ -2433,13 +2452,13 @@ impl ProfApp { }); }; - show_row("Title", &Field::String(item_meta.title.to_string())); + show_row("Title", &Field::String(item_meta.title.to_string()), None); if cx.debug { - show_row("Item UID", &Field::U64(item_meta.item_uid.0)); + show_row("Item UID", &Field::U64(item_meta.item_uid.0), None); } - for (field_id, field) in &item_meta.fields { + for (field_id, field, color) in &item_meta.fields { let name = field_schema.get_name(*field_id).unwrap(); - show_row(name, field); + show_row(name, field, *color); } }); ui.with_layout(egui::Layout::top_down(egui::Align::Center), |ui| { diff --git a/src/data.rs b/src/data.rs index a8843cf..f4e2587 100644 --- a/src/data.rs +++ b/src/data.rs @@ -160,7 +160,7 @@ pub struct ItemMeta { // entire duration of the original item, unexpanded and unsliced. pub original_interval: Interval, pub title: String, - pub fields: Vec<(FieldID, Field)>, + pub fields: Vec<(FieldID, Field, Option)>, } #[derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Deserialize, Serialize)] diff --git a/src/main.rs b/src/main.rs index ee6e6c2..e3f2e1c 100644 --- a/src/main.rs +++ b/src/main.rs @@ -216,8 +216,13 @@ impl RandomDataSource { ( self.interval_field, Field::Interval(Interval::new(start, stop)), + None, + ), + ( + self.item_uid_field, + Field::U64(item_uid.0), + Some(Color32::RED), ), - (self.item_uid_field, Field::U64(item_uid.0)), ], }); } diff --git a/src/merge_data.rs b/src/merge_data.rs index 4a26b6f..f7ae601 100644 --- a/src/merge_data.rs +++ b/src/merge_data.rs @@ -180,7 +180,7 @@ impl MergeDeferredDataSource { for items in &mut tile.data.items { for item in items { item.item_uid = self.map_src_to_dst_item_uid(idx, item.item_uid); - for (_, field) in &mut item.fields { + for (_, field, _) in &mut item.fields { self.map_src_to_dst_field(idx, field); } }