summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteve Manuel <nilslice@gmail.com>2017-01-11 14:04:31 -0800
committerSteve Manuel <nilslice@gmail.com>2017-01-11 14:04:31 -0800
commitad3572b01a17ff5a5d6722f097973f448261b2de (patch)
tree491c44128f02ec03163d2a5e98078ba3b83a10df
parentac82561825ab76f2b5db5c4086541e590fcb70cb (diff)
hiding UI elements when not needed, adding save addon routine
-rw-r--r--management/editor/editor.go9
-rw-r--r--system/admin/handlers.go62
2 files changed, 69 insertions, 2 deletions
diff --git a/management/editor/editor.go b/management/editor/editor.go
index 404e7cd..66a0a7d 100644
--- a/management/editor/editor.go
+++ b/management/editor/editor.go
@@ -149,12 +149,15 @@ func Form(post Editable, fields ...Field) ([]byte, error) {
del = form.find('button.delete-post'),
external = form.find('.post-controls.external'),
id = form.find('input[name=id]'),
- timestamp = $('.__ponzu.content-only');
+ timestamp = $('.__ponzu.content-only'),
+ slug = $('input[name=slug]'),
+ hiddenInput = $('input[type=hidden]');
// hide if this is a new post, or a non-post editor page
if (id.val() === '-1' || form.attr('action') !== '/admin/edit') {
del.hide();
external.hide();
+ hiddenInput.parent().hide();
}
// hide approval if not on a pending content item
@@ -162,9 +165,11 @@ func Form(post Editable, fields ...Field) ([]byte, error) {
external.hide();
}
- // no timestamp on addons
+ // no timestamp, slug or hidden input parents visible on addons
if (form.attr('action') === '/admin/addon') {
timestamp.hide();
+ slug.hide();
+ hiddenInput.parent().hide();
}
save.on('click', function(e) {
diff --git a/system/admin/handlers.go b/system/admin/handlers.go
index a8ca681..a7d367b 100644
--- a/system/admin/handlers.go
+++ b/system/admin/handlers.go
@@ -2181,6 +2181,68 @@ func addonHandler(res http.ResponseWriter, req *http.Request) {
res.Write(addonView)
case http.MethodPost:
+ // save req.Form
+ err := req.ParseMultipartForm(1024 * 1024 * 4) // maxMemory 4MB
+ if err != nil {
+ log.Println(err)
+ res.WriteHeader(http.StatusInternalServerError)
+ errView, err := Error500()
+ if err != nil {
+ return
+ }
+
+ res.Write(errView)
+ return
+ }
+
+ name := req.FormValue("addon_name")
+ id := req.FormValue("addon_reverse_dns")
+
+ at, ok := addon.Types[id]
+ if !ok {
+ log.Println("Error: addon", name, "has no record in addon.Types map at", id)
+ res.WriteHeader(http.StatusBadRequest)
+ errView, err := Error400()
+ if err != nil {
+ return
+ }
+
+ res.Write(errView)
+ return
+ }
+
+ // if Hookable, call BeforeSave prior to saving
+ h, ok := at().(item.Hookable)
+ if ok {
+ err := h.BeforeSave(req)
+ if err != nil {
+ log.Println(err)
+ res.WriteHeader(http.StatusInternalServerError)
+ errView, err := Error500()
+ if err != nil {
+ return
+ }
+
+ res.Write(errView)
+ return
+ }
+ }
+
+ err := db.SetAddon(req.Form)
+ if err != nil {
+ log.Println("Error saving addon:", name, err)
+ res.WriteHeader(http.StatusInternalServerError)
+ errView, err := Error500()
+ if err != nil {
+ return
+ }
+
+ res.Write(errView)
+ return
+ }
+
+ http.Redirect(res, req, "/admin/addon?id="+id, http.StatusFound)
+
default:
res.WriteHeader(http.StatusBadRequest)
errView, err := Error405()