editor technically works

This commit is contained in:
Bel LaPointe
2022-02-15 16:08:24 -07:00
parent 0e1ced34b2
commit 701ba9c48f
4 changed files with 64 additions and 6 deletions

View File

@@ -222,17 +222,57 @@ func (server *Server) uiSearchHandler(w http.ResponseWriter, r *http.Request) er
data[i].ID = idsTitles[i][0]
data[i].Title = idsTitles[i][1]
}
log.Printf("ui search: %v", data)
return t.Lookup("search").Execute(w, map[string]interface{}{"Results": data})
}
func (server *Server) uiFilesHandler(w http.ResponseWriter, r *http.Request) error {
r.URL.Path = strings.TrimPrefix(r.URL.Path, "/ui/files")
id := strings.Split(strings.TrimPrefix(r.URL.Path, "/"), "/")
if len(id) == 0 || (len(id) == 1 && id[0] == "") {
return server.rootHandler(w, r)
}
t, err := server.uiSubTemplates()
if err != nil {
return err
}
return t.Lookup("files").Execute(w, "TODO data")
t, err = t.ParseFiles(path.Join(server.root, "ui", "files.ctmpl"))
if err != nil {
return err
}
tree := server.tree()
branches, err := tree.GetRootMeta()
if err != nil {
return err
}
branchesJSON, err := json.Marshal(branches)
if err != nil {
return err
}
var parent Leaf
if len(id) > 1 {
parent, err = tree.Get(id[:len(id)-1])
if err != nil {
return err
}
}
leaf, err := tree.Get(id)
if err != nil {
if len(id) > 1 && parent.Title == "" {
return err
}
}
data := map[string]interface{}{
"This": map[string]string{
"Title": leaf.Title,
"Content": leaf.Content,
"ID": r.URL.Path,
"PID": path.Dir(r.URL.Path),
"PTitle": parent.Title,
},
"Tree": string(branchesJSON),
}
log.Printf("%v => %+v", id, data)
return t.Lookup("files").Execute(w, data)
}
func (server *Server) uiSubTemplates() (*template.Template, error) {
@@ -263,7 +303,7 @@ func (server *Server) uiSubTemplates() (*template.Template, error) {
}
func (server *Server) rootHandler(w http.ResponseWriter, r *http.Request) error {
http.Redirect(w, r, "/ui/files", 301)
http.Redirect(w, r, "/ui/files/"+uuid.New().String()[:5], 301)
return nil
}