/* * The contents of this file are subject to the terms of the Common Development and * Distribution License (the License). You may not use this file except in compliance with the * License. * * You can obtain a copy of the License at legal/CDDLv1.0.txt. See the License for the * specific language governing permission and limitations under the License. * * When distributing Covered Software, include this CDDL Header Notice in each file and include * the License file at legal/CDDLv1.0.txt. If applicable, add the following below the CDDL * Header, with the fields enclosed by brackets [] replaced by your own identifying * information: "Portions Copyright [year] [name of copyright owner]". * * Copyright 2008 Sun Microsystems, Inc. * Portions Copyright 2015-2016 ForgeRock AS. */ package org.opends.guitools.controlpanel.ui.renderer; import java.awt.BorderLayout; import java.awt.Component; import java.awt.Font; import javax.swing.JComboBox; import javax.swing.JList; import javax.swing.JPanel; import javax.swing.JSeparator; import javax.swing.ListCellRenderer; import javax.swing.border.EmptyBorder; import org.opends.guitools.controlpanel.datamodel.CategorizedComboBoxElement; import org.opends.guitools.controlpanel.ui.StatusGenericPanel; /** * A renderer used in the Control Panel that deals with * CategorizedComboBoxElement elements. It can be used to render JList and * JComboBoxes. */ public class CustomListCellRenderer implements ListCellRenderer { private ListCellRenderer defaultRenderer; /** The separator used to render a non-selectable separator in the combo box. */ protected Component separator; /** The default font. */ protected Font defaultFont; /** The category font. */ protected Font categoryFont; /** * Constructor of a renderer to be used with a combo box. * @param combo the combo box containing the elements to be rendered. */ public CustomListCellRenderer(JComboBox combo) { this(combo.getRenderer()); } /** * Constructor of a renderer to be used with a list. * @param list the list to be rendered. */ public CustomListCellRenderer(JList list) { this(list.getCellRenderer()); } private CustomListCellRenderer(ListCellRenderer defaultRenderer) { this.defaultRenderer = defaultRenderer; JSeparator sep = new JSeparator(); separator = new JPanel(new BorderLayout()); ((JPanel)separator).setOpaque(false); ((JPanel)separator).add(sep, BorderLayout.CENTER); ((JPanel)separator).setBorder(new EmptyBorder(5, 3, 5, 3)); } @Override public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) { Component comp; if (StatusGenericPanel.COMBO_SEPARATOR.equals(value)) { return separator; } else if (value instanceof CategorizedComboBoxElement) { CategorizedComboBoxElement element = (CategorizedComboBoxElement)value; String name = getStringValue(element); boolean isRegular = element.getType() == CategorizedComboBoxElement.Type.REGULAR; if (isRegular) { name = " "+name; } comp = defaultRenderer.getListCellRendererComponent(list, name, index, isSelected && isRegular, cellHasFocus); if (defaultFont == null) { defaultFont = comp.getFont(); categoryFont = defaultFont.deriveFont(Font.BOLD | Font.ITALIC); } if (element.getType() == CategorizedComboBoxElement.Type.REGULAR) { comp.setFont(defaultFont); } else { comp.setFont(categoryFont); } } else { comp = defaultRenderer.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus); if (defaultFont == null) { defaultFont = comp.getFont(); categoryFont = defaultFont.deriveFont(Font.BOLD | Font.ITALIC); } comp.setFont(defaultFont); } return comp; } /** * Returns the String value for a given CategorizedComboBoxElement. * @param desc the combo box element. * @return the String value for a given CategorizedComboBoxElement. */ protected String getStringValue(CategorizedComboBoxElement desc) { return String.valueOf(desc.getValue()); } }