schedulelib/dto/
study_period_response.rs

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
use std::collections::HashMap;
use chrono::naive::serde::ts_milliseconds;
use chrono::NaiveDateTime;
use serde::{Deserialize, Serialize};
use uuid::Uuid;

use crate::dto::schedule_response::ScheduleResponse;
use crate::dto::slot_response::SlotResponse;
use crate::jsonb::holiday_range::HolidayRange;

#[derive(Serialize, Deserialize, Debug, Clone)]
#[serde(rename_all = "camelCase")]
pub struct StudyPeriodResponse {
    pub id: Uuid,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub ver: Option<i32>,
    #[serde(with = "ts_milliseconds")]
    pub date_start: NaiveDateTime,
    #[serde(with = "ts_milliseconds")]
    pub date_end: NaiveDateTime,
    pub period_type: String,
    pub status: String,
    pub organization: Uuid,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub parent: Option<Uuid>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub name: Option<String>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub melody_start: Option<Uuid>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub melody_end: Option<Uuid>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub active_schedule: Option<HashMap<Uuid, Uuid>>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub origin: Option<Uuid>,
    pub slot_list: Vec<SlotResponse>,
    pub study_period_list: Vec<StudyPeriodResponse>,
    pub schedules: Vec<ScheduleResponse>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub public_holidays: Option<Vec<HolidayRange>>,
}