aboutsummaryrefslogtreecommitdiffstats
path: root/src/models/scheduled_transaction_detail.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/models/scheduled_transaction_detail.rs')
-rw-r--r--src/models/scheduled_transaction_detail.rs79
1 files changed, 15 insertions, 64 deletions
diff --git a/src/models/scheduled_transaction_detail.rs b/src/models/scheduled_transaction_detail.rs
index d86ef25..d553329 100644
--- a/src/models/scheduled_transaction_detail.rs
+++ b/src/models/scheduled_transaction_detail.rs
@@ -9,11 +9,8 @@
*/
-#[allow(unused_imports)]
-use serde_json::Value;
-
-#[derive(Debug, Serialize, Deserialize)]
+#[derive(Debug, PartialEq, Serialize, Deserialize)]
pub struct ScheduledTransactionDetail {
#[serde(rename = "id")]
pub id: String,
@@ -31,14 +28,14 @@ pub struct ScheduledTransactionDetail {
#[serde(rename = "memo", skip_serializing_if = "Option::is_none")]
pub memo: Option<String>,
/// The scheduled transaction flag
- #[serde(rename = "flag_color")]
- pub flag_color: String,
+ #[serde(rename = "flag_color", skip_serializing_if = "Option::is_none")]
+ pub flag_color: Option<String>,
#[serde(rename = "account_id")]
pub account_id: String,
#[serde(rename = "payee_id", skip_serializing_if = "Option::is_none")]
pub payee_id: Option<String>,
- #[serde(rename = "category_id")]
- pub category_id: String,
+ #[serde(rename = "category_id", skip_serializing_if = "Option::is_none")]
+ pub category_id: Option<String>,
/// If a transfer, the account_id which the scheduled transaction transfers to
#[serde(rename = "transfer_account_id", skip_serializing_if = "Option::is_none")]
pub transfer_account_id: Option<String>,
@@ -47,17 +44,17 @@ pub struct ScheduledTransactionDetail {
pub deleted: bool,
#[serde(rename = "account_name")]
pub account_name: String,
- #[serde(rename = "payee_name")]
- pub payee_name: String,
- #[serde(rename = "category_name")]
- pub category_name: String,
+ #[serde(rename = "payee_name", skip_serializing_if = "Option::is_none")]
+ pub payee_name: Option<String>,
+ #[serde(rename = "category_name", skip_serializing_if = "Option::is_none")]
+ pub category_name: Option<String>,
/// If a split scheduled transaction, the subtransactions.
#[serde(rename = "subtransactions")]
- pub subtransactions: Vec<::models::ScheduledSubTransaction>,
+ pub subtransactions: Vec<crate::models::ScheduledSubTransaction>,
}
impl ScheduledTransactionDetail {
- pub fn new(id: String, date_first: String, date_next: String, frequency: String, amount: i64, flag_color: String, account_id: String, category_id: String, deleted: bool, account_name: String, payee_name: String, category_name: String, subtransactions: Vec<::models::ScheduledSubTransaction>) -> ScheduledTransactionDetail {
+ pub fn new(id: String, date_first: String, date_next: String, frequency: String, amount: i64, account_id: String, deleted: bool, account_name: String, subtransactions: Vec<crate::models::ScheduledSubTransaction>) -> ScheduledTransactionDetail {
ScheduledTransactionDetail {
id: id,
date_first: date_first,
@@ -65,64 +62,18 @@ impl ScheduledTransactionDetail {
frequency: frequency,
amount: amount,
memo: None,
- flag_color: flag_color,
+ flag_color: None,
account_id: account_id,
payee_id: None,
- category_id: category_id,
+ category_id: None,
transfer_account_id: None,
deleted: deleted,
account_name: account_name,
- payee_name: payee_name,
- category_name: category_name,
+ payee_name: None,
+ category_name: None,
subtransactions: subtransactions,
}
}
}
-///
-#[derive(Debug, Serialize, Deserialize)]
-pub enum Frequency {
- #[serde(rename = "never")]
- Never,
- #[serde(rename = "daily")]
- Daily,
- #[serde(rename = "weekly")]
- Weekly,
- #[serde(rename = "everyOtherWeek")]
- EveryOtherWeek,
- #[serde(rename = "twiceAMonth")]
- TwiceAMonth,
- #[serde(rename = "every4Weeks")]
- Every4Weeks,
- #[serde(rename = "monthly")]
- Monthly,
- #[serde(rename = "everyOtherMonth")]
- EveryOtherMonth,
- #[serde(rename = "every3Months")]
- Every3Months,
- #[serde(rename = "every4Months")]
- Every4Months,
- #[serde(rename = "twiceAYear")]
- TwiceAYear,
- #[serde(rename = "yearly")]
- Yearly,
- #[serde(rename = "everyOtherYear")]
- EveryOtherYear,
-}
-/// The scheduled transaction flag
-#[derive(Debug, Serialize, Deserialize)]
-pub enum FlagColor {
- #[serde(rename = "red")]
- Red,
- #[serde(rename = "orange")]
- Orange,
- #[serde(rename = "yellow")]
- Yellow,
- #[serde(rename = "green")]
- Green,
- #[serde(rename = "blue")]
- Blue,
- #[serde(rename = "purple")]
- Purple,
-}