diff options
author | Johannes Dahlström <johannesd@vaadin.com> | 2013-02-06 12:26:42 +0000 |
---|---|---|
committer | Vaadin Code Review <review@vaadin.com> | 2013-02-06 12:26:42 +0000 |
commit | 797e7dfef177643e3b6e81692000440156e490b2 (patch) | |
tree | f0bc7b3b3e1c379a476a9afdf24ec1515f0fa03f | |
parent | 7e278d4af37a45fda84cbda917418dcd6d8e08e6 (diff) | |
parent | 1a0a3bd5cf248d3b368e52608d38767f2a501115 (diff) | |
download | vaadin-framework-797e7dfef177643e3b6e81692000440156e490b2.tar.gz vaadin-framework-797e7dfef177643e3b6e81692000440156e490b2.zip |
Merge "Merge of (#10890) to Vaadin 7." into 7.0
3 files changed, 95 insertions, 1 deletions
diff --git a/client/src/com/vaadin/client/ui/VScrollTable.java b/client/src/com/vaadin/client/ui/VScrollTable.java index b9244a1e91..8553398718 100644 --- a/client/src/com/vaadin/client/ui/VScrollTable.java +++ b/client/src/com/vaadin/client/ui/VScrollTable.java @@ -2629,7 +2629,11 @@ public class VScrollTable extends FlowPanel implements HasWidgets, for (int i = start; i <= visibleCellCount; i++) { if (i > 0) { final String colKey = getColKeyByIndex(i - 1); - slotX += getColWidth(colKey); + // getColWidth only returns the internal width + // without padding, not the offset width of the + // whole td (#10890) + slotX += getColWidth(colKey) + + scrollBody.getCellExtraWidth(); } final int dist = Math.abs(x - slotX); if (closestDistance == -1 || dist < closestDistance) { diff --git a/uitest/src/com/vaadin/tests/components/table/ColumnReorderingWithManyColumns.html b/uitest/src/com/vaadin/tests/components/table/ColumnReorderingWithManyColumns.html new file mode 100644 index 0000000000..5b5c83e629 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/ColumnReorderingWithManyColumns.html @@ -0,0 +1,42 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> +<head profile="http://selenium-ide.openqa.org/profiles/test-case"> +<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> +<link rel="selenium.base" href="http://localhost:8068/" /> +<title>ColumnReorderingWithManyColumns</title> +</head> +<body> +<table cellpadding="1" cellspacing="1" border="1"> +<thead> +<tr><td rowspan="1" colspan="3">ColumnReorderingWithManyColumns</td></tr> +</thead><tbody> +<tr> + <td>open</td> + <td>/run/ColumnReorderingWithManyColumns?restartApplication</td> + <td></td> +</tr> +<tr> + <td>drag</td> + <td>vaadin=runColumnReorderingWithManyColumns::/VVerticalLayout[0]/Slot[1]/VVerticalLayout[0]/Slot[0]/VScrollTable[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[2]/</td> + <td>10,10</td> +</tr> +<tr> + <td>mouseMoveAt</td> + <td>vaadin=runColumnReorderingWithManyColumns::/VVerticalLayout[0]/Slot[1]/VVerticalLayout[0]/Slot[0]/VScrollTable[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[10]/domChild[2]</td> + <td>10,10</td> +</tr> +<tr> + <td>screenCapture</td> + <td></td> + <td></td> +</tr> +<tr> + <td>drop</td> + <td>vaadin=runColumnReorderingWithManyColumns::/VVerticalLayout[0]/Slot[1]/VVerticalLayout[0]/Slot[0]/VScrollTable[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[0]/domChild[10]/domChild[2]</td> + <td>10,10</td> +</tr> + +</tbody></table> +</body> +</html> diff --git a/uitest/src/com/vaadin/tests/components/table/ColumnReorderingWithManyColumns.java b/uitest/src/com/vaadin/tests/components/table/ColumnReorderingWithManyColumns.java new file mode 100644 index 0000000000..aeebd299ff --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/ColumnReorderingWithManyColumns.java @@ -0,0 +1,48 @@ +/* + * Copyright 2012 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.tests.components.table; + +import com.vaadin.tests.components.TestBase; +import com.vaadin.ui.Table; + +public class ColumnReorderingWithManyColumns extends TestBase { + + private static final int NUM_COLS = 16; + + @Override + protected void setup() { + Table table = new Table(); + table.setSizeFull(); + table.setColumnReorderingAllowed(true); + + for (int i = 0; i < NUM_COLS; ++i) { + table.addContainerProperty("col-" + i, String.class, null); + } + + addComponent(table); + } + + @Override + protected String getDescription() { + return "When reordering columns via drag'n'drop, the drop marker is drawn too far to the right."; + } + + @Override + protected Integer getTicketNumber() { + return 10890; + } +} |