package com.limegroup.gnutella.gui.options.panes;
import java.io.IOException;
import javax.swing.JCheckBox;
import com.limegroup.gnutella.gui.LabeledComponent;
import com.limegroup.gnutella.settings.QuestionsHandler;
/**
* This class defines the panel in the options window that allows the user
* to redisplay all messages.
*/
//2345678|012345678|012345678|012345678|012345678|012345678|012345678|012345678|
public final class PopupsPaneItem extends AbstractPaneItem {
/**
* Constant for the key of the locale-specific <tt>String</tt> for the
* chat enabled check box label in the options window.
*/
private final String CHECK_BOX_LABEL =
"OPTIONS_POPUPS_DISPLAY_CHECK_BOX_LABEL";
/**
* Constant for the check box that specifies whether or not downloads
* should be automatically cleared.
*/
private final JCheckBox CHECK_BOX = new JCheckBox();
/**
* The constructor constructs all of the elements of this
* <tt>AbstractPaneItem</tt>.
*
* @param key the key for this <tt>AbstractPaneItem</tt> that the
* superclass uses to generate locale-specific keys
*/
public PopupsPaneItem(final String key) {
super(key);
LabeledComponent comp = new LabeledComponent(CHECK_BOX_LABEL,
CHECK_BOX,
LabeledComponent.LEFT_GLUE);
add(comp.getComponent());
}
/**
* Defines the abstract method in <tt>AbstractPaneItem</tt>.<p>
*
* Sets the options for the fields in this <tt>PaneItem</tt> when the
* window is shown.
*/
public void initOptions() {
// always display the checkbox as unchecked.
}
/**
* Defines the abstract method in <tt>AbstractPaneItem</tt>.<p>
*
* Applies the options currently set in this window, displaying an
* error message to the user if a setting could not be applied.
*
* @throws IOException if the options could not be applied for some reason
*/
public boolean applyOptions() throws IOException {
if ( CHECK_BOX.isSelected() )
QuestionsHandler.instance().revertToDefault();
CHECK_BOX.setSelected(false);
return false;
}
public boolean isDirty() {
return CHECK_BOX.isSelected();
}
}