Files
unshell/unshell-gui/src/app.rs
T

108 lines
3.5 KiB
Rust
Raw Normal View History

2025-11-26 12:48:23 -07:00
use crate::{config::Config, flowchart::FlowChart};
2025-11-26 08:55:07 -07:00
/// We derive Deserialize/Serialize so we can persist app state on shutdown.
#[derive(serde::Deserialize, serde::Serialize)]
#[serde(default)] // if we add new fields, give them default values when deserializing old state
pub struct TemplateApp {
tab: Tab,
flowchart: FlowChart,
2025-11-26 12:48:23 -07:00
config: Config,
2025-11-26 08:55:07 -07:00
}
2025-11-26 12:48:23 -07:00
#[derive(serde::Deserialize, serde::Serialize, PartialEq, Eq)]
2025-11-26 08:55:07 -07:00
pub enum Tab {
Flowchart,
Test,
}
impl Default for TemplateApp {
fn default() -> Self {
Self {
tab: Tab::Flowchart,
// Example stuff:
// label: "Hello World!".to_owned(),
// value: 2.7,
flowchart: FlowChart::new(),
2025-11-26 12:48:23 -07:00
config: Config::new(),
2025-11-26 08:55:07 -07:00
}
}
}
impl TemplateApp {
/// Called once before the first frame.
2025-11-27 16:52:38 -07:00
pub fn new(_cc: &eframe::CreationContext<'_>) -> Self {
2025-11-26 08:55:07 -07:00
// This is also where you can customize the look and feel of egui using
// `cc.egui_ctx.set_visuals` and `cc.egui_ctx.set_fonts`.
// Load previous app state (if any).
// Note that you must enable the `persistence` feature for this to work.
2025-11-27 16:52:38 -07:00
// if let Some(storage) = cc.storage {
// eframe::get_value(storage, eframe::APP_KEY).unwrap_or_default()
// } else {
Default::default()
// }
2025-11-26 08:55:07 -07:00
}
}
impl eframe::App for TemplateApp {
/// Called by the framework to save state before shutdown.
fn save(&mut self, storage: &mut dyn eframe::Storage) {
eframe::set_value(storage, eframe::APP_KEY, self);
}
/// Called each time the UI needs repainting, which may be many times per second.
fn update(&mut self, ctx: &egui::Context, _frame: &mut eframe::Frame) {
// Put your widgets into a `SidePanel`, `TopBottomPanel`, `CentralPanel`, `Window` or `Area`.
// For inspiration and more examples, go to https://emilk.github.io/egui
egui::TopBottomPanel::top("tab_panel").show(ctx, |ui| {
// The top panel is often a good place for a menu bar:
2025-11-26 12:48:23 -07:00
egui::MenuBar::new().ui(ui, |ui| {
2025-11-27 19:19:11 -07:00
ui.menu_button("File", |ui| {
ui.label("File");
});
ui.menu_button("View", |ui| {
ui.label("View");
if ui
.selectable_label(self.tab == Tab::Flowchart, "Network")
.clicked()
{
self.tab = Tab::Flowchart;
}
if ui
.selectable_label(self.tab == Tab::Test, self.config.title())
.clicked()
{
self.tab = Tab::Test;
}
});
2025-11-26 08:55:07 -07:00
2025-11-26 12:48:23 -07:00
ui.with_layout(egui::Layout::right_to_left(egui::Align::Center), |ui| {
egui::widgets::global_theme_preference_switch(ui);
2025-11-26 08:55:07 -07:00
});
2025-11-26 12:48:23 -07:00
});
2025-11-26 08:55:07 -07:00
});
egui::TopBottomPanel::bottom("tab_panel").show(ctx, |ui| {
ui.with_layout(egui::Layout::right_to_left(egui::Align::Center), |ui| {
ui.label(format!("UnShell UI {}", env!("CARGO_PKG_VERSION")));
egui::warn_if_debug_build(ui);
});
});
2025-11-26 12:48:23 -07:00
egui::CentralPanel::default().show(ctx, |ui| match self.tab {
Tab::Flowchart => {
self.flowchart.paint(ui);
}
Tab::Test => {
self.config.update(ui);
2025-11-26 08:55:07 -07:00
}
});
}
}