126 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Go
		
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Go
		
	
	
| package utils
 | |
| 
 | |
| import (
 | |
| 	"errors"
 | |
| 	"log"
 | |
| 	"net/http"
 | |
| 	"reflect"
 | |
| 	"strings"
 | |
| 	"text/template"
 | |
| 	"unicode"
 | |
| 
 | |
| 	"github.com/hacdias/caddy-hugo/assets"
 | |
| )
 | |
| 
 | |
| // GetTemplate is used to get a ready to use template based on the url and on
 | |
| // other sent templates
 | |
| func GetTemplate(r *http.Request, functions template.FuncMap, templates ...string) (*template.Template, error) {
 | |
| 	// If this is a pjax request, use the minimal template to send only
 | |
| 	// the main content
 | |
| 	if r.Header.Get("X-PJAX") == "true" {
 | |
| 		templates = append(templates, "base_minimal")
 | |
| 	} else {
 | |
| 		templates = append(templates, "base_full")
 | |
| 	}
 | |
| 
 | |
| 	var tpl *template.Template
 | |
| 
 | |
| 	// For each template, add it to the the tpl variable
 | |
| 	for i, t := range templates {
 | |
| 		// Get the template from the assets
 | |
| 		page, err := assets.Asset("templates/" + t + ".tmpl")
 | |
| 
 | |
| 		// Check if there is some error. If so, the template doesn't exist
 | |
| 		if err != nil {
 | |
| 			log.Print(err)
 | |
| 			return new(template.Template), err
 | |
| 		}
 | |
| 
 | |
| 		// If it's the first iteration, creates a new template and add the
 | |
| 		// functions map
 | |
| 		if i == 0 {
 | |
| 			tpl, err = template.New(t).Funcs(functions).Parse(string(page))
 | |
| 		} else {
 | |
| 			tpl, err = tpl.Parse(string(page))
 | |
| 		}
 | |
| 
 | |
| 		if err != nil {
 | |
| 			log.Print(err)
 | |
| 			return new(template.Template), err
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return tpl, nil
 | |
| }
 | |
| 
 | |
| // Dict allows to send more than one variable into a template
 | |
| func Dict(values ...interface{}) (map[string]interface{}, error) {
 | |
| 	if len(values)%2 != 0 {
 | |
| 		return nil, errors.New("invalid dict call")
 | |
| 	}
 | |
| 	dict := make(map[string]interface{}, len(values)/2)
 | |
| 	for i := 0; i < len(values); i += 2 {
 | |
| 		key, ok := values[i].(string)
 | |
| 		if !ok {
 | |
| 			return nil, errors.New("dict keys must be strings")
 | |
| 		}
 | |
| 		dict[key] = values[i+1]
 | |
| 	}
 | |
| 	return dict, nil
 | |
| }
 | |
| 
 | |
| // IsMap checks if some variable is a map
 | |
| func IsMap(sth interface{}) bool {
 | |
| 	return reflect.ValueOf(sth).Kind() == reflect.Map
 | |
| }
 | |
| 
 | |
| // IsSlice checks if some variable is a slice
 | |
| func IsSlice(sth interface{}) bool {
 | |
| 	return reflect.ValueOf(sth).Kind() == reflect.Slice
 | |
| }
 | |
| 
 | |
| // SplitCapitalize splits a string by its uppercase letters and capitalize the
 | |
| // first letter of the string
 | |
| func SplitCapitalize(name string) string {
 | |
| 	var words []string
 | |
| 	l := 0
 | |
| 	for s := name; s != ""; s = s[l:] {
 | |
| 		l = strings.IndexFunc(s[1:], unicode.IsUpper) + 1
 | |
| 		if l <= 0 {
 | |
| 			l = len(s)
 | |
| 		}
 | |
| 		words = append(words, s[:l])
 | |
| 	}
 | |
| 
 | |
| 	name = ""
 | |
| 
 | |
| 	for _, element := range words {
 | |
| 		name += element + " "
 | |
| 	}
 | |
| 
 | |
| 	name = strings.ToLower(name[:len(name)-1])
 | |
| 	name = strings.ToUpper(string(name[0])) + name[1:len(name)]
 | |
| 
 | |
| 	return name
 | |
| }
 | |
| 
 | |
| // ParseComponents parses the components of an URL creating an array
 | |
| func ParseComponents(r *http.Request) []string {
 | |
| 	//The URL that the user queried.
 | |
| 	path := r.URL.Path
 | |
| 	path = strings.TrimSpace(path)
 | |
| 	//Cut off the leading and trailing forward slashes, if they exist.
 | |
| 	//This cuts off the leading forward slash.
 | |
| 	if strings.HasPrefix(path, "/") {
 | |
| 		path = path[1:]
 | |
| 	}
 | |
| 	//This cuts off the trailing forward slash.
 | |
| 	if strings.HasSuffix(path, "/") {
 | |
| 		cutOffLastCharLen := len(path) - 1
 | |
| 		path = path[:cutOffLastCharLen]
 | |
| 	}
 | |
| 	//We need to isolate the individual components of the path.
 | |
| 	components := strings.Split(path, "/")
 | |
| 	return components
 | |
| }
 |