use serde::Deserialize;
use serde::de::Unexpected;
use serde::de;
use serde::Deserializer;
use zigbee2mqtt_types_base_types::LastSeen;
/// peq:3300-P [zigbee2mqtt link](https://www.zigbee2mqtt.io/devices/3300-P.html)
///
///
#[cfg_attr(feature = "debug", derive(Debug))]
#[cfg_attr(feature = "clone", derive(Clone))]
#[derive(Deserialize)]
pub struct Zigbee3300Dp {
///Remaining battery in %, can take up to 24 hours before reported.
pub battery: f64,
///Zigbee herdsman description: "Indicates if the battery of this device is almost empty"
///Boolean values can be an unintuitive way round: value_on = true and value_off = false, consider double checking Zigbee2MQTT to understand what they mean
pub battery_low: bool,
///Zigbee herdsman description: "Indicates if the contact is closed (= true) or open (= false)"
///Boolean values can be an unintuitive way round: value_on = false and value_off = true, consider double checking Zigbee2MQTT to understand what they mean
pub contact: bool,
///Link quality (signal strength)
pub linkquality: f64,
///Zigbee herdsman description: "Indicates whether the device is tampered"
///Boolean values can be an unintuitive way round: value_on = true and value_off = false, consider double checking Zigbee2MQTT to understand what they mean
pub tamper: bool,
///Measured temperature value
pub temperature: f64,
/// Optional last_seen type, set as a global zigbee2mqtt setting
pub last_seen: Option<LastSeen>,
/// Optional elapsed type
pub elapsed: Option<u64>,
}
#[cfg(all(feature = "last_seen_epoch", feature = "last_seen_iso_8601"))]
compile_error!{"Feature last_seen epoch and iso_8601 are mutually exclusive and cannot be enabled together.
This was done because it is a global setting in zigbee2mqtt and therefor can't see a reason both would be enabled.
If you have a any reason to have both ways enabled please submit an issue to https://gitlab.com/seam345/zigbee2mqtt-types/-/issues"}