Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/DoubleTrade/lit-datatable
lit-datatable is a material design implementation of a data table, powered by lit-element.
https://github.com/DoubleTrade/lit-datatable
Last synced: about 2 months ago
JSON representation
lit-datatable is a material design implementation of a data table, powered by lit-element.
- Host: GitHub
- URL: https://github.com/DoubleTrade/lit-datatable
- Owner: DoubleTrade
- License: apache-2.0
- Created: 2019-06-25T09:39:54.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-07T05:12:21.000Z (about 2 years ago)
- Last Synced: 2024-11-10T19:46:01.618Z (2 months ago)
- Language: TypeScript
- Homepage:
- Size: 1.45 MB
- Stars: 57
- Watchers: 15
- Forks: 12
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-lit - `<lit-datatable>` - Material Design implementation of a data table, powered by LitElement. (Standalone Components)
README
![CI](https://github.com/DoubleTrade/lit-datatable/workflows/CI/badge.svg) [![Published on webcomponents.org](https://img.shields.io/badge/webcomponents.org-published-blue.svg)](https://www.webcomponents.org/element/@doubletrade/lit-datatable)
# lit-datatable
`lit-datatable` is a material design implementation of a data table.
![screen](screen.png)
## Roadmap
Add some helpers.## Install
```
npm install @doubletrade/lit-datatable
```## Launch demo
```
npm install
npm run build
npm run serve
```## Lint
```
npm run lint:javascript
```## Data
```js
// Data from api
const data = [
{ fruit: 'apple', color: 'green', weight: '100gr' },
{ fruit: 'banana', color: 'yellow', weight: '140gr' }
];
// Conf to set order of column and visibility (can be dynamically)
const conf = [
{ property: 'fruit', header: 'Fruit', hidden: false },
{ property: 'color', header: 'Color', hidden: true },
{ property: 'weight', header: 'Weight', hidden: false }
];
```## Simple example
```html```
## Simple example with sticky header
```html```
## With HTML header
Use native html from lit-html to render a custom header.
Header can use value from data and property from conf.
```js
const headerOfFruit = (value, property) => html`${value}`;
```
```html
```
## With HTML data
As header, use native html from lit-html to render a custom body.
```js
const bodyOfFruit = (value, property) => html`${value}`;
```
```html
```
## With HTML data and footer
A footer is available to catch size and page changed in order to relaunch the request to the backend.
```html
```
## With HTML data and sorter
A default sorter is available, set a header column without html and type `sort`.
The sort must be of the following form : `property,direction`, ex: `fruit,asc`.
```html
```
## With HTML data and custom sorter
You can use a specific sorter is available in helpers.
```js
const sort = key => (value, property) => html`
${value}
`;
```
```html
```
## Custom style on a td
```html```
## With HTML data and filter
```html
```
## With HTML data, sort and filter
```html
```
## With HTML data and choices filter
```html
```
## With HTML data and choices filter with value filtering
```html
```
## With HTML data and date filter
The format of startDate and endDate is a timestamp.
```html
```
---
[![Testing Powered By SauceLabs](https://opensource.saucelabs.com/images/opensauce/powered-by-saucelabs-badge-white.png?sanitize=true 'Testing Powered By SauceLabs')](https://saucelabs.com)