DEVELOPMENT ENVIRONMENT

~liljamo/felu

ref: 26f0389c0378d6e648048933d385e19265cde2c2 felu/internal/renderer/renderer.go -rw-r--r-- 1.1 KiB
26f0389cJonni Liljamo docs(notice): update copyright year 8 months ago
                                                                                
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
/*
 * Copyright (C) 2024 Jonni Liljamo <jonni@liljamo.com>
 *
 * This file is licensed under AGPL-3.0-or-later, see NOTICE and LICENSE for
 * more information.
 */

// Package renderer implements templ rendering.
package renderer

import (
	"context"
	"net/http"

	"github.com/a-h/templ"
	"github.com/gin-gonic/gin/render"
)

// TemplRender holds the required info for rendering templ components.
type TemplRender struct {
	Code int
	Data templ.Component
}

// Render renders templ templates to HTML (and friends).
func (t TemplRender) Render(w http.ResponseWriter) error {
	w.WriteHeader(t.Code)
	if t.Data != nil {
		return t.Data.Render(context.Background(), w)
	}

	return nil
}

// WriteContentType sets the Content-Type header.
func (t TemplRender) WriteContentType(w http.ResponseWriter) {
	w.Header().Set("Content-Type", "text/html; charset=utf-8")
}

// Instance returns an instance of the templ renderer.
func (t *TemplRender) Instance( /* name */ _ string, data interface{}) render.Render {
	if templData, ok := data.(templ.Component); ok {
		return &TemplRender{
			Code: http.StatusOK,
			Data: templData,
		}
	}
	return nil
}