add edit-recipe-name
This commit is contained in:
parent
41d8a54132
commit
de2fb7dc9c
|
|
@ -3,6 +3,7 @@
|
||||||
{% block main %}
|
{% block main %}
|
||||||
<h1>{{ recipe.title }}</h1>
|
<h1>{{ recipe.title }}</h1>
|
||||||
{% if perms.recipes.add_recipe %}
|
{% if perms.recipes.add_recipe %}
|
||||||
|
<p><a href="{% url 'edit-recipe' recipe.slug %}">Edit recipe name</a></p>
|
||||||
<p><a href="{% url 'add-version' recipe.slug %}">Add version</a></p>
|
<p><a href="{% url 'add-version' recipe.slug %}">Add version</a></p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<ul>
|
<ul>
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,7 @@
|
||||||
<p><a href="{{ recipe.get_absolute_url }}">Show all versions</a></p>
|
<p><a href="{{ recipe.get_absolute_url }}">Show all versions</a></p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if perms.recipes.add_recipe %}
|
{% if perms.recipes.add_recipe %}
|
||||||
|
<p><a href="{% url 'edit-recipe' recipe.slug %}">Edit recipe name</a></p>
|
||||||
<p><a href="{% url 'add-version' recipe.slug %}">Add version</a></p>
|
<p><a href="{% url 'add-version' recipe.slug %}">Add version</a></p>
|
||||||
<p><a href="{% url 'edit-version' recipe.slug version.slug %}">Edit Version</a></p>
|
<p><a href="{% url 'edit-version' recipe.slug version.slug %}">Edit Version</a></p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@ urlpatterns = [
|
||||||
path('', views.recipes, name='recipes'),
|
path('', views.recipes, name='recipes'),
|
||||||
path('add-recipe/', views.add_recipe, name='add-recipe'),
|
path('add-recipe/', views.add_recipe, name='add-recipe'),
|
||||||
path('<slug:slug>/add-version/', views.add_version, name='add-version'),
|
path('<slug:slug>/add-version/', views.add_version, name='add-version'),
|
||||||
|
path('<slug:slug>/edit-recipe/', views.edit_recipe, name='edit-recipe'),
|
||||||
path('<slug:slug_recipe>/<slug:slug_version>/edit-version/', views.edit_version, name='edit-version'),
|
path('<slug:slug_recipe>/<slug:slug_version>/edit-version/', views.edit_version, name='edit-version'),
|
||||||
path('<slug:slug_recipe>/<slug:slug_version>/', views.version, name='version'),
|
path('<slug:slug_recipe>/<slug:slug_version>/', views.version, name='version'),
|
||||||
path('<slug:slug>/', views.recipe, name='recipe'),
|
path('<slug:slug>/', views.recipe, name='recipe'),
|
||||||
|
|
|
||||||
|
|
@ -69,6 +69,21 @@ def add_recipe(request):
|
||||||
ingredients_formset = IngredientFormSet(queryset=Ingredient.objects.none(), prefix=INGREDIENTS_FORMSET_PREFIX)
|
ingredients_formset = IngredientFormSet(queryset=Ingredient.objects.none(), prefix=INGREDIENTS_FORMSET_PREFIX)
|
||||||
|
|
||||||
return render(request, 'add-recipe.html', {'recipe_form': recipe_form, 'version_form': version_form, 'ingredients_formset': ingredients_formset})
|
return render(request, 'add-recipe.html', {'recipe_form': recipe_form, 'version_form': version_form, 'ingredients_formset': ingredients_formset})
|
||||||
|
# TODO refactor Recipe.objects.get ... with get_object_or_404
|
||||||
|
@login_required
|
||||||
|
def edit_recipe(request, slug):
|
||||||
|
recipe = get_object_or_404(Recipe, slug=slug)
|
||||||
|
|
||||||
|
if request.method == 'POST':
|
||||||
|
form = RecipeForm(request.POST, instance=recipe, prefix=RECIPE_FORM_PREFIX)
|
||||||
|
if form.is_valid():
|
||||||
|
if form.has_changed():
|
||||||
|
form.save()
|
||||||
|
return HttpResponseRedirect(reverse('recipe', kwargs={'slug': recipe.slug}))
|
||||||
|
else:
|
||||||
|
form = RecipeForm(instance=recipe, prefix=RECIPE_FORM_PREFIX)
|
||||||
|
|
||||||
|
return render(request, 'edit-recipe.html', {'form': form})
|
||||||
|
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('recipes.add_recipe')
|
@permission_required('recipes.add_recipe')
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue