template

package
v0.5.5 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 2, 2022 License: MIT Imports: 9 Imported by: 1

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrNoFiles = errors.New("no files provided")
)

Functions

func CurrentUser

func CurrentUser(u any) (string, func() any)

CurrentUser encloses some value representing a user. It returns "currentUser" as the name of the function for convenient passing to a template.FuncMap and returns a function returning the enclosed value when called.

func Env

func Env(e string) (string, func() string)

Env encloses some string representing an environment. It returns "env" as the name of the function for convenient passing to a template.FuncMap and returns a function returning the enclosed value when called.

func Nonce

func Nonce() (string, func() string)

Nonce returns "nonce" as the name of the function for convenient passing to a template.FuncMap and returns a function generating a uuid.

func RootUrl

func RootUrl(u *url.URL) (string, func() string)

RootUrl encloses the *url.URL representing the base URL of the web app. It returns "rootUrl" as the name of the function for convenient passing to a template.FuncMap and returns a function returning its *url.URL.String(). If u is nil, that function will always return an empty string.

func TagPacker

func TagPacker(env string, filesys fs.FS) func(string, bool) html.HTML

TagPacker encloses the environment and filesystem so when called executing a template, emits valid paths to JS and CSS assets.

TODO(dlk):

- configurable asset paths? - represent error states; ship files in trails generate?

func TagPackerModern added in v0.3.11

func TagPackerModern(env string, filesys fs.FS) func(string, bool) html.HTML

Types

type Parse

type Parse struct {
	// contains filtered or unexported fields
}

Parse implements Parser with a focus on utilizing embedded HTML templates through fs.FS.

func (*Parse) AddFn

func (p *Parse) AddFn(name string, fn any)

AddFn includes the named function in the Parse function map.

func (*Parse) Parse

func (p *Parse) Parse(fps ...string) (*html.Template, error)

Parse parses files found in the *Parse.fs with those functions provided previously.

type Parser

type Parser interface {
	AddFn(name string, fn any)
	Parse(fps ...string) (*html.Template, error)
}

Parser is the interface for parsing HTML templates with the functions provided.

func NewParser

func NewParser(opts ...ParserOptFn) Parser

NewParser constructs a Parse with the provided fs.FS and functional options.

type ParserOptFn

type ParserOptFn func(*Parse)

The ParserOptFn applies functional options to a *Parse when constructing it.

func WithFS added in v0.5.0

func WithFS(filesys fs.FS) ParserOptFn

func WithFn

func WithFn(name string, fn any) ParserOptFn

WithFn encloses a named function so it can be added to a *Parse's function map.

Directories

Path Synopsis
Package templatetest exposes a mock fs.FS that implements basic file operations.
Package templatetest exposes a mock fs.FS that implements basic file operations.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL