@scoped-vaadin/grid
v23.4.100
Published
A free, flexible and high-quality Web Component for showing large amounts of tabular data
Downloads
247
Maintainers
Readme
@scoped-vaadin/grid
This component is based on @vaadin/grid
A web component for showing tabular data.
<vaadin23-grid theme="row-dividers" column-reordering-allowed multi-sort>
<vaadin23-grid-selection-column auto-select frozen></vaadin23-grid-selection-column>
<vaadin23-grid-sort-column width="9em" path="firstName"></vaadin23-grid-sort-column>
<vaadin23-grid-sort-column width="9em" path="lastName"></vaadin23-grid-sort-column>
<vaadin23-grid-column id="address" width="15em" flex-grow="2" header="Address"></vaadin23-grid-column>
</vaadin23-grid>
<script>
// Customize the "Address" column's renderer
document.querySelector('#address').renderer = (root, grid, model) => {
root.textContent = `${model.item.address.street}, ${model.item.address.city}`;
};
// Populate the grid with data
const grid = document.querySelector('vaadin23-grid');
fetch('https://demo.vaadin.com/demo-data/1.0/people?count=200')
.then((res) => res.json())
.then((json) => (grid.items = json.result));
</script>
Installation
Install the component:
npm i @scoped-vaadin/grid
Once installed, import the components in your application:
import '@scoped-vaadin/grid';
import '@scoped-vaadin/grid/vaadin-grid-column-group.js';
import '@scoped-vaadin/grid/vaadin-grid-filter-column.js';
import '@scoped-vaadin/grid/vaadin-grid-selection-column.js';
import '@scoped-vaadin/grid/vaadin-grid-sort-column.js';
import '@scoped-vaadin/grid/vaadin-grid-tree-column.js';
Themes
Vaadin components come with two built-in themes, Lumo and Material. The main entrypoint of the package uses the Lumo theme.
To use the Material theme, import the components from the theme/material
folder:
import '@scoped-vaadin/grid/theme/material/vaadin-grid.js';
import '@scoped-vaadin/grid/theme/material/vaadin-grid-filter-column.js';
import '@scoped-vaadin/grid/theme/material/vaadin-grid-selection-column.js';
import '@scoped-vaadin/grid/theme/material/vaadin-grid-sort-column.js';
import '@scoped-vaadin/grid/theme/material/vaadin-grid-tree-column.js';
You can also import the Lumo version of the components explicitly:
import '@scoped-vaadin/grid/theme/lumo/vaadin-grid.js';
import '@scoped-vaadin/grid/theme/lumo/vaadin-grid-filter-column.js';
import '@scoped-vaadin/grid/theme/lumo/vaadin-grid-selection-column.js';
import '@scoped-vaadin/grid/theme/lumo/vaadin-grid-sort-column.js';
import '@scoped-vaadin/grid/theme/lumo/vaadin-grid-tree-column.js';
Finally, you can import the un-themed components from the src
folder to get a minimal starting point:
import '@scoped-vaadin/grid/src/vaadin-grid.js';
import '@scoped-vaadin/grid/src/vaadin-grid-column-group.js';
import '@scoped-vaadin/grid/src/vaadin-grid-filter-column.js';
import '@scoped-vaadin/grid/src/vaadin-grid-selection-column.js';
import '@scoped-vaadin/grid/src/vaadin-grid-sort-column.js';
import '@scoped-vaadin/grid/src/vaadin-grid-tree-column.js';
Contributing
Read the contributing guide to learn about our development process, how to propose bugfixes and improvements, and how to test your changes to Vaadin components.
License
Apache License 2.0
Vaadin collects usage statistics at development time to improve this product. For details and to opt-out, see https://github.com/vaadin/vaadin-usage-statistics.