@searchspring/snap-store-mobx 0.20.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +54 -0
- package/dist/cjs/Abstract/AbstractStore.d.ts +18 -0
- package/dist/cjs/Abstract/AbstractStore.d.ts.map +1 -0
- package/dist/cjs/Abstract/AbstractStore.js +31 -0
- package/dist/cjs/Autocomplete/AutocompleteStore.d.ts +32 -0
- package/dist/cjs/Autocomplete/AutocompleteStore.d.ts.map +1 -0
- package/dist/cjs/Autocomplete/AutocompleteStore.js +121 -0
- package/dist/cjs/Autocomplete/Stores/FacetStore.d.ts +9 -0
- package/dist/cjs/Autocomplete/Stores/FacetStore.d.ts.map +1 -0
- package/dist/cjs/Autocomplete/Stores/FacetStore.js +69 -0
- package/dist/cjs/Autocomplete/Stores/QueryStore.d.ts +15 -0
- package/dist/cjs/Autocomplete/Stores/QueryStore.d.ts.map +1 -0
- package/dist/cjs/Autocomplete/Stores/QueryStore.js +30 -0
- package/dist/cjs/Autocomplete/Stores/StateStore.d.ts +23 -0
- package/dist/cjs/Autocomplete/Stores/StateStore.d.ts.map +1 -0
- package/dist/cjs/Autocomplete/Stores/StateStore.js +52 -0
- package/dist/cjs/Autocomplete/Stores/TermStore.d.ts +19 -0
- package/dist/cjs/Autocomplete/Stores/TermStore.d.ts.map +1 -0
- package/dist/cjs/Autocomplete/Stores/TermStore.js +86 -0
- package/dist/cjs/Autocomplete/Stores/TrendingStore.d.ts +7 -0
- package/dist/cjs/Autocomplete/Stores/TrendingStore.d.ts.map +1 -0
- package/dist/cjs/Autocomplete/Stores/TrendingStore.js +44 -0
- package/dist/cjs/Autocomplete/Stores/index.d.ts +6 -0
- package/dist/cjs/Autocomplete/Stores/index.d.ts.map +1 -0
- package/dist/cjs/Autocomplete/Stores/index.js +13 -0
- package/dist/cjs/Finder/FinderStore.d.ts +21 -0
- package/dist/cjs/Finder/FinderStore.d.ts.map +1 -0
- package/dist/cjs/Finder/FinderStore.js +56 -0
- package/dist/cjs/Finder/Stores/SelectionStore.d.ts +8 -0
- package/dist/cjs/Finder/Stores/SelectionStore.d.ts.map +1 -0
- package/dist/cjs/Finder/Stores/SelectionStore.js +232 -0
- package/dist/cjs/Finder/Stores/index.d.ts +2 -0
- package/dist/cjs/Finder/Stores/index.d.ts.map +1 -0
- package/dist/cjs/Finder/Stores/index.js +5 -0
- package/dist/cjs/Recommendation/RecommendationStore.d.ts +14 -0
- package/dist/cjs/Recommendation/RecommendationStore.d.ts.map +1 -0
- package/dist/cjs/Recommendation/RecommendationStore.js +51 -0
- package/dist/cjs/Recommendation/Stores/ProfileStore.d.ts +8 -0
- package/dist/cjs/Recommendation/Stores/ProfileStore.d.ts.map +1 -0
- package/dist/cjs/Recommendation/Stores/ProfileStore.js +22 -0
- package/dist/cjs/Recommendation/Stores/index.d.ts +2 -0
- package/dist/cjs/Recommendation/Stores/index.d.ts.map +1 -0
- package/dist/cjs/Recommendation/Stores/index.js +5 -0
- package/dist/cjs/Search/SearchStore.d.ts +26 -0
- package/dist/cjs/Search/SearchStore.d.ts.map +1 -0
- package/dist/cjs/Search/SearchStore.js +61 -0
- package/dist/cjs/Search/Stores/FacetStore.d.ts +8 -0
- package/dist/cjs/Search/Stores/FacetStore.d.ts.map +1 -0
- package/dist/cjs/Search/Stores/FacetStore.js +317 -0
- package/dist/cjs/Search/Stores/FilterStore.d.ts +7 -0
- package/dist/cjs/Search/Stores/FilterStore.d.ts.map +1 -0
- package/dist/cjs/Search/Stores/FilterStore.js +100 -0
- package/dist/cjs/Search/Stores/MerchandisingStore.d.ts +20 -0
- package/dist/cjs/Search/Stores/MerchandisingStore.d.ts.map +1 -0
- package/dist/cjs/Search/Stores/MerchandisingStore.js +59 -0
- package/dist/cjs/Search/Stores/PaginationStore.d.ts +40 -0
- package/dist/cjs/Search/Stores/PaginationStore.d.ts.map +1 -0
- package/dist/cjs/Search/Stores/PaginationStore.js +190 -0
- package/dist/cjs/Search/Stores/QueryStore.d.ts +16 -0
- package/dist/cjs/Search/Stores/QueryStore.d.ts.map +1 -0
- package/dist/cjs/Search/Stores/QueryStore.js +34 -0
- package/dist/cjs/Search/Stores/ResultStore.d.ts +7 -0
- package/dist/cjs/Search/Stores/ResultStore.d.ts.map +1 -0
- package/dist/cjs/Search/Stores/ResultStore.js +156 -0
- package/dist/cjs/Search/Stores/SortingStore.d.ts +21 -0
- package/dist/cjs/Search/Stores/SortingStore.d.ts.map +1 -0
- package/dist/cjs/Search/Stores/SortingStore.js +75 -0
- package/dist/cjs/Search/Stores/index.d.ts +8 -0
- package/dist/cjs/Search/Stores/index.d.ts.map +1 -0
- package/dist/cjs/Search/Stores/index.js +17 -0
- package/dist/cjs/Storage/StorageStore.d.ts +25 -0
- package/dist/cjs/Storage/StorageStore.d.ts.map +1 -0
- package/dist/cjs/Storage/StorageStore.js +130 -0
- package/dist/cjs/index.d.ts +8 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +27 -0
- package/dist/cjs/types.d.ts +81 -0
- package/dist/cjs/types.d.ts.map +1 -0
- package/dist/cjs/types.js +9 -0
- package/dist/esm/Abstract/AbstractStore.d.ts +18 -0
- package/dist/esm/Abstract/AbstractStore.d.ts.map +1 -0
- package/dist/esm/Abstract/AbstractStore.js +25 -0
- package/dist/esm/Autocomplete/AutocompleteStore.d.ts +32 -0
- package/dist/esm/Autocomplete/AutocompleteStore.d.ts.map +1 -0
- package/dist/esm/Autocomplete/AutocompleteStore.js +94 -0
- package/dist/esm/Autocomplete/Stores/FacetStore.d.ts +9 -0
- package/dist/esm/Autocomplete/Stores/FacetStore.d.ts.map +1 -0
- package/dist/esm/Autocomplete/Stores/FacetStore.js +29 -0
- package/dist/esm/Autocomplete/Stores/QueryStore.d.ts +15 -0
- package/dist/esm/Autocomplete/Stores/QueryStore.d.ts.map +1 -0
- package/dist/esm/Autocomplete/Stores/QueryStore.js +24 -0
- package/dist/esm/Autocomplete/Stores/StateStore.d.ts +23 -0
- package/dist/esm/Autocomplete/Stores/StateStore.d.ts.map +1 -0
- package/dist/esm/Autocomplete/Stores/StateStore.js +40 -0
- package/dist/esm/Autocomplete/Stores/TermStore.d.ts +19 -0
- package/dist/esm/Autocomplete/Stores/TermStore.d.ts.map +1 -0
- package/dist/esm/Autocomplete/Stores/TermStore.js +42 -0
- package/dist/esm/Autocomplete/Stores/TrendingStore.d.ts +7 -0
- package/dist/esm/Autocomplete/Stores/TrendingStore.d.ts.map +1 -0
- package/dist/esm/Autocomplete/Stores/TrendingStore.js +16 -0
- package/dist/esm/Autocomplete/Stores/index.d.ts +6 -0
- package/dist/esm/Autocomplete/Stores/index.d.ts.map +1 -0
- package/dist/esm/Autocomplete/Stores/index.js +5 -0
- package/dist/esm/Finder/FinderStore.d.ts +21 -0
- package/dist/esm/Finder/FinderStore.d.ts.map +1 -0
- package/dist/esm/Finder/FinderStore.js +33 -0
- package/dist/esm/Finder/Stores/SelectionStore.d.ts +8 -0
- package/dist/esm/Finder/Stores/SelectionStore.d.ts.map +1 -0
- package/dist/esm/Finder/Stores/SelectionStore.js +171 -0
- package/dist/esm/Finder/Stores/index.d.ts +2 -0
- package/dist/esm/Finder/Stores/index.d.ts.map +1 -0
- package/dist/esm/Finder/Stores/index.js +1 -0
- package/dist/esm/Recommendation/RecommendationStore.d.ts +14 -0
- package/dist/esm/Recommendation/RecommendationStore.d.ts.map +1 -0
- package/dist/esm/Recommendation/RecommendationStore.js +28 -0
- package/dist/esm/Recommendation/Stores/ProfileStore.d.ts +8 -0
- package/dist/esm/Recommendation/Stores/ProfileStore.d.ts.map +1 -0
- package/dist/esm/Recommendation/Stores/ProfileStore.js +17 -0
- package/dist/esm/Recommendation/Stores/index.d.ts +2 -0
- package/dist/esm/Recommendation/Stores/index.d.ts.map +1 -0
- package/dist/esm/Recommendation/Stores/index.js +1 -0
- package/dist/esm/Search/SearchStore.d.ts +26 -0
- package/dist/esm/Search/SearchStore.d.ts.map +1 -0
- package/dist/esm/Search/SearchStore.js +38 -0
- package/dist/esm/Search/Stores/FacetStore.d.ts +8 -0
- package/dist/esm/Search/Stores/FacetStore.d.ts.map +1 -0
- package/dist/esm/Search/Stores/FacetStore.js +264 -0
- package/dist/esm/Search/Stores/FilterStore.d.ts +7 -0
- package/dist/esm/Search/Stores/FilterStore.d.ts.map +1 -0
- package/dist/esm/Search/Stores/FilterStore.js +68 -0
- package/dist/esm/Search/Stores/MerchandisingStore.d.ts +20 -0
- package/dist/esm/Search/Stores/MerchandisingStore.d.ts.map +1 -0
- package/dist/esm/Search/Stores/MerchandisingStore.js +32 -0
- package/dist/esm/Search/Stores/PaginationStore.d.ts +40 -0
- package/dist/esm/Search/Stores/PaginationStore.d.ts.map +1 -0
- package/dist/esm/Search/Stores/PaginationStore.js +148 -0
- package/dist/esm/Search/Stores/QueryStore.d.ts +16 -0
- package/dist/esm/Search/Stores/QueryStore.d.ts.map +1 -0
- package/dist/esm/Search/Stores/QueryStore.js +28 -0
- package/dist/esm/Search/Stores/ResultStore.d.ts +7 -0
- package/dist/esm/Search/Stores/ResultStore.d.ts.map +1 -0
- package/dist/esm/Search/Stores/ResultStore.js +117 -0
- package/dist/esm/Search/Stores/SortingStore.d.ts +21 -0
- package/dist/esm/Search/Stores/SortingStore.d.ts.map +1 -0
- package/dist/esm/Search/Stores/SortingStore.js +65 -0
- package/dist/esm/Search/Stores/index.d.ts +8 -0
- package/dist/esm/Search/Stores/index.d.ts.map +1 -0
- package/dist/esm/Search/Stores/index.js +7 -0
- package/dist/esm/Storage/StorageStore.d.ts +25 -0
- package/dist/esm/Storage/StorageStore.d.ts.map +1 -0
- package/dist/esm/Storage/StorageStore.js +123 -0
- package/dist/esm/index.d.ts +8 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +7 -0
- package/dist/esm/types.d.ts +81 -0
- package/dist/esm/types.d.ts.map +1 -0
- package/dist/esm/types.js +6 -0
- package/package.json +34 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2022 Searchspring
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
# Snap MobX Store
|
|
2
|
+
|
|
3
|
+
<a href="https://www.npmjs.com/package/@searchspring/snap-store-mobx"><img alt="NPM Status" src="https://img.shields.io/npm/v/@searchspring/snap-store-mobx.svg?style=flat"></a>
|
|
4
|
+
|
|
5
|
+
Management of Snap state using Mobx.
|
|
6
|
+
|
|
7
|
+
## Dependency
|
|
8
|
+
|
|
9
|
+
Snap Store MobX is a dependency of [@searchspring/snap-controller](https://github.com/searchspring/snap/tree/main/packages/snap-controller) <a href="https://www.npmjs.com/package/@searchspring/snap-controller"><img alt="NPM Status" src="https://img.shields.io/npm/v/@searchspring/snap-controller.svg?style=flat"></a>
|
|
10
|
+
|
|
11
|
+
## Dependencies
|
|
12
|
+
|
|
13
|
+
Snap Store MobX requires the following dependencies as services:
|
|
14
|
+
|
|
15
|
+
<a href="https://www.npmjs.com/package/@searchspring/snap-url-manager"><img alt="NPM Status" src="https://img.shields.io/npm/v/@searchspring/snap-url-manager.svg?style=flat"></a> [@searchspring/snap-url-manager](https://github.com/searchspring/snap/tree/main/packages/snap-url-manager)
|
|
16
|
+
|
|
17
|
+
## Installation
|
|
18
|
+
|
|
19
|
+
```bash
|
|
20
|
+
npm install --save @searchspring/snap-store-mobx
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
## Import
|
|
24
|
+
```typescript
|
|
25
|
+
import { AbstractStore, SearchStore, AutocompleteStore, FinderStore, RecommendationStore, StorageStore } from '@searchspring/snap-store-mobx';
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
## Controller usage
|
|
29
|
+
|
|
30
|
+
Snap Store MobX is a dependency of Snap Controller which will handle store changes as needed. As such, it is recommended to use methods of the controller to access and update the store.
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
## Standalone usage
|
|
34
|
+
|
|
35
|
+
```typescript
|
|
36
|
+
import { SearchStore } from '@searchspring/snap-store-mobx'
|
|
37
|
+
import { UrlManager, UrlTranslator } from '@searchspring/snap-url-manager';
|
|
38
|
+
|
|
39
|
+
const searchConfig = {
|
|
40
|
+
id: 'search',
|
|
41
|
+
globals: {
|
|
42
|
+
pagination: {
|
|
43
|
+
pageSize: 12
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
const store = new SearchStore(searchConfig, { urlManager: new UrlManager(new UrlTranslator()) });
|
|
49
|
+
|
|
50
|
+
store.update(data);
|
|
51
|
+
|
|
52
|
+
// log the store
|
|
53
|
+
console.log(store.toJSON());
|
|
54
|
+
```
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { StoreConfigs, ErrorType } from '../types';
|
|
2
|
+
export declare abstract class AbstractStore {
|
|
3
|
+
protected controller: any;
|
|
4
|
+
custom: {};
|
|
5
|
+
loading: boolean;
|
|
6
|
+
loaded: boolean;
|
|
7
|
+
error: {
|
|
8
|
+
code?: number;
|
|
9
|
+
type: ErrorType;
|
|
10
|
+
message: string;
|
|
11
|
+
};
|
|
12
|
+
config: StoreConfigs;
|
|
13
|
+
constructor(config: StoreConfigs);
|
|
14
|
+
setConfig(newConfig: StoreConfigs): void;
|
|
15
|
+
abstract update(data: any): void;
|
|
16
|
+
toJSON(thing?: this): this;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=AbstractStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractStore.d.ts","sourceRoot":"","sources":["../../../src/Abstract/AbstractStore.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAOxD,8BAAsB,aAAa;IAClC,SAAS,CAAC,UAAU,MAAC;IACd,MAAM,KAAM;IACZ,OAAO,UAAS;IAChB,MAAM,UAAS;IACf,KAAK,EAAE;QACb,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,IAAI,EAAE,SAAS,CAAC;QAChB,OAAO,EAAE,MAAM,CAAC;KAChB,CAAC;IACK,MAAM,EAAE,YAAY,CAAC;gBAEhB,MAAM,EAAE,YAAY;IAUhC,SAAS,CAAC,SAAS,EAAE,YAAY,GAAG,IAAI;IAIxC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAA,GAAG,IAAI;IAE3B,MAAM,CAAC,KAAK,OAAO;CAInB"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AbstractStore = void 0;
|
|
4
|
+
var mobx_1 = require("mobx");
|
|
5
|
+
(0, mobx_1.configure)({
|
|
6
|
+
// useProxies: "never", // for IE 11 (es5) support
|
|
7
|
+
enforceActions: 'never',
|
|
8
|
+
});
|
|
9
|
+
var AbstractStore = /** @class */ (function () {
|
|
10
|
+
function AbstractStore(config) {
|
|
11
|
+
this.custom = {};
|
|
12
|
+
this.loading = false;
|
|
13
|
+
this.loaded = false;
|
|
14
|
+
this.config = config;
|
|
15
|
+
(0, mobx_1.makeObservable)(this, {
|
|
16
|
+
custom: mobx_1.observable,
|
|
17
|
+
loading: mobx_1.observable,
|
|
18
|
+
loaded: mobx_1.observable,
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
AbstractStore.prototype.setConfig = function (newConfig) {
|
|
22
|
+
this.config = newConfig;
|
|
23
|
+
};
|
|
24
|
+
AbstractStore.prototype.toJSON = function (thing) {
|
|
25
|
+
if (thing === void 0) { thing = this; }
|
|
26
|
+
// TODO: make this work better
|
|
27
|
+
return (0, mobx_1.toJS)(thing);
|
|
28
|
+
};
|
|
29
|
+
return AbstractStore;
|
|
30
|
+
}());
|
|
31
|
+
exports.AbstractStore = AbstractStore;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { AutocompleteResponseModel, MetaResponseModel } from '@searchspring/snapi-types';
|
|
2
|
+
import { AbstractStore } from '../Abstract/AbstractStore';
|
|
3
|
+
import { FilterStore, ResultStore, MerchandisingStore, PaginationStore, SortingStore } from '../Search/Stores';
|
|
4
|
+
import { StorageStore } from '../Storage/StorageStore';
|
|
5
|
+
import type { AutocompleteStoreConfig, StoreServices } from '../types';
|
|
6
|
+
import { StateStore, TermStore, QueryStore, FacetStore, TrendingStore } from './Stores';
|
|
7
|
+
export declare class AutocompleteStore extends AbstractStore {
|
|
8
|
+
config: AutocompleteStoreConfig;
|
|
9
|
+
services: StoreServices;
|
|
10
|
+
meta: MetaResponseModel;
|
|
11
|
+
merchandising: MerchandisingStore;
|
|
12
|
+
search: QueryStore;
|
|
13
|
+
terms: TermStore;
|
|
14
|
+
facets: FacetStore;
|
|
15
|
+
filters: FilterStore;
|
|
16
|
+
results: ResultStore;
|
|
17
|
+
pagination: PaginationStore;
|
|
18
|
+
sorting: SortingStore;
|
|
19
|
+
state: StateStore;
|
|
20
|
+
storage: StorageStore;
|
|
21
|
+
trending: TrendingStore;
|
|
22
|
+
constructor(config: AutocompleteStoreConfig, services: StoreServices);
|
|
23
|
+
reset(): void;
|
|
24
|
+
resetTrending(): void;
|
|
25
|
+
resetTerms(): void;
|
|
26
|
+
setService(name: any, service: any): void;
|
|
27
|
+
updateTrendingTerms(data: any): void;
|
|
28
|
+
update(data: AutocompleteResponseModel & {
|
|
29
|
+
meta: MetaResponseModel;
|
|
30
|
+
}): void;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=AutocompleteStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AutocompleteStore.d.ts","sourceRoot":"","sources":["../../../src/Autocomplete/AutocompleteStore.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,yBAAyB,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9F,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,kBAAkB,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAC/G,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,KAAK,EAAE,uBAAuB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEvE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACxF,qBAAa,iBAAkB,SAAQ,aAAa;IACnD,MAAM,EAAE,uBAAuB,CAAC;IAChC,QAAQ,EAAE,aAAa,CAAC;IACxB,IAAI,EAAE,iBAAiB,CAAM;IAE7B,aAAa,EAAE,kBAAkB,CAAC;IAClC,MAAM,EAAE,UAAU,CAAC;IACnB,KAAK,EAAE,SAAS,CAAC;IACjB,MAAM,EAAE,UAAU,CAAC;IACnB,OAAO,EAAE,WAAW,CAAC;IACrB,OAAO,EAAE,WAAW,CAAC;IACrB,UAAU,EAAE,eAAe,CAAC;IAC5B,OAAO,EAAE,YAAY,CAAC;IACtB,KAAK,EAAE,UAAU,CAAC;IAClB,OAAO,EAAE,YAAY,CAAC;IACtB,QAAQ,EAAE,aAAa,CAAC;gBAEZ,MAAM,EAAE,uBAAuB,EAAE,QAAQ,EAAE,aAAa;IA4BpE,KAAK,IAAI,IAAI;IAMb,aAAa,IAAI,IAAI;IAQrB,UAAU,IAAI,IAAI;IAQlB,UAAU,CAAC,IAAI,KAAA,EAAE,OAAO,KAAA,GAAG,IAAI;IAS/B,mBAAmB,CAAC,IAAI,KAAA,GAAG,IAAI;IAW/B,MAAM,CAAC,IAAI,EAAE,yBAAyB,GAAG;QAAE,IAAI,EAAE,iBAAiB,CAAA;KAAE,GAAG,IAAI;CA8C3E"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __extends = (this && this.__extends) || (function () {
|
|
3
|
+
var extendStatics = function (d, b) {
|
|
4
|
+
extendStatics = Object.setPrototypeOf ||
|
|
5
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
6
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
7
|
+
return extendStatics(d, b);
|
|
8
|
+
};
|
|
9
|
+
return function (d, b) {
|
|
10
|
+
if (typeof b !== "function" && b !== null)
|
|
11
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
12
|
+
extendStatics(d, b);
|
|
13
|
+
function __() { this.constructor = d; }
|
|
14
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
15
|
+
};
|
|
16
|
+
})();
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.AutocompleteStore = void 0;
|
|
19
|
+
var mobx_1 = require("mobx");
|
|
20
|
+
var AbstractStore_1 = require("../Abstract/AbstractStore");
|
|
21
|
+
var Stores_1 = require("../Search/Stores");
|
|
22
|
+
var StorageStore_1 = require("../Storage/StorageStore");
|
|
23
|
+
var Stores_2 = require("./Stores");
|
|
24
|
+
var AutocompleteStore = /** @class */ (function (_super) {
|
|
25
|
+
__extends(AutocompleteStore, _super);
|
|
26
|
+
function AutocompleteStore(config, services) {
|
|
27
|
+
var _a;
|
|
28
|
+
var _this = _super.call(this, config) || this;
|
|
29
|
+
_this.meta = {};
|
|
30
|
+
if (typeof services != 'object' || typeof ((_a = services.urlManager) === null || _a === void 0 ? void 0 : _a.subscribe) != 'function') {
|
|
31
|
+
throw new Error("Invalid service 'urlManager' passed to AutocompleteStore. Missing \"subscribe\" function.");
|
|
32
|
+
}
|
|
33
|
+
_this.services = services;
|
|
34
|
+
_this.state = new Stores_2.StateStore(services);
|
|
35
|
+
_this.storage = new StorageStore_1.StorageStore();
|
|
36
|
+
_this.trending = [];
|
|
37
|
+
_this.reset();
|
|
38
|
+
(0, mobx_1.makeObservable)(_this, {
|
|
39
|
+
state: mobx_1.observable,
|
|
40
|
+
search: mobx_1.observable,
|
|
41
|
+
terms: mobx_1.observable,
|
|
42
|
+
facets: mobx_1.observable,
|
|
43
|
+
filters: mobx_1.observable,
|
|
44
|
+
merchandising: mobx_1.observable,
|
|
45
|
+
results: mobx_1.observable,
|
|
46
|
+
pagination: mobx_1.observable,
|
|
47
|
+
sorting: mobx_1.observable,
|
|
48
|
+
});
|
|
49
|
+
return _this;
|
|
50
|
+
}
|
|
51
|
+
AutocompleteStore.prototype.reset = function () {
|
|
52
|
+
this.state.reset();
|
|
53
|
+
this.update({ meta: this.meta });
|
|
54
|
+
this.resetTrending();
|
|
55
|
+
};
|
|
56
|
+
AutocompleteStore.prototype.resetTrending = function () {
|
|
57
|
+
var _a;
|
|
58
|
+
if ((_a = this.trending) === null || _a === void 0 ? void 0 : _a.length) {
|
|
59
|
+
this.trending.forEach(function (term) {
|
|
60
|
+
term.active = false;
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
AutocompleteStore.prototype.resetTerms = function () {
|
|
65
|
+
var _a;
|
|
66
|
+
if (((_a = this.terms) === null || _a === void 0 ? void 0 : _a.length) > 0) {
|
|
67
|
+
this.terms.forEach(function (term) {
|
|
68
|
+
term.active = false;
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
AutocompleteStore.prototype.setService = function (name, service) {
|
|
73
|
+
if (this.services[name] && service) {
|
|
74
|
+
this.services[name] = service;
|
|
75
|
+
if (name === 'urlManager') {
|
|
76
|
+
this.state.url = service;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
AutocompleteStore.prototype.updateTrendingTerms = function (data) {
|
|
81
|
+
var _this = this;
|
|
82
|
+
this.trending = new Stores_2.TrendingStore(this.services, data.trending, function () {
|
|
83
|
+
_this.resetTerms();
|
|
84
|
+
}, this.state);
|
|
85
|
+
};
|
|
86
|
+
AutocompleteStore.prototype.update = function (data) {
|
|
87
|
+
var _this = this;
|
|
88
|
+
this.error = undefined;
|
|
89
|
+
this.loaded = !!data.pagination;
|
|
90
|
+
this.meta = data.meta;
|
|
91
|
+
// set the query to match the actual queried term and not the input query
|
|
92
|
+
if (data.search) {
|
|
93
|
+
this.state.url = this.services.urlManager = this.services.urlManager.set('query', data.search.query);
|
|
94
|
+
}
|
|
95
|
+
// only run if we want to update the terms (not locked)
|
|
96
|
+
if (!this.state.locks.terms.locked) {
|
|
97
|
+
this.terms = new Stores_2.TermStore(this.services, data.autocomplete, data.pagination, function () {
|
|
98
|
+
_this.resetTrending();
|
|
99
|
+
}, this.state);
|
|
100
|
+
// only lock if there was data
|
|
101
|
+
data.autocomplete && this.state.locks.terms.lock();
|
|
102
|
+
}
|
|
103
|
+
this.merchandising = new Stores_1.MerchandisingStore(this.services, data.merchandising);
|
|
104
|
+
this.search = new Stores_2.QueryStore(this.services, data.autocomplete, data.search);
|
|
105
|
+
// only run if we want to update the facets (not locked)
|
|
106
|
+
if (!this.state.locks.facets.locked) {
|
|
107
|
+
this.facets = new Stores_2.FacetStore(this.config, this.services, this.storage, data.facets, data.pagination, this.meta, this.state);
|
|
108
|
+
}
|
|
109
|
+
this.filters = new Stores_1.FilterStore(this.services, data.filters, this.meta);
|
|
110
|
+
this.results = new Stores_1.ResultStore(this.config, this.services, data.results, data.pagination, data.merchandising);
|
|
111
|
+
if ((this.results.length === 0 && !this.trending.filter(function (term) { return term.active; }).length) || this.terms.filter(function (term) { return term.active; }).length) {
|
|
112
|
+
// if a trending term was selected and then a subsequent search yields no results, reset trending terms to remove active state
|
|
113
|
+
// OR if any terms are active, also reset to ensure only a single term or trending term is active
|
|
114
|
+
this.resetTrending();
|
|
115
|
+
}
|
|
116
|
+
this.pagination = new Stores_1.PaginationStore(this.config, this.services, data.pagination);
|
|
117
|
+
this.sorting = new Stores_1.SortingStore(this.services, data.sorting, data.search, this.meta);
|
|
118
|
+
};
|
|
119
|
+
return AutocompleteStore;
|
|
120
|
+
}(AbstractStore_1.AbstractStore));
|
|
121
|
+
exports.AutocompleteStore = AutocompleteStore;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { StorageStore } from '../../Storage/StorageStore';
|
|
2
|
+
import type { StateStore } from './StateStore';
|
|
3
|
+
import type { AutocompleteStoreConfig, SearchStoreConfig, StoreServices } from '../../types';
|
|
4
|
+
import type { SearchResponseModelFacet, SearchResponseModelPagination, MetaResponseModel } from '@searchspring/snapi-types';
|
|
5
|
+
export declare class FacetStore extends Array {
|
|
6
|
+
static get [Symbol.species](): ArrayConstructor;
|
|
7
|
+
constructor(config: SearchStoreConfig | AutocompleteStoreConfig, services: StoreServices, storage: StorageStore, facetsData: SearchResponseModelFacet[], paginationData: SearchResponseModelPagination, meta: MetaResponseModel, rootState: StateStore);
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=FacetStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FacetStore.d.ts","sourceRoot":"","sources":["../../../../src/Autocomplete/Stores/FacetStore.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,KAAK,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC7F,OAAO,KAAK,EAAE,wBAAwB,EAAE,6BAA6B,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAE5H,qBAAa,UAAW,SAAQ,KAAK;IACpC,MAAM,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,gBAAgB,CAE9C;gBAGA,MAAM,EAAE,iBAAiB,GAAG,uBAAuB,EACnD,QAAQ,EAAE,aAAa,EACvB,OAAO,EAAE,YAAY,EACrB,UAAU,EAAE,wBAAwB,EAAE,EACtC,cAAc,EAAE,6BAA6B,EAC7C,IAAI,EAAE,iBAAiB,EACvB,SAAS,EAAE,UAAU;CA2BtB"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __extends = (this && this.__extends) || (function () {
|
|
3
|
+
var extendStatics = function (d, b) {
|
|
4
|
+
extendStatics = Object.setPrototypeOf ||
|
|
5
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
6
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
7
|
+
return extendStatics(d, b);
|
|
8
|
+
};
|
|
9
|
+
return function (d, b) {
|
|
10
|
+
if (typeof b !== "function" && b !== null)
|
|
11
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
12
|
+
extendStatics(d, b);
|
|
13
|
+
function __() { this.constructor = d; }
|
|
14
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
15
|
+
};
|
|
16
|
+
})();
|
|
17
|
+
var __assign = (this && this.__assign) || function () {
|
|
18
|
+
__assign = Object.assign || function(t) {
|
|
19
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
20
|
+
s = arguments[i];
|
|
21
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
22
|
+
t[p] = s[p];
|
|
23
|
+
}
|
|
24
|
+
return t;
|
|
25
|
+
};
|
|
26
|
+
return __assign.apply(this, arguments);
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.FacetStore = void 0;
|
|
30
|
+
var Stores_1 = require("../../Search/Stores");
|
|
31
|
+
var FacetStore = /** @class */ (function (_super) {
|
|
32
|
+
__extends(FacetStore, _super);
|
|
33
|
+
function FacetStore(config, services, storage, facetsData, paginationData, meta, rootState) {
|
|
34
|
+
var _this = this;
|
|
35
|
+
// allow for only a singular facet option selection at a time
|
|
36
|
+
var alteredServices = __assign(__assign({}, services), { urlManager: services.urlManager.remove('filter') });
|
|
37
|
+
var facets = new Stores_1.FacetStore(config, alteredServices, storage, facetsData, paginationData, meta);
|
|
38
|
+
// mutate facet values to add 'preview' function
|
|
39
|
+
facets.forEach(function (facet) {
|
|
40
|
+
var _a;
|
|
41
|
+
(_a = facet.values) === null || _a === void 0 ? void 0 : _a.forEach(function (value) {
|
|
42
|
+
value.preview = function () {
|
|
43
|
+
facets.map(function (facet) {
|
|
44
|
+
var _a;
|
|
45
|
+
facet.filtered = false;
|
|
46
|
+
(_a = facet.values) === null || _a === void 0 ? void 0 : _a.map(function (value) {
|
|
47
|
+
value.filtered = false;
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
facet.filtered = true;
|
|
51
|
+
value.filtered = true;
|
|
52
|
+
rootState.locks.facets.lock();
|
|
53
|
+
value.url.go();
|
|
54
|
+
};
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
_this = _super.apply(this, facets) || this;
|
|
58
|
+
return _this;
|
|
59
|
+
}
|
|
60
|
+
Object.defineProperty(FacetStore, Symbol.species, {
|
|
61
|
+
get: function () {
|
|
62
|
+
return Array;
|
|
63
|
+
},
|
|
64
|
+
enumerable: false,
|
|
65
|
+
configurable: true
|
|
66
|
+
});
|
|
67
|
+
return FacetStore;
|
|
68
|
+
}(Array));
|
|
69
|
+
exports.FacetStore = FacetStore;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { UrlManager } from '@searchspring/snap-url-manager';
|
|
2
|
+
import type { SearchResponseModelSearch, AutocompleteResponseModelAllOfAutocomplete } from '@searchspring/snapi-types';
|
|
3
|
+
import type { StoreServices } from '../../types';
|
|
4
|
+
export declare class QueryStore {
|
|
5
|
+
query: Query;
|
|
6
|
+
originalQuery: Query;
|
|
7
|
+
constructor(services: StoreServices, autocomplete: AutocompleteResponseModelAllOfAutocomplete, search: SearchResponseModelSearch);
|
|
8
|
+
}
|
|
9
|
+
declare class Query {
|
|
10
|
+
string: string;
|
|
11
|
+
url: UrlManager;
|
|
12
|
+
constructor(urlManager: any, query: any);
|
|
13
|
+
}
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=QueryStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"QueryStore.d.ts","sourceRoot":"","sources":["../../../../src/Autocomplete/Stores/QueryStore.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,KAAK,EAAE,yBAAyB,EAAE,0CAA0C,EAAE,MAAM,2BAA2B,CAAC;AACvH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAEjD,qBAAa,UAAU;IACtB,KAAK,EAAE,KAAK,CAAC;IACb,aAAa,EAAE,KAAK,CAAC;gBAET,QAAQ,EAAE,aAAa,EAAE,YAAY,EAAE,0CAA0C,EAAE,MAAM,EAAE,yBAAyB;CAehI;AAMD,cAAM,KAAK;IACV,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,UAAU,CAAC;gBAEJ,UAAU,KAAA,EAAE,KAAK,KAAA;CAS7B"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.QueryStore = void 0;
|
|
4
|
+
var mobx_1 = require("mobx");
|
|
5
|
+
var QueryStore = /** @class */ (function () {
|
|
6
|
+
function QueryStore(services, autocomplete, search) {
|
|
7
|
+
var observables = {};
|
|
8
|
+
if (search === null || search === void 0 ? void 0 : search.query) {
|
|
9
|
+
this.query = new Query(services.urlManager, search.query);
|
|
10
|
+
observables.query = mobx_1.observable;
|
|
11
|
+
}
|
|
12
|
+
if (autocomplete === null || autocomplete === void 0 ? void 0 : autocomplete.correctedQuery) {
|
|
13
|
+
this.originalQuery = new Query(services.urlManager, autocomplete.query);
|
|
14
|
+
observables.originalQuery = mobx_1.observable;
|
|
15
|
+
}
|
|
16
|
+
(0, mobx_1.makeObservable)(this, observables);
|
|
17
|
+
}
|
|
18
|
+
return QueryStore;
|
|
19
|
+
}());
|
|
20
|
+
exports.QueryStore = QueryStore;
|
|
21
|
+
var Query = /** @class */ (function () {
|
|
22
|
+
function Query(urlManager, query) {
|
|
23
|
+
this.string = query;
|
|
24
|
+
this.url = urlManager.set({ query: this.string });
|
|
25
|
+
(0, mobx_1.makeObservable)(this, {
|
|
26
|
+
string: mobx_1.observable,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
return Query;
|
|
30
|
+
}());
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { UrlManager } from '@searchspring/snap-url-manager';
|
|
2
|
+
import type { StoreServices } from '../../types';
|
|
3
|
+
export declare class StateStore {
|
|
4
|
+
locks: {
|
|
5
|
+
terms: Lock;
|
|
6
|
+
facets: Lock;
|
|
7
|
+
};
|
|
8
|
+
focusedInput: HTMLInputElement;
|
|
9
|
+
input: string;
|
|
10
|
+
url: UrlManager;
|
|
11
|
+
constructor(services: StoreServices);
|
|
12
|
+
reset(): void;
|
|
13
|
+
}
|
|
14
|
+
export declare class Lock {
|
|
15
|
+
private state;
|
|
16
|
+
private startState;
|
|
17
|
+
constructor(state?: boolean);
|
|
18
|
+
reset(): void;
|
|
19
|
+
get locked(): boolean;
|
|
20
|
+
lock(): void;
|
|
21
|
+
unlock(): void;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=StateStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StateStore.d.ts","sourceRoot":"","sources":["../../../../src/Autocomplete/Stores/StateStore.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAEjD,qBAAa,UAAU;IACtB,KAAK,EAAE;QACN,KAAK,EAAE,IAAI,CAAC;QACZ,MAAM,EAAE,IAAI,CAAC;KACb,CAAC;IACF,YAAY,EAAE,gBAAgB,CAAa;IAC3C,KAAK,SAAM;IACX,GAAG,EAAE,UAAU,CAAC;gBAEJ,QAAQ,EAAE,aAAa;IAgBnC,KAAK,IAAI,IAAI;CAKb;AAED,qBAAa,IAAI;IAChB,OAAO,CAAC,KAAK,CAAU;IACvB,OAAO,CAAC,UAAU,CAAU;gBAEhB,KAAK,UAAQ;IAIzB,KAAK,IAAI,IAAI;IAIb,IAAI,MAAM,IAAI,OAAO,CAEpB;IAED,IAAI,IAAI,IAAI;IAIZ,MAAM,IAAI,IAAI;CAGd"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Lock = exports.StateStore = void 0;
|
|
4
|
+
var mobx_1 = require("mobx");
|
|
5
|
+
var StateStore = /** @class */ (function () {
|
|
6
|
+
function StateStore(services) {
|
|
7
|
+
this.focusedInput = undefined;
|
|
8
|
+
this.input = '';
|
|
9
|
+
this.locks = {
|
|
10
|
+
terms: new Lock(false),
|
|
11
|
+
facets: new Lock(false),
|
|
12
|
+
};
|
|
13
|
+
this.url = services.urlManager;
|
|
14
|
+
(0, mobx_1.makeObservable)(this, {
|
|
15
|
+
focusedInput: mobx_1.observable,
|
|
16
|
+
locks: mobx_1.observable,
|
|
17
|
+
input: mobx_1.observable,
|
|
18
|
+
reset: mobx_1.action,
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
StateStore.prototype.reset = function () {
|
|
22
|
+
this.input = '';
|
|
23
|
+
this.locks.terms.reset();
|
|
24
|
+
this.locks.facets.reset();
|
|
25
|
+
};
|
|
26
|
+
return StateStore;
|
|
27
|
+
}());
|
|
28
|
+
exports.StateStore = StateStore;
|
|
29
|
+
var Lock = /** @class */ (function () {
|
|
30
|
+
function Lock(state) {
|
|
31
|
+
if (state === void 0) { state = false; }
|
|
32
|
+
this.state = this.startState = state;
|
|
33
|
+
}
|
|
34
|
+
Lock.prototype.reset = function () {
|
|
35
|
+
this.state = this.startState;
|
|
36
|
+
};
|
|
37
|
+
Object.defineProperty(Lock.prototype, "locked", {
|
|
38
|
+
get: function () {
|
|
39
|
+
return this.state;
|
|
40
|
+
},
|
|
41
|
+
enumerable: false,
|
|
42
|
+
configurable: true
|
|
43
|
+
});
|
|
44
|
+
Lock.prototype.lock = function () {
|
|
45
|
+
this.state = true;
|
|
46
|
+
};
|
|
47
|
+
Lock.prototype.unlock = function () {
|
|
48
|
+
this.state = false;
|
|
49
|
+
};
|
|
50
|
+
return Lock;
|
|
51
|
+
}());
|
|
52
|
+
exports.Lock = Lock;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { UrlManager } from '@searchspring/snap-url-manager';
|
|
2
|
+
import type { StateStore } from './StateStore';
|
|
3
|
+
import type { StoreServices } from '../../types';
|
|
4
|
+
import type { AutocompleteResponseModelAllOfAutocomplete, SearchResponseModelPagination } from '@searchspring/snapi-types';
|
|
5
|
+
export declare class TermStore extends Array {
|
|
6
|
+
static get [Symbol.species](): ArrayConstructor;
|
|
7
|
+
constructor(services: StoreServices, autocomplete: AutocompleteResponseModelAllOfAutocomplete, paginationData: SearchResponseModelPagination, resetTerms: () => void, rootState: StateStore);
|
|
8
|
+
}
|
|
9
|
+
export declare class Term {
|
|
10
|
+
active: boolean;
|
|
11
|
+
value: string;
|
|
12
|
+
preview: () => void;
|
|
13
|
+
url: UrlManager;
|
|
14
|
+
constructor(services: StoreServices, term: {
|
|
15
|
+
active: boolean;
|
|
16
|
+
value: string;
|
|
17
|
+
}, terms: Term[], resetTerms: () => void, rootState: StateStore);
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=TermStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TermStore.d.ts","sourceRoot":"","sources":["../../../../src/Autocomplete/Stores/TermStore.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,KAAK,EAAE,0CAA0C,EAAE,6BAA6B,EAAE,MAAM,2BAA2B,CAAC;AAE3H,qBAAa,SAAU,SAAQ,KAAK;IACnC,MAAM,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,gBAAgB,CAE9C;gBAGA,QAAQ,EAAE,aAAa,EACvB,YAAY,EAAE,0CAA0C,EACxD,cAAc,EAAE,6BAA6B,EAC7C,UAAU,EAAE,MAAM,IAAI,EACtB,SAAS,EAAE,UAAU;CA6BtB;AAED,qBAAa,IAAI;IAChB,MAAM,EAAE,OAAO,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,GAAG,EAAE,UAAU,CAAC;gBAEJ,QAAQ,EAAE,aAAa,EAAE,IAAI,EAAE;QAAE,MAAM,EAAE,OAAO,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,MAAM,IAAI,EAAE,SAAS,EAAE,UAAU;CAwB3I"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __extends = (this && this.__extends) || (function () {
|
|
3
|
+
var extendStatics = function (d, b) {
|
|
4
|
+
extendStatics = Object.setPrototypeOf ||
|
|
5
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
6
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
7
|
+
return extendStatics(d, b);
|
|
8
|
+
};
|
|
9
|
+
return function (d, b) {
|
|
10
|
+
if (typeof b !== "function" && b !== null)
|
|
11
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
12
|
+
extendStatics(d, b);
|
|
13
|
+
function __() { this.constructor = d; }
|
|
14
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
15
|
+
};
|
|
16
|
+
})();
|
|
17
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
18
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
19
|
+
if (ar || !(i in from)) {
|
|
20
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
21
|
+
ar[i] = from[i];
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
25
|
+
};
|
|
26
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
27
|
+
exports.Term = exports.TermStore = void 0;
|
|
28
|
+
var mobx_1 = require("mobx");
|
|
29
|
+
var TermStore = /** @class */ (function (_super) {
|
|
30
|
+
__extends(TermStore, _super);
|
|
31
|
+
function TermStore(services, autocomplete, paginationData, resetTerms, rootState) {
|
|
32
|
+
var _a;
|
|
33
|
+
var _this = this;
|
|
34
|
+
var suggestions = __spreadArray([], ((autocomplete === null || autocomplete === void 0 ? void 0 : autocomplete.alternatives) ? autocomplete.alternatives : []).map(function (term) { return term.text; }), true);
|
|
35
|
+
if ((_a = autocomplete === null || autocomplete === void 0 ? void 0 : autocomplete.suggested) === null || _a === void 0 ? void 0 : _a.text) {
|
|
36
|
+
suggestions.unshift(autocomplete.suggested.text);
|
|
37
|
+
}
|
|
38
|
+
else if ((autocomplete === null || autocomplete === void 0 ? void 0 : autocomplete.query) && paginationData.totalResults) {
|
|
39
|
+
suggestions.unshift(autocomplete === null || autocomplete === void 0 ? void 0 : autocomplete.query);
|
|
40
|
+
}
|
|
41
|
+
var terms = [];
|
|
42
|
+
suggestions.map(function (term, index) {
|
|
43
|
+
return terms.push(new Term(services, {
|
|
44
|
+
active: index === 0,
|
|
45
|
+
value: term,
|
|
46
|
+
}, terms, resetTerms, rootState));
|
|
47
|
+
});
|
|
48
|
+
_this = _super.apply(this, terms) || this;
|
|
49
|
+
return _this;
|
|
50
|
+
}
|
|
51
|
+
Object.defineProperty(TermStore, Symbol.species, {
|
|
52
|
+
get: function () {
|
|
53
|
+
return Array;
|
|
54
|
+
},
|
|
55
|
+
enumerable: false,
|
|
56
|
+
configurable: true
|
|
57
|
+
});
|
|
58
|
+
return TermStore;
|
|
59
|
+
}(Array));
|
|
60
|
+
exports.TermStore = TermStore;
|
|
61
|
+
var Term = /** @class */ (function () {
|
|
62
|
+
function Term(services, term, terms, resetTerms, rootState) {
|
|
63
|
+
var _this = this;
|
|
64
|
+
var _a;
|
|
65
|
+
this.active = term.active;
|
|
66
|
+
this.value = term.value;
|
|
67
|
+
this.url = (_a = services === null || services === void 0 ? void 0 : services.urlManager) === null || _a === void 0 ? void 0 : _a.set({ query: this.value });
|
|
68
|
+
this.preview = function () {
|
|
69
|
+
var _a;
|
|
70
|
+
resetTerms();
|
|
71
|
+
terms.map(function (term) {
|
|
72
|
+
term.active = false;
|
|
73
|
+
});
|
|
74
|
+
_this.active = true;
|
|
75
|
+
rootState.locks.terms.lock();
|
|
76
|
+
rootState.locks.facets.unlock();
|
|
77
|
+
(_a = _this.url) === null || _a === void 0 ? void 0 : _a.set({ query: _this.value }).go();
|
|
78
|
+
};
|
|
79
|
+
(0, mobx_1.makeObservable)(this, {
|
|
80
|
+
active: mobx_1.observable,
|
|
81
|
+
value: mobx_1.observable,
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
return Term;
|
|
85
|
+
}());
|
|
86
|
+
exports.Term = Term;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { StoreServices } from '../../types';
|
|
2
|
+
import type { StateStore } from './StateStore';
|
|
3
|
+
export declare class TrendingStore extends Array {
|
|
4
|
+
static get [Symbol.species](): ArrayConstructor;
|
|
5
|
+
constructor(services: StoreServices, trendingData: any, resetTerms: () => void, rootState: StateStore);
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=TrendingStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TrendingStore.d.ts","sourceRoot":"","sources":["../../../../src/Autocomplete/Stores/TrendingStore.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG/C,qBAAa,aAAc,SAAQ,KAAK;IACvC,MAAM,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,gBAAgB,CAE9C;gBAEW,QAAQ,EAAE,aAAa,EAAE,YAAY,KAAA,EAAE,UAAU,EAAE,MAAM,IAAI,EAAE,SAAS,EAAE,UAAU;CAoBhG"}
|