2025-11-28 00:09:00 -07:00
|
|
|
use egui::Frame;
|
|
|
|
|
use egui_tiles::Tree;
|
|
|
|
|
|
|
|
|
|
use crate::app::{AppState, windows::WindowWrapper};
|
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 {
|
2025-11-28 00:09:00 -07:00
|
|
|
// tab: Tab,
|
|
|
|
|
state: AppState,
|
|
|
|
|
tree: Tree<WindowWrapper>,
|
2025-11-26 08:55:07 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
impl Default for TemplateApp {
|
|
|
|
|
fn default() -> Self {
|
2025-11-28 00:09:00 -07:00
|
|
|
// let mut tiles = egui_tiles::Tiles::default();
|
|
|
|
|
|
|
|
|
|
// let invis_1 = tiles.insert_pane(WindowWrapper {
|
|
|
|
|
// nr: 0,
|
|
|
|
|
// window: AppWindow::None,
|
|
|
|
|
// });
|
|
|
|
|
// let invis_2 = tiles.insert_pane(WindowWrapper {
|
|
|
|
|
// nr: 0,
|
|
|
|
|
// window: AppWindow::None,
|
|
|
|
|
// });
|
|
|
|
|
|
|
|
|
|
// tiles.set_visible(invis_1, false);
|
|
|
|
|
// tiles.set_visible(invis_2, false);
|
|
|
|
|
// let root = tiles.insert_horizontal_tile(vec![invis_1]);
|
|
|
|
|
|
2025-11-26 08:55:07 -07:00
|
|
|
Self {
|
2025-11-28 00:09:00 -07:00
|
|
|
state: AppState::default(),
|
|
|
|
|
tree: egui_tiles::Tree::new_horizontal("tree_root", Vec::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");
|
|
|
|
|
|
2025-11-28 00:09:00 -07:00
|
|
|
self.state.labels(&mut self.tree, ui);
|
2025-11-27 19:19:11 -07:00
|
|
|
});
|
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-28 00:09:00 -07:00
|
|
|
|
|
|
|
|
// ui.style
|
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-28 00:09:00 -07:00
|
|
|
egui::CentralPanel::default()
|
|
|
|
|
.frame(Frame::central_panel(&ctx.style()).inner_margin(0))
|
|
|
|
|
.show(ctx, |ui| self.tree.ui(&mut self.state, ui));
|
2025-11-26 08:55:07 -07:00
|
|
|
}
|
|
|
|
|
}
|