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

https://github.com/ecomplus/search-engine

Isomorphic JS lib to handle products search for E-Com Plus stores
https://github.com/ecomplus/search-engine

ecommerce-search ecomplus elasticsearch products-search search-algorithms search-api search-items

Last synced: about 1 month ago
JSON representation

Isomorphic JS lib to handle products search for E-Com Plus stores

Awesome Lists containing this project

README

        

# E-Com Plus Search Engine

[![Publish](https://github.com/ecomplus/search-engine/workflows/Publish/badge.svg)](https://github.com/ecomplus/search-engine/actions?workflow=Publish) [![CodeFactor](https://www.codefactor.io/repository/github/ecomplus/search-engine/badge)](https://www.codefactor.io/repository/github/ecomplus/search-engine) [![npm version](https://img.shields.io/npm/v/@ecomplus/search-engine.svg)](https://www.npmjs.org/@ecomplus/search-engine) [![License MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

UMD JS lib to handle products search for E-Com Plus stores

[CHANGELOG](https://github.com/ecomplus/search-engine/blob/master/CHANGELOG.md)

## Usage

The `@ecomplus/search-engine` package is a wrapper for [E-Com Plus Search API](https://developers.e-com.plus/docs/api/#/search/), can be used to handle a full featured products search system, from simple items search to applying multiple filters and aggregations.

It's available for both Node.js and browser environments.

- [Get started](https://developers.e-com.plus/search-engine/module-@ecomplus_search-engine.html)
- [Class reference](https://developers.e-com.plus/search-engine/EcomSearch.html)

### Example

```js
import EcomSearch from '@ecomplus/search-engine'

const search = new EcomSearch()

search.setSearchTerm('smartphone').fetch()
.then(result => {
search.getItems().forEach(item => {
console.log(item.name)
})
})
.catch(error => {
console.error(error)
if (error.response) {
console.log(error.response)
}
})
```

#### Customize search query before fetch

```js
import EcomSearch from '@ecomplus/search-engine'

EcomSearch.dslMiddlewares.push((dsl) => {
dsl.query.bool.filter.push({
terms: {
channel_id: [123]
}
})
})
```

### Installation

It _may_ require and doesn't include `core-js` (optional) and [`@ecomplus/utils`](https://developers.e-com.plus/utils/) (peer dependency).

#### Webpack

```bash
npm i --save core-js @ecomplus/utils @ecomplus/search-engine
```

#### Node.js

```bash
npm i --save @ecomplus/utils @ecomplus/search-engine
```

#### CDN

```html

```

When importing from CDN, `_.cloneDeep`, `_.merge`, `ecomUtils` and `ecomClient` libraries **must be included separately** and available on window scope.