diff options
6 files changed, 160 insertions, 32 deletions
diff --git a/client/src/com/vaadin/client/data/AbstractDataChangeHandler.java b/client/src/com/vaadin/client/data/AbstractDataChangeHandler.java new file mode 100644 index 0000000000..b5a92e1307 --- /dev/null +++ b/client/src/com/vaadin/client/data/AbstractDataChangeHandler.java @@ -0,0 +1,45 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.client.data; + +/** + * Empty {@link DataChangeHandler}. Use this when only a few of the methods are + * needed. + * + * @since + */ +public abstract class AbstractDataChangeHandler implements DataChangeHandler { + + @Override + public void dataUpdated(int firstRowIndex, int numberOfRows) { + } + + @Override + public void dataRemoved(int firstRowIndex, int numberOfRows) { + } + + @Override + public void dataAdded(int firstRowIndex, int numberOfRows) { + } + + @Override + public void dataAvailable(int firstRowIndex, int numberOfRows) { + } + + @Override + public void resetDataAndSize(int estimatedNewDataSize) { + } +} 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 62d39d50ec..60cf17ab57 100644 --- a/server/src/com/vaadin/server/communication/data/typed/DataProvider.java +++ b/server/src/com/vaadin/server/communication/data/typed/DataProvider.java @@ -16,6 +16,7 @@ package com.vaadin.server.communication.data.typed; import java.util.Collection; +import java.util.LinkedHashSet; import com.vaadin.server.AbstractExtension; import com.vaadin.shared.data.DataProviderClientRpc; @@ -34,6 +35,28 @@ import elemental.json.JsonObject; public class DataProvider<T> extends AbstractExtension { /** + * Creates the appropriate type of DataProvider based on the type of + * Collection provided to the method. + * <p> + * <strong>Note:</strong> this method will also extend the given component + * with the newly created DataProvider. The user should <strong>not</strong> + * call the {@link #extend(com.vaadin.server.AbstractClientConnector)} + * method explicitly. + * + * @param data + * collection of data objects + * @param component + * component to extend with the data provider + * @return created data provider + */ + public static <V> DataProvider<V> create(Collection<V> data, + AbstractComponent component) { + DataProvider<V> dataProvider = new DataProvider<V>(data); + dataProvider.extend(component); + return dataProvider; + } + + /** * Simple implementation of collection data provider communication. All data * is sent by server automatically and no data is requested by client. */ @@ -55,20 +78,16 @@ public class DataProvider<T> extends AbstractExtension { } private Collection<T> data; + private Collection<TypedDataGenerator<T>> generators = new LinkedHashSet<TypedDataGenerator<T>>(); /** - * Creates a new DataProvider, connecting it to given Collection and - * Component + * Creates a new DataProvider with the given Collection. * * @param data * collection of data to use - * @param component - * component to extend */ - public DataProvider(Collection<T> data, AbstractComponent component) { + protected DataProvider(Collection<T> data) { this.data = data; - extend(component); - registerRpc(createRpc()); } @@ -88,6 +107,26 @@ public class DataProvider<T> extends AbstractExtension { } /** + * Adds a TypedDataGenerator to this DataProvider. + * + * @param generator + * typed data generator + */ + public void addDataGenerator(TypedDataGenerator<T> generator) { + generators.add(generator); + } + + /** + * Removes a TypedDataGenerator from this DataProvider. + * + * @param generator + * typed data generator + */ + public void removeDataGenerator(TypedDataGenerator<T> generator) { + generators.add(generator); + } + + /** * Sends given row range to the client. * * @param firstIndex @@ -117,9 +156,9 @@ public class DataProvider<T> extends AbstractExtension { protected JsonObject getDataObject(T item) { JsonObject dataObject = Json.createObject(); - dataObject.put("k", item.toString()); - - // TODO: Add data generator stuff.. + for (TypedDataGenerator<T> generator : generators) { + generator.generateData(item, dataObject); + } return dataObject; } diff --git a/server/src/com/vaadin/server/communication/data/typed/TypedDataGenerator.java b/server/src/com/vaadin/server/communication/data/typed/TypedDataGenerator.java new file mode 100644 index 0000000000..ed2e321df8 --- /dev/null +++ b/server/src/com/vaadin/server/communication/data/typed/TypedDataGenerator.java @@ -0,0 +1,39 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.server.communication.data.typed; + +import java.io.Serializable; + +import elemental.json.JsonObject; + +/** + * Simple typed data generator for {@link DataProvider}. + * + * @since + */ +public interface TypedDataGenerator<T> extends Serializable { + + /** + * Adds data for given object to JsonObject. This JsonObject will be sent to + * client-side DataSource. + * + * @param data + * data object + * @param jsonObject + * json object being sent to the client + */ + void generateData(T data, JsonObject jsonObject); +} diff --git a/shared/src/com/vaadin/shared/data/DataProviderClientRpc.java b/shared/src/com/vaadin/shared/data/DataProviderClientRpc.java index e734d4e818..94010e5aca 100644 --- a/shared/src/com/vaadin/shared/data/DataProviderClientRpc.java +++ b/shared/src/com/vaadin/shared/data/DataProviderClientRpc.java @@ -19,6 +19,11 @@ import com.vaadin.shared.communication.ClientRpc; import elemental.json.JsonArray; +/** + * RPC interface used by DataProvider to send data to the client-side. + * + * @since + */ public interface DataProviderClientRpc extends ClientRpc { /** diff --git a/uitest/src/com/vaadin/tests/dataprovider/DummyDataProviderUI.java b/uitest/src/com/vaadin/tests/dataprovider/DummyDataProviderUI.java index 943c2b3b96..85ff2e7398 100644 --- a/uitest/src/com/vaadin/tests/dataprovider/DummyDataProviderUI.java +++ b/uitest/src/com/vaadin/tests/dataprovider/DummyDataProviderUI.java @@ -22,25 +22,41 @@ import java.util.Random; import com.vaadin.annotations.Widgetset; import com.vaadin.server.VaadinRequest; import com.vaadin.server.communication.data.typed.DataProvider; +import com.vaadin.server.communication.data.typed.TypedDataGenerator; import com.vaadin.tests.components.AbstractTestUI; import com.vaadin.tests.fieldgroup.ComplexPerson; import com.vaadin.tests.widgetset.TestingWidgetSet; import com.vaadin.ui.AbstractComponent; +import elemental.json.JsonObject; + @Widgetset(TestingWidgetSet.NAME) public class DummyDataProviderUI extends AbstractTestUI { - public static class DummyDataComponent<T> extends AbstractComponent { + public static class DummyDataComponent extends AbstractComponent { + + private DataProvider<ComplexPerson> dataProvider; + + public DummyDataComponent(Collection<ComplexPerson> data) { + dataProvider = DataProvider.create(data, this); + dataProvider + .addDataGenerator(new TypedDataGenerator<ComplexPerson>() { - public DummyDataComponent(Collection<T> data) { - new DataProvider<T>(data, this); + @Override + public void generateData(ComplexPerson data, + JsonObject dataObject) { + String name = data.getLastName() + ", " + + data.getFirstName(); + dataObject.put("name", name); + } + }); } } @Override protected void setup(VaadinRequest request) { - addComponent(new DummyDataComponent<ComplexPerson>(getPersons(20))); + addComponent(new DummyDataComponent(getPersons(20))); } private Collection<ComplexPerson> getPersons(int count) { diff --git a/uitest/src/com/vaadin/tests/widgetset/client/dataprovider/DummyDataConnector.java b/uitest/src/com/vaadin/tests/widgetset/client/dataprovider/DummyDataConnector.java index eae615a962..4733026bd7 100644 --- a/uitest/src/com/vaadin/tests/widgetset/client/dataprovider/DummyDataConnector.java +++ b/uitest/src/com/vaadin/tests/widgetset/client/dataprovider/DummyDataConnector.java @@ -16,7 +16,7 @@ package com.vaadin.tests.widgetset.client.dataprovider; import com.google.gwt.user.client.ui.FlowPanel; -import com.vaadin.client.data.DataChangeHandler; +import com.vaadin.client.data.AbstractDataChangeHandler; import com.vaadin.client.data.DataSource; import com.vaadin.client.data.HasDataSource; import com.vaadin.client.ui.AbstractComponentConnector; @@ -45,23 +45,7 @@ public class DummyDataConnector extends AbstractComponentConnector implements @Override public void setDataSource(DataSource<JsonObject> ds) { dataSource = ds; - dataSource.setDataChangeHandler(new DataChangeHandler() { - - @Override - public void resetDataAndSize(int estimatedNewDataSize) { - } - - @Override - public void dataUpdated(int firstRowIndex, int numberOfRows) { - } - - @Override - public void dataRemoved(int firstRowIndex, int numberOfRows) { - } - - @Override - public void dataAvailable(int firstRowIndex, int numberOfRows) { - } + dataSource.setDataChangeHandler(new AbstractDataChangeHandler() { @Override public void dataAdded(int firstRowIndex, int numberOfRows) { |