Home

Awesome

<div align="center"> <img align="center" src="./static/logo.svg" alt="logo" width="172"/> <p align="center"> <h1 align="center" style="font-size:32px;margin:0;border:none;">svelte simple datatables</h1> <p style="color:#eee">A toolkit for creating datatable components with Svelte</p> <img src="https://img.shields.io/npm/v/@vincjo/datatables?color=%23c2185b" alt="npm version"/> <img src="https://img.shields.io/github/license/vincjo/datatables?color=c2185b" alt="last commit"/> </p> </div>

[!NOTE]

Upcoming Svelte 5 runes

With the imminent release of Svelte 5, SSD is getting a facelift for its next major 2.0. You can have a look at the preview documentation here: https://vincjo.fr/datatables.runes/

Presentation

This lib provides an API to dynamically interact with iterable data on the client-side: filtering, paging, sorting, selecting...

Also provides some showcase components, which you can grab and customize in your own project.

:globe_with_meridians: Live examples

<br>

:satellite: Server-side data processing

<img src="./static/logo-remote.svg" alt="logo" align="left" width="72"/>

Support for server-side pagination, sort, filters is located in @vincjo/datatables/remote namespace.

Basic usage | Examples

<br>

Install

npm i -D @vincjo/datatables

Sample code

<script lang="ts">
    import { DataHandler } from '@vincjo/datatables'
    import { someData } from './data'

    const handler = new DataHandler(someData, { rowsPerPage: 50 })
    const rows = handler.getRows()
</script>

<table>
    <thead>
        <tr>
            <th>First name</th>
            <th>Last name</th>
        </tr>
    </thead>
    <tbody>
        {#each $rows as row}
            <tr>
                <td>{row.first_name}</td>
                <td>{row.last_name}</td>
            </tr>
        {/each}
    </tbody>
</table>

:globe_with_meridians: See full documentation

<br>

DataHandler methods

getRows(): Readable<Row[]>
setRows( data: Row[] ): void
sort( orderBy: Field<Row> ): void
sortAsc( orderBy: Field<Row> ): void
sortDesc( orderBy: Field<Row> ): void
getSort(): Writable<(Sort<Row>)>
applySort( params: { orderBy?: Field<Row>, direction?: 'asc' | 'desc'} = null ): void
defineSort( params: { orderBy?: Field<Row>, direction?: 'asc' | 'desc'} = null ): void
clearSort(): void
filter( value: string, filterBy: Field<Row>, comparator: Comparator<Row> ): void
clearFilters(): void
getFilterCount(): Readable<number>
search( value: string, scope?: Field<Row>[] ): void
clearSearch(): void
getRowsPerPage(): Writable<number | null>
getRowCount(): Readable<{ total: number; start: number; end: number; }>
getPages( param: { ellipsis: boolean } ): Readable<number[]>
getPageCount(): Readable<number>
getPageNumber(): Readable<number>
setPage( value: number | ‘previous’ | ‘next’ ): void
select(value: Row[] | (Row[keyof Row])[]): void
getSelected(): Writable<Row[] | (Row[keyof Row])[]>
selectAll(params: { selectBy?: keyof Row, scope?: 'all' | 'currentPage' } = { scope: 'all' }): void
isAllSelected(): Readable<boolean>
on(event: 'change' | 'clearFilters' | 'clearSearch', callback: () => void)