Group enum, Copy RenderConfig

This commit is contained in:
Csaba
2024-11-07 09:38:19 +01:00
parent 6a91dd46cd
commit 80f0214e47
3 changed files with 19 additions and 13 deletions

View File

@@ -1,3 +1,4 @@
use crate::config::Group;
use crate::config::KomobarConfig;
use crate::config::KomobarTheme;
use crate::config::Position;
@@ -317,7 +318,12 @@ impl Komobar {
) -> Self {
let mut komobar = Self {
config: config.clone(),
render_config: RenderConfig::from(config.clone()),
render_config: RenderConfig {
_group: match config.group {
None => Group::None,
Some(group) => group,
},
},
komorebi_notification_state: None,
left_widgets: vec![],
right_widgets: vec![],
@@ -440,13 +446,13 @@ impl eframe::App for Komobar {
ui.horizontal_centered(|ui| {
ui.with_layout(Layout::left_to_right(Align::Center), |ui| {
for w in &mut self.left_widgets {
w.render(ctx, ui, self.render_config.clone());
w.render(ctx, ui, self.render_config);
}
});
ui.with_layout(Layout::right_to_left(Align::Center), |ui| {
for w in &mut self.right_widgets {
w.render(ctx, ui, self.render_config.clone());
w.render(ctx, ui, self.render_config);
}
})
})

View File

@@ -28,6 +28,8 @@ pub struct KomobarConfig {
pub max_label_width: Option<f32>,
/// Theme
pub theme: Option<KomobarTheme>,
/// Visual grouping for widgets
pub group: Option<Group>,
/// Left side widgets (ordered left-to-right)
pub left_widgets: Vec<WidgetConfig>,
/// Right side widgets (ordered left-to-right)
@@ -178,3 +180,8 @@ pub enum LabelPrefix {
/// Show an icon and text
IconAndText,
}
#[derive(Copy, Clone, Debug, Serialize, Deserialize, JsonSchema)]
pub enum Group {
None
}

View File

@@ -1,6 +1,6 @@
use crate::battery::Battery;
use crate::battery::BatteryConfig;
use crate::config::KomobarConfig;
use crate::config::Group;
use crate::cpu::Cpu;
use crate::cpu::CpuConfig;
use crate::date::Date;
@@ -22,22 +22,15 @@ use eframe::egui::Ui;
use schemars::JsonSchema;
use serde::Deserialize;
use serde::Serialize;
use std::sync::Arc;
pub trait BarWidget {
fn render(&mut self, ctx: &Context, ui: &mut Ui, config: RenderConfig);
}
#[derive(Clone)]
#[derive(Copy, Clone)]
pub struct RenderConfig {
/// Sets how widgets are grouped
_group: i32,
}
impl RenderConfig {
pub fn from(_config: Arc<KomobarConfig>) -> Self {
Self { _group: 1 }
}
pub _group: Group,
}
#[derive(Clone, Debug, Serialize, Deserialize, JsonSchema)]