Merge branch 'master' of ggriffiniii/i3xs into master
This commit is contained in:
commit
4d150ac985
@ -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(),
|
||||||
|
|||||||
@ -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(),
|
||||||
|
|||||||
@ -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),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user