lite-grid

simple es6 grid widget

Usage no npm install needed!

<script type="module">
  import liteGrid from 'https://cdn.skypack.dev/lite-grid';
</script>

README

lite-grid

Simple ES6 grid widget. No external dependencies, just pure ES6 javascript.

DEMO

Features

  • flexible & easy to use
  • sortable
  • filterable
  • themable
  • tiny

Usage

import Grid from 'src';

const data = {
    total: 10,
    totalAmount: 100,
    items: [
        { id: 1, date: '2015-01-01', category: 'Category', desc: 'Description text', amount: 21 },
        { id: 2, date: '2015-01-02', category: 'Category', desc: 'Description text', amount: 22 },
        { id: 3, date: '2015-01-03', category: 'Category', desc: 'Description text', amount: 23 },
        { id: 4, date: '2015-01-04', category: 'Category', desc: 'Description text', amount: 24 },
        { id: 5, date: '2015-01-05', category: 'Category', desc: 'Description text', amount: 25 },
        { id: 6, date: '2015-01-05', category: 'Category', desc: 'Description text', amount: 26 },
        { id: 7, date: '2015-01-05', category: 'Category', desc: 'Description text', amount: 27 },
        { id: 8, date: '2015-01-05', category: 'Category', desc: 'Description text', amount: 28 },
        { id: 9, date: '2015-01-05', category: 'Category', desc: 'Description text', amount: 29 },
        { id: 10, date: '2015-01-05', category: 'Category', desc: 'Description text', amount: 30 },
        { id: 11, date: '2015-01-05', category: 'Category', desc: 'Description text', amount: 31 }
    ]
};

const grid = new Grid({
    // theme: 'light',
    target: document.getElementById('grid1'),
    sort: { by: 'date', order: 'desc' },
    // dataSource: function (params) {
    //  return $.ajax('data.json', params);
    // },
    dataSource: (params) => {
        console.log('params: ', params);
        return {}; // data;
    },
    columns: [
        {
            width: 50,
            icons: {
                pencil: {
                    title: 'Edit',
                    cb: function (item, row) {
                        this.selectRow(row, true);
                        console.log(item, row);
                    }
                },
                'trash-o': {
                    title: 'Delete',
                    cb: function (item, row) {
                        this.selectRow(row, true);
                        console.log(item, row);
                    }
                }
            }
        },
        { name: 'Date', field: 'date', width: 85 },
        { name: 'Category', field: 'category', width: '40%' },
        { name: 'Desc', field: 'desc' },
        {
            name: 'Amount',
            field: 'amount',
            width: 100,
            renderer: (txt) => `€${txt}`,  // or rec.amount
            footer: function (data) {
                return '€' + this.items.reduce((pre, cur) => pre + cur.amount, 0);
            }
        }
    ]
});