package editform import ( "bytes" "fmt" "reflect" "strconv" "strings" "github.com/animenotifier/arn" "github.com/animenotifier/notify.moe/components" "github.com/animenotifier/notify.moe/utils" ) // Render ... func Render(obj interface{}, title string, user *arn.User) string { t := reflect.TypeOf(obj).Elem() v := reflect.ValueOf(obj).Elem() id := reflect.Indirect(v.FieldByName("ID")) lowerCaseTypeName := strings.ToLower(t.Name()) endpoint := `/api/` + lowerCaseTypeName + `/` + id.String() var b bytes.Buffer b.WriteString(`
") return b.String() } // RenderObject ... func RenderObject(b *bytes.Buffer, obj interface{}, idPrefix string) { t := reflect.TypeOf(obj).Elem() v := reflect.ValueOf(obj).Elem() // Fields for i := 0; i < t.NumField(); i++ { field := t.Field(i) RenderField(b, &v, field, idPrefix) } } // RenderField ... func RenderField(b *bytes.Buffer, v *reflect.Value, field reflect.StructField, idPrefix string) { if field.Anonymous || field.Tag.Get("editable") != "true" { return } fieldValue := reflect.Indirect(v.FieldByName(field.Name)) switch field.Type.String() { case "string": if field.Tag.Get("type") == "textarea" { b.WriteString(components.InputTextArea(idPrefix+field.Name, fieldValue.String(), field.Name, "")) } else { b.WriteString(components.InputText(idPrefix+field.Name, fieldValue.String(), field.Name, "")) } case "[]string": b.WriteString(components.InputTags(idPrefix+field.Name, fieldValue.Interface().([]string), field.Name, field.Tag.Get("tooltip"))) case "bool": if field.Name == "IsDraft" { return } case "[]*arn.ExternalMedia": for sliceIndex := 0; sliceIndex < fieldValue.Len(); sliceIndex++ { b.WriteString(` `) } b.WriteString(` `) default: panic("No edit form implementation for " + idPrefix + field.Name + " with type " + field.Type.String()) } }