Much progress
This commit is contained in:
parent
ca35e6760d
commit
c6975d3814
6 changed files with 133 additions and 19 deletions
|
|
@ -4,7 +4,9 @@ import (
|
|||
"html/template"
|
||||
"log"
|
||||
"net/http"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"strings"
|
||||
|
||||
"gitea.gwairfelin.com/max/gonotes/internal/conf"
|
||||
"gitea.gwairfelin.com/max/gonotes/internal/notes"
|
||||
|
|
@ -17,15 +19,16 @@ func GetRoutes(prefix string) *http.ServeMux {
|
|||
myurls = urls.URLs{
|
||||
Prefix: prefix,
|
||||
URLs: map[string]urls.URL{
|
||||
"view": {Path: "/{note}/", Protocol: "GET", Handler: viewHandler},
|
||||
"edit": {Path: "/{note}/edit/", Protocol: "GET", Handler: editHandler},
|
||||
"save": {Path: "/{note}/edit/save/", Protocol: "POST", Handler: saveHandler},
|
||||
"view": {Path: "/{note}/", Protocol: "GET", Handler: view},
|
||||
"edit": {Path: "/{note}/edit/", Protocol: "GET", Handler: edit},
|
||||
"save": {Path: "/{note}/edit/save/", Protocol: "POST", Handler: save},
|
||||
"list": {Path: "/", Protocol: "GET", Handler: list},
|
||||
},
|
||||
}
|
||||
return myurls.GetRouter()
|
||||
}
|
||||
|
||||
func viewHandler(w http.ResponseWriter, r *http.Request) {
|
||||
func view(w http.ResponseWriter, r *http.Request) {
|
||||
title := r.PathValue("note")
|
||||
note, err := notes.LoadNote(title)
|
||||
if err != nil {
|
||||
|
|
@ -36,13 +39,13 @@ func viewHandler(w http.ResponseWriter, r *http.Request) {
|
|||
note.Render()
|
||||
err = renderTemplate(w, "view.html", note)
|
||||
if err != nil {
|
||||
log.Println(err)
|
||||
log.Print(err.Error())
|
||||
http.Error(w, "Couldn't load template", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
func editHandler(w http.ResponseWriter, r *http.Request) {
|
||||
func edit(w http.ResponseWriter, r *http.Request) {
|
||||
title := r.PathValue("note")
|
||||
note, err := notes.LoadNote(title)
|
||||
if err != nil {
|
||||
|
|
@ -51,13 +54,13 @@ func editHandler(w http.ResponseWriter, r *http.Request) {
|
|||
|
||||
err = renderTemplate(w, "edit.html", note)
|
||||
if err != nil {
|
||||
log.Println(err)
|
||||
log.Print(err.Error())
|
||||
http.Error(w, "Couldn't load template", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
func saveHandler(w http.ResponseWriter, r *http.Request) {
|
||||
func save(w http.ResponseWriter, r *http.Request) {
|
||||
title := r.PathValue("note")
|
||||
body := r.FormValue("body")
|
||||
note := ¬es.Note{Title: title, Body: []byte(body)}
|
||||
|
|
@ -65,8 +68,37 @@ func saveHandler(w http.ResponseWriter, r *http.Request) {
|
|||
http.Redirect(w, r, myurls.Reverse("view", map[string]string{"note": title}), http.StatusFound)
|
||||
}
|
||||
|
||||
func renderTemplate(w http.ResponseWriter, tmpl string, note *notes.Note) error {
|
||||
t, err := template.ParseFiles(filepath.Join(conf.Conf.TemplatesDir, tmpl))
|
||||
t.Execute(w, note)
|
||||
func list(w http.ResponseWriter, r *http.Request) {
|
||||
files, err := os.ReadDir(conf.Conf.NotesDir)
|
||||
if err != nil {
|
||||
log.Print(err.Error())
|
||||
http.Error(w, "Internal Server Error", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
|
||||
titles := make([]string, 0)
|
||||
|
||||
for _, f := range files {
|
||||
if !f.IsDir() {
|
||||
title := strings.TrimSuffix(f.Name(), filepath.Ext(f.Name()))
|
||||
titles = append(titles, title)
|
||||
}
|
||||
}
|
||||
|
||||
err = renderTemplate(w, "list.tmpl.html", map[string]any{"titles": titles})
|
||||
if err != nil {
|
||||
log.Print(err.Error())
|
||||
http.Error(w, "Internal Server Error", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
func renderTemplate(w http.ResponseWriter, tmpl string, context any) error {
|
||||
files := []string{
|
||||
filepath.Join(conf.Conf.TemplatesDir, "base.tmpl.html"),
|
||||
filepath.Join(conf.Conf.TemplatesDir, tmpl),
|
||||
}
|
||||
t, err := template.ParseFiles(files...)
|
||||
t.ExecuteTemplate(w, "base", context)
|
||||
return err
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue