https://github.com/nir3x/tmplreload
tmplreload - Auto-Reloading Templates for Go
https://github.com/nir3x/tmplreload
auto-reload go golang html templates tmplreload web-development
Last synced: 3 months ago
JSON representation
tmplreload - Auto-Reloading Templates for Go
- Host: GitHub
- URL: https://github.com/nir3x/tmplreload
- Owner: NIR3X
- License: agpl-3.0
- Created: 2024-01-23T01:00:22.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-02-16T04:04:24.000Z (over 1 year ago)
- Last Synced: 2024-06-21T18:15:05.851Z (12 months ago)
- Topics: auto-reload, go, golang, html, templates, tmplreload, web-development
- Language: Go
- Homepage:
- Size: 49.8 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# tmplreload - Auto-Reloading Templates for Go
`tmplreload` is a Go module that provides auto-reloading templates based on the `html/template` package. It allows you to create templates that automatically reload when the underlying template file changes. This can be particularly useful during development when you want to see the changes to your templates without restarting your application.
## Features
* **Auto-Reloading:** Templates are automatically reloaded when the underlying file changes.
* **Function Map Management:** Easily add, remove, or update template functions.## Installation
To use `tmplreload` in your Go project, you can simply run:
```bash
go get -u github.com/NIR3X/tmplreload
```## Example Usage
```go
package mainimport (
"bytes"
"fmt"
"html/template"
"net/http"
"time""github.com/NIR3X/tmplreload"
)func main() {
// Create a new TmplColl (Template Collection).
tmplColl := tmplreload.NewTmplColl(60, 1)// Close the TmplColl when the main function ends.
defer tmplColl.Close()// Define a function to be used in the template.
funcMap := template.FuncMap{
"currentTime": func() string {
return time.Now().Format(time.RFC3339)
},
}// Add the function to the TmplColl function map.
tmplColl.FuncsAdd(funcMap)// Parse template files in the "templates" directory.
err := tmplColl.ParseGlob("templates/*.html")
if err != nil {
fmt.Println("Error parsing templates:", err)
return
}// Start an HTTP server to render the templates.
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
// Execute the template and pass data.
data := struct{ Message string }{"Hello, tmplreload!"}
err := tmplColl.ExecuteTemplate(w, "templates/index.html", data)
if err != nil {
http.Error(w, "Error rendering template", http.StatusInternalServerError)
}
})// Start the server on port 8000.
fmt.Println("Server is running on http://127.0.0.1:8000")
http.ListenAndServe(":8000", nil)
}
```## Example HTML Template (templates/index.html)
```html
Example Template
{{ .Message }}!
Current time: {{ currentTime }}
```
In this example, the `tmplreload` module is used to create a template collection (`TmplColl`). Templates are parsed from the "templates" directory, and a function (`currentTime`) is added to the function map. The HTTP server renders the template on incoming requests.
## Documentation
* [GoDoc](https://pkg.go.dev/github.com/NIR3X/tmplreload#section-documentation)
## License
[](https://www.gnu.org/licenses/agpl-3.0.html)
This program is Free Software: You can use, study share and improve it at your
will. Specifically you can redistribute and/or modify it under the terms of the
[GNU Affero General Public License](https://www.gnu.org/licenses/agpl-3.0.html) as
published by the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.