1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
package reference
import (
"encoding/json"
"fmt"
"log"
"github.com/bosssauce/ponzu/content"
"github.com/bosssauce/ponzu/management/editor"
"github.com/bosssauce/ponzu/system/db"
)
// Select returns the []byte of a <select> HTML element plus internal <options> with a label.
// IMPORTANT:
// The `fieldName` argument will cause a panic if it is not exactly the string
// form of the struct field that this editor input is representing
func Select(fieldName string, p interface{}, attrs map[string]string, contentType string) []byte {
ct, ok := content.Types[contentType]
if !ok {
log.Println("Cannot reference an invalid content type:", contentType)
return nil
}
// get a handle to the underlying interface type for decoding
t := ct()
fmt.Println(t)
// // decode all content type from db into options map
// // map["?type=<contentType>&id=<id>"]t.String()
options := make(map[string]string)
jj := db.ContentAll(contentType + "__sorted")
for i := range jj {
err := json.Unmarshal(jj[i], t)
if err != nil {
log.Println("Error decoding into reference handle:", contentType, err)
}
// make sure it is an Identifiable
item, ok := t.(content.Identifiable)
if !ok {
log.Println("Cannot use type", contentType, "as a reference since it does not implement content.Identifiable")
return nil
}
k := fmt.Sprintf("?type=%s&id=%d", contentType, item.ItemID())
v := item.String()
options[k] = v
}
return editor.Select(fieldName, p, attrs, options)
}
|