aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--all/src/main/templates/release-notes.html5
-rw-r--r--testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java32
-rw-r--r--themes/src/main/themes/VAADIN/themes/valo/components/_newtree.scss19
3 files changed, 38 insertions, 18 deletions
diff --git a/all/src/main/templates/release-notes.html b/all/src/main/templates/release-notes.html
index 46b99dd727..d7546701ec 100644
--- a/all/src/main/templates/release-notes.html
+++ b/all/src/main/templates/release-notes.html
@@ -84,7 +84,7 @@
<ul>
<li>Components In Grid</li>
<li>HTML5 Drag and Drop support</li>
- <li>TreeGrid and HierarchicalDataProvider</li>
+ <li>TreeGrid, Tree and HierarchicalDataProvider</li>
<li>Improved OSGi Support</li>
</ul>
@@ -100,7 +100,8 @@
<h2 id="incompatible">Incompatible or Behavior-altering Changes in @version@</h2>
- <li>The <tt>TreeGrid</tt> component replaces both <tt>TreeTable</tt> and <tt>Tree</tt> component</li>
+ <li>The <tt>TreeGrid</tt> component replaces <tt>TreeTable</tt> component</li>
+ <li>The <tt>Tree</tt> component replaces old <tt>Tree</tt> component</li>
<li>The <tt>HierarchicalDataProvider</tt> interface replaces <tt>Container.Hierarchical</tt> and <<tt>InMemoryHierarchicalDataProvider</tt> replaces <tt>HierarchicalContainer</tt></li>
<li>The <tt>DragSourceExtension</tt> and <tt>DropTargetExtension</tt> extensions replace the old DnD features</li>
<li>OSGi bundle manifests of Vaadin Framework JARs no longer export <tt>/VAADIN</tt>, and there are new mechanisms for publishing static resources for OSGi</li>
diff --git a/testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java b/testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java
index 80f90fd349..371cc8b31f 100644
--- a/testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java
+++ b/testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java
@@ -17,6 +17,7 @@ package com.vaadin.testbench.elements;
import java.util.Arrays;
import java.util.List;
+import java.util.stream.Collectors;
import org.openqa.selenium.By;
import org.openqa.selenium.NoSuchElementException;
@@ -109,25 +110,40 @@ public class TreeElement extends AbstractComponentElement {
}
/**
- * Gets all items currently shown in this tree.
+ * Gets all items currently shown in this tree. The returned element objects
+ * are the rendered contents for each item.
*
- * @return list of all items
+ * @return list of content elements for all items
*/
public List<TestBenchElement> getAllItems() {
- return TestBenchElement.wrapElements(
- asTreeGrid().getBody().findElements(By.tagName("tr")),
- getCommandExecutor());
+ return asTreeGrid().getBody().findElements(By.tagName("tr")).stream()
+ .map(this::findCellContentFromRow).collect(Collectors.toList());
}
/**
- * Gets an item at given index.
+ * Gets an item at given index. The returned element object is the rendered
+ * content in the given index.
*
* @param index
* 0-based row index
- * @return item at given index
+ * @return content element for item at given index
*/
public TestBenchElement getItem(int index) {
- return asTreeGrid().getCell(index, 0);
+ return findCellContentFromRow(asTreeGrid().getRow(index));
+ }
+
+ /**
+ * Finds the rendered cell content from given row element. This expects the
+ * row to contain only a single column rendered with TreeRenderer.
+ *
+ * @param rowElement
+ * the row element
+ * @return cell content element
+ */
+ protected TestBenchElement findCellContentFromRow(WebElement rowElement) {
+ return TestBenchElement.wrapElement(
+ rowElement.findElement(By.className("gwt-HTML")),
+ getCommandExecutor());
}
/**
diff --git a/themes/src/main/themes/VAADIN/themes/valo/components/_newtree.scss b/themes/src/main/themes/VAADIN/themes/valo/components/_newtree.scss
index 9929d7ef47..20af676e4b 100644
--- a/themes/src/main/themes/VAADIN/themes/valo/components/_newtree.scss
+++ b/themes/src/main/themes/VAADIN/themes/valo/components/_newtree.scss
@@ -6,16 +6,20 @@ $v-newtree-border-radius: 3px;
@include valo-treegrid($primary-stylename);
+ .#{$primary-stylename} {
+ background-color: transparent;
+ }
+
.#{$primary-stylename}-row > td {
background-color: transparent;
border: none;
}
-
+
.#{$primary-stylename}-tablewrapper {
background-color: transparent;
border: none;
}
-
+
.#{$primary-stylename}-row-selected > .#{$primary-stylename}-cell {
background-color: transparent;
background-image: none;
@@ -23,23 +27,23 @@ $v-newtree-border-radius: 3px;
text-shadow: none;
border: none;
}
-
+
.#{$primary-stylename}:focus .#{$primary-stylename}-rowmode-row-focused:before {
display: none;
}
-
+
.#{$primary-stylename}-cell-content {
border: $v-grid-cell-focused-border;
border-color: transparent;
border-radius: $v-newtree-border-radius;
padding: $v-grid-cell-padding;
}
-
- .#{$primary-stylename}:focus .#{$primary-stylename}-rowmode-cell-focused
+
+ .#{$primary-stylename}:focus .#{$primary-stylename}-rowmode-cell-focused
> .#{$primary-stylename}-node > .#{$primary-stylename}-cell-content {
border: $v-grid-cell-focused-border;
}
-
+
// Selected
.#{$primary-stylename}-row-selected {
$grid-sel-bg: $v-grid-row-selected-background-color;
@@ -56,4 +60,3 @@ $v-newtree-border-radius: 3px;
}
}
}
-