37 lines
1.5 KiB
JavaScript
37 lines
1.5 KiB
JavaScript
const orderAction = document.getElementById("order-action");
|
|
const rmButton = document.getElementById("remove-order");
|
|
const locals = {
|
|
order: document.querySelector("#order1>h2").innerHTML.replace(" 1", ""),
|
|
sandwich: document.querySelector("label[for='sandwich1']").innerHTML,
|
|
day: document.querySelector("label[for='day1']").innerHTML
|
|
};
|
|
const [min, max] = [document.getElementById("day1").min, document.getElementById("day1").max];
|
|
|
|
function lastOrderId() {
|
|
let list = document.querySelectorAll("div.order h2");
|
|
return parseInt(list[list.length-1].innerText.replace(locals.order+" ", ""));
|
|
}
|
|
|
|
document.getElementById("add-order").addEventListener("click", () => {
|
|
let id = lastOrderId() + 1;
|
|
orderAction.insertAdjacentHTML("beforebegin", `<div id="order${id}" class="order">
|
|
<h2>${locals.order} ${id}</h2>
|
|
<div class="field">
|
|
<label for="sandwich${id}">${locals.sandwich}</label>
|
|
<input id="sandwich${id}" type="list" list="sandwich-list" name="sandwich${id}" autocomplete="off" required>
|
|
</div>
|
|
<div class="field">
|
|
<label for="day${id}">${locals.day}</label>
|
|
<input id="da${id}y" type="date" min="${min}" max="${max}" name="date${id}" required>
|
|
</div>
|
|
</div>`);
|
|
document.getElementById("order"+lastOrderId()).scrollIntoView({behavior: "smooth"});
|
|
rmButton.classList.remove("hide");
|
|
});
|
|
|
|
rmButton.addEventListener("click", () => {
|
|
let id = lastOrderId();
|
|
document.getElementById("order"+id).remove();
|
|
if (id === 2)
|
|
rmButton.classList.add("hide");
|
|
});
|