Class IMenuButton

All Implemented Interfaces:
HasAttachHandlers, HasHandlers, EventListener, HasVisibility, IsWidget, LogicalStructure, HasClearHandlers, HasClickHandlers, HasDoubleClickHandlers, HasDragMoveHandlers, HasDragRepositionMoveHandlers, HasDragRepositionStartHandlers, HasDragRepositionStopHandlers, HasDragResizeMoveHandlers, HasDragResizeStartHandlers, HasDragResizeStopHandlers, HasDragStartHandlers, HasDragStopHandlers, HasDropHandlers, HasDropMoveHandlers, HasDropOutHandlers, HasDropOverHandlers, HasFocusChangedHandlers, HasHoverHandlers, HasHoverHiddenHandlers, HasIconClickHandlers, HasKeyDownHandlers, HasKeyPressHandlers, HasMouseDownHandlers, HasMouseMoveHandlers, HasMouseOutHandlers, HasMouseOverHandlers, HasMouseStillDownHandlers, HasMouseUpHandlers, HasMouseWheelHandlers, HasMovedHandlers, HasParentMovedHandlers, HasResizedHandlers, HasRightMouseDownHandlers, HasRuleContextChangedHandlers, HasScrolledHandlers, HasShowContextMenuHandlers, HasTitleHoverHandlers, HasVisibilityChangedHandlers
Direct Known Subclasses:
ToolStripMenuButton

public class IMenuButton extends StretchImgButton
IMenuButton based version of the MenuButton class.
  • Constructor Details

    • IMenuButton

      public IMenuButton()
    • IMenuButton

      public IMenuButton(JavaScriptObject jsObj)
    • IMenuButton

      public IMenuButton(String title)
    • IMenuButton

      public IMenuButton(String title, Menu menu)
  • Method Details

    • getOrCreateRef

      public static IMenuButton getOrCreateRef(JavaScriptObject jsObj)
    • changeAutoChildDefaults

      public static void changeAutoChildDefaults(String autoChildName, Canvas defaults)
      Changes the defaults for Canvas AutoChildren named autoChildName.
      Parameters:
      autoChildName - name of an AutoChild to customize the defaults for.
      defaults - Canvas defaults to apply. These defaults override any existing properties without destroying or wiping out non-overridden properties. For usage tips on this param, see SGWTProperties.
      See Also:
    • changeAutoChildDefaults

      public static void changeAutoChildDefaults(String autoChildName, FormItem defaults)
      Changes the defaults for FormItem AutoChildren named autoChildName.
      Parameters:
      autoChildName - name of an AutoChild to customize the defaults for.
      defaults - FormItem defaults to apply. These defaults override any existing properties without destroying or wiping out non-overridden properties. For usage tips on this param, see SGWTProperties.
      See Also:
    • create

      protected JavaScriptObject create()
      Overrides:
      create in class StretchImgButton
    • setAutoDestroyMenu

      public IMenuButton setAutoDestroyMenu(Boolean autoDestroyMenu)
      If this menuButton is destroyed, should it also destroy its MenuButton.menu?
      Parameters:
      autoDestroyMenu - New autoDestroyMenu value. Default value is true
      Returns:
      IMenuButton instance, for chaining setter calls
    • getAutoDestroyMenu

      public Boolean getAutoDestroyMenu()
      If this menuButton is destroyed, should it also destroy its MenuButton.menu?
      Returns:
      Current autoDestroyMenu value. Default value is true
    • setHiliteAccessKey

      public IMenuButton setHiliteAccessKey(Boolean hiliteAccessKey) throws IllegalStateException
      If this MenuButton has a specified accessKey, underline it in the title of the button by default
      Overrides:
      setHiliteAccessKey in class StretchImgButton
      Parameters:
      hiliteAccessKey - New hiliteAccessKey value. Default value is true
      Returns:
      IMenuButton instance, for chaining setter calls
      Throws:
      IllegalStateException - this property cannot be changed after the component has been created
    • getHiliteAccessKey

      public Boolean getHiliteAccessKey()
      If this MenuButton has a specified accessKey, underline it in the title of the button by default
      Overrides:
      getHiliteAccessKey in class StretchImgButton
      Returns:
      Current hiliteAccessKey value. Default value is true
    • setMenu

      public IMenuButton setMenu(Menu menu)
      The menu to show.

      For a menu button with no menu (menu: null) the up/down arrow image can be suppressed by setting showMenuButtonImage: false.

      Parameters:
      menu - New menu value. Default value is null
      Returns:
      IMenuButton instance, for chaining setter calls
    • getMenu

      public Menu getMenu()
      The menu to show.

      For a menu button with no menu (menu: null) the up/down arrow image can be suppressed by setting showMenuButtonImage: false.

      Returns:
      Current menu value. Default value is null
    • setMenuAlign

      public IMenuButton setMenuAlign(Alignment menuAlign) throws IllegalStateException
      The horizontal alignment of this button's menu, in relation to the button. When unset, default behavior is to align the right edges of button and menu if the page is in RTL mode, and the left edges otherwise.
      Parameters:
      menuAlign - New menuAlign value. Default value is null
      Returns:
      IMenuButton instance, for chaining setter calls
      Throws:
      IllegalStateException - this property cannot be changed after the component has been created
    • getMenuAlign

      public Alignment getMenuAlign()
      The horizontal alignment of this button's menu, in relation to the button. When unset, default behavior is to align the right edges of button and menu if the page is in RTL mode, and the left edges otherwise.
      Returns:
      Current menuAlign value. Default value is null
    • setMenuAnimationEffect

      public IMenuButton setMenuAnimationEffect(String menuAnimationEffect)
      Allows you to specify an animation effect to apply to the menu when it is being shown. Valid options are "none" (no animation), "fade", "slide" and "wipe". If unspecified falls through to menu.showAnimationEffect

      Note : This is an advanced setting

      Parameters:
      menuAnimationEffect - New menuAnimationEffect value. Default value is null
      Returns:
      IMenuButton instance, for chaining setter calls
    • getMenuAnimationEffect

      public String getMenuAnimationEffect()
      Allows you to specify an animation effect to apply to the menu when it is being shown. Valid options are "none" (no animation), "fade", "slide" and "wipe". If unspecified falls through to menu.showAnimationEffect
      Returns:
      Current menuAnimationEffect value. Default value is null
    • setMenuButtonImage

      public IMenuButton setMenuButtonImage(String menuButtonImage) throws IllegalStateException
      Image for menu button indicating that the button expands a menu. This image is shown for menus expanding down from the button. Menu direction is controlled by MenuButton.showMenuBelow.

      Note : This is an advanced setting

      Parameters:
      menuButtonImage - New menuButtonImage value. Default value is "[SKIN]menu_button.gif"
      Returns:
      IMenuButton instance, for chaining setter calls
      Throws:
      IllegalStateException - this property cannot be changed after the component has been created
      See Also:
    • getMenuButtonImage

      public String getMenuButtonImage()
      Image for menu button indicating that the button expands a menu. This image is shown for menus expanding down from the button. Menu direction is controlled by MenuButton.showMenuBelow.
      Returns:
      Current menuButtonImage value. Default value is "[SKIN]menu_button.gif"
      See Also:
    • setMenuButtonImageUp

      public IMenuButton setMenuButtonImageUp(String menuButtonImageUp) throws IllegalStateException
      Image for menu button indicating that the button expands a menu. This image is shown for menus expanding up from the button. Menu direction is controlled by MenuButton.showMenuBelow.

      Note : This is an advanced setting

      Parameters:
      menuButtonImageUp - New menuButtonImageUp value. Default value is "[SKIN]menu_button_up.gif"
      Returns:
      IMenuButton instance, for chaining setter calls
      Throws:
      IllegalStateException - this property cannot be changed after the component has been created
      See Also:
    • getMenuButtonImageUp

      public String getMenuButtonImageUp()
      Image for menu button indicating that the button expands a menu. This image is shown for menus expanding up from the button. Menu direction is controlled by MenuButton.showMenuBelow.
      Returns:
      Current menuButtonImageUp value. Default value is "[SKIN]menu_button_up.gif"
      See Also:
    • setShowMenuBelow

      public IMenuButton setShowMenuBelow(Boolean showMenuBelow)
      The menu drops down below the menu button. Set to false if the menu should appear above the menu button.

      If this method is called after the component has been drawn/initialized: Setter for the 'showMenuButtonBelow' property - determines whether the menu will be shown above or below the MenuButton.
      Parameters:
      showMenuBelow - True if the menu should be shown below the MenuButton. Default value is true
      Returns:
      IMenuButton instance, for chaining setter calls
    • getShowMenuBelow

      public Boolean getShowMenuBelow()
      The menu drops down below the menu button. Set to false if the menu should appear above the menu button.
      Returns:
      Current showMenuBelow value. Default value is true
    • setShowMenuButtonImage

      public IMenuButton setShowMenuButtonImage(Boolean showMenuButtonImage) throws IllegalStateException
      Show menu button image (up / down arrowhead) for this menu button.

      If this method is called after the component has been drawn/initialized: Setter for the 'showMenuButtonImage' property - shows/hides the menu button image at runtime.
      Parameters:
      showMenuButtonImage - Should the image be shown. Default value is true
      Returns:
      IMenuButton instance, for chaining setter calls
      Throws:
      IllegalStateException - this property cannot be changed after the component has been created
    • getShowMenuButtonImage

      public Boolean getShowMenuButtonImage()
      Show menu button image (up / down arrowhead) for this menu button.
      Returns:
      Current showMenuButtonImage value. Default value is true
    • setTitle

      public void setTitle(String title)
      Default title for the button.
      Overrides:
      setTitle in class StretchImgButton
      Parameters:
      title - New title value. Default value is "Show Menu"
      See Also:
    • getTitle

      public String getTitle()
      Default title for the button.
      Overrides:
      getTitle in class StretchImgButton
      Returns:
      Current title value. Default value is "Show Menu"
      See Also:
    • setDefaultProperties

      public static void setDefaultProperties(IMenuButton iMenuButtonProperties)
      Class level method to set the default properties of this class. If set, then all existing and subsequently created instances of this class will automatically have default properties corresponding to the properties set on the SmartGWT class instance passed to this function before its underlying SmartClient JS object was created. This is a powerful feature that eliminates the need for users to create a separate hierarchy of subclasses that only alter the default properties of this class. Can also be used for skinning / styling purposes.

      Note: This method is intended for setting default attributes only and will affect all instances of the underlying class (including those automatically generated in JavaScript). This method should not be used to apply standard EventHandlers or override methods for a class - use a custom subclass instead. Calling this method after instances have been created can result in undefined behavior, since it bypasses any setters and a class instance may have already examined a particular property and not be expecting any changes through this route.

      Parameters:
      iMenuButtonProperties - properties that should be used as new defaults when instances of this class are created
      See Also:
    • setLogicalStructure

      public LogicalStructureObject setLogicalStructure(IMenuButtonLogicalStructure s)
      Setter implementing the LogicalStructure interface, which supports Eclipse's logical structure debugging facility.
    • getLogicalStructure

      public LogicalStructureObject getLogicalStructure()
      Getter implementing the LogicalStructure interface, which supports Eclipse's logical structure debugging facility.
      Specified by:
      getLogicalStructure in interface LogicalStructure
      Overrides:
      getLogicalStructure in class StretchImgButton