summaryrefslogtreecommitdiffstats
path: root/client
diff options
context:
space:
mode:
authorAnna Koskinen <Ansku@users.noreply.github.com>2021-07-15 16:21:10 +0300
committerGitHub <noreply@github.com>2021-07-15 16:21:10 +0300
commit512703d56c11032740ed9d0c60ee180a438af415 (patch)
treeab1a71a83a4e6755dd0b4c35be8c63cbf37da8dc /client
parent3afe45849edc79f0e7b371a7fd3ef209292dce79 (diff)
downloadvaadin-framework-512703d56c11032740ed9d0c60ee180a438af415.tar.gz
vaadin-framework-512703d56c11032740ed9d0c60ee180a438af415.zip
Checkstyle fixes (#12339)
- Added missing default sections to switch blocks. - Added missing JavaDocs and JavaDoc parameters. - Added wildcards where possible. - Deprecated unused method. - Fixed JavaDoc formatting. - Removed inner assignments. - Removed unused imports. - Removed unused variables. - Removed warning suppressions that were unnecessary or about boxing (not tracked by coding conventions). - Suppressed warnings about rawtypes, deprecation, and unchecked where couldn't be avoided.
Diffstat (limited to 'client')
-rw-r--r--client/src/main/java/com/vaadin/client/connectors/grid/ColumnConnector.java8
-rw-r--r--client/src/main/java/com/vaadin/client/connectors/grid/ComponentRendererConnector.java8
-rw-r--r--client/src/main/java/com/vaadin/client/connectors/grid/EditorConnector.java4
-rw-r--r--client/src/main/java/com/vaadin/client/connectors/grid/GridConnector.java6
-rw-r--r--client/src/main/java/com/vaadin/client/connectors/grid/TreeRendererConnector.java1
-rw-r--r--client/src/main/java/com/vaadin/client/connectors/grid/UnsafeHtmlRendererConnector.java3
-rw-r--r--client/src/main/java/com/vaadin/client/renderers/ButtonRenderer.java13
-rw-r--r--client/src/main/java/com/vaadin/client/renderers/ClickableRenderer.java2
-rw-r--r--client/src/main/java/com/vaadin/client/renderers/ComplexRenderer.java3
-rw-r--r--client/src/main/java/com/vaadin/client/renderers/DateRenderer.java15
-rw-r--r--client/src/main/java/com/vaadin/client/renderers/HierarchyRenderer.java9
-rw-r--r--client/src/main/java/com/vaadin/client/renderers/ImageRenderer.java1
-rw-r--r--client/src/main/java/com/vaadin/client/renderers/NumberRenderer.java9
-rw-r--r--client/src/main/java/com/vaadin/client/renderers/WidgetRenderer.java4
-rw-r--r--client/src/main/java/com/vaadin/client/widget/escalator/FlyweightCell.java26
-rw-r--r--client/src/main/java/com/vaadin/client/widget/escalator/FlyweightRow.java30
-rw-r--r--client/src/main/java/com/vaadin/client/widget/escalator/ScrollbarBundle.java45
-rw-r--r--client/src/main/java/com/vaadin/client/widget/escalator/Spacer.java2
-rw-r--r--client/src/main/java/com/vaadin/client/widget/escalator/events/RowHeightChangedEvent.java5
-rw-r--r--client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerIndexChangedEvent.java5
-rw-r--r--client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerVisibilityChangedEvent.java5
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/AutoScroller.java15
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/CellReference.java6
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/DataAvailableEvent.java7
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/DefaultEditorEventHandler.java40
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/EventCellReference.java20
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/RendererCellReference.java1
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/datasources/ListDataSource.java4
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/datasources/ListSorter.java11
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridKeyEventHandler.java30
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridMouseEventHandler.java18
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/ColumnReorderEvent.java16
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/ColumnResizeEvent.java8
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeEvent.java17
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeHandler.java6
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/GridClickEvent.java6
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/GridDoubleClickEvent.java6
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledEvent.java7
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyDownEvent.java6
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyPressEvent.java6
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyUpEvent.java6
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/events/SelectAllHandler.java3
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/selection/ClickSelectHandler.java4
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/selection/HasSelectionHandlers.java3
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/selection/MultiSelectionRenderer.java33
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionEvent.java3
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionModel.java8
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/sort/SortEvent.java4
-rw-r--r--client/src/main/java/com/vaadin/client/widget/grid/sort/SortHandler.java4
-rw-r--r--client/src/main/java/com/vaadin/client/widgets/Escalator.java235
-rwxr-xr-xclient/src/main/java/com/vaadin/client/widgets/Grid.java525
51 files changed, 1177 insertions, 85 deletions
diff --git a/client/src/main/java/com/vaadin/client/connectors/grid/ColumnConnector.java b/client/src/main/java/com/vaadin/client/connectors/grid/ColumnConnector.java
index 2b6ced0c95..bf364e0ecc 100644
--- a/client/src/main/java/com/vaadin/client/connectors/grid/ColumnConnector.java
+++ b/client/src/main/java/com/vaadin/client/connectors/grid/ColumnConnector.java
@@ -38,6 +38,9 @@ import elemental.json.JsonValue;
@Connect(com.vaadin.ui.Grid.Column.class)
public class ColumnConnector extends AbstractExtensionConnector {
+ /**
+ * Class for representing a custom column.
+ */
public abstract static class CustomColumn
extends Column<Object, JsonObject> {
@@ -48,6 +51,11 @@ public class ColumnConnector extends AbstractExtensionConnector {
this.connectorId = connectorId;
}
+ /**
+ * Returns the id for the corresponding connector.
+ *
+ * @return the id for the connector
+ */
public String getConnectorId() {
return connectorId;
}
diff --git a/client/src/main/java/com/vaadin/client/connectors/grid/ComponentRendererConnector.java b/client/src/main/java/com/vaadin/client/connectors/grid/ComponentRendererConnector.java
index e5ed860d39..927642fada 100644
--- a/client/src/main/java/com/vaadin/client/connectors/grid/ComponentRendererConnector.java
+++ b/client/src/main/java/com/vaadin/client/connectors/grid/ComponentRendererConnector.java
@@ -17,7 +17,6 @@ package com.vaadin.client.connectors.grid;
import java.util.HashSet;
import java.util.Iterator;
-import java.util.logging.Logger;
import com.google.gwt.core.client.GWT;
import com.google.gwt.event.shared.HandlerRegistration;
@@ -28,7 +27,6 @@ import com.vaadin.client.ConnectorMap;
import com.vaadin.client.renderers.Renderer;
import com.vaadin.client.renderers.WidgetRenderer;
import com.vaadin.client.ui.AbstractComponentConnector;
-import com.vaadin.client.ui.AbstractConnector;
import com.vaadin.client.widget.grid.RendererCellReference;
import com.vaadin.shared.ui.Connect;
import com.vaadin.shared.ui.grid.renderers.ComponentRendererState;
@@ -119,9 +117,9 @@ public class ComponentRendererConnector
}
private void unregisterHierarchyHandler() {
- if (this.handlerRegistration != null) {
- this.handlerRegistration.removeHandler();
- this.handlerRegistration = null;
+ if (handlerRegistration != null) {
+ handlerRegistration.removeHandler();
+ handlerRegistration = null;
}
}
diff --git a/client/src/main/java/com/vaadin/client/connectors/grid/EditorConnector.java b/client/src/main/java/com/vaadin/client/connectors/grid/EditorConnector.java
index 297a360f8b..26ba9858a2 100644
--- a/client/src/main/java/com/vaadin/client/connectors/grid/EditorConnector.java
+++ b/client/src/main/java/com/vaadin/client/connectors/grid/EditorConnector.java
@@ -47,9 +47,6 @@ import elemental.json.JsonObject;
@Connect(EditorImpl.class)
public class EditorConnector extends AbstractExtensionConnector {
- private Integer currentEditedRow = null;
- private boolean waitingForAvailableData = false;
-
/**
* EditorHandler for communicating with the server-side implementation.
*/
@@ -132,7 +129,6 @@ public class EditorConnector extends AbstractExtensionConnector {
// a confirmation from the server
rpc.cancel(afterBeingSaved);
}
- currentEditedRow = null;
}
@Override
diff --git a/client/src/main/java/com/vaadin/client/connectors/grid/GridConnector.java b/client/src/main/java/com/vaadin/client/connectors/grid/GridConnector.java
index 1632baa292..42d39bae73 100644
--- a/client/src/main/java/com/vaadin/client/connectors/grid/GridConnector.java
+++ b/client/src/main/java/com/vaadin/client/connectors/grid/GridConnector.java
@@ -497,7 +497,7 @@ public class GridConnector extends AbstractListingConnector
}
private void updateStaticRow(RowState rowState,
- Grid.StaticSection.StaticRow row) {
+ Grid.StaticSection.StaticRow<?> row) {
rowState.cells
.forEach((columnId, cellState) -> updateStaticCellFromState(
row.getCell(getColumn(columnId)), cellState));
@@ -794,11 +794,11 @@ public class GridConnector extends AbstractListingConnector
return null;
}
- private TooltipInfo getHeaderFooterTooltip(CellReference cell) {
+ private TooltipInfo getHeaderFooterTooltip(CellReference<?> cell) {
Section section = Section.BODY;
if (cell instanceof EventCellReference) {
// Header or footer
- section = ((EventCellReference) cell).getSection();
+ section = ((EventCellReference<?>) cell).getSection();
}
StaticCell staticCell = null;
if (section == Section.HEADER) {
diff --git a/client/src/main/java/com/vaadin/client/connectors/grid/TreeRendererConnector.java b/client/src/main/java/com/vaadin/client/connectors/grid/TreeRendererConnector.java
index d8b12cae28..1efca63a49 100644
--- a/client/src/main/java/com/vaadin/client/connectors/grid/TreeRendererConnector.java
+++ b/client/src/main/java/com/vaadin/client/connectors/grid/TreeRendererConnector.java
@@ -33,6 +33,7 @@ import elemental.json.JsonObject;
* @author Vaadin Ltd
* @since 8.1
*/
+@SuppressWarnings("deprecation")
@Connect(TreeRenderer.class)
public class TreeRendererConnector
extends AbstractGridRendererConnector<String> {
diff --git a/client/src/main/java/com/vaadin/client/connectors/grid/UnsafeHtmlRendererConnector.java b/client/src/main/java/com/vaadin/client/connectors/grid/UnsafeHtmlRendererConnector.java
index ccc10b7bfc..905eb5a4f5 100644
--- a/client/src/main/java/com/vaadin/client/connectors/grid/UnsafeHtmlRendererConnector.java
+++ b/client/src/main/java/com/vaadin/client/connectors/grid/UnsafeHtmlRendererConnector.java
@@ -30,6 +30,9 @@ import com.vaadin.shared.ui.grid.renderers.HtmlRendererState;
public class UnsafeHtmlRendererConnector
extends AbstractGridRendererConnector<String> {
+ /**
+ * Constructs a renderer for unsafe html content.
+ */
public static class UnsafeHtmlRenderer implements Renderer<String> {
@Override
public void render(RendererCellReference cell, String data) {
diff --git a/client/src/main/java/com/vaadin/client/renderers/ButtonRenderer.java b/client/src/main/java/com/vaadin/client/renderers/ButtonRenderer.java
index f98b7528e6..0547402aa3 100644
--- a/client/src/main/java/com/vaadin/client/renderers/ButtonRenderer.java
+++ b/client/src/main/java/com/vaadin/client/renderers/ButtonRenderer.java
@@ -39,10 +39,23 @@ public class ButtonRenderer extends ClickableRenderer<String, Button> {
return b;
}
+ /**
+ * Sets whether HTML content is allowed.
+ *
+ * @param htmlContentAllowed
+ * {@code true} if HTML content allowed, {@code false} if
+ * contents should be rendered as plain text
+ */
public void setHtmlContentAllowed(boolean htmlContentAllowed) {
this.htmlContentAllowed = htmlContentAllowed;
}
+ /**
+ * Returns whether HTML content is allowed.
+ *
+ * @return {@code true} if HTML content allowed, {@code false} if contents
+ * are rendered as plain text
+ */
public boolean isHtmlContentAllowed() {
return htmlContentAllowed;
}
diff --git a/client/src/main/java/com/vaadin/client/renderers/ClickableRenderer.java b/client/src/main/java/com/vaadin/client/renderers/ClickableRenderer.java
index 271884af23..4b55e0b031 100644
--- a/client/src/main/java/com/vaadin/client/renderers/ClickableRenderer.java
+++ b/client/src/main/java/com/vaadin/client/renderers/ClickableRenderer.java
@@ -211,6 +211,8 @@ public abstract class ClickableRenderer<T, W extends Widget>
*
* @param handler
* the click handler to be added
+ * @return the handler registration, can be stored in order to remove the
+ * handler later
*/
public HandlerRegistration addClickHandler(
RendererClickHandler<?> handler) {
diff --git a/client/src/main/java/com/vaadin/client/renderers/ComplexRenderer.java b/client/src/main/java/com/vaadin/client/renderers/ComplexRenderer.java
index cd6eecebdc..2b3ff8af8a 100644
--- a/client/src/main/java/com/vaadin/client/renderers/ComplexRenderer.java
+++ b/client/src/main/java/com/vaadin/client/renderers/ComplexRenderer.java
@@ -37,6 +37,9 @@ import com.vaadin.client.widget.grid.RendererCellReference;
* Also provides a helper method for hiding the cell contents by overriding
* {@link #setContentVisible(FlyweightCell, boolean)}
*
+ * @param <T>
+ * the column data type
+ *
* @since 7.4.0
* @author Vaadin Ltd
*/
diff --git a/client/src/main/java/com/vaadin/client/renderers/DateRenderer.java b/client/src/main/java/com/vaadin/client/renderers/DateRenderer.java
index 7bd1e4ed97..62df7daa06 100644
--- a/client/src/main/java/com/vaadin/client/renderers/DateRenderer.java
+++ b/client/src/main/java/com/vaadin/client/renderers/DateRenderer.java
@@ -37,14 +37,29 @@ public class DateRenderer implements Renderer<Date> {
private TimeZone timeZone = TimeZone
.createTimeZone(new Date().getTimezoneOffset());
+ /**
+ * Constructs a renderer for displaying date data.
+ */
public DateRenderer() {
this(PredefinedFormat.DATE_TIME_SHORT);
}
+ /**
+ * Constructs a renderer for displaying date data.
+ *
+ * @param format
+ * the required display format
+ */
public DateRenderer(PredefinedFormat format) {
this(DateTimeFormat.getFormat(format));
}
+ /**
+ * Constructs a renderer for displaying date data.
+ *
+ * @param format
+ * the required display format
+ */
public DateRenderer(DateTimeFormat format) {
setFormat(format);
}
diff --git a/client/src/main/java/com/vaadin/client/renderers/HierarchyRenderer.java b/client/src/main/java/com/vaadin/client/renderers/HierarchyRenderer.java
index 25ce251dfa..8a1c28084c 100644
--- a/client/src/main/java/com/vaadin/client/renderers/HierarchyRenderer.java
+++ b/client/src/main/java/com/vaadin/client/renderers/HierarchyRenderer.java
@@ -91,6 +91,7 @@ public class HierarchyRenderer extends ClickableRenderer<Object, Widget> {
private static final String CLASS_EXPANDED = "expanded";
private static final String CLASS_DEPTH = "depth-";
+ @SuppressWarnings("rawtypes")
private Renderer innerRenderer;
/**
@@ -148,6 +149,7 @@ public class HierarchyRenderer extends ClickableRenderer<Object, Widget> {
return new HierarchyItem(nodeStyleName);
}
+ @SuppressWarnings({ "unchecked", "rawtypes" })
@Override
public void render(RendererCellReference cell, Object data, Widget widget) {
@@ -234,6 +236,7 @@ public class HierarchyRenderer extends ClickableRenderer<Object, Widget> {
* @param innerRenderer
* Renderer to be wrapped.
*/
+ @SuppressWarnings("rawtypes")
public void setInnerRenderer(Renderer innerRenderer) {
this.innerRenderer = innerRenderer;
}
@@ -243,12 +246,18 @@ public class HierarchyRenderer extends ClickableRenderer<Object, Widget> {
*
* @return Wrapped renderer.
*/
+ @SuppressWarnings("rawtypes")
public Renderer getInnerRenderer() {
return innerRenderer;
}
/**
* Decides whether the element was rendered by {@link HierarchyRenderer}.
+ *
+ * @param element
+ * the element to check
+ * @return {@code true} if the element was rendered by a HierarchyRenderer,
+ * {@code false} otherwise.
*/
public static boolean isElementInHierarchyWidget(Element element) {
Widget w = WidgetUtil.findWidget(element);
diff --git a/client/src/main/java/com/vaadin/client/renderers/ImageRenderer.java b/client/src/main/java/com/vaadin/client/renderers/ImageRenderer.java
index 6a5ebca52d..d7a9484b8b 100644
--- a/client/src/main/java/com/vaadin/client/renderers/ImageRenderer.java
+++ b/client/src/main/java/com/vaadin/client/renderers/ImageRenderer.java
@@ -29,6 +29,7 @@ import com.vaadin.client.widget.grid.RendererCellReference;
*/
public class ImageRenderer extends ClickableRenderer<String, Image> {
+ /** Placeholder URL for the image. Used if URL data is set to null. */
public static final String TRANSPARENT_GIF_1PX = "";
@Override
diff --git a/client/src/main/java/com/vaadin/client/renderers/NumberRenderer.java b/client/src/main/java/com/vaadin/client/renderers/NumberRenderer.java
index 9a370158fb..26a76431a0 100644
--- a/client/src/main/java/com/vaadin/client/renderers/NumberRenderer.java
+++ b/client/src/main/java/com/vaadin/client/renderers/NumberRenderer.java
@@ -30,10 +30,19 @@ public class NumberRenderer implements Renderer<Number> {
private NumberFormat format;
+ /**
+ * Constructs a renderer for presenting number data.
+ */
public NumberRenderer() {
this(NumberFormat.getDecimalFormat());
}
+ /**
+ * Constructs a renderer for presenting number data.
+ *
+ * @param format
+ * the format to use when the number is displayed
+ */
public NumberRenderer(NumberFormat format) {
setFormat(format);
}
diff --git a/client/src/main/java/com/vaadin/client/renderers/WidgetRenderer.java b/client/src/main/java/com/vaadin/client/renderers/WidgetRenderer.java
index c45b5f1332..b8dd223f20 100644
--- a/client/src/main/java/com/vaadin/client/renderers/WidgetRenderer.java
+++ b/client/src/main/java/com/vaadin/client/renderers/WidgetRenderer.java
@@ -26,7 +26,7 @@ import com.vaadin.client.widget.grid.RendererCellReference;
* @since 7.4
* @author Vaadin Ltd
* @param <T>
- * the row data type
+ * the column data type
* @param <W>
* the Widget type
*/
@@ -96,6 +96,8 @@ public abstract class WidgetRenderer<T, W extends Widget>
* is not an instance of the given class. Cannot be called for cells that do
* not contain a widget.
*
+ * @param <W>
+ * the Widget type
* @param e
* the element inside to find a widget
* @param klass
diff --git a/client/src/main/java/com/vaadin/client/widget/escalator/FlyweightCell.java b/client/src/main/java/com/vaadin/client/widget/escalator/FlyweightCell.java
index 89230c7370..83b000b3be 100644
--- a/client/src/main/java/com/vaadin/client/widget/escalator/FlyweightCell.java
+++ b/client/src/main/java/com/vaadin/client/widget/escalator/FlyweightCell.java
@@ -38,6 +38,7 @@ import com.vaadin.client.widgets.Escalator;
* @author Vaadin Ltd
*/
public class FlyweightCell {
+ /** The column span property name. */
public static final String COLSPAN_ATTR = "colSpan";
private final int column;
@@ -46,6 +47,17 @@ public class FlyweightCell {
private TableCellElement element = null;
private CellIterator currentIterator = null;
+ /**
+ * Creates a cell representation that follows the
+ * <code>Flyweight</code>-pattern.
+ *
+ * @param row
+ * representation of the row that contains the cell
+ * @param column
+ * the column index of the cell
+ *
+ * @see FlyweightCell
+ */
public FlyweightCell(final FlyweightRow row, final int column) {
this.row = row;
this.column = column;
@@ -53,6 +65,8 @@ public class FlyweightCell {
/**
* Returns the row index of the cell.
+ *
+ * @return the row index
*/
public int getRow() {
assertSetup();
@@ -61,6 +75,8 @@ public class FlyweightCell {
/**
* Returns the column index of the cell.
+ *
+ * @return the column index
*/
public int getColumn() {
assertSetup();
@@ -70,6 +86,8 @@ public class FlyweightCell {
/**
* Returns the element of the cell. Can be either a <code>TD</code> element
* or a <code>TH</code> element.
+ *
+ * @return the element
*/
public TableCellElement getElement() {
assertSetup();
@@ -78,6 +96,8 @@ public class FlyweightCell {
/**
* Return the colspan attribute of the element of the cell.
+ *
+ * @return the colspan attribute
*/
public int getColSpan() {
assertSetup();
@@ -148,6 +168,12 @@ public class FlyweightCell {
+ "inappropriately.";
}
+ /**
+ * Set the colspan attribute for the element of the cell.
+ *
+ * @param numberOfCells
+ * spanned cell count, must be at least 1
+ */
public void setColSpan(final int numberOfCells) {
if (numberOfCells < 1) {
throw new IllegalArgumentException(
diff --git a/client/src/main/java/com/vaadin/client/widget/escalator/FlyweightRow.java b/client/src/main/java/com/vaadin/client/widget/escalator/FlyweightRow.java
index 3e4c229bb1..a03512d6d0 100644
--- a/client/src/main/java/com/vaadin/client/widget/escalator/FlyweightRow.java
+++ b/client/src/main/java/com/vaadin/client/widget/escalator/FlyweightRow.java
@@ -144,6 +144,18 @@ public class FlyweightRow implements Row {
private double[] columnWidths = null;
private final List<FlyweightCell> cells = new ArrayList<>();
+ /**
+ * Configure this FlyweightRow for the current use. This method is expected
+ * to be called multiple times during the Grid's life-cycle.
+ *
+ * @param e
+ * the root element for this row
+ * @param row
+ * the row index
+ * @param columnWidths
+ * widths for each column on the row
+ * @see FlyweightRow
+ */
public void setup(final TableRowElement e, final int row,
double[] columnWidths) {
element = e;
@@ -186,6 +198,15 @@ public class FlyweightRow implements Row {
return element;
}
+ /**
+ * Adds cell representations (i.e. new columns) for the indicated cell range
+ * and updates the subsequent indexing.
+ *
+ * @param index
+ * start index of the range
+ * @param numberOfColumns
+ * length of the range
+ */
public void addCells(final int index, final int numberOfColumns) {
for (int i = 0; i < numberOfColumns; i++) {
final int col = index + i;
@@ -194,6 +215,15 @@ public class FlyweightRow implements Row {
updateRestOfCells(index + numberOfColumns);
}
+ /**
+ * Removes cell representations (i.e. removed columns) from the indicated
+ * cell range and updates the subsequent indexing.
+ *
+ * @param index
+ * start index of the range
+ * @param numberOfColumns
+ * length of the range
+ */
public void removeCells(final int index, final int numberOfColumns) {
cells.subList(index, index + numberOfColumns).clear();
updateRestOfCells(index);
diff --git a/client/src/main/java/com/vaadin/client/widget/escalator/ScrollbarBundle.java b/client/src/main/java/com/vaadin/client/widget/escalator/ScrollbarBundle.java
index a05d54351d..0b3cbd7491 100644
--- a/client/src/main/java/com/vaadin/client/widget/escalator/ScrollbarBundle.java
+++ b/client/src/main/java/com/vaadin/client/widget/escalator/ScrollbarBundle.java
@@ -111,6 +111,7 @@ public abstract class ScrollbarBundle implements DeferredWorker {
* The orientation of the scrollbar.
*/
public enum Direction {
+ /** Scrollbar orientation, indicated by the name. */
VERTICAL, HORIZONTAL;
}
@@ -147,8 +148,12 @@ public abstract class ScrollbarBundle implements DeferredWorker {
void visibilityChanged(VisibilityChangeEvent event);
}
+ /**
+ * Event for scrollbar visibility changes.
+ */
public static class VisibilityChangeEvent
extends GwtEvent<VisibilityHandler> {
+ /** Event type. */
public static final Type<VisibilityHandler> TYPE = new Type<ScrollbarBundle.VisibilityHandler>() {
@Override
public String toString() {
@@ -335,8 +340,14 @@ public abstract class ScrollbarBundle implements DeferredWorker {
}
}
+ /** Root element for the scrollbar-composition. */
protected final Element root = DOM.createDiv();
+ /**
+ * Scroll size element. The size of this element determines the number of
+ * pixels the scrollbar is able to scroll through
+ */
protected final Element scrollSizeElement = DOM.createDiv();
+ /** Is the scrollbar "invisible" (thickness set to 0). */
protected boolean isInvisibleScrollbar = false;
private double scrollPos = 0;
@@ -362,6 +373,12 @@ public abstract class ScrollbarBundle implements DeferredWorker {
root.setTabIndex(-1);
}
+ /**
+ * Returns the width (for horizontal) or height (for vertical) css property
+ * for the scroll size element.
+ *
+ * @return the relevant size property based on orientation
+ */
protected abstract String internalGetScrollSize();
/**
@@ -495,6 +512,10 @@ public abstract class ScrollbarBundle implements DeferredWorker {
* is hidden, so the event must be fired manually.
* <p>
* When IE8 support is dropped, this should really be simplified.
+ *
+ * @param enable
+ * {@code true} if the scrollbar should be forced to be visible,
+ * {@code false} otherwise.
*/
protected void forceScrollbar(boolean enable) {
if (enable) {
@@ -512,6 +533,15 @@ public abstract class ScrollbarBundle implements DeferredWorker {
internalForceScrollbar(enable);
}
+ /**
+ * Sets the overflow-x (for horizontal) or overflow-y (for vertical)
+ * property to {@code "scroll"} if enabled, or clears the property if
+ * disabled.
+ *
+ * @param enable
+ * {@code true} if the overflow property should be set,
+ * {@code false} otherwise.
+ */
protected abstract void internalForceScrollbar(boolean enable);
/**
@@ -523,6 +553,12 @@ public abstract class ScrollbarBundle implements DeferredWorker {
return parseCssDimensionToPixels(internalGetOffsetSize());
}
+ /**
+ * Returns the width (for horizontal) or height (for vertical) css property
+ * for the root element.
+ *
+ * @return the relevant size property based on orientation
+ */
public abstract String internalGetOffsetSize();
/**
@@ -765,6 +801,10 @@ public abstract class ScrollbarBundle implements DeferredWorker {
return getScrollSize() - getOffsetSize() > WidgetUtil.PIXEL_EPSILON;
}
+ /**
+ * Calculates and sets maximum scroll position based on the current scroll
+ * size and the scrollbar's length.
+ */
public void recalculateMaxScrollPos() {
double scrollSize = getScrollSize();
double offsetSize = getOffsetSize();
@@ -804,6 +844,11 @@ public abstract class ScrollbarBundle implements DeferredWorker {
}
}
+ /**
+ * Returns the handler manager for this scrollbar bundle.
+ *
+ * @return the handler manager
+ */
protected HandlerManager getHandlerManager() {
if (handlerManager == null) {
handlerManager = new HandlerManager(this);
diff --git a/client/src/main/java/com/vaadin/client/widget/escalator/Spacer.java b/client/src/main/java/com/vaadin/client/widget/escalator/Spacer.java
index 2d45f451b0..11ccbd320d 100644
--- a/client/src/main/java/com/vaadin/client/widget/escalator/Spacer.java
+++ b/client/src/main/java/com/vaadin/client/widget/escalator/Spacer.java
@@ -35,6 +35,8 @@ public interface Spacer {
/**
* Gets the decorative element for this spacer.
+ *
+ * @return the decorative element
*/
Element getDecoElement();
diff --git a/client/src/main/java/com/vaadin/client/widget/escalator/events/RowHeightChangedEvent.java b/client/src/main/java/com/vaadin/client/widget/escalator/events/RowHeightChangedEvent.java
index 0ec3b13561..f9561c346e 100644
--- a/client/src/main/java/com/vaadin/client/widget/escalator/events/RowHeightChangedEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/escalator/events/RowHeightChangedEvent.java
@@ -31,6 +31,11 @@ public class RowHeightChangedEvent extends GwtEvent<RowHeightChangedHandler> {
*/
public static final Type<RowHeightChangedHandler> TYPE = new Type<>();
+ /**
+ * Returns the associated handler type.
+ *
+ * @return the handler type
+ */
public static final Type<RowHeightChangedHandler> getType() {
return TYPE;
}
diff --git a/client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerIndexChangedEvent.java b/client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerIndexChangedEvent.java
index a20f0002cd..d993cf0457 100644
--- a/client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerIndexChangedEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerIndexChangedEvent.java
@@ -31,6 +31,11 @@ public class SpacerIndexChangedEvent
*/
public static final Type<SpacerIndexChangedHandler> TYPE = new Type<>();
+ /**
+ * Returns the associated handler type.
+ *
+ * @return the handler type
+ */
public static final Type<SpacerIndexChangedHandler> getType() {
return TYPE;
}
diff --git a/client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerVisibilityChangedEvent.java b/client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerVisibilityChangedEvent.java
index e40870d1a0..3c8311e2e8 100644
--- a/client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerVisibilityChangedEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/escalator/events/SpacerVisibilityChangedEvent.java
@@ -31,6 +31,11 @@ public class SpacerVisibilityChangedEvent
*/
public static final Type<SpacerVisibilityChangedHandler> TYPE = new Type<>();
+ /**
+ * Returns the associated handler type.
+ *
+ * @return the handler type
+ */
public static final Type<SpacerVisibilityChangedHandler> getType() {
return TYPE;
}
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/AutoScroller.java b/client/src/main/java/com/vaadin/client/widget/grid/AutoScroller.java
index ba7f66cbec..56de6d1ce0 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/AutoScroller.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/AutoScroller.java
@@ -73,7 +73,11 @@ public class AutoScroller {
void onAutoScrollReachedMax();
}
+ /**
+ * Scroll direction for automatic scrolling.
+ */
public enum ScrollAxis {
+ /** Scroll should happen to the direction indicated by the name. */
VERTICAL, HORIZONTAL
}
@@ -131,6 +135,9 @@ public class AutoScroller {
// TODO investigate if this works as desired
stop();
break;
+ default:
+ // NOP
+ break;
}
}
@@ -437,6 +444,9 @@ public class AutoScroller {
case Event.ONTOUCHCANCEL:
stop();
break;
+ default:
+ // NOP
+ break;
}
};
@@ -606,6 +616,11 @@ public class AutoScroller {
}
}
+ /**
+ * Returns how wide the frozen columns are all counted together.
+ *
+ * @return the width of frozen columns
+ */
public double getFrozenColumnsWidth() {
double value = 0;
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/CellReference.java b/client/src/main/java/com/vaadin/client/widget/grid/CellReference.java
index 29aefbb8fe..949ac40f74 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/CellReference.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/CellReference.java
@@ -38,6 +38,12 @@ public class CellReference<T> {
private Grid.Column<?, T> column;
private final RowReference<T> rowReference;
+ /**
+ * Constructs a new cell reference for the given row.
+ *
+ * @param rowReference
+ * the row that requires a new cell
+ */
public CellReference(RowReference<T> rowReference) {
this.rowReference = rowReference;
}
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/DataAvailableEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/DataAvailableEvent.java
index 2eb5505085..28c92e873c 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/DataAvailableEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/DataAvailableEvent.java
@@ -27,8 +27,15 @@ import com.vaadin.shared.Range;
public class DataAvailableEvent extends GwtEvent<DataAvailableHandler> {
private Range rowsAvailable;
+ /** Handler type for DataAvailableEvents. */
public static final Type<DataAvailableHandler> TYPE = new Type<>();
+ /**
+ * Constructs a data availability event for the given row range.
+ *
+ * @param rowsAvailable
+ * the range of available rows
+ */
public DataAvailableEvent(Range rowsAvailable) {
this.rowsAvailable = rowsAvailable;
}
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/DefaultEditorEventHandler.java b/client/src/main/java/com/vaadin/client/widget/grid/DefaultEditorEventHandler.java
index a76760af6e..9acf0718e1 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/DefaultEditorEventHandler.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/DefaultEditorEventHandler.java
@@ -38,15 +38,24 @@ import com.vaadin.client.widgets.Grid.EditorDomEvent;
* The default handler for Grid editor events. Offers several overridable
* protected methods for easier customization.
*
+ * @param <T>
+ * The row type of the grid. The row type is the POJO type from where
+ * the data is retrieved into the column cells.
+ *
* @since 7.6
* @author Vaadin Ltd
*/
public class DefaultEditorEventHandler<T> implements Editor.EventHandler<T> {
+ /** Default key code for showing the editor. */
public static final int KEYCODE_OPEN = KeyCodes.KEY_ENTER;
+ /** Default key code for moving the editor up or down. */
public static final int KEYCODE_MOVE_VERTICAL = KeyCodes.KEY_ENTER;
+ /** Default key code for hiding the editor. */
public static final int KEYCODE_CLOSE = KeyCodes.KEY_ESCAPE;
+ /** Default key code for moving cursor horizontally within the editor. */
public static final int KEYCODE_MOVE_HORIZONTAL = KeyCodes.KEY_TAB;
+ /** Default key code for triggering save in buffered mode. */
public static final int KEYCODE_BUFFERED_SAVE = KeyCodes.KEY_ENTER;
private double lastTouchEventTime = 0;
@@ -134,9 +143,12 @@ public class DefaultEditorEventHandler<T> implements Editor.EventHandler<T> {
* Specifies the direction at which the focus should move.
*/
public enum CursorMoveDelta {
+ /** Move focus one step to the direction indicated by name. */
UP(-1, 0), RIGHT(0, 1), DOWN(1, 0), LEFT(0, -1);
+ /** Vertical change. */
public final int rowDelta;
+ /** Horizontal change. */
public final int colDelta;
CursorMoveDelta(int rowDelta, int colDelta) {
@@ -144,6 +156,12 @@ public class DefaultEditorEventHandler<T> implements Editor.EventHandler<T> {
this.colDelta = colDelta;
}
+ /**
+ * Returns whether the cursor move has either horizontal or vertical
+ * changes.
+ *
+ * @return {@code true} if there are changes, {@code false} otherwise
+ */
public boolean isChanged() {
return rowDelta != 0 || colDelta != 0;
}
@@ -267,6 +285,15 @@ public class DefaultEditorEventHandler<T> implements Editor.EventHandler<T> {
return -1;
}
+ /**
+ * Checks whether the field within the given editor column is editable.
+ *
+ * @param grid
+ * the grid that is being edited
+ * @param column
+ * the column to investigate
+ * @return {@code true} if the field is editable, {@code false} otherwise
+ */
protected boolean isEditable(Grid<T> grid, Grid.Column<?, T> column) {
if (!column.isEditable()) {
return false;
@@ -403,6 +430,19 @@ public class DefaultEditorEventHandler<T> implements Editor.EventHandler<T> {
return false;
}
+ /**
+ * Opens the editor over the row with the given index and attempts to focus
+ * the editor widget in the given column index. If the given indices are
+ * outside of the existing range, the closest value within the range is
+ * used.
+ *
+ * @param event
+ * the wrapped DOM event
+ * @param rowIndex
+ * index of the row to edit
+ * @param colIndex
+ * index of the editor column to focus
+ */
protected void editRow(EditorDomEvent<T> event, int rowIndex,
int colIndex) {
int rowCount = event.getGrid().getDataSource().size();
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/EventCellReference.java b/client/src/main/java/com/vaadin/client/widget/grid/EventCellReference.java
index 1ec5de73f8..ca9f0854fb 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/EventCellReference.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/EventCellReference.java
@@ -29,6 +29,10 @@ import com.vaadin.shared.ui.grid.GridConstants.Section;
* this object is subject to change without the user knowing it and so should
* not be stored anywhere outside of the method providing these instances.
*
+ * @param <T>
+ * The row type of the grid. The row type is the POJO type from where
+ * the data is retrieved into the column cells.
+ *
* @since 7.4
* @author Vaadin Ltd
*/
@@ -37,15 +41,27 @@ public class EventCellReference<T> extends CellReference<T> {
private Section section;
private TableCellElement element;
+ /**
+ * Constructs a cell reference for an event targeting a grid cell. Needs to
+ * be populated using {@link #set(Cell, Section)}.
+ *
+ * @param grid
+ * the grid the event originates from
+ *
+ * @see EventCellReference
+ */
public EventCellReference(Grid<T> grid) {
super(new RowReference<>(grid));
}
/**
- * Sets the RowReference and CellReference to point to given Cell.
+ * Configures this CellReference and its internal RowReference to point to
+ * the given Cell.
*
* @param targetCell
- * cell to point to
+ * the cell to point to
+ * @param section
+ * the section the cell belongs to
*/
public void set(Cell targetCell, Section section) {
Grid<T> grid = getGrid();
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/RendererCellReference.java b/client/src/main/java/com/vaadin/client/widget/grid/RendererCellReference.java
index 827f3cbebf..767821da30 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/RendererCellReference.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/RendererCellReference.java
@@ -54,6 +54,7 @@ public class RendererCellReference extends CellReference<Object> {
* @param column
* the column to reference
*/
+ @SuppressWarnings("unchecked")
public void set(FlyweightCell cell, int columnIndex,
Grid.Column<?, ?> column) {
this.cell = cell;
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/datasources/ListDataSource.java b/client/src/main/java/com/vaadin/client/widget/grid/datasources/ListDataSource.java
index 7f325cb188..41049d62de 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/datasources/ListDataSource.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/datasources/ListDataSource.java
@@ -56,6 +56,9 @@ import com.vaadin.shared.util.SharedUtil;
* ds.asList().addAll(Arrays.asList(5, 6, 7));
* </pre>
*
+ * @param <T>
+ * the type of the items in the grid
+ *
* @since 7.4
* @author Vaadin Ltd
*/
@@ -356,6 +359,7 @@ public class ListDataSource<T> implements DataSource<T> {
* @param rows
* The rows to initially add to the data source
*/
+ @SuppressWarnings("unchecked")
public ListDataSource(T... rows) {
if (rows == null) {
ds = new ArrayList<>();
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/datasources/ListSorter.java b/client/src/main/java/com/vaadin/client/widget/grid/datasources/ListSorter.java
index b30c1ad940..a94881bffd 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/datasources/ListSorter.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/datasources/ListSorter.java
@@ -43,6 +43,12 @@ public class ListSorter<T> {
private Map<Grid.Column<?, T>, Comparator<?>> comparators;
private HandlerRegistration sortHandlerRegistration;
+ /**
+ * Constructs a sorting facility for the given Grid.
+ *
+ * @param grid
+ * the Grid that needs sort handling
+ */
public ListSorter(Grid<T> grid) {
if (grid == null) {
@@ -76,6 +82,8 @@ public class ListSorter<T> {
* and Dates). Any existing comparator can be removed by passing in a
* non-null GridColumn and a null Comparator.
*
+ * @param <C>
+ * the column data type
* @param column
* a grid column. May not be null.
* @param comparator
@@ -98,6 +106,8 @@ public class ListSorter<T> {
/**
* Retrieve the comparator assigned for a specific grid column.
*
+ * @param <C>
+ * the column data type
* @param column
* a grid column. May not be null.
* @return a comparator, or null if no comparator for the specified grid
@@ -126,6 +136,7 @@ public class ListSorter<T> {
* @param order
* the sort order list provided by the grid sort event
*/
+ @SuppressWarnings({ "rawtypes", "unchecked" })
private void sort(final List<SortOrder> order) {
DataSource<T> ds = grid.getDataSource();
if (!(ds instanceof ListDataSource)) {
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridKeyEventHandler.java b/client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridKeyEventHandler.java
index 00a47b21d6..1e61bc2401 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridKeyEventHandler.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridKeyEventHandler.java
@@ -26,18 +26,48 @@ import com.vaadin.client.widgets.Grid.AbstractGridKeyEvent;
*/
public abstract interface AbstractGridKeyEventHandler extends EventHandler {
+ /**
+ * Handler for Grid key down events.
+ */
public abstract interface GridKeyDownHandler
extends AbstractGridKeyEventHandler {
+ /**
+ * Perform actions that should happen when a key down event is triggered
+ * within a Grid.
+ *
+ * @param event
+ * the key down event
+ */
public void onKeyDown(GridKeyDownEvent event);
}
+ /**
+ * Handler for Grid key up events.
+ */
public abstract interface GridKeyUpHandler
extends AbstractGridKeyEventHandler {
+ /**
+ * Perform actions that should happen when a key up event is triggered
+ * within a Grid.
+ *
+ * @param event
+ * the key up event
+ */
public void onKeyUp(GridKeyUpEvent event);
}
+ /**
+ * Handler for Grid key press events.
+ */
public abstract interface GridKeyPressHandler
extends AbstractGridKeyEventHandler {
+ /**
+ * Perform actions that should happen when a key press event is
+ * triggered within a Grid.
+ *
+ * @param event
+ * the key press event
+ */
public void onKeyPress(GridKeyPressEvent event);
}
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridMouseEventHandler.java b/client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridMouseEventHandler.java
index 67e23f5d43..cfd0d0a3e1 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridMouseEventHandler.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/AbstractGridMouseEventHandler.java
@@ -26,13 +26,31 @@ import com.vaadin.client.widgets.Grid.AbstractGridMouseEvent;
*/
public abstract interface AbstractGridMouseEventHandler extends EventHandler {
+ /**
+ * Handler for Grid click events.
+ */
public abstract interface GridClickHandler
extends AbstractGridMouseEventHandler {
+ /**
+ * Perform actions that should happen when the Grid is clicked.
+ *
+ * @param event
+ * the click event
+ */
public void onClick(GridClickEvent event);
}
+ /**
+ * Handler for Grid double-click events.
+ */
public abstract interface GridDoubleClickHandler
extends AbstractGridMouseEventHandler {
+ /**
+ * Perform actions that should happen when the Grid is double-clicked.
+ *
+ * @param event
+ * the double-click event
+ */
public void onDoubleClick(GridDoubleClickEvent event);
}
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnReorderEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnReorderEvent.java
index ab7ff6794a..6383edde66 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnReorderEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnReorderEvent.java
@@ -36,6 +36,11 @@ public class ColumnReorderEvent<T> extends GwtEvent<ColumnReorderHandler<T>> {
*/
private static final Type<ColumnReorderHandler<?>> TYPE = new Type<>();
+ /**
+ * Returns the associated handler type.
+ *
+ * @return the handler type
+ */
public static final Type<ColumnReorderHandler<?>> getType() {
return TYPE;
}
@@ -46,6 +51,17 @@ public class ColumnReorderEvent<T> extends GwtEvent<ColumnReorderHandler<T>> {
private final boolean userOriginated;
+ /**
+ * Constructs a reorder event for grid columns.
+ *
+ * @param oldColumnOrder
+ * the old order
+ * @param newColumnOrder
+ * the new order
+ * @param userOriginated
+ * {@code true} if the event was triggered by user interaction,
+ * {@code false} otherwise
+ */
public ColumnReorderEvent(List<Column<?, T>> oldColumnOrder,
List<Column<?, T>> newColumnOrder, boolean userOriginated) {
this.oldColumnOrder = oldColumnOrder;
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnResizeEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnResizeEvent.java
index ef2e443fe9..457f85ed9f 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnResizeEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnResizeEvent.java
@@ -37,12 +37,20 @@ public class ColumnResizeEvent<T> extends GwtEvent<ColumnResizeHandler<T>> {
private Column<?, T> column;
/**
+ * Constructs a resize event for a grid column.
+ *
* @param column
+ * the updated column
*/
public ColumnResizeEvent(Column<?, T> column) {
this.column = column;
}
+ /**
+ * Returns the associated handler type.
+ *
+ * @return the handler type
+ */
public static final Type<ColumnResizeHandler<?>> getType() {
return TYPE;
}
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeEvent.java
index 3c176e703f..6ca8b263a7 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeEvent.java
@@ -33,6 +33,11 @@ public class ColumnVisibilityChangeEvent<T>
private static final Type<ColumnVisibilityChangeHandler<?>> TYPE = new Type<>();
+ /**
+ * Returns the associated handler type.
+ *
+ * @return the handler type
+ */
public static final Type<ColumnVisibilityChangeHandler<?>> getType() {
return TYPE;
}
@@ -43,6 +48,18 @@ public class ColumnVisibilityChangeEvent<T>
private final boolean hidden;
+ /**
+ * Constructs a visibility change event for a grid column.
+ *
+ * @param column
+ * the updated column
+ * @param hidden
+ * {@code true} if the column is now hidden, {@code false}
+ * otherwise
+ * @param userOriginated
+ * {@code true} if the event was triggered by user interaction,
+ * {@code false} otherwise
+ */
public ColumnVisibilityChangeEvent(Column<?, T> column, boolean hidden,
boolean userOriginated) {
this.column = column;
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeHandler.java b/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeHandler.java
index 159f1d7a47..ce55d4c438 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeHandler.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/ColumnVisibilityChangeHandler.java
@@ -21,9 +21,9 @@ import com.google.gwt.event.shared.EventHandler;
* Handler for a Grid column visibility change event, called when the Grid's
* columns have changed visibility to hidden or visible.
*
- * @param<T> The
- * row type of the grid. The row type is the POJO type from where
- * the data is retrieved into the column cells.
+ * @param <T>
+ * The row type of the grid. The row type is the POJO type from where
+ * the data is retrieved into the column cells.
*
* @since 7.5.0
* @author Vaadin Ltd
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/GridClickEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/GridClickEvent.java
index 4a91a94706..2690eec0b5 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/GridClickEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/GridClickEvent.java
@@ -30,6 +30,7 @@ import com.vaadin.shared.ui.grid.GridConstants.Section;
*/
public class GridClickEvent extends AbstractGridMouseEvent<GridClickHandler> {
+ /** DOM event type. */
public static final Type<GridClickHandler> TYPE = new Type<GridClickHandler>(
BrowserEvents.CLICK, new GridClickEvent());
@@ -42,6 +43,11 @@ public class GridClickEvent extends AbstractGridMouseEvent<GridClickHandler> {
/**
* @deprecated This constructor's arguments are no longer used. Use the
* no-args constructor instead.
+ *
+ * @param grid
+ * the grid the event occurred in, not used
+ * @param targetCell
+ * the cell the event targets, not used
*/
@Deprecated
public GridClickEvent(Grid<?> grid, CellReference<?> targetCell) {
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/GridDoubleClickEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/GridDoubleClickEvent.java
index 1a1a3a35e5..da14e74130 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/GridDoubleClickEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/GridDoubleClickEvent.java
@@ -31,6 +31,7 @@ import com.vaadin.shared.ui.grid.GridConstants.Section;
public class GridDoubleClickEvent
extends AbstractGridMouseEvent<GridDoubleClickHandler> {
+ /** DOM event type. */
public static final Type<GridDoubleClickHandler> TYPE = new Type<GridDoubleClickHandler>(
BrowserEvents.DBLCLICK, new GridDoubleClickEvent());
@@ -43,6 +44,11 @@ public class GridDoubleClickEvent
/**
* @deprecated This constructor's arguments are no longer used. Use the
* no-args constructor instead.
+ *
+ * @param grid
+ * the grid the event occurred in, not used
+ * @param targetCell
+ * the cell the event targets, not used
*/
@Deprecated
public GridDoubleClickEvent(Grid<?> grid, CellReference<?> targetCell) {
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledEvent.java
index 6d8ac737df..2122c899aa 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledEvent.java
@@ -30,6 +30,13 @@ public class GridEnabledEvent extends GwtEvent<GridEnabledHandler> {
public static final Type<GridEnabledHandler> TYPE = new Type<>();
private final boolean enabled;
+ /**
+ * Constructs an event that informs about Grid's enabled status change.
+ *
+ * @param enabled
+ * {@code true} if the Grid is now enabled, {@code false} if the
+ * Grid is now disabled
+ */
public GridEnabledEvent(boolean enabled) {
this.enabled = enabled;
}
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyDownEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyDownEvent.java
index 48848cf054..9148ff375d 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyDownEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyDownEvent.java
@@ -31,6 +31,7 @@ import com.vaadin.shared.ui.grid.GridConstants.Section;
*/
public class GridKeyDownEvent extends AbstractGridKeyEvent<GridKeyDownHandler> {
+ /** DOM event type. */
public static final Type<GridKeyDownHandler> TYPE = new Type<GridKeyDownHandler>(
BrowserEvents.KEYDOWN, new GridKeyDownEvent());
@@ -43,6 +44,11 @@ public class GridKeyDownEvent extends AbstractGridKeyEvent<GridKeyDownHandler> {
/**
* @deprecated This constructor's arguments are no longer used. Use the
* no-args constructor instead.
+ *
+ * @param grid
+ * the grid the event occurred in, not used
+ * @param targetCell
+ * the cell the event targets, not used
*/
@Deprecated
public GridKeyDownEvent(Grid<?> grid, CellReference<?> targetCell) {
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyPressEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyPressEvent.java
index 87c9862f87..26f5023825 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyPressEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyPressEvent.java
@@ -31,6 +31,7 @@ import com.vaadin.shared.ui.grid.GridConstants.Section;
public class GridKeyPressEvent
extends AbstractGridKeyEvent<GridKeyPressHandler> {
+ /** DOM event type. */
public static final Type<GridKeyPressHandler> TYPE = new Type<GridKeyPressHandler>(
BrowserEvents.KEYPRESS, new GridKeyPressEvent());
@@ -43,6 +44,11 @@ public class GridKeyPressEvent
/**
* @deprecated This constructor's arguments are no longer used. Use the
* no-args constructor instead.
+ *
+ * @param grid
+ * the grid the event occurred in, not used
+ * @param targetCell
+ * the cell the event targets, not used
*/
@Deprecated
public GridKeyPressEvent(Grid<?> grid, CellReference<?> targetCell) {
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyUpEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyUpEvent.java
index 30f6e5f287..a981ef66cf 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyUpEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/GridKeyUpEvent.java
@@ -31,6 +31,7 @@ import com.vaadin.shared.ui.grid.GridConstants.Section;
*/
public class GridKeyUpEvent extends AbstractGridKeyEvent<GridKeyUpHandler> {
+ /** DOM event type. */
public static final Type<GridKeyUpHandler> TYPE = new Type<GridKeyUpHandler>(
BrowserEvents.KEYUP, new GridKeyUpEvent());
@@ -43,6 +44,11 @@ public class GridKeyUpEvent extends AbstractGridKeyEvent<GridKeyUpHandler> {
/**
* @deprecated This constructor's arguments are no longer used. Use the
* no-args constructor instead.
+ *
+ * @param grid
+ * the grid the event occurred in, not used
+ * @param targetCell
+ * the cell the event targets, not used
*/
@Deprecated
public GridKeyUpEvent(Grid<?> grid, CellReference<?> targetCell) {
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/SelectAllHandler.java b/client/src/main/java/com/vaadin/client/widget/grid/events/SelectAllHandler.java
index 6a1717df7a..d2d8678146 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/events/SelectAllHandler.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/events/SelectAllHandler.java
@@ -21,6 +21,9 @@ import com.google.gwt.event.shared.EventHandler;
* Handler for a Grid select all event, called when the Grid needs all rows in
* data source to be selected.
*
+ * @param <T>
+ * the type of the items in the Grid
+ *
* @since 7.4
* @author Vaadin Ltd
*/
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/selection/ClickSelectHandler.java b/client/src/main/java/com/vaadin/client/widget/grid/selection/ClickSelectHandler.java
index 0c42a0adb5..d6e7c0dd2b 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/selection/ClickSelectHandler.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/selection/ClickSelectHandler.java
@@ -23,6 +23,9 @@ import com.vaadin.client.widgets.Grid;
/**
* Generic class to perform selections when clicking on cells in body of Grid.
*
+ * @param <T>
+ * the type of the items in the Grid
+ *
* @since 7.4
* @author Vaadin Ltd
*/
@@ -39,6 +42,7 @@ public class ClickSelectHandler<T> {
if (!grid.getSelectionModel().isSelectionAllowed()) {
return;
}
+ @SuppressWarnings("unchecked")
T row = (T) event.getTargetCell().getRow();
if (!grid.isSelected(row)) {
grid.select(row);
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/selection/HasSelectionHandlers.java b/client/src/main/java/com/vaadin/client/widget/grid/selection/HasSelectionHandlers.java
index c0b60b769a..3149e99657 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/selection/HasSelectionHandlers.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/selection/HasSelectionHandlers.java
@@ -20,6 +20,9 @@ import com.google.gwt.event.shared.HandlerRegistration;
/**
* Marker interface for widgets that fires selection events.
*
+ * @param <T>
+ * the type of the items in the Grid
+ *
* @author Vaadin Ltd
* @since 7.4
*/
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/selection/MultiSelectionRenderer.java b/client/src/main/java/com/vaadin/client/widget/grid/selection/MultiSelectionRenderer.java
index 4b1a3d63bb..343345775e 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/selection/MultiSelectionRenderer.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/selection/MultiSelectionRenderer.java
@@ -42,7 +42,6 @@ import com.google.gwt.user.client.Event;
import com.google.gwt.user.client.Event.NativePreviewEvent;
import com.google.gwt.user.client.Event.NativePreviewHandler;
import com.google.gwt.user.client.ui.CheckBox;
-import com.vaadin.client.VConsole;
import com.vaadin.client.WidgetUtil;
import com.vaadin.client.renderers.ClickableRenderer;
import com.vaadin.client.widget.grid.CellReference;
@@ -58,7 +57,7 @@ import com.vaadin.client.widgets.Grid;
*
* @author Vaadin Ltd
* @param <T>
- * the type of the associated grid
+ * the type of the items in the associated Grid
* @since 7.4
*/
public class MultiSelectionRenderer<T>
@@ -196,6 +195,9 @@ public class MultiSelectionRenderer<T>
event.cancel();
}
break;
+ default:
+ // NOP
+ break;
}
}
@@ -525,6 +527,9 @@ public class MultiSelectionRenderer<T>
case Event.ONTOUCHCANCEL:
stop();
break;
+ default:
+ // NOP
+ break;
}
};
@@ -599,6 +604,13 @@ public class MultiSelectionRenderer<T>
private final AutoScrollHandler autoScrollHandler = new AutoScrollHandler();
+ /**
+ * Constructs a renderer for a selection column with multi-selection
+ * CheckBoxes.
+ *
+ * @param grid
+ * the parent grid
+ */
public MultiSelectionRenderer(final Grid<T> grid) {
this.grid = grid;
}
@@ -785,10 +797,27 @@ public class MultiSelectionRenderer<T>
+ getTheadElement().getOffsetHeight() + 1;
}
+ /**
+ * Checks whether the given row is selected.
+ *
+ * @param logicalRow
+ * logical index of the row to check
+ * @return {@code true} if the current selection model considers the row
+ * selected, {@code false} otherwise
+ */
protected boolean isSelected(final int logicalRow) {
return grid.isSelected(grid.getDataSource().getRow(logicalRow));
}
+ /**
+ * Updates selection status for the given row.
+ *
+ * @param logicalRow
+ * logical index of the row to update
+ * @param select
+ * {@code true} if the row should be marked selected,
+ * {@code false} otherwise
+ */
protected void setSelected(final int logicalRow, final boolean select) {
T row = grid.getDataSource().getRow(logicalRow);
if (select) {
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionEvent.java
index cec6d6ec2d..991d96cdd9 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionEvent.java
@@ -26,6 +26,9 @@ import com.vaadin.client.widgets.Grid;
/**
* Event object describing a change in Grid row selection state.
*
+ * @param <T>
+ * the type of the items in the Grid
+ *
* @since 7.4
* @author Vaadin Ltd
*/
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionModel.java b/client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionModel.java
index 5b6d1431a7..37c16a3fca 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionModel.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/selection/SelectionModel.java
@@ -26,11 +26,17 @@ import elemental.json.JsonObject;
* @author Vaadin Ltd.
*
* @param <T>
- * the type of the items to select
+ * the type of the items in the Grid
* @since 8.0
*/
public interface SelectionModel<T> {
+ /**
+ * Selection model that does not allow any selection.
+ *
+ * @param <T>
+ * the type of the items to select
+ */
public static class NoSelectionModel<T> implements SelectionModel<T> {
@Override
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/sort/SortEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/sort/SortEvent.java
index 410ed4345c..b0e37741bc 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/sort/SortEvent.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/sort/SortEvent.java
@@ -24,6 +24,10 @@ import com.vaadin.client.widgets.Grid;
* A sort event, fired by the Grid when it needs its data source to provide data
* sorted in a specific manner.
*
+ * @param <T>
+ * The row type of the Grid. The row type is the POJO type from where
+ * the data is retrieved into the column cells.
+ *
* @since 7.4
* @author Vaadin Ltd
*/
diff --git a/client/src/main/java/com/vaadin/client/widget/grid/sort/SortHandler.java b/client/src/main/java/com/vaadin/client/widget/grid/sort/SortHandler.java
index 5ecaeae00b..9d54b9e2f0 100644
--- a/client/src/main/java/com/vaadin/client/widget/grid/sort/SortHandler.java
+++ b/client/src/main/java/com/vaadin/client/widget/grid/sort/SortHandler.java
@@ -21,6 +21,10 @@ import com.google.gwt.event.shared.EventHandler;
* Handler for a Grid sort event, called when the Grid needs its data source to
* provide data sorted in a specific manner.
*
+ * @param <T>
+ * The row type of the Grid. The row type is the POJO type from where
+ * the data is retrieved into the column cells.
+ *
* @since 7.4
* @author Vaadin Ltd
*/
diff --git a/client/src/main/java/com/vaadin/client/widgets/Escalator.java b/client/src/main/java/com/vaadin/client/widgets/Escalator.java
index 8f6d8992bb..0c289b0ef0 100644
--- a/client/src/main/java/com/vaadin/client/widgets/Escalator.java
+++ b/client/src/main/java/com/vaadin/client/widgets/Escalator.java
@@ -479,7 +479,8 @@ public class Escalator extends Widget
void validate(Movement other) {
if (!run || other.velocity > 0
&& Math.abs(velocity / other.velocity) < F_AXIS) {
- delta = offset = 0;
+ delta = 0;
+ offset = 0;
run = false;
}
}
@@ -764,13 +765,13 @@ public class Escalator extends Widget
/*-{
var vScroll = esc.@com.vaadin.client.widgets.Escalator::verticalScrollbar;
var vScrollElem = vScroll.@com.vaadin.client.widget.escalator.ScrollbarBundle::getElement()();
-
+
var hScroll = esc.@com.vaadin.client.widgets.Escalator::horizontalScrollbar;
var hScrollElem = hScroll.@com.vaadin.client.widget.escalator.ScrollbarBundle::getElement()();
-
+
return $entry(function(e) {
var target = e.target;
-
+
// in case the scroll event was native (i.e. scrollbars were dragged, or
// the scrollTop/Left was manually modified), the bundles have old cache
// values. We need to make sure that the caches are kept up to date.
@@ -791,29 +792,29 @@ public class Escalator extends Widget
return $entry(function(e) {
var deltaX = e.deltaX ? e.deltaX : -0.5*e.wheelDeltaX;
var deltaY = e.deltaY ? e.deltaY : -0.5*e.wheelDeltaY;
-
+
// Delta mode 0 is in pixels; we don't need to do anything...
-
+
// A delta mode of 1 means we're scrolling by lines instead of pixels
// We need to scale the number of lines by the default line height
if (e.deltaMode === 1) {
var brc = esc.@com.vaadin.client.widgets.Escalator::body;
deltaY *= brc.@com.vaadin.client.widgets.Escalator.AbstractRowContainer::getDefaultRowHeight()();
}
-
+
// Other delta modes aren't supported
if ((e.deltaMode !== undefined) && (e.deltaMode >= 2 || e.deltaMode < 0)) {
var msg = "Unsupported wheel delta mode \"" + e.deltaMode + "\"";
-
+
// Print warning message
esc.@com.vaadin.client.widgets.Escalator::logWarning(*)(msg);
}
-
+
// IE8 has only delta y
if (isNaN(deltaY)) {
deltaY = -0.5*e.wheelDelta;
}
-
+
@com.vaadin.client.widgets.Escalator.JsniUtil::moveScrollFromEvent(*)(esc, deltaX, deltaY, e);
});
}-*/;
@@ -1230,8 +1231,31 @@ public class Escalator extends Widget
*/
public enum AriaGridRole {
- ROW("row"), ROWHEADER("rowheader"), ROWGROUP("rowgroup"), GRIDCELL(
- "gridcell"), COLUMNHEADER("columnheader");
+ /**
+ * Aria role for grid row elements except within the header.
+ *
+ * @see AriaGridRole#ROWHEADER
+ */
+ ROW("row"),
+ /**
+ * Aria role for grid row elements within the header.
+ */
+ ROWHEADER("rowheader"),
+ /**
+ * Aria role for grid row group elements, i.e. each root element that
+ * contains all the rows per section (header, body, or footer).
+ */
+ ROWGROUP("rowgroup"),
+ /**
+ * Aria role for grid cell elements except within the header.
+ *
+ * @see AriaGridRole#COLUMNHEADER
+ */
+ GRIDCELL("gridcell"),
+ /**
+ * Aria role for grid column header cell elements.
+ */
+ COLUMNHEADER("columnheader");
private final String name;
@@ -1249,15 +1273,18 @@ public class Escalator extends Widget
}
}
+ /**
+ * A representation of the rows within a section (header, body, or footer).
+ */
public abstract class AbstractRowContainer implements RowContainer {
private EscalatorUpdater updater = EscalatorUpdater.NULL;
private int rows;
/**
- * The table section element ({@code <thead>}, {@code <tbody>} or
- * {@code <tfoot>}) the rows (i.e. <code>&lt;tr&gt;</code> tags) are
- * contained in.
+ * The table section element (<code>&lt;thead&gt;</code>,
+ * <code>&lt;tbody&gt;</code> or <code>&lt;tfoot&gt;</code>) the rows
+ * (i.e. <code>&lt;tr&gt;</code> tags) are contained in.
*/
protected final TableSectionElement root;
@@ -1275,6 +1302,13 @@ public class Escalator extends Widget
private boolean autodetectingRowHeightLater = false;
+ /**
+ * Constructs a row container that uses the given table section element
+ * as the root element for the rows.
+ *
+ * @param rowContainerElement
+ * the table section element
+ */
public AbstractRowContainer(
final TableSectionElement rowContainerElement) {
root = rowContainerElement;
@@ -1434,6 +1468,19 @@ public class Escalator extends Widget
}
+ /**
+ * Checks validity of the given arguments for a row range that needs
+ * handling. Throws an exception if the arguments are not valid.
+ *
+ * @param index
+ * the start index of the range
+ * @param numberOfRows
+ * the number of rows within the range
+ * @throws IllegalArgumentException
+ * if the range doesn't have a positive length
+ * @throws IndexOutOfBoundsException
+ * if the entire range doesn't fit within the existing rows
+ */
protected void assertArgumentsAreValidAndWithinRange(final int index,
final int numberOfRows)
throws IllegalArgumentException, IndexOutOfBoundsException {
@@ -1543,6 +1590,18 @@ public class Escalator extends Widget
protected abstract void paintInsertRows(final int visualIndex,
final int numberOfRows);
+ /**
+ * Add static rows into the DOM. Usually this would be considered to
+ * mean only header or footer rows, but the body row container
+ * implementation also uses this method to get a starting point for
+ * further modifications.
+ *
+ * @param visualIndex
+ * the DOM index to add rows into
+ * @param numberOfRows
+ * the number of rows to insert
+ * @return a list of added row elements
+ */
protected List<TableRowElement> paintInsertStaticRows(
final int visualIndex, final int numberOfRows) {
assert isAttached() : "Can't paint rows if Escalator is not attached";
@@ -1653,10 +1712,19 @@ public class Escalator extends Widget
return elem;
}
+ /**
+ * Triggers section height calculation. Does nothing by default if
+ * called for the body row section, because body section height handling
+ * has more complicated logic. Note that updating header or footer
+ * height triggers a check that the body has correct amount of rows and
+ * their spacers.
+ */
protected abstract void recalculateSectionHeight();
/**
* Returns the height of all rows in the row container.
+ *
+ * @return total height of container's rows
*/
protected double calculateTotalRowHeight() {
return getDefaultRowHeight() * getRowCount();
@@ -1679,6 +1747,14 @@ public class Escalator extends Widget
refreshCells(rowRange, colRange);
}
+ /**
+ * Refresh cells within the given row and column ranges.
+ *
+ * @param logicalRowRange
+ * the range within the logical row indexes
+ * @param colRange
+ * the range within the column indexes
+ */
protected abstract void refreshCells(Range logicalRowRange,
Range colRange);
@@ -1743,6 +1819,14 @@ public class Escalator extends Widget
protected abstract TableRowElement getTrByVisualIndex(int index)
throws IndexOutOfBoundsException;
+ /**
+ * Remove the given number of columns starting from the given index.
+ *
+ * @param offset
+ * the index of the first column to remove
+ * @param numberOfColumns
+ * the number of columns to remove
+ */
protected void paintRemoveColumns(final int offset,
final int numberOfColumns) {
for (int i = 0; i < getDomRowCount(); i++) {
@@ -1766,6 +1850,18 @@ public class Escalator extends Widget
}
}
+ /**
+ * Add the given number of columns starting from the given index. Frozen
+ * columns shouldn't be added after non-frozen columns.
+ *
+ * @param offset
+ * the index of the first column to add
+ * @param numberOfColumns
+ * the number of columns to add
+ * @param frozen
+ * {@code true} if the added columns should be frozen,
+ * {@code false} otherwise
+ */
protected void paintInsertColumns(final int offset,
final int numberOfColumns, boolean frozen) {
@@ -1843,6 +1939,16 @@ public class Escalator extends Widget
assert flyweightRow.teardown();
}
+ /**
+ * Sets a column's frozen status. Frozen columns shouldn't be added
+ * after non-frozen columns.
+ *
+ * @param column
+ * the index of the column
+ * @param frozen
+ * {@code true} if the column should be frozen, {@code false}
+ * otherwise
+ */
public void setColumnFrozen(int column, boolean frozen) {
toggleFrozenColumnClass(column, frozen, "frozen");
@@ -1871,10 +1977,27 @@ public class Escalator extends Widget
}
}
+ /**
+ * Sets the last frozen state of the given column.
+ *
+ * @param column
+ * the index of the column
+ * @param lastFrozen
+ * {@code true} if the column is the last frozen one,
+ * {@code false} otherwise
+ */
public void setColumnLastFrozen(int column, boolean lastFrozen) {
toggleFrozenColumnClass(column, lastFrozen, "last-frozen");
}
+ /**
+ * Updates the freeze position for the given column.
+ *
+ * @param column
+ * the index of the column
+ * @param scrollLeft
+ * the x coordinate, in pixels
+ */
public void updateFreezePosition(int column, double scrollLeft) {
final NodeList<TableRowElement> childRows = root.getRows();
@@ -2076,6 +2199,14 @@ public class Escalator extends Widget
*/
protected abstract void reapplyDefaultRowHeights();
+ /**
+ * Updates the cells within the row to the given height.
+ *
+ * @param tr
+ * the row to update
+ * @param heightPx
+ * the height to set, in pixels
+ */
protected void reapplyRowHeight(final TableRowElement tr,
final double heightPx) {
assert heightPx >= 0 : "Height must not be negative";
@@ -2092,6 +2223,16 @@ public class Escalator extends Widget
*/
}
+ /**
+ * Updates the position of the given row to the given coordinates.
+ *
+ * @param tr
+ * the row to update
+ * @param x
+ * the x coordinate, in pixels
+ * @param y
+ * the y coordinate, in pixels
+ */
protected void setRowPosition(final TableRowElement tr, final int x,
final double y) {
positions.set(tr, x, y);
@@ -2113,6 +2254,12 @@ public class Escalator extends Widget
return positions.getTop(tr);
}
+ /**
+ * Removes the given row from the position bookkeeping.
+ *
+ * @param tr
+ * the row to remove
+ */
protected void removeRowPosition(TableRowElement tr) {
positions.remove(tr);
}
@@ -6231,7 +6378,6 @@ public class Escalator extends Widget
* Sets a new row index for this spacer. Also updates the
* bookkeeping at {@link SpacerContainer#rowIndexToSpacer}.
*/
- @SuppressWarnings("boxing")
public void setRowIndex(int rowIndex) {
SpacerImpl spacer = rowIndexToSpacer.remove(this.rowIndex);
assert this == spacer : "trying to move an unexpected spacer.";
@@ -6391,7 +6537,22 @@ public class Escalator extends Widget
}
}
- @SuppressWarnings("boxing")
+ /**
+ * @deprecated This method is no longer used by Escalator and is likely
+ * to be removed soon. Use
+ * {@link Escalator#scrollToSpacer(int, ScrollDestination, int)}
+ * instead
+ *
+ * @param spacerIndex
+ * the index of the logical row to scroll to, -1 takes the
+ * topmost spacer into account as well
+ * @param destination
+ * where the row should be aligned visually after scrolling
+ * @param padding
+ * the number pixels to place between the scrolled-to row and
+ * the viewport edge
+ */
+ @Deprecated
void scrollToSpacer(int spacerIndex, ScrollDestination destination,
int padding) {
@@ -6433,7 +6594,6 @@ public class Escalator extends Widget
* @param removedRange
* logical range of spacers to remove
*/
- @SuppressWarnings("boxing")
public void removeSpacers(Range removedRange) {
Map<Integer, SpacerImpl> removedSpacers = rowIndexToSpacer.subMap(
@@ -6497,7 +6657,6 @@ public class Escalator extends Widget
* @return the sum of all spacers from {@code logicalRowIndex} and
* onwards, or 0 if no suitable spacers were found
*/
- @SuppressWarnings("boxing")
public Collection<SpacerImpl> getSpacersForRowAndAfter(
int logicalRowIndex) {
return new ArrayList<>(
@@ -6708,7 +6867,6 @@ public class Escalator extends Widget
* a logical row index
* @return the pixels occupied by spacers up until {@code logicalIndex}
*/
- @SuppressWarnings("boxing")
public double getSpacerHeightsSumUntilIndex(int logicalIndex) {
return getHeights(
rowIndexToSpacer.headMap(logicalIndex, false).values());
@@ -6743,7 +6901,6 @@ public class Escalator extends Widget
return rowIndexToSpacer.containsKey(Integer.valueOf(rowIndex));
}
- @SuppressWarnings("boxing")
private void insertNewSpacer(int rowIndex, double height) {
if (spacerScrollerRegistration == null) {
@@ -6873,7 +7030,6 @@ public class Escalator extends Widget
return body.getRowTop(logicalIndex) + body.getDefaultRowHeight();
}
- @SuppressWarnings("boxing")
private void shiftSpacerPositionsAfterRow(int changedRowIndex,
double diffPx) {
for (SpacerImpl spacer : rowIndexToSpacer
@@ -7027,18 +7183,53 @@ public class Escalator extends Widget
this.indices = indices;
}
+ /**
+ * Returns type of the element, e.g. "header", "cell", or "spacer".
+ *
+ * @return type
+ */
public String getType() {
return type;
}
+ /**
+ * Returns how many indices there are within these arguments.
+ *
+ * @return index count
+ */
public int getIndicesLength() {
return indices.length;
}
+ /**
+ * Returns the indicated index within the indices array.
+ *
+ * @param i
+ * the index of the required member of the indices array
+ * @return the indicated index
+ */
public int getIndex(int i) {
return indices[i];
}
+ /**
+ * Returns indices that define which particular element is being
+ * targeted. If the array is empty, the target is the row container
+ * itself.
+ * <p>
+ * result[0] - index of a row element <br>
+ * result[1] - column index of a cell within that row <br>
+ * result[2..n] - child index within the previous element <br>
+ * <p>
+ * Spacer types should have exactly one index, which is for row index,
+ * and targets the spacer element of that row.
+ * <p>
+ * Editor types can have one index, which is for column index of a cell
+ * within the editor row. If no index is given, the target is the editor
+ * overlay itself.
+ *
+ * @return array of indices
+ */
public int[] getIndices() {
return Arrays.copyOf(indices, indices.length);
}
diff --git a/client/src/main/java/com/vaadin/client/widgets/Grid.java b/client/src/main/java/com/vaadin/client/widgets/Grid.java
index 3688eb32b1..3188f70b09 100755
--- a/client/src/main/java/com/vaadin/client/widgets/Grid.java
+++ b/client/src/main/java/com/vaadin/client/widgets/Grid.java
@@ -229,6 +229,7 @@ import com.vaadin.shared.util.SharedUtil;
* @since 7.4
* @author Vaadin Ltd
*/
+@SuppressWarnings("deprecation")
public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
SubPartAware, DeferredWorker, Focusable,
com.google.gwt.user.client.ui.Focusable, HasWidgets, HasEnabled {
@@ -293,11 +294,22 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return (String) content;
}
+ /**
+ * Returns the section where this cell belongs.
+ *
+ * @return the section
+ */
protected StaticSection<?> getSection() {
assert section != null;
return section;
}
+ /**
+ * Sets the section where this cell belongs. Should not be null.
+ *
+ * @param section
+ * the section to set
+ */
protected void setSection(StaticSection<?> section) {
this.section = section;
}
@@ -609,6 +621,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* @return The remaining visible cell after the merge, or the first
* cell if all columns are hidden
*/
+ @SuppressWarnings("unchecked")
public CELLTYPE join(CELLTYPE... cells) {
if (cells.length <= 1) {
throw new IllegalArgumentException(
@@ -644,6 +657,14 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return null;
}
+ /**
+ * Returns the size of the cell group for the given column. Zero if
+ * no cell group is set.
+ *
+ * @param column
+ * the column whose cell group size is being investigated
+ * @return size of the cell group, default is {@code 0}
+ */
protected int getSizeOfCellGroup(Column<?, ?> column) {
for (Entry<CELLTYPE, Set<Column<?, ?>>> entry : cellGroups
.entrySet()) {
@@ -704,22 +725,50 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return false;
}
+ /**
+ * Creates and adds a cell to this row for the given column.
+ *
+ * @param column
+ * the column that requires a new cell
+ */
protected void addCell(Column<?, ?> column) {
CELLTYPE cell = createCell();
cell.setSection(getSection());
cells.put(column, cell);
}
+ /**
+ * Removes a cell for the given column from this row.
+ *
+ * @param column
+ * the column that should have its cell reference cleared
+ */
protected void removeCell(Column<?, ?> column) {
cells.remove(column);
}
+ /**
+ * Creates a cell of a type that matches this row.
+ *
+ * @return a new cell
+ */
protected abstract CELLTYPE createCell();
+ /**
+ * Returns the section where this row belongs.
+ *
+ * @return the section
+ */
protected StaticSection<?> getSection() {
return section;
}
+ /**
+ * Sets the section where this row belongs. Should not be null.
+ *
+ * @param section
+ * the section to set
+ */
protected void setSection(StaticSection<?> section) {
this.section = section;
}
@@ -929,35 +978,74 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return rows.size();
}
+ /**
+ * Returns the current list of rows within this section.
+ *
+ * @return list of rows
+ */
protected List<ROWTYPE> getRows() {
return rows;
}
+ /**
+ * Returns how many visible rows there are within this section (all or
+ * nothing, visibility cannot be set on the row level).
+ *
+ * @return amount of visible rows
+ */
protected int getVisibleRowCount() {
return isVisible() ? getRowCount() : 0;
}
+ /**
+ * Adds cells for the given column to all the rows within this section.
+ *
+ * @param column
+ * the column that requires cells
+ */
protected void addColumn(Column<?, ?> column) {
for (ROWTYPE row : rows) {
row.addCell(column);
}
}
+ /**
+ * Removes cells for the given column from all the rows within this
+ * section.
+ *
+ * @param column
+ * the column that should have its cells removed
+ */
protected void removeColumn(Column<?, ?> column) {
for (ROWTYPE row : rows) {
row.removeCell(column);
}
}
+ /**
+ * Sets the grid this section belongs to. Should not be null.
+ *
+ * @param grid
+ * the parent grid
+ */
protected void setGrid(Grid<?> grid) {
this.grid = grid;
}
+ /**
+ * Returns the grid this section belongs to.
+ *
+ * @return the parent grid
+ */
protected Grid<?> getGrid() {
assert grid != null;
return grid;
}
+ /**
+ * Triggers column span calculation for all the rows within this section
+ * that contain spanned cells.
+ */
protected void updateColSpans() {
for (ROWTYPE row : rows) {
if (row.hasSpannedCells()) {
@@ -1077,6 +1165,16 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
private boolean isDefault = false;
+ /**
+ * Sets whether this is the default header row or not. Setting this
+ * value to {@code true} resets the cell contents for this row to column
+ * header captions. Setting this value to {@code false} doesn't update
+ * the cell contents.
+ *
+ * @param isDefault
+ * {@code true} if this row should be default header row,
+ * {@code false} otherwise
+ */
protected void setDefault(boolean isDefault) {
this.isDefault = isDefault;
if (isDefault) {
@@ -1086,6 +1184,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * Returns whether this is the default header row or not.
+ *
+ * @return {@code true} if this row is the default header row,
+ * {@code false} otherwise
+ */
public boolean isDefault() {
return isDefault;
}
@@ -1271,6 +1375,14 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
private EventCellReference<T> cell;
private boolean handled = false;
+ /**
+ * Constructs a new {@link GridEvent}.
+ *
+ * @param event
+ * a native event
+ * @param cell
+ * the cell the event targets
+ */
protected GridEvent(Event event, EventCellReference<T> cell) {
this.event = event;
this.cell = cell;
@@ -1317,6 +1429,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* marks this event as having already been handled.
*
* @param handled
+ * {@code true} if the event has already been handled,
+ * {@code false} otherwise
*/
public void setHandled(boolean handled) {
this.handled = handled;
@@ -1335,6 +1449,16 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
private final Widget editorWidget;
+ /**
+ * Constructs a new {@link EditorDomEvent}.
+ *
+ * @param event
+ * a native event
+ * @param cell
+ * the cell the event targets
+ * @param editorWidget
+ * the editor widget of that cell
+ */
protected EditorDomEvent(Event event, EventCellReference<T> cell,
Widget editorWidget) {
super(event, cell);
@@ -1390,7 +1514,17 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*/
public static class Editor<T> implements DeferredWorker {
+ /**
+ * @deprecated use {@link DefaultEditorEventHandler#KEYCODE_OPEN}
+ * instead
+ */
+ @Deprecated
public static final int KEYCODE_SHOW = KeyCodes.KEY_ENTER;
+ /**
+ * @deprecated use {@link DefaultEditorEventHandler#KEYCODE_CLOSE}
+ * instead
+ */
+ @Deprecated
public static final int KEYCODE_HIDE = KeyCodes.KEY_ESCAPE;
private static final String ERROR_CLASS_NAME = "error";
@@ -1427,8 +1561,29 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
void confirmValidity(boolean isValid);
}
+ /**
+ * The internal state options for the editor.
+ */
protected enum State {
- INACTIVE, ACTIVATING, BINDING, ACTIVE, SAVING
+ /** Editor is closed or disabled and as such not in edit mode. */
+ INACTIVE,
+ /**
+ * Editor is getting activated. If activation is successful, next
+ * state will be {@link State#BINDING} .
+ */
+ ACTIVATING,
+ /**
+ * Editor binding is being set up. If binding is successful, next
+ * state will be {@link State#ACTIVE}.
+ */
+ BINDING,
+ /** Editor is open and enabled and in edit mode. */
+ ACTIVE,
+ /**
+ * Editor is saving changes. If saving is successful, state will be
+ * updated to {@link State#INACTIVE}.
+ */
+ SAVING
}
private Grid<T> grid;
@@ -1554,6 +1709,9 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
private double originalScrollTop;
private RowHandle<T> pinnedRowHandle;
+ /**
+ * Constructs a new {@link Editor}.
+ */
public Editor() {
saveButton = new Button();
saveButton.setText(GridConstants.DEFAULT_SAVE_CAPTION);
@@ -1570,6 +1728,19 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
});
}
+ /**
+ * Sets an error message for the editor, or removes it if the given
+ * message is {@code null}. If the editor is in edit mode or currently
+ * processing a save operation, updates the editor cells to show error
+ * styles for the given columns and clears error styles from any other
+ * columns.
+ *
+ * @param errorMessage
+ * the message to set, or {@code null} if no message should
+ * be shown
+ * @param errorColumns
+ * the columns that currently contain errors
+ */
public void setEditorError(String errorMessage,
Collection<Column<?, T>> errorColumns) {
@@ -1594,6 +1765,14 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * Returns the index of the row that is currently assigned to the
+ * editor. If the editor is open and in the edit mode, that row's
+ * contents can be edited via the editor cells. -1 if the editor is
+ * closed.
+ *
+ * @return currently assigned row index, or -1 if not set
+ */
public int getRow() {
return rowIndex;
}
@@ -1606,6 +1785,9 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* If a Grid cell was not focused prior to calling this method, it will
* be equivalent to {@code editRow(rowIndex, -1)}.
*
+ * @param rowIndex
+ * the index of the row to be edited
+ *
* @see #editRow(int, int)
*/
public void editRow(int rowIndex) {
@@ -1813,6 +1995,11 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
handler = rowHandler;
}
+ /**
+ * Returns the enabled state of this editor.
+ *
+ * @return {@code true} if enabled, {@code false} otherwise
+ */
public boolean isEnabled() {
return enabled;
}
@@ -1821,7 +2008,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* Sets the enabled state of this editor.
*
* @param enabled
- * true if enabled, false otherwise
+ * {@code true} if enabled, {@code false} otherwise
*
* @throws IllegalStateException
* if in edit mode and trying to disable
@@ -1839,6 +2026,17 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
this.enabled = enabled;
}
+ /**
+ * If the Editor is still activating, proceeds to the binding phase.
+ * Otherwise does nothing.
+ *
+ * @param rowIndex
+ * the index of the row to be edited
+ * @param columnIndex
+ * the column index (excluding hidden columns) of the editor
+ * widget that should be initially focused or -1 to not set
+ * focus
+ */
protected void show(int rowIndex, int columnIndex) {
if (state == State.ACTIVATING) {
state = State.BINDING;
@@ -1852,6 +2050,13 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * Sets the grid this editor belongs to. Should not be null. Should only
+ * be called once.
+ *
+ * @param grid
+ * the parent grid
+ */
protected void setGrid(final Grid<T> grid) {
assert grid != null : "Grid cannot be null";
assert this.grid == null : "Can only attach editor to Grid once";
@@ -1859,10 +2064,21 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
this.grid = grid;
}
+ /**
+ * Returns the internal state of the editor.
+ *
+ * @return the state
+ */
protected State getState() {
return state;
}
+ /**
+ * Sets the internal state of the editor.
+ *
+ * @param state
+ * the state to set
+ */
protected void setState(State state) {
this.state = state;
}
@@ -1895,7 +2111,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
/**
- * Opens the editor overlay over the table row indicated by
+ * Opens the editor overlay over the grid row indicated by
* {@link #getRow()}.
*
* @since 7.5
@@ -2098,6 +2314,9 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return bottomOfButtons < tfootPageTop;
}
+ /**
+ * Hides the editor overlay and clears its contents.
+ */
protected void hideOverlay() {
if (editorOverlay.getParentElement() == null) {
return;
@@ -2143,6 +2362,13 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * Sets the editor's primary style name and updates all dependent style
+ * names.
+ *
+ * @param primaryName
+ * the new primary style name
+ */
protected void setStylePrimaryName(String primaryName) {
if (styleName != null) {
editorOverlay.removeClassName(styleName);
@@ -2239,6 +2465,15 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
editorOverlay.getStyle().setTop(newTop, Unit.PX);
}
+ /**
+ * Sets the editor's buttons enabled. Does not update the enabled status
+ * of the grid this editor belongs to, nor ask the enabled status from
+ * it.
+ *
+ * @param enabled
+ * {@code true} to enable the buttons, {@code false} to
+ * disable them
+ */
protected void setGridEnabled(boolean enabled) {
// TODO: This should be informed to handler as well so possible
// fields can be disabled.
@@ -2250,6 +2485,14 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
cancelButton.setEnabled(enabled);
}
+ /**
+ * Sets the caption of the save button. Should not be {@code null}.
+ *
+ * @param saveCaption
+ * the new caption text
+ * @throws IllegalArgumentException
+ * if the given text is {@code null}
+ */
public void setSaveCaption(String saveCaption)
throws IllegalArgumentException {
if (saveCaption == null) {
@@ -2259,10 +2502,23 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
saveButton.setText(saveCaption);
}
+ /**
+ * Returns the caption of the save button.
+ *
+ * @return the caption text
+ */
public String getSaveCaption() {
return saveButton.getText();
}
+ /**
+ * Sets the caption of the cancel button. Should not be {@code null}.
+ *
+ * @param cancelCaption
+ * the new caption text
+ * @throws IllegalArgumentException
+ * if the given text is {@code null}
+ */
public void setCancelCaption(String cancelCaption)
throws IllegalArgumentException {
if (cancelCaption == null) {
@@ -2272,10 +2528,29 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
cancelButton.setText(cancelCaption);
}
+ /**
+ * Returns the caption of the cancel button.
+ *
+ * @return the caption text
+ */
public String getCancelCaption() {
return cancelButton.getText();
}
+ /**
+ * If the given column is indicated to have an error in the editor, sets
+ * the error styles to the corresponding editor cell and lists the
+ * column as having an error. Otherwise removes the error styles from
+ * the cell and removes the column from the error collection.
+ *
+ * @param column
+ * the column which should have its editor error status
+ * updated
+ * @param hasError
+ * {@code true} if the cell should get error styles,
+ * {@code false} if the error styles should be removed from
+ * the cell
+ */
public void setEditorColumnError(Column<?, T> column,
boolean hasError) {
if (state != State.ACTIVE && state != State.SAVING) {
@@ -2298,6 +2573,10 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * Clears all editor error styles from the editor cells and clears the
+ * error column collection.
+ */
public void clearEditorColumnErrors() {
/*
@@ -2313,15 +2592,39 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
columnErrors.clear();
}
+ /**
+ * Returns true if the column has been listed as containing an error.
+ *
+ * @param column
+ * the column whose error status is checked
+ * @return {@code true} if the column is listed as containing an error,
+ * {@code false} otherwise
+ */
public boolean isEditorColumnError(Column<?, T> column) {
return columnErrors.contains(column);
}
+ /**
+ * Sets the buffered mode. When the editor is in buffered mode, edits
+ * are only committed when the user clicks the save button. In
+ * unbuffered mode valid changes are automatically committed.
+ *
+ * @param buffered
+ * {@code true} if editor should be buffered, {@code false}
+ * otherwise
+ */
public void setBuffered(boolean buffered) {
this.buffered = buffered;
setMessageAndButtonsWrapperVisible(buffered);
}
+ /**
+ * Returns whether this editor is buffered or not.
+ *
+ * @return {@code true} if editor is buffered, {@code false} otherwise
+ *
+ * @see #setBuffered(boolean)
+ */
public boolean isBuffered() {
return buffered;
}
@@ -2360,6 +2663,15 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return saveTimeout.isRunning() || bindTimeout.isRunning();
}
+ /**
+ * Returns the column index of the editor cell that contains the given
+ * element, or -1 if the element can't be found within the editor cells.
+ *
+ * @param e
+ * the element to be located
+ * @return the column index of the associated editor cell, or -1 if not
+ * found
+ */
protected int getElementColumn(Element e) {
int frozenCells = frozenCellWrapper.getChildCount();
if (frozenCellWrapper.isOrHasChild(e)) {
@@ -2382,6 +2694,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * Event class for key events that happen within the grid.
+ *
+ * @param <HANDLER>
+ * the event handler type
+ */
public abstract static class AbstractGridKeyEvent<HANDLER extends AbstractGridKeyEventHandler>
extends KeyEvent<HANDLER> {
@@ -2392,6 +2710,11 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
/**
+ * @param grid
+ * the grid where the event occurred
+ * @param targetCell
+ * the cell that the event targeted
+ *
* @deprecated This constructor's arguments are no longer used. Use the
* no-args constructor instead.
*/
@@ -2399,6 +2722,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
public AbstractGridKeyEvent(Grid<?> grid, CellReference<?> targetCell) {
}
+ /**
+ * Returns the {@link BrowserEvents} type that corresponds with this
+ * event.
+ *
+ * @return the browser event type
+ */
protected abstract String getBrowserEventType();
/**
@@ -2463,9 +2792,24 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * The given handler processes the event if the handler type matches the
+ * given section.
+ *
+ * @param handler
+ * handler
+ * @param section
+ * the section where the target element is located
+ */
protected abstract void doDispatch(HANDLER handler, Section section);
}
+ /**
+ * Event class for mouse events that happen within the grid.
+ *
+ * @param <HANDLER>
+ * the event handler type
+ */
public abstract static class AbstractGridMouseEvent<HANDLER extends AbstractGridMouseEventHandler>
extends MouseEvent<HANDLER> {
@@ -2476,6 +2820,11 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
/**
+ * @param grid
+ * the grid where the event occurred
+ * @param targetCell
+ * the cell that the event targeted
+ *
* @deprecated This constructor's arguments are no longer used. Use the
* no-args constructor instead.
*/
@@ -2484,6 +2833,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
CellReference<?> targetCell) {
}
+ /**
+ * Returns the {@link BrowserEvents} type that corresponds with this
+ * event.
+ *
+ * @return the browser event type
+ */
protected abstract String getBrowserEventType();
/**
@@ -2584,6 +2939,15 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return childWidget && !handleWidgetEvent;
}
+ /**
+ * The given handler processes the event if the handler type matches the
+ * given section.
+ *
+ * @param handler
+ * handler
+ * @param section
+ * the section where the target element is located
+ */
protected abstract void doDispatch(HANDLER handler, Section section);
}
@@ -2599,6 +2963,10 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
private EventCellReference<T> eventCell = new EventCellReference<T>(this);
+ /**
+ * Focus handler for Grid's cells. Updates focus style names and handles
+ * focus scrolling.
+ */
private class CellFocusHandler {
private RowContainer containerWithFocus = escalator.getBody();
@@ -3018,6 +3386,11 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * A column that contains CheckBoxes for representing Grid's row selection.
+ * By default only used with MultiSelectionModel.
+ *
+ */
public final class SelectionColumn extends Column<Boolean, T>
implements GridEnabledHandler, GridSelectionAllowedHandler {
@@ -3378,7 +3751,6 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*/
private class AutoColumnWidthsRecalculator {
private double lastCalculatedInnerWidth = -1;
- private double lastCalculatedInnerHeight = -1;
private final ScheduledCommand calculateCommand = new ScheduledCommand() {
@@ -3471,7 +3843,6 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
// Update latest width to prevent recalculate on height change.
lastCalculatedInnerWidth = escalator.getInnerWidth();
- lastCalculatedInnerHeight = escalator.getInnerHeight();
}
private boolean columnsAreGuaranteedToBeWiderThanGrid() {
@@ -3503,7 +3874,6 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return freeSpace < 0;
}
- @SuppressWarnings("boxing")
private void applyColumnWidths() {
/* Step 1: Apply all column widths as they are. */
@@ -4394,6 +4764,10 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*/
private SelectionModel<T> selectionModel;
+ /**
+ * Focus handler for Grid's cells. Updates focus style names and handles
+ * focus scrolling.
+ */
protected final CellFocusHandler cellFocusHandler;
private final UserSorter sorter = new UserSorter();
@@ -4449,6 +4823,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
private RowStyleGenerator<T> rowStyleGenerator;
private RowReference<T> rowReference = new RowReference<>(this);
private CellReference<T> cellReference = new CellReference<>(rowReference);
+ @SuppressWarnings("unchecked")
private RendererCellReference rendererCellReference = new RendererCellReference(
(RowReference<Object>) rowReference);
@@ -4722,13 +5097,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
.indexOf(getVisibleColumn(focusedCell.getColumn()));
}
+ @SuppressWarnings("unchecked")
Column<?, T>[] array = reordered
.toArray(new Column[reordered.size()]);
setColumnOrder(true, array);
transferCellFocusOnDrop();
- } // else
- // no
- // reordering
+ } // else no reordering
}
private void transferCellFocusOnDrop() {
@@ -4794,7 +5168,6 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
- @SuppressWarnings("boxing")
private void calculatePossibleDropPositions() {
possibleDropPositions.clear();
@@ -5195,7 +5568,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
// Complex renderers need to be destroyed.
if (bodyRenderer instanceof ComplexRenderer) {
- ((ComplexRenderer) bodyRenderer).destroy();
+ ((ComplexRenderer<? super C>) bodyRenderer).destroy();
}
bodyRenderer = renderer;
@@ -5790,6 +6163,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
+ /**
+ * EscalatorUpdater implementation for Grid's body section.
+ *
+ * @see EscalatorUpdater
+ *
+ */
protected class BodyUpdater implements EscalatorUpdater {
@Override
@@ -5848,6 +6227,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
@Override
+ @SuppressWarnings("unchecked")
public void update(Row row, Iterable<FlyweightCell> cellsToUpdate) {
int rowIndex = row.getRow();
TableRowElement rowElement = row.getElement();
@@ -5934,13 +6314,15 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
setCustomStyleName(cell.getElement(), null);
}
+ @SuppressWarnings("rawtypes")
Renderer renderer = column.getRenderer();
try {
rendererCellReference.set(cell, columnIndex, column);
if (renderer instanceof ComplexRenderer) {
// Hide cell content if needed
- ComplexRenderer clxRenderer = (ComplexRenderer) renderer;
+ @SuppressWarnings("rawtypes")
+ ComplexRenderer clxRenderer = (ComplexRenderer<?>) renderer;
if (hasData) {
if (!usedToHaveData) {
// Prepare cell for rendering
@@ -6015,7 +6397,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
cell.getColumn());
rendererCellReference.set(cell,
getColumns().indexOf(column), column);
- ((ComplexRenderer) renderer)
+ ((ComplexRenderer<?>) renderer)
.destroy(rendererCellReference);
} catch (RuntimeException e) {
getLogger().log(Level.SEVERE,
@@ -6028,11 +6410,26 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * EscalatorUpdater implementation for Grid's static sections (header and
+ * footer).
+ *
+ * @see EscalatorUpdater
+ *
+ */
protected class StaticSectionUpdater implements EscalatorUpdater {
private StaticSection<?> section;
private RowContainer container;
+ /**
+ * Constructs an updater instance for the given section.
+ *
+ * @param section
+ * the section that needs an updater
+ * @param container
+ * the row container of the given section
+ */
public StaticSectionUpdater(StaticSection<?> section,
RowContainer container) {
super();
@@ -6069,7 +6466,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
// Wrap text or html content in default header to isolate
// the content from the possible column resize drag handle
// next to it
- if (metadata.getType() != GridStaticCellType.WIDGET) {
+ GridStaticCellType metaDataType = metadata.getType();
+ if (metaDataType != GridStaticCellType.WIDGET) {
content = DOM.createDiv();
if (staticRow instanceof HeaderRow) {
@@ -6093,7 +6491,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
content = td;
}
- switch (metadata.getType()) {
+ switch (metaDataType) {
case TEXT:
content.setInnerText(metadata.getText());
break;
@@ -6105,6 +6503,11 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
content.setInnerHTML("");
postAttach(row, Arrays.asList(cell));
break;
+ default:
+ getLogger().severe("Unhandled metadata type: "
+ + (metaDataType == null ? "null"
+ : metaDataType.name()));
+ break;
}
// XXX: Should add only once in preAttach/postAttach or when
@@ -6437,6 +6840,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
}
+ /**
+ * Returns the Grid instance for this updater.
+ *
+ * @return the grid that is being updated
+ */
+ @SuppressWarnings("rawtypes")
protected Grid getGrid() {
return section.grid;
}
@@ -6770,6 +7179,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* @param columns
* the columns to add
*/
+ @SuppressWarnings("unchecked")
public void addColumns(Column<?, T>... columns) {
if (columns.length == 0) {
// Nothing to add.
@@ -6782,6 +7192,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
/**
* Adds a column as the last column in the grid.
*
+ * @param <C>
+ * class that extends Column
* @param column
* the column to add
* @return given column
@@ -6794,10 +7206,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
/**
* Inserts a column into a specific position in the grid.
*
- * @param index
- * the index where the column should be inserted into
+ * @param <C>
+ * class that extends Column
* @param column
* the column to add
+ * @param index
+ * the index where the column should be inserted into
* @return given column
*
* @throws IllegalStateException
@@ -7279,6 +7693,11 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return footer.isVisible();
}
+ /**
+ * Returns the {@link Editor} for this Grid.
+ *
+ * @return editor
+ */
public Editor<T> getEditor() {
return editor;
}
@@ -7528,6 +7947,15 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
return frozenColumnCount;
}
+ /**
+ * Adds an event handler that gets notified when the range of visible rows
+ * changes e.g. because of scrolling, row resizing or spacers
+ * appearing/disappearing.
+ *
+ * @param handler
+ * the event handler
+ * @return a handler registration for the added handler
+ */
public HandlerRegistration addRowVisibilityChangeHandler(
RowVisibilityChangeHandler handler) {
/*
@@ -8284,7 +8712,6 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
};
@Override
- @SuppressWarnings("deprecation")
public com.google.gwt.user.client.Element getSubPartElement(
String subPart) {
@@ -8356,7 +8783,6 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
}
@Override
- @SuppressWarnings("deprecation")
public String getSubPartName(
com.google.gwt.user.client.Element subElement) {
@@ -8554,6 +8980,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
/**
* Sorts the Grid data in ascending order along one column.
*
+ * @param <C>
+ * the column type
* @param column
* a grid column reference
*/
@@ -8564,6 +8992,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
/**
* Sorts the Grid data along one column.
*
+ * @param <C>
+ * the column type
* @param column
* a grid column reference
* @param direction
@@ -8630,7 +9060,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* a sort event handler
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addSortHandler(SortHandler<T> handler) {
return addHandler(handler, SortEvent.getType());
@@ -8646,7 +9076,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* a select all event handler
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addSelectAllHandler(
SelectAllHandler<T> handler) {
@@ -8665,7 +9095,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* a data available event handler
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addDataAvailableHandler(
final DataAvailableHandler handler) {
@@ -8686,7 +9116,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the key handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addBodyKeyDownHandler(
BodyKeyDownHandler handler) {
@@ -8700,7 +9130,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the key handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addBodyKeyUpHandler(BodyKeyUpHandler handler) {
return addHandler(handler, GridKeyUpEvent.TYPE);
@@ -8713,7 +9143,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the key handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addBodyKeyPressHandler(
BodyKeyPressHandler handler) {
@@ -8727,7 +9157,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the key handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addHeaderKeyDownHandler(
HeaderKeyDownHandler handler) {
@@ -8741,7 +9171,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the key handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addHeaderKeyUpHandler(
HeaderKeyUpHandler handler) {
@@ -8755,7 +9185,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the key handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addHeaderKeyPressHandler(
HeaderKeyPressHandler handler) {
@@ -8769,7 +9199,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the key handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addFooterKeyDownHandler(
FooterKeyDownHandler handler) {
@@ -8783,7 +9213,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the key handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addFooterKeyUpHandler(
FooterKeyUpHandler handler) {
@@ -8797,7 +9227,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the key handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addFooterKeyPressHandler(
FooterKeyPressHandler handler) {
@@ -8810,7 +9240,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the click handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addBodyClickHandler(BodyClickHandler handler) {
return addHandler(handler, GridClickEvent.TYPE);
@@ -8822,7 +9252,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the click handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addHeaderClickHandler(
HeaderClickHandler handler) {
@@ -8835,7 +9265,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the click handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addFooterClickHandler(
FooterClickHandler handler) {
@@ -8849,7 +9279,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the double click handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addBodyDoubleClickHandler(
BodyDoubleClickHandler handler) {
@@ -8863,7 +9293,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the double click handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addHeaderDoubleClickHandler(
HeaderDoubleClickHandler handler) {
@@ -8877,7 +9307,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the double click handler to register
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addFooterDoubleClickHandler(
FooterDoubleClickHandler handler) {
@@ -8891,7 +9321,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* @since 7.5.0
* @param handler
* the handler for the event
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addColumnReorderHandler(
ColumnReorderHandler<T> handler) {
@@ -8905,7 +9335,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* @since 7.5.0
* @param handler
* the handler for the event
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addColumnVisibilityChangeHandler(
ColumnVisibilityChangeHandler<T> handler) {
@@ -8919,7 +9349,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* @since 7.6
* @param handler
* the handler for the event
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addColumnResizeHandler(
ColumnResizeHandler<T> handler) {
@@ -8933,7 +9363,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the handler for the event
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addEnabledHandler(GridEnabledHandler handler) {
return addHandler(handler, GridEnabledEvent.TYPE);
@@ -8946,13 +9376,22 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param handler
* the handler for the event
- * @return the registration for the event
+ * @return the registration for the handler
*/
public HandlerRegistration addSelectionAllowedHandler(
GridSelectionAllowedHandler handler) {
return addHandler(handler, GridSelectionAllowedEvent.TYPE);
}
+ /**
+ * Register a row height changed handler to this Grid. The event for this
+ * handler is fired when the row height is changed in the Grid's header,
+ * body or footer.
+ *
+ * @param handler
+ * the handler for the event
+ * @return the registration for the handler
+ */
public HandlerRegistration addRowHeightChangedHandler(
RowHeightChangedHandler handler) {
return escalator.addHandler(handler, RowHeightChangedEvent.TYPE);
@@ -9081,10 +9520,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* @param orderedColumns
* array of columns in wanted order
*/
+ @SuppressWarnings("unchecked")
public void setColumnOrder(Column<?, T>... orderedColumns) {
setColumnOrder(false, orderedColumns);
}
+ @SuppressWarnings("unchecked")
private void setColumnOrder(boolean isUserOriginated,
Column<?, T>... orderedColumns) {
List<Column<?, T>> newOrder = new ArrayList<>();