com.l2fprod.common.swing.JOutlookBar Maven / Gradle / Ivy
/**
* @PROJECT.FULLNAME@ @VERSION@ License.
*
* Copyright @YEAR@ L2FProd.com
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.l2fprod.common.swing;
import com.l2fprod.common.swing.plaf.JOutlookBarAddon;
import com.l2fprod.common.swing.plaf.LookAndFeelAddons;
import com.l2fprod.common.swing.plaf.OutlookBarUI;
import java.awt.Color;
import java.awt.Component;
import java.util.Iterator;
import java.util.Map;
import java.util.WeakHashMap;
import javax.swing.Icon;
import javax.swing.JScrollPane;
import javax.swing.JTabbedPane;
import javax.swing.UIManager;
import javax.swing.plaf.TabbedPaneUI;
/**
* JOutlookBar
brings the famous Outlook component to
* Swing. The component shows stacks of components where only one
* stack is visible at a time.
*
* The tab orientation of the {@link javax.swing.JTabbedPane}is
* mapped to the JOutlookBar orientation as follow:
*
* - with JTabbedPane.TOP or JTabbedPane.BOTTOM, JOutlookBar will
* layout the components horizontally
*
- with JTabbedPane.LEFT or JTabbedPane.RIGHT, JOutlookBar will
* layout the components vertically (default)
*
*
* @javabean.class
* name="JOutlookBar"
* shortDescription="JOutlookBar brings the famous Outlook component to Swing"
* stopClass="javax.swing.JTabbedPane"
*
* @javabean.icons
* mono16="JOutlookBar16-mono.gif"
* color16="JOutlookBar16.gif"
* mono32="JOutlookBar32-mono.gif"
* color32="JOutlookBar32.gif"
*/
public class JOutlookBar extends JTabbedPane {
public static final String UI_CLASS_ID = "OutlookBarUI";
static {
LookAndFeelAddons.contribute(new JOutlookBarAddon());
}
/**
* Used when generating PropertyChangeEvents for the "animated" property
*/
public static final String ANIMATED_CHANGED_KEY = "animated";
protected Map extendedPages;
private boolean animated = true;
/**
*
*/
public JOutlookBar() {
this(LEFT);
}
/**
* @param tabPlacement
*/
public JOutlookBar(int tabPlacement) {
super(tabPlacement, WRAP_TAB_LAYOUT);
extendedPages = new WeakHashMap();
updateUI();
}
/**
* Notification from the UIManager
that the L&F has
* changed. Replaces the current UI object with the latest version
* from the UIManager
.
*
* @see javax.swing.JComponent#updateUI
*/
public void updateUI() {
setUI((OutlookBarUI)LookAndFeelAddons.getUI(this, OutlookBarUI.class));
}
/**
* Sets the L&F object that renders this component.
*
* @param ui the OutlookBarUI
L&F object
* @see javax.swing.UIDefaults#getUI
*
* @beaninfo bound: true hidden: true description: The UI object
* that implements the buttonbar's LookAndFeel.
*/
public void setUI(OutlookBarUI ui) {
super.setUI((TabbedPaneUI)ui);
}
/**
* Returns the name of the L&F class that renders this component.
*
* @return the string {@link #UI_CLASS_ID}
* @see javax.swing.JComponent#getUIClassID
* @see javax.swing.UIDefaults#getUI
*/
public String getUIClassID() {
return UI_CLASS_ID;
}
/**
* Enables or disables animation during tab transition.
*
* @param animated
* @javabean.property
* bound="true"
* preferred="true"
*/
public void setAnimated(boolean animated) {
if (this.animated != animated) {
this.animated = animated;
firePropertyChange(ANIMATED_CHANGED_KEY, !animated, animated);
}
}
/**
* @return true if this taskpane is animated during expand/collapse
* transition.
*/
public boolean isAnimated() {
return animated;
}
/**
* Builds a JScrollPane to hold the component. By default tabs are
* not scrollable. They can be made scrollable by putting them in a
* JScrollPane and adding the JScrollPane instead of the tab to the
* JOutlookBar. It is recommended to use this method to create the
* scrollbar as the UI may choose to return a JScrollPane specially
* configured for the JOutlookBar component (ex. with different
* scrollbars)
*
* @param component
* @return a JScrollPane with component
as view
*/
public JScrollPane makeScrollPane(Component component) {
return ((OutlookBarUI)getUI()).makeScrollPane(component);
}
public void removeTabAt(int index) {
checkIndex(index);
removeExtendedPage(index);
super.removeTabAt(index);
}
/**
* Sets the title alignment for all tabs
*
* @param alignment
* one of {@link javax.swing.SwingConstants#LEFT},
* {@link javax.swing.SwingConstants#CENTER},
* {@link javax.swing.SwingConstants#RIGHT}.
*/
public void setAllTabsAlignment(int alignment) {
for (Iterator iter = extendedPages.values().iterator(); iter.hasNext();) {
ExtendedPage page = (ExtendedPage)iter.next();
page.setTabAlignment(alignment);
}
}
/**
* Sets the title alignment of the tab at index
*
* @param index
* @param alignment
* one of {@link javax.swing.SwingConstants#LEFT},
* {@link javax.swing.SwingConstants#CENTER},
* {@link javax.swing.SwingConstants#RIGHT}.
*/
public void setAlignmentAt(int index, int alignment) {
getExtendedPage(index).setTabAlignment(alignment);
}
/**
* @param index
* @return the title alignment of the tab at index
*/
public int getAlignmentAt(int index) {
return getExtendedPage(index).getTabAlignment();
}
/**
* Overriden to notify the UI about the change
*/
public void setTitleAt(int index, String title) {
super.setTitleAt(index, title);
firePropertyChange("tabPropertyChangedAtIndex", null, new Integer(index));
}
/**
* Overriden to notify the UI about the change
*/
public void setIconAt(int index, Icon icon) {
super.setIconAt(index, icon);
firePropertyChange("tabPropertyChangedAtIndex", null, new Integer(index));
}
public Color getBackgroundAt(int index) {
return getExtendedPage(index).getBackground();
}
/**
* Overriden to notify the UI about the change
*/
public void setBackgroundAt(int index, Color background) {
getExtendedPage(index).setBackground(background);
firePropertyChange("tabPropertyChangedAtIndex", null, new Integer(index));
}
public Color getForegroundAt(int index) {
return getExtendedPage(index).getForeground();
}
/**
* Overriden to notify the UI about the change
*/
public void setForegroundAt(int index, Color foreground) {
getExtendedPage(index).setForeground(foreground);
firePropertyChange("tabPropertyChangedAtIndex", null, new Integer(index));
}
/**
* Overriden to notify the UI about the change
*/
public void setToolTipTextAt(int index, String toolTipText) {
super.setToolTipTextAt(index, toolTipText);
firePropertyChange("tabPropertyChangedAtIndex", null, new Integer(index));
}
/**
* Overriden to notify the UI about the change
*/
public void setDisplayedMnemonicIndexAt(int tabIndex, int mnemonicIndex) {
super.setDisplayedMnemonicIndexAt(tabIndex, mnemonicIndex);
firePropertyChange("tabPropertyChangedAtIndex", null, new Integer(tabIndex));
}
/**
* Overriden to notify the UI about the change
*/
public void setMnemonicAt(int index, int mnemonic) {
super.setMnemonicAt(index, mnemonic);
firePropertyChange("tabPropertyChangedAtIndex", null, new Integer(index));
}
/**
* Overriden to notify the UI about the change
*/
public void setDisabledIconAt(int index, Icon disabledIcon) {
super.setDisabledIconAt(index, disabledIcon);
firePropertyChange("tabPropertyChangedAtIndex", null, new Integer(index));
}
/**
* Overriden to notify the UI about the change
*/
public void setEnabledAt(int index, boolean enabled) {
super.setEnabledAt(index, enabled);
firePropertyChange("tabPropertyChangedAtIndex", null, new Integer(index));
}
protected void addImpl(Component comp, Object constraints, int index) {
if (index != -1) {
super.addImpl(comp, constraints, index);
} else {
// insertTab always add component at the end of the components array
// however the look and feel classes of JOutlookBar expect the component
// to be in the right order when it calls getComponents().
// We must make sure the component gets inserted in the right place
int pageIndex = indexOfComponent(comp);
if (pageIndex == -1) {
super.addImpl(comp, constraints, index);
} else {
// this is one of our component, attempt to insert it in the right
// position
super.addImpl(comp, constraints, pageIndex * 2);
}
}
}
protected void removeExtendedPage(int index) {
Component component = getComponentAt(index);
extendedPages.remove(component);
}
protected ExtendedPage getExtendedPage(int index) {
checkIndex(index);
Component component = getComponentAt(index);
ExtendedPage page = (ExtendedPage)extendedPages.get(component);
if (page == null) {
page = new ExtendedPage();
page.component = component;
extendedPages.put(component, page);
}
return page;
}
private void checkIndex(int index) {
if (index < 0 || index >= getTabCount()) {
throw new IndexOutOfBoundsException(
"Index: " + index + ", Tab count: " + getTabCount());
}
}
private class ExtendedPage {
Component component;
int alignment = UIManager.getInt("OutlookBar.tabAlignment");
Color background = null;
Color foreground = null;
public void setTabAlignment(int alignment) {
if (this.alignment != alignment) {
this.alignment = alignment;
JOutlookBar.this.firePropertyChange("tabPropertyChangedAtIndex", null,
new Integer(getIndex()));
}
}
public int getIndex() {
return indexOfComponent(component);
}
public int getTabAlignment() {
return alignment;
}
public Color getBackground() {
return background;
}
public void setBackground(Color background) {
this.background = background;
}
public Color getForeground() {
return foreground;
}
public void setForeground(Color foreground) {
this.foreground = foreground;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy