/
infinite-hits.stories.js
67 lines (63 loc) · 1.67 KB
/
infinite-hits.stories.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/* eslint-disable import/default */
import { storiesOf } from 'dev-novel';
import instantsearch from '../../../../index';
import { wrapWithHits } from '../../utils/wrap-with-hits.js';
const stories = storiesOf('InfiniteHits');
export default () => {
stories
.add(
'default',
wrapWithHits(container => {
window.search.addWidget(
instantsearch.widgets.infiniteHits({
container,
showMoreLabel: 'Show more',
templates: {
item: '{{name}}',
},
})
);
})
)
.add(
'with custom css classes',
wrapWithHits(container => {
const style = window.document.createElement('style');
window.document.head.appendChild(style);
style.sheet.insertRule(
'.button button{border: 1px solid black; background: #fff;}'
);
window.search.addWidget(
instantsearch.widgets.infiniteHits({
container,
showMoreLabel: 'Show more',
cssClasses: {
showmore: 'button',
},
templates: {
item: '{{name}}',
},
})
);
})
)
.add(
'with transformed items',
wrapWithHits(container => {
window.search.addWidget(
instantsearch.widgets.infiniteHits({
container,
showMoreLabel: 'Show more',
templates: {
item: '{{name}}',
},
transformItems: items =>
items.map(item => ({
...item,
name: `${item.name} (transformed)`,
})),
})
);
})
);
};