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 🙏

© 2025 – Pkg Stats / Ryan Hefner

@gerstams/ngx-table-search

v0.1.2

Published

NgxTableSearch is a simple and lightweight library to add fulltext-search filter functionality for tables.

Readme

NgxTableSearch

NgxTableSearch is a simple and lightweight library to add fulltext-search filter functionality for tables.

Features

  • Fulltext search for your tables (and collections in general)
  • Exclude any columns/properties that you don't want to filter upon

Usage

Define your template with an input field to enter the search string and the table you want to filter:

<input type="text">

<table>
  <thead>
    <tr>
      <th>User ID</th>
      <th>ID</th>
      <th>Title</th>
      <th>Body</th>
    </tr>
  </thead>
  <tbody>
    <tr *ngFor="let post of posts">
      <td>{{ post.userId }}</td>
      <td>{{ post.id }}</td>
      <td>{{ post.title }}</td>
      <td>{{ post.body }}</td>
    </tr>
  </tbody>
</table>

Next, add the NgxTableSearch features to connect your input field with the filter:

<input type="text" #search ngxTableSearch>

<table>
  <thead>
    <tr>
      <th>User ID</th>
      <th>ID</th>
      <th>Title</th>
      <th>Body</th>
    </tr>
  </thead>
  <tbody>
    <tr *ngFor="let post of posts | ngxtablesearch:search.value">
      <td>{{ post.userId }}</td>
      <td>{{ post.id }}</td>
      <td>{{ post.title }}</td>
      <td>{{ post.body }}</td>
    </tr>
  </tbody>
</table>

The #search creates a ViewChild that can be used to get the current value by ngxtablesearch:search.value. The ngxTableSearch directive makes any updates of the input field available and triggers the change detection.

Scenarios

  1. Primitive data types The filter wraps the input value in a string and then does the fulltext search.

  2. Nested objects In case your objects contain properties that itself are objects, these nested properties are unwrapped and part of the fulltext search.

Eclude specific fields

If you want to filter an entire tables (i.e. by all its columns) expect for a few specific ones, you can specify these column names and they will be ignored when filtering. Just add any column name as a string as the third (and any further argument, all separated by a colon) like this:

<input type="text" #search ngxTableSearch>

<table>
  <thead>
    <tr>
      <th>User ID</th>
      <th>ID</th>
      <th>Title</th>
      <th>Body</th>
    </tr>
  </thead>
  <tbody>
    <tr *ngFor="let post of posts | ngxtablesearch:search.value:'title'">
      <td>{{ post.userId }}</td>
      <td>{{ post.id }}</td>
      <td>{{ post.title }}</td>
      <td>{{ post.body }}</td>
    </tr>
  </tbody>
</table>

An example for more than one column to exclude:

<input type="text" #search ngxTableSearch>

<table>
  <thead>
    <tr>
      <th>User ID</th>
      <th>ID</th>
      <th>Title</th>
      <th>Body</th>
    </tr>
  </thead>
  <tbody>
    <tr *ngFor="let post of posts | ngxtablesearch:search.value:'title':'body'">
      <td>{{ post.userId }}</td>
      <td>{{ post.id }}</td>
      <td>{{ post.title }}</td>
      <td>{{ post.body }}</td>
    </tr>
  </tbody>
</table>

Note: Make sure to use the actual property name of your items instead of the columns names you are displaying as they could be different.

Heads-Up

The library is filtering the table by all properties of its items except for those that you specified for exclusion as opposed to those fields that you display in your table. This actually confused me once myself ;-)

Source Code

Find the source code for this library on my GitHub profile.

License

MIT