diff options
author | Alan Pearce | 2024-05-15 12:35:40 +0200 |
---|---|---|
committer | Alan Pearce | 2024-05-15 12:35:40 +0200 |
commit | 149cbe7681607eb48f47df14c7a39e6f289fb7b6 (patch) | |
tree | 97c00c61a61f38001205b39bdf15cf7bdb16784c /internal/server/templates.go | |
parent | 5624cf8f6427064dd17de40acd1d3fdfe8332e96 (diff) | |
download | searchix-149cbe7681607eb48f47df14c7a39e6f289fb7b6.tar.lz searchix-149cbe7681607eb48f47df14c7a39e6f289fb7b6.tar.zst searchix-149cbe7681607eb48f47df14c7a39e6f289fb7b6.zip |
refactor(templates): render partials with less hackiness
Diffstat (limited to 'internal/server/templates.go')
-rw-r--r-- | internal/server/templates.go | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/internal/server/templates.go b/internal/server/templates.go index bd3ad90..d8ffcf5 100644 --- a/internal/server/templates.go +++ b/internal/server/templates.go @@ -47,7 +47,10 @@ var templateFuncs = template.FuncMap{ }, } -func loadTemplate(layoutFile string, filename string) (*template.Template, error) { +func loadTemplate( + layoutFile string, + filenames ...string, +) (*template.Template, error) { tpl := template.New("index.gotmpl") tpl.Funcs(templateFuncs) @@ -56,8 +59,8 @@ func loadTemplate(layoutFile string, filename string) (*template.Template, error return nil, errors.WithMessage(err, "could not parse layout template") } - if filename != "" { - _, err = tpl.ParseFS(frontend.Files, filename) + if len(filenames) > 0 { + _, err = tpl.ParseFS(frontend.Files, filenames...) if err != nil { return nil, errors.WithMessage(err, "could not parse template") } @@ -72,7 +75,7 @@ func loadTemplates() (TemplateCollection, error) { layoutFile := path.Join(templateDir, "index.gotmpl") - index, err := loadTemplate(layoutFile, "") + index, err := loadTemplate(layoutFile) if err != nil { return nil, err } @@ -84,7 +87,7 @@ func loadTemplates() (TemplateCollection, error) { return nil, errors.WithMessage(err, "could not glob block templates") } for _, fullname := range templatePaths { - tpl, err := loadTemplate(layoutFile, glob) + tpl, err := loadTemplate(layoutFile, glob, fullname) if err != nil { return nil, err } |