123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196 |
- package com.vaadin.tests.dd;
-
- import java.util.Collection;
- import java.util.HashSet;
- import java.util.Set;
-
- import com.vaadin.data.Item;
- import com.vaadin.data.util.IndexedContainer;
- import com.vaadin.demo.tutorial.addressbook.data.Person;
- import com.vaadin.demo.tutorial.addressbook.data.PersonContainer;
- import com.vaadin.event.DataBoundTransferable;
- import com.vaadin.event.dd.DragAndDropEvent;
- import com.vaadin.event.dd.DropHandler;
- import com.vaadin.event.dd.acceptcriteria.AcceptCriterion;
- import com.vaadin.terminal.ThemeResource;
- import com.vaadin.tests.components.TestBase;
- import com.vaadin.tests.util.TestUtils;
- import com.vaadin.ui.HorizontalLayout;
- import com.vaadin.ui.Table;
- import com.vaadin.ui.Window;
- import com.vaadin.ui.AbstractSelect.AbstractSelectDropTargetDetails;
-
- public class DDTest7 extends TestBase {
-
- java.util.Random r = new java.util.Random(1);
-
- HorizontalLayout hl = new HorizontalLayout();
- Table table = new Table(
- "Drag and drop sortable table with lazy loading rule. Dragged row can only be accepted after hevier row (weigh column). If starting from topmost row in viewport, hevies will end up on top.");
-
- @Override
- protected void setup() {
- Window w = getLayout().getWindow();
-
- TestUtils
- .injectCSS(
- w,
- ".v-table-row-drag-middle .v-table-cell-content {"
- + " background-color: inherit ; border-bottom: 1px solid cyan;"
- + "}"
- + ".v-table-row-drag-middle .v-table-cell-wrapper {"
- + " margin-bottom: -1px;"
- + "}"
- + ""
- // always show the drop hint below
- + ".v-table-row-drag-top .v-table-cell-content {"
- + "border-top: 0; margin-top:0;border-bottom:1px solid cyan;"
- + " margin-bottom: -1px;" + "}" + ""
-
- );
-
- // hl.addComponent(tree1);
- hl.addComponent(table);
- // hl.addComponent(tree2);
- hl.setWidth("100%");
- hl.setSpacing(true);
- hl.setExpandRatio(table, 1);
- table.setWidth("100%");
- table.setPageLength(10);
- table.setRowHeaderMode(Table.ROW_HEADER_MODE_ID);
- table.setSelectable(true);
- table.setMultiSelect(true);
- populateTable();
- addComponent(hl);
-
- /*
- * Make table rows draggable
- */
- table.setDragMode(Table.TableDragMode.ROWS);
-
- table.setDropHandler(new DropHandler() {
- // accept only drags from this table
- AcceptCriterion crit = new Table.TableDropCriterion() {
- @Override
- protected Set<Object> getAllowedItemIds(
- DragAndDropEvent dragEvent, Table table,
- Collection<Object> visibleItemIds) {
-
- Object draggedItemId = ((Table.TableTransferable) dragEvent
- .getTransferable()).getItemId();
- Integer weightOfDraggedRow = (Integer) table.getItem(
- draggedItemId).getItemProperty("Weight").getValue();
-
- HashSet<Object> accepted = new HashSet<Object>();
- for (Object itemId : visibleItemIds) {
- Item item = table.getItem(itemId);
- Integer w = (Integer) item.getItemProperty("Weight")
- .getValue();
- if (weightOfDraggedRow < w) {
- accepted.add(itemId);
- }
-
- }
- return accepted;
- }
- };
-
- public AcceptCriterion getAcceptCriterion() {
- return crit;
- }
-
- public void drop(DragAndDropEvent dropEvent) {
- AbstractSelectDropTargetDetails dropTargetData = (AbstractSelectDropTargetDetails) dropEvent
- .getDropTargetDetails();
- DataBoundTransferable transferable = (DataBoundTransferable) dropEvent
- .getTransferable();
- Object itemIdOver = dropTargetData.getItemIdOver();
- Object itemId = transferable.getItemId();
- if (itemId == null || itemIdOver == null
- || itemId.equals(itemIdOver)) {
- return; // no move happened
- }
-
- // IndexedContainer goodies... (hint: don't use it in real apps)
- IndexedContainer containerDataSource = (IndexedContainer) table
- .getContainerDataSource();
- int newIndex = containerDataSource.indexOfId(itemIdOver) - 1;
- // always add after
- newIndex++;
- if (newIndex < 0) {
- newIndex = 0;
- }
- Object idAfter = containerDataSource.getIdByIndex(newIndex);
- Collection selections = (Collection) table.getValue();
- if (selections != null && selections.contains(itemId)) {
- // dragged a selected item, if multiple rows selected, drag
- // them too (functionality similar to apple mail)
- for (Object object : selections) {
- moveAfter(containerDataSource, object, idAfter);
- }
-
- } else {
- // move just the dragged row, not considering selection at
- // all
- moveAfter(containerDataSource, itemId, idAfter);
- }
-
- }
-
- private void moveAfter(IndexedContainer containerDataSource,
- Object itemId, Object idAfter) {
- try {
- IndexedContainer clone = null;
- clone = (IndexedContainer) containerDataSource.clone();
- containerDataSource.removeItem(itemId);
- Item newItem = containerDataSource.addItemAfter(idAfter,
- itemId);
- Item item = clone.getItem(itemId);
- for (Object propId : item.getItemPropertyIds()) {
- newItem.getItemProperty(propId).setValue(
- item.getItemProperty(propId).getValue());
- }
-
- // TODO Auto-generated method stub
- } catch (CloneNotSupportedException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
-
- }
- });
-
- }
-
- private void populateTable() {
- table.addContainerProperty("Name", String.class, "");
- table.addContainerProperty("Weight", Integer.class, 0);
-
- PersonContainer testData = PersonContainer.createWithTestData();
-
- for (int i = 0; i < 40; i++) {
- Item addItem = table.addItem("Item" + i);
- Person p = testData.getIdByIndex(i);
- addItem.getItemProperty("Name").setValue(
- p.getFirstName() + " " + p.getLastName());
- addItem.getItemProperty("Weight").setValue(50 + r.nextInt(60));
- }
-
- }
-
- private final static ThemeResource FOLDER = new ThemeResource(
- "../runo/icons/16/folder.png");
- private final static ThemeResource DOC = new ThemeResource(
- "../runo/icons/16/document.png");
-
- @Override
- protected String getDescription() {
- return "dd";
- }
-
- @Override
- protected Integer getTicketNumber() {
- return 119;
- }
-
- }
|