Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joseluisq/sortboard
A small ES6 library for easy sorting and filtering of elements.
https://github.com/joseluisq/sortboard
blocks css3 elements filtering regex sort
Last synced: 3 months ago
JSON representation
A small ES6 library for easy sorting and filtering of elements.
- Host: GitHub
- URL: https://github.com/joseluisq/sortboard
- Owner: joseluisq
- License: mit
- Archived: true
- Created: 2014-11-28T17:12:58.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2021-04-10T17:04:21.000Z (over 3 years ago)
- Last Synced: 2024-04-14T05:36:23.092Z (9 months ago)
- Topics: blocks, css3, elements, filtering, regex, sort
- Language: TypeScript
- Homepage:
- Size: 1020 KB
- Stars: 29
- Watchers: 6
- Forks: 8
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Sortboard
[![npm](https://img.shields.io/npm/v/sortboard.svg)](https://www.npmjs.com/package/sortboard) [![npm](https://img.shields.io/npm/dt/sortboard.svg)](https://www.npmjs.com/package/sortboard) [![Build Status](https://travis-ci.org/joseluisq/sortboard.svg?branch=master)](https://travis-ci.org/joseluisq/sortboard) [![JavaScript Style Guide](https://img.shields.io/badge/code%20style-standard-brightgreen.svg)](http://standardjs.com/)
> An small library for easy sorting and filtering of elements.Sortboard is small library for sorting and filtering HTML elements which uses CSS3 [`matrix()` and `scale()`](http://www.w3.org/TR/2011/WD-css3-2d-transforms-20111215/) transform functions. It supports [RegEx](https://developer.mozilla.org/en/docs/Web/JavaScript/Guide/Regular_Expressions) filters and it's responsive by default.
:tada: View demo on [Codepen](http://codepen.io/joseluisq/full/IlHzo/)
## Install
[Yarn](https://github.com/yarnpkg/)
```sh
yarn add sortboard --dev
```[NPM](https://www.npmjs.com/)
```sh
npm install sortboard --save-dev
```The [UMD](https://github.com/umdjs/umd) build is also available on [unpkg](https://unpkg.com).
```html
```
You can use the library via `window.sortboard`
## Usage
Define some list. For example an `ul` with `li` child elements, then set your filters in each `li` element with the `data-filter` attribute. It can add several filters by element separated by whitespace.
__Typescript:__
```ts
import { sortboard, Sortboard, Listener } from 'sortboard'const sb = sortboard({
container: '#mylist',
selector: 'li'
})const onEvent: Listener = () => console.log('ok!')
sb.on('filter', onEvent)sb.filter('programing front-end')
// Or filter using a RegEx
sb.filter(/(webdesign|illustration)/)
```__Markup:__
```html
```
## API
### Options
- __container__ : The container of elements.
- __selector__ : The query selector for each element.
- __gutter__ : The margin for each element defined in pixels. Default is `10` pixels.
- __resetFilterValue__ : The reset filter value used by `reset()` method. Default is `all`.
- __hiddenClass__ : Class name for hidden elements. Default is `.sortboard-hidden` class name.
- __matchedClass__ : Class name for matched elements. Default is `.sortboard-matched` class name.
### Methods
- __filter( string | RegExp )__ : It's string or `RegExp` regular expresion pattern to filter. Which should match to `data-filter` attribute for each element to searching.
- __reset()__ : Reset the elements which uses `resetFilterValue` option for resetting.
- __sort()__ : Sort the element positions in the container. Sort method is called after the `filter()` method and in each trigger of `window.resize` event.
### Events
#### filter
Trigger when filter is completed.
Passed params:
- __matchedElements:__ An `array` with all matched elements.
- __restElements:__ An `array` with the rest (not matched) elements.
- __filterValue:__ A `string` with the current filter value used.
```js
sb.on('filter', (matchedElements, restElements, filterValue) => {})
```
#### sort
Trigger when sort is completed.
```js
sb.on('sort', () => {})
```
## Development
```sh
yarn start
```
## Contributions
Feel free to send some [pull request](https://github.com/joseluisq/sortboard/pulls) or [issue](https://github.com/joseluisq/sortboard/issues).
## License
MIT license
© 2014-present [José Luis Quintana](http://git.io/joseluisq)