Scheduled recipes can now be removed
This commit is contained in:
parent
084be9fb00
commit
a3f2b4a86a
8 changed files with 64 additions and 7 deletions
10
Cargo.lock
generated
10
Cargo.lock
generated
|
|
@ -712,6 +712,7 @@ dependencies = [
|
||||||
"futures",
|
"futures",
|
||||||
"gloo",
|
"gloo",
|
||||||
"ron",
|
"ron",
|
||||||
|
"scanf",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_html_form",
|
"serde_html_form",
|
||||||
"thiserror 2.0.11",
|
"thiserror 2.0.11",
|
||||||
|
|
@ -2188,6 +2189,15 @@ version = "1.0.19"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "6ea1a2d0a644769cc99faa24c3ad26b379b786fe7c36fd3c546254801650e6dd"
|
checksum = "6ea1a2d0a644769cc99faa24c3ad26b379b786fe7c36fd3c546254801650e6dd"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "scanf"
|
||||||
|
version = "1.2.3"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "cbf5845f2587e0dd28b0dc313d1bbe0b7aa70aedb8e236785f670dcd1df1f677"
|
||||||
|
dependencies = [
|
||||||
|
"nom",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "scopeguard"
|
name = "scopeguard"
|
||||||
version = "1.2.0"
|
version = "1.2.0"
|
||||||
|
|
|
||||||
|
|
@ -146,6 +146,7 @@ pub enum Sentence {
|
||||||
CalendarAddToPlannerAlreadyExists,
|
CalendarAddToPlannerAlreadyExists,
|
||||||
CalendarDateFormat, // See https://docs.rs/chrono/latest/chrono/format/strftime/index.html.
|
CalendarDateFormat, // See https://docs.rs/chrono/latest/chrono/format/strftime/index.html.
|
||||||
CalendarAddIngredientsToShoppingList,
|
CalendarAddIngredientsToShoppingList,
|
||||||
|
CalendarUnscheduleConfirmation,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub const DEFAULT_LANGUAGE_CODE: &str = "en";
|
pub const DEFAULT_LANGUAGE_CODE: &str = "en";
|
||||||
|
|
|
||||||
|
|
@ -49,5 +49,8 @@
|
||||||
<div id="hidden-templates-calendar">
|
<div id="hidden-templates-calendar">
|
||||||
<div class="scheduled-recipe-with-link-and-remove"><a></a><span class="remove-scheduled-recipe">X</span></div>
|
<div class="scheduled-recipe-with-link-and-remove"><a></a><span class="remove-scheduled-recipe">X</span></div>
|
||||||
<div class="scheduled-recipe"></div>
|
<div class="scheduled-recipe"></div>
|
||||||
|
|
||||||
|
<span class="unschedule-confirmation">{{ tr.t(Sentence::CalendarUnscheduleConfirmation) }}</span>
|
||||||
|
<span class="calendar-date-format">{{ tr.t(Sentence::CalendarDateFormat) }}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
@ -17,6 +17,7 @@
|
||||||
<div class="item-scheduled-recipe"><a></a></div>
|
<div class="item-scheduled-recipe"><a></a></div>
|
||||||
<div class="item-delete"></div>
|
<div class="item-delete"></div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<span class="calendar-date-format">{{ tr.t(Sentence::CalendarDateFormat) }}</span>
|
<span class="calendar-date-format">{{ tr.t(Sentence::CalendarDateFormat) }}</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -130,6 +130,7 @@
|
||||||
(CalendarAddToPlannerAlreadyExists, "Recipe {title} has already been scheduled for {date}"),
|
(CalendarAddToPlannerAlreadyExists, "Recipe {title} has already been scheduled for {date}"),
|
||||||
(CalendarDateFormat, "%A, %-d %B, %C%y"), // See https://docs.rs/chrono/latest/chrono/format/strftime/index.html.
|
(CalendarDateFormat, "%A, %-d %B, %C%y"), // See https://docs.rs/chrono/latest/chrono/format/strftime/index.html.
|
||||||
(CalendarAddIngredientsToShoppingList, "Add ingredients to shopping list"),
|
(CalendarAddIngredientsToShoppingList, "Add ingredients to shopping list"),
|
||||||
|
(CalendarUnscheduleConfirmation, "Are you sure to remove {title} on {date}"),
|
||||||
]
|
]
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
|
|
@ -263,6 +264,7 @@
|
||||||
(CalendarAddToPlannerAlreadyExists, "La recette {title} a été déjà été agendée pour le {date}"),
|
(CalendarAddToPlannerAlreadyExists, "La recette {title} a été déjà été agendée pour le {date}"),
|
||||||
(CalendarDateFormat, "%A %-d %B %C%y"), // See https://docs.rs/chrono/latest/chrono/format/strftime/index.html.
|
(CalendarDateFormat, "%A %-d %B %C%y"), // See https://docs.rs/chrono/latest/chrono/format/strftime/index.html.
|
||||||
(CalendarAddIngredientsToShoppingList, "Ajouter les ingrédients à la liste de course"),
|
(CalendarAddIngredientsToShoppingList, "Ajouter les ingrédients à la liste de course"),
|
||||||
|
(CalendarUnscheduleConfirmation, "Êtes-vous sûr de vouloir enlever {title} du {date}"),
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
|
|
@ -22,6 +22,8 @@ thiserror = "2"
|
||||||
|
|
||||||
futures = "0.3"
|
futures = "0.3"
|
||||||
|
|
||||||
|
scanf = "1.2"
|
||||||
|
|
||||||
wasm-bindgen = "0.2"
|
wasm-bindgen = "0.2"
|
||||||
wasm-bindgen-futures = "0.4"
|
wasm-bindgen-futures = "0.4"
|
||||||
web-sys = { version = "0.3", features = [
|
web-sys = { version = "0.3", features = [
|
||||||
|
|
|
||||||
|
|
@ -1,14 +1,18 @@
|
||||||
use std::{cell::RefCell, rc::Rc};
|
use std::{cell::RefCell, rc::Rc};
|
||||||
|
|
||||||
use chrono::{offset::Local, Datelike, Days, Months, NaiveDate, Weekday};
|
use chrono::{offset::Local, Datelike, Days, Months, NaiveDate, Weekday};
|
||||||
|
use common::{ron_api, utils::substitute_with_names};
|
||||||
use gloo::{console::log, events::EventListener, utils::document};
|
use gloo::{console::log, events::EventListener, utils::document};
|
||||||
|
use scanf::sscanf;
|
||||||
use wasm_bindgen::prelude::*;
|
use wasm_bindgen::prelude::*;
|
||||||
use wasm_bindgen_futures::spawn_local;
|
use wasm_bindgen_futures::spawn_local;
|
||||||
use web_sys::Element;
|
use web_sys::Element;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
|
modal_dialog,
|
||||||
recipe_scheduler::RecipeScheduler,
|
recipe_scheduler::RecipeScheduler,
|
||||||
utils::{by_id, selector, selector_all, SelectorExt},
|
request,
|
||||||
|
utils::{by_id, get_locale, selector, selector_all, SelectorExt},
|
||||||
};
|
};
|
||||||
|
|
||||||
struct CalendarStateInternal {
|
struct CalendarStateInternal {
|
||||||
|
|
@ -123,7 +127,46 @@ pub fn setup(
|
||||||
recipe_scheduler,
|
recipe_scheduler,
|
||||||
);
|
);
|
||||||
} else if target.class_name() == "remove-scheduled-recipe" {
|
} else if target.class_name() == "remove-scheduled-recipe" {
|
||||||
log!("REMOVE"); // TODO.
|
spawn_local(async move {
|
||||||
|
let mut recipe_id: i64 = 0;
|
||||||
|
let mut date: NaiveDate = NaiveDate::default();
|
||||||
|
sscanf!(
|
||||||
|
&target.parent_element().unwrap().id(),
|
||||||
|
"scheduled-recipe-{}-{}",
|
||||||
|
recipe_id,
|
||||||
|
date
|
||||||
|
)
|
||||||
|
.unwrap();
|
||||||
|
|
||||||
|
let title = target.previous_element_sibling().unwrap().inner_html();
|
||||||
|
|
||||||
|
if modal_dialog::show_and_initialize(
|
||||||
|
"#hidden-templates-calendar .unschedule-confirmation",
|
||||||
|
async |element| {
|
||||||
|
let date_format =
|
||||||
|
selector::<Element>("#hidden-templates-calendar .calendar-date-format")
|
||||||
|
.inner_html();
|
||||||
|
element.set_inner_html(&substitute_with_names(
|
||||||
|
&element.inner_html(),
|
||||||
|
&["{title}", "{date}"],
|
||||||
|
&[
|
||||||
|
&title,
|
||||||
|
&date
|
||||||
|
.format_localized(&date_format, get_locale())
|
||||||
|
.to_string(),
|
||||||
|
],
|
||||||
|
));
|
||||||
|
},
|
||||||
|
)
|
||||||
|
.await
|
||||||
|
.is_some()
|
||||||
|
{
|
||||||
|
let body = ron_api::ScheduledRecipe { recipe_id, date };
|
||||||
|
let _ =
|
||||||
|
request::delete::<(), _>("calendar/remove_scheduled_recipe", body).await;
|
||||||
|
target.parent_element().unwrap().remove();
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.forget();
|
.forget();
|
||||||
|
|
|
||||||
|
|
@ -267,16 +267,11 @@ pub fn setup_page(recipe_id: i64) -> Result<(), JsValue> {
|
||||||
let body = ron_api::Id { id: recipe_id };
|
let body = ron_api::Id { id: recipe_id };
|
||||||
let _ = request::delete::<(), _>("recipe/remove", body).await;
|
let _ = request::delete::<(), _>("recipe/remove", body).await;
|
||||||
window().location().set_href("/").unwrap();
|
window().location().set_href("/").unwrap();
|
||||||
|
|
||||||
// by_id::<Element>(&format!("group-{}", group_id)).remove();
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
.forget();
|
.forget();
|
||||||
|
|
||||||
// let group_dropzone: Element = selector(".dropzone-group");
|
|
||||||
// setup_dragzone_events(&group_dropzone);
|
|
||||||
|
|
||||||
// Load initial groups, steps and ingredients.
|
// Load initial groups, steps and ingredients.
|
||||||
{
|
{
|
||||||
spawn_local(async move {
|
spawn_local(async move {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue