| Copyright | Will Thompson Iñaki García Etxebarria and Jonas Platte | 
|---|---|
| License | LGPL-2.1 | 
| Maintainer | Iñaki García Etxebarria | 
| Safe Haskell | Safe-Inferred | 
| Language | Haskell2010 | 
GI.Gtk.Objects.PopoverMenu
Description
GtkPopoverMenu is a subclass of Popover that treats its
 children like menus and allows switching between them. It
 can open submenus as traditional, nested submenus, or in a
 more touch-friendly sliding fashion.
GtkPopoverMenu is meant to be used primarily with menu models,
 using popoverMenuNewFromModel. If you need to put other
 widgets such as SpinButton or Switch into a popover,
 use a plain Popover.
Menu models
The XML format understood by Builder for MenuModel consists
 of a toplevel <menu> element, which contains one or more <item>
 elements. Each <item> element contains <attribute> and <link>
 elements with a mandatory name attribute. <link> elements have the
 same content model as <menu>. Instead of <link name="submenu> or
 <link name="section">, you can use <submenu> or <section>
 elements.
xml code
<menu id='app-menu'>
  <section>
    <item>
      <attribute name='label' translatable='yes'>_New Window</attribute>
      <attribute name='action'>app.new</attribute>
    </item>
    <item>
      <attribute name='label' translatable='yes'>_About Sunny</attribute>
      <attribute name='action'>app.about</attribute>
    </item>
    <item>
      <attribute name='label' translatable='yes'>_Quit</attribute>
      <attribute name='action'>app.quit</attribute>
    </item>
  </section>
</menu>Attribute values can be translated using gettext, like other Builder
 content. <attribute> elements can be marked for translation with a
 translatable="yes" attribute. It is also possible to specify message
 context and translator comments, using the context and comments attributes.
 To make use of this, the Builder must have been given the gettext
 domain to use.
The following attributes are used when constructing menu items:
- "label": a user-visible string to display
- "action": the prefixed name of the action to trigger
- "target": the parameter to use when activating the action
- "icon" and "verb-icon": names of icons that may be displayed
- "submenu-action": name of an action that may be used to determine if a submenu can be opened
- "hidden-when": a string used to determine when the item will be hidden.
    Possible values include "action-disabled", "action-missing", "macos-menubar".
    This is mainly useful for exported menus, see applicationSetMenubar.
- "custom": a string used to match against the ID of a custom child added
    with popoverMenuAddChild,popoverMenuBarAddChild, or in the ui file with<child type="ID">.
The following attributes are used when constructing sections:
- "label": a user-visible string to use as section heading
- "display-hint": a string used to determine special formatting for the section. Possible values include "horizontal-buttons", "circular-buttons" and "inline-buttons". They all indicate that section should be displayed as a horizontal row of buttons.
- "text-direction": a string used to determine the TextDirectionto use when "display-hint" is set to "horizontal-buttons". Possible values include "rtl", "ltr", and "none".
The following attributes are used when constructing submenus:
- "label": a user-visible string to display
- "icon": icon name to display
Menu items will also show accelerators, which are usually associated
 with actions via applicationSetAccelsForAction,
 gtk_widget_class_add_binding_action() or shortcutControllerAddShortcut.
CSS Nodes
PopoverMenu is just a subclass of Popover that adds
 custom content to it, therefore it has the same CSS nodes.
 It is one of the cases that add a .menu style class to
 the popover's main node.
Accessibility
GtkPopoverMenu uses the GTK_ACCESSIBLE_ROLE_MENU role, and its
 items use the GTK_ACCESSIBLE_ROLE_MENU_ITEM, GTK_ACCESSIBLE_ROLE_MENU_ITEM_CHECKBOX or GTK_ACCESSIBLE_ROLE_MENU_ITEM_RADIO roles, depending on the
 action they are connected to.
Synopsis
- newtype PopoverMenu = PopoverMenu (ManagedPtr PopoverMenu)
- class (GObject o, IsDescendantOf PopoverMenu o) => IsPopoverMenu o
- toPopoverMenu :: (MonadIO m, IsPopoverMenu o) => o -> m PopoverMenu
- popoverMenuAddChild :: (HasCallStack, MonadIO m, IsPopoverMenu a, IsWidget b) => a -> b -> Text -> m Bool
- popoverMenuGetMenuModel :: (HasCallStack, MonadIO m, IsPopoverMenu a) => a -> m MenuModel
- popoverMenuNewFromModel :: (HasCallStack, MonadIO m, IsMenuModel a) => Maybe a -> m PopoverMenu
- popoverMenuNewFromModelFull :: (HasCallStack, MonadIO m, IsMenuModel a) => a -> [PopoverMenuFlags] -> m PopoverMenu
- popoverMenuRemoveChild :: (HasCallStack, MonadIO m, IsPopoverMenu a, IsWidget b) => a -> b -> m Bool
- popoverMenuSetMenuModel :: (HasCallStack, MonadIO m, IsPopoverMenu a, IsMenuModel b) => a -> Maybe b -> m ()
- clearPopoverMenuMenuModel :: (MonadIO m, IsPopoverMenu o) => o -> m ()
- constructPopoverMenuMenuModel :: (IsPopoverMenu o, MonadIO m, IsMenuModel a) => a -> m (GValueConstruct o)
- getPopoverMenuMenuModel :: (MonadIO m, IsPopoverMenu o) => o -> m MenuModel
- setPopoverMenuMenuModel :: (MonadIO m, IsPopoverMenu o, IsMenuModel a) => o -> a -> m ()
- clearPopoverMenuVisibleSubmenu :: (MonadIO m, IsPopoverMenu o) => o -> m ()
- constructPopoverMenuVisibleSubmenu :: (IsPopoverMenu o, MonadIO m) => Text -> m (GValueConstruct o)
- getPopoverMenuVisibleSubmenu :: (MonadIO m, IsPopoverMenu o) => o -> m (Maybe Text)
- setPopoverMenuVisibleSubmenu :: (MonadIO m, IsPopoverMenu o) => o -> Text -> m ()
Exported types
newtype PopoverMenu Source #
Memory-managed wrapper type.
Constructors
| PopoverMenu (ManagedPtr PopoverMenu) | 
Instances
| Eq PopoverMenu Source # | |
| Defined in GI.Gtk.Objects.PopoverMenu | |
| GObject PopoverMenu Source # | |
| Defined in GI.Gtk.Objects.PopoverMenu | |
| ManagedPtrNewtype PopoverMenu Source # | |
| Defined in GI.Gtk.Objects.PopoverMenu Methods toManagedPtr :: PopoverMenu -> ManagedPtr PopoverMenu | |
| TypedObject PopoverMenu Source # | |
| Defined in GI.Gtk.Objects.PopoverMenu | |
| HasParentTypes PopoverMenu Source # | |
| Defined in GI.Gtk.Objects.PopoverMenu | |
| IsGValue (Maybe PopoverMenu) Source # | Convert  | 
| Defined in GI.Gtk.Objects.PopoverMenu Methods gvalueGType_ :: IO GType gvalueSet_ :: Ptr GValue -> Maybe PopoverMenu -> IO () gvalueGet_ :: Ptr GValue -> IO (Maybe PopoverMenu) | |
| type ParentTypes PopoverMenu Source # | |
| Defined in GI.Gtk.Objects.PopoverMenu type ParentTypes PopoverMenu = '[Popover, Widget, Object, Accessible, Buildable, ConstraintTarget, Native, ShortcutManager] | |
class (GObject o, IsDescendantOf PopoverMenu o) => IsPopoverMenu o Source #
Type class for types which can be safely cast to PopoverMenu, for instance with toPopoverMenu.
Instances
| (GObject o, IsDescendantOf PopoverMenu o) => IsPopoverMenu o Source # | |
| Defined in GI.Gtk.Objects.PopoverMenu | |
toPopoverMenu :: (MonadIO m, IsPopoverMenu o) => o -> m PopoverMenu Source #
Cast to PopoverMenu, for types for which this is known to be safe. For general casts, use castTo.
Methods
Click to display all available methods, including inherited ones
Methods
actionSetEnabled, activate, activateAction, activateDefault, addChild, addController, addCssClass, addMnemonicLabel, addTickCallback, allocate, bindProperty, bindPropertyFull, childFocus, computeBounds, computeExpand, computePoint, computeTransform, contains, createPangoContext, createPangoLayout, dragCheckThreshold, errorBell, forceFloating, freezeNotify, getv, grabFocus, hasCssClass, hasDefault, hasFocus, hasVisibleFocus, hide, inDestruction, initTemplate, insertActionGroup, insertAfter, insertBefore, isAncestor, isDrawable, isFloating, isFocus, isSensitive, isVisible, keynavFailed, listMnemonicLabels, map, measure, mnemonicActivate, notify, notifyByPspec, observeChildren, observeControllers, pick, popdown, popup, present, queueAllocate, queueDraw, queueResize, realize, ref, refSink, removeChild, removeController, removeCssClass, removeMnemonicLabel, removeTickCallback, resetProperty, resetRelation, resetState, runDispose, shouldLayout, show, sizeAllocate, snapshotChild, stealData, stealQdata, thawNotify, translateCoordinates, triggerTooltipQuery, unmap, unparent, unrealize, unref, unsetStateFlags, updateProperty, updateRelation, updateState, watchClosure.
Getters
getAccessibleRole, getAllocatedBaseline, getAllocatedHeight, getAllocatedWidth, getAllocation, getAncestor, getAutohide, getBuildableId, getCanFocus, getCanTarget, getCascadePopdown, getChild, getChildVisible, getClipboard, getCssClasses, getCssName, getCursor, getData, getDirection, getDisplay, getFirstChild, getFocusChild, getFocusOnClick, getFocusable, getFontMap, getFontOptions, getFrameClock, getHalign, getHasArrow, getHasTooltip, getHeight, getHexpand, getHexpandSet, getLastChild, getLayoutManager, getMapped, getMarginBottom, getMarginEnd, getMarginStart, getMarginTop, getMenuModel, getMnemonicsVisible, getName, getNative, getNextSibling, getOffset, getOpacity, getOverflow, getPangoContext, getParent, getPointingTo, getPosition, getPreferredSize, getPrevSibling, getPrimaryClipboard, getProperty, getQdata, getRealized, getReceivesDefault, getRenderer, getRequestMode, getRoot, getScaleFactor, getSensitive, getSettings, getSize, getSizeRequest, getStateFlags, getStyleContext, getSurface, getSurfaceTransform, getTemplateChild, getTooltipMarkup, getTooltipText, getValign, getVexpand, getVexpandSet, getVisible, getWidth.
Setters
setAutohide, setCanFocus, setCanTarget, setCascadePopdown, setChild, setChildVisible, setCssClasses, setCursor, setCursorFromName, setData, setDataFull, setDefaultWidget, setDirection, setFocusChild, setFocusOnClick, setFocusable, setFontMap, setFontOptions, setHalign, setHasArrow, setHasTooltip, setHexpand, setHexpandSet, setLayoutManager, setMarginBottom, setMarginEnd, setMarginStart, setMarginTop, setMenuModel, setMnemonicsVisible, setName, setOffset, setOpacity, setOverflow, setParent, setPointingTo, setPosition, setProperty, setReceivesDefault, setSensitive, setSizeRequest, setStateFlags, setTooltipMarkup, setTooltipText, setValign, setVexpand, setVexpandSet, setVisible.
addChild
Arguments
| :: (HasCallStack, MonadIO m, IsPopoverMenu a, IsWidget b) | |
| => a | 
 | 
| -> b | 
 | 
| -> Text | 
 | 
| -> m Bool | Returns:  | 
Adds a custom widget to a generated menu.
For this to work, the menu model of popover must have an
 item with a custom attribute that matches id.
getMenuModel
popoverMenuGetMenuModel Source #
Arguments
| :: (HasCallStack, MonadIO m, IsPopoverMenu a) | |
| => a | 
 | 
| -> m MenuModel | Returns: the menu model of  | 
Returns the menu model used to populate the popover.
newFromModel
popoverMenuNewFromModel Source #
Arguments
| :: (HasCallStack, MonadIO m, IsMenuModel a) | |
| => Maybe a | |
| -> m PopoverMenu | Returns: the new  | 
Creates a PopoverMenu and populates it according to
 model.
The created buttons are connected to actions found in the
 ApplicationWindow to which the popover belongs - typically
 by means of being attached to a widget that is contained within
 the GtkApplicationWindows widget hierarchy.
Actions can also be added using widgetInsertActionGroup
 on the menus attach widget or on any of its parent widgets.
This function creates menus with sliding submenus.
 See popoverMenuNewFromModelFull for a way
 to control this.
newFromModelFull
popoverMenuNewFromModelFull Source #
Arguments
| :: (HasCallStack, MonadIO m, IsMenuModel a) | |
| => a | 
 | 
| -> [PopoverMenuFlags] | 
 | 
| -> m PopoverMenu | Returns: the new  | 
Creates a PopoverMenu and populates it according to
 model.
The created buttons are connected to actions found in the
 action groups that are accessible from the parent widget.
 This includes the ApplicationWindow to which the popover
 belongs. Actions can also be added using widgetInsertActionGroup
 on the parent widget or on any of its parent widgets.
The only flag that is supported currently is
 GTK_POPOVER_MENU_NESTED, which makes GTK create traditional,
 nested submenus instead of the default sliding submenus.
removeChild
popoverMenuRemoveChild Source #
Arguments
| :: (HasCallStack, MonadIO m, IsPopoverMenu a, IsWidget b) | |
| => a | 
 | 
| -> b | 
 | 
| -> m Bool | Returns:  | 
Removes a widget that has previously been added with
 popoverMenuAddChild.
setMenuModel
popoverMenuSetMenuModel Source #
Arguments
| :: (HasCallStack, MonadIO m, IsPopoverMenu a, IsMenuModel b) | |
| => a | 
 | 
| -> Maybe b | |
| -> m () | 
Sets a new menu model on popover.
The existing contents of popover are removed, and
 the popover is populated with new contents according
 to model.
Properties
menuModel
No description available in the introspection data.
clearPopoverMenuMenuModel :: (MonadIO m, IsPopoverMenu o) => o -> m () Source #
Set the value of the “menu-model” property to Nothing.
 When overloading is enabled, this is equivalent to
clear #menuModel
constructPopoverMenuMenuModel :: (IsPopoverMenu o, MonadIO m, IsMenuModel a) => a -> m (GValueConstruct o) Source #
Construct a GValueConstruct with valid value for the “menu-model” property. This is rarely needed directly, but it is used by new.
getPopoverMenuMenuModel :: (MonadIO m, IsPopoverMenu o) => o -> m MenuModel Source #
Get the value of the “menu-model” property.
 When overloading is enabled, this is equivalent to
get popoverMenu #menuModel
setPopoverMenuMenuModel :: (MonadIO m, IsPopoverMenu o, IsMenuModel a) => o -> a -> m () Source #
Set the value of the “menu-model” property.
 When overloading is enabled, this is equivalent to
setpopoverMenu [ #menuModel:=value ]
visibleSubmenu
No description available in the introspection data.
clearPopoverMenuVisibleSubmenu :: (MonadIO m, IsPopoverMenu o) => o -> m () Source #
Set the value of the “visible-submenu” property to Nothing.
 When overloading is enabled, this is equivalent to
clear #visibleSubmenu
constructPopoverMenuVisibleSubmenu :: (IsPopoverMenu o, MonadIO m) => Text -> m (GValueConstruct o) Source #
Construct a GValueConstruct with valid value for the “visible-submenu” property. This is rarely needed directly, but it is used by new.
getPopoverMenuVisibleSubmenu :: (MonadIO m, IsPopoverMenu o) => o -> m (Maybe Text) Source #
Get the value of the “visible-submenu” property.
 When overloading is enabled, this is equivalent to
get popoverMenu #visibleSubmenu
setPopoverMenuVisibleSubmenu :: (MonadIO m, IsPopoverMenu o) => o -> Text -> m () Source #
Set the value of the “visible-submenu” property.
 When overloading is enabled, this is equivalent to
setpopoverMenu [ #visibleSubmenu:=value ]