summaryrefslogtreecommitdiffstats
path: root/cmd/web/handlers.go
diff options
context:
space:
mode:
authorMatthew Lemon <y@yulqen.org>2024-02-15 15:43:04 +0000
committerMatthew Lemon <y@yulqen.org>2024-02-15 15:43:04 +0000
commitdd24746bcde550cffaf698a0c9c727e869e3cfb3 (patch)
tree5321ea481b1c214c38654bf36f152f763f4de1bd /cmd/web/handlers.go
parentc8065a2fcd2386b96eaa1521513afe3f9ba59770 (diff)
Implemented template cache
This is not perfect. At the moment, the new render() function, introduced in this commit, expects a templateData{} struct which contains an Operations field. This will need to be made generic, or we have multiple render() functions to accommdate the different types of data struct we want to be able to pass to templates. Also, in this commit I had to get rid of the /pages/operations and /pages/organisation sub directories for now. This does not fit the newTemplateCache() function - also introduced here. This needs to be refactored if we want to have subdirectories of templates - or else we stick to putting them inside pages/ and we name them appropriately, as we have done here with operations_list and organisation_list templates.
Diffstat (limited to '')
-rw-r--r--cmd/web/handlers.go23
1 files changed, 3 insertions, 20 deletions
diff --git a/cmd/web/handlers.go b/cmd/web/handlers.go
index 6901661..4d90469 100644
--- a/cmd/web/handlers.go
+++ b/cmd/web/handlers.go
@@ -34,32 +34,15 @@ func (app *application) listOperations(w http.ResponseWriter, r *http.Request) {
}
}
- files := []string{
- "./ui/html/base.tmpl.html",
- "./ui/html/pages/operations/list.tmpl.html",
- "./ui/html/partials/nav.tmpl.html",
- }
-
- ts, err := template.ParseFiles(files...)
- if err != nil {
- app.serverError(w, r, err) // Use the serverError() helper
- return
- }
-
- data := operationsTemplateData{
+ app.render(w, r, http.StatusOK, "operations_list.tmpl.html", templateData{
Operations: newOps,
- }
-
- err = ts.ExecuteTemplate(w, "base", data)
- if err != nil {
- app.serverError(w, r, err) // Use the serverError() helper
- }
+ })
}
func (app *application) listOrganisations(w http.ResponseWriter, r *http.Request) {
files := []string{
"./ui/html/base.tmpl.html",
- "./ui/html/pages/organisations/list.tmpl.html",
+ "./ui/html/pages/organisations_list.tmpl.html",
"./ui/html/partials/nav.tmpl.html",
}