CategoryPanel.java revision 6638c2755466ca601450700d5a39f390f23d4781
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at legal-notices/CDDLv1_0.txt
* or http://forgerock.org/license/CDDLv1.0.html.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at legal-notices/CDDLv1_0.txt.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information:
* Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*
*
* Copyright 2008 Sun Microsystems, Inc.
* Portions Copyright 2015 ForgeRock AS.
*/
package org.opends.guitools.controlpanel.ui.components;
import java.awt.BorderLayout;
import java.awt.Color;
import javax.swing.JComponent;
import javax.swing.JPanel;
import javax.swing.border.Border;
import javax.swing.event.ChangeEvent;
import javax.swing.event.ChangeListener;
import org.opends.guitools.controlpanel.datamodel.Category;
import org.opends.guitools.controlpanel.ui.border.AccordionElementBorder;
/**
* The panel representing a category. It contains a CategoryButton and a panel
* that is displayed when the CategoryButton is in a certain state. They
* are used on the left side of the main Control Panel.
*
*/
public class CategoryPanel extends JPanel {
private static final long serialVersionUID = 8941374689175404431L;
private JPanel panel;
private JComponent child;
private Category category;
private CategoryButton expandButton;
private boolean expanded = true;
static final Border categoryBorder = new AccordionElementBorder();
/**
* Constructor the the panel.
* @param child the component that must be displayed by this panel if its
* CategoryButton is in a certain state.
* @param category the Category associated with the panel.
*/
public CategoryPanel(JComponent child, Category category)
{
this.child = child;
setLayout(new BorderLayout());
panel = new JPanel(new BorderLayout());
add(panel, BorderLayout.CENTER);
panel.add(child, BorderLayout.CENTER);
expandButton = new CategoryButton(category);
expandButton.setSelected(isExpanded());
expandButton.addChangeListener(new CollapseListener());
add(expandButton, BorderLayout.NORTH);
this.category = category;
setBorder(categoryBorder);
}
/**
* Sets whether the state of the panel is extended or not (if expanded the
* Component provided in the constructor will be displayed).
* @param expanded whether the panel is extended or not.
*/
public void setExpanded(boolean expanded) {
boolean oldExpanded = this.expanded;
if (oldExpanded != expanded) {
expandButton.setSelected(expanded);
this.expanded = expanded;
//setCollapseHeight(expanded? childPrefSize.height : 0);
child.setVisible(expanded);
firePropertyChange("expanded", oldExpanded, expanded);
}
}
/**
* Returns the category associated with this panel.
* @return the category associated with this panel.
*/
public Category getCategory()
{
return category;
}
/**
* Returns the component that must be displayed by this panel if its
* CategoryButton is in a certain state.
* @return the component that must be displayed by this panel if its
* CategoryButton is in a certain state.
*/
public JComponent getChild()
{
return child;
}
/**
* Returns <CODE>true</CODE> if the panel is extended and <CODE>false</CODE>
* otherwise.
* @return <CODE>true</CODE> if the panel is extended and <CODE>false</CODE>
* otherwise.
*/
public boolean isExpanded()
{
return expanded;
}
/** {@inheritDoc} */
public void setForeground(Color foreground)
{
super.setForeground(foreground);
if (expandButton != null)
{
expandButton.setForeground(foreground);
}
}
/** The custom listener used to display the child component. */
private class CollapseListener implements ChangeListener
{
/** {@inheritDoc} */
public void stateChanged(ChangeEvent event) {
setExpanded(expandButton.isSelected());
}
}
}