django-project/recipes/templates/add-version.html
2023-03-02 18:58:21 +01:00

61 lines
1.9 KiB
HTML

{% extends "base_main.html" %}
{% block title %}{{ recipe.title }}{% endblock %}
{% block main %}
<form action="" method="post" id="add-version-form">
{%csrf_token %}
<table>
{{ version_form.as_table }}
</table>
{{ ingredients_formset.management_form }}
{% for ingredient_form in ingredients_formset %}
{{ ingredient_form.as_div }}
{% endfor %}
<button id="add-ingredient" type="button">Add Ingredient</button>
<input type="submit" value="Submit">
</form>
<script>
let userIsAuthorCheckbox = document.querySelector("#id_version-use_user_for_author");
let authorNameValue = "";
function enableAuthorNameInput() {
let authorName = document.querySelector("#id_version-alternative_author")
if (userIsAuthorCheckbox.checked) {
authorName.setAttribute("disabled", "");
authorNameValue = authorName.value;
authorName.value = "";
} else {
authorName.removeAttribute("disabled");
authorName.value = authorNameValue;
}
}
enableAuthorNameInput();
userIsAuthorCheckbox.addEventListener('input', enableAuthorNameInput)
let firstIngredientDiv = document.querySelector("input[id^=id_ingredient][id$=text]").parentElement;
let addIngredientButton = document.querySelector("#add-ingredient");
let form = document.querySelector("#add-version-form");
let totalIngredientFormsInput = document.querySelector("#id_ingredient-TOTAL_FORMS");
addIngredientButton.addEventListener('click', addIngredient);
function addIngredient(e) {
let nextIngredientIndex = document.querySelectorAll("input[id^=id_ingredient][id$=text]").length
e.preventDefault();
let newIngredientDiv = firstIngredientDiv.cloneNode(true);
let formRegex = new RegExp('ingredient-(\\d){1}-', 'g');
newIngredientDiv.innerHTML = newIngredientDiv.innerHTML.replace(formRegex, `ingredient-${nextIngredientIndex}-`);
form.insertBefore(newIngredientDiv, addIngredientButton);
totalIngredientFormsInput.setAttribute('value', `${nextIngredientIndex + 1}`);
}
</script>
{% endblock %}