From 17f2abc3961fb854fb127f6b99c30ebb494b8e3d Mon Sep 17 00:00:00 2001 From: xengineering Date: Sat, 22 Apr 2023 17:40:02 +0200 Subject: Implement basic recipe target with JSON --- data/templates/recipe.html | 19 +++++++++++++++++-- handler.go | 20 ++++++++++---------- recipe.go | 37 +++++++++++++++++++++++++++++++++++++ 3 files changed, 64 insertions(+), 12 deletions(-) create mode 100644 recipe.go diff --git a/data/templates/recipe.html b/data/templates/recipe.html index 348a44d..7bbb660 100644 --- a/data/templates/recipe.html +++ b/data/templates/recipe.html @@ -11,11 +11,26 @@ HOME add recipe -

{{.Title}}

+

{{.Recipe.Title}}

- {{.Html}} +

This recipe is written for {{.Recipe.Portions}} portions.

+ +

Link

+ +
+ + {{range .Recipe.Steps}} +

{{.Text}}

+ +
+ {{end}} + {{ template "footer.html" }} diff --git a/handler.go b/handler.go index de055d3..04c4581 100644 --- a/handler.go +++ b/handler.go @@ -63,18 +63,18 @@ func recipeGet(w http.ResponseWriter, r *http.Request) { } idStr := ids[0] - textpath := filepath.Join(config.Data, "recipes", idStr, "text") - data, _ := ioutil.ReadFile(textpath) - markup := Markup(data) - - recipe := Recipe{ - idStr, - markup.title(), - string(data), - markup.html(), + rec, err := getRecipe(idStr) + if err != nil { + http.Error(w, "Could not get recipe.", 400) + return } - ServeTemplate(w, "recipe.html", recipe) + data := struct{ + Id string + Recipe recipe + }{idStr, rec} + + ServeTemplate(w, "recipe.html", data) } func recipeEditGet(w http.ResponseWriter, r *http.Request) { diff --git a/recipe.go b/recipe.go new file mode 100644 index 0000000..167f690 --- /dev/null +++ b/recipe.go @@ -0,0 +1,37 @@ +package main + +import ( + "encoding/json" + "path/filepath" + "io/ioutil" +) + +type recipe struct { + Title string + Portions int + Url string + Steps []struct { + Text string + Ingredients []struct { + Type string + Amount any + } + } +} + +func getRecipe(id string) (recipe, error) { + r := recipe{} + + textpath := filepath.Join(config.Data, "recipes", id, "text") + data, err := ioutil.ReadFile(textpath) + if err != nil { + return r, err + } + + err = json.Unmarshal(data, &r) + if err != nil { + return r, err + } + + return r, nil +} -- cgit v1.2.3-70-g09d2