T - the data type of the listpublic class ListDataProvider<T> extends AbstractDataProvider<T>
AbstractDataProvider that is backed by an
 in-memory list.
 
 
 Modifications (inserts, removes, sets, etc.) to the list returned by
 getList() will be reflected in the model. However, mutations to the
 items contained within the list will NOT be reflected in the model. You must
 call List.set(int, Object) to update the item within the list and
 push the change to the display, or call refresh() to push all rows
 to the displays. List.set(int, Object) performs better because it
 allows the data provider to push only those rows which have changed, and
 usually allows the display to re-render only a subset of the rows.
 
public class ListDataProviderExample implements EntryPoint {
  public void onModuleLoad() {
    // Create a CellList.
    CellList<String> cellList = new CellList<String>(new TextCell());
    // Create a list data provider.
    final ListDataProvider<String> dataProvider = new ListDataProvider<String>();
    // Add the cellList to the dataProvider.
    dataProvider.addDataDisplay(cellList);
    // Create a form to add values to the data provider.
    final TextBox valueBox = new TextBox();
    valueBox.setText("Enter new value");
    Button addButton = new Button("Add value", new ClickHandler() {
      public void onClick(ClickEvent event) {
        // Get the value from the text box.
        String newValue = valueBox.getText();
        // Get the underlying list from data dataProvider.
        List<String> list = dataProvider.getList();
        // Add the value to the list. The dataProvider will update the cellList.
        list.add(newValue);
      }
    });
    // Add the widgets to the root panel.
    VerticalPanel vPanel = new VerticalPanel();
    vPanel.add(valueBox);
    vPanel.add(addButton);
    vPanel.add(cellList);
    RootPanel.get().add(vPanel);
  }
}
| Constructor and Description | 
|---|
| ListDataProvider()Creates an empty model. | 
| ListDataProvider(java.util.List<T> listToWrap)Creates a list model that wraps the given list. | 
| ListDataProvider(java.util.List<T> listToWrap,
                ProvidesKey<T> keyProvider)Creates a list model that wraps the given list. | 
| ListDataProvider(ProvidesKey<T> keyProvider)Creates an empty list model that wraps the given collection. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | flush()Flush pending list changes to the displays. | 
| java.util.List<T> | getList()Get the list that backs this model. | 
| protected void | onRangeChanged(HasData<T> display)Called when a display changes its range of interest. | 
| void | refresh()Refresh all of the displays listening to this adapter. | 
| void | setList(java.util.List<T> listToWrap)Replace this model's list with the specified list. | 
addDataDisplay, getDataDisplays, getKey, getKeyProvider, getRanges, removeDataDisplay, updateRowCount, updateRowData, updateRowDatapublic ListDataProvider()
public ListDataProvider(java.util.List<T> listToWrap)
 The wrapped list should no longer be modified as the data provider cannot
 detect changes to the wrapped list. Instead, call getList() to
 retrieve a wrapper that can be modified and will correctly forward changes
 to displays.
listToWrap - the List to be wrappedpublic ListDataProvider(ProvidesKey<T> keyProvider)
keyProvider - an instance of ProvidesKeypublic ListDataProvider(java.util.List<T> listToWrap, ProvidesKey<T> keyProvider)
 The wrapped list should no longer be modified as the data provider cannot
 detect changes to the wrapped list. Instead, call getList() to
 retrieve a wrapper that can be modified and will correctly forward changes
 to displays.
listToWrap - the List to be wrappedkeyProvider - an instance of ProvidesKeypublic void flush()
public java.util.List<T> getList()
 NOTE: Mutations to the items contained within the list will NOT be
 reflected in the model. You must call List.set(int, Object) to
 update the item within the list and push the change to the display, or call
 refresh() to push all rows to the displays.
 List.set(int, Object) performs better because it allows the data
 provider to push only those rows which have changed, and usually allows the
 display to re-render only a subset of the rows.
setList(List)public void refresh()
 Use refresh() to push mutations to the underlying data items
 contained within the list. The data provider cannot detect changes to data
 objects within the list, so you must call this method if you modify items.
 
 
 This is a shortcut for calling List.set(int, Object) on every item
 that you modify, but note that calling List.set(int, Object)
 performs better because the data provider knows which rows were modified
 and can push only the modified rows the the displays.
public void setList(java.util.List<T> listToWrap)
 The wrapped list should no longer be modified as the data provider cannot
 detect changes to the wrapped list. Instead, call getList() to
 retrieve a wrapper that can be modified and will correctly forward changes
 to displays.
listToWrap - the model's new listgetList()protected void onRangeChanged(HasData<T> display)
AbstractDataProvideronRangeChanged in class AbstractDataProvider<T>display - the display whose range has changed