mirror of
https://github.com/kataras/iris.git
synced 2025-01-25 03:31:04 +01:00
244a59e055
Former-commit-id: ed84f99c89f43fe5e980a8e6d0ee22c186f0e1b9
94 lines
3.0 KiB
Go
94 lines
3.0 KiB
Go
package view
|
|
|
|
import (
|
|
"github.com/kataras/go-template/django"
|
|
)
|
|
|
|
type (
|
|
// Value conversion for django.Value
|
|
Value django.Value
|
|
// Error conversion for django.Error
|
|
Error django.Error
|
|
// FilterFunction conversion for django.FilterFunction
|
|
FilterFunction func(in *Value, param *Value) (out *Value, err *Error)
|
|
)
|
|
|
|
// this exists because of moving the pongo2 to the vendors without conflictitions if users
|
|
// wants to register pongo2 filters they can use this django.FilterFunc to do so.
|
|
func convertFilters(djangoFilters map[string]FilterFunction) map[string]django.FilterFunction {
|
|
filters := make(map[string]django.FilterFunction, len(djangoFilters))
|
|
for k, v := range djangoFilters {
|
|
func(filterName string, filterFunc FilterFunction) {
|
|
fn := django.FilterFunction(func(in *django.Value, param *django.Value) (*django.Value, *django.Error) {
|
|
theOut, theErr := filterFunc((*Value)(in), (*Value)(param))
|
|
return (*django.Value)(theOut), (*django.Error)(theErr)
|
|
})
|
|
filters[filterName] = fn
|
|
}(k, v)
|
|
}
|
|
return filters
|
|
}
|
|
|
|
// DjangoAdaptor is the adaptor for the Django engine.
|
|
// Read more about the Django Go Template at:
|
|
// https://github.com/flosch/pongo2
|
|
// and https://github.com/kataras/go-template/tree/master/django
|
|
type DjangoAdaptor struct {
|
|
*Adaptor
|
|
engine *django.Engine
|
|
filters map[string]FilterFunction
|
|
}
|
|
|
|
// Django returns a new kataras/go-template/django template engine
|
|
// with the same features as all iris' view engines have:
|
|
// Binary assets load (templates inside your executable with .go extension)
|
|
// Layout, Funcs, {{ url }} {{ urlpath}} for reverse routing and much more.
|
|
//
|
|
// Read more: https://github.com/flosch/pongo2
|
|
func Django(directory string, extension string) *DjangoAdaptor {
|
|
e := django.New()
|
|
return &DjangoAdaptor{
|
|
Adaptor: NewAdaptor(directory, extension, e),
|
|
engine: e,
|
|
filters: make(map[string]FilterFunction, 0),
|
|
}
|
|
}
|
|
|
|
// Filters for pongo2, map[name of the filter] the filter function .
|
|
//
|
|
// Note, these Filters function overrides ALL the previous filters
|
|
// It SETS a new filter map based on the given 'filtersMap' parameter.
|
|
func (d *DjangoAdaptor) Filters(filtersMap map[string]FilterFunction) *DjangoAdaptor {
|
|
|
|
if len(filtersMap) == 0 {
|
|
return d
|
|
}
|
|
// configuration maps are never nil, because
|
|
// they are initialized at each of the engine's New func
|
|
// so we're just passing them inside it.
|
|
|
|
filters := convertFilters(filtersMap)
|
|
d.engine.Config.Filters = filters
|
|
return d
|
|
}
|
|
|
|
// Globals share context fields between templates. https://github.com/flosch/pongo2/issues/35
|
|
func (d *DjangoAdaptor) Globals(globalsMap map[string]interface{}) *DjangoAdaptor {
|
|
if len(globalsMap) == 0 {
|
|
return d
|
|
}
|
|
|
|
for k, v := range globalsMap {
|
|
d.engine.Config.Globals[k] = v
|
|
}
|
|
|
|
return d
|
|
}
|
|
|
|
// DebugTemplates enables template debugging.
|
|
// The verbose error messages will appear in browser instead of quiet passes with error code.
|
|
func (d *DjangoAdaptor) DebugTemplates(debug bool) *DjangoAdaptor {
|
|
d.engine.Config.DebugTemplates = debug
|
|
return d
|
|
}
|