2018-03-26 18:17:01 +03:00
|
|
|
import { IS_BROWSER } from '../utils/';
|
2018-03-05 18:58:19 +03:00
|
|
|
import { IMenuItem } from './MenuStore';
|
2018-02-22 19:48:50 +03:00
|
|
|
import { OperationModel } from './models';
|
2018-03-06 14:12:14 +03:00
|
|
|
|
|
|
|
let worker;
|
|
|
|
|
2018-03-26 18:14:38 +03:00
|
|
|
if (IS_BROWSER) {
|
2018-03-06 14:12:14 +03:00
|
|
|
try {
|
2018-03-26 18:17:01 +03:00
|
|
|
// tslint:disable-next-line
|
2018-03-06 15:20:44 +03:00
|
|
|
worker = require('workerize-loader?inline&fallback=false!./SearchWorker.worker');
|
2018-03-06 14:12:14 +03:00
|
|
|
} catch (e) {
|
|
|
|
worker = require('./SearchWorker.worker').default;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
worker = require('./SearchWorker.worker').default;
|
|
|
|
}
|
2018-02-08 19:41:02 +03:00
|
|
|
|
|
|
|
export class SearchStore {
|
|
|
|
searchWorker = new worker();
|
|
|
|
|
2018-02-22 19:48:50 +03:00
|
|
|
indexItems(groups: Array<IMenuItem | OperationModel>) {
|
2018-03-06 14:12:49 +03:00
|
|
|
const recurse = items => {
|
|
|
|
items.forEach(group => {
|
2018-03-06 14:10:08 +03:00
|
|
|
if (group.type !== 'group') {
|
|
|
|
this.add(group.name, group.description || '', group.id);
|
|
|
|
}
|
|
|
|
recurse(group.items);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
recurse(groups);
|
|
|
|
this.searchWorker.done();
|
2018-02-08 19:41:02 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
add(title: string, body: string, ref: string) {
|
|
|
|
this.searchWorker.add(title, body, ref);
|
|
|
|
}
|
|
|
|
|
|
|
|
search(q: string) {
|
|
|
|
return this.searchWorker.search(q);
|
|
|
|
}
|
2018-03-06 14:10:08 +03:00
|
|
|
|
|
|
|
async toJS() {
|
|
|
|
return this.searchWorker.toJS();
|
|
|
|
}
|
|
|
|
|
|
|
|
load(state: any) {
|
|
|
|
this.searchWorker.load(state);
|
|
|
|
}
|
2018-02-08 19:41:02 +03:00
|
|
|
}
|