adjustments in render

This commit is contained in:
Pedro Pérez 2025-05-24 20:23:10 +02:00
parent 2fea2e6ac5
commit d54fbcacf0
2 changed files with 45 additions and 15 deletions

View File

@ -34,22 +34,17 @@ func (a *App) JSON(w http.ResponseWriter, code int, v any) {
json.NewEncoder(w).Encode(v)
}
func (a *App) HTML(w http.ResponseWriter, code int, layout, page string, td *TemplateData) {
func (a *App) HTML(w http.ResponseWriter, r *http.Request, code int, layout string, page string, td *TemplateData) {
w.Header().Set("Content-Type", "text/html; charset=utf-8")
w.WriteHeader(code)
err := a.Templates.Template(w, layout, page, td)
err := a.Templates.Render(w, layout, page, td, r.Header.Get("HX-Request") != "true")
if err != nil {
slog.Error("error rendering template", "error", err)
slog.Error("error rendering", "layout", layout, "page", page, "error", err)
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
}
func (a *App) RenderComponent(name string, td *TemplateData) (string, error) {
result, err := a.Templates.RenderComponent(name, td)
if err != nil {
slog.Error("error rendering component", "component", name, "error", err)
return "", err
}
return result, nil
return a.Templates.RenderComponent(name, td)
}

View File

@ -3,6 +3,7 @@ package goblocks
import (
"bytes"
"errors"
"fmt"
"html/template"
"log/slog"
"maps"
@ -40,6 +41,7 @@ func defaultHTMLRender() *Render {
Functions: template.FuncMap{
"default": defaultIfEmpty,
"dict": Dict,
"duration": Duration,
},
templateCache: templateCache{},
}
@ -74,18 +76,36 @@ func cloneFuncMap(src template.FuncMap) template.FuncMap {
return c
}
func (re *Render) Template(w http.ResponseWriter, layoutName, pageName string, td *TemplateData) error {
func (re *Render) Render(w http.ResponseWriter, layoutName, pageName string, td *TemplateData, useLayout bool) error {
if td == nil {
td = &TemplateData{}
}
if !useLayout {
path := filepath.Join(re.TemplatesPath, "pages", pageName)
funcs := cloneFuncMap(re.Functions)
tmpl, err := template.New(strings.TrimSuffix(pageName, ".gohtml")).Funcs(funcs).ParseFiles(path)
if err != nil {
return err
}
var buf bytes.Buffer
if err := tmpl.ExecuteTemplate(&buf, strings.TrimSuffix(pageName, ".gohtml"), td); err != nil {
return err
}
_, err = buf.WriteTo(w)
return err
}
tmpl, err := re.loadTemplateWithLayout(layoutName, pageName)
if err != nil {
return err
}
buf := new(bytes.Buffer)
if err = tmpl.ExecuteTemplate(buf, strings.TrimSuffix(layoutName, ".gohtml"), td); err != nil {
var buf bytes.Buffer
if err := tmpl.ExecuteTemplate(&buf, strings.TrimSuffix(layoutName, ".gohtml"), td); err != nil {
return err
}
@ -103,6 +123,7 @@ func (re *Render) RenderComponent(name string, td *TemplateData) (string, error)
files := []string{path}
matches, err := filepath.Glob(filepath.Join(re.TemplatesPath, "components", "*.gohtml"))
if err != nil {
slog.Error("error loading component files", "error", err)
return "", err
}
files = append(files, matches...)
@ -110,11 +131,15 @@ func (re *Render) RenderComponent(name string, td *TemplateData) (string, error)
funcs := cloneFuncMap(re.Functions)
tmpl, err := template.New(name).Funcs(funcs).ParseFiles(files...)
if err != nil {
slog.Error("error loading component files", "error", err)
return "", err
}
var buf bytes.Buffer
err = tmpl.ExecuteTemplate(&buf, strings.TrimSuffix(name, ".gohtml"), td)
if err != nil {
slog.Error("error executing component template", "error", err)
}
return buf.String(), err
}
@ -342,3 +367,13 @@ func FormatDateSpanish(date time.Time) string {
return dayName + ", " + strconv.Itoa(day) + " de " + month + " de " + strconv.Itoa(year)
}
func Duration(start, end time.Time) string {
if end.IsZero() {
end = time.Now()
}
d := end.Sub(start)
h := int(d.Hours())
m := int(d.Minutes()) % 60
return fmt.Sprintf("%d:%02d", h, m)
}