com.jidesoft.swing.SidePaneItem Maven / Gradle / Ivy
/*
* @(#)JideSidePaneItem.java
*
* Copyright 2002 JIDE Software Inc. All rights reserved.
*/
package com.jidesoft.swing;
import javax.swing.*;
import javax.swing.event.MouseInputListener;
import java.awt.*;
/**
* SidePaneItem is a data structure used by {@link SidePane}. It has a title, an icon, a component
* and a mouse listener.
*
* @see SidePane
*/
public class SidePaneItem {
private Icon _icon;
private String _title;
private Component _component;
private Color _foreground;
private Color _background;
private Font _font;
private MouseInputListener _mouseListener;
private boolean _selected = false;
/**
* Constructs a SidePaneItem with title.
*
* @param title title of SidePaneItem
*/
public SidePaneItem(String title) {
this(title, null, null, null);
}
/**
* Constructs a SidePaneItem with title and icon.
*
* @param title title of SidePaneItem
* @param icon icon of SidePaneItem
*/
public SidePaneItem(String title, Icon icon) {
this(title, icon, null, null);
}
/**
* Constructs a SidePaneItem with title, icon and component.
*
* @param title title of SidePaneItem
* @param icon icon of SidePaneItem
* @param component component in SidePaneItem
*/
public SidePaneItem(String title, Icon icon, Component component) {
this(title, icon, component, null);
}
/**
* Constructs a SidePaneItem with title, icon and component.
*
* @param title title of SidePaneItem
* @param icon icon of SidePaneItem
* @param component component in SidePaneItem
* @param listener mouse listener when user hover or click on SidePane
*/
public SidePaneItem(String title, Icon icon, Component component, MouseInputListener listener) {
setTitle(title);
setIcon(icon);
setComponent(component);
setMouseInputListener(listener);
}
/**
* Gets the icon.
*
* @return the icon
*/
public Icon getIcon() {
return _icon;
}
/**
* Sets the icon.
*
* @param icon the new icon
*/
public void setIcon(Icon icon) {
_icon = icon;
}
/**
* Gets the title.
*
* @return the title
*/
public String getTitle() {
return _title;
}
/**
* Sets the title.
*
* @param title the new title
*/
public void setTitle(String title) {
_title = title;
}
/**
* Gets the component.
*
* @return the component
*/
public Component getComponent() {
return _component;
}
/**
* Sets the component.
*
* @param component the new component
*/
public void setComponent(Component component) {
_component = component;
}
/**
* Gets the mouse listener.
*
* @return the mouse listener
*/
public MouseInputListener getMouseListener() {
return _mouseListener;
}
/**
* Sets the mouse listener.
*
* @param mouseListener the new mouse listener
*/
public void setMouseInputListener(MouseInputListener mouseListener) {
_mouseListener = mouseListener;
}
/**
* True if the item is selected.
*
* @return true if the item is selected.
*/
public boolean isSelected() {
return _selected;
}
/**
* Selects the item.
*
* @param selected the flag
*/
public void setSelected(boolean selected) {
_selected = selected;
}
/**
* Gets the foreground.
*
* If you didn't ever invoke {@link #setForeground(java.awt.Color)} and the component is an instance of {@link TabColorProvider},
* {@link TabColorProvider#getTabForeground()} will be used.
*
* @return the foreground color. null means that default color will be used.
*/
public Color getForeground() {
Color foreground = _foreground;
if (foreground == null && _component instanceof TabColorProvider) {
foreground = ((TabColorProvider) _component).getTabForeground();
}
return foreground;
}
/**
* Sets the foreground.
*
* @param foreground the foreground color
*/
public void setForeground(Color foreground) {
_foreground = foreground;
}
/**
* Gets the background.
*
* If you didn't ever invoke {@link #setBackground(java.awt.Color)} and the component is an instance of {@link TabColorProvider},
* {@link TabColorProvider#getTabBackground()} will be used.
*
* @return the background color. null means that default color will be used.
*/
public Color getBackground() {
Color background = _background;
if (background == null && _component instanceof TabColorProvider) {
background = ((TabColorProvider) _component).getTabBackground();
}
return background;
}
/**
* Sets the background.
*
* @param background the background color
*/
public void setBackground(Color background) {
_background = background;
}
/**
* Gets the font.
*
* @return the font. null means that default font will be used.
*/
public Font getFont() {
return _font;
}
/**
* Sets the font.
*
* @param font the font
*/
public void setFont(Font font) {
_font = font;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy