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-dynamic-filterbar

v0.2.3

Published

A filter bar to host dynamic filters using react.

Downloads

108

Readme

React Dynamic Filter Bar

A component that provides a filters to the user in a way that can added or remove form the bar. The user is presented with a list of available filters in a list. Choosing a filter adds it to the bar with the option to then remove that filter. Those filters present the user with the fields or selections that allow the user to configure the values and operations of that filter.

Install

npm install react-dynamic-filterbar

Usage

Add your filterbar to the page and handle the updateF

import { Filters, FilterBar, ChangeFQLHander } from 'react-dynamic-filterbar';
type AppProps = {};
type AppState = {
    fql?: FilterBars.FilterQueryLanguage<MyData>,
}

class App extends React.Component<AppProps, AppState> {
  constructor(props: AppProps) {
      super(props);
      this.state = {
          fql: undefined,
      }
  }

  onFilterUpdate: ChangeFQLHander<MyData> = (fql) => {
      this.setState({ fql });
  }

  render() {
  return (
    <FilterBar onFilterUpdate={this.onFilterUpdate} fql={fql} buttonClassName="btn">
      <Filters.StringFilter field={['firstName', 'lastName']} label="Name" className="form-control" buttonClassName="btn btn-primary" />
      <Filters.StringFilter field="comment" label="Comment" className="form-control" buttonClassName="btn btn-primary" showOperator />
      <Filters.NumericFilter field="amount" label="Amount" className="form-control" />
      <Filters.SelectFilter field="color" label="Colors" options={colorOptions} styles={customStyles} isMulti />
      <Filters.DateFilter field="birthday" label="Birthday" showOperator buttonClassName="btn btn-primary" shown/>
    </FilterBar>);
  }
}

Filter Options

Filter Bar

  • onFilterUpdate - Event Handler called when any filters update the FQL.
  • fql - The FQL data to be displayed by the filters in the filter bar.
  • buttonClassName - Class to be applied the add filter dropdown of the filter bar.

Common

  • field - The field the filter applies to.
  • label - The string used to represent the filter. Used in the add fitler and filter labels.
  • shown - The filter is added at page load with default values.

String and Number

  • showOperator - Show a dropdown to choose what operation to be applied.
  • buttonClassName - Class to be applied the operartion dropdown of the filter.
  • className - Class applied the the input element.

Select (react-select)

  • isMulti - Make the select a multi-select box.
  • options - The options list provided as an array of { value: string, option: string }.
  • styles - Style object to pass to react-select control.

Understanding Filter Query Language (FQL)

FQL is designed to be a normalized definition of filters that can be applied to a dataset in a serializable format. The format allows for flexable filter configuration that still includes order of filter application and nested properties. This result is an object that can represent the WHERE clause of a SQL while keeping the information needed to display the filters.

  FQL = { // The base FQL wrapping object.
    logic: AND, // AND | OR - Used to represent how multiple filters are grouped together. (Default: AND)
    filterQueries: [ 
      logic: OR, // Logic used to join filter values on a property together and multiple filters.
      field: 'name', // The property or field to be filtered on. Can be array of fields or nested fields. ex ['user.firstName', 'user.lastName']
      filterItems: [{
        operation: EQ, // Logic used in the comparison operation.
        value: 'Jim' // The value to check against.
      }]
    ]
  }

As SQL

SELECT * FROM USER WHERE [name] = 'Jim';
  FQL = { // The base FQL wrapping object.
    logic: AND
    filterQueries: [ 
      logic: OR,
      field: 'comment',
      filterItems: [
        operation: CONTAINS,
        value: 'Test'
      ]
    ],
    filterQueries: [ 
      logic: OR,
      field: 'color',
      filterItems: [{
        operation: EQ,
        value: 'red'
      }, {
        operation: EQ,
        value: 'blue'
      }]
    ]
  }

As SQL

SELECT * FROM USER WHERE [comment] LIKE '%Test%' AND ([color] = 'red' OR [color] = 'blue');
SELECT * FROM USER WHERE [comment] LIKE '%Test%' AND ([color] IN ('red', 'blue'));

Examples

Text filter added for a name.

  • Input to type in string to filter on.
  • Optionally select filter logic.
    • Contains
    • Equals (An exact match)
    • Starts with
    • Ends with
    • Does not contain
  • Optionally provide case sensitivity. (Preferred case insensitivity.)

Custom Filters

You can make your own custom filter. The filter is responsable for consuming its part of filter query and calling the event handler when that filter query has changed. The filter is wrapped in a control that supplies a remove link.