/reactivesearch

A React components library for building awesome :mag: search UIs

Primary LanguageJavaScriptApache License 2.0Apache-2.0

Reactive Search

npm version Gitter npm PRs Welcome

React UI components for Elasticsearch.

v2 of reactivesearch is here 🍾. Go read how to build an e-commerce search UI on codeburst.

🚀 npm install @appbaseio/reactivesearch

Banner Image showing all the UI components we offer

TOC

  1. Reactive Search: Intro
  2. Features
  3. Component Playground
  4. Live Examples
  5. Installation
  6. Getting Started
  7. Docs Manual
  8. Developing Locally
  9. Other Projects You Might Like

1. ReactiveSearch: Intro

ReactiveSearch is a React UI components library for Elasticsearch. It has 25+ components for Lists, Dropdowns, RangeSliders, DataSearch, MultiLevelMenu, Calendars, Feeds, RatingsFilter, ResultCard and ResultList.

The library is conceptually divided into two parts:

  1. Sensor components and
  2. Actuator components.

Each sensor component is purpose built for applying a specific filter on the data. For example:

  • A SingleList sensor component applies an exact match filter based on the selected item.
  • A RangeSlider component applies a numeric range query based on the values selected from the UI.
  • A DataSearch component applies a suggestions and search query based on the search term typed by the user.

Sensor components can be configured to create a combined query context and render the matching results via an actuator component.

ReactiveSearch primarily comes with two actuators: ResultCard and ResultList. ResultCard displays the results in a card interface whereas ResultList displays them in a list. Both provide built-in support for pagination and infinite scroll views.

Besides these, the library also provides low level actuators (ReactiveComponent and ReactiveList) to render in a more customized fashion.

2. Features

Design

  • The sensor / actuator design pattern allows creating complex UIs where any number of sensors can be chained together to reactively update an actuator (or even multiple actuators).
  • The library handles the transformation of the UI interactions into database queries. You only need to include the components and associate each with a DB field.
  • Built in live updates - Actuators can be set to update results even when the underlying data changes in the DB.
  • Comes with a cleanly namespaced CSS classes API that allows extending built-in styles without hassle.
  • Is themable via ThemeProvider.

Ease of Use

⬆ Back to Top

3. Component Playground

Try the live component playground at playground. Look out for the knobs section in the playground part of the stories to tweak each prop and see the effects.

4. Live Demos

A set of live demos inspired by real world apps, built with ReactiveSearch.

You can check all of them on the examples page. // TODO: Fix the examples page link.

⬆ Back to Top

5. Installation

Installing ReactiveSearch is just one command.

npm install @appbaseio/reactivesearch

You can also read about it here.

6. Getting Started

Follow the getting started guide to build a Hello Search! app from the official docs here.

7. Docs Manual

The official docs for the library are at https://opensource.appbase.io/reactive-manual.

The components are divided into four sections:

⬆ Back to Top

8. Developing Locally

  1. Clone the repo
git clone https://github.com/appbaseio/reactivesearch.git
  1. cd into the project directory

  2. Checkout the dev branch (should be default)

  3. fetch the submodules. In case you don't have ssh setup for github, change the URLs in .gitmodules to use https instead

git submodule init
git submodule sync
git submodule update --remote
  1. The submodules will be fetched into /packages. Defaults to dev in /packages/playground and master in /packages/reactivecore.

9. Other Projects You Might Like

  • ReactiveSearch Dashboard All your Reactive Search related apps (created via interactive tutorial, shared by others, etc.) can be accessed from here.

  • ReactiveMaps is a similar project to Reactive Search that allows building realtime maps easily.

  • appbase-js While building search UIs is dandy with Reactive Search, you might also need to add some input forms. appbase-js comes in handy there.

  • dejavu allows viewing raw data within an appbase.io (or Elasticsearch) app. Soon to be released feature: An ability to import custom data from CSV and JSON files, along with a guided walkthrough on applying data mappings.

  • mirage ReactiveSearch components can be extended using custom Elasticsearch queries. For those new to Elasticsearch, Mirage provides an intuitive GUI for composing queries.

⬆ Back to Top