// Code generated by wa-generator. DO NOT EDIT. // Source: Web Awesome wa-input package wa import ( "github.com/a-h/templ" ) // Inputs collect data from the user. // // Web Awesome component: // InputProps holds all properties for the wa-input component type InputProps struct { // The type of input. Works the same as a native element, but only a subset of types are supported. Defaults // Valid values: "date", "datetime-local", "email", "number", "password", "search", "tel", "text", "time", "url" Type string `attr:"type"` // The default value of the form control. Primarily used for resetting the form control. Value string `attr:"value"` // The input's size. // Valid values: "small", "medium", "large" Size string `attr:"size"` // The input's visual appearance. // Valid values: "filled", "outlined", "filled-outlined" Appearance string `attr:"appearance"` // Draws a pill-style input with rounded edges. Pill bool `attr:"pill"` // The input's label. If you need to display HTML, use the label slot instead. Label string `attr:"label"` // The input's hint. If you need to display HTML, use the hint slot instead. Hint string `attr:"hint"` // Adds a clear button when the input is not empty. WithClear bool `attr:"with-clear"` // Placeholder text to show as a hint when the input is empty. Placeholder string `attr:"placeholder"` // Makes the input readonly. Readonly bool `attr:"readonly"` // Adds a button to toggle the password's visibility. Only applies to password types. PasswordToggle bool `attr:"password-toggle"` // Determines whether or not the password is currently visible. Only applies to password input types. PasswordVisible bool `attr:"password-visible"` // Hides the browser's built-in increment/decrement spin buttons for number inputs. WithoutSpinButtons bool `attr:"without-spin-buttons"` // Makes the input a required field. Required bool `attr:"required"` // A regular expression pattern to validate input against. Pattern string `attr:"pattern"` // The minimum length of input that will be considered valid. Minlength float64 `attr:"minlength"` // The maximum length of input that will be considered valid. Maxlength float64 `attr:"maxlength"` // The input's minimum value. Only applies to date and number input types. Min string `attr:"min"` // The input's maximum value. Only applies to date and number input types. Max string `attr:"max"` // Specifies the granularity that the value must adhere to, or the special value any which means no stepping is // Valid values: "any" Step string `attr:"step"` // Controls whether and how text input is automatically capitalized as it is entered by the user. // Valid values: "off", "none", "on", "sentences", "words", "characters" Autocapitalize string `attr:"autocapitalize"` // Indicates whether the browser's autocorrect feature is on or off. // Valid values: "off", "on" Autocorrect string `attr:"autocorrect"` // Specifies what permission the browser has to provide assistance in filling out form field values. Refer to Autocomplete string `attr:"autocomplete"` // Indicates that the input should receive focus on page load. Autofocus bool `attr:"autofocus"` // Used to customize the label or icon of the Enter key on virtual keyboards. // Valid values: "enter", "done", "go", "next", "previous", "search", "send" Enterkeyhint string `attr:"enterkeyhint"` // Enables spell checking on the input. Spellcheck bool `attr:"spellcheck"` // Tells the browser what type of data will be entered by the user, allowing it to display the appropriate virtual // Valid values: "none", "text", "decimal", "numeric", "tel", "search", "email", "url" Inputmode string `attr:"inputmode"` // Used for SSR. Will determine if the SSRed component will have the label slot rendered on initial paint. WithLabel bool `attr:"with-label"` // Used for SSR. Will determine if the SSRed component will have the hint slot rendered on initial paint. WithHint bool `attr:"with-hint"` // Events // Emitted when the control receives input. OnInput string `attr:"x-on:input"` // Emitted when an alteration to the control's value is committed by the user. OnChange string `attr:"x-on:change"` // Emitted when the control loses focus. OnBlur string `attr:"x-on:blur"` // Emitted when the control gains focus. OnFocus string `attr:"x-on:focus"` // Emitted when the clear button is activated. OnClear string `attr:"x-on:wa-clear"` // Emitted when the form control has been checked for validity and its constraints aren't satisfied. OnInvalid string `attr:"x-on:wa-invalid"` // Slots contains named slot content Slots InputSlots // Attrs contains additional HTML attributes Attrs templ.Attributes } // InputSlots holds named slot content for the component type InputSlots struct { // The input's label. Alternatively, you can use the label attribute. Label templ.Component // An element, such as , placed at the start of the input control. Start templ.Component // An element, such as , placed at the end of the input control. End templ.Component // An icon to use in lieu of the default clear icon. ClearIcon templ.Component // An icon to use in lieu of the default show password icon. ShowPasswordIcon templ.Component // An icon to use in lieu of the default hide password icon. HidePasswordIcon templ.Component // Text that describes how to use the input. Alternatively, you can use the hint attribute. Hint templ.Component } // InputBuilder provides a fluent API for constructing InputProps type InputBuilder struct { props InputProps } // NewInput creates a new builder for wa-input func NewInput() *InputBuilder { return &InputBuilder{} } // Type sets the type attribute // The type of input. Works the same as a native element, but only a subset of types are supported. Defaults func (b *InputBuilder) Type(v string) *InputBuilder { b.props.Type = v return b } // Value sets the value attribute // The default value of the form control. Primarily used for resetting the form control. func (b *InputBuilder) Value(v string) *InputBuilder { b.props.Value = v return b } // Size sets the size attribute // The input's size. func (b *InputBuilder) Size(v string) *InputBuilder { b.props.Size = v return b } // Appearance sets the appearance attribute // The input's visual appearance. func (b *InputBuilder) Appearance(v string) *InputBuilder { b.props.Appearance = v return b } // Pill sets the pill attribute // Draws a pill-style input with rounded edges. func (b *InputBuilder) Pill(v bool) *InputBuilder { b.props.Pill = v return b } // Label sets the label attribute // The input's label. If you need to display HTML, use the label slot instead. func (b *InputBuilder) Label(v string) *InputBuilder { b.props.Label = v return b } // Hint sets the hint attribute // The input's hint. If you need to display HTML, use the hint slot instead. func (b *InputBuilder) Hint(v string) *InputBuilder { b.props.Hint = v return b } // WithClear sets the with-clear attribute // Adds a clear button when the input is not empty. func (b *InputBuilder) WithClear(v bool) *InputBuilder { b.props.WithClear = v return b } // Placeholder sets the placeholder attribute // Placeholder text to show as a hint when the input is empty. func (b *InputBuilder) Placeholder(v string) *InputBuilder { b.props.Placeholder = v return b } // Readonly sets the readonly attribute // Makes the input readonly. func (b *InputBuilder) Readonly(v bool) *InputBuilder { b.props.Readonly = v return b } // PasswordToggle sets the password-toggle attribute // Adds a button to toggle the password's visibility. Only applies to password types. func (b *InputBuilder) PasswordToggle(v bool) *InputBuilder { b.props.PasswordToggle = v return b } // PasswordVisible sets the password-visible attribute // Determines whether or not the password is currently visible. Only applies to password input types. func (b *InputBuilder) PasswordVisible(v bool) *InputBuilder { b.props.PasswordVisible = v return b } // WithoutSpinButtons sets the without-spin-buttons attribute // Hides the browser's built-in increment/decrement spin buttons for number inputs. func (b *InputBuilder) WithoutSpinButtons(v bool) *InputBuilder { b.props.WithoutSpinButtons = v return b } // Required sets the required attribute // Makes the input a required field. func (b *InputBuilder) Required(v bool) *InputBuilder { b.props.Required = v return b } // Pattern sets the pattern attribute // A regular expression pattern to validate input against. func (b *InputBuilder) Pattern(v string) *InputBuilder { b.props.Pattern = v return b } // Minlength sets the minlength attribute // The minimum length of input that will be considered valid. func (b *InputBuilder) Minlength(v float64) *InputBuilder { b.props.Minlength = v return b } // Maxlength sets the maxlength attribute // The maximum length of input that will be considered valid. func (b *InputBuilder) Maxlength(v float64) *InputBuilder { b.props.Maxlength = v return b } // Min sets the min attribute // The input's minimum value. Only applies to date and number input types. func (b *InputBuilder) Min(v string) *InputBuilder { b.props.Min = v return b } // Max sets the max attribute // The input's maximum value. Only applies to date and number input types. func (b *InputBuilder) Max(v string) *InputBuilder { b.props.Max = v return b } // Step sets the step attribute // Specifies the granularity that the value must adhere to, or the special value any which means no stepping is func (b *InputBuilder) Step(v string) *InputBuilder { b.props.Step = v return b } // Autocapitalize sets the autocapitalize attribute // Controls whether and how text input is automatically capitalized as it is entered by the user. func (b *InputBuilder) Autocapitalize(v string) *InputBuilder { b.props.Autocapitalize = v return b } // Autocorrect sets the autocorrect attribute // Indicates whether the browser's autocorrect feature is on or off. func (b *InputBuilder) Autocorrect(v string) *InputBuilder { b.props.Autocorrect = v return b } // Autocomplete sets the autocomplete attribute // Specifies what permission the browser has to provide assistance in filling out form field values. Refer to func (b *InputBuilder) Autocomplete(v string) *InputBuilder { b.props.Autocomplete = v return b } // Autofocus sets the autofocus attribute // Indicates that the input should receive focus on page load. func (b *InputBuilder) Autofocus(v bool) *InputBuilder { b.props.Autofocus = v return b } // Enterkeyhint sets the enterkeyhint attribute // Used to customize the label or icon of the Enter key on virtual keyboards. func (b *InputBuilder) Enterkeyhint(v string) *InputBuilder { b.props.Enterkeyhint = v return b } // Spellcheck sets the spellcheck attribute // Enables spell checking on the input. func (b *InputBuilder) Spellcheck(v bool) *InputBuilder { b.props.Spellcheck = v return b } // Inputmode sets the inputmode attribute // Tells the browser what type of data will be entered by the user, allowing it to display the appropriate virtual func (b *InputBuilder) Inputmode(v string) *InputBuilder { b.props.Inputmode = v return b } // WithLabel sets the with-label attribute // Used for SSR. Will determine if the SSRed component will have the label slot rendered on initial paint. func (b *InputBuilder) WithLabel(v bool) *InputBuilder { b.props.WithLabel = v return b } // WithHint sets the with-hint attribute // Used for SSR. Will determine if the SSRed component will have the hint slot rendered on initial paint. func (b *InputBuilder) WithHint(v bool) *InputBuilder { b.props.WithHint = v return b } // OnInput sets the handler for input event // Emitted when the control receives input. func (b *InputBuilder) OnInput(handler string) *InputBuilder { b.props.OnInput = handler return b } // OnChange sets the handler for change event // Emitted when an alteration to the control's value is committed by the user. func (b *InputBuilder) OnChange(handler string) *InputBuilder { b.props.OnChange = handler return b } // OnBlur sets the handler for blur event // Emitted when the control loses focus. func (b *InputBuilder) OnBlur(handler string) *InputBuilder { b.props.OnBlur = handler return b } // OnFocus sets the handler for focus event // Emitted when the control gains focus. func (b *InputBuilder) OnFocus(handler string) *InputBuilder { b.props.OnFocus = handler return b } // OnClear sets the handler for wa-clear event // Emitted when the clear button is activated. func (b *InputBuilder) OnClear(handler string) *InputBuilder { b.props.OnClear = handler return b } // OnInvalid sets the handler for wa-invalid event // Emitted when the form control has been checked for validity and its constraints aren't satisfied. func (b *InputBuilder) OnInvalid(handler string) *InputBuilder { b.props.OnInvalid = handler return b } // LabelSlot sets the label slot content // The input's label. Alternatively, you can use the label attribute. func (b *InputBuilder) LabelSlot(c templ.Component) *InputBuilder { b.props.Slots.Label = c return b } // StartSlot sets the start slot content // An element, such as , placed at the start of the input control. func (b *InputBuilder) StartSlot(c templ.Component) *InputBuilder { b.props.Slots.Start = c return b } // EndSlot sets the end slot content // An element, such as , placed at the end of the input control. func (b *InputBuilder) EndSlot(c templ.Component) *InputBuilder { b.props.Slots.End = c return b } // ClearIconSlot sets the clear-icon slot content // An icon to use in lieu of the default clear icon. func (b *InputBuilder) ClearIconSlot(c templ.Component) *InputBuilder { b.props.Slots.ClearIcon = c return b } // ShowPasswordIconSlot sets the show-password-icon slot content // An icon to use in lieu of the default show password icon. func (b *InputBuilder) ShowPasswordIconSlot(c templ.Component) *InputBuilder { b.props.Slots.ShowPasswordIcon = c return b } // HidePasswordIconSlot sets the hide-password-icon slot content // An icon to use in lieu of the default hide password icon. func (b *InputBuilder) HidePasswordIconSlot(c templ.Component) *InputBuilder { b.props.Slots.HidePasswordIcon = c return b } // HintSlot sets the hint slot content // Text that describes how to use the input. Alternatively, you can use the hint attribute. func (b *InputBuilder) HintSlot(c templ.Component) *InputBuilder { b.props.Slots.Hint = c return b } // Attr adds a custom HTML attribute func (b *InputBuilder) Attr(name, value string) *InputBuilder { if b.props.Attrs == nil { b.props.Attrs = templ.Attributes{} } b.props.Attrs[name] = value return b } // Attrs merges multiple attributes func (b *InputBuilder) Attrs(attrs templ.Attributes) *InputBuilder { 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 *InputBuilder) Props() InputProps { return b.props } // Build returns the props (alias for Props for semantic clarity) func (b *InputBuilder) Build() InputProps { return b.props } // Input renders the wa-input component templ Input(props InputProps) { if props.Slots.Label != nil {
@props.Slots.Label
} if props.Slots.Start != nil {
@props.Slots.Start
} if props.Slots.End != nil {
@props.Slots.End
} if props.Slots.ClearIcon != nil {
@props.Slots.ClearIcon
} if props.Slots.ShowPasswordIcon != nil {
@props.Slots.ShowPasswordIcon
} if props.Slots.HidePasswordIcon != nil {
@props.Slots.HidePasswordIcon
} if props.Slots.Hint != nil {
@props.Slots.Hint
} { children... }
} // InputFunc renders with a builder function for inline configuration templ InputFunc(fn func(*InputBuilder)) { {{ b := NewInput(); fn(b) }} @Input(b.Props()) { { children... } } }