vue-instantsearch 4.14.0 → 4.15.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.
Files changed (30) hide show
  1. package/package.json +4 -4
  2. package/src/__tests__/common-widgets.test.js +16 -0
  3. package/src/components/RefinementList.vue +3 -2
  4. package/src/components/SearchInput.vue +0 -1
  5. package/src/components/__tests__/NumericMenu.js +0 -51
  6. package/vue2/cjs/index.js +1 -1
  7. package/vue2/cjs/index.js.map +1 -1
  8. package/vue2/es/package.json.js +1 -1
  9. package/vue2/es/src/components/RefinementList.vue.js +1 -1
  10. package/vue2/es/src/components/RefinementList.vue_rollup-plugin-vue=script.js.map +1 -1
  11. package/vue2/umd/index.js +1 -1
  12. package/vue2/umd/index.js.map +1 -1
  13. package/vue3/cjs/index.js +1 -1
  14. package/vue3/cjs/index.js.map +1 -1
  15. package/vue3/es/package.json.js +1 -1
  16. package/vue3/es/src/components/RefinementList.vue.js +1 -1
  17. package/vue3/es/src/components/RefinementList.vue_vue&type=script&lang.js.map +1 -1
  18. package/vue3/es/src/components/RefinementList.vue_vue&type=template&id=e39e9d16&lang.js +2 -0
  19. package/vue3/es/src/components/RefinementList.vue_vue&type=template&id=e39e9d16&lang.js.map +1 -0
  20. package/vue3/es/src/components/SearchInput.vue.js +1 -1
  21. package/vue3/es/src/components/SearchInput.vue_vue&type=script&lang.js.map +1 -1
  22. package/vue3/es/src/components/{SearchInput.vue_vue&type=template&id=02fb82e2&lang.js → SearchInput.vue_vue&type=template&id=79e30e4e&lang.js} +1 -1
  23. package/vue3/es/src/components/SearchInput.vue_vue&type=template&id=79e30e4e&lang.js.map +1 -0
  24. package/vue3/umd/index.js +1 -1
  25. package/vue3/umd/index.js.map +1 -1
  26. package/src/components/__tests__/RefinementList.js +0 -199
  27. package/src/components/__tests__/__snapshots__/RefinementList.js.snap +0 -405
  28. package/vue3/es/src/components/RefinementList.vue_vue&type=template&id=80c1baee&lang.js +0 -2
  29. package/vue3/es/src/components/RefinementList.vue_vue&type=template&id=80c1baee&lang.js.map +0 -1
  30. package/vue3/es/src/components/SearchInput.vue_vue&type=template&id=02fb82e2&lang.js.map +0 -1
package/package.json CHANGED
@@ -16,7 +16,7 @@
16
16
  "autocomplete"
17
17
  ],
18
18
  "license": "MIT",
19
- "version": "4.14.0",
19
+ "version": "4.15.0",
20
20
  "files": [
21
21
  "vue2",
22
22
  "vue3",
@@ -37,7 +37,7 @@
37
37
  },
38
38
  "dependencies": {
39
39
  "instantsearch-ui-components": "0.4.0",
40
- "instantsearch.js": "4.66.0",
40
+ "instantsearch.js": "4.66.1",
41
41
  "mitt": "^2.1.0"
42
42
  },
43
43
  "peerDependencies": {
@@ -62,7 +62,7 @@
62
62
  "@vue/test-utils": "1.3.0",
63
63
  "@vue/test-utils2": "npm:@vue/test-utils@2.0.0-rc.11",
64
64
  "algoliasearch": "4.22.1",
65
- "algoliasearch-helper": "3.16.3",
65
+ "algoliasearch-helper": "3.17.0",
66
66
  "instantsearch.css": "8.1.0",
67
67
  "rollup": "1.32.1",
68
68
  "rollup-plugin-babel": "4.4.0",
@@ -89,5 +89,5 @@
89
89
  "vuex": "3.5.1",
90
90
  "vuex4": "npm:vuex@4.0.0"
91
91
  },
92
- "gitHead": "358f849cba15cbbb415da05feb582b47358aa239"
92
+ "gitHead": "d309ca3333476a842be080fcb01b8be925aad204"
93
93
  }
@@ -25,6 +25,7 @@ import {
25
25
  AisSortBy,
26
26
  AisStats,
27
27
  AisRatingMenu,
28
+ AisNumericMenu,
28
29
  } from '../instantsearch';
29
30
  import { renderCompat } from '../util/vue-compat';
30
31
 
@@ -421,6 +422,21 @@ const testSetups = {
421
422
 
422
423
  await nextTick();
423
424
  },
425
+ async createNumericMenuWidgetTests({ instantSearchOptions, widgetParams }) {
426
+ mountApp(
427
+ {
428
+ render: renderCompat((h) =>
429
+ h(AisInstantSearch, { props: instantSearchOptions }, [
430
+ h(AisNumericMenu, { props: widgetParams }),
431
+ h(GlobalErrorSwallower),
432
+ ])
433
+ ),
434
+ },
435
+ document.body.appendChild(document.createElement('div'))
436
+ );
437
+
438
+ await nextTick();
439
+ },
424
440
  async createToggleRefinementWidgetTests({
425
441
  instantSearchOptions,
426
442
  widgetParams,
@@ -1,6 +1,6 @@
1
1
  <template>
2
2
  <div
3
- :class="[suit(), !state.canRefine && suit('', 'noRefinement')]"
3
+ :class="[suit(), items.length === 0 && suit('', 'noRefinement')]"
4
4
  v-if="state"
5
5
  >
6
6
  <slot
@@ -19,6 +19,7 @@
19
19
  <div :class="suit('searchBox')" v-if="searchable">
20
20
  <search-input
21
21
  v-model="searchForFacetValues"
22
+ :show-loading-indicator="true"
22
23
  :placeholder="searchablePlaceholder"
23
24
  :class-names="classNames"
24
25
  />
@@ -30,7 +31,7 @@
30
31
  >
31
32
  <div :class="suit('noResults')">No results.</div>
32
33
  </slot>
33
- <ul :class="suit('list')">
34
+ <ul v-if="items.length > 0" :class="suit('list')">
34
35
  <li
35
36
  :class="[suit('item'), item.isRefined && suit('item', 'selected')]"
36
37
  v-for="item in items"
@@ -47,7 +47,6 @@
47
47
  </svg>
48
48
  </slot>
49
49
  </button>
50
-
51
50
  <button
52
51
  type="reset"
53
52
  :title="resetTitle"
@@ -62,57 +62,6 @@ const defaultProps = {
62
62
  ],
63
63
  };
64
64
 
65
- it('accepts an attribute prop', () => {
66
- __setState(defaultState);
67
-
68
- const props = {
69
- ...defaultProps,
70
- };
71
-
72
- const wrapper = mount(NumericMenu, {
73
- propsData: props,
74
- });
75
-
76
- expect(wrapper.vm.widgetParams.attribute).toBe('brand');
77
- });
78
-
79
- it('accepts an items prop', () => {
80
- __setState(defaultState);
81
-
82
- const props = {
83
- ...defaultProps,
84
- };
85
-
86
- const wrapper = mount(NumericMenu, {
87
- propsData: props,
88
- });
89
-
90
- expect(wrapper.vm.widgetParams.items).toEqual([
91
- { label: 'All' },
92
- { label: '<= 10$', end: 10 },
93
- { label: '10$ - 100$', start: 10, end: 100 },
94
- { label: '100$ - 500$', start: 100, end: 500 },
95
- { label: '>= 500$', start: 500 },
96
- ]);
97
- });
98
-
99
- it('accepts an transformItems prop', () => {
100
- __setState(defaultState);
101
-
102
- const identity = (x) => x;
103
-
104
- const props = {
105
- ...defaultProps,
106
- transformItems: identity,
107
- };
108
-
109
- const wrapper = mount(NumericMenu, {
110
- propsData: props,
111
- });
112
-
113
- expect(wrapper.vm.widgetParams.transformItems).toBe(identity);
114
- });
115
-
116
65
  describe('default render', () => {
117
66
  it('renders correctly', () => {
118
67
  __setState(defaultState);