| Copyright | Will Thompson Iñaki García Etxebarria and Jonas Platte | 
|---|---|
| License | LGPL-2.1 | 
| Maintainer | Iñaki García Etxebarria | 
| Safe Haskell | None | 
| Language | Haskell2010 | 
GI.Gtk.Objects.FlowBox
Contents
- Exported types
- Methods- Overloaded methods
- bindModel
- getActivateOnSingleClick
- getChildAtIndex
- getChildAtPos
- getColumnSpacing
- getHomogeneous
- getMaxChildrenPerLine
- getMinChildrenPerLine
- getRowSpacing
- getSelectedChildren
- getSelectionMode
- insert
- invalidateFilter
- invalidateSort
- new
- selectAll
- selectChild
- selectedForeach
- setActivateOnSingleClick
- setColumnSpacing
- setFilterFunc
- setHadjustment
- setHomogeneous
- setMaxChildrenPerLine
- setMinChildrenPerLine
- setRowSpacing
- setSelectionMode
- setSortFunc
- setVadjustment
- unselectAll
- unselectChild
 
- Properties
- Signals
Description
A GtkFlowBox positions child widgets in sequence according to its orientation.
For instance, with the horizontal orientation, the widgets will be arranged from left to right, starting a new row under the previous row when necessary. Reducing the width in this case will require more rows, so a larger height will be requested.
Likewise, with the vertical orientation, the widgets will be arranged from top to bottom, starting a new column to the right when necessary. Reducing the height will require more columns, so a larger width will be requested.
The size request of a GtkFlowBox alone may not be what you expect; if you
 need to be able to shrink it along both axes and dynamically reflow its
 children, you may have to wrap it in a ScrolledWindow to enable that.
The children of a GtkFlowBox can be dynamically sorted and filtered.
Although a GtkFlowBox must have only FlowBoxChild children,
 you can add any kind of widget to it via containerAdd, and
 a GtkFlowBoxChild widget will automatically be inserted between
 the box and the widget.
Also see ListBox.
GtkFlowBox was added in GTK+ 3.12.
CSS nodes
plain code
flowbox ├── flowboxchild │ ╰── <child> ├── flowboxchild │ ╰── <child> ┊ ╰── [rubberband]
GtkFlowBox uses a single CSS node with name flowbox. GtkFlowBoxChild uses a single CSS node with name flowboxchild. For rubberband selection, a subnode with name rubberband is used.
Synopsis
- newtype FlowBox = FlowBox (ManagedPtr FlowBox)
- class (GObject o, IsDescendantOf FlowBox o) => IsFlowBox o
- toFlowBox :: (MonadIO m, IsFlowBox o) => o -> m FlowBox
- noFlowBox :: Maybe FlowBox
- flowBoxBindModel :: (HasCallStack, MonadIO m, IsFlowBox a, IsListModel b) => a -> Maybe b -> FlowBoxCreateWidgetFunc -> m ()
- flowBoxGetActivateOnSingleClick :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m Bool
- flowBoxGetChildAtIndex :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Int32 -> m (Maybe FlowBoxChild)
- flowBoxGetChildAtPos :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Int32 -> Int32 -> m (Maybe FlowBoxChild)
- flowBoxGetColumnSpacing :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m Word32
- flowBoxGetHomogeneous :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m Bool
- flowBoxGetMaxChildrenPerLine :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m Word32
- flowBoxGetMinChildrenPerLine :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m Word32
- flowBoxGetRowSpacing :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m Word32
- flowBoxGetSelectedChildren :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m [FlowBoxChild]
- flowBoxGetSelectionMode :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m SelectionMode
- flowBoxInsert :: (HasCallStack, MonadIO m, IsFlowBox a, IsWidget b) => a -> b -> Int32 -> m ()
- flowBoxInvalidateFilter :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m ()
- flowBoxInvalidateSort :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m ()
- flowBoxNew :: (HasCallStack, MonadIO m) => m FlowBox
- flowBoxSelectAll :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m ()
- flowBoxSelectChild :: (HasCallStack, MonadIO m, IsFlowBox a, IsFlowBoxChild b) => a -> b -> m ()
- flowBoxSelectedForeach :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> FlowBoxForeachFunc -> m ()
- flowBoxSetActivateOnSingleClick :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Bool -> m ()
- flowBoxSetColumnSpacing :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Word32 -> m ()
- flowBoxSetFilterFunc :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Maybe FlowBoxFilterFunc -> m ()
- flowBoxSetHadjustment :: (HasCallStack, MonadIO m, IsFlowBox a, IsAdjustment b) => a -> b -> m ()
- flowBoxSetHomogeneous :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Bool -> m ()
- flowBoxSetMaxChildrenPerLine :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Word32 -> m ()
- flowBoxSetMinChildrenPerLine :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Word32 -> m ()
- flowBoxSetRowSpacing :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Word32 -> m ()
- flowBoxSetSelectionMode :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> SelectionMode -> m ()
- flowBoxSetSortFunc :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> Maybe FlowBoxSortFunc -> m ()
- flowBoxSetVadjustment :: (HasCallStack, MonadIO m, IsFlowBox a, IsAdjustment b) => a -> b -> m ()
- flowBoxUnselectAll :: (HasCallStack, MonadIO m, IsFlowBox a) => a -> m ()
- flowBoxUnselectChild :: (HasCallStack, MonadIO m, IsFlowBox a, IsFlowBoxChild b) => a -> b -> m ()
- constructFlowBoxActivateOnSingleClick :: IsFlowBox o => Bool -> IO (GValueConstruct o)
- getFlowBoxActivateOnSingleClick :: (MonadIO m, IsFlowBox o) => o -> m Bool
- setFlowBoxActivateOnSingleClick :: (MonadIO m, IsFlowBox o) => o -> Bool -> m ()
- constructFlowBoxColumnSpacing :: IsFlowBox o => Word32 -> IO (GValueConstruct o)
- getFlowBoxColumnSpacing :: (MonadIO m, IsFlowBox o) => o -> m Word32
- setFlowBoxColumnSpacing :: (MonadIO m, IsFlowBox o) => o -> Word32 -> m ()
- constructFlowBoxHomogeneous :: IsFlowBox o => Bool -> IO (GValueConstruct o)
- getFlowBoxHomogeneous :: (MonadIO m, IsFlowBox o) => o -> m Bool
- setFlowBoxHomogeneous :: (MonadIO m, IsFlowBox o) => o -> Bool -> m ()
- constructFlowBoxMaxChildrenPerLine :: IsFlowBox o => Word32 -> IO (GValueConstruct o)
- getFlowBoxMaxChildrenPerLine :: (MonadIO m, IsFlowBox o) => o -> m Word32
- setFlowBoxMaxChildrenPerLine :: (MonadIO m, IsFlowBox o) => o -> Word32 -> m ()
- constructFlowBoxMinChildrenPerLine :: IsFlowBox o => Word32 -> IO (GValueConstruct o)
- getFlowBoxMinChildrenPerLine :: (MonadIO m, IsFlowBox o) => o -> m Word32
- setFlowBoxMinChildrenPerLine :: (MonadIO m, IsFlowBox o) => o -> Word32 -> m ()
- constructFlowBoxRowSpacing :: IsFlowBox o => Word32 -> IO (GValueConstruct o)
- getFlowBoxRowSpacing :: (MonadIO m, IsFlowBox o) => o -> m Word32
- setFlowBoxRowSpacing :: (MonadIO m, IsFlowBox o) => o -> Word32 -> m ()
- constructFlowBoxSelectionMode :: IsFlowBox o => SelectionMode -> IO (GValueConstruct o)
- getFlowBoxSelectionMode :: (MonadIO m, IsFlowBox o) => o -> m SelectionMode
- setFlowBoxSelectionMode :: (MonadIO m, IsFlowBox o) => o -> SelectionMode -> m ()
- type C_FlowBoxActivateCursorChildCallback = Ptr () -> Ptr () -> IO ()
- type FlowBoxActivateCursorChildCallback = IO ()
- afterFlowBoxActivateCursorChild :: (IsFlowBox a, MonadIO m) => a -> FlowBoxActivateCursorChildCallback -> m SignalHandlerId
- genClosure_FlowBoxActivateCursorChild :: MonadIO m => FlowBoxActivateCursorChildCallback -> m (GClosure C_FlowBoxActivateCursorChildCallback)
- mk_FlowBoxActivateCursorChildCallback :: C_FlowBoxActivateCursorChildCallback -> IO (FunPtr C_FlowBoxActivateCursorChildCallback)
- noFlowBoxActivateCursorChildCallback :: Maybe FlowBoxActivateCursorChildCallback
- onFlowBoxActivateCursorChild :: (IsFlowBox a, MonadIO m) => a -> FlowBoxActivateCursorChildCallback -> m SignalHandlerId
- wrap_FlowBoxActivateCursorChildCallback :: FlowBoxActivateCursorChildCallback -> C_FlowBoxActivateCursorChildCallback
- type C_FlowBoxChildActivatedCallback = Ptr () -> Ptr FlowBoxChild -> Ptr () -> IO ()
- type FlowBoxChildActivatedCallback = FlowBoxChild -> IO ()
- afterFlowBoxChildActivated :: (IsFlowBox a, MonadIO m) => a -> FlowBoxChildActivatedCallback -> m SignalHandlerId
- genClosure_FlowBoxChildActivated :: MonadIO m => FlowBoxChildActivatedCallback -> m (GClosure C_FlowBoxChildActivatedCallback)
- mk_FlowBoxChildActivatedCallback :: C_FlowBoxChildActivatedCallback -> IO (FunPtr C_FlowBoxChildActivatedCallback)
- noFlowBoxChildActivatedCallback :: Maybe FlowBoxChildActivatedCallback
- onFlowBoxChildActivated :: (IsFlowBox a, MonadIO m) => a -> FlowBoxChildActivatedCallback -> m SignalHandlerId
- wrap_FlowBoxChildActivatedCallback :: FlowBoxChildActivatedCallback -> C_FlowBoxChildActivatedCallback
- type C_FlowBoxMoveCursorCallback = Ptr () -> CUInt -> Int32 -> Ptr () -> IO CInt
- type FlowBoxMoveCursorCallback = MovementStep -> Int32 -> IO Bool
- afterFlowBoxMoveCursor :: (IsFlowBox a, MonadIO m) => a -> FlowBoxMoveCursorCallback -> m SignalHandlerId
- genClosure_FlowBoxMoveCursor :: MonadIO m => FlowBoxMoveCursorCallback -> m (GClosure C_FlowBoxMoveCursorCallback)
- mk_FlowBoxMoveCursorCallback :: C_FlowBoxMoveCursorCallback -> IO (FunPtr C_FlowBoxMoveCursorCallback)
- noFlowBoxMoveCursorCallback :: Maybe FlowBoxMoveCursorCallback
- onFlowBoxMoveCursor :: (IsFlowBox a, MonadIO m) => a -> FlowBoxMoveCursorCallback -> m SignalHandlerId
- wrap_FlowBoxMoveCursorCallback :: FlowBoxMoveCursorCallback -> C_FlowBoxMoveCursorCallback
- type C_FlowBoxSelectAllCallback = Ptr () -> Ptr () -> IO ()
- type FlowBoxSelectAllCallback = IO ()
- afterFlowBoxSelectAll :: (IsFlowBox a, MonadIO m) => a -> FlowBoxSelectAllCallback -> m SignalHandlerId
- genClosure_FlowBoxSelectAll :: MonadIO m => FlowBoxSelectAllCallback -> m (GClosure C_FlowBoxSelectAllCallback)
- mk_FlowBoxSelectAllCallback :: C_FlowBoxSelectAllCallback -> IO (FunPtr C_FlowBoxSelectAllCallback)
- noFlowBoxSelectAllCallback :: Maybe FlowBoxSelectAllCallback
- onFlowBoxSelectAll :: (IsFlowBox a, MonadIO m) => a -> FlowBoxSelectAllCallback -> m SignalHandlerId
- wrap_FlowBoxSelectAllCallback :: FlowBoxSelectAllCallback -> C_FlowBoxSelectAllCallback
- type C_FlowBoxSelectedChildrenChangedCallback = Ptr () -> Ptr () -> IO ()
- type FlowBoxSelectedChildrenChangedCallback = IO ()
- afterFlowBoxSelectedChildrenChanged :: (IsFlowBox a, MonadIO m) => a -> FlowBoxSelectedChildrenChangedCallback -> m SignalHandlerId
- genClosure_FlowBoxSelectedChildrenChanged :: MonadIO m => FlowBoxSelectedChildrenChangedCallback -> m (GClosure C_FlowBoxSelectedChildrenChangedCallback)
- mk_FlowBoxSelectedChildrenChangedCallback :: C_FlowBoxSelectedChildrenChangedCallback -> IO (FunPtr C_FlowBoxSelectedChildrenChangedCallback)
- noFlowBoxSelectedChildrenChangedCallback :: Maybe FlowBoxSelectedChildrenChangedCallback
- onFlowBoxSelectedChildrenChanged :: (IsFlowBox a, MonadIO m) => a -> FlowBoxSelectedChildrenChangedCallback -> m SignalHandlerId
- wrap_FlowBoxSelectedChildrenChangedCallback :: FlowBoxSelectedChildrenChangedCallback -> C_FlowBoxSelectedChildrenChangedCallback
- type C_FlowBoxToggleCursorChildCallback = Ptr () -> Ptr () -> IO ()
- type FlowBoxToggleCursorChildCallback = IO ()
- afterFlowBoxToggleCursorChild :: (IsFlowBox a, MonadIO m) => a -> FlowBoxToggleCursorChildCallback -> m SignalHandlerId
- genClosure_FlowBoxToggleCursorChild :: MonadIO m => FlowBoxToggleCursorChildCallback -> m (GClosure C_FlowBoxToggleCursorChildCallback)
- mk_FlowBoxToggleCursorChildCallback :: C_FlowBoxToggleCursorChildCallback -> IO (FunPtr C_FlowBoxToggleCursorChildCallback)
- noFlowBoxToggleCursorChildCallback :: Maybe FlowBoxToggleCursorChildCallback
- onFlowBoxToggleCursorChild :: (IsFlowBox a, MonadIO m) => a -> FlowBoxToggleCursorChildCallback -> m SignalHandlerId
- wrap_FlowBoxToggleCursorChildCallback :: FlowBoxToggleCursorChildCallback -> C_FlowBoxToggleCursorChildCallback
- type C_FlowBoxUnselectAllCallback = Ptr () -> Ptr () -> IO ()
- type FlowBoxUnselectAllCallback = IO ()
- afterFlowBoxUnselectAll :: (IsFlowBox a, MonadIO m) => a -> FlowBoxUnselectAllCallback -> m SignalHandlerId
- genClosure_FlowBoxUnselectAll :: MonadIO m => FlowBoxUnselectAllCallback -> m (GClosure C_FlowBoxUnselectAllCallback)
- mk_FlowBoxUnselectAllCallback :: C_FlowBoxUnselectAllCallback -> IO (FunPtr C_FlowBoxUnselectAllCallback)
- noFlowBoxUnselectAllCallback :: Maybe FlowBoxUnselectAllCallback
- onFlowBoxUnselectAll :: (IsFlowBox a, MonadIO m) => a -> FlowBoxUnselectAllCallback -> m SignalHandlerId
- wrap_FlowBoxUnselectAllCallback :: FlowBoxUnselectAllCallback -> C_FlowBoxUnselectAllCallback
Exported types
Memory-managed wrapper type.
Constructors
| FlowBox (ManagedPtr FlowBox) | 
Instances
| Eq FlowBox Source # | |
| IsGValue FlowBox Source # | Convert  | 
| GObject FlowBox Source # | |
| Defined in GI.Gtk.Objects.FlowBox Methods gobjectType :: IO GType # | |
| HasParentTypes FlowBox Source # | |
| Defined in GI.Gtk.Objects.FlowBox | |
| type ParentTypes FlowBox Source # | |
| Defined in GI.Gtk.Objects.FlowBox | |
class (GObject o, IsDescendantOf FlowBox o) => IsFlowBox o Source #
Instances
| (GObject o, IsDescendantOf FlowBox o) => IsFlowBox o Source # | |
| Defined in GI.Gtk.Objects.FlowBox | |
Methods
Overloaded methods
bindModel
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a, IsListModel b) | |
| => a | 
 | 
| -> Maybe b | 
 | 
| -> FlowBoxCreateWidgetFunc | 
 | 
| -> m () | 
Binds model to box.
If box was already bound to a model, that previous binding is
 destroyed.
The contents of box are cleared and then filled with widgets that
 represent items from model. box is updated whenever model changes.
 If model is Nothing, box is left empty.
It is undefined to add or remove widgets directly (for example, with
 flowBoxInsert or containerAdd) while box is bound to a
 model.
Note that using a model is incompatible with the filtering and sorting functionality in GtkFlowBox. When using a model, filtering and sorting should be implemented by the model.
Since: 3.18
getActivateOnSingleClick
flowBoxGetActivateOnSingleClick Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m Bool | Returns:  | 
Returns whether children activate on single clicks.
Since: 3.12
getChildAtIndex
flowBoxGetChildAtIndex Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Int32 | 
 | 
| -> m (Maybe FlowBoxChild) | Returns: the child widget, which will
     always be a  | 
Gets the nth child in the box.
Since: 3.12
getChildAtPos
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Int32 | 
 | 
| -> Int32 | 
 | 
| -> m (Maybe FlowBoxChild) | Returns: the child widget, which will
     always be a  | 
Gets the child in the (x, y) position.
Since: 3.22.6
getColumnSpacing
flowBoxGetColumnSpacing Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m Word32 | Returns: the horizontal spacing | 
Gets the horizontal spacing.
Since: 3.12
getHomogeneous
flowBoxGetHomogeneous Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m Bool | Returns:  | 
Returns whether the box is homogeneous (all children are the
 same size). See boxSetHomogeneous.
Since: 3.12
getMaxChildrenPerLine
flowBoxGetMaxChildrenPerLine Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m Word32 | Returns: the maximum number of children per line | 
Gets the maximum number of children per line.
Since: 3.12
getMinChildrenPerLine
flowBoxGetMinChildrenPerLine Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m Word32 | Returns: the minimum number of children per line | 
Gets the minimum number of children per line.
Since: 3.12
getRowSpacing
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m Word32 | Returns: the vertical spacing | 
Gets the vertical spacing.
Since: 3.12
getSelectedChildren
flowBoxGetSelectedChildren Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m [FlowBoxChild] | Returns: 
     A  | 
Creates a list of all selected children.
Since: 3.12
getSelectionMode
flowBoxGetSelectionMode Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m SelectionMode | Returns: the  | 
Gets the selection mode of box.
Since: 3.12
insert
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a, IsWidget b) | |
| => a | 
 | 
| -> b | 
 | 
| -> Int32 | 
 | 
| -> m () | 
Inserts the widget into box at position.
If a sort function is set, the widget will actually be inserted
 at the calculated position and this function has the same effect
 as containerAdd.
If position is -1, or larger than the total number of children
 in the box, then the widget will be appended to the end.
Since: 3.12
invalidateFilter
flowBoxInvalidateFilter Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m () | 
Updates the filtering for all children.
Call this function when the result of the filter
 function on the box is changed due ot an external
 factor. For instance, this would be used if the
 filter function just looked for a specific search
 term, and the entry with the string has changed.
Since: 3.12
invalidateSort
flowBoxInvalidateSort Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m () | 
Updates the sorting for all children.
Call this when the result of the sort function on
 box is changed due to an external factor.
Since: 3.12
new
Arguments
| :: (HasCallStack, MonadIO m) | |
| => m FlowBox | Returns: a new  | 
Creates a GtkFlowBox.
Since: 3.12
selectAll
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m () | 
Select all children of box, if the selection
 mode allows it.
Since: 3.12
selectChild
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a, IsFlowBoxChild b) | |
| => a | 
 | 
| -> b | 
 | 
| -> m () | 
Selects a single child of box, if the selection
 mode allows it.
Since: 3.12
selectedForeach
flowBoxSelectedForeach Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> FlowBoxForeachFunc | 
 | 
| -> m () | 
Calls a function for each selected child.
Note that the selection cannot be modified from within this function.
Since: 3.12
setActivateOnSingleClick
flowBoxSetActivateOnSingleClick Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Bool | 
 | 
| -> m () | 
If single is True, children will be activated when you click
 on them, otherwise you need to double-click.
Since: 3.12
setColumnSpacing
flowBoxSetColumnSpacing Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Word32 | 
 | 
| -> m () | 
Sets the horizontal space to add between children.
 See the FlowBox:column-spacing property.
Since: 3.12
setFilterFunc
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Maybe FlowBoxFilterFunc | 
 | 
| -> m () | 
By setting a filter function on the box one can decide dynamically
 which of the children to show. For instance, to implement a search
 function that only shows the children matching the search terms.
The filterFunc will be called for each child after the call, and
 it will continue to be called each time a child changes (via
 flowBoxChildChanged) or when flowBoxInvalidateFilter
 is called.
Note that using a filter function is incompatible with using a model
 (see flowBoxBindModel).
Since: 3.12
setHadjustment
flowBoxSetHadjustment Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a, IsAdjustment b) | |
| => a | 
 | 
| -> b | 
 | 
| -> m () | 
Hooks up an adjustment to focus handling in box.
 The adjustment is also used for autoscrolling during
 rubberband selection. See scrolledWindowGetHadjustment
 for a typical way of obtaining the adjustment, and
 flowBoxSetVadjustmentfor setting the vertical
 adjustment.
The adjustments have to be in pixel units and in the same coordinate system as the allocation for immediate children of the box.
Since: 3.12
setHomogeneous
flowBoxSetHomogeneous Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Bool | 
 | 
| -> m () | 
Sets the FlowBox:homogeneous property of box, controlling
 whether or not all children of box are given equal space
 in the box.
Since: 3.12
setMaxChildrenPerLine
flowBoxSetMaxChildrenPerLine Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Word32 | 
 | 
| -> m () | 
Sets the maximum number of children to request and
 allocate space for in box’s orientation.
Setting the maximum number of children per line
 limits the overall natural size request to be no more
 than nChildren children long in the given orientation.
Since: 3.12
setMinChildrenPerLine
flowBoxSetMinChildrenPerLine Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Word32 | 
 | 
| -> m () | 
Sets the minimum number of children to line up
 in box’s orientation before flowing.
Since: 3.12
setRowSpacing
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Word32 | 
 | 
| -> m () | 
Sets the vertical space to add between children.
 See the FlowBox:row-spacing property.
Since: 3.12
setSelectionMode
flowBoxSetSelectionMode Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> SelectionMode | 
 | 
| -> m () | 
Sets how selection works in box.
 See SelectionMode for details.
Since: 3.12
setSortFunc
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> Maybe FlowBoxSortFunc | 
 | 
| -> m () | 
By setting a sort function on the box, one can dynamically
 reorder the children of the box, based on the contents of
 the children.
The sortFunc will be called for each child after the call,
 and will continue to be called each time a child changes (via
 flowBoxChildChanged) and when flowBoxInvalidateSort
 is called.
Note that using a sort function is incompatible with using a model
 (see flowBoxBindModel).
Since: 3.12
setVadjustment
flowBoxSetVadjustment Source #
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a, IsAdjustment b) | |
| => a | 
 | 
| -> b | 
 | 
| -> m () | 
Hooks up an adjustment to focus handling in box.
 The adjustment is also used for autoscrolling during
 rubberband selection. See scrolledWindowGetVadjustment
 for a typical way of obtaining the adjustment, and
 flowBoxSetHadjustmentfor setting the horizontal
 adjustment.
The adjustments have to be in pixel units and in the same coordinate system as the allocation for immediate children of the box.
Since: 3.12
unselectAll
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a) | |
| => a | 
 | 
| -> m () | 
Unselect all children of box, if the selection
 mode allows it.
Since: 3.12
unselectChild
Arguments
| :: (HasCallStack, MonadIO m, IsFlowBox a, IsFlowBoxChild b) | |
| => a | 
 | 
| -> b | 
 | 
| -> m () | 
Unselects a single child of box, if the selection
 mode allows it.
Since: 3.12
Properties
activateOnSingleClick
Determines whether children can be activated with a single click, or require a double-click.
constructFlowBoxActivateOnSingleClick :: IsFlowBox o => Bool -> IO (GValueConstruct o) Source #
Construct a GValueConstruct with valid value for the “activate-on-single-click” property. This is rarely needed directly, but it is used by new.
getFlowBoxActivateOnSingleClick :: (MonadIO m, IsFlowBox o) => o -> m Bool Source #
Get the value of the “activate-on-single-click” property.
 When overloading is enabled, this is equivalent to
get flowBox #activateOnSingleClick
setFlowBoxActivateOnSingleClick :: (MonadIO m, IsFlowBox o) => o -> Bool -> m () Source #
Set the value of the “activate-on-single-click” property.
 When overloading is enabled, this is equivalent to
setflowBox [ #activateOnSingleClick:=value ]
columnSpacing
The amount of horizontal space between two children.
constructFlowBoxColumnSpacing :: IsFlowBox o => Word32 -> IO (GValueConstruct o) Source #
Construct a GValueConstruct with valid value for the “column-spacing” property. This is rarely needed directly, but it is used by new.
getFlowBoxColumnSpacing :: (MonadIO m, IsFlowBox o) => o -> m Word32 Source #
Get the value of the “column-spacing” property.
 When overloading is enabled, this is equivalent to
get flowBox #columnSpacing
setFlowBoxColumnSpacing :: (MonadIO m, IsFlowBox o) => o -> Word32 -> m () Source #
Set the value of the “column-spacing” property.
 When overloading is enabled, this is equivalent to
setflowBox [ #columnSpacing:=value ]
homogeneous
Determines whether all children should be allocated the same size.
constructFlowBoxHomogeneous :: IsFlowBox o => Bool -> IO (GValueConstruct o) Source #
Construct a GValueConstruct with valid value for the “homogeneous” property. This is rarely needed directly, but it is used by new.
getFlowBoxHomogeneous :: (MonadIO m, IsFlowBox o) => o -> m Bool Source #
Get the value of the “homogeneous” property.
 When overloading is enabled, this is equivalent to
get flowBox #homogeneous
setFlowBoxHomogeneous :: (MonadIO m, IsFlowBox o) => o -> Bool -> m () Source #
Set the value of the “homogeneous” property.
 When overloading is enabled, this is equivalent to
setflowBox [ #homogeneous:=value ]
maxChildrenPerLine
The maximum amount of children to request space for consecutively in the given orientation.
constructFlowBoxMaxChildrenPerLine :: IsFlowBox o => Word32 -> IO (GValueConstruct o) Source #
Construct a GValueConstruct with valid value for the “max-children-per-line” property. This is rarely needed directly, but it is used by new.
getFlowBoxMaxChildrenPerLine :: (MonadIO m, IsFlowBox o) => o -> m Word32 Source #
Get the value of the “max-children-per-line” property.
 When overloading is enabled, this is equivalent to
get flowBox #maxChildrenPerLine
setFlowBoxMaxChildrenPerLine :: (MonadIO m, IsFlowBox o) => o -> Word32 -> m () Source #
Set the value of the “max-children-per-line” property.
 When overloading is enabled, this is equivalent to
setflowBox [ #maxChildrenPerLine:=value ]
minChildrenPerLine
The minimum number of children to allocate consecutively in the given orientation.
Setting the minimum children per line ensures that a reasonably small height will be requested for the overall minimum width of the box.
constructFlowBoxMinChildrenPerLine :: IsFlowBox o => Word32 -> IO (GValueConstruct o) Source #
Construct a GValueConstruct with valid value for the “min-children-per-line” property. This is rarely needed directly, but it is used by new.
getFlowBoxMinChildrenPerLine :: (MonadIO m, IsFlowBox o) => o -> m Word32 Source #
Get the value of the “min-children-per-line” property.
 When overloading is enabled, this is equivalent to
get flowBox #minChildrenPerLine
setFlowBoxMinChildrenPerLine :: (MonadIO m, IsFlowBox o) => o -> Word32 -> m () Source #
Set the value of the “min-children-per-line” property.
 When overloading is enabled, this is equivalent to
setflowBox [ #minChildrenPerLine:=value ]
rowSpacing
The amount of vertical space between two children.
constructFlowBoxRowSpacing :: IsFlowBox o => Word32 -> IO (GValueConstruct o) Source #
Construct a GValueConstruct with valid value for the “row-spacing” property. This is rarely needed directly, but it is used by new.
getFlowBoxRowSpacing :: (MonadIO m, IsFlowBox o) => o -> m Word32 Source #
Get the value of the “row-spacing” property.
 When overloading is enabled, this is equivalent to
get flowBox #rowSpacing
setFlowBoxRowSpacing :: (MonadIO m, IsFlowBox o) => o -> Word32 -> m () Source #
Set the value of the “row-spacing” property.
 When overloading is enabled, this is equivalent to
setflowBox [ #rowSpacing:=value ]
selectionMode
The selection mode used by the flow box.
constructFlowBoxSelectionMode :: IsFlowBox o => SelectionMode -> IO (GValueConstruct o) Source #
Construct a GValueConstruct with valid value for the “selection-mode” property. This is rarely needed directly, but it is used by new.
getFlowBoxSelectionMode :: (MonadIO m, IsFlowBox o) => o -> m SelectionMode Source #
Get the value of the “selection-mode” property.
 When overloading is enabled, this is equivalent to
get flowBox #selectionMode
setFlowBoxSelectionMode :: (MonadIO m, IsFlowBox o) => o -> SelectionMode -> m () Source #
Set the value of the “selection-mode” property.
 When overloading is enabled, this is equivalent to
setflowBox [ #selectionMode:=value ]
Signals
activateCursorChild
type C_FlowBoxActivateCursorChildCallback = Ptr () -> Ptr () -> IO () Source #
Type for the callback on the (unwrapped) C side.
type FlowBoxActivateCursorChildCallback = IO () Source #
The activateCursorChild signal is a
 [keybinding signal][GtkBindingSignal]
 which gets emitted when the user activates the box.
afterFlowBoxActivateCursorChild :: (IsFlowBox a, MonadIO m) => a -> FlowBoxActivateCursorChildCallback -> m SignalHandlerId Source #
Connect a signal handler for the activateCursorChild signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after flowBox #activateCursorChild callback
genClosure_FlowBoxActivateCursorChild :: MonadIO m => FlowBoxActivateCursorChildCallback -> m (GClosure C_FlowBoxActivateCursorChildCallback) Source #
Wrap the callback into a GClosure.
mk_FlowBoxActivateCursorChildCallback :: C_FlowBoxActivateCursorChildCallback -> IO (FunPtr C_FlowBoxActivateCursorChildCallback) Source #
Generate a function pointer callable from C code, from a C_FlowBoxActivateCursorChildCallback.
noFlowBoxActivateCursorChildCallback :: Maybe FlowBoxActivateCursorChildCallback Source #
A convenience synonym for Nothing :: Maybe FlowBoxActivateCursorChildCallback
onFlowBoxActivateCursorChild :: (IsFlowBox a, MonadIO m) => a -> FlowBoxActivateCursorChildCallback -> m SignalHandlerId Source #
Connect a signal handler for the activateCursorChild signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on flowBox #activateCursorChild callback
wrap_FlowBoxActivateCursorChildCallback :: FlowBoxActivateCursorChildCallback -> C_FlowBoxActivateCursorChildCallback Source #
childActivated
type C_FlowBoxChildActivatedCallback = Ptr () -> Ptr FlowBoxChild -> Ptr () -> IO () Source #
Type for the callback on the (unwrapped) C side.
type FlowBoxChildActivatedCallback Source #
Arguments
| = FlowBoxChild | 
 | 
| -> IO () | 
The childActivated signal is emitted when a child has been activated by the user.
afterFlowBoxChildActivated :: (IsFlowBox a, MonadIO m) => a -> FlowBoxChildActivatedCallback -> m SignalHandlerId Source #
Connect a signal handler for the childActivated signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after flowBox #childActivated callback
genClosure_FlowBoxChildActivated :: MonadIO m => FlowBoxChildActivatedCallback -> m (GClosure C_FlowBoxChildActivatedCallback) Source #
Wrap the callback into a GClosure.
mk_FlowBoxChildActivatedCallback :: C_FlowBoxChildActivatedCallback -> IO (FunPtr C_FlowBoxChildActivatedCallback) Source #
Generate a function pointer callable from C code, from a C_FlowBoxChildActivatedCallback.
noFlowBoxChildActivatedCallback :: Maybe FlowBoxChildActivatedCallback Source #
A convenience synonym for Nothing :: Maybe FlowBoxChildActivatedCallback
onFlowBoxChildActivated :: (IsFlowBox a, MonadIO m) => a -> FlowBoxChildActivatedCallback -> m SignalHandlerId Source #
Connect a signal handler for the childActivated signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on flowBox #childActivated callback
wrap_FlowBoxChildActivatedCallback :: FlowBoxChildActivatedCallback -> C_FlowBoxChildActivatedCallback Source #
Wrap a FlowBoxChildActivatedCallback into a C_FlowBoxChildActivatedCallback.
moveCursor
type C_FlowBoxMoveCursorCallback = Ptr () -> CUInt -> Int32 -> Ptr () -> IO CInt Source #
Type for the callback on the (unwrapped) C side.
type FlowBoxMoveCursorCallback Source #
Arguments
| = MovementStep | 
 | 
| -> Int32 | 
 | 
| -> IO Bool | Returns:  | 
The moveCursor signal is a [keybinding signal][GtkBindingSignal] which gets emitted when the user initiates a cursor movement.
Applications should not connect to it, but may emit it with
 g_signal_emit_by_name() if they need to control the cursor
 programmatically.
The default bindings for this signal come in two variants, the variant with the Shift modifier extends the selection, the variant without the Shift modifer does not. There are too many key combinations to list them all here.
- Arrow keys move by individual children
- Home/End keys move to the ends of the box
- PageUp/PageDown keys move vertically by pages
afterFlowBoxMoveCursor :: (IsFlowBox a, MonadIO m) => a -> FlowBoxMoveCursorCallback -> m SignalHandlerId Source #
Connect a signal handler for the moveCursor signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after flowBox #moveCursor callback
genClosure_FlowBoxMoveCursor :: MonadIO m => FlowBoxMoveCursorCallback -> m (GClosure C_FlowBoxMoveCursorCallback) Source #
Wrap the callback into a GClosure.
mk_FlowBoxMoveCursorCallback :: C_FlowBoxMoveCursorCallback -> IO (FunPtr C_FlowBoxMoveCursorCallback) Source #
Generate a function pointer callable from C code, from a C_FlowBoxMoveCursorCallback.
noFlowBoxMoveCursorCallback :: Maybe FlowBoxMoveCursorCallback Source #
A convenience synonym for Nothing :: Maybe FlowBoxMoveCursorCallback
onFlowBoxMoveCursor :: (IsFlowBox a, MonadIO m) => a -> FlowBoxMoveCursorCallback -> m SignalHandlerId Source #
Connect a signal handler for the moveCursor signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on flowBox #moveCursor callback
wrap_FlowBoxMoveCursorCallback :: FlowBoxMoveCursorCallback -> C_FlowBoxMoveCursorCallback Source #
Wrap a FlowBoxMoveCursorCallback into a C_FlowBoxMoveCursorCallback.
selectAll
type C_FlowBoxSelectAllCallback = Ptr () -> Ptr () -> IO () Source #
Type for the callback on the (unwrapped) C side.
type FlowBoxSelectAllCallback = IO () Source #
The selectAll signal is a [keybinding signal][GtkBindingSignal] which gets emitted to select all children of the box, if the selection mode permits it.
The default bindings for this signal is Ctrl-a.
afterFlowBoxSelectAll :: (IsFlowBox a, MonadIO m) => a -> FlowBoxSelectAllCallback -> m SignalHandlerId Source #
Connect a signal handler for the selectAll signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after flowBox #selectAll callback
genClosure_FlowBoxSelectAll :: MonadIO m => FlowBoxSelectAllCallback -> m (GClosure C_FlowBoxSelectAllCallback) Source #
Wrap the callback into a GClosure.
mk_FlowBoxSelectAllCallback :: C_FlowBoxSelectAllCallback -> IO (FunPtr C_FlowBoxSelectAllCallback) Source #
Generate a function pointer callable from C code, from a C_FlowBoxSelectAllCallback.
noFlowBoxSelectAllCallback :: Maybe FlowBoxSelectAllCallback Source #
A convenience synonym for Nothing :: Maybe FlowBoxSelectAllCallback
onFlowBoxSelectAll :: (IsFlowBox a, MonadIO m) => a -> FlowBoxSelectAllCallback -> m SignalHandlerId Source #
Connect a signal handler for the selectAll signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on flowBox #selectAll callback
wrap_FlowBoxSelectAllCallback :: FlowBoxSelectAllCallback -> C_FlowBoxSelectAllCallback Source #
Wrap a FlowBoxSelectAllCallback into a C_FlowBoxSelectAllCallback.
selectedChildrenChanged
type C_FlowBoxSelectedChildrenChangedCallback = Ptr () -> Ptr () -> IO () Source #
Type for the callback on the (unwrapped) C side.
type FlowBoxSelectedChildrenChangedCallback = IO () Source #
The selectedChildrenChanged signal is emitted when the set of selected children changes.
Use flowBoxSelectedForeach or
 flowBoxGetSelectedChildren to obtain the
 selected children.
afterFlowBoxSelectedChildrenChanged :: (IsFlowBox a, MonadIO m) => a -> FlowBoxSelectedChildrenChangedCallback -> m SignalHandlerId Source #
Connect a signal handler for the selectedChildrenChanged signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after flowBox #selectedChildrenChanged callback
genClosure_FlowBoxSelectedChildrenChanged :: MonadIO m => FlowBoxSelectedChildrenChangedCallback -> m (GClosure C_FlowBoxSelectedChildrenChangedCallback) Source #
Wrap the callback into a GClosure.
mk_FlowBoxSelectedChildrenChangedCallback :: C_FlowBoxSelectedChildrenChangedCallback -> IO (FunPtr C_FlowBoxSelectedChildrenChangedCallback) Source #
Generate a function pointer callable from C code, from a C_FlowBoxSelectedChildrenChangedCallback.
noFlowBoxSelectedChildrenChangedCallback :: Maybe FlowBoxSelectedChildrenChangedCallback Source #
A convenience synonym for Nothing :: Maybe FlowBoxSelectedChildrenChangedCallback
onFlowBoxSelectedChildrenChanged :: (IsFlowBox a, MonadIO m) => a -> FlowBoxSelectedChildrenChangedCallback -> m SignalHandlerId Source #
Connect a signal handler for the selectedChildrenChanged signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on flowBox #selectedChildrenChanged callback
wrap_FlowBoxSelectedChildrenChangedCallback :: FlowBoxSelectedChildrenChangedCallback -> C_FlowBoxSelectedChildrenChangedCallback Source #
toggleCursorChild
type C_FlowBoxToggleCursorChildCallback = Ptr () -> Ptr () -> IO () Source #
Type for the callback on the (unwrapped) C side.
type FlowBoxToggleCursorChildCallback = IO () Source #
The toggleCursorChild signal is a [keybinding signal][GtkBindingSignal] which toggles the selection of the child that has the focus.
The default binding for this signal is Ctrl-Space.
afterFlowBoxToggleCursorChild :: (IsFlowBox a, MonadIO m) => a -> FlowBoxToggleCursorChildCallback -> m SignalHandlerId Source #
Connect a signal handler for the toggleCursorChild signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after flowBox #toggleCursorChild callback
genClosure_FlowBoxToggleCursorChild :: MonadIO m => FlowBoxToggleCursorChildCallback -> m (GClosure C_FlowBoxToggleCursorChildCallback) Source #
Wrap the callback into a GClosure.
mk_FlowBoxToggleCursorChildCallback :: C_FlowBoxToggleCursorChildCallback -> IO (FunPtr C_FlowBoxToggleCursorChildCallback) Source #
Generate a function pointer callable from C code, from a C_FlowBoxToggleCursorChildCallback.
noFlowBoxToggleCursorChildCallback :: Maybe FlowBoxToggleCursorChildCallback Source #
A convenience synonym for Nothing :: Maybe FlowBoxToggleCursorChildCallback
onFlowBoxToggleCursorChild :: (IsFlowBox a, MonadIO m) => a -> FlowBoxToggleCursorChildCallback -> m SignalHandlerId Source #
Connect a signal handler for the toggleCursorChild signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on flowBox #toggleCursorChild callback
wrap_FlowBoxToggleCursorChildCallback :: FlowBoxToggleCursorChildCallback -> C_FlowBoxToggleCursorChildCallback Source #
unselectAll
type C_FlowBoxUnselectAllCallback = Ptr () -> Ptr () -> IO () Source #
Type for the callback on the (unwrapped) C side.
type FlowBoxUnselectAllCallback = IO () Source #
The unselectAll signal is a [keybinding signal][GtkBindingSignal] which gets emitted to unselect all children of the box, if the selection mode permits it.
The default bindings for this signal is Ctrl-Shift-a.
afterFlowBoxUnselectAll :: (IsFlowBox a, MonadIO m) => a -> FlowBoxUnselectAllCallback -> m SignalHandlerId Source #
Connect a signal handler for the unselectAll signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after flowBox #unselectAll callback
genClosure_FlowBoxUnselectAll :: MonadIO m => FlowBoxUnselectAllCallback -> m (GClosure C_FlowBoxUnselectAllCallback) Source #
Wrap the callback into a GClosure.
mk_FlowBoxUnselectAllCallback :: C_FlowBoxUnselectAllCallback -> IO (FunPtr C_FlowBoxUnselectAllCallback) Source #
Generate a function pointer callable from C code, from a C_FlowBoxUnselectAllCallback.
noFlowBoxUnselectAllCallback :: Maybe FlowBoxUnselectAllCallback Source #
A convenience synonym for Nothing :: Maybe FlowBoxUnselectAllCallback
onFlowBoxUnselectAll :: (IsFlowBox a, MonadIO m) => a -> FlowBoxUnselectAllCallback -> m SignalHandlerId Source #
Connect a signal handler for the unselectAll signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on flowBox #unselectAll callback