npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

react-hooks-grid

v0.0.6

Published

Lightweight and customizable data grid for React applications from 16.8 version.

Downloads

6

Readme

react-hooks-grid

Lightweight and customizable data grid for React applications from 16.8 version.

Now library is in progress.

npm version npm bundle size License: MIT

Installation

$ npm install react-hooks-grid

Live demo

Test it! Go to live demo with 100 000 rows.

Quick start

import { useGrid } from 'react-hooks-grid';

const DataGrid = ({data}) => {
    const { grid, setGrid, rowCount } = useGrid(data);

    return (
        <table>
            {grid.rows.map(row => (
                <tr>
                    {row.cells.map(cell => (<td>{cell.value}</td>))}
                </tr>
            ))}
        </table>
    );
};
export default DataGrid;

Plugins

All useGrid's power comes from plugins that can be fully customized to developer's needs. Additionally everyone can add custom plugin for him needs and create powerful data grid.

To create your own plugin go to section useCustomPlugin.

useSorting

useSorting(column, descending, customSortFn)

  • column - initial column choice
  • descending - initial order choice, is it descending
  • customSortFn - custom function of sorting - customFn(rowA, rowB, column, descending)

setSort(column, descending)

  • column - sorting by new column
  • descending - sorting by new order

Special sorting rules or local difference - if is needed create own sort function and put as customSortFn

Multi column sorting - if multi sorting is needed, only change some parameters. 'column' use as array of column next 'descending' the same and and set your own sort function.

order = 30

import { useGrid, useSorting } from 'react-hooks-grid';

const DataGrid = ({data}) => {
    const { grid, sortColumn, sortDesc, setSort } = useGrid(data, {
        useSorting()
    });

    return (
        <table>
            <tr>
                <th>
                  <div onClick={e => setSort('firstName', !sortDesc)}>First Name</div>
                </th>
                <th>
                  <div onClick={e => setSort('lastName', !sortDesc)}>Last Name</div>
                </th>
            </tr>
            {grid.rows.map(row => (
                <tr>
                    {row.cells.map(cell => (<td>{cell.value}</td>))}
                </tr>
            ))}
        </table>
    );
};
export default DataGrid;

useFiltering

useFiltering(filters, customPredicates)

  • filters - filters for grid. Set object where key will be id of filter and value as object with type of filter and column. See sample below.
  • customPredicates - custom predicates for filters. Set object where key will be name of predicate and value as custom predicate function with below structure. You will get filter and row while you should implement predicate condition.
filter => row => { return predicateCondition }

setFilter(filterId, value)

  • filterId - id of filter
  • value - new value for filter

Filter types

  • contains
  • equals
  • greater
  • lesser

order = 20

import { useGrid, useFiltering } from 'react-hooks-grid';

const DataGrid = ({data}) => {
    const { grid, filters, setFilter } = useGrid(data, {
        useFiltering({
            firstNameId: { type: 'contains', column: 'firstName' },
            lastNameId: { type: 'containsWithUpperCase', column: 'lastName' },
        },{
            containsWithUpperCase: filter => row => row[filter.column].indexOf(filter.value) > -1,
        })
    });

    return (
        <table>
            <tr>
                <th>
                    <input
                        type="text"
                        value={filters.firstName.value || ''}
                        onChange={e => setFilter('firstNameId', e.target.value)}
                    />
                    <div>First Name</div>
                </th>
                <th>
                    <input
                        type="text"
                        value={filters.lastName.value || ''}
                        onChange={e => setFilter('lastNameId', e.target.value)}
                    />
                    <div>Last Name</div>
                </th>
            </tr>
            {grid.rows.map(row => (
                <tr>
                    {row.cells.map(cell => (<td>{cell.value}</td>))}
                </tr>
            ))}
        </table>
    );
};
export default DataGrid;

usePaging

usePaging(size, index)

  • size - initial size of page
  • index - initial page index

setIndex(index)

  • index - new page index

setSize(size)

  • size - new size of page

order = 40

import { useGrid, usePaging } from 'react-hooks-grid';
import PagingComponent from './PagingComponent'

const DataGrid = ({data}) => {
    const { grid, pageIndex, pageSize, setIndex, setSize, pageCount } = useGrid(data, {
        usePaging(10)
    });

    return (
        <table>
            <tr>
                <th>First Name</th>
                <th>Last Name</th>
            </tr>
            {grid.rows.map(row => (
                <tr>
                    {row.cells.map(cell => (<td>{cell.value}</td>))}
                </tr>
            ))}
            <PagingComponent pageIndex={pageIndex}, pageSize={pageSize}, setIndex={setIndex}, setSize={setSize}, pageCount={pageCount} />
        </table>
    );
};
export default DataGrid;

useFormat

Embedded plugin which changing structure of entry data. If you want to create a new plugin, you must remember about structure before or after change.

order = 50

Format:

grid {
    rows: [
        {
            cells: [
                { value, key }
            ]
        }
    ]
}

useCustomPlugin

If existing plugins that is not enough. Create your own ;)

Each plugin will be called during the grid update in a certain order. The property order is responsible for this. When you create your own plugin set appropriate order for it.

Below is boilerplate for own plugins.

export const useCustomPlugin = (anyNumberOfParameters) => updateGrid => {
    pluginLogic

    const order = anyOrder;
    const setGrid = grid => modifyGrid;
    const mixinApi = instance => {
        Object.assign(instance, { customPublicApi });
    };

    return { order, setGrid, mixinApi };
};
  • anyNumberOfParameters - any number of parameters for plugin,
  • pluginLogic - all custom logic for that plugin,
  • anyOrder - set order for plugin when will be called during update grid,
  • modifyGrid - implement function which modify or calculate grid,
  • customPublicApi - expose public api for using outside,
  • updateGrid - given function for invoke when grid update will be needed. Last step in all exposed functions like setSort, setIndex setSize etc. Don't implement it. Just invoke updateGrid() when it is necessary.

Licence

MIT