summaryrefslogtreecommitdiffstats
path: root/src/app/data_harvester/battery_harvester.rs
blob: 66e3c76b77813e126e6d0f6c334e726ff25eeaa4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
use battery::{
    units::{power::watt, ratio::percent, time::second},
    Battery, Manager,
};

#[derive(Debug, Clone)]
pub struct BatteryHarvest {
    pub charge_percent: f64,
    pub secs_until_full: Option<i64>,
    pub secs_until_empty: Option<i64>,
    pub power_consumption_rate_watts: f64,
    pub health_percent: f64,
}

pub fn refresh_batteries(manager: &Manager, batteries: &mut [Battery]) -> Vec<BatteryHarvest> {
    batteries
        .iter_mut()
        .filter_map(|battery| {
            if manager.refresh(battery).is_ok() {
                Some(BatteryHarvest {
                    secs_until_full: {
                        let optional_time = battery.time_to_full();
                        if let Some(time) = optional_time {
                            Some(f64::from(time.get::<second>()) as i64)
                        } else {
                            None
                        }
                    },
                    secs_until_empty: {
                        let optional_time = battery.time_to_empty();
                        if let Some(time) = optional_time {
                            Some(f64::from(time.get::<second>()) as i64)
                        } else {
                            None
                        }
                    },
                    charge_percent: f64::from(battery.state_of_charge().get::<percent>()),
                    power_consumption_rate_watts: f64::from(battery.energy_rate().get::<watt>()),
                    health_percent: f64::from(battery.state_of_health().get::<percent>()),
                })
            } else {
                None
            }
        })
        .collect::<Vec<_>>()
}