Class AutoCompleteSupport<E>
- java.lang.Object
-
- org.jadice.util.glazedlists.gui.AutoCompleteSupport<E>
-
public final class AutoCompleteSupport<E> extends Object
This classinstall(javax.swing.JComboBox, org.jadice.util.glazedlists.EventList<E>)
s support for filtering and autocompletion into a standardJComboBox
. It also acts as a factory class forcreating autocompleting table cell editors
.All autocompletion behaviour provided is meant to mimic the functionality of the Firefox address field. To be explicit, the following is a list of expected behaviours which are installed:
Typing into the ComboBox Editor
- typing any value into the editor when the popup is invisible causes the popup to appear and its contents to be filtered according to the editor's text. It also autocompletes to the first item that is prefixed with the editor's text and selects that item within the popup.
- typing any value into the editor when the popup is visible causes the popup to be refiltered according to the editor's text and reselects an appropriate autocompletion item.
- typing the down or up arrow keys in the editor when the popup is invisible causes the popup to appear and its contents to be filtered according to the editor's text. It also autocompletes to the first item that is prefixed with the editor's text and selects that item within the popup.
- typing the up arrow key when the popup is visible and the selected element is the first element causes the autocompletion to be cleared and the popup's selection to be removed.
- typing the up arrow key when no selection exists causes the last element of the popup to become selected and used for autocompletion
- typing the down arrow key when the popup is visible and the selected element is the last element causes the autocompletion to be cleared and the popup's selection to be removed
- typing the down arrow key when no selection exists causes the first element of the popup to become selected and used for autocompletion
- typing the delete key while in strict mode will select the prior text rather than delete it. Attempting to delete all text results in a beep unless the autcomplete support has been configured to not beep.
- clicking the arrow button when the popup is invisible causes the popup to appear and its contents to be shown unfiltered
- clicking the arrow button when the popup is visible causes the popup to be hidden
- the popup is always at least as wide as the autocompleting
JComboBox
, but may be wider to accomodate aprototype display value
if a non-null prototype display value exists - as items are filtered in the ComboBoxModel, the popup height is adjusted to display between 0
and
JComboBox.getMaximumRowCount()
rows before scrolling the popup
A single
ActionEvent
is fired from the JComboBox in these situations:- the user hits the enter key
- the selected item within the popup is changed (which can happen due to a mouse click, a change in the autocompletion term, or using the arrow keys)
- the JComboBox loses focus and contains a value that does not appear in the ComboBoxModel
null
values located in the ComboBoxModel are considered identical to empty Strings ("") for the purposes of locating autocompletion terms.
ComboBoxEditor Focus- the text in the ComboBoxEditor is selected if
getSelectsTextOnFocusGain()
returnstrue
- the JPopupMenu is hidden when the ComboBoxEditor loses focus if
getHidesPopupOnFocusLost()
returnstrue
Each value in the ComboBoxModel must be converted to a String for many reasons: filtering, setting into the ComboBoxEditor, displaying in the renderer, etc. By default, JComboBox relies on
Object.toString()
to map elements to their String equivalents. Sometimes, however, toString() is not a reliable or desirable mechanism to use. To deal with this problem, AutoCompleteSupport provides an install method that takes aFormat
object which is used to do all converting back and forth between Strings and ComboBoxModel objects.In order to achieve all of the autocompletion and filtering behaviour, the following occurs when
install(javax.swing.JComboBox, org.jadice.util.glazedlists.EventList<E>)
is called:- the JComboBox will be made editable
- the JComboBox will have a custom ComboBoxModel installed on it containing the given items
- the ComboBoxEditor will be wrapped with functionality and set back into the JComboBox as the editor
- the JTextField which is the editor component for the JComboBox will have a DocumentFilter installed on its backing Document
The strategy of this support class is to alter all of the objects which influence the behaviour of the JComboBox in one single context. With that achieved, it greatly reduces the cross-functional communication required to customize the behaviour of JComboBox for filtering and autocompletion.
Warning: This class must be mutated from the Swing Event Dispatch Thread. Failure to do so will result in an
IllegalStateException
thrown from any one of:-
install(JComboBox, EventList)
-
install(JComboBox, EventList, TextFilterator)
-
install(JComboBox, EventList, TextFilterator, Format)
-
isInstalled()
-
uninstall()
-
setCorrectsCase(boolean)
-
setStrict(boolean)
-
setBeepOnStrictViolation(boolean)
-
setSelectsTextOnFocusGain(boolean)
-
setHidesPopupOnFocusLost(boolean)
-
setFilterMode(int)
-
setFirstItem(Object)
-
removeFirstItem()
- Author:
- James Lemieux
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
AutoCompleteSupport.AutoCompleteCellEditor<E>
This extension of DefaultCellEditor exists solely to provide a handle to the AutoCompleteSupport object that is providing autocompletion capabilities to the JComboBox.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static <E> AutoCompleteSupport.AutoCompleteCellEditor<E>
createTableCellEditor(Comparator uniqueComparator, TableFormat<E> tableFormat, EventList<E> tableData, int columnIndex)
This factory method creates and returns aAutoCompleteSupport.AutoCompleteCellEditor
which adapts an autocompletingJComboBox
for use as a Table Cell Editor.static <E> AutoCompleteSupport.AutoCompleteCellEditor<E>
createTableCellEditor(EventList<E> source)
This factory method creates and returns aAutoCompleteSupport.AutoCompleteCellEditor
which adapts an autocompletingJComboBox
for use as a Table Cell Editor.static <E> AutoCompleteSupport.AutoCompleteCellEditor<E>
createTableCellEditor(TableFormat<E> tableFormat, EventList<E> tableData, int columnIndex)
This factory method creates and returns aAutoCompleteSupport.AutoCompleteCellEditor
which adapts an autocompletingJComboBox
for use as a Table Cell Editor.boolean
getBeepOnStrictViolation()
Returnstrue
if a beep sound is played when the user attempts to violate the strict invariant;false
if no beep sound is played.JComboBox
getComboBox()
boolean
getCorrectsCase()
Returnstrue
if user specified strings are converted to the case of the autocompletion term they match;false
otherwise.int
getFilterMode()
Returns the manner in which the contents of theComboBoxModel
are filtered.E
getFirstItem()
Returns the optional single value used as the first element in theComboBoxModel
ornull
if no first item has been set.boolean
getHidesPopupOnFocusLost()
Returnstrue
if the popup menu is hidden whenever the combo box editor loses focus;false
otherwise.EventList<E>
getItemList()
Returns the filteredEventList
of items which backs theComboBoxModel
of the autocompletingJComboBox
.boolean
getSelectsTextOnFocusGain()
Returnstrue
if the combo box editor text is selected when it gains focus;false
otherwise.TextFilterator<? super E>
getTextFilterator()
Returns theTextFilterator
that extracts searchable strings from each item in theComboBoxModel
.Object
getTextMatchingStrategy()
Returns the manner in which the contents of theComboBoxModel
are filtered and autocompletion terms are matched.static <E> AutoCompleteSupport<E>
install(JComboBox comboBox, EventList<E> items)
Installs support for autocompletion into thecomboBox
and returns the support object that is actually providing those facilities.static <E> AutoCompleteSupport<E>
install(JComboBox comboBox, EventList<E> items, TextFilterator<? super E> filterator)
Installs support for autocompletion into thecomboBox
and returns the support object that is actually providing those facilities.static <E> AutoCompleteSupport<E>
install(JComboBox comboBox, EventList<E> items, TextFilterator<? super E> filterator, Format format)
Installs support for autocompletion into thecomboBox
and returns the support object that is actually providing those facilities.boolean
isInstalled()
Returnstrue
if this autocomplete support instance is currently installed and altering the behaviour of the combo box;false
if it has beenuninstall()
ed.boolean
isStrict()
Returnstrue
if the user is able to specify values which do not appear in the popup list of suggestions;false
otherwise.E
removeFirstItem()
Removes and returns the optional single value used as the first element in theComboBoxModel
ornull
if no first item has been set.void
setBeepOnStrictViolation(boolean beepOnStrictViolation)
Sets the policy for indicating strict-mode violations to the user by way of a beep sound.void
setCorrectsCase(boolean correctCase)
IfcorrectCase
istrue
, user specified strings will be converted to the case of the element they match.void
setFilterMode(int mode)
Sets the manner in which the contents of theComboBoxModel
are filtered.void
setFirstItem(E item)
This method set a single optional value to be used as the first element in theComboBoxModel
.void
setHidesPopupOnFocusLost(boolean hidesPopupOnFocusLost)
IfhidesPopupOnFocusLost
istrue
, then the popup menu of the combo box is always hidden whenever the combo box editor loses focus.void
setSelectsTextOnFocusGain(boolean selectsTextOnFocusGain)
IfselectsTextOnFocusGain
istrue
, all text in the editor is selected when the combo box editor gains focus.void
setStrict(boolean strict)
Ifstrict
isfalse
, the user can specify values not appearing within the ComboBoxModel.void
setTextMatchingStrategy(Object strategy)
Sets the manner in which the contents of theComboBoxModel
are filtered and autocompletion terms are matched.void
uninstall()
This method removes autocompletion support from theJComboBox
it was installed on.
-
-
-
Method Detail
-
install
public static <E> AutoCompleteSupport<E> install(JComboBox comboBox, EventList<E> items)
Installs support for autocompletion into thecomboBox
and returns the support object that is actually providing those facilities. The support object is returned so that the caller may invokeuninstall()
at some later time to remove the autocompletion features.This method assumes that the
items
can be converted into reasonable String representations viaObject.toString()
.The following must be true in order to successfully install support for autocompletion on a
JComboBox
:- The JComboBox must use a
JTextField
as its editor component - The JTextField must use an
AbstractDocument
as its model
- Parameters:
comboBox
- theJComboBox
to decorate with autocompletionitems
- the objects to display in thecomboBox
- Returns:
- an instance of the support class providing autocomplete features
- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread
- The JComboBox must use a
-
install
public static <E> AutoCompleteSupport<E> install(JComboBox comboBox, EventList<E> items, TextFilterator<? super E> filterator)
Installs support for autocompletion into thecomboBox
and returns the support object that is actually providing those facilities. The support object is returned so that the caller may invokeuninstall()
at some later time to remove the autocompletion features.This method assumes that the
items
can be converted into reasonable String representations viaObject.toString()
.The
filterator
will be used to extract searchable text strings from each of theitems
. Anull
filterator implies the item's toString() method should be used when filtering it.The following must be true in order to successfully install support for autocompletion on a
JComboBox
:- The JComboBox must use a
JTextField
as its editor component - The JTextField must use an
AbstractDocument
as its model
- Parameters:
comboBox
- theJComboBox
to decorate with autocompletionitems
- the objects to display in thecomboBox
filterator
- extracts searchable text strings from each item;null
implies the item's toString() method should be used when filtering it- Returns:
- an instance of the support class providing autocomplete features
- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread
- The JComboBox must use a
-
install
public static <E> AutoCompleteSupport<E> install(JComboBox comboBox, EventList<E> items, TextFilterator<? super E> filterator, Format format)
Installs support for autocompletion into thecomboBox
and returns the support object that is actually providing those facilities. The support object is returned so that the caller may invokeuninstall()
at some later time to remove the autocompletion features.This method uses the given
format
to convert the givenitems
into Strings and back again. In other words, this method does NOT rely onObject.toString()
to produce a reasonable String representation of each item. Likewise, it does not rely on the existence of a valueOf(String) method for creating items out of Strings as is the default behaviour of JComboBox.It can be assumed that the only methods called on the given
format
are:As a convenience, this method will install a custom
ListCellRenderer
on thecomboBox
that displays the String value returned by theformat
. Though this is only done if the givenformat
is notnull
and if thecomboBox
does not already use a custom renderer.The
filterator
will be used to extract searchable text strings from each of theitems
. Anull
filterator implies one of two default strategies will be used. If theformat
is not null then the String value returned from theformat
object will be used when filtering a given item. Otherwise, the item's toString() method will be used when it is filtered.The following must be true in order to successfully install support for autocompletion on a
JComboBox
:- The JComboBox must use a
JTextField
as its editor component - The JTextField must use an
AbstractDocument
as its model
- Parameters:
comboBox
- theJComboBox
to decorate with autocompletionitems
- the objects to display in thecomboBox
filterator
- extracts searchable text strings from each item. If theformat
is not null then the String value returned from theformat
object will be used when filtering a given item. Otherwise, the item's toString() method will be used when it is filtered.format
- a Format object capable of convertingitems
into Strings and back.null
indicates the standard JComboBox methods of converting are acceptable.- Returns:
- an instance of the support class providing autocomplete features
- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread
- The JComboBox must use a
-
getComboBox
public JComboBox getComboBox()
-
getTextFilterator
public TextFilterator<? super E> getTextFilterator()
Returns theTextFilterator
that extracts searchable strings from each item in theComboBoxModel
.
-
getItemList
public EventList<E> getItemList()
Returns the filteredEventList
of items which backs theComboBoxModel
of the autocompletingJComboBox
.
-
getCorrectsCase
public boolean getCorrectsCase()
Returnstrue
if user specified strings are converted to the case of the autocompletion term they match;false
otherwise.
-
setCorrectsCase
public void setCorrectsCase(boolean correctCase)
IfcorrectCase
istrue
, user specified strings will be converted to the case of the element they match. Otherwise they will be left unaltered.Note: this flag only has meeting when strict mode is turned off. When strict mode is on, case is corrected regardless of this setting.
- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread- See Also:
setStrict(boolean)
-
isStrict
public boolean isStrict()
Returnstrue
if the user is able to specify values which do not appear in the popup list of suggestions;false
otherwise.
-
setStrict
public void setStrict(boolean strict)
Ifstrict
isfalse
, the user can specify values not appearing within the ComboBoxModel. If it istrue
each keystroke must continue to match some value in the ComboBoxModel or it will be discarded.Note: When strict mode is enabled, all user input is corrected to the case of the autocompletion term, regardless of the correctsCase setting.
- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread- See Also:
setCorrectsCase(boolean)
-
getBeepOnStrictViolation
public boolean getBeepOnStrictViolation()
Returnstrue
if a beep sound is played when the user attempts to violate the strict invariant;false
if no beep sound is played. This setting is only respected ifisStrict()
returnstrue
.- See Also:
setStrict(boolean)
-
setBeepOnStrictViolation
public void setBeepOnStrictViolation(boolean beepOnStrictViolation)
Sets the policy for indicating strict-mode violations to the user by way of a beep sound.- Parameters:
beepOnStrictViolation
-true
if a beep sound should be played when the user attempts to violate the strict invariant;false
if no beep sound should be played- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread
-
getSelectsTextOnFocusGain
public boolean getSelectsTextOnFocusGain()
Returnstrue
if the combo box editor text is selected when it gains focus;false
otherwise.
-
setSelectsTextOnFocusGain
public void setSelectsTextOnFocusGain(boolean selectsTextOnFocusGain)
IfselectsTextOnFocusGain
istrue
, all text in the editor is selected when the combo box editor gains focus. If it isfalse
the selection state of the editor is not effected by focus changes.- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread
-
getHidesPopupOnFocusLost
public boolean getHidesPopupOnFocusLost()
Returnstrue
if the popup menu is hidden whenever the combo box editor loses focus;false
otherwise.
-
setHidesPopupOnFocusLost
public void setHidesPopupOnFocusLost(boolean hidesPopupOnFocusLost)
IfhidesPopupOnFocusLost
istrue
, then the popup menu of the combo box is always hidden whenever the combo box editor loses focus. If it isfalse
the default behaviour is preserved. In practice this means that if focus is lost because of a MouseEvent, the behaviour is reasonable, but if focus is lost because of a KeyEvent (e.g. tabbing to the next focusable component) then the popup menu remains visible.- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread
-
getFilterMode
public int getFilterMode()
Returns the manner in which the contents of theComboBoxModel
are filtered. This method will return one ofTextMatcherEditor.CONTAINS
orTextMatcherEditor.STARTS_WITH
.TextMatcherEditor.CONTAINS
indicates elements of theComboBoxModel
are matched when they contain the text entered by the user.TextMatcherEditor.STARTS_WITH
indicates elements of theComboBoxModel
are matched when they start with the text entered by the user.In both modes, autocompletion only occurs when a given item starts with user-specified text. The filter mode only affects the filtering aspect of autocomplete support.
-
setFilterMode
public void setFilterMode(int mode)
Sets the manner in which the contents of theComboBoxModel
are filtered. The givenmode
must be one ofTextMatcherEditor.CONTAINS
orTextMatcherEditor.STARTS_WITH
.- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread- See Also:
getFilterMode()
-
setTextMatchingStrategy
public void setTextMatchingStrategy(Object strategy)
Sets the manner in which the contents of theComboBoxModel
are filtered and autocompletion terms are matched. The givenstrategy
must be one ofTextMatcherEditor.IDENTICAL_STRATEGY
orTextMatcherEditor.NORMALIZED_STRATEGY
or the Unicode strategy of the ICU4J extension.- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread- See Also:
getTextMatchingStrategy()
-
getTextMatchingStrategy
public Object getTextMatchingStrategy()
Returns the manner in which the contents of theComboBoxModel
are filtered and autocompletion terms are matched. The returnedstrategy
is one ofTextMatcherEditor.IDENTICAL_STRATEGY
orTextMatcherEditor.NORMALIZED_STRATEGY
or the Unicode strategy of the ICU4J extension.
-
setFirstItem
public void setFirstItem(E item)
This method set a single optional value to be used as the first element in theComboBoxModel
. This value typically represents "no selection" or "blank". This value is always present and is not filtered away during autocompletion.- Parameters:
item
- the first value to present in theComboBoxModel
-
getFirstItem
public E getFirstItem()
Returns the optional single value used as the first element in theComboBoxModel
ornull
if no first item has been set.- Returns:
- the special first value presented in the
ComboBoxModel
ornull
if no first item has been set
-
removeFirstItem
public E removeFirstItem()
Removes and returns the optional single value used as the first element in theComboBoxModel
ornull
if no first item has been set.- Returns:
- the special first value presented in the
ComboBoxModel
ornull
if no first item has been set
-
isInstalled
public boolean isInstalled()
Returnstrue
if this autocomplete support instance is currently installed and altering the behaviour of the combo box;false
if it has beenuninstall()
ed.- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread
-
uninstall
public void uninstall()
This method removes autocompletion support from theJComboBox
it was installed on. This method is useful when theEventList
of items that backs the combo box must outlive the combo box itself. Calling this method will return the combo box to its original state before autocompletion was installed, and it will be available for garbage collection independently of theEventList
of items.- Throws:
IllegalStateException
- if this method is called from any Thread other than the Swing Event Dispatch Thread
-
createTableCellEditor
public static <E> AutoCompleteSupport.AutoCompleteCellEditor<E> createTableCellEditor(TableFormat<E> tableFormat, EventList<E> tableData, int columnIndex)
This factory method creates and returns aAutoCompleteSupport.AutoCompleteCellEditor
which adapts an autocompletingJComboBox
for use as a Table Cell Editor. The values within the table column are used as autocompletion terms within theComboBoxModel
.This version of
createTableCellEditor
assumes that the values stored in the TableModel at the givencolumnIndex
are allComparable
, and that the natural ordering defined by thoseComparable
values also determines which are duplicates (and thus can safely be removed) and which are unique (and thus must remain in theComboBoxModel
).Note that this factory method is only appropriate for use when the values in the
ComboBoxModel
should be the unique set of values in a table column. If some other list of values will be used thencreateTableCellEditor(EventList)
is the appropriate factory method to use.If the appearance or function of the autocompleting
JComboBox
is to be customized, it can be retrieved usingDefaultCellEditor.getComponent()
.- Parameters:
tableFormat
- specifies how each row object within a table is broken apart into column valuestableData
- theEventList
backing the TableModelcolumnIndex
- the index of the column for which to return aAutoCompleteSupport.AutoCompleteCellEditor
- Returns:
- a
AutoCompleteSupport.AutoCompleteCellEditor
which contains an autocompleting combobox whose contents remain consistent with the data in the table column at the givencolumnIndex
-
createTableCellEditor
public static <E> AutoCompleteSupport.AutoCompleteCellEditor<E> createTableCellEditor(Comparator uniqueComparator, TableFormat<E> tableFormat, EventList<E> tableData, int columnIndex)
This factory method creates and returns aAutoCompleteSupport.AutoCompleteCellEditor
which adapts an autocompletingJComboBox
for use as a Table Cell Editor. The values within the table column are used as autocompletion terms within theComboBoxModel
.This version of
createTableCellEditor
makes no assumption about the values stored in the TableModel at the givencolumnIndex
. Instead, it uses the givenuniqueComparator
to determine which values are duplicates (and thus can safely be removed) and which are unique (and thus must remain in theComboBoxModel
).Note that this factory method is only appropriate for use when the values in the
ComboBoxModel
should be the unique set of values in a table column. If some other list of values will be used thencreateTableCellEditor(EventList)
is the appropriate factory method to use.If the appearance or function of the autocompleting
JComboBox
is to be customized, it can be retrieved usingDefaultCellEditor.getComponent()
.- Parameters:
uniqueComparator
- theComparator
that strips away duplicate elements from theComboBoxModel
tableFormat
- specifies how each row object within a table is broken apart into column valuestableData
- theEventList
backing the TableModelcolumnIndex
- the index of the column for which to return aAutoCompleteSupport.AutoCompleteCellEditor
- Returns:
- a
AutoCompleteSupport.AutoCompleteCellEditor
which contains an autocompleting combobox whose contents remain consistent with the data in the table column at the givencolumnIndex
-
createTableCellEditor
public static <E> AutoCompleteSupport.AutoCompleteCellEditor<E> createTableCellEditor(EventList<E> source)
This factory method creates and returns aAutoCompleteSupport.AutoCompleteCellEditor
which adapts an autocompletingJComboBox
for use as a Table Cell Editor. The values within thesource
are used as autocompletion terms within theComboBoxModel
.If the appearance or function of the autocompleting
JComboBox
is to be customized, it can be retrieved usingDefaultCellEditor.getComponent()
.- Parameters:
source
- the source of data for the JComboBox within the table cell editor- Returns:
- a
AutoCompleteSupport.AutoCompleteCellEditor
which contains an autocompleting combobox whose model contents are determined by the givensource
-
-