// // LinkButton.swift // Adwaita // // Created by auto-generation on 22.01.24. // import CAdw import LevenshteinTransformations /// A `GtkLinkButton` is a button with a hyperlink. /// /// ![An example GtkLinkButton](link-button.png) /// /// It is useful to show quick links to resources. /// /// A link button is created by calling either [ctor@Gtk.LinkButton.new] or /// [ctor@Gtk.LinkButton.new_with_label]. If using the former, the URI you /// pass to the constructor is used as a label for the widget. /// /// The URI bound to a `GtkLinkButton` can be set specifically using /// [method@Gtk.LinkButton.set_uri]. /// /// By default, `GtkLinkButton` calls [method@Gtk.FileLauncher.launch] when the button /// is clicked. This behaviour can be overridden by connecting to the /// [signal@Gtk.LinkButton::activate-link] signal and returning %TRUE from /// the signal handler. /// /// # CSS nodes /// /// `GtkLinkButton` has a single CSS node with name button. To differentiate /// it from a plain `GtkButton`, it gets the .link style class. /// /// # Accessibility /// /// `GtkLinkButton` uses the %GTK_ACCESSIBLE_ROLE_LINK role. public struct LinkButton: Widget { /// Additional update functions for type extensions. var updateFunctions: [(ViewStorage) -> Void] = [] /// Additional appear functions for type extensions. var appearFunctions: [(ViewStorage) -> Void] = [] /// The URI bound to this button. var uri: String /// The 'visited' state of this button. /// /// A visited link is drawn in a different color. var visited: Bool? /// Whether the size of the button can be made smaller than the natural /// size of its contents. /// /// For text buttons, setting this property will allow ellipsizing the label. /// /// If the contents of a button are an icon or a custom widget, setting this /// property has no effect. var canShrink: Bool? /// The child widget. var child: (() -> Body)? /// Whether the button has a frame. var hasFrame: Bool? /// The name of the icon used to automatically populate the button. var iconName: String? /// Text of the label inside the button, if the button contains a label widget. var label: String? /// If set, an underline in the text indicates that the following character is /// to be used as mnemonic. var useUnderline: Bool? /// Emitted to animate press then release. /// /// This is an action signal. Applications should never connect /// to this signal, but use the [signal@Gtk.Button::clicked] signal. /// /// The default bindings for this signal are all forms of the /// and Enter keys. var activate: (() -> Void)? /// Emitted when the button has been activated (pressed and released). var clicked: (() -> Void)? /// The application. var app: GTUIApp? /// The window. var window: GTUIApplicationWindow? /// Initialize `LinkButton`. public init(uri: String) { self.uri = uri } /// Get the widget's view storage. /// - Parameter modifiers: The view modifiers. /// - Returns: The view storage. public func container(modifiers: [(View) -> View]) -> ViewStorage { let storage = ViewStorage(gtk_link_button_new(uri)?.opaque()) update(storage, modifiers: modifiers) if let childStorage = child?().widget(modifiers: modifiers).storage(modifiers: modifiers) { storage.content["child"] = [childStorage] gtk_button_set_child(storage.pointer?.cast(), childStorage.pointer?.cast()) } for function in appearFunctions { function(storage) } return storage } /// Update the widget's view storage. /// - Parameters: /// - storage: The view storage. /// - modifiers: The view modifiers. public func update(_ storage: ViewStorage, modifiers: [(View) -> View]) { if let activate { storage.connectSignal(name: "activate") { activate() } } if let clicked { storage.connectSignal(name: "clicked") { clicked() } } storage.modify { widget in gtk_link_button_set_uri(widget, uri) if let visited { gtk_link_button_set_visited(widget, visited.cBool) } if let canShrink { gtk_button_set_can_shrink(widget?.cast(), canShrink.cBool) } if let widget = storage.content["child"]?.first { child?().widget(modifiers: modifiers).update(widget, modifiers: modifiers) } if let hasFrame { gtk_button_set_has_frame(widget?.cast(), hasFrame.cBool) } if let iconName { gtk_button_set_icon_name(widget?.cast(), iconName) } if let label, storage.content["child"] == nil { gtk_button_set_label(widget?.cast(), label) } if let useUnderline { gtk_button_set_use_underline(widget?.cast(), useUnderline.cBool) } } for function in updateFunctions { function(storage) } } /// The URI bound to this button. public func uri(_ uri: String) -> Self { var newSelf = self newSelf.uri = uri return newSelf } /// The 'visited' state of this button. /// /// A visited link is drawn in a different color. public func visited(_ visited: Bool? = true) -> Self { var newSelf = self newSelf.visited = visited return newSelf } /// Whether the size of the button can be made smaller than the natural /// size of its contents. /// /// For text buttons, setting this property will allow ellipsizing the label. /// /// If the contents of a button are an icon or a custom widget, setting this /// property has no effect. public func canShrink(_ canShrink: Bool? = true) -> Self { var newSelf = self newSelf.canShrink = canShrink return newSelf } /// The child widget. public func child(@ViewBuilder _ child: @escaping (() -> Body)) -> Self { var newSelf = self newSelf.child = child return newSelf } /// Whether the button has a frame. public func hasFrame(_ hasFrame: Bool? = true) -> Self { var newSelf = self newSelf.hasFrame = hasFrame return newSelf } /// The name of the icon used to automatically populate the button. public func iconName(_ iconName: String?) -> Self { var newSelf = self newSelf.iconName = iconName return newSelf } /// Text of the label inside the button, if the button contains a label widget. public func label(_ label: String?) -> Self { var newSelf = self newSelf.label = label return newSelf } /// If set, an underline in the text indicates that the following character is /// to be used as mnemonic. public func useUnderline(_ useUnderline: Bool? = true) -> Self { var newSelf = self newSelf.useUnderline = useUnderline return newSelf } /// Emitted to animate press then release. /// /// This is an action signal. Applications should never connect /// to this signal, but use the [signal@Gtk.Button::clicked] signal. /// /// The default bindings for this signal are all forms of the /// and Enter keys. public func activate(_ activate: @escaping () -> Void) -> Self { var newSelf = self newSelf.activate = activate return newSelf } /// Emitted when the button has been activated (pressed and released). public func clicked(_ clicked: @escaping () -> Void) -> Self { var newSelf = self newSelf.clicked = clicked return newSelf } }