summaryrefslogtreecommitdiff
path: root/system/api/external.go
diff options
context:
space:
mode:
authorSteve <nilslice@gmail.com>2017-01-20 19:16:18 -0800
committerGitHub <noreply@github.com>2017-01-20 19:16:18 -0800
commit0cf0d36f7613bbb2e13c0c8406689de3be9ee8d5 (patch)
treefd657507abc89d80ef20a19a5f4d9881458ae7c8 /system/api/external.go
parent51710940ef4d09e37d20397b5676c4d37dc182ad (diff)
parentb41ed1b96f5078344ab5b9e3b3586dd3963755d4 (diff)
Merge pull request #39 from ponzu-cms/ponzu-dev
[core] Consistent order of saved repeater items
Diffstat (limited to 'system/api/external.go')
-rw-r--r--system/api/external.go45
1 files changed, 35 insertions, 10 deletions
diff --git a/system/api/external.go b/system/api/external.go
index 5d4b302..5a74107 100644
--- a/system/api/external.go
+++ b/system/api/external.go
@@ -79,23 +79,48 @@ func externalContentHandler(res http.ResponseWriter, req *http.Request) {
// check for any multi-value fields (ex. checkbox fields)
// and correctly format for db storage. Essentially, we need
// fieldX.0: value1, fieldX.1: value2 => fieldX: []string{value1, value2}
- var discardKeys []string
+ fieldOrderValue := make(map[string]map[string][]string)
+ ordVal := make(map[string][]string)
for k, v := range req.PostForm {
if strings.Contains(k, ".") {
- key := strings.Split(k, ".")[0]
+ fo := strings.Split(k, ".")
- if req.PostForm.Get(key) == "" {
- req.PostForm.Set(key, v[0])
- } else {
- req.PostForm.Add(key, v[0])
- }
+ // put the order and the field value into map
+ field := string(fo[0])
+ order := string(fo[1])
+ fieldOrderValue[field] = ordVal
- discardKeys = append(discardKeys, k)
+ // orderValue is 0:[?type=Thing&id=1]
+ orderValue := fieldOrderValue[field]
+ orderValue[order] = v
+ fieldOrderValue[field] = orderValue
+
+ // discard the post form value with name.N
+ req.PostForm.Del(k)
}
+
}
- for _, discardKey := range discardKeys {
- req.PostForm.Del(discardKey)
+ // add/set the key & value to the post form in order
+ for f, ov := range fieldOrderValue {
+ for i := 0; i < len(ov); i++ {
+ position := fmt.Sprintf("%d", i)
+ fieldValue := ov[position]
+
+ if req.PostForm.Get(f) == "" {
+ for i, fv := range fieldValue {
+ if i == 0 {
+ req.PostForm.Set(f, fv)
+ } else {
+ req.PostForm.Add(f, fv)
+ }
+ }
+ } else {
+ for _, fv := range fieldValue {
+ req.PostForm.Add(f, fv)
+ }
+ }
+ }
}
// call Accept with the request, enabling developer to add or chack data