// // SpinRow.swift // Adwaita // // Created by auto-generation on 29.01.24. // import CAdw import LevenshteinTransformations /// An [class@ActionRow] with an embedded spin button. /// /// spin-row /// /// Example of an `AdwSpinRow` UI definition: /// /// ```xml /// Spin Row010050101 /// ``` /// /// See [class@Gtk.SpinButton] for details. /// /// ## CSS nodes /// /// `AdwSpinRow` has the same structure as [class@ActionRow], as well as the /// `.spin` style class on the main node. public struct SpinRow: Widget { /// Additional update functions for type extensions. var updateFunctions: [(ViewStorage) -> Void] = [] /// Additional appear functions for type extensions. var appearFunctions: [(ViewStorage) -> Void] = [] /// The acceleration rate when you hold down a button or key. var climbRate: Double /// The number of decimal places to display. var digits: UInt /// Whether non-numeric characters should be ignored. var numeric: Bool? /// Whether invalid values are snapped to the nearest step increment. var snapToTicks: Bool? /// The current value. var value: Binding? /// Whether the spin row should wrap upon reaching its limits. var wrap: Bool? /// The widget to activate when the row is activated. /// /// The row can be activated either by clicking on it, calling /// [method@ActionRow.activate], or via mnemonics in the title. /// See the [property@PreferencesRow:use-underline] property to enable /// mnemonics. /// /// The target widget will be activated by emitting the /// [signal@Gtk.Widget::mnemonic-activate] signal on it. var activatableWidget: (() -> Body)? /// The icon name for this row. var iconName: String? /// The subtitle for this row. /// /// The subtitle is interpreted as Pango markup unless /// [property@PreferencesRow:use-markup] is set to `FALSE`. var subtitle: String? /// The number of lines at the end of which the subtitle label will be /// ellipsized. /// /// If the value is 0, the number of lines won't be limited. var subtitleLines: Int? /// Whether the user can copy the subtitle from the label. /// /// See also [property@Gtk.Label:selectable]. var subtitleSelectable: Bool? /// The number of lines at the end of which the title label will be ellipsized. /// /// If the value is 0, the number of lines won't be limited. var titleLines: Int? /// The title of the preference represented by this row. /// /// The title is interpreted as Pango markup unless /// [property@PreferencesRow:use-markup] is set to `FALSE`. var title: String? /// Whether the user can copy the title from the label. /// /// See also [property@Gtk.Label:selectable]. var titleSelectable: Bool? /// Whether to use Pango markup for the title label. /// /// Subclasses may also use it for other labels, such as subtitle. /// /// See also [func@Pango.parse_markup]. var useMarkup: Bool? /// Whether an embedded underline in the title indicates a mnemonic. var useUnderline: Bool? /// Emitted to convert the user's input into a double value. /// /// The signal handler is expected to use [method@Gtk.Editable.get_text] to /// retrieve the text of the spinbutton and set new_value to the new value. /// /// The default conversion uses [func@GLib.strtod]. /// /// See [signal@Gtk.SpinButton::input]. var input: (() -> Void)? /// Emitted to tweak the formatting of the value for display. /// /// See [signal@Gtk.SpinButton::output]. var output: (() -> Void)? /// Emitted right after the spinbutton wraps. /// /// See [signal@Gtk.SpinButton::wrapped]. var wrapped: (() -> Void)? /// This signal is emitted after the row has been activated. var activated: (() -> Void)? /// The body for the widget "suffix". var suffix: () -> Body = { [] } /// The body for the widget "prefix". var prefix: () -> Body = { [] } /// The application. var app: GTUIApp? /// The window. var window: GTUIApplicationWindow? /// Initialize `SpinRow`. public init(climbRate: Double, digits: UInt) { self.climbRate = climbRate self.digits = digits } /// 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(adw_spin_row_new(nil, climbRate, digits.cInt)?.opaque()) update(storage, modifiers: modifiers, updateProperties: true) if let activatableWidgetStorage = activatableWidget?().widget(modifiers: modifiers).storage(modifiers: modifiers) { storage.content["activatableWidget"] = [activatableWidgetStorage] adw_action_row_set_activatable_widget(storage.pointer?.cast(), activatableWidgetStorage.pointer?.cast()) } var suffixStorage: [ViewStorage] = [] for view in suffix() { suffixStorage.append(view.storage(modifiers: modifiers)) adw_action_row_add_suffix(storage.pointer?.cast(), suffixStorage.last?.pointer?.cast()) } storage.content["suffix"] = suffixStorage var prefixStorage: [ViewStorage] = [] for view in prefix() { prefixStorage.append(view.storage(modifiers: modifiers)) adw_action_row_add_prefix(storage.pointer?.cast(), prefixStorage.last?.pointer?.cast()) } storage.content["prefix"] = prefixStorage storage.notify(name: "value") { value?.wrappedValue = adw_spin_row_get_value(storage.pointer) } for function in appearFunctions { function(storage) } return storage } /// Update the widget's view storage. /// - Parameters: /// - storage: The view storage. /// - modifiers: The view modifiers. /// - updateProperties: Whether to update the view's properties. public func update(_ storage: ViewStorage, modifiers: [(View) -> View], updateProperties: Bool) { if let input { storage.connectSignal(name: "input", argCount: 1) { input() } } if let output { storage.connectSignal(name: "output", argCount: 0) { output() } } if let wrapped { storage.connectSignal(name: "wrapped", argCount: 0) { wrapped() } } if let activated { storage.connectSignal(name: "activated", argCount: 0) { activated() } } storage.modify { widget in if updateProperties { adw_spin_row_set_climb_rate(widget, climbRate) } if updateProperties { adw_spin_row_set_digits(widget, digits.cInt) } if let numeric, updateProperties { adw_spin_row_set_numeric(widget, numeric.cBool) } if let snapToTicks, updateProperties { adw_spin_row_set_snap_to_ticks(widget, snapToTicks.cBool) } if let value, updateProperties { adw_spin_row_set_value(widget, value.wrappedValue) } if let wrap, updateProperties { adw_spin_row_set_wrap(widget, wrap.cBool) } if let widget = storage.content["activatableWidget"]?.first { activatableWidget?().widget(modifiers: modifiers).update(widget, modifiers: modifiers, updateProperties: updateProperties) } if let iconName, updateProperties { adw_action_row_set_icon_name(widget?.cast(), iconName) } if let subtitle, updateProperties { adw_action_row_set_subtitle(widget?.cast(), subtitle) } if let subtitleLines, updateProperties { adw_action_row_set_subtitle_lines(widget?.cast(), subtitleLines.cInt) } if let subtitleSelectable, updateProperties { adw_action_row_set_subtitle_selectable(widget?.cast(), subtitleSelectable.cBool) } if let titleLines, updateProperties { adw_action_row_set_title_lines(widget?.cast(), titleLines.cInt) } if let title, updateProperties { adw_preferences_row_set_title(widget?.cast(), title) } if let titleSelectable, updateProperties { adw_preferences_row_set_title_selectable(widget?.cast(), titleSelectable.cBool) } if let useMarkup, updateProperties { adw_preferences_row_set_use_markup(widget?.cast(), useMarkup.cBool) } if let useUnderline, updateProperties { adw_preferences_row_set_use_underline(widget?.cast(), useUnderline.cBool) } } for function in updateFunctions { function(storage) } } /// The acceleration rate when you hold down a button or key. public func climbRate(_ climbRate: Double) -> Self { var newSelf = self newSelf.climbRate = climbRate return newSelf } /// The number of decimal places to display. public func digits(_ digits: UInt) -> Self { var newSelf = self newSelf.digits = digits return newSelf } /// Whether non-numeric characters should be ignored. public func numeric(_ numeric: Bool? = true) -> Self { var newSelf = self newSelf.numeric = numeric return newSelf } /// Whether invalid values are snapped to the nearest step increment. public func snapToTicks(_ snapToTicks: Bool? = true) -> Self { var newSelf = self newSelf.snapToTicks = snapToTicks return newSelf } /// The current value. public func value(_ value: Binding?) -> Self { var newSelf = self newSelf.value = value return newSelf } /// Whether the spin row should wrap upon reaching its limits. public func wrap(_ wrap: Bool? = true) -> Self { var newSelf = self newSelf.wrap = wrap return newSelf } /// The widget to activate when the row is activated. /// /// The row can be activated either by clicking on it, calling /// [method@ActionRow.activate], or via mnemonics in the title. /// See the [property@PreferencesRow:use-underline] property to enable /// mnemonics. /// /// The target widget will be activated by emitting the /// [signal@Gtk.Widget::mnemonic-activate] signal on it. public func activatableWidget(@ViewBuilder _ activatableWidget: @escaping (() -> Body)) -> Self { var newSelf = self newSelf.activatableWidget = activatableWidget return newSelf } /// The icon name for this row. public func iconName(_ iconName: String?) -> Self { var newSelf = self newSelf.iconName = iconName return newSelf } /// The subtitle for this row. /// /// The subtitle is interpreted as Pango markup unless /// [property@PreferencesRow:use-markup] is set to `FALSE`. public func subtitle(_ subtitle: String?) -> Self { var newSelf = self newSelf.subtitle = subtitle return newSelf } /// The number of lines at the end of which the subtitle label will be /// ellipsized. /// /// If the value is 0, the number of lines won't be limited. public func subtitleLines(_ subtitleLines: Int?) -> Self { var newSelf = self newSelf.subtitleLines = subtitleLines return newSelf } /// Whether the user can copy the subtitle from the label. /// /// See also [property@Gtk.Label:selectable]. public func subtitleSelectable(_ subtitleSelectable: Bool? = true) -> Self { var newSelf = self newSelf.subtitleSelectable = subtitleSelectable return newSelf } /// The number of lines at the end of which the title label will be ellipsized. /// /// If the value is 0, the number of lines won't be limited. public func titleLines(_ titleLines: Int?) -> Self { var newSelf = self newSelf.titleLines = titleLines return newSelf } /// The title of the preference represented by this row. /// /// The title is interpreted as Pango markup unless /// [property@PreferencesRow:use-markup] is set to `FALSE`. public func title(_ title: String?) -> Self { var newSelf = self newSelf.title = title return newSelf } /// Whether the user can copy the title from the label. /// /// See also [property@Gtk.Label:selectable]. public func titleSelectable(_ titleSelectable: Bool? = true) -> Self { var newSelf = self newSelf.titleSelectable = titleSelectable return newSelf } /// Whether to use Pango markup for the title label. /// /// Subclasses may also use it for other labels, such as subtitle. /// /// See also [func@Pango.parse_markup]. public func useMarkup(_ useMarkup: Bool? = true) -> Self { var newSelf = self newSelf.useMarkup = useMarkup return newSelf } /// Whether an embedded underline in the title indicates a mnemonic. public func useUnderline(_ useUnderline: Bool? = true) -> Self { var newSelf = self newSelf.useUnderline = useUnderline return newSelf } /// Emitted to convert the user's input into a double value. /// /// The signal handler is expected to use [method@Gtk.Editable.get_text] to /// retrieve the text of the spinbutton and set new_value to the new value. /// /// The default conversion uses [func@GLib.strtod]. /// /// See [signal@Gtk.SpinButton::input]. public func input(_ input: @escaping () -> Void) -> Self { var newSelf = self newSelf.input = input return newSelf } /// Emitted to tweak the formatting of the value for display. /// /// See [signal@Gtk.SpinButton::output]. public func output(_ output: @escaping () -> Void) -> Self { var newSelf = self newSelf.output = output return newSelf } /// Emitted right after the spinbutton wraps. /// /// See [signal@Gtk.SpinButton::wrapped]. public func wrapped(_ wrapped: @escaping () -> Void) -> Self { var newSelf = self newSelf.wrapped = wrapped return newSelf } /// This signal is emitted after the row has been activated. public func activated(_ activated: @escaping () -> Void) -> Self { var newSelf = self newSelf.activated = activated return newSelf } }