// templui component button - version: main installed by templui v0.71.0 package button import ( "git.jmbit.de/jmb/scanfile/server/web/templui/utils" "strings" ) type Variant string type Size string type Type string const ( VariantDefault Variant = "default" VariantDestructive Variant = "destructive" VariantOutline Variant = "outline" VariantSecondary Variant = "secondary" VariantGhost Variant = "ghost" VariantLink Variant = "link" ) const ( TypeButton Type = "button" TypeReset Type = "reset" TypeSubmit Type = "submit" ) const ( SizeIcon Size = "icon" ) type Props struct { ID string Class string Attributes templ.Attributes Variant Variant Size Size FullWidth bool Href string Target string Disabled bool Type Type HxGet string HxPost string HxPut string HxDelete string HxTrigger string HxTarget string HxSwap string HxReplaceUrl string } templ Button(props ...Props) { {{ var p Props }} if len(props) > 0 { {{ p = props[0] }} } if p.Type == "" { {{ p.Type = TypeButton }} } if p.Href != "" && !p.Disabled { { children... } } else { } } func (b Props) variantClasses() string { switch b.Variant { case VariantDestructive: return "bg-destructive text-destructive-foreground hover:bg-destructive/90" case VariantOutline: return "border border-input bg-background hover:bg-accent hover:text-accent-foreground" case VariantSecondary: return "bg-secondary text-secondary-foreground hover:bg-secondary/80" case VariantGhost: return "hover:bg-accent hover:text-accent-foreground" case VariantLink: return "text-primary underline-offset-4 hover:underline" default: return "bg-primary text-primary-foreground hover:bg-primary/90" } } func (b Props) sizeClasses() string { switch b.Size { case SizeIcon: return "h-10 w-10" default: return "h-10 px-4 py-2 rounded-md" } } func (b Props) modifierClasses() string { classes := []string{} if b.FullWidth { classes = append(classes, "w-full") } return strings.Join(classes, " ") }