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

grid-component

v0.11.1

Published

Grid Component

Downloads

29

Readme

Grid Component built with CanJS

Build Status npm version Join the chat at https://gitter.im/icanjs/grid-component

js-semistandard-style

A template based grid component that supports sorting, row selection, paged rendering and checkboxes. Built with CanJS.

Feel free to open an issue or chat with us on gitter.

Latest version 0.11.0 requires CanJS v4.

For CanJS v3 use [email protected]

Grid Demo

Installation

npm install grid-component --save

To check out the demo:

  • install dependencies;
  • run http server on the root of the project;
  • load the demo file in browser (src/demo/demo.html).

Use

<can-import from="grid-filter" />

<grid-component rows:from="items">

  <div class="grid-tools">
    <grid-filter rows:from="rows"></grid-filter>
  </div>

  <table>
    <thead>
      <tr>
        <th on:click="{sortBy('title')}">Title {{{sortArrow('title')}}}</th>
        <th on:click="{sortBy('amount')}">Amount {{{sortArrow('amount')}}}</th>
      </tr>
    </thead>

    <tbody>
      {{#each(rows)}}
        <tr class="{{#if(isHidden)}}hidden{{/if}}">
          <td>{{title}}</td>
          <td>{{amount}}</td>
        </tr>
      {{/each}}
    </tbody>
  </table>

</grid-component>

Server pagination: total, limit and skip

For a full demo see src/demo/demo-pagination-server.html.

Your view model:

import DefineMap from "can-define/map/map";
import DefineList from "can-define/list/list";

let myPageViewModel = DefineMap.extend({
  rows: {
    type: DefineList
  },
  pagination: DefineMap.extend({
    skip: 'number',
    limit: 'number',
    total: 'number'
  }),
  loadPage () {
    let pagination = this.pagination;
    MyModel.getList({skip: pagination.skip, limit: pagination.limit}).then(items => {
      this.rows = items;
    });
  }
});

and template:

    <grid-component rows:from="rows" pagination:from="pagination" on:vm:onpage="loadPage()">
      <table>
        <tbody>
          {{#each(rows)}}
            <tr>
              <td>{{id}}</td>
              <td>{{title}}</td>
            </tr>
          {{/each}}
        </tbody>
      </table>
      {{#if(hasPages)}}
      <button on:click="prev()" {{^if(isPrevActive)}} disabled {{/if}}>Prev</button>
      <ul>
        {{#each(pages)}}
          <li class="{{#if(isActive)}}active{{/if}}" on:click="../changePage(pageNumber)">
            {{pageTitle}}
          </li>
        {{/each}}
      </ul>
      <button on:click="next()" {{^if(isNextActive)}} disabled {{/if}}>Next</button>
      {{/if}}
    </grid-component>

or if there are too many pages and we want to show only a section of pages (issue https://github.com/icanjs/grid-component/issues/13):

      {{#if(hasPages)}}
      <button on:click="prev()" {{^if(isPrevActive)}} disabled {{/if}}>Prev</button>
      <ul>
        {{#if(isLeftEllipsisShown)}}
           <li>...</li>
        {{/if}}

        {{#each(pagesVisible)}}
           <li class="{{#if(isActive)}}active{{/if}}" on:click="../changePage(pageNumber)">{{pageTitle}}</li>
        {{/each}}

        {{#if isRightEllipsisShown}}
           <li>...</li>
        {{/if}}
      </ul>
      <button on:click="next()" {{^if(isNextActive)}} disabled {{/if}}>Next</button>
      {{/if}}

Simple local pagination: custom view-model configuration

For how to define grid component with a custom view-model see the section below.

For the full demo see src/demo/demo-pagination.html.

    <grid-component rows:from="items" pagination:from="10">
      <table>
        <tbody>
          {{#each(pagedRows)}}
            <tr>
              <td>{{id}}</td>
              <td>{{title}}</td>
            </tr>
          {{/each}}
        </tbody>
      </table>
      {{#if(hasPages)}}
      <button on:click="prev()" {{^if(isPrevActive)}} disabled {{/if}}>Prev</button>
      <ul>
        {{#each(pages)}}
          <li class="{{#if(isActive)}}active{{/if}}" on:click="../changePage(pageNumber)">
            {{pageTitle}}
          </li>
        {{/each}}
      </ul>
      <button on:click="next()" {{^if(isNextActive)}} disabled {{/if}}>Next</button>
      {{/if}}
    </grid-component>

Custom view-model:

To customize grid's view model you can choose any of the available mixins as well as provide your own to override them.

E.g. if you need only sorting and local pagination (all rows will be given to the grid) you can do:

import VM from 'grid-component/src/view-model';
import mixinSort from 'grid-component/src/mixins/sort';
import mixinPagination from 'grid-component/src/mixins/pagination';

let MyCustomVM = DefineMap.extend({seal: false}, mixin(VM, mixinSort, mixinPagination));

Component.extend({
   tag: 'my-grid-component',
   viewModel: MyCustomVM
});

Note: can.Component allows to declare a tag only one time, so make sure you either do not import the default grid-component or name your new tag differently (e.g. my-grid-component).

Features

  • Sorting. Mixin, by default is ON.
  • Simple pagination. Mixin, by default is off. Includes pagination numeric config property of how many rows are shown per page, methods: next, prev, changePage.
  • Server pagination. Mixin, by default is ON:
    • pages
    • pagesVisibleNumber, pagesVisible, isLeftEllipsisShown, isRightEllipsisShown
  • Row selection.
  • Checkbox row selection. Mixin, by default is ON.
  • Expandable child rows. Mixin, by default is ON.
  • Filtering (with external grid-filter component)
  • Scroll-near-bottom events. To use for loading/showing more rows on scroll.
  • Paged rendering. A performance enhancement for cases when there are a lot of rows (n x 10K), when grid renders the specified amount of rows (renderPageSize) and adds a new render page when uses scrolls close to the bottom. Works well with sorting and filtering.

API:

  • rows Data source of the rows.

Configuration:

  • renderPageSize How many pages grid should render. To use with a lot of rows. Default 200.
  • loadOnScroll If ON grid will emit scrollEventName when user scrolls close to the bottom.
  • scrollThrottleInterval
  • scrollBottomDistance
  • scrollEventName Event name. Default grid-should-load-more.
  • pagination How many rows show per page.

Read API:

  • Derived lists:
  • visibleRows A derived list with rows that are not hidden by filter (row's isHidden is false).
  • renderedRows List of rendered rows (to be used with renderPageSize).
  • visibleEnabledRows
  • checkedRows List of checked rows
  • checkedVisibleRows
  • checkedVisibleEnabledRows
  • Sorting mixin:
  • sortColumnName Indicates what column the rows are sorted by.
  • sortAsc <Boolean>, TRUE for ascending, FALSE for descending.
  • selectedRow The row selected by clicking.
  • Checkbox mixin:
  • isHeaderChecked To be used for the header "master" checkbox.
  • areAllVisibleChecked.
  • Simple pagination mixin:
  • pagedRows List of rows to show for the current page.
  • currentPage <Number> Number of the current page (starts with 0).
  • hasPages <Boolean> Indicates whether there are pages.

Template helpers and methods:

  • selectRow Method for row selection
  • sortArrow Helper to show a sort arrow. Pagination:
  • next Method to go to the next page.
  • prev Method to go to the previous page.
  • changePage Method to set page to a particular number.

Changelog

  • 0.11.0 Upgraded to CanJS v4.
  • 0.10.0 Added pagesVisible, isLeftEllipsisShown and isRightEllipsisShown to pagination-server mixin.
  • 0.9.0 Added pagination-server mixin to handle server-side pagination based on total, limit and skip params.
    • set pagination-server as a default mixin (instead of local pagination).
  • 0.8.0 Upgraded to CanJS v3 and Steal v1.
    • switched to Semistandard.
  • 0.7.2 Added changePage, hasPages.
  • 0.7.0 Added simple pagination support with helpers: next(), prev(), pages object. Provide pagination config option with a number of how many rows to show per page. Use pagedRows derived list.