diff options
author | René 'Necoro' Neumann <necoro@necoro.eu> | 2020-04-21 01:26:48 +0200 |
---|---|---|
committer | René 'Necoro' Neumann <necoro@necoro.eu> | 2020-04-21 01:26:48 +0200 |
commit | 87935efe945c6847d2b18afaf7bfae5e80aa61e6 (patch) | |
tree | 748e678472b937d19c4985b059d8db590890fed0 /internal/template/template.go | |
parent | afe2c4919dc2ded2f3b7d796b914dd66fbe78e64 (diff) | |
download | feed2imap-go-87935efe945c6847d2b18afaf7bfae5e80aa61e6.tar.gz feed2imap-go-87935efe945c6847d2b18afaf7bfae5e80aa61e6.tar.bz2 feed2imap-go-87935efe945c6847d2b18afaf7bfae5e80aa61e6.zip |
HTML Template part of the mail
Diffstat (limited to '')
-rw-r--r-- | internal/template/template.go | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/internal/template/template.go b/internal/template/template.go new file mode 100644 index 0000000..e31ece2 --- /dev/null +++ b/internal/template/template.go @@ -0,0 +1,57 @@ +package template + +import ( + "fmt" + "html/template" + "path/filepath" + "strings" +) + +func dict(v ...string) map[string]string { + dict := map[string]string{} + lenv := len(v) + for i := 0; i < lenv; i += 2 { + key := v[i] + if i+1 >= lenv { + dict[key] = "" + continue + } + dict[key] = v[i+1] + } + return dict +} + +func join(sep string, parts []string) string { + return strings.Join(parts, sep) +} + +func LastUrlPart(url string) string { + split := strings.Split(url, "/") + return split[len(split)-1] +} + +func byteCount(b int64) string { + const unit = 1024 + if b < unit { + return fmt.Sprintf("%d B", b) + } + div, exp := int64(unit), 0 + for n := b / unit; n >= unit; n /= unit { + div *= unit + exp++ + } + return fmt.Sprintf("%.1f %cB", float64(b)/float64(div), "KMGTPE"[exp]) +} + +var funcMap = template.FuncMap{ + "dict": dict, + "join": join, + "lastUrlPart": LastUrlPart, + "byteCount": byteCount, +} + +func ForFile(filename string) *template.Template { + name := filepath.Base(filename) + tpl := template.New(name).Funcs(funcMap) + return template.Must(tpl.ParseFiles(filename)) +} |