aboutsummaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/src/main/java/com/vaadin/ui/Grid.java4
-rw-r--r--server/src/main/java/com/vaadin/ui/components/grid/GridDragSource.java1
-rw-r--r--server/src/main/java/com/vaadin/ui/components/grid/GridDragger.java46
-rw-r--r--server/src/main/java/com/vaadin/ui/components/grid/GridDropTarget.java1
-rw-r--r--server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerOneGridTest.java20
-rw-r--r--server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerTwoGridsTest.java18
6 files changed, 85 insertions, 5 deletions
diff --git a/server/src/main/java/com/vaadin/ui/Grid.java b/server/src/main/java/com/vaadin/ui/Grid.java
index 4b5ab2a84b..d79fad7ec2 100644
--- a/server/src/main/java/com/vaadin/ui/Grid.java
+++ b/server/src/main/java/com/vaadin/ui/Grid.java
@@ -1182,6 +1182,10 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
/**
* Sets whether the user can sort this column or not.
+ * <p>
+ * By default, a grid using a in-memory data provider has its columns
+ * sortable by default. For a backend data provider, the columns are not
+ * sortable by default.
*
* @param sortable
* {@code true} if the column can be sorted by the user;
diff --git a/server/src/main/java/com/vaadin/ui/components/grid/GridDragSource.java b/server/src/main/java/com/vaadin/ui/components/grid/GridDragSource.java
index c5a3b0dd94..e3482a04f2 100644
--- a/server/src/main/java/com/vaadin/ui/components/grid/GridDragSource.java
+++ b/server/src/main/java/com/vaadin/ui/components/grid/GridDragSource.java
@@ -43,6 +43,7 @@ import elemental.json.JsonObject;
* The Grid bean type.
* @author Vaadin Ltd.
* @since 8.1
+ * @see GridDragger
*/
public class GridDragSource<T> extends DragSourceExtension<Grid<T>> {
diff --git a/server/src/main/java/com/vaadin/ui/components/grid/GridDragger.java b/server/src/main/java/com/vaadin/ui/components/grid/GridDragger.java
index a7186a0801..a181b792ad 100644
--- a/server/src/main/java/com/vaadin/ui/components/grid/GridDragger.java
+++ b/server/src/main/java/com/vaadin/ui/components/grid/GridDragger.java
@@ -26,12 +26,21 @@ import com.vaadin.shared.ui.dnd.DropEffect;
import com.vaadin.shared.ui.grid.DropLocation;
import com.vaadin.shared.ui.grid.DropMode;
import com.vaadin.ui.Grid;
+import com.vaadin.ui.Grid.Column;
/**
- * Allows dragging rows for reordering within a Grid and between separate Grids.
+ * Allows dragging rows for reordering within a Grid and between two separate
+ * Grids when the item type is the same.
* <p>
* When dragging a selected row, all the visible selected rows are dragged. Note
- * that ONLY currently visible rows are taken into account.
+ * that ONLY currently visible rows are taken into account. The drop mode for
+ * the target grid is by default {@link DropMode#BETWEEN}.
+ * <p>
+ * To customize the settings for either the source or the target grid, use
+ * {@link #getGridDragSource()} and {@link #getGridDropTarget()}.The drop target
+ * grid has been set to not allow drops for a target row when the grid has been
+ * sorted, since the visual drop target location would not match where the item
+ * would actually be dropped into.
* <p>
* <em>NOTE: this helper works only with {@link ListDataProvider} on both grids.
* If you have another data provider, you should customize data provider
@@ -68,6 +77,20 @@ public class GridDragger<T> implements Serializable {
* Enables DnD reordering for the rows in the given grid.
* <p>
* {@link DropMode#BETWEEN} is used.
+ * <p>
+ * <em>NOTE:</em> this only works when the grid has a
+ * {@link ListDataProvider}. Use the custom handlers
+ * {@link #setSourceDataProviderUpdater(SourceDataProviderUpdater)} and
+ * {@link #setTargetDataProviderUpdater(TargetDataProviderUpdater)} for
+ * other data providers.
+ * <p>
+ * <em>NOTE:</em> When allowing the user to DnD reorder a grid's rows, you
+ * should not allow the user to sort the grid since when the grid is sorted,
+ * as the reordering doens't make any sense since the drop target cannot be
+ * shown for the correct place due to the sorting. Sorting columns is
+ * enabled by default for in-memory data provider grids. Sorting can be
+ * disabled for columns with {@link Grid#getColumns()} and
+ * {@link Column#setSortable(boolean)}.
*
* @param grid
* Grid to be extended.
@@ -80,11 +103,19 @@ public class GridDragger<T> implements Serializable {
* Enables DnD reordering the rows in the given grid with the given drop
* mode.
* <p>
- * <em>NOTE: this only works when the grid has a
- * {@link ListDataProvider}.</em> Use the custom handlers
+ * <em>NOTE:</em> this only works when the grid has a
+ * {@link ListDataProvider}. Use the custom handlers
* {@link #setSourceDataProviderUpdater(SourceDataProviderUpdater)} and
* {@link #setTargetDataProviderUpdater(TargetDataProviderUpdater)} for
* other data providers.
+ * <p>
+ * <em>NOTE:</em> When allowing the user to DnD reorder a grid's rows, you
+ * should not allow the user to sort the grid since when the grid is sorted,
+ * as the reordering doens't make any sense since the drop target cannot be
+ * shown for the correct place due to the sorting. Sorting columns is
+ * enabled by default for in-memory data provider grids. Sorting can be
+ * disabled for columns with {@link Grid#getColumns()} and
+ * {@link Column#setSortable(boolean)}.
*
* @param grid
* the grid to enable row DnD reordering on
@@ -159,6 +190,7 @@ public class GridDragger<T> implements Serializable {
gridDragSource = new GridDragSource<>(source);
gridDropTarget = new GridDropTarget<>(target, dropMode);
+ gridDropTarget.setDropAllowedOnSortedGridRows(false);
gridDragSource.addGridDragStartListener(event -> {
draggedItems = event.getDraggedItems();
@@ -277,7 +309,7 @@ public class GridDragger<T> implements Serializable {
* Returns the currently dragged items captured from the source grid no drag
* start event, or {@code null} if no drag active.
*
- * @return the currenytly dragged items or {@code null}
+ * @return the currently dragged items or {@code null}
*/
protected List<T> getDraggedItems() {
return draggedItems;
@@ -374,6 +406,10 @@ public class GridDragger<T> implements Serializable {
// instead of using setItems or creating a new data provider,
// refresh the existing one to keep filters etc. in place
listDataProvider.refreshAll();
+
+ // if dropped to the end of the grid, the grid should scroll there so
+ // that the dropped row is visible, but that is just recommended in
+ // documentation and left for the users to take into use
}
private int calculateDropIndex(GridDropEvent<T> event) {
diff --git a/server/src/main/java/com/vaadin/ui/components/grid/GridDropTarget.java b/server/src/main/java/com/vaadin/ui/components/grid/GridDropTarget.java
index e4b175fe81..5073287c52 100644
--- a/server/src/main/java/com/vaadin/ui/components/grid/GridDropTarget.java
+++ b/server/src/main/java/com/vaadin/ui/components/grid/GridDropTarget.java
@@ -35,6 +35,7 @@ import com.vaadin.ui.dnd.DropTargetExtension;
* Type of the Grid bean.
* @author Vaadin Ltd
* @since 8.1
+ * @see GridDragger
*/
public class GridDropTarget<T> extends DropTargetExtension<Grid<T>> {
diff --git a/server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerOneGridTest.java b/server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerOneGridTest.java
index 6d24020e45..24e72566f4 100644
--- a/server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerOneGridTest.java
+++ b/server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerOneGridTest.java
@@ -45,6 +45,7 @@ public class GridDraggerOneGridTest {
@Before
public void setupListCase() {
source = new Grid<>();
+ source.addColumn(s -> s).setId("1");
dragger = new TestGridDragger(source);
}
@@ -203,4 +204,23 @@ public class GridDraggerOneGridTest {
verifyDataProvider("1", "0", "2", "4", "3");
}
+ @Test
+ public void dropOnSortedGrid_byDefault_dropsToTheEnd() {
+ Assert.assertFalse(
+ "Default drops on sorted grid rows should not be allowed",
+ dragger.getGridDropTarget().isDropAllowedOnSortedGridRows());
+
+ source.setItems("0", "1", "2", "3", "4");
+
+ drop("3", DropLocation.BELOW, "1");
+
+ verifyDataProvider("0", "2", "3", "1", "4");
+
+ source.sort("1");
+
+ drop(null, DropLocation.EMPTY, "0");
+
+ verifyDataProvider("2", "3", "1", "4", "0");
+ }
+
}
diff --git a/server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerTwoGridsTest.java b/server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerTwoGridsTest.java
index 0711b711df..c73641097d 100644
--- a/server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerTwoGridsTest.java
+++ b/server/src/test/java/com/vaadin/tests/server/component/grid/GridDraggerTwoGridsTest.java
@@ -47,6 +47,7 @@ public class GridDraggerTwoGridsTest {
public void setupListCase() {
source = new Grid<>();
target = new Grid<>();
+ target.addColumn(s -> s).setId("1");
dragger = new TestGridDragger(source, target);
target.setItems(); // setup to use list data provider
@@ -249,4 +250,21 @@ public class GridDraggerTwoGridsTest {
Assert.assertEquals("given drop index to target updater is wrong", 2,
updaterTrigger.get());
}
+
+ @Test
+ public void dropOnSortedGrid_byDefault_dropsToTheEnd() {
+ Assert.assertFalse(
+ "Default drops on sorted grid rows should not be allowed",
+ dragger.getGridDropTarget().isDropAllowedOnSortedGridRows());
+
+ source.setItems("0", "1", "2");
+ target.setItems("4", "5");
+
+ target.sort("1");
+
+ drop(null, DropLocation.EMPTY, "0");
+
+ verifySourceDataProvider("1", "2");
+ verifyTargetDataProvider("4", "5", "0");
+ }
}