Files
nebula/pkg/wa/qr-code.templ

167 lines
4.2 KiB
Plaintext
Raw Permalink Normal View History

2026-01-01 14:41:31 -05:00
// Code generated by wa-generator. DO NOT EDIT.
// Source: Web Awesome wa-qr-code
package wa
import (
"github.com/a-h/templ"
)
// Generates a QR code and renders it using the Canvas API.
//
// Web Awesome component: <wa-qr-code>
// QrCodeProps holds all properties for the wa-qr-code component
type QrCodeProps struct {
// The QR code's value.
Value string `attr:"value"`
// The label for assistive devices to announce. If unspecified, the value will be used instead.
Label string `attr:"label"`
// The size of the QR code, in pixels.
Size float64 `attr:"size"`
// The fill color. This can be any valid CSS color, but not a CSS custom property.
Fill string `attr:"fill"`
// The background color. This can be any valid CSS color or transparent. It cannot be a CSS custom property.
Background string `attr:"background"`
// The edge radius of each module. Must be between 0 and 0.5.
Radius float64 `attr:"radius"`
// The level of error correction to use. Learn more
// Valid values: "L", "M", "Q", "H"
ErrorCorrection string `attr:"error-correction"`
// Events
// Slots contains named slot content
Slots QrCodeSlots
// Attrs contains additional HTML attributes
Attrs templ.Attributes
}
// QrCodeBuilder provides a fluent API for constructing QrCodeProps
type QrCodeBuilder struct {
props QrCodeProps
}
// NewQrCode creates a new builder for wa-qr-code
func NewQrCode() *QrCodeBuilder {
return &QrCodeBuilder{}
}
// Value sets the value attribute
// The QR code's value.
func (b *QrCodeBuilder) Value(v string) *QrCodeBuilder {
b.props.Value = v
return b
}
// Label sets the label attribute
// The label for assistive devices to announce. If unspecified, the value will be used instead.
func (b *QrCodeBuilder) Label(v string) *QrCodeBuilder {
b.props.Label = v
return b
}
// Size sets the size attribute
// The size of the QR code, in pixels.
func (b *QrCodeBuilder) Size(v float64) *QrCodeBuilder {
b.props.Size = v
return b
}
// Fill sets the fill attribute
// The fill color. This can be any valid CSS color, but not a CSS custom property.
func (b *QrCodeBuilder) Fill(v string) *QrCodeBuilder {
b.props.Fill = v
return b
}
// Background sets the background attribute
// The background color. This can be any valid CSS color or transparent. It cannot be a CSS custom property.
func (b *QrCodeBuilder) Background(v string) *QrCodeBuilder {
b.props.Background = v
return b
}
// Radius sets the radius attribute
// The edge radius of each module. Must be between 0 and 0.5.
func (b *QrCodeBuilder) Radius(v float64) *QrCodeBuilder {
b.props.Radius = v
return b
}
// ErrorCorrection sets the error-correction attribute
// The level of error correction to use. Learn more
func (b *QrCodeBuilder) ErrorCorrection(v string) *QrCodeBuilder {
b.props.ErrorCorrection = v
return b
}
// Attr adds a custom HTML attribute
func (b *QrCodeBuilder) Attr(name, value string) *QrCodeBuilder {
if b.props.Attrs == nil {
b.props.Attrs = templ.Attributes{}
}
b.props.Attrs[name] = value
return b
}
// Attrs merges multiple attributes
func (b *QrCodeBuilder) Attrs(attrs templ.Attributes) *QrCodeBuilder {
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 *QrCodeBuilder) Props() QrCodeProps {
return b.props
}
// Build returns the props (alias for Props for semantic clarity)
func (b *QrCodeBuilder) Build() QrCodeProps {
return b.props
}
// QrCode renders the wa-qr-code component
templ QrCode(props QrCodeProps) {
<wa-qr-code
if props.Value != "" {
value={ props.Value }
}
if props.Label != "" {
label={ props.Label }
}
if props.Size != 0 {
size={ templ.Sprintf("%v", props.Size) }
}
if props.Fill != "" {
fill={ props.Fill }
}
if props.Background != "" {
background={ props.Background }
}
if props.Radius != 0 {
radius={ templ.Sprintf("%v", props.Radius) }
}
if props.ErrorCorrection != "" {
error-correction={ props.ErrorCorrection }
}
{ props.Attrs... }
>
{ children... }
</wa-qr-code>
}
// QrCodeFunc renders with a builder function for inline configuration
templ QrCodeFunc(fn func(*QrCodeBuilder)) {
{{ b := NewQrCode(); fn(b) }}
@QrCode(b.Props()) {
{ children... }
}
}