Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/bekzod/ember-slack-search-input

Ember Addon
https://github.com/bekzod/ember-slack-search-input

ember ember-addon slack

Last synced: 3 months ago
JSON representation

Ember Addon

Awesome Lists containing this project

README

        

# ember-slack-search-input [![Ember Observer Score](http://emberobserver.com/badges/ember-slack-search-input.svg)](http://emberobserver.com/addons/ember-slack-search-input) [![npm version](https://badge.fury.io/js/ember-slack-search-input.svg)](https://badge.fury.io/js/ember-slack-search-input) [![travis status](https://travis-ci.org/bekzod/ember-slack-search-input.svg)](https://travis-ci.org/bekzod/ember-slack-search-input.svg)

Attempt to replicate slack search input field as ember addon.
### [Demo](http://ember-slack-search-input.surge.sh)

Like search input field in slack, special keywords(modifiers) are used to filter out the search. This modifiers are passed as form of config object with options like:

```javascript
configHash: {
"@": { // '@' is special key (modifier) which highlighted in input
type: 'list', // type of modifier (either list or date)
defaultHint: 'any user', // displayed when modifier is active but has no value
sectionTitle: 'Users', // used as header when all modifiers content displayed
content: [ // content to be used for displaying list
{value: 'abrahm', label: 'Abrahm Micanski' },
{value: 'lilly', label: 'Lilly Richards' },
{value: 'emma', label: 'Emma Roberts' },
]
},

"before:": {
type: 'date',
defaultHint: 'a date',
}
}
```

```hbs
{{slack-search-input
placeholder='search for objects'
configHash=configHash
inputValue=''
isPopupHidden=false
maxlength=250
valueChange=(action 'searchValueChange')
modifierAutoComplete=(action 'modifierAutoComplete')
enter=(action 'search')
focus-in=(action 'inputFocusedIn')
focus-out=(action 'inputFocusedOut')
}}
```
There is also help popup which is displayed when user focuses input first time. The content of popup should be passed to `slack-search-input` in block form.

```hbs
{{#slack-search-input as |concatToInputValue|}}


Search with Filters

Narrow your search using filter before:, channel: or @. Or press plus key + to get all available filters
{{/slack-search-input}}
```

## slack-search-input options

#### placeholder:String
Simple placeholder displayed when input has no value

#### configHash:Object
Config object used for getting modifiers

#### inputValue:String
Initial value of input

#### isPopupHidden:Boolean
Can be used to hide popups

#### maxlength:Number
Max character length of input

#### valueChange(newValue:String)
Fired when inputValue changes

#### modifierAutoComplete(newValue:String, modifierValue:Object)
Fired when modifier has valid value

#### escape()
Fired when the escape key is hit

## Modifier Types
Currently two types of modifiers are supported `list` and `date`:
* Date - Date picker popup is showed when modifier is active.
* List - List is simple list of possible options

## Deserialize Query String
Once you got query string, you can deserialze it to object.

```javascript
import { deserializeQueryString } from `ember-slack-search-input`;

search() {
let queryString = get(this, 'queryString');
console.log(queryString) // `before:2000-23-23 lorem`
let modifiers = deserializeQueryString(queryString);
let before = modifiers['before:'];
let { model, fullText, modifier, value } = before[0]; //first occurance of `before:`
console.log(model); // moment date
console.log(fullText); // before:2000-23-23
console.log(modifier); // before:
console.log(value); // 2000-23-23
}
```

## Requirements
Currently addon styles has hard dependency on `bootstrap 3.x.x`, bootstrap should be installed already to styles work properly.
For input field to react properly to `paste/cut` events, they should be added to `customEvents` hash in `app.js`.
```javascript
App = Ember.Application.extend({
customEvents: {
paste: "paste",
cut: "cut"
},
...
});
```

## Installation

```shell
ember install ember-slack-search-input
```

## TODO
* write more tests
* add more modifier types
* remove bootstrap dependency