package vuetifyx import ( "context" "github.com/qor5/ui/vuetify" "github.com/qor5/web" h "github.com/theplant/htmlgo" ) type VXAutocompleteBuilder struct { tag *h.HTMLTagBuilder selectedItems interface{} items interface{} } func VXAutocomplete(children ...h.HTMLComponent) (r *VXAutocompleteBuilder) { r = &VXAutocompleteBuilder{ tag: h.Tag("vx-autocomplete").Children(children...), } r.Multiple(true) return } func (b *VXAutocompleteBuilder) ErrorMessages(v ...string) (r *VXAutocompleteBuilder) { vuetify.SetErrorMessages(b.tag, v) return b } func (b *VXAutocompleteBuilder) Items(v interface{}) (r *VXAutocompleteBuilder) { b.items = v return b } func (b *VXAutocompleteBuilder) FieldName(v string) (r *VXAutocompleteBuilder) { b.tag.Attr(web.VFieldName(v)...) return b } func (b *VXAutocompleteBuilder) SelectedItems(v interface{}) (r *VXAutocompleteBuilder) { b.selectedItems = v return b } func (b *VXAutocompleteBuilder) SetDataSource(ds *AutocompleteDataSource) (r *VXAutocompleteBuilder) { b.tag.Attr("remote-url", ds.RemoteURL) b.tag.Attr("event-name", ds.EventName) b.tag.Attr("is-paging", ds.IsPaging) b.tag.Attr("has-icon", ds.HasIcon) return b } func (b *VXAutocompleteBuilder) MarshalHTML(ctx context.Context) (r []byte, err error) { if b.items == nil { b.items = b.selectedItems } b.tag.Attr(":items", b.items) b.tag.Attr(":selected-items", b.selectedItems) return b.tag.MarshalHTML(ctx) } type AutocompleteDataSource struct { RemoteURL string `json:"remote-url"` EventName string `json:"event-name"` IsPaging bool `json:"is-paging"` HasIcon bool `json:"has-icon"` }