grim/src/gui/screens/accounts.rs

67 lines
2.2 KiB
Rust
Raw Normal View History

2023-04-27 01:28:55 +03:00
// Copyright 2023 The Grim Developers
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
use egui::Frame;
2023-05-04 20:09:26 +03:00
use crate::gui::app::is_dual_panel_mode;
use crate::gui::icons::{ARROW_CIRCLE_LEFT, GEAR_SIX, GLOBE};
2023-04-27 01:28:55 +03:00
use crate::gui::platform::PlatformCallbacks;
2023-04-27 02:05:16 +03:00
use crate::gui::screens::{Navigator, Screen, ScreenId};
use crate::gui::views::{DEFAULT_STROKE, TitlePanel, TitlePanelAction};
2023-04-27 01:28:55 +03:00
#[derive(Default)]
pub struct Accounts {}
2023-04-27 01:28:55 +03:00
impl Screen for Accounts {
fn id(&self) -> ScreenId {
ScreenId::Accounts
}
2023-05-04 20:09:26 +03:00
fn ui(&mut self,
ui: &mut egui::Ui,
frame: &mut eframe::Frame,
nav: &mut Navigator,
cb: &dyn PlatformCallbacks) {
let mut panel: TitlePanel = TitlePanel::new(nav)
.title(t!("accounts"))
2023-05-04 20:09:26 +03:00
.right_action(TitlePanelAction {
icon: GEAR_SIX.into(),
2023-05-04 20:09:26 +03:00
on_click: Box::new(|nav| {
//TODO: open settings
}),
});
2023-05-04 20:09:26 +03:00
if !is_dual_panel_mode(frame) {
panel = panel.left_action(TitlePanelAction {
icon: GLOBE.into(),
2023-05-04 20:09:26 +03:00
on_click: Box::new(|nav|{
nav.toggle_left_panel();
2023-05-04 20:09:26 +03:00
}),
2023-04-27 22:02:10 +03:00
});
}
panel.ui(ui);
2023-05-04 20:09:26 +03:00
egui::CentralPanel::default().frame(Frame {
stroke: DEFAULT_STROKE,
2023-05-04 20:09:26 +03:00
.. Default::default()
}).show_inside(ui, |ui| {
ui.label(format!("{}Here we go 10000 ツ", ARROW_CIRCLE_LEFT));
2023-05-04 20:09:26 +03:00
if ui.button("TEST").clicked() {
nav.to(ScreenId::Account)
};
if ui.button(format!("{}BACK ", ARROW_CIRCLE_LEFT)).clicked() {
2023-05-04 20:09:26 +03:00
nav.to(ScreenId::Account)
};
});
2023-04-27 01:28:55 +03:00
}
}