use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
pub struct ContinuousLeg {
#[serde(rename = "start")]
pub start: Box<models::Place>,
#[serde(rename = "end")]
pub end: Box<models::Place>,
#[serde(rename = "service")]
pub service: Box<models::ContinuousService>,
#[serde(rename = "timeWindowStart", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub time_window_start: Option<Option<String>>,
#[serde(rename = "timeWindowEnd", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub time_window_end: Option<Option<String>>,
#[serde(rename = "duration", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub duration: Option<Option<String>>,
#[serde(rename = "situationFullRefs", skip_serializing_if = "Option::is_none")]
pub situation_full_refs: Option<Vec<String>>,
#[serde(rename = "co2Emission", skip_serializing_if = "Option::is_none")]
pub co2_emission: Option<Box<models::Quantity>>,
}
impl ContinuousLeg {
pub fn new(start: models::Place, end: models::Place, service: models::ContinuousService) -> ContinuousLeg {
ContinuousLeg {
start: Box::new(start),
end: Box::new(end),
service: Box::new(service),
time_window_start: None,
time_window_end: None,
duration: None,
situation_full_refs: None,
co2_emission: None,
}
}
}