summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorxengineering <me@xengineering.eu>2024-05-14 20:14:42 +0200
committerxengineering <me@xengineering.eu>2024-05-14 20:43:41 +0200
commita87128138bdb301ede64049ec5068e47abb5c839 (patch)
tree72495022f7237458f4a24122ffd13dd872263698
parentb5b72880a0b6e9f188b532c9b2ad360ff1dab2ea (diff)
downloadceres-a87128138bdb301ede64049ec5068e47abb5c839.tar
ceres-a87128138bdb301ede64049ec5068e47abb5c839.tar.zst
ceres-a87128138bdb301ede64049ec5068e47abb5c839.zip
view: Complete ingredient editing
-rw-r--r--view/html/recipe-edit.html3
-rw-r--r--view/html/recipe-ingredient.html6
-rw-r--r--view/html/recipe-step.html3
-rw-r--r--view/static/ceres.js28
4 files changed, 32 insertions, 8 deletions
diff --git a/view/html/recipe-edit.html b/view/html/recipe-edit.html
index c46bbd4..f8a6bd9 100644
--- a/view/html/recipe-edit.html
+++ b/view/html/recipe-edit.html
@@ -30,6 +30,9 @@
<template id="recipe-step-template">
{{template "recipe-step"}}
</template>
+ <template id="recipe-ingredient-template">
+{{template "recipe-ingredient"}}
+ </template>
<script src="/static/view/static/ceres.js"></script>
</body>
</html>
diff --git a/view/html/recipe-ingredient.html b/view/html/recipe-ingredient.html
index 9ea90be..e925737 100644
--- a/view/html/recipe-ingredient.html
+++ b/view/html/recipe-ingredient.html
@@ -1,6 +1,6 @@
{{define "recipe-ingredient"}} <p>
- <input type="text" placeholder="Amount" value="{{.Amount}}">
- <input type="text" placeholder="Unit" value="{{.Unit}}">
- <input type="text" placeholder="Type" value="{{.Type}}">
+ <input class="amount" type="text" placeholder="Amount" value="{{.Amount}}">
+ <input class="unit" type="text" placeholder="Unit" value="{{.Unit}}">
+ <input class="type" type="text" placeholder="Type" value="{{.Type}}">
<button type="button" onclick="parentNode.remove();">remove ingredient</button>
</p>{{end}}
diff --git a/view/html/recipe-step.html b/view/html/recipe-step.html
index 3fd22a7..13c0bb7 100644
--- a/view/html/recipe-step.html
+++ b/view/html/recipe-step.html
@@ -1,7 +1,8 @@
{{define "recipe-step"}} <section>
<textarea rows="4" cols="50" placeholder="Step description">{{.Text}}</textarea>
- <div>{{range .Ingredients}}
+ <div class="ingredients">{{range .Ingredients}}
{{ template "recipe-ingredient" . }}{{end}}
</div>
+ <button type="button" onclick="addNewIngredient(this);">add ingredient</button>
<button type="button" onclick="parentNode.remove();">remove step</button>
</section>{{end}}
diff --git a/view/static/ceres.js b/view/static/ceres.js
index 43b8290..2405a59 100644
--- a/view/static/ceres.js
+++ b/view/static/ceres.js
@@ -59,12 +59,23 @@ function updateRecipe(event) {
let obj = Object.fromEntries(data.entries());
obj.steps = [];
- const steps = document.querySelectorAll('form section textarea');
- steps.forEach(step => {
+ var steps_container = document.getElementById('steps');
+ var steps = steps_container.children;
+ for (var i = 0; i < steps.length; i++) {
let s = {};
- s.text = step.value;
+ s.text = steps[i].querySelector('textarea').value;
+ s.ingredients = [];
+ var ingredients_container = steps[i].querySelector('.ingredients')
+ var ingredients = ingredients_container.children;
+ for (var j = 0; j < ingredients.length; j++) {
+ let ingr = {};
+ ingr.amount = ingredients[j].querySelector('.amount').value;
+ ingr.unit = ingredients[j].querySelector('.unit').value;
+ ingr.type = ingredients[j].querySelector('.type').value;
+ s.ingredients.push(ingr)
+ }
obj.steps.push(s);
- });
+ }
fetch(url, {
method: 'POST',
@@ -93,3 +104,12 @@ function addNewStep() {
let step = template.content.cloneNode(true);
steps.appendChild(step);
}
+
+function addNewIngredient(button) {
+ let step = button.parentNode;
+ let template = document.getElementById("recipe-ingredient-template");
+ let ingredients = step.querySelector('.ingredients');
+
+ let ingredient = template.content.cloneNode(true);
+ ingredients.appendChild(ingredient);
+}