diff options
-rw-r--r-- | server/src/com/vaadin/server/communication/data/typed/DataProvider.java | 15 | ||||
-rw-r--r-- | server/src/com/vaadin/server/communication/data/typed/SimpleDataProvider.java | 57 |
2 files changed, 42 insertions, 30 deletions
diff --git a/server/src/com/vaadin/server/communication/data/typed/DataProvider.java b/server/src/com/vaadin/server/communication/data/typed/DataProvider.java index 40cb147e9e..7cba66aa64 100644 --- a/server/src/com/vaadin/server/communication/data/typed/DataProvider.java +++ b/server/src/com/vaadin/server/communication/data/typed/DataProvider.java @@ -22,6 +22,7 @@ import java.util.LinkedHashSet; import java.util.Set; import com.vaadin.server.AbstractExtension; +import com.vaadin.server.communication.data.typed.DataSource.DataChangeHandler; import com.vaadin.shared.data.DataProviderClientRpc; import com.vaadin.shared.data.DataProviderConstants; import com.vaadin.shared.data.DataRequestRpc; @@ -176,13 +177,14 @@ public abstract class DataProvider<T> extends AbstractExtension { protected ActiveDataHandler handler = new ActiveDataHandler(); protected DataProviderClientRpc rpc; - // TODO: Add a "BackEnd" API - // protected BackEnd data; + protected DataSource<T> dataSource; - protected DataProvider() { + protected DataProvider(DataSource<T> dataSource) { addDataGenerator(handler); + this.dataSource = dataSource; rpc = getRpcProxy(DataProviderClientRpc.class); registerRpc(createRpc()); + this.dataSource.addDataChangeHandler(createDataChangeHandler()); } /** @@ -277,4 +279,11 @@ public abstract class DataProvider<T> extends AbstractExtension { * @return data request rpc implementation */ protected abstract DataRequestRpc createRpc(); + + /** + * Creates a {@link DataChangeHandler} to use with the {@link DataSource}. + * + * @return data change handler + */ + protected abstract DataChangeHandler<T> createDataChangeHandler(); } diff --git a/server/src/com/vaadin/server/communication/data/typed/SimpleDataProvider.java b/server/src/com/vaadin/server/communication/data/typed/SimpleDataProvider.java index 91a7772ae3..a6a0e193db 100644 --- a/server/src/com/vaadin/server/communication/data/typed/SimpleDataProvider.java +++ b/server/src/com/vaadin/server/communication/data/typed/SimpleDataProvider.java @@ -58,14 +58,13 @@ public class SimpleDataProvider<T> extends DataProvider<T> { } // Use the whole data as the ones sent to the client. - handler.cleanUp(data); + handler.cleanUp(dataSource); } } private boolean reset = false; private final Set<T> updatedData = new HashSet<T>(); - private DataSource<T> data; // TODO: Allow customizing the used key mapper private DataKeyMapper<T> keyMapper = new KeyMapper<T>(); @@ -76,29 +75,7 @@ public class SimpleDataProvider<T> extends DataProvider<T> { * collection of data to use */ protected SimpleDataProvider(DataSource<T> data) { - this.data = data; - this.data.addDataChangeHandler(new DataChangeHandler<T>() { - - @Override - public void onDataChange() { - reset(); - } - - @Override - public void onDataAdd(T data) { - add(data); - } - - @Override - public void onDataRemove(T data) { - remove(data); - } - - @Override - public void onDataUpdate(T data) { - refresh(data); - } - }); + super(data); } /** @@ -110,8 +87,9 @@ public class SimpleDataProvider<T> extends DataProvider<T> { super.beforeClientResponse(initial); if (initial || reset) { - getRpcProxy(DataProviderClientRpc.class).resetSize(data.size()); - pushData(0, data); + getRpcProxy(DataProviderClientRpc.class).resetSize( + dataSource.size()); + pushData(0, dataSource); } else if (!updatedData.isEmpty()) { JsonArray dataArray = Json.createArray(); int i = 0; @@ -185,4 +163,29 @@ public class SimpleDataProvider<T> extends DataProvider<T> { return new SimpleDataRequestRpc(); } + @Override + protected DataChangeHandler<T> createDataChangeHandler() { + return new DataChangeHandler<T>() { + + @Override + public void onDataChange() { + reset(); + } + + @Override + public void onDataAdd(T data) { + add(data); + } + + @Override + public void onDataRemove(T data) { + remove(data); + } + + @Override + public void onDataUpdate(T data) { + refresh(data); + } + }; + } } |