// Package editor enables users to create edit views from their content // structs so that admins can manage content package editor import ( "bytes" "net/http" ) // Editable ensures data is editable type Editable interface { Editor() *Editor MarshalEditor() ([]byte, error) } // Mergeable allows external post content to be approved and published through // the public-facing API type Mergeable interface { // Approve copies an external post to the internal collection and triggers // a re-sort of its content type posts Approve(req *http.Request) error } // Editor is a view containing fields to manage content type Editor struct { ViewBuf *bytes.Buffer } // Field is used to create the editable view for a field // within a particular content struct type Field struct { View []byte } // Form takes editable content and any number of Field funcs to describe the edit // page for any content struct added by a user func Form(post Editable, fields ...Field) ([]byte, error) { editor := post.Editor() editor.ViewBuf = &bytes.Buffer{} editor.ViewBuf.Write([]byte(`
`)) for _, f := range fields { addFieldToEditorView(editor, f) } editor.ViewBuf.Write([]byte(` |
`))
publishTime := `
:
|