// Controller to handle submission for content type change form. func ContentTypeEditorSubmit(w *wrapper.Wrapper) { elementid := w.APIParams[0] e, err := elements.LoadContentElement(elementid, w) if err != nil { errmessage := fmt.Sprintf("Element not found to edit for %s by %s", elementid, w.Request.Host) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("This element was not found", "Error", w) w.Serve() return } type Post struct { Type string `json:"type"` } var post Post err = form.GetValidFormData(w, &post) if err != nil { return } e.ContentValues.Type = post.Type err = e.Save(w) if err != nil { errmessage := fmt.Sprintf("Element not saved %s by %s", w.APIParams[0], w.Request.Host) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("Unable to save element.", "Error", w) } else { services.AddMessage("Element content type saved.", "Success", w) } w.Serve() return }
// Controller to handle content editor submission. func ContentEditorSubmit(w *wrapper.Wrapper) { elementid := w.APIParams[0] e, err := elements.LoadContentElement(elementid, w) post := make(map[string]interface{}) err = form.GetValidFormData(w, &post) if err != nil { return } e.ContentValues.Content = post delete(e.ContentValues.Content, "mongolartype") delete(e.ContentValues.Content, "mongolarid") delete(e.ContentValues.Content, "form_id") err = e.Save(w) if err != nil { errmessage := fmt.Sprintf("Element not saved %s by %s", w.APIParams[0], w.Request.Host) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("Unable to save element.", "Error", w) w.Serve() return } services.AddMessage("Element content saved.", "Success", w) dynamic := services.Dynamic{ Target: elementid, Id: elementid, Controller: "admin/element", Template: "admin/element.html", } services.SetDynamic(dynamic, w) w.Serve() return }
// Controller for adding existing element to path form submission. func AddExistingPathSubmit(w *wrapper.Wrapper) { parentid := w.APIParams[0] var post map[string]string err := form.GetValidFormData(w, &post) if err != nil { return } var parent paths.Path parent, err = paths.LoadPath(parentid, w) if err != nil { errmessage := fmt.Sprintf("Unable to loap parent element by %s : %s", w.Request.Host, err.Error()) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("Could not load parent element.", "Error", w) w.Serve() return } parent.Elements = append(parent.Elements, post["element"]) err = parent.Save(w) if err != nil { errmessage := fmt.Sprintf("Unable to save parent element by %s : %s", w.Request.Host, err.Error()) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("Could not save parent element.", "Error", w) w.Serve() return } dynamic := services.Dynamic{ Target: "centereditor", Controller: "admin/path_elements", Template: "admin/path_elements.html", Id: parentid, } services.SetDynamic(dynamic, w) services.AddMessage("You have added an existing element.", "Success", w) w.Serve() }
func SlugUrlEditorSubmit(w *wrapper.Wrapper) { slugid := w.APIParams[0] post := make(map[string]string) err := form.GetValidFormData(w, &post) if err != nil { return } vals := make(map[string]string) for id, slug := range post { if bson.IsObjectIdHex(id) { vals[slug] = id } } var e elements.SlugElement e, err = elements.LoadSlugElement(slugid, w) if err != nil { errmessage := fmt.Sprintf("Element not found to edit for %s by %s", slugid, w.Request.Host) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("Unable to load parent slug", "Error", w) w.Serve() return } e.Slugs = vals err = e.Save(w) if err != nil { errmessage := fmt.Sprintf("Slugs not saved %s by %s", w.APIParams[0], w.Request.Host) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("Unable to save slug values.", "Error", w) w.Serve() return } services.AddMessage("Slug values updated.", "Success", w) w.Serve() return }
// Controller to handle path editor form submissions. func PathEditorSubmit(w *wrapper.Wrapper) { pathid := w.APIParams[0] var path paths.Path var err error if pathid != "new" { path, err = paths.LoadPath(pathid, w) if err != nil { errmessage := fmt.Sprintf("Unable to save path %s by %s: %s", pathid, w.Request.Host, err.Error()) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("There was a problem saving your path.", "Error", w) w.Serve() return } } err = form.GetValidFormData(w, &path) if err != nil { return } err = path.Save(w) if err != nil { errmessage := fmt.Sprintf("Unable to save path %s by %s: %s", pathid, w.Request.Host, err.Error()) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("There was a problem saving your path.", "Error", w) w.Serve() return } services.AddMessage("Your path was saved.", "Success", w) dynamic := services.Dynamic{ Target: "pathbar", Controller: "admin/paths", Template: "admin/path_list.html", } services.SetDynamic(dynamic, w) w.Serve() return }
// Controller to edit an elements properties // TODO: break this into smaller functions to make it easier to maintain func ElementEditor(w *wrapper.Wrapper) { var elementid string if len(w.APIParams) > 0 { elementid = w.APIParams[0] } else { http.Error(w.Writer, "Forbidden", 403) } if w.Request.Method != "POST" { f := form.NewForm() f.AddText("title", "text").AddLabel("Title") op := make([]map[string]string, 0) for _, ec := range w.SiteConfig.ElementControllers { uc := []rune(ec) uc[0] = unicode.ToUpper(uc[0]) name := string(uc) op = append(op, map[string]string{"name": name, "value": ec}) } f.AddSelect("controller", op).AddLabel("Controller") f.AddText("template", "text").AddLabel("Template") f.AddText("dyn", "text").AddLabel("Dynamic Id") f.AddText("classes", "text").AddLabel("Classes") f.AddText("id", "text").Hidden() if elementid != "new" { e := elements.NewElement() err := elements.GetById(elementid, &e, w) if err != nil { errmessage := fmt.Sprintf("Element not found to edit for %s by %s", elementid, w.Request.Host, err.Error()) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("This element was not found", "Error", w) w.Serve() return } // Have to do this for namespacing stuff on the AngularJs side. data := map[string]string{ "controller": e.Controller, "template": e.Template, "dyn": e.DynamicId, "classes": e.Classes, "id": e.MongoId.Hex(), "title": e.Title, } f.FormData = data } f.Register(w) w.SetTemplate("admin/form.html") w.SetPayload("form", f) } else { post := make(map[string]string) err := form.GetValidFormData(w, &post) if err != nil { return } else { c := w.DbSession.DB("").C("elements") if post["mongolarid"] == "new" { p := elements.Element{ Controller: post["controller"], DynamicId: post["dyn"], Template: post["template"], Title: post["title"], Classes: post["classes"], } err := c.Insert(p) if err != nil { errmessage := fmt.Sprintf("Unable to save new element by %s : %s", w.Request.Host, err.Error()) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("There was a problem saving your element.", "Error", w) } else { services.AddMessage("Your element was saved.", "Success", w) } } else { p := bson.M{ "$set": bson.M{ "template": post["template"], "title": post["title"], "dynamic_id": post["dyn"], "controller": post["controller"], "classes": post["classes"], }, } s := bson.M{"_id": bson.ObjectIdHex(post["mongolarid"])} err := c.Update(s, p) if err != nil { errmessage := fmt.Sprintf("Unable to save element %s by %s : %s", post["mongolarid"], w.Request.Host, err.Error()) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("There was a problem saving your element.", "Error", w) } else { services.AddMessage("Your element was saved.", "Success", w) dynamic := services.Dynamic{ Target: post["mongolarid"], Id: post["mongolarid"], Controller: "admin/element", Template: "admin/element.html", } services.SetDynamic(dynamic, w) } } } } w.Serve() return }
func EditContentTypeSubmit(w *wrapper.Wrapper) { post := make(map[string]interface{}) err := form.GetValidFormData(w, &post) if err != nil { return } elements := reflect.ValueOf(post["elements"]) f := form.NewForm() for i := 0; i < elements.Len(); i++ { var field *form.Field element := elements.Index(i).Interface().(map[string]interface{}) switch element["type"].(string) { case "input": field = f.AddText(element["key"].(string), "text") case "textarea": field = f.AddTextArea(element["key"].(string)) case "radio": values := strings.Split(element["options"].(string), "\n") opt := make([]map[string]string, 0) for _, value := range values { namval := strings.Split(value, "|") if len(namval) < 2 { errmessage := fmt.Sprintf("Attempt to set incorrect form option %s by %s", value, w.Request.Host) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("Your options must be of the format Name|Value", "Error", w) w.Serve() return } newval := map[string]string{ "name": namval[0], "value": namval[1], } opt = append(opt, newval) } field = f.AddRadio(element["key"].(string), opt) case "checkbox": field = f.AddCheckBox(element["key"].(string)) default: //TODO messaging and logging return } if _, ok := element["label"]; ok { if element["label"].(string) != "" { field.AddLabel(element["label"].(string)) } } if _, ok := element["placeholder"]; ok { if element["placeholder"].(string) != "" { field.AddPlaceHolder(element["placeholder"].(string)) } } if _, ok := element["rows"]; ok { if _, ok := element["cols"]; ok { if element["rows"].(float64) != 0 && element["cols"] != 0 { field.AddRowsCols(int(element["rows"].(float64)), int(element["cols"].(float64))) } } } } var id bson.ObjectId if post["mongolarid"].(string) == "new" { id = bson.NewObjectId() } else { id = bson.ObjectIdHex(post["mongolarid"].(string)) } ct := ContentType{ Form: f.Fields, Type: post["content_type"].(string), MongoId: id, } s := bson.M{"_id": id} c := w.DbSession.DB("").C("content_types") _, err = c.Upsert(s, ct) if err != nil { errmessage := fmt.Sprintf("Cannnot save content type %s : %s", post["mongolarid"].(string), err.Error()) w.SiteConfig.Logger.Error(errmessage) services.AddMessage("Unable to save content type.", "Error", w) w.Serve() return } services.AddMessage("Content type saved.", "Success", w) dynamic := services.Dynamic{ Target: "contenttypelist", Controller: "admin/all_content_types", Template: "admin/content_type_list.html", } services.SetDynamic(dynamic, w) w.Serve() return }