// Code generated by wa-generator. DO NOT EDIT. // Source: Web Awesome wa-dialog package wa import ( "github.com/a-h/templ" ) // Dialogs, sometimes called "modals", appear above the page and require the user's immediate attention. // // Web Awesome component: // DialogProps holds all properties for the wa-dialog component type DialogProps struct { // Indicates whether or not the dialog is open. Toggle this attribute to show and hide the dialog. Open bool `attr:"open"` // The dialog's label as displayed in the header. You should always include a relevant label, as it is required for Label string `attr:"label"` // Disables the header. This will also remove the default close button. WithoutHeader bool `attr:"without-header"` // When enabled, the dialog will be closed when the user clicks outside of it. LightDismiss bool `attr:"light-dismiss"` // Events // Emitted when the dialog opens. OnShow string `attr:"x-on:wa-show"` // Emitted after the dialog opens and all animations are complete. OnAfterShow string `attr:"x-on:wa-after-show"` // Emitted when the dialog is requested to close. Calling event.preventDefault() will prevent the dialog from closing. Y... OnHide string `attr:"x-on:wa-hide"` // Emitted after the dialog closes and all animations are complete. OnAfterHide string `attr:"x-on:wa-after-hide"` // Slots contains named slot content Slots DialogSlots // Attrs contains additional HTML attributes Attrs templ.Attributes } // DialogSlots holds named slot content for the component type DialogSlots struct { // The dialog's label. Alternatively, you can use the label attribute. Label templ.Component // Optional actions to add to the header. Works best with . HeaderActions templ.Component // The dialog's footer, usually one or more buttons representing various options. Footer templ.Component } // DialogBuilder provides a fluent API for constructing DialogProps type DialogBuilder struct { props DialogProps } // NewDialog creates a new builder for wa-dialog func NewDialog() *DialogBuilder { return &DialogBuilder{} } // Open sets the open attribute // Indicates whether or not the dialog is open. Toggle this attribute to show and hide the dialog. func (b *DialogBuilder) Open(v bool) *DialogBuilder { b.props.Open = v return b } // Label sets the label attribute // The dialog's label as displayed in the header. You should always include a relevant label, as it is required for func (b *DialogBuilder) Label(v string) *DialogBuilder { b.props.Label = v return b } // WithoutHeader sets the without-header attribute // Disables the header. This will also remove the default close button. func (b *DialogBuilder) WithoutHeader(v bool) *DialogBuilder { b.props.WithoutHeader = v return b } // LightDismiss sets the light-dismiss attribute // When enabled, the dialog will be closed when the user clicks outside of it. func (b *DialogBuilder) LightDismiss(v bool) *DialogBuilder { b.props.LightDismiss = v return b } // OnShow sets the handler for wa-show event // Emitted when the dialog opens. func (b *DialogBuilder) OnShow(handler string) *DialogBuilder { b.props.OnShow = handler return b } // OnAfterShow sets the handler for wa-after-show event // Emitted after the dialog opens and all animations are complete. func (b *DialogBuilder) OnAfterShow(handler string) *DialogBuilder { b.props.OnAfterShow = handler return b } // OnHide sets the handler for wa-hide event // Emitted when the dialog is requested to close. Calling event.preventDefault() will prevent the dialog from closing. Y... func (b *DialogBuilder) OnHide(handler string) *DialogBuilder { b.props.OnHide = handler return b } // OnAfterHide sets the handler for wa-after-hide event // Emitted after the dialog closes and all animations are complete. func (b *DialogBuilder) OnAfterHide(handler string) *DialogBuilder { b.props.OnAfterHide = handler return b } // LabelSlot sets the label slot content // The dialog's label. Alternatively, you can use the label attribute. func (b *DialogBuilder) LabelSlot(c templ.Component) *DialogBuilder { b.props.Slots.Label = c return b } // HeaderActionsSlot sets the header-actions slot content // Optional actions to add to the header. Works best with . func (b *DialogBuilder) HeaderActionsSlot(c templ.Component) *DialogBuilder { b.props.Slots.HeaderActions = c return b } // FooterSlot sets the footer slot content // The dialog's footer, usually one or more buttons representing various options. func (b *DialogBuilder) FooterSlot(c templ.Component) *DialogBuilder { b.props.Slots.Footer = c return b } // Attr adds a custom HTML attribute func (b *DialogBuilder) Attr(name, value string) *DialogBuilder { if b.props.Attrs == nil { b.props.Attrs = templ.Attributes{} } b.props.Attrs[name] = value return b } // Attrs merges multiple attributes func (b *DialogBuilder) Attrs(attrs templ.Attributes) *DialogBuilder { 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 *DialogBuilder) Props() DialogProps { return b.props } // Build returns the props (alias for Props for semantic clarity) func (b *DialogBuilder) Build() DialogProps { return b.props } // Dialog renders the wa-dialog component templ Dialog(props DialogProps) { if props.Slots.Label != nil {
@props.Slots.Label
} if props.Slots.HeaderActions != nil {
@props.Slots.HeaderActions
} if props.Slots.Footer != nil {
@props.Slots.Footer
} { children... }
} // DialogFunc renders with a builder function for inline configuration templ DialogFunc(fn func(*DialogBuilder)) { {{ b := NewDialog(); fn(b) }} @Dialog(b.Props()) { { children... } } }