From a6fa8add79f4d67ef1d4cb904eb0c0166c96b107 Mon Sep 17 00:00:00 2001 From: krolxon Date: Tue, 11 Jun 2024 21:49:35 +0530 Subject: add toggle mute keymap --- src/connection.rs | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'src/connection.rs') diff --git a/src/connection.rs b/src/connection.rs index c31c346..d3ff3a5 100755 --- a/src/connection.rs +++ b/src/connection.rs @@ -5,6 +5,12 @@ use mpd::{Client, State}; use simple_dmenu::dmenu; use std::time::Duration; +#[derive(Debug)] +pub enum VolumeStatus { + Muted(i8), + Unmuted, +} + #[derive(Debug)] /// struct storing the mpd Client related stuff pub struct Connection { @@ -16,6 +22,7 @@ pub struct Connection { pub current_song: Song, pub stats: mpd::Stats, pub status: mpd::Status, + pub volume_status: VolumeStatus, } impl Connection { @@ -41,6 +48,13 @@ impl Connection { .currentsong() .unwrap_or_else(|_| Some(empty_song.clone())) .unwrap_or(empty_song); + + let volume_status = if status.volume == 0 { + VolumeStatus::Muted(status.volume) + } else { + VolumeStatus::Unmuted + }; + Ok(Self { conn, songs_filenames, @@ -50,6 +64,7 @@ impl Connection { current_song, stats, status, + volume_status, }) } @@ -207,6 +222,7 @@ impl Connection { pub fn inc_volume(&mut self, v: i8) { let cur = self.status.volume; if cur + v <= 100 { + self.volume_status = VolumeStatus::Unmuted; self.conn.volume(cur + v).unwrap(); } } @@ -215,6 +231,7 @@ impl Connection { pub fn dec_volume(&mut self, v: i8) { let cur = self.status.volume; if cur - v >= 0 { + self.volume_status = VolumeStatus::Unmuted; self.conn.volume(cur - v).unwrap(); } } -- cgit v1.2.3