All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jidesoft.swing.SelectAllUtils Maven / Gradle / Ivy

/*
 * @(#)SelectAllFocusListener.java 8/30/2006
 *
 * Copyright 2002 - 2006 JIDE Software Inc. All rights reserved.
 */

package com.jidesoft.swing;

import javax.swing.text.JTextComponent;
import java.awt.*;
import java.awt.event.FocusAdapter;
import java.awt.event.FocusEvent;
import java.awt.event.FocusListener;

/**
 * SelectAllUtils is a utility class to select all the text
 * in a text component when the component first time receives focus. It's very easy to use it.
 * 

 * JTextField field = new JTextField();
 * SelectAllUtils.install(field);
 * 
* The component you pass in can be a JTextComponent or any container that contains * one or more JTextComponents. All JTextComponents will be installed such a * focus listener to select all when it gets focus for the first time. For example, * you can install it to an editable JComboBox. *

 * JComboBox comboBox = new JComboBox();
 * comboBox.setEditable(true);
 * SelectAllUtils.install(comboBox);
 * 
* Although JComboBox is not JTextComponent but it contains a JTextField so it * will still work. However please make sure call it after the call to * comboBox.setEditable(true). Otherwise it will not work because JTextField is not created * until setEditable(true) is called. */ public class SelectAllUtils { /** * A client property. If set to Boolean.TRUE, we will only select all the text just for the first time when the component gets focus. */ public static final String CLIENT_PROPERTY_ONLYONCE = "SelectAll.onlyOnce"; private static FocusListener SELECT_ALL = new FocusAdapter() { @Override public void focusGained(FocusEvent e) { Object object = e.getSource(); if (object instanceof JTextComponent) { ((JTextComponent) object).selectAll(); Object clientProperty = ((JTextComponent) object).getClientProperty(CLIENT_PROPERTY_ONLYONCE); if (Boolean.TRUE.equals(clientProperty)) { ((JTextComponent) object).removeFocusListener(SELECT_ALL); } } else if (object instanceof Component) { JideSwingUtilities.setRecursively((Component) object, new JideSwingUtilities.Handler() { public boolean condition(Component c) { return c instanceof JTextComponent; } public void action(Component c) { ((JTextComponent) c).selectAll(); Object clientProperty = ((JTextComponent) c).getClientProperty(CLIENT_PROPERTY_ONLYONCE); if (Boolean.TRUE.equals(clientProperty)) { c.removeFocusListener(SELECT_ALL); } } public void postAction(Component c) { } }); } } }; /** * Installs focus listener to all text components inside the component. This focus listener * will select all the text when it gets focus. * * @param component the component to make it select all when having focus. The component could be a JTextComponent or could be * a container that contains one or more JTextComponents. This install method will make all JTextComponents * to have this select all feature. */ public static void install(final Component component) { install(component, true); } /** * Installs focus listener to all text components inside the component. This focus listener * will select all the text when it gets focus. * * @param component the component to make it select all when having focus. The component could be a JTextComponent or could be * a container that contains one or more JTextComponents. This install method will make all JTextComponents * to have this select all feature. * @param onlyOnce if true, we will only select all the text when the component has focus for the first time. Otherwise, it will * always select all the text whenever the component receives focus. */ public static void install(final Component component, final boolean onlyOnce) { if (component instanceof JTextComponent) { if (onlyOnce) { ((JTextComponent) component).putClientProperty(CLIENT_PROPERTY_ONLYONCE, Boolean.TRUE); } component.addFocusListener(SELECT_ALL); } else { JideSwingUtilities.setRecursively(component, new JideSwingUtilities.Handler() { public boolean condition(Component c) { return c instanceof JTextComponent; } public void action(Component c) { if (onlyOnce) { ((JTextComponent) c).putClientProperty(CLIENT_PROPERTY_ONLYONCE, Boolean.TRUE); } c.addFocusListener(SELECT_ALL); } public void postAction(Component c) { } }); } } /** * Uninstalls focus listener to all text components inside the component. * * @param component the component which {@link #install(java.awt.Component)} is called. */ public static void uninstall(Component component) { if (component instanceof JTextComponent) { component.removeFocusListener(SELECT_ALL); } else { JideSwingUtilities.setRecursively(component, new JideSwingUtilities.Handler() { public boolean condition(Component c) { return c instanceof JTextComponent; } public void action(Component c) { c.removeFocusListener(SELECT_ALL); } public void postAction(Component c) { } }); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy