162 lines
3.8 KiB
Plaintext
162 lines
3.8 KiB
Plaintext
|
|
// Code generated by wa-generator. DO NOT EDIT.
|
|||
|
|
// Source: Web Awesome wa-option
|
|||
|
|
|
|||
|
|
package wa
|
|||
|
|
|
|||
|
|
import (
|
|||
|
|
"github.com/a-h/templ"
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
// Options define the selectable items within a select component.
|
|||
|
|
//
|
|||
|
|
// Web Awesome component: <wa-option>
|
|||
|
|
|
|||
|
|
// OptionProps holds all properties for the wa-option component
|
|||
|
|
type OptionProps struct {
|
|||
|
|
// The option's value. When selected, the containing form control will receive this value. The value must be unique
|
|||
|
|
Value string `attr:"value"`
|
|||
|
|
// Draws the option in a disabled state, preventing selection.
|
|||
|
|
Disabled bool `attr:"disabled"`
|
|||
|
|
// Selects an option initially.
|
|||
|
|
Selected bool `attr:"selected"`
|
|||
|
|
// The option’s plain text label.
|
|||
|
|
Label string `attr:"label"`
|
|||
|
|
|
|||
|
|
// Events
|
|||
|
|
|
|||
|
|
// Slots contains named slot content
|
|||
|
|
Slots OptionSlots
|
|||
|
|
|
|||
|
|
// Attrs contains additional HTML attributes
|
|||
|
|
Attrs templ.Attributes
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// OptionSlots holds named slot content for the component
|
|||
|
|
type OptionSlots struct {
|
|||
|
|
// An element, such as <wa-icon>, placed before the label.
|
|||
|
|
Start templ.Component
|
|||
|
|
// An element, such as <wa-icon>, placed after the label.
|
|||
|
|
End templ.Component
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// OptionBuilder provides a fluent API for constructing OptionProps
|
|||
|
|
type OptionBuilder struct {
|
|||
|
|
props OptionProps
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// NewOption creates a new builder for wa-option
|
|||
|
|
func NewOption() *OptionBuilder {
|
|||
|
|
return &OptionBuilder{}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// Value sets the value attribute
|
|||
|
|
// The option's value. When selected, the containing form control will receive this value. The value must be unique
|
|||
|
|
func (b *OptionBuilder) Value(v string) *OptionBuilder {
|
|||
|
|
b.props.Value = v
|
|||
|
|
return b
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// Disabled sets the disabled attribute
|
|||
|
|
// Draws the option in a disabled state, preventing selection.
|
|||
|
|
func (b *OptionBuilder) Disabled(v bool) *OptionBuilder {
|
|||
|
|
b.props.Disabled = v
|
|||
|
|
return b
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// Selected sets the selected attribute
|
|||
|
|
// Selects an option initially.
|
|||
|
|
func (b *OptionBuilder) Selected(v bool) *OptionBuilder {
|
|||
|
|
b.props.Selected = v
|
|||
|
|
return b
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// Label sets the label attribute
|
|||
|
|
// The option’s plain text label.
|
|||
|
|
func (b *OptionBuilder) Label(v string) *OptionBuilder {
|
|||
|
|
b.props.Label = v
|
|||
|
|
return b
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// StartSlot sets the start slot content
|
|||
|
|
// An element, such as <wa-icon>, placed before the label.
|
|||
|
|
func (b *OptionBuilder) StartSlot(c templ.Component) *OptionBuilder {
|
|||
|
|
b.props.Slots.Start = c
|
|||
|
|
return b
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// EndSlot sets the end slot content
|
|||
|
|
// An element, such as <wa-icon>, placed after the label.
|
|||
|
|
func (b *OptionBuilder) EndSlot(c templ.Component) *OptionBuilder {
|
|||
|
|
b.props.Slots.End = c
|
|||
|
|
return b
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// Attr adds a custom HTML attribute
|
|||
|
|
func (b *OptionBuilder) Attr(name, value string) *OptionBuilder {
|
|||
|
|
if b.props.Attrs == nil {
|
|||
|
|
b.props.Attrs = templ.Attributes{}
|
|||
|
|
}
|
|||
|
|
b.props.Attrs[name] = value
|
|||
|
|
return b
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// Attrs merges multiple attributes
|
|||
|
|
func (b *OptionBuilder) Attrs(attrs templ.Attributes) *OptionBuilder {
|
|||
|
|
if b.props.Attrs == nil {
|
|||
|
|
b.props.Attrs = templ.Attributes{}
|
|||
|
|
}
|
|||
|
|
for k, v := range attrs {
|
|||
|
|
b.props.Attrs[k] = v
|
|||
|
|
}
|
|||
|
|
return b
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// Props returns the built properties
|
|||
|
|
func (b *OptionBuilder) Props() OptionProps {
|
|||
|
|
return b.props
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// Build returns the props (alias for Props for semantic clarity)
|
|||
|
|
func (b *OptionBuilder) Build() OptionProps {
|
|||
|
|
return b.props
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// Option renders the wa-option component
|
|||
|
|
templ Option(props OptionProps) {
|
|||
|
|
<wa-option
|
|||
|
|
if props.Value != "" {
|
|||
|
|
value={ props.Value }
|
|||
|
|
}
|
|||
|
|
if props.Disabled {
|
|||
|
|
disabled
|
|||
|
|
}
|
|||
|
|
if props.Selected {
|
|||
|
|
selected
|
|||
|
|
}
|
|||
|
|
if props.Label != "" {
|
|||
|
|
label={ props.Label }
|
|||
|
|
}
|
|||
|
|
{ props.Attrs... }
|
|||
|
|
>
|
|||
|
|
if props.Slots.Start != nil {
|
|||
|
|
<div slot="start">
|
|||
|
|
@props.Slots.Start
|
|||
|
|
</div>
|
|||
|
|
}
|
|||
|
|
if props.Slots.End != nil {
|
|||
|
|
<div slot="end">
|
|||
|
|
@props.Slots.End
|
|||
|
|
</div>
|
|||
|
|
}
|
|||
|
|
{ children... }
|
|||
|
|
</wa-option>
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// OptionFunc renders with a builder function for inline configuration
|
|||
|
|
templ OptionFunc(fn func(*OptionBuilder)) {
|
|||
|
|
{{ b := NewOption(); fn(b) }}
|
|||
|
|
@Option(b.Props()) {
|
|||
|
|
{ children... }
|
|||
|
|
}
|
|||
|
|
}
|