Skip to content

Tyrenn/svelte-gridjs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Grid.js for Svelte

Svelte component for Grid.js. Highly inspired by abandoned library gridjs-svelte and library gridjs-react

Install

npm install --save svelte-gridjs

Also, make sure you have Grid.js installed already as it's a peer dependency of gridjs-svelte:

npm install --save gridjs

Usage

Import the Grid component first

import Grid from "svelte-gridjs";
<Grid
  data={[
		{ name: "John", email: "[email protected]" },
		{ name: "Mark", email: "[email protected]" }
	]}
  columns={['Name', 'Email']}
  search
  pagination={{
    enabled: true,
    limit: 1,
  }}
/>

Then you can pass all Grid.js configs to the Grid component. See Grid.js Config for more details.

Svelte component in cells

You can bind your svelte components in Table cells (both in header and body cells) : The composer function _ allows you to pass a svelte component, props and events with listeners to attach to it. It is fully functionnal with svelte reactivity. Component will unmount properly.

import Grid, {_} from "svelte-gridjs";
import MockComponent from "./MockComponent.svelte";
<Grid
  data={[
		{ name: "John", email: "[email protected]" },
		{ name: "Mark", email: "[email protected]" }
	]}
  columns={[
		'Name', 
		{
			name: 'Email',
			formatter: (cell) => _({component : MockComponent, props : {cell}, events : [{event : 'myevent', callback : () => {console.log('hello')}}]})
		}
	]}
  search
  pagination={{
    enabled: true,
    limit: 1,
  }}
/>

Example

See the Svelte example.

License

MIT

About

A Svelte wrapper component for Grid.js

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages