From 2704cb76554b02f546bf3f9d2d11be98f2854b7b Mon Sep 17 00:00:00 2001 From: xengineering Date: Tue, 23 Apr 2024 17:42:57 +0200 Subject: Remove default recipe name To avoid not clickable recipes on the /recipes page a default name used to be inserted on recipe creation. This was not a proper fix for the problem and also was annoying that the user first had to remove the default recipe name. This commit removes this default name. --- controller/recipe.go | 17 ++++++++++++++--- server.go | 1 + view/html/recipe-edit.html | 2 +- view/html/recipes.html | 2 +- view/recipe.go | 10 ++++++++++ 5 files changed, 27 insertions(+), 5 deletions(-) diff --git a/controller/recipe.go b/controller/recipe.go index 9529b2a..b0a81d9 100644 --- a/controller/recipe.go +++ b/controller/recipe.go @@ -13,19 +13,30 @@ import ( ) func RecipeCreate(w http.ResponseWriter, r *http.Request) { + buf, err := io.ReadAll(r.Body) + if err != nil { + http.Error(w, err.Error(), http.StatusInternalServerError) + return + } + recipe := model.Recipe{} - recipe.Title = "recipe without title" + err = json.Unmarshal(buf, &recipe) + if err != nil { + http.Error(w, err.Error(), http.StatusBadRequest) + return + } + recipe.LastChanged = fmt.Sprint(time.Now().Unix()) recipe.Created = recipe.LastChanged var obj model.Object = &recipe - err := model.Transaction(obj.Create) + err = model.Transaction(obj.Create) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } - http.Redirect(w, r, "/recipe/"+recipe.Id+"?view=recipe-edit", http.StatusSeeOther) + http.Redirect(w, r, "/recipe/"+recipe.Id, http.StatusSeeOther) } func RecipeUpdate(w http.ResponseWriter, r *http.Request) { diff --git a/server.go b/server.go index 570d8ed..7caf328 100644 --- a/server.go +++ b/server.go @@ -28,6 +28,7 @@ func NewServer(addr string) Server { r.HandleFunc("/version", view.VersionRead(version)).Methods(`GET`) r.HandleFunc("/recipes", view.RecipesRead).Methods(`GET`) + r.HandleFunc("/recipe/create", view.RecipeCreate).Methods(`GET`) r.HandleFunc("/recipe", controller.RecipeCreate).Methods(`POST`) r.HandleFunc("/recipe/{id:[0-9]+}", view.RecipeRead).Methods(`GET`) diff --git a/view/html/recipe-edit.html b/view/html/recipe-edit.html index 3925293..8d940f8 100644 --- a/view/html/recipe-edit.html +++ b/view/html/recipe-edit.html @@ -8,7 +8,7 @@

Recipe editor

-
+

diff --git a/view/html/recipes.html b/view/html/recipes.html index 89620ed..d9e720b 100644 --- a/view/html/recipes.html +++ b/view/html/recipes.html @@ -8,7 +8,7 @@

Recipes

-

+

{{if ne (len .) 0}}

    {{range .}} diff --git a/view/recipe.go b/view/recipe.go index 7b9980d..8236476 100644 --- a/view/recipe.go +++ b/view/recipe.go @@ -51,3 +51,13 @@ func RecipeRead(w http.ResponseWriter, r *http.Request) { return } } + +func RecipeCreate(w http.ResponseWriter, r *http.Request) { + recipe := model.Recipe{} + + err := html.ExecuteTemplate(w, "recipe-edit", recipe) + if err != nil { + http.Error(w, err.Error(), http.StatusInternalServerError) + return + } +} -- cgit v1.2.3-70-g09d2