diff options
Diffstat (limited to 'uitest/src')
-rw-r--r-- | uitest/src/main/java/com/vaadin/tests/components/grid/GridDragAndDrop.java | 166 |
1 files changed, 107 insertions, 59 deletions
diff --git a/uitest/src/main/java/com/vaadin/tests/components/grid/GridDragAndDrop.java b/uitest/src/main/java/com/vaadin/tests/components/grid/GridDragAndDrop.java index 8fed8eabca..3fde1c6bf4 100644 --- a/uitest/src/main/java/com/vaadin/tests/components/grid/GridDragAndDrop.java +++ b/uitest/src/main/java/com/vaadin/tests/components/grid/GridDragAndDrop.java @@ -15,15 +15,22 @@ */ package com.vaadin.tests.components.grid; -import java.util.ArrayList; import java.util.Arrays; import java.util.List; -import java.util.stream.IntStream; +import java.util.Random; +import java.util.Set; +import java.util.stream.Collectors; +import java.util.stream.Stream; -import com.vaadin.server.Page; +import com.vaadin.data.provider.ListDataProvider; import com.vaadin.server.VaadinRequest; +import com.vaadin.shared.ui.dnd.DropEffect; +import com.vaadin.shared.ui.dnd.EffectAllowed; +import com.vaadin.shared.ui.grid.DropLocation; import com.vaadin.shared.ui.grid.DropMode; import com.vaadin.tests.components.AbstractTestUIWithLog; +import com.vaadin.tests.util.Person; +import com.vaadin.tests.util.TestDataGenerator; import com.vaadin.ui.Grid; import com.vaadin.ui.GridDragSource; import com.vaadin.ui.GridDropTarget; @@ -35,41 +42,23 @@ import elemental.json.Json; import elemental.json.JsonObject; public class GridDragAndDrop extends AbstractTestUIWithLog { + + private Set<Person> draggedItems; + @Override protected void setup(VaadinRequest request) { // Drag source Grid - Grid<Bean> dragSourceComponent = new Grid<>(); - dragSourceComponent.setItems(createItems(50, "left")); - dragSourceComponent.addColumn(Bean::getId).setCaption("ID"); - dragSourceComponent.addColumn(Bean::getValue).setCaption("Value"); - - GridDragSource<Bean> dragSource = new GridDragSource<>( - dragSourceComponent); - dragSource.setDragDataGenerator(bean -> { - JsonObject ret = Json.createObject(); - ret.put("generatedId", bean.getId()); - ret.put("generatedValue", bean.getValue()); - return ret; - }); + Grid<Person> left = createGridAndFillWithData(50); + GridDragSource<Person> dragSource = applyDragSource(left); // Drop target Grid - Grid<Bean> dropTargetComponent = new Grid<>(); - dropTargetComponent.setItems(createItems(5, "right")); - dropTargetComponent.addColumn(Bean::getId).setCaption("ID"); - dropTargetComponent.addColumn(Bean::getValue).setCaption("Value"); - - GridDropTarget<Bean> dropTarget = new GridDropTarget<>( - dropTargetComponent, DropMode.ON_TOP); - dropTarget.addGridDropListener(event -> { - log(event.getDataTransferText() + ", targetId=" + event - .getDropTargetRow().getId() + ", location=" + event - .getDropLocation()); - }); + Grid<Person> right = createGridAndFillWithData(5); + GridDropTarget<Person> dropTarget = applyDropTarget(right); // Layout the two grids Layout grids = new HorizontalLayout(); - grids.addComponents(dragSourceComponent, dropTargetComponent); + grids.addComponents(left, right); // Selection modes List<Grid.SelectionMode> selectionModes = Arrays.asList( @@ -77,14 +66,14 @@ public class GridDragAndDrop extends AbstractTestUIWithLog { RadioButtonGroup<Grid.SelectionMode> selectionModeSelect = new RadioButtonGroup<>( "Selection mode", selectionModes); selectionModeSelect.setSelectedItem(Grid.SelectionMode.SINGLE); - selectionModeSelect.addValueChangeListener(event -> dragSourceComponent + selectionModeSelect.addValueChangeListener(event -> left .setSelectionMode(event.getValue())); // Drop locations List<DropMode> dropLocations = Arrays.asList(DropMode.values()); RadioButtonGroup<DropMode> dropLocationSelect = new RadioButtonGroup<>( "Allowed drop location", dropLocations); - dropLocationSelect.setSelectedItem(DropMode.ON_TOP); + dropLocationSelect.setSelectedItem(DropMode.BETWEEN); dropLocationSelect.addValueChangeListener( event -> dropTarget.setDropMode(event.getValue())); @@ -92,45 +81,104 @@ public class GridDragAndDrop extends AbstractTestUIWithLog { dropLocationSelect); addComponents(controls, grids); - - // Set dragover styling - Page.getCurrent().getStyles().add(".v-drag-over {color: red;}"); } - private List<Bean> createItems(int num, String prefix) { - List<Bean> items = new ArrayList<>(num); + private Grid<Person> createGridAndFillWithData(int numberOfItems) { + Grid<Person> grid = new Grid<>(); - IntStream.range(0, num) - .forEach(i -> items - .add(new Bean(prefix + "_" + i, "value_" + i))); + grid.setItems(generateItems(numberOfItems)); + grid.addColumn( + person -> person.getFirstName() + " " + person.getLastName()) + .setCaption("Name"); + grid.addColumn(person -> person.getAddress().getStreetAddress()) + .setCaption("Street Address"); + grid.addColumn(person -> person.getAddress().getCity()) + .setCaption("City"); - return items; + return grid; } - public static class Bean { - private String id; - private String value; + private GridDragSource<Person> applyDragSource(Grid<Person> grid) { + GridDragSource<Person> dragSource = new GridDragSource<>(grid); - public Bean(String id, String value) { - this.id = id; - this.value = value; - } + dragSource.setEffectAllowed(EffectAllowed.MOVE); - public String getId() { + // Set data generator + dragSource.setDragDataGenerator(person -> { + JsonObject data = Json.createObject(); + data.put("name", + person.getFirstName() + " " + person.getLastName()); + data.put("city", person.getAddress().getCity()); + return data; + }); - return id; - } + // Add drag start listener + dragSource.addGridDragStartListener(event -> + draggedItems = event.getDraggedItems() + ); + + // Add drag end listener + dragSource.addGridDragEndListener(event -> { + if (event.getDropEffect() == DropEffect.MOVE) { + // If drop is successful, remove dragged item from source Grid + ((ListDataProvider<Person>) grid.getDataProvider()).getItems() + .removeAll(draggedItems); + grid.getDataProvider().refreshAll(); + + // Remove reference to dragged items + draggedItems = null; + } + }); - public void setId(String id) { - this.id = id; - } + return dragSource; + } + + private GridDropTarget<Person> applyDropTarget(Grid<Person> grid) { + // Create and attach extension + GridDropTarget<Person> dropTarget = new GridDropTarget<>(grid, + DropMode.BETWEEN); + dropTarget.setDropEffect(DropEffect.MOVE); + + // Add listener + dropTarget.addGridDropListener(event -> { + event.getDragSourceExtension().ifPresent(source -> { + if (source instanceof GridDragSource) { + ListDataProvider<Person> dataProvider = (ListDataProvider<Person>) event + .getComponent().getDataProvider(); + List<Person> items = (List<Person>) dataProvider.getItems(); + + // Calculate the target row's index + int index = items.indexOf(event.getDropTargetRow()) + ( + event.getDropLocation() == DropLocation.BELOW + ? 1 : 0); + + // Add dragged items to the target Grid + items.addAll(index, draggedItems); + dataProvider.refreshAll(); + + log("dragData=" + event.getDataTransferText() + + ", target=" + + event.getDropTargetRow().getFirstName() + + " " + event.getDropTargetRow().getLastName() + + ", location=" + event.getDropLocation()); + } + }); + }); + + return dropTarget; + } - public String getValue() { - return value; - } + private List<Person> generateItems(int num) { + return Stream.generate(() -> generateRandomPerson(new Random())) + .limit(num).collect(Collectors.toList()); + } - public void setValue(String value) { - this.value = value; - } + private Person generateRandomPerson(Random r) { + return new Person(TestDataGenerator.getFirstName(r), + TestDataGenerator.getLastName(r), "foo@bar.com", + TestDataGenerator.getPhoneNumber(r), + TestDataGenerator.getStreetAddress(r), + TestDataGenerator.getPostalCode(r), + TestDataGenerator.getCity(r)); } } |