Blame view

go/src/themaru/vendor/github.com/gin-contrib/multitemplate/README.md 2.96 KB
476d2547e   김태훈   태마루 시스템 설정 / 업데이트...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
  # Multitemplate
  
  [![Build Status](https://travis-ci.org/gin-contrib/multitemplate.svg)](https://travis-ci.org/gin-contrib/multitemplate)
  [![codecov](https://codecov.io/gh/gin-contrib/multitemplate/branch/master/graph/badge.svg)](https://codecov.io/gh/gin-contrib/multitemplate)
  [![Go Report Card](https://goreportcard.com/badge/github.com/gin-contrib/multitemplate)](https://goreportcard.com/report/github.com/gin-contrib/multitemplate)
  [![GoDoc](https://godoc.org/github.com/gin-contrib/multitemplate?status.svg)](https://godoc.org/github.com/gin-contrib/multitemplate)
  
  This is a custom HTML render to support multi templates, ie. more than one `*template.Template`.
  
  ## Usage
  
  ### Start using it
  
  Download and install it:
  
  ```sh
  $ go get github.com/gin-contrib/multitemplate
  ```
  
  Import it in your code:
  
  ```go
  import "github.com/gin-contrib/multitemplate"
  ```
  
  ### Simple example
  
  See [example/simple/example.go](example/simple/example.go)
  
  [embedmd]:# (example/simple/example.go go)
  ```go
  package main
  
  import (
  	"github.com/gin-contrib/multitemplate"
  	"github.com/gin-gonic/gin"
  )
  
  func createMyRender() multitemplate.Renderer {
  	r := multitemplate.NewRenderer()
  	r.AddFromFiles("index", "templates/base.html", "templates/index.html")
  	r.AddFromFiles("article", "templates/base.html", "templates/index.html", "templates/article.html")
  	return r
  }
  
  func main() {
  	router := gin.Default()
  	router.HTMLRender = createMyRender()
  	router.GET("/", func(c *gin.Context) {
  		c.HTML(200, "index", gin.H{
  			"title": "Html5 Template Engine",
  		})
  	})
  	router.GET("/article", func(c *gin.Context) {
  		c.HTML(200, "article", gin.H{
  			"title": "Html5 Article Engine",
  		})
  	})
  	router.Run(":8080")
  }
  ```
  
  ### Advanced example
  
  [Approximating html/template Inheritance](https://elithrar.github.io/article/approximating-html-template-inheritance/)
  
  See [example/advanced/example.go](example/advanced/example.go)
  
  [embedmd]:# (example/advanced/example.go go)
  ```go
  package main
  
  import (
  	"path/filepath"
  
  	"github.com/gin-contrib/multitemplate"
  	"github.com/gin-gonic/gin"
  )
  
  func main() {
  	router := gin.Default()
  	router.HTMLRender = loadTemplates("./templates")
  	router.GET("/", func(c *gin.Context) {
  		c.HTML(200, "index.html", gin.H{
  			"title": "Welcome!",
  		})
  	})
  	router.GET("/article", func(c *gin.Context) {
  		c.HTML(200, "article.html", gin.H{
  			"title": "Html5 Article Engine",
  		})
  	})
  
  	router.Run(":8080")
  }
  
  func loadTemplates(templatesDir string) multitemplate.Renderer {
  	r := multitemplate.NewRenderer()
  
  	layouts, err := filepath.Glob(templatesDir + "/layouts/*.html")
  	if err != nil {
  		panic(err.Error())
  	}
  
  	includes, err := filepath.Glob(templatesDir + "/includes/*.html")
  	if err != nil {
  		panic(err.Error())
  	}
  
  	// Generate our templates map from our layouts/ and includes/ directories
  	for _, include := range includes {
  		layoutCopy := make([]string, len(layouts))
  		copy(layoutCopy, layouts)
  		files := append(layoutCopy, include)
  		r.AddFromFiles(filepath.Base(include), files...)
  	}
  	return r
  }
  ```