summaryrefslogtreecommitdiffstats
path: root/vaadin-grid/vaadin-grid.html
diff options
context:
space:
mode:
Diffstat (limited to 'vaadin-grid/vaadin-grid.html')
-rw-r--r--vaadin-grid/vaadin-grid.html808
1 files changed, 391 insertions, 417 deletions
diff --git a/vaadin-grid/vaadin-grid.html b/vaadin-grid/vaadin-grid.html
index 5a545bf..1b147be 100644
--- a/vaadin-grid/vaadin-grid.html
+++ b/vaadin-grid/vaadin-grid.html
@@ -2,8 +2,8 @@
@element v-grid
-->
-<link rel='import' href='vaadin-grid-import.html'>
<link rel='import' href='../../polymer/polymer.html'>
+<script type="text/javascript" language="javascript" src="VaadinGridImport.nocache.js"></script>
<style>
v-grid > table {
@@ -12,247 +12,338 @@
</style>
<!--
-Vaadin v-grid is a grid component fully configurable and customizable, plenty of features and with the mind set on performance.
+Data grid for showing large amounts of tabular data.
+
+Basic usage:
+```html
+<v-grid>
+ <table>
+ <colgroup>
+ <col header-text="Name">
+ <col header-text="Value">
+ <col header-text="Progress">
+ </colgroup>
+ <tbody>
+ <tr>
+ <td>Project A</td><td>10000</td><td>0.8</td>
+ </tr>
+ <tr>
+ <td>Project B</td><td>999999</td><td>0.8</td>
+ </tr>
+ </tbody>
+ </table>
+</v-grid>
+```
+
+More examples available at http://vaadin.github.io/components-examples/v-grid/
-->
<dom-module id="v-grid">
<style>
- /* Functional properties */
-
+ /* Host styles */
:host {
- white-space: nowrap;
-webkit-tap-highlight-color: transparent;
-webkit-touch-callout: none;
- transition: opacity 200ms;
+ box-sizing: border-box;
+ display: block;
+ font: 400 13px/1.1 Roboto, sans-serif;
+ color: rgba(0, 0, 0, 0.87);
cursor: default;
+ transition: opacity 200ms;
+ white-space: nowrap;
}
- :host(.loading) {
- opacity: 0;
+ :host(.v-grid-loading) {
height: 0;
+ opacity: 0;
transition: none;
}
- :host,
- .v-grid-tablewrapper > table,
- .v-grid-body,
- .v-grid-header,
- .v-grid-footer,
- .v-grid-row {
- display: block;
- box-sizing: border-box;
+ :host > div {
+ height: 100%;
+ outline: none;
+ position: relative;
}
- .v-grid-cell {
- display: -webkit-inline-flex;
- display: inline-flex;
- -webkit-align-items: center;
- align-items: center;
+ /* Anim */
+ @keyframes v-grid-spin-360 {
+ 100% {
+ transform: rotate(360deg);
+ }
+ }
+
+ @-webkit-keyframes v-grid-spin-360 {
+ 100% {
+ -webkit-transform: rotate(360deg);
+ transform: rotate(360deg);
+ }
+ }
+
+ /* Table wrapper */
+ .v-grid-tablewrapper {
box-sizing: border-box;
overflow: hidden;
- text-overflow: ellipsis;
- background: #fff;
+ outline: none;
+ position: absolute;
+ z-index: 5;
}
- :host > div {
- position: relative;
- outline: none;
+ .v-grid-tablewrapper:before {
+ display: none;
}
+ .v-grid-tablewrapper > table {
+ box-sizing: border-box;
+ display: block;
+ }
+
+ .v-grid-loading-data .v-grid-tablewrapper:before {
+ -webkit-animation: v-grid-spin-360 400ms linear infinite;
+ animation: v-grid-spin-360 400ms linear infinite;
+ border: 2px solid #03A9F4;
+ border-radius: 50%;
+ border-right-color: transparent;
+ border-top-color: transparent;
+ content: "";
+ display: block;
+ height: 16px;
+ left: 50%;
+ margin-left: -8px;
+ margin-top: -8px;
+ position: absolute;
+ top: 50%;
+ width: 16px;
+ }
+
+ /* Scroller styles */
.v-grid-scroller {
+ box-sizing: border-box;
+ outline: none;
position: absolute;
z-index: 1;
- outline: none;
- box-sizing: border-box;
}
.v-grid-scroller-horizontal {
+ bottom: 0;
left: 0;
right: 0;
- bottom: 0;
overflow-y: hidden;
-ms-overflow-y: hidden;
}
.v-grid-scroller-vertical {
+ bottom: 0;
right: 0;
top: 0;
- bottom: 0;
overflow-x: hidden;
-ms-overflow-x: hidden;
}
- .v-grid-tablewrapper {
- position: absolute;
- overflow: hidden;
- box-sizing: border-box;
- z-index: 5;
- outline: none;
- }
-
- .v-grid-header-deco,
- .v-grid-footer-deco,
.v-grid-horizontal-scrollbar-deco {
+ bottom: 0;
+ box-sizing: border-box;
+ left: 0;
position: absolute;
right: 0;
- box-sizing: border-box;
}
- .v-grid-header,
- .v-grid-body,
- .v-grid-footer {
- position: absolute;
+ /* Grid body */
+ .v-grid-body {
+ box-sizing: border-box;
+ display: block;
left: 0;
- z-index: 10;
+ position: absolute;
+ top: 0;
+ z-index: 0;
}
- .v-grid-header,
- .v-grid-header-deco {
+ :host(:not([selection-mode])) .v-grid-body,
+ :host([selection-mode="single"]) .v-grid-body {
+ cursor: pointer;
+ }
+
+ .v-grid-body tr {
+ height: 48px;
+ left: 0;
top: 0;
+ position: absolute;
}
- .v-grid-footer,
- .v-grid-footer-deco {
- bottom: 0;
+ .v-grid-body td {
+ opacity: 0;
}
- .v-grid-horizontal-scrollbar-deco {
- left: 0;
- bottom: 0;
+ .v-grid-row-has-data td {
+ border-bottom: 1px solid #e3e3e3;
+ opacity: 1;
}
- .v-grid-body {
- z-index: 0;
- top: 0;
+ /* Row styles */
+ .v-grid-row {
+ box-sizing: border-box;
+ display: block;
}
- .v-grid-body .v-grid-row {
- position: absolute;
- top: 0;
- left: 0;
+ .v-grid-row:hover td {
+ background-color: #eeeeee;
}
- :host(:not([selection-mode])) .v-grid-body,
- :host([selection-mode="single"]) .v-grid-body {
- cursor: pointer;
+ .v-grid-row-selected td {
+ background-color: #f5f5f5;
}
- .v-grid-editor {
- position: absolute;
- z-index: 20;
- overflow: hidden;
+ /* Focus styles */
+ .v-grid-row:after {
+ background-color: #03A9F4;
+ bottom: 0;
+ content: "";
+ height: 2px;
left: 0;
+ pointer-events: none;
+ position: absolute;
right: 0;
- margin-top: -1px;
+ transition: all 0.16s ease-in-out;
+ -webkit-transform: scaleX(0.0);
+ transform: scaleX(0.0);
+ z-index: 1;
}
- .v-grid-editor-cells {
- position: relative;
+ :focus .v-grid-row-focused:after {
+ -webkit-transform: scaleX(1.0);
+ transform: scaleX(1.0);
}
- .v-grid-editor-cells > div {
- display: inline-block;
+ :focus .v-grid-row-focused {
+ -webkit-animation: v-grid-row-focused 820ms ease-in-out;
+ animation: v-grid-row-focused 820ms ease-in-out;
}
- .v-grid-editor-footer {
- display: -webkit-flex;
- display: flex;
- -webkit-align-items: center;
- align-items: center;
- box-sizing: border-box;
+ @-webkit-keyframes v-grid-row-focused {
+ 50% {
+ color: #03A9F4;
+ } 100% {
+ color: inherit;
+ }
}
- .v-grid-editor-message {
- -webkit-flex: 1;
- flex: 1;
+ @keyframes v-grid-row-focused {
+ 50% {
+ color: #03A9F4;
+ } 100% {
+ color: inherit;
+ }
}
- /* Theming properties */
-
- :host {
- font: 400 100%/1.1 Roboto, sans-serif;
- color: rgba(0, 0, 0, 0.83);
+ /* Grid cell */
+ .v-grid-cell {
+ -webkit-align-items: center;
+ align-items: center;
+ background-color: white;
+ box-sizing: border-box;
+ display: -webkit-inline-flex;
+ display: inline-flex;
+ height: inherit;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ transition: opacity 0.1s ease-in;
}
- .v-grid-cell {
- padding: 0 16px;
- height: 32px;
+ /* Grid header */
+ .v-grid-header {
+ box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
+ box-sizing: border-box;
+ display: block;
+ left: 0;
+ position: absolute;
+ top: 0;
+ z-index: 10;
}
- .v-grid-header,
- .v-grid-header-deco {
- box-shadow: 0px 3px 2px 0px rgba(0, 0, 0, 0.20);
+ .v-grid-header tr {
+ color: rgba(0, 0, 0, 0.54);
+ font-size: 12px;
+ height: 56px;
}
.v-grid-header th {
- background: #03A9F4;
- color: #fff;
- text-transform: uppercase;
- font-weight: 600;
- font-size: 0.8125em;
- height: 32px;
- border-right: 1px solid rgba(255, 255, 255, 0.3);
- border-bottom: 1px solid rgba(255, 255, 255, 0.3);
+ font-weight: 500;
}
.v-grid-header-deco {
- background: #03A9F4;
+ background-color: white;
border-left: 1px solid rgba(255, 255, 255, 0.3);
+ box-sizing: border-box;
+ position: absolute;
+ right: 0;
+ top: 0;
z-index: 1;
}
+ /* Sorting */
.v-grid-header [class*="sort-"] {
+ font-weight: 500;
+ font-size: 12px;
+ color: rgba(0, 0, 0, 0.87);
position: relative;
- padding-right: 32px;
}
.v-grid-header [class*="sort-"]:after {
- position: absolute;
- font-family: sans-serif;
- content: url(sort-asc.svg) " " attr(sort-order);
- right: 12px;
- font-size: 12px;
- width: 11px;
- height: 5px;
+ font-size: 8px;
+ padding-left: 8px;
}
- .v-grid-header .sort-desc:after {
- content: url(sort-desc.svg) " " attr(sort-order);
+ .v-grid-header .sort-asc:after {
+ content: url(arrow-up.svg) " " attr(sort-order);
}
- .v-grid-header [class*="sort-"][sort-order]:after {
- right: 20px;
+ .v-grid-header .sort-desc:after {
+ content: url(arrow-down.svg) " " attr(sort-order);
}
- .v-grid-footer td,
- .v-grid-footer-deco,
- .v-grid-horizontal-scrollbar-deco {
- background: #E6E6E6;
- font-size: 0.8125em;
- font-weight: 500;
- color: rgba(0, 0, 0, 0.56);
+ /* Grid footer */
+ .v-grid-footer {
+ bottom: 0;
+ box-sizing: border-box;
+ display: block;
+ left: 0;
+ position: absolute;
+ z-index: 10;
}
.v-grid-footer td {
- border-right: 1px solid rgba(255, 255, 255, 0.5);
- border-bottom: 1px solid rgba(255, 255, 255, 0.5);
+ font-size: 12px;
+ font-weight: 500;
+ color: rgba(0, 0, 0, 0.56);
+ height: 56px;
}
.v-grid-footer-deco {
- border-left: 1px solid rgba(255, 255, 255, 0.5);
- }
-
- .v-grid-horizontal-scrollbar-deco {
- border-top: 1px solid rgba(255, 255, 255, 0.5);
+ bottom: 0;
+ box-sizing: border-box;
+ position: absolute;
+ right: 0;
+ z-index: 1;
}
- .v-grid-header th:last-child,
- .v-grid-footer td:last-child {
- border-right: 0;
+ /* Cell padding */
+ .v-grid-header th,
+ .v-grid-body td,
+ .v-grid-footer td {
+ /* Google Material Design specifies 56dp inbetween columns.
+ Columns are as wide as their widest item. This approach
+ might not be applicable for us, as we allow column expand
+ ratio, etc. Options 1, 2 and 3 listed below. */
+ /* Divide padding equally among cells. */
+ padding: 0 24px 0 24px;
+ /* Put all padding on right side.
+ padding: 0 56px 0 0; */
+ /* No padding, allow users to specify expand ratio.
+ padding: 0; */
}
- .v-grid-header tr:last-child th,
- .v-grid-footer tr:last-child td {
- border-bottom: 0;
+ .v-grid-header th.frozen,
+ .v-grid-body td.frozen,
+ .v-grid-footer td.frozen {
+ border-right: 1px solid #e3e3e3;
}
/* TODO We need some other way of defining the frozen column divider than
@@ -264,81 +355,9 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
.v-grid-cell.frozen.frozen {
position: relative;
z-index: 1;
- border-right: 0;
- box-shadow: 1px 0 0 0 rgba(0,0,0,0.04),
- 2px 0 0 0 rgba(0,0,0,0.04),
- 3px 0 0 0 rgba(0,0,0,0.04),
- 4px 0 0 0 rgba(0,0,0,0.04);
- }
-
- .v-grid-row-selected > td {
- background-color: #f2f2f2;
- }
-
- .v-grid-editor {
- background: #fff;
- box-shadow: 0 0 0 1px rgba(0,0,0,0.15),
- 0 8px 17px 0 rgba(0,0,0,0.2),
- 0 6px 20px 0 rgba(0,0,0,0.188235);
- margin-top: -5px;
- }
-
- .v-grid-editor[style*="bottom"] {
- margin-top: 0;
- margin-bottom: -5px;
- }
-
- .v-grid-editor input[type="text"],
- .v-grid-editor input:not([type]) {
- box-sizing: border-box;
- width: 100%;
- height: 100%;
- padding: 0 0 1px;
- font: inherit;
- color: inherit;
- border: 0;
- border-bottom: 1px solid rgba(0,0,0,0.2);
- background: transparent;
- outline: none;
- transition: all 200ms;
- }
-
- .v-grid-editor input[type="text"]:focus {
- border-bottom: 2px solid #03A9F4;
- padding-bottom: 0;
- }
-
- .v-grid-editor-cells > div {
- box-sizing: border-box;
- margin: 5px 0;
- padding: 5px 16px;
- height: 42px;
- }
-
- .v-grid-editor-buttons button {
- height: 32px;
- padding: 0 11px;
- margin: 5px;
- font: inherit;
- font-size: 14px;
- color: #03A9F4;
- text-transform: uppercase;
- background: transparent;
- border: 0;
- border-radius: 3px;
- outline: none;
- cursor: pointer;
- transition: all 200ms;
- }
-
- .v-grid-editor-buttons button:focus {
- box-shadow: 0 2px 6px 0 rgba(0,0,0,0.5);
- }
-
- .v-grid-editor-buttons button:active:focus {
- box-shadow: none;
}
+ /* Input styles */
input[type="checkbox"] {
position: absolute;
opacity: 0;
@@ -349,9 +368,9 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
left: 0;
box-sizing: border-box;
display: block;
- width: 16px;
- height: 16px;
- border: 2px solid rgba(0,0,0,0.3);
+ width: 18px;
+ height: 18px;
+ border: 2px solid #7a7a7a;
border-radius: 2px;
cursor: pointer;
transition: background-color 120ms, border-color 120ms;
@@ -361,18 +380,14 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
outline: none;
}
- input[type="checkbox"]:focus + label {
- border-color: rgba(0,0,0,0.6);
- }
-
input[type="checkbox"] + label:after {
content: url("tick.svg");
position: absolute;
- top: -2px;
- left: -2px;
+ top: -1px;
+ left: -1px;
display: block;
- width: 16px;
- height: 16px;
+ width: 18px;
+ height: 18px;
transition: all 200ms;
-webkit-transform: scale(0);
transform: scale(0);
@@ -392,7 +407,8 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
input[type="checkbox"]:indeterminate + label:after {
content: "–";
- font-size: 14px;
+ left: -2px;
+ font-size: 13px;
text-align: center;
-webkit-transform: none;
transform: none;
@@ -402,12 +418,12 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
input[type="checkbox"] + label:before {
content: "";
position: absolute;
- top: -14px;
- left: -14px;
- width: 40px;
- height: 40px;
+ top: -13px;
+ left: -13px;
+ width: 41px;
+ height: 41px;
border-radius: 50%;
- background: #666;
+ background-color: #666;
opacity: 0;
-webkit-transform: scale(0.8);
transform: scale(0.8);
@@ -422,43 +438,18 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
}
input[type="checkbox"]:checked + label:before {
- background: #03A9F4;
+ background-color: #03A9F4;
}
/* Small adjustments for the checkbox in the header */
-
- .v-grid-header input[type="checkbox"] + label {
- border-color: rgba(255,255,255,0.5);
- }
-
.v-grid-header input[type="checkbox"] + label:before {
- background: #fff;
+ background-color: white;
}
.v-grid-header input[type="checkbox"] + label:after {
transition: none;
}
- /* Focus styles */
-
- .v-grid-row-focused:after {
- content: "";
- position: absolute;
- z-index: 1;
- top: 0;
- right: 0;
- bottom: 0;
- left: 0;
- border: 1px solid rgba(0,0,0,0.2);
- pointer-events: none;
- opacity: 0;
- transition: opacity 300ms;
- }
-
- :focus .v-grid-row-focused:after {
- opacity: 1;
- }
-
#measure {
width: 100% !important;
height: 100% !important;
@@ -475,78 +466,50 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
width: 100% !important;
height: 100% !important;
}
+
+ /* The following is a workaround to https://dev.vaadin.com/ticket/18376 */
+ .v-grid-scroller[invisible]::-webkit-scrollbar {
+ border: none;
+ }
+
+ .v-grid-scroller[invisible]::-webkit-scrollbar-thumb {
+ border-radius: 10px;
+ border: 4px solid transparent;
+ background: rgba(0,0,0,.3);
+ -webkit-background-clip: content-box;
+ background-clip: content-box;
+ }
+
+
+ .v-grid-scroller-vertical[invisible]::-webkit-scrollbar-thumb {
+ min-height: 30px;
+ }
+
+ .v-grid-scroller-horizontal[invisible]::-webkit-scrollbar-thumb {
+ min-width: 30px;
+ }
+
</style>
<template>
<div id="measure" class="v-grid">
- <object id="measureobject" class="v-grid" type="text/html"></object>
+ <iframe id="measureobject" class="v-grid"></iframe>
</div>
<content></content>
</template>
</dom-module>
<script>
- function loadComponent() {
VGrid = Polymer({
+
is: "v-grid",
_grid: undefined,
properties: {
/**
- * The row editor specific fields
- *
- * @property editor
- * @type {Editor}
- */
- editor: {
- type: Object,
- readOnly: true,
- value: function() {
- var _this = this;
- return {
- get enabled() {
- return _this._grid.getEditor().isEnabled();
- },
- set enabled(enabled) {
- _this._grid.getEditor().setEnabled(enabled);
- if (_this.editable !== enabled) {
- _this.editable = enabled;
- }
- },
- get handler() {
- return _this._grid.getEditor().getHandler();
- },
- set handler(handler) {
- _this._grid.getEditor().setHandler(handler);
- },
- get saveButtonText() {
- return _this._grid.getEditor().getSaveButtonText();
- },
- set saveButtonText(saveButtonText) {
- _this._grid.getEditor().setSaveButtonText(saveButtonText);
- },
- get cancelButtonText() {
- return _this._grid.getEditor().getSaveButtonText();
- },
- set cancelButtonText(cancelButtonText) {
- _this._grid.getEditor().setCancelButtonText(cancelButtonText);
- },
- editRow: function(row) {
- _this._grid.getEditor().editRow(row);
- },
- save: function() {
- _this._grid.getEditor().save();
- },
- cancel: function() {
- _this._grid.getEditor().cancel();
- }
- };
- },
- },
- /**
- * The data source object for the grid.
+ * Object for controlling and accessing the data source of the grid.
*
- * @property data
+ * @property {Data} data
* @type {Data}
*/
data: {
@@ -580,16 +543,15 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
clearCache: function(estimatedNewSize) {
_this._grid.getDataSource().clearCache(estimatedNewSize);
- },
-
+ }
};
}
},
/**
- * Object for manipulating header rows
+ * Object for controlling and accessing the header rows in the grid.
*
- * @property header
+ * @property {Header} header
* @type {Header}
*/
header: {
@@ -630,9 +592,9 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
},
/**
- * Object for manipulating footer rows
+ * Object for controlling and accessing the footer rows in the grid.
*
- * @property footer
+ * @property {Footer} footer
* @type {Footer}
*/
footer: {
@@ -667,9 +629,9 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
},
/**
- * Selection model
+ * Object for controlling and accessing the selected rows in the grid.
*
- * @property selection
+ * @property {Selection} selection
* @type {Selection}
*/
selection: {
@@ -716,7 +678,7 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
}
};
}
- },
+ }
},
attributeChanged: function(name, type, value) {
@@ -724,12 +686,6 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
case 'disabled':
this.disabled = typeof value == "string";
break;
- case 'editable':
- this.editable = typeof value == "string";
- break;
- case 'style':
- this._grid.redraw();
- break;
case 'selection-mode':
this.selection.mode = value;
break;
@@ -740,18 +696,24 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
listeners: {
/**
+ * A change in the sorting order.
+ *
* @event sort
*/
/**
+ * Row is selected or deselected.
+ *
* @event select
*/
/**
+ * A change in the selection mode.
+ *
* @event selectionmodechange
*/
- 'selectionmodechange': 'onSelectionModeChange'
+ 'selectionmodechange': '_onSelectionModeChange'
},
- onSelectionModeChange: function() {
+ _onSelectionModeChange: function() {
this.serializeValueToAttribute(this.selection.mode, "selection-mode");
},
@@ -760,30 +722,23 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
},
ready: function() {
- var _this = this;
- setTimeout(function() {
- for (var i = 0; i < _this.attributes.length; i++) {
- _this.attributeChanged(_this.attributes[i].nodeName, null, _this.attributes[i].nodeValue);
+ this.async(function() {
+ for (var i = 0; i < this.attributes.length; i++) {
+ this.attributeChanged(this.attributes[i].nodeName, null, this.attributes[i].nodeValue);
}
- }, 1);
-
+ });
},
_bindResizeListener: function() {
var _this = this;
this.$.measureobject.addEventListener("load", function() {
this.contentDocument.defaultView.addEventListener('resize', function(e) {
- _this._grid.redraw();
- });
-
- _this.then(function() {
- // ...because one then just isn't enough.
- _this.then(function() {
- _this._grid.redraw();
- });
+ _this._grid.updateSize();
});
+ _this._grid.updateSize();
});
- this.$.measureobject.data = "about:blank";
+
+ this.$.measureobject.src = "about:blank";
},
attached: function() {
@@ -792,21 +747,24 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
this._bindResizeListener();
// hide until fully loaded
- this.toggleClass('loading', true);
+ this.toggleClass('v-grid-loading', true);
this.then(function() {
- _this.toggleClass('loading', false);
+ _this.toggleClass('v-grid-loading', false);
});
},
/**
* Scrolls to a certain row, using user-specified scroll destination.
- * Since its asynchronous nature, this method returns a 'thenable'
- * so as you can use the 'then()' method to be notified when the data
- * request finished and the scroll is actually moved.
+ *
+ * Scrolling happens asynchronously, so this method returns a 'thenable'
+ * which can be used to be notified when the scrolling is finished.
+ *
+ * Example: `grid.scrollToRow(10, 'end').then(doMoreStuff);`
*
* @method scrollToRow
- * @param {number} index - zero-based index of the row to scroll to.
- * @param {string} scrollDestination - desired destination placement of scrolled-to-row.
+ * @param {number} index - Zero-based index of the row to scroll to.
+ * @param {string} scrollDestination - Desired destination placement of scrolled-to-row. Valid values are `any`, `start`, `middle` and `end`. Defaults to `any`.
+ * @return {v-grid}
*/
scrollToRow: function(index, scrollDestination) {
this._grid.scrollToRow(index, scrollDestination);
@@ -814,12 +772,15 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
},
/**
- * Scrolls to the beginning of the very first row.
- * Since its asynchronous nature, this method returns a 'thenable'
- * so as you can use the 'then()' method to be notified when the data
- * request finished and the scroll is actually moved.
+ * Scrolls to the beginning of the grid.
+ *
+ * Scrolling happens asynchronously, so this method returns a 'thenable'
+ * which can be used to be notified when the scrolling is finished.
+ *
+ * Example: `grid.scrollToStart().then(doMoreStuff);`
*
* @method scrollToStart
+ * @return {v-grid}
*/
scrollToStart: function() {
this._grid.scrollToStart();
@@ -827,12 +788,15 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
},
/**
- * Scrolls to the end of the very last row.
- * Since its asynchronous nature, this method returns a 'thenable'
- * so as you can use the 'then()' method to be notified when the data
- * request finished and the scroll is actually moved.
+ * Scrolls to the end of the grid.
+ *
+ * Scrolling happens asynchronously, so this method returns a 'thenable'
+ * which can be used to be notified when the scrolling is finished.
+ *
+ * Example: `grid.scrollToEnd().then(doMoreStuff);`
*
* @method scrollToEnd
+ * @return {v-grid}
*/
scrollToEnd: function() {
this._grid.scrollToEnd();
@@ -840,55 +804,83 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
},
/**
- * Adds new column
+ * Adds a new column. Column is added at the end if `beforeColumn` is not defined.
*
* @method addColumn
- * @param {Column} column
- * @param {string} beforeColumn
+ * @param {Column} column - Column to be added.
+ * @param {string} beforeColumn - Index or id of the column before which the new column should be added.
*/
addColumn: function(column, beforeColumn) {
this._grid.addColumn(column, beforeColumn);
},
/**
- * Removes column with certain id
+ * Removes a column with certain id
*
* @method removeColumn
- * @param {string} id
+ * @param {string} id - Column to be removed.
*/
removeColumn: function(id) {
this._grid.removeColumn(id);
},
- /**
- * Sets the style generator that is used for generating styles for rows.
- *
- * @attribute rowClassGenerator
- * @type object
- */
get rowClassGenerator() {
return this._grid.getRowClassGenerator();
},
- set rowClassGenerator(rowClassGenerator) {
- this._grid.setRowClassGenerator(rowClassGenerator);
- },
+
/**
- * Sets the style generator that is used for generating styles for cells.
+ * The style generator that is used for generating styles for rows.
*
- * @attribute cellClassGenerator
- * @type object
+ * Example:
+ * ```
+ * grid.rowClassGenerator = function(row) {
+ * var activity = row.data[2];
+ * return 'activity-' + activity.toLowerCase();
+ * };
+ *```
+ *
+ * @property {function} rowClassGenerator
+ * @param {Row} row - Reference to the row being rendered.
+ * @type {function}
*/
+ set rowClassGenerator(row) {
+ this._grid.setRowClassGenerator(row);
+ },
+
get cellClassGenerator() {
return this._grid.getCellClassGenerator();
},
- set cellClassGenerator(cellClassGenerator) {
- this._grid.setCellClassGenerator(cellClassGenerator);
+
+ /**
+ * The style generator that is used for generating styles for cells.
+ *
+ * Example:
+ * ```
+ * grid.cellClassGenerator = function(cell) {
+ * if (cell.index == 2) {
+ * var activity = cell.row.data[2];
+ * return 'activity-' + activity.toLowerCase();
+ * }
+ * return '';
+ * };
+ * ```
+ * @property {function} cellClassGenerator
+ * @param {Cell} cell - Reference to the cell being rendered.
+ * @type {function}
+ *
+ */
+ set cellClassGenerator(cell) {
+ this._grid.setCellClassGenerator(cell);
},
+
/**
- * Disables the grid functionality.
+ * Disables the grid.
*
- * @attribute disabled
- * @type boolean
+ * Attribute: `disabled`
+ *
+ * @property {boolean} disabled
+ * @default false
+ * @type {boolean}
*/
get disabled() {
return this._grid.isDisabled();
@@ -897,27 +889,18 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
this._grid.setDisabled(disabled);
this.reflectPropertyToAttribute("disabled");
},
+
/**
- * Enables the row editor feature (double click/tap or or Enter key in a content row activates the editing mode)
- *
- * @attribute editable
- * @type boolean
- */
- get editable() {
- return this.editor.enabled;
- },
- set editable(editable) {
- this.editor.enabled = editable;
- this.reflectPropertyToAttribute("editable");
- },
- /**
- * Sets the number of frozen columns in this grid. Setting the count to 0
+ * The number of frozen columns in this grid. Setting it to 0
* means that no data columns will be frozen, but the built-in selection
* checkbox column will still be frozen if it's in use. Setting the count to
* -1 will also disable the selection column.
*
- * @attribute frozen-columns
- * @type Number
+ * Attribute: `frozen-columns`
+ *
+ * @property {number} frozenColumns
+ * @default 0
+ * @type {number}
*/
get frozenColumns() {
return this._grid.getFrozenColumns();
@@ -926,25 +909,31 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
this._grid.setFrozenColumns(frozenColumns);
this.reflectPropertyToAttribute("frozenColumns");
},
+
/**
- * Declares the number of visible rows in the grid. Implicitly sets the height
+ * The number of visible rows in the grid. Implicitly sets the height
* in the inline style, overriding any previous height. Setting style.height
* in this case should be ignored if possible.
*
- * @attribute rows
- * @type Number
+ * Attribute: `rows`
+ *
+ * @property {number} rows
+ * @default 10
+ * @type {number}
*/
get rows() {
- return this._grid.getRows();
+ var rows = this._grid.getRows();
+ return rows > 0 ? rows : undefined;
},
set rows(rows) {
this._grid.setRows(rows);
this.reflectPropertyToAttribute("rows");
},
+
/**
- * The columns array
+ * The array of Columns attached to the grid.
*
- * @property columns
+ * @property {Array<Column>} columns
* @type {Array<Column>}
*/
get columns() {
@@ -953,31 +942,16 @@ Vaadin v-grid is a grid component fully configurable and customizable, plenty of
set columns(cols) {
this._grid.setColumns(cols);
},
+
/**
* Executes a callback when the grid has finished any pending work.
*
- * @method them
+ * @method then
* @param {Function} callback
- * @return a chainable promise
+ * @return {Promise}
*/
- then: function(cb) {
- return this._grid.then(cb);
+ then: function(callback) {
+ return this._grid.then(callback);
}
}); // End Polymer prototype
-
- // Give some time to gwt async processes to run (we need this in FF)
- setTimeout(function() {
- vaadin._v_grid_ready = true;
- document.dispatchEvent(new CustomEvent('v-grid-ready'));
- }, 5);
-
- } // End loadComponent function
-
- if (window.vaadin && window.vaadin.GridComponent) {
- loadComponent();
- } else {
- document.addEventListener("v-grid-loaded", function() {
- loadComponent();
- });
- }
</script>