updates
parent
788218e115
commit
e9d507fec3
|
@ -2,6 +2,7 @@ package edit
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
|
@ -24,18 +25,21 @@ func Execute(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||||
err := ioutil.WriteFile(filename, []byte(r.Form["content"][0]), 0666)
|
err := ioutil.WriteFile(filename, []byte(r.Form["content"][0]), 0666)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
log.Print(err)
|
||||||
return 500, err
|
return 500, err
|
||||||
}
|
}
|
||||||
|
|
||||||
commands.Execute()
|
commands.Execute()
|
||||||
} else {
|
} else {
|
||||||
if _, err := os.Stat(filename); os.IsNotExist(err) {
|
if _, err := os.Stat(filename); os.IsNotExist(err) {
|
||||||
|
log.Print(err)
|
||||||
return 404, nil
|
return 404, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
file, err := ioutil.ReadFile(filename)
|
file, err := ioutil.ReadFile(filename)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
log.Print(err)
|
||||||
return 500, err
|
return 500, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
61
page/page.go
61
page/page.go
|
@ -2,52 +2,19 @@ package page
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"html/template"
|
"html/template"
|
||||||
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"reflect"
|
|
||||||
"strings"
|
|
||||||
"unicode"
|
|
||||||
|
|
||||||
"github.com/hacdias/caddy-hugo/assets"
|
"github.com/hacdias/caddy-hugo/assets"
|
||||||
|
"github.com/hacdias/caddy-hugo/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
templateExtension = ".tmpl"
|
templateExtension = ".tmpl"
|
||||||
headerMark = "{{#HEADER#}}"
|
|
||||||
footerMark = "{{#FOOTER#}}"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var funcMap = template.FuncMap{
|
var funcMap = template.FuncMap{
|
||||||
"splitCapitalize": splitCapitalize,
|
"splitCapitalize": utils.SplitCapitalize,
|
||||||
"isMap": isMap,
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: utilspackage
|
|
||||||
func isMap(sth interface{}) bool {
|
|
||||||
return reflect.ValueOf(sth).Kind() == reflect.Map
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: utils package
|
|
||||||
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
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Page type
|
// Page type
|
||||||
|
@ -58,38 +25,34 @@ type Page struct {
|
||||||
|
|
||||||
// Render the page
|
// Render the page
|
||||||
func (p *Page) Render(name string, w http.ResponseWriter) (int, error) {
|
func (p *Page) Render(name string, w http.ResponseWriter) (int, error) {
|
||||||
rawHeader, err := assets.Asset("templates/header" + templateExtension)
|
base, err := assets.Asset("templates/base" + templateExtension)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
log.Print(err)
|
||||||
return 500, err
|
return 500, err
|
||||||
}
|
}
|
||||||
|
|
||||||
header := string(rawHeader)
|
page, err := assets.Asset("templates/" + name + templateExtension)
|
||||||
|
|
||||||
rawFooter, err := assets.Asset("templates/footer" + templateExtension)
|
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
log.Print(err)
|
||||||
return 500, err
|
return 500, err
|
||||||
}
|
}
|
||||||
|
|
||||||
footer := string(rawFooter)
|
tpl, err := template.New("base").Funcs(funcMap).Parse(string(base))
|
||||||
|
|
||||||
rawPage, err := assets.Asset("templates/" + name + templateExtension)
|
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
log.Print(err)
|
||||||
return 500, err
|
return 500, err
|
||||||
}
|
}
|
||||||
|
|
||||||
page := string(rawPage)
|
tpl, err = tpl.Parse(string(page))
|
||||||
page = strings.Replace(page, headerMark, header, -1)
|
|
||||||
page = strings.Replace(page, footerMark, footer, -1)
|
|
||||||
|
|
||||||
tpl, err := template.New("page").Funcs(funcMap).Parse(page)
|
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
log.Print(err)
|
||||||
return 500, err
|
return 500, err
|
||||||
}
|
}
|
||||||
|
|
||||||
tpl.Execute(w, p)
|
tpl.ExecuteTemplate(w, "base", p)
|
||||||
return 200, nil
|
return 200, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,11 +4,18 @@ import (
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
|
"sort"
|
||||||
|
|
||||||
"github.com/hacdias/caddy-hugo/page"
|
"github.com/hacdias/caddy-hugo/page"
|
||||||
|
"github.com/hacdias/caddy-hugo/utils"
|
||||||
"github.com/spf13/hugo/parser"
|
"github.com/spf13/hugo/parser"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type settings struct {
|
||||||
|
Settings interface{}
|
||||||
|
Keys []string
|
||||||
|
}
|
||||||
|
|
||||||
// Execute the page
|
// Execute the page
|
||||||
func Execute(w http.ResponseWriter, r *http.Request) (int, error) {
|
func Execute(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||||
if r.Method == "POST" {
|
if r.Method == "POST" {
|
||||||
|
@ -27,9 +34,14 @@ func Execute(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||||
return 500, err
|
return 500, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// configIndex := getConfigNames(config)
|
||||||
|
|
||||||
|
cnf := new(settings)
|
||||||
|
cnf.Settings = getConfigNames(config, "")
|
||||||
|
|
||||||
page := new(page.Page)
|
page := new(page.Page)
|
||||||
page.Title = "settings"
|
page.Title = "Settings"
|
||||||
page.Body = config
|
page.Body = cnf
|
||||||
return page.Render("settings", w)
|
return page.Render("settings", w)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -54,21 +66,6 @@ func getConfigFrontMatter() string {
|
||||||
return frontmatter
|
return frontmatter
|
||||||
}
|
}
|
||||||
|
|
||||||
func getConfig(frontmatter string) (interface{}, error) {
|
|
||||||
content := getConfigFileContent(frontmatter)
|
|
||||||
|
|
||||||
switch frontmatter {
|
|
||||||
case "yaml":
|
|
||||||
return parser.HandleYAMLMetaData(content)
|
|
||||||
case "json":
|
|
||||||
return parser.HandleJSONMetaData(content)
|
|
||||||
case "toml":
|
|
||||||
return parser.HandleTOMLMetaData(content)
|
|
||||||
}
|
|
||||||
|
|
||||||
return []string{}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func getConfigFileContent(frontmatter string) []byte {
|
func getConfigFileContent(frontmatter string) []byte {
|
||||||
file, err := ioutil.ReadFile("config." + frontmatter)
|
file, err := ioutil.ReadFile("config." + frontmatter)
|
||||||
|
|
||||||
|
@ -79,3 +76,66 @@ func getConfigFileContent(frontmatter string) []byte {
|
||||||
|
|
||||||
return file
|
return file
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// make it generic to frontmatter. everything bellow -> new file
|
||||||
|
func getConfig(frontmatter string) (interface{}, error) {
|
||||||
|
content := getConfigFileContent(frontmatter)
|
||||||
|
// config := []string{}
|
||||||
|
|
||||||
|
// get the config into a map
|
||||||
|
if frontmatter == "yaml" {
|
||||||
|
return parser.HandleYAMLMetaData(content)
|
||||||
|
} else if frontmatter == "json" {
|
||||||
|
return parser.HandleJSONMetaData(content)
|
||||||
|
} else if frontmatter == "toml" {
|
||||||
|
return parser.HandleTOMLMetaData(content)
|
||||||
|
}
|
||||||
|
|
||||||
|
return []string{}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type conf struct {
|
||||||
|
Name string
|
||||||
|
Master string
|
||||||
|
Content interface{}
|
||||||
|
SubContent bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func getConfigNames(config interface{}, master string) interface{} {
|
||||||
|
var mapsNames []string
|
||||||
|
var stringsNames []string
|
||||||
|
|
||||||
|
for index, element := range config.(map[string]interface{}) {
|
||||||
|
if utils.IsMap(element) {
|
||||||
|
mapsNames = append(mapsNames, index)
|
||||||
|
} else {
|
||||||
|
stringsNames = append(stringsNames, index)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sort.Strings(mapsNames)
|
||||||
|
sort.Strings(stringsNames)
|
||||||
|
names := append(stringsNames, mapsNames...)
|
||||||
|
|
||||||
|
settings := make([]interface{}, len(names))
|
||||||
|
|
||||||
|
for index := range names {
|
||||||
|
c := new(conf)
|
||||||
|
c.Name = names[index]
|
||||||
|
c.Master = master
|
||||||
|
c.SubContent = false
|
||||||
|
|
||||||
|
i := config.(map[string]interface{})[names[index]]
|
||||||
|
|
||||||
|
if utils.IsMap(i) {
|
||||||
|
c.Content = getConfigNames(i, c.Name)
|
||||||
|
c.SubContent = true
|
||||||
|
} else {
|
||||||
|
c.Content = i
|
||||||
|
}
|
||||||
|
|
||||||
|
settings[index] = c
|
||||||
|
}
|
||||||
|
|
||||||
|
return settings
|
||||||
|
}
|
||||||
|
|
|
@ -30,3 +30,7 @@ textarea {
|
||||||
border: 0;
|
border: 0;
|
||||||
font-family: inherit;
|
font-family: inherit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.block {
|
||||||
|
margin: 1em 0;
|
||||||
|
}
|
||||||
|
|
|
@ -20,3 +20,9 @@
|
||||||
<header class="site-header">
|
<header class="site-header">
|
||||||
Admin
|
Admin
|
||||||
</header>
|
</header>
|
||||||
|
|
||||||
|
{{ template "content" . }}
|
||||||
|
|
||||||
|
<footer></footer>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -1,4 +1,4 @@
|
||||||
{{#HEADER#}}
|
{{ define "content" }}
|
||||||
{{ with .Body }}
|
{{ with .Body }}
|
||||||
|
|
||||||
<div class="content">
|
<div class="content">
|
||||||
|
@ -13,4 +13,4 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{#FOOTER#}}
|
{{ end }}
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
<footer>
|
|
||||||
|
|
||||||
</footer>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
|
@ -1,4 +1,18 @@
|
||||||
{{#HEADER#}}
|
{{ define "optsLoop" }}
|
||||||
|
{{ range $key, $value := . }}
|
||||||
|
{{ if $value.SubContent }}
|
||||||
|
<h2>{{ splitCapitalize $value.Name }}</h2>
|
||||||
|
{{ template "optsLoop" $value.Content }}
|
||||||
|
{{ else}}
|
||||||
|
|
||||||
|
<label for="{{ $value.Master }}_{{ $value.Name }}">{{ splitCapitalize $value.Name }}</label>
|
||||||
|
<input name="{{ $value.Master }}_{{ $value.Name }}" id="{{ $value.Master }}_{{ $value.Name }}" value="{{ $value.Content }}"></input><br>
|
||||||
|
{{ end }}
|
||||||
|
{{ end }}
|
||||||
|
{{ end }}
|
||||||
|
|
||||||
|
|
||||||
|
{{ define "content" }}
|
||||||
{{ with .Body }}
|
{{ with .Body }}
|
||||||
|
|
||||||
<div class="content">
|
<div class="content">
|
||||||
|
@ -6,25 +20,11 @@
|
||||||
<h1>Settings</h1>
|
<h1>Settings</h1>
|
||||||
|
|
||||||
<form>
|
<form>
|
||||||
{{ range $key, $value := . }}
|
{{ template "optsLoop" .Settings }}
|
||||||
{{ if isMap $value }}
|
|
||||||
<h2>{{ splitCapitalize $key }}</h2>
|
|
||||||
|
|
||||||
<div id="{{ $key }}">
|
|
||||||
<!-- call this range again -->
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{{ else }}
|
|
||||||
|
|
||||||
<label for="{{ $key }}">{{ splitCapitalize $key }}</label>
|
|
||||||
<input name="{{ $key }}" id="{{ $key }}" value="{{ $value }}"></input><br>
|
|
||||||
|
|
||||||
{{ end }}
|
|
||||||
{{ end }}
|
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{#FOOTER#}}
|
{{ end }}
|
||||||
|
|
|
@ -0,0 +1,51 @@
|
||||||
|
package utils
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"reflect"
|
||||||
|
"strings"
|
||||||
|
"unicode"
|
||||||
|
)
|
||||||
|
|
||||||
|
// 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
|
||||||
|
}
|
||||||
|
|
||||||
|
func IsMap(sth interface{}) bool {
|
||||||
|
return reflect.ValueOf(sth).Kind() == reflect.Map
|
||||||
|
}
|
||||||
|
|
||||||
|
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
|
||||||
|
}
|
Loading…
Reference in New Issue