Compare commits
2 commits
cb6c12354a
...
fd8e140897
| Author | SHA1 | Date | |
|---|---|---|---|
| fd8e140897 | |||
| e2c59d5f28 |
4 changed files with 38 additions and 7 deletions
|
|
@ -58,3 +58,8 @@ func LoadNote(title string) (*Note, error) {
|
||||||
}
|
}
|
||||||
return &Note{Title: title, Body: body}, nil
|
return &Note{Title: title, Body: body}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func DeleteNote(title string) error {
|
||||||
|
filename := filepath.Join(conf.Conf.NotesDir, fmtPath(title))
|
||||||
|
return os.Remove(filename)
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -19,10 +19,11 @@ func GetRoutes(prefix string) *http.ServeMux {
|
||||||
myurls = urls.URLs{
|
myurls = urls.URLs{
|
||||||
Prefix: prefix,
|
Prefix: prefix,
|
||||||
URLs: map[string]urls.URL{
|
URLs: map[string]urls.URL{
|
||||||
"view": {Path: "/{note}/", Protocol: "GET", Handler: view},
|
"view": {Path: "/{note}/", Protocol: "GET", Handler: view},
|
||||||
"edit": {Path: "/{note}/edit/", Protocol: "GET", Handler: edit},
|
"delete": {Path: "/{note}/delete/", Protocol: "GET", Handler: delete},
|
||||||
"save": {Path: "/{note}/edit/save/", Protocol: "POST", Handler: save},
|
"edit": {Path: "/{note}/edit/", Protocol: "GET", Handler: edit},
|
||||||
"list": {Path: "/", Protocol: "GET", Handler: list},
|
"save": {Path: "/{note}/edit/save/", Protocol: "POST", Handler: save},
|
||||||
|
"list": {Path: "/", Protocol: "GET", Handler: list},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
return myurls.GetRouter()
|
return myurls.GetRouter()
|
||||||
|
|
@ -32,12 +33,13 @@ func view(w http.ResponseWriter, r *http.Request) {
|
||||||
title := r.PathValue("note")
|
title := r.PathValue("note")
|
||||||
note, err := notes.LoadNote(title)
|
note, err := notes.LoadNote(title)
|
||||||
urlEdit := myurls.Reverse("edit", urls.Repl{"note": title})
|
urlEdit := myurls.Reverse("edit", urls.Repl{"note": title})
|
||||||
|
urlDelete := myurls.Reverse("delete", urls.Repl{"note": title})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
http.Redirect(w, r, urlEdit, http.StatusFound)
|
http.Redirect(w, r, urlEdit, http.StatusFound)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
context := templ.Ctx{"note": note, "urlEdit": urlEdit}
|
context := templ.Ctx{"note": note, "urlEdit": urlEdit, "urlDelete": urlDelete}
|
||||||
note.Render()
|
note.Render()
|
||||||
err = templ.RenderTemplate(w, "view.tmpl.html", context)
|
err = templ.RenderTemplate(w, "view.tmpl.html", context)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
@ -64,11 +66,31 @@ func edit(w http.ResponseWriter, r *http.Request) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func save(w http.ResponseWriter, r *http.Request) {
|
func delete(w http.ResponseWriter, r *http.Request) {
|
||||||
title := r.PathValue("note")
|
title := r.PathValue("note")
|
||||||
|
err := notes.DeleteNote(title)
|
||||||
|
if err != nil {
|
||||||
|
log.Print(err.Error())
|
||||||
|
http.Error(w, "Couldn't delete note", http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
urlDelete := myurls.Reverse("list", urls.Repl{})
|
||||||
|
http.Redirect(w, r, urlDelete, http.StatusFound)
|
||||||
|
}
|
||||||
|
|
||||||
|
func save(w http.ResponseWriter, r *http.Request) {
|
||||||
|
oldTitle := r.PathValue("note")
|
||||||
|
title := r.FormValue("title")
|
||||||
body := r.FormValue("body")
|
body := r.FormValue("body")
|
||||||
|
|
||||||
note := ¬es.Note{Title: title, Body: []byte(body)}
|
note := ¬es.Note{Title: title, Body: []byte(body)}
|
||||||
note.Save()
|
note.Save()
|
||||||
|
|
||||||
|
if oldTitle != title {
|
||||||
|
notes.DeleteNote(oldTitle)
|
||||||
|
}
|
||||||
|
|
||||||
http.Redirect(w, r, myurls.Reverse("view", urls.Repl{"note": title}), http.StatusFound)
|
http.Redirect(w, r, myurls.Reverse("view", urls.Repl{"note": title}), http.StatusFound)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,10 @@
|
||||||
{{define "main"}}
|
{{define "main"}}
|
||||||
<form action="{{.urlSave}}" method="POST">
|
<form action="{{.urlSave}}" method="POST">
|
||||||
<div class="mb-3">
|
<div class="mb-3">
|
||||||
<label for="noteBodyInput" class="form-label">Note</label>
|
<input type="text" class="form-control" id="noteTitleInput" name="title" aria-described-by="titleHelp" value="{{.note.Title}}"/>
|
||||||
|
<div id="titleHelp" class="form-text">Enter your note title</div>
|
||||||
|
</div>
|
||||||
|
<div class="mb-3">
|
||||||
<div class="border rounded rounded-1">
|
<div class="border rounded rounded-1">
|
||||||
<div id="toolbar"></div>
|
<div id="toolbar"></div>
|
||||||
<textarea class="form-control" id="noteBodyInput" name="body" aria-described-by="bodyHelp">{{.text}}</textarea>
|
<textarea class="form-control" id="noteBodyInput" name="body" aria-described-by="bodyHelp">{{.text}}</textarea>
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<a href="{{.urlEdit}}">Edit</a>
|
<a href="{{.urlEdit}}">Edit</a>
|
||||||
|
<a href="{{.urlDelete}}">Delete</a>
|
||||||
</div>
|
</div>
|
||||||
{{end}}
|
{{end}}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue