Merge branch 'master' of ggriffiniii/i3xs into master

This commit is contained in:
Bill Thiede 2019-10-03 18:19:51 +00:00 committed by Gitea
commit 4d150ac985
3 changed files with 53 additions and 58 deletions

View File

@ -25,8 +25,8 @@ fn main() {
// Realtime upload/download rate for a interface // Realtime upload/download rate for a interface
bar.push(NetworkSpeedWidget::new(&opts.nic, 6)); bar.push(NetworkSpeedWidget::new(&opts.nic, 6));
let mut dt = DateTimeWidget::new("%m/%d %H:%M".to_string()); let mut dt = DateTimeWidget::new("%m/%d %H:%M");
dt.set_colors(&vec![ dt.set_colors(vec![
TimeColor { TimeColor {
start: NaiveTime::from_hms(19, 0, 0), start: NaiveTime::from_hms(19, 0, 0),
color: ColorRGB::yellow(), color: ColorRGB::yellow(),

View File

@ -25,8 +25,8 @@ fn main() {
// Realtime upload/download rate for a interface // Realtime upload/download rate for a interface
bar.push(NetworkSpeedWidget::new(&opts.nic, 6)); bar.push(NetworkSpeedWidget::new(&opts.nic, 6));
let mut dt = DateTimeWidget::tz("%H:%M %Z".to_string(), "Europe/London".to_string()); let mut dt = DateTimeWidget::tz("%H:%M %Z", chrono_tz::Europe::London);
dt.set_colors(&vec![ dt.set_colors(vec![
TimeColor { TimeColor {
start: NaiveTime::from_hms(0, 0, 0), start: NaiveTime::from_hms(0, 0, 0),
color: ColorRGB::red(), color: ColorRGB::red(),
@ -46,8 +46,8 @@ fn main() {
]); ]);
bar.push(dt); bar.push(dt);
let mut dt = DateTimeWidget::new("%m/%d %H:%M".to_string()); let mut dt = DateTimeWidget::new("%m/%d %H:%M");
dt.set_colors(&vec![ dt.set_colors(vec![
TimeColor { TimeColor {
start: NaiveTime::from_hms(0, 0, 0), start: NaiveTime::from_hms(0, 0, 0),
color: ColorRGB::red(), color: ColorRGB::red(),

View File

@ -1,19 +1,17 @@
use chrono::NaiveTime; use chrono::{offset::TimeZone, Local, NaiveTime, Utc};
use chrono_tz::Tz; use std::fmt::Display;
use i3monkit::Block; use i3monkit::Block;
use i3monkit::ColorRGB; use i3monkit::ColorRGB;
use i3monkit::{Widget, WidgetUpdate}; use i3monkit::{Widget, WidgetUpdate};
/// The widget that shows local time /// The widget that shows local time
pub struct DateTimeWidget { pub struct DateTimeWidget<Tz> {
/// fmt to format the datetime, see /// fmt to format the datetime, see
/// https://docs.rs/chrono/*/chrono/format/strftime/index.html for documentation. /// https://docs.rs/chrono/*/chrono/format/strftime/index.html for documentation.
fmt: String, fmt: String,
/// tz string, values from https://docs.rs/chrono-tz/*/chrono_tz/ tz: Tz,
/// None will use local time. colors: Vec<TimeColor>,
tz: Option<String>,
colors: Option<Vec<TimeColor>>,
} }
#[derive(Clone)] #[derive(Clone)]
@ -22,66 +20,63 @@ pub struct TimeColor {
pub color: ColorRGB, pub color: ColorRGB,
} }
impl DateTimeWidget { impl DateTimeWidget<Local> {
// Create a new time widget pub fn new(fmt: impl Into<String>) -> Self {
pub fn new(fmt: String) -> Self { DateTimeWidget::tz(fmt, Local)
DateTimeWidget {
fmt,
tz: None,
colors: None,
}
}
pub fn tz(fmt: String, tz: String) -> Self {
DateTimeWidget {
fmt,
tz: Some(tz),
colors: None,
}
}
pub fn set_colors(&mut self, colors: &[TimeColor]) {
let mut colors = colors.to_vec();
colors.sort_by(|l, r| l.start.cmp(&r.start));
self.colors = Some(colors);
} }
} }
impl Widget for DateTimeWidget { impl<Tz> DateTimeWidget<Tz>
where
Tz: TimeZone,
Tz::Offset: Display,
{
pub fn tz(fmt: impl Into<String>, tz: Tz) -> Self {
DateTimeWidget {
fmt: fmt.into(),
tz,
colors: Vec::new(),
}
}
pub fn set_colors(&mut self, colors: impl Into<Vec<TimeColor>>) {
let mut colors = colors.into();
colors.sort_by(|l, r| l.start.cmp(&r.start));
self.colors = colors;
}
fn now(&self) -> chrono::DateTime<Tz> {
Utc::now().with_timezone(&self.tz)
}
}
impl<Tz> Widget for DateTimeWidget<Tz>
where
Tz: TimeZone,
Tz::Offset: Display,
{
fn update(&mut self) -> Option<WidgetUpdate> { fn update(&mut self) -> Option<WidgetUpdate> {
let (time, time_string) = match &self.tz { let now = self.now();
Some(tz) => {
let tz: Tz = tz.parse().unwrap();
let now = chrono::Local::now();
let now = now.with_timezone(&tz);
(now.time(), now.format(&self.fmt).to_string())
}
None => {
let now = chrono::Local::now();
(now.time(), now.format(&self.fmt).to_string())
}
};
let color = if let Some(colors) = &self.colors {
colors
.iter()
.filter(|tc| tc.start < time)
.last()
.map(|tc| tc.color.clone())
} else {
None
};
let time_string = format!( let time_string = format!(
r#"<span size="x-large" weight="heavy">{}</span>"#, r#"<span size="x-large" weight="heavy">{}</span>"#,
time_string now.format(&self.fmt)
); );
let mut data = Block::new() let mut data = Block::new()
.append_full_text(&time_string) .append_full_text(&time_string)
.use_pango() .use_pango()
.clone(); .clone();
if let Some(color) = color {
let time = now.time();
if let Some(color) = self
.colors
.iter()
.filter(|tc| tc.start < time)
.last()
.map(|tc| tc.color.clone())
{
data.color(color); data.color(color);
} }
Some(WidgetUpdate { Some(WidgetUpdate {
refresh_interval: std::time::Duration::new(1, 0), refresh_interval: std::time::Duration::from_secs(1),
data: Some(data), data: Some(data),
}) })
} }