instantsearch.js 4.70.0 → 4.71.1

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 (77) hide show
  1. package/cjs/connectors/frequently-bought-together/connectFrequentlyBoughtTogether.js +1 -2
  2. package/cjs/connectors/geo-search/connectGeoSearch.js +4 -3
  3. package/cjs/connectors/hits/connectHits.js +10 -7
  4. package/cjs/connectors/infinite-hits/connectInfiniteHits.js +7 -8
  5. package/cjs/connectors/looking-similar/connectLookingSimilar.js +2 -3
  6. package/cjs/connectors/related-products/connectRelatedProducts.js +2 -3
  7. package/cjs/connectors/trending-items/connectTrendingItems.js +5 -3
  8. package/cjs/lib/InstantSearch.js +2 -2
  9. package/cjs/lib/version.js +1 -1
  10. package/cjs/widgets/frequently-bought-together/frequently-bought-together.js +1 -3
  11. package/cjs/widgets/geo-search/geo-search.js +4 -3
  12. package/cjs/widgets/hits/defaultTemplates.js +2 -0
  13. package/cjs/widgets/hits/hits.js +3 -4
  14. package/cjs/widgets/infinite-hits/infinite-hits.js +3 -4
  15. package/cjs/widgets/looking-similar/looking-similar.js +4 -6
  16. package/cjs/widgets/rating-menu/defaultTemplates.js +1 -0
  17. package/cjs/widgets/related-products/related-products.js +1 -3
  18. package/cjs/widgets/trending-items/trending-items.js +1 -3
  19. package/dist/instantsearch.development.d.ts +4298 -235
  20. package/dist/instantsearch.development.js +8535 -8525
  21. package/dist/instantsearch.development.js.map +1 -1
  22. package/dist/instantsearch.production.d.ts +4298 -235
  23. package/dist/instantsearch.production.min.d.ts +4298 -235
  24. package/dist/instantsearch.production.min.js +2 -2
  25. package/dist/instantsearch.production.min.js.map +1 -1
  26. package/es/connectors/frequently-bought-together/connectFrequentlyBoughtTogether.d.ts +311 -7
  27. package/es/connectors/frequently-bought-together/connectFrequentlyBoughtTogether.js +2 -3
  28. package/es/connectors/geo-search/connectGeoSearch.d.ts +218 -8
  29. package/es/connectors/geo-search/connectGeoSearch.js +5 -4
  30. package/es/connectors/hits/connectHits.d.ts +128 -7
  31. package/es/connectors/hits/connectHits.js +11 -8
  32. package/es/connectors/hits/connectHitsWithInsights.d.ts +190 -1
  33. package/es/connectors/infinite-hits/connectInfiniteHits.d.ts +192 -12
  34. package/es/connectors/infinite-hits/connectInfiniteHits.js +8 -9
  35. package/es/connectors/infinite-hits/connectInfiniteHitsWithInsights.d.ts +249 -1
  36. package/es/connectors/looking-similar/connectLookingSimilar.d.ts +303 -7
  37. package/es/connectors/looking-similar/connectLookingSimilar.js +3 -4
  38. package/es/connectors/related-products/connectRelatedProducts.d.ts +303 -7
  39. package/es/connectors/related-products/connectRelatedProducts.js +3 -4
  40. package/es/connectors/trending-items/connectTrendingItems.d.ts +310 -9
  41. package/es/connectors/trending-items/connectTrendingItems.js +7 -5
  42. package/es/lib/InstantSearch.d.ts +1 -2
  43. package/es/lib/InstantSearch.js +1 -1
  44. package/es/lib/utils/checkIndexUiState.d.ts +1 -2
  45. package/es/lib/utils/checkRendering.d.ts +1 -1
  46. package/es/lib/utils/getWidgetAttribute.d.ts +1 -2
  47. package/es/lib/utils/isIndexWidget.d.ts +1 -2
  48. package/es/lib/utils/render-args.d.ts +1 -2
  49. package/es/lib/utils/resolveSearchParameters.d.ts +1 -1
  50. package/es/lib/utils/setIndexHelperState.d.ts +1 -2
  51. package/es/lib/version.d.ts +1 -1
  52. package/es/lib/version.js +1 -1
  53. package/es/types/index.d.ts +0 -1
  54. package/es/types/index.js +1 -4
  55. package/es/types/results.d.ts +4 -3
  56. package/es/types/widget.d.ts +2 -2
  57. package/es/widgets/frequently-bought-together/frequently-bought-together.d.ts +306 -9
  58. package/es/widgets/frequently-bought-together/frequently-bought-together.js +2 -4
  59. package/es/widgets/geo-search/geo-search.d.ts +328 -8
  60. package/es/widgets/geo-search/geo-search.js +5 -4
  61. package/es/widgets/hits/defaultTemplates.d.ts +32 -2
  62. package/es/widgets/hits/defaultTemplates.js +3 -0
  63. package/es/widgets/hits/hits.d.ts +204 -8
  64. package/es/widgets/hits/hits.js +4 -5
  65. package/es/widgets/index.d.ts +1 -0
  66. package/es/widgets/infinite-hits/infinite-hits.d.ts +262 -9
  67. package/es/widgets/infinite-hits/infinite-hits.js +4 -5
  68. package/es/widgets/looking-similar/looking-similar.d.ts +309 -9
  69. package/es/widgets/looking-similar/looking-similar.js +5 -7
  70. package/es/widgets/rating-menu/defaultTemplates.js +1 -0
  71. package/es/widgets/related-products/related-products.d.ts +306 -9
  72. package/es/widgets/related-products/related-products.js +2 -4
  73. package/es/widgets/trending-items/trending-items.d.ts +310 -9
  74. package/es/widgets/trending-items/trending-items.js +2 -4
  75. package/package.json +5 -5
  76. package/scripts/transforms/README.md +1 -1
  77. package/scripts/transforms/addWidget-to-addWidgets.js +7 -27
@@ -7,9 +7,9 @@ export type CreateMarker = (args: {
7
7
  item: GeoHit;
8
8
  map: google.maps.Map;
9
9
  }) => google.maps.OverlayView | google.maps.Marker;
10
- export type GeoSearchTemplates = Partial<{
10
+ export type GeoSearchTemplates<THit extends GeoHit = GeoHit> = Partial<{
11
11
  /** Template to use for the marker. */
12
- HTMLMarker: Template<GeoHit>;
12
+ HTMLMarker: Template<THit>;
13
13
  /** Template for the reset button. */
14
14
  reset: Template;
15
15
  /** Template for the toggle label. */
@@ -38,13 +38,13 @@ export type GeoSearchCSSClasses = Partial<{
38
38
  /** The reset refinement button. */
39
39
  reset: string | string[];
40
40
  }>;
41
- export type GeoSearchMarker<TOptions> = {
41
+ export type GeoSearchMarker<TOptions, THit extends GeoHit = GeoHit> = {
42
42
  /**
43
43
  * Function used to create the options passed to the Google Maps marker.
44
44
  * See the documentation for more information:
45
45
  * https://developers.google.com/maps/documentation/javascript/reference/3/#MarkerOptions
46
46
  */
47
- createOptions?: (item: GeoHit) => TOptions;
47
+ createOptions?: (item: THit) => TOptions;
48
48
  /**
49
49
  * Object that takes an event type (ex: `click`, `mouseover`) as key and a
50
50
  * listener as value. The listener is provided with an object that contains:
@@ -59,7 +59,7 @@ export type GeoSearchMarker<TOptions> = {
59
59
  }) => void;
60
60
  };
61
61
  };
62
- export type GeoSearchWidgetParams = {
62
+ export type GeoSearchWidgetParams<THit extends GeoHit = GeoHit> = {
63
63
  /**
64
64
  * By default the map will set the zoom accordingly to the markers displayed on it.
65
65
  * When we refine it may happen that the results are empty. For those situations we
@@ -76,7 +76,7 @@ export type GeoSearchWidgetParams = {
76
76
  */
77
77
  initialPosition?: GeoLoc;
78
78
  /** Templates to use for the widget. */
79
- templates?: GeoSearchTemplates;
79
+ templates?: GeoSearchTemplates<THit>;
80
80
  /** CSS classes to add to the wrapping elements. */
81
81
  cssClasses?: GeoSearchCSSClasses;
82
82
  /**
@@ -138,5 +138,325 @@ export type GeoSearchWidget = WidgetFactory<GeoSearchWidgetDescription & {
138
138
  *
139
139
  * Don't forget to explicitly set the `height` of the map container (default class `.ais-geo-search--map`), otherwise it won't be shown (it's a requirement of Google Maps).
140
140
  */
141
- declare const geoSearch: GeoSearchWidget;
142
- export default geoSearch;
141
+ declare const _default: <THit extends GeoHit = GeoHit>(widgetParams: GeoSearchWidgetParams<THit> & GeoSearchConnectorParams<THit>) => {
142
+ $$widgetType: "ais.geoSearch";
143
+ $$type: "ais.geoSearch";
144
+ init(initArgs: import("../../types").InitOptions): void;
145
+ render(renderArgs: import("../../types").RenderOptions): void;
146
+ getWidgetRenderState(renderOptions: import("../../types").InitOptions | import("../../types").RenderOptions): {
147
+ items: GeoHit<THit>[];
148
+ position: {
149
+ lat: number;
150
+ lng: number;
151
+ } | undefined;
152
+ currentRefinement: {
153
+ northEast: {
154
+ lat: number;
155
+ lng: number;
156
+ };
157
+ southWest: {
158
+ lat: number;
159
+ lng: number;
160
+ };
161
+ } | undefined;
162
+ refine: ({ northEast: ne, southWest: sw }: {
163
+ northEast: GeoLoc;
164
+ southWest: GeoLoc;
165
+ }) => void;
166
+ sendEvent: import("../../lib/utils").SendEventForHits;
167
+ clearMapRefinement: () => void;
168
+ isRefinedWithMap: () => boolean;
169
+ toggleRefineOnMapMove: () => void;
170
+ isRefineOnMapMove: () => boolean;
171
+ setMapMoveSinceLastRefine: () => void;
172
+ hasMapMoveSinceLastRefine: () => boolean;
173
+ widgetParams: {
174
+ renderState: {
175
+ templateProps?: import("../../lib/templating").PreparedTemplateProps<Partial<{
176
+ /** Template to use for the marker. */
177
+ HTMLMarker: Template<GeoHit>;
178
+ /** Template for the reset button. */
179
+ reset: Template;
180
+ /** Template for the toggle label. */
181
+ toggle: Template;
182
+ /** Template for the redo button. */
183
+ redo: Template;
184
+ }>> | undefined;
185
+ isUserInteraction?: boolean | undefined;
186
+ isPendingRefine?: boolean | undefined;
187
+ markers?: any[] | undefined;
188
+ };
189
+ container: HTMLElement;
190
+ googleReference: typeof google;
191
+ initialZoom: number | undefined;
192
+ initialPosition: GeoLoc | undefined;
193
+ templates: Partial<{
194
+ /** Template to use for the marker. */
195
+ HTMLMarker: Template<GeoHit>;
196
+ /** Template for the reset button. */
197
+ reset: Template;
198
+ /** Template for the toggle label. */
199
+ toggle: Template;
200
+ /** Template for the redo button. */
201
+ redo: Template;
202
+ }>;
203
+ cssClasses: import("../../types").ComponentCSSClasses<Partial<{
204
+ /** The root div of the widget. */
205
+ root: string | string[];
206
+ /** The map container of the widget. */
207
+ map: string | string[];
208
+ /** The control element of the widget. */
209
+ control: string | string[];
210
+ /** The label of the control element. */
211
+ label: string | string[];
212
+ /** The selected label of the control element. */
213
+ selectedLabel: string | string[];
214
+ /** The input of the control element. */
215
+ input: string | string[];
216
+ /** The redo search button. */
217
+ redo: string | string[];
218
+ /** The disabled redo search button. */
219
+ disabledRedo: string | string[];
220
+ /** The reset refinement button. */
221
+ reset: string | string[];
222
+ }> | undefined>;
223
+ createMarker: CreateMarker;
224
+ markerOptions: GeoSearchMarker<any>;
225
+ enableRefine: boolean | undefined;
226
+ enableClearMapRefinement: boolean | undefined;
227
+ enableRefineControl: boolean | undefined;
228
+ } & GeoSearchConnectorParams<THit>;
229
+ };
230
+ getRenderState(renderState: {
231
+ answers?: import("../../types").WidgetRenderState<import("../../connectors/answers/connectAnswers").AnswersRenderState, import("../../connectors/answers/connectAnswers").AnswersConnectorParams> | undefined;
232
+ autocomplete?: import("../../types").WidgetRenderState<import("../../connectors/autocomplete/connectAutocomplete").AutocompleteRenderState, import("../../connectors/autocomplete/connectAutocomplete").AutocompleteConnectorParams> | undefined;
233
+ breadcrumb?: {
234
+ [rootAttribute: string]: import("../../types").WidgetRenderState<import("../../connectors/breadcrumb/connectBreadcrumb").BreadcrumbRenderState, import("../../connectors/breadcrumb/connectBreadcrumb").BreadcrumbConnectorParams>;
235
+ } | undefined;
236
+ clearRefinements?: import("../../types").WidgetRenderState<import("../../connectors/clear-refinements/connectClearRefinements").ClearRefinementsRenderState, import("../../connectors/clear-refinements/connectClearRefinements").ClearRefinementsConnectorParams> | undefined;
237
+ configure?: import("../../types").WidgetRenderState<import("../../connectors/configure/connectConfigure").ConfigureRenderState, import("../../connectors/configure/connectConfigure").ConfigureConnectorParams> | undefined;
238
+ currentRefinements?: import("../../types").WidgetRenderState<import("../../connectors/current-refinements/connectCurrentRefinements").CurrentRefinementsRenderState, import("../../connectors/current-refinements/connectCurrentRefinements").CurrentRefinementsConnectorParams> | undefined;
239
+ geoSearch?: import("../../types").WidgetRenderState<import("../../connectors/geo-search/connectGeoSearch").GeoSearchRenderState<GeoHit>, GeoSearchConnectorParams<GeoHit>> | undefined;
240
+ hierarchicalMenu?: {
241
+ [rootAttribute: string]: import("../../types").WidgetRenderState<import("../../connectors/hierarchical-menu/connectHierarchicalMenu").HierarchicalMenuRenderState, import("../../connectors/hierarchical-menu/connectHierarchicalMenu").HierarchicalMenuConnectorParams>;
242
+ } | undefined;
243
+ hits?: import("../../types").WidgetRenderState<import("../../connectors/hits/connectHits").HitsRenderState<import("../../types").BaseHit>, import("../../connectors/hits/connectHits").HitsConnectorParams<import("../../types").BaseHit>> | undefined;
244
+ hitsPerPage?: import("../../types").WidgetRenderState<import("../../connectors/hits-per-page/connectHitsPerPage").HitsPerPageRenderState, import("../../connectors/hits-per-page/connectHitsPerPage").HitsPerPageConnectorParams> | undefined;
245
+ infiniteHits?: import("../../types").WidgetRenderState<import("../../connectors/infinite-hits/connectInfiniteHits").InfiniteHitsRenderState<import("../../types").BaseHit>, import("../../connectors/infinite-hits/connectInfiniteHits").InfiniteHitsConnectorParams<import("../../types").BaseHit>> | undefined;
246
+ menu?: {
247
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/menu/connectMenu").MenuRenderState, import("../../connectors/menu/connectMenu").MenuConnectorParams>;
248
+ } | undefined;
249
+ numericMenu?: {
250
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/numeric-menu/connectNumericMenu").NumericMenuRenderState, import("../../connectors/numeric-menu/connectNumericMenu").NumericMenuConnectorParams>;
251
+ } | undefined;
252
+ pagination?: import("../../types").WidgetRenderState<import("../../connectors/pagination/connectPagination").PaginationRenderState, import("../../connectors/pagination/connectPagination").PaginationConnectorParams> | undefined;
253
+ poweredBy?: import("../../types").WidgetRenderState<import("../../connectors/powered-by/connectPoweredBy").PoweredByRenderState, import("../../connectors/powered-by/connectPoweredBy").PoweredByConnectorParams> | undefined;
254
+ queryRules?: import("../../types").WidgetRenderState<import("../../connectors/query-rules/connectQueryRules").QueryRulesRenderState, import("../../connectors/query-rules/connectQueryRules").QueryRulesConnectorParams> | undefined;
255
+ range?: {
256
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/range/connectRange").RangeRenderState, import("../../connectors/range/connectRange").RangeConnectorParams>;
257
+ } | undefined;
258
+ ratingMenu?: {
259
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/rating-menu/connectRatingMenu").RatingMenuRenderState, import("../../connectors/rating-menu/connectRatingMenu").RatingMenuConnectorParams>;
260
+ } | undefined;
261
+ refinementList?: {
262
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/refinement-list/connectRefinementList").RefinementListRenderState, import("../../connectors/refinement-list/connectRefinementList").RefinementListConnectorParams>;
263
+ } | undefined;
264
+ relevantSort?: import("../../types").WidgetRenderState<import("../../connectors/relevant-sort/connectRelevantSort").RelevantSortRenderState, import("../../connectors/relevant-sort/connectRelevantSort").RelevantSortConnectorParams> | undefined;
265
+ searchBox?: import("../../types").WidgetRenderState<import("../../connectors/search-box/connectSearchBox").SearchBoxRenderState, import("../../connectors/search-box/connectSearchBox").SearchBoxConnectorParams> | undefined;
266
+ sortBy?: import("../../types").WidgetRenderState<import("../../connectors/sort-by/connectSortBy").SortByRenderState, import("../../connectors/sort-by/connectSortBy").SortByConnectorParams> | undefined;
267
+ stats?: import("../../types").WidgetRenderState<import("../../connectors/stats/connectStats").StatsRenderState, import("../../connectors/stats/connectStats").StatsConnectorParams> | undefined;
268
+ toggleRefinement?: {
269
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/toggle-refinement/connectToggleRefinement").ToggleRefinementRenderState, import("../../connectors/toggle-refinement/connectToggleRefinement").ToggleRefinementConnectorParams>;
270
+ } | undefined;
271
+ voiceSearch?: import("../../types").WidgetRenderState<import("../../connectors/voice-search/connectVoiceSearch").VoiceSearchRenderState, import("../../connectors/voice-search/connectVoiceSearch").VoiceSearchConnectorParams> | undefined;
272
+ analytics?: import("../../types").WidgetRenderState<Record<string, unknown>, import("../analytics/analytics").AnalyticsWidgetParams> | undefined;
273
+ places?: import("../../types").WidgetRenderState<Record<string, unknown>, import("../places/places").PlacesWidgetParams> | undefined;
274
+ }, renderOptions: import("../../types").InitOptions | import("../../types").RenderOptions): Partial<{
275
+ answers: import("../../types").WidgetRenderState<import("../../connectors/answers/connectAnswers").AnswersRenderState, import("../../connectors/answers/connectAnswers").AnswersConnectorParams>;
276
+ } & {
277
+ autocomplete: import("../../types").WidgetRenderState<import("../../connectors/autocomplete/connectAutocomplete").AutocompleteRenderState, import("../../connectors/autocomplete/connectAutocomplete").AutocompleteConnectorParams>;
278
+ } & {
279
+ breadcrumb: {
280
+ [rootAttribute: string]: import("../../types").WidgetRenderState<import("../../connectors/breadcrumb/connectBreadcrumb").BreadcrumbRenderState, import("../../connectors/breadcrumb/connectBreadcrumb").BreadcrumbConnectorParams>;
281
+ };
282
+ } & {
283
+ /** The map container of the widget. */
284
+ clearRefinements: import("../../types").WidgetRenderState<import("../../connectors/clear-refinements/connectClearRefinements").ClearRefinementsRenderState, import("../../connectors/clear-refinements/connectClearRefinements").ClearRefinementsConnectorParams>;
285
+ } & {
286
+ configure: import("../../types").WidgetRenderState<import("../../connectors/configure/connectConfigure").ConfigureRenderState, import("../../connectors/configure/connectConfigure").ConfigureConnectorParams>;
287
+ } & {
288
+ currentRefinements: import("../../types").WidgetRenderState<import("../../connectors/current-refinements/connectCurrentRefinements").CurrentRefinementsRenderState, import("../../connectors/current-refinements/connectCurrentRefinements").CurrentRefinementsConnectorParams>;
289
+ } & {
290
+ geoSearch: import("../../types").WidgetRenderState<import("../../connectors/geo-search/connectGeoSearch").GeoSearchRenderState<GeoHit>, GeoSearchConnectorParams<GeoHit>>;
291
+ } & {
292
+ hierarchicalMenu: {
293
+ [rootAttribute: string]: import("../../types").WidgetRenderState<import("../../connectors/hierarchical-menu/connectHierarchicalMenu").HierarchicalMenuRenderState, import("../../connectors/hierarchical-menu/connectHierarchicalMenu").HierarchicalMenuConnectorParams>;
294
+ };
295
+ } & {
296
+ hits: import("../../types").WidgetRenderState<import("../../connectors/hits/connectHits").HitsRenderState<import("../../types").BaseHit>, import("../../connectors/hits/connectHits").HitsConnectorParams<import("../../types").BaseHit>>;
297
+ } & {
298
+ hitsPerPage: import("../../types").WidgetRenderState<import("../../connectors/hits-per-page/connectHitsPerPage").HitsPerPageRenderState, import("../../connectors/hits-per-page/connectHitsPerPage").HitsPerPageConnectorParams>;
299
+ } & {
300
+ infiniteHits: import("../../types").WidgetRenderState<import("../../connectors/infinite-hits/connectInfiniteHits").InfiniteHitsRenderState<import("../../types").BaseHit>, import("../../connectors/infinite-hits/connectInfiniteHits").InfiniteHitsConnectorParams<import("../../types").BaseHit>>;
301
+ } & {
302
+ menu: {
303
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/menu/connectMenu").MenuRenderState, import("../../connectors/menu/connectMenu").MenuConnectorParams>;
304
+ };
305
+ } & {
306
+ numericMenu: {
307
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/numeric-menu/connectNumericMenu").NumericMenuRenderState, import("../../connectors/numeric-menu/connectNumericMenu").NumericMenuConnectorParams>;
308
+ };
309
+ } & {
310
+ pagination: import("../../types").WidgetRenderState<import("../../connectors/pagination/connectPagination").PaginationRenderState, import("../../connectors/pagination/connectPagination").PaginationConnectorParams>;
311
+ } & {
312
+ poweredBy: import("../../types").WidgetRenderState<import("../../connectors/powered-by/connectPoweredBy").PoweredByRenderState, import("../../connectors/powered-by/connectPoweredBy").PoweredByConnectorParams>;
313
+ } & {
314
+ queryRules: import("../../types").WidgetRenderState<import("../../connectors/query-rules/connectQueryRules").QueryRulesRenderState, import("../../connectors/query-rules/connectQueryRules").QueryRulesConnectorParams>;
315
+ } & {
316
+ range: {
317
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/range/connectRange").RangeRenderState, import("../../connectors/range/connectRange").RangeConnectorParams>;
318
+ };
319
+ } & {
320
+ ratingMenu: {
321
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/rating-menu/connectRatingMenu").RatingMenuRenderState, import("../../connectors/rating-menu/connectRatingMenu").RatingMenuConnectorParams>;
322
+ };
323
+ } & {
324
+ refinementList: {
325
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/refinement-list/connectRefinementList").RefinementListRenderState, import("../../connectors/refinement-list/connectRefinementList").RefinementListConnectorParams>;
326
+ };
327
+ } & {
328
+ relevantSort: import("../../types").WidgetRenderState<import("../../connectors/relevant-sort/connectRelevantSort").RelevantSortRenderState, import("../../connectors/relevant-sort/connectRelevantSort").RelevantSortConnectorParams>;
329
+ } & {
330
+ searchBox: import("../../types").WidgetRenderState<import("../../connectors/search-box/connectSearchBox").SearchBoxRenderState, import("../../connectors/search-box/connectSearchBox").SearchBoxConnectorParams>;
331
+ } & {
332
+ sortBy: import("../../types").WidgetRenderState<import("../../connectors/sort-by/connectSortBy").SortByRenderState, import("../../connectors/sort-by/connectSortBy").SortByConnectorParams>;
333
+ } & {
334
+ stats: import("../../types").WidgetRenderState<import("../../connectors/stats/connectStats").StatsRenderState, import("../../connectors/stats/connectStats").StatsConnectorParams>;
335
+ } & {
336
+ toggleRefinement: {
337
+ [attribute: string]: import("../../types").WidgetRenderState<import("../../connectors/toggle-refinement/connectToggleRefinement").ToggleRefinementRenderState, import("../../connectors/toggle-refinement/connectToggleRefinement").ToggleRefinementConnectorParams>;
338
+ };
339
+ } & {
340
+ voiceSearch: import("../../types").WidgetRenderState<import("../../connectors/voice-search/connectVoiceSearch").VoiceSearchRenderState, import("../../connectors/voice-search/connectVoiceSearch").VoiceSearchConnectorParams>;
341
+ } & {
342
+ analytics: import("../../types").WidgetRenderState<Record<string, unknown>, import("../analytics/analytics").AnalyticsWidgetParams>;
343
+ } & {
344
+ places: import("../../types").WidgetRenderState<Record<string, unknown>, import("../places/places").PlacesWidgetParams>;
345
+ }> & {
346
+ geoSearch: import("../../types").WidgetRenderState<import("../../connectors/geo-search/connectGeoSearch").GeoSearchRenderState<GeoHit>, GeoSearchConnectorParams<GeoHit>>;
347
+ };
348
+ dispose({ state }: import("../../types").DisposeOptions): import("algoliasearch-helper").SearchParameters;
349
+ getWidgetUiState(uiState: {
350
+ geoSearch?: {
351
+ boundingBox: string;
352
+ } | undefined;
353
+ query?: string | undefined;
354
+ configure?: import("algoliasearch-helper").PlainSearchParameters | undefined;
355
+ hierarchicalMenu?: {
356
+ [rootAttribute: string]: string[];
357
+ } | undefined;
358
+ hitsPerPage?: number | undefined;
359
+ page?: number | undefined;
360
+ menu?: {
361
+ [attribute: string]: string;
362
+ } | undefined;
363
+ numericMenu?: {
364
+ [attribute: string]: string;
365
+ } | undefined;
366
+ range?: {
367
+ [attribute: string]: string;
368
+ } | undefined;
369
+ ratingMenu?: {
370
+ [attribute: string]: number | undefined;
371
+ } | undefined;
372
+ refinementList?: {
373
+ [attribute: string]: string[];
374
+ } | undefined;
375
+ relevantSort?: number | undefined;
376
+ sortBy?: string | undefined;
377
+ toggle?: {
378
+ [attribute: string]: boolean;
379
+ } | undefined;
380
+ places?: {
381
+ query: string;
382
+ position: string;
383
+ } | undefined;
384
+ }, { searchParameters }: {
385
+ searchParameters: import("algoliasearch-helper").SearchParameters;
386
+ helper: import("algoliasearch-helper").AlgoliaSearchHelper;
387
+ }): {
388
+ geoSearch?: {
389
+ boundingBox: string;
390
+ } | undefined;
391
+ query?: string | undefined;
392
+ configure?: import("algoliasearch-helper").PlainSearchParameters | undefined;
393
+ hierarchicalMenu?: {
394
+ [rootAttribute: string]: string[];
395
+ } | undefined;
396
+ hitsPerPage?: number | undefined;
397
+ page?: number | undefined;
398
+ menu?: {
399
+ [attribute: string]: string;
400
+ } | undefined;
401
+ numericMenu?: {
402
+ [attribute: string]: string;
403
+ } | undefined;
404
+ range?: {
405
+ [attribute: string]: string;
406
+ } | undefined;
407
+ ratingMenu?: {
408
+ [attribute: string]: number | undefined;
409
+ } | undefined;
410
+ refinementList?: {
411
+ [attribute: string]: string[];
412
+ } | undefined;
413
+ relevantSort?: number | undefined;
414
+ sortBy?: string | undefined;
415
+ toggle?: {
416
+ [attribute: string]: boolean;
417
+ } | undefined;
418
+ places?: {
419
+ query: string;
420
+ position: string;
421
+ } | undefined;
422
+ };
423
+ getWidgetSearchParameters(searchParameters: import("algoliasearch-helper").SearchParameters, { uiState }: {
424
+ uiState: {
425
+ geoSearch?: {
426
+ boundingBox: string;
427
+ } | undefined;
428
+ query?: string | undefined;
429
+ configure?: import("algoliasearch-helper").PlainSearchParameters | undefined;
430
+ hierarchicalMenu?: {
431
+ [rootAttribute: string]: string[];
432
+ } | undefined;
433
+ hitsPerPage?: number | undefined;
434
+ page?: number | undefined;
435
+ menu?: {
436
+ [attribute: string]: string;
437
+ } | undefined;
438
+ numericMenu?: {
439
+ [attribute: string]: string;
440
+ } | undefined;
441
+ range?: {
442
+ [attribute: string]: string;
443
+ } | undefined;
444
+ ratingMenu?: {
445
+ [attribute: string]: number | undefined;
446
+ } | undefined;
447
+ refinementList?: {
448
+ [attribute: string]: string[];
449
+ } | undefined;
450
+ relevantSort?: number | undefined;
451
+ sortBy?: string | undefined;
452
+ toggle?: {
453
+ [attribute: string]: boolean;
454
+ } | undefined;
455
+ places?: {
456
+ query: string;
457
+ position: string;
458
+ } | undefined;
459
+ };
460
+ }): import("algoliasearch-helper").SearchParameters;
461
+ };
462
+ export default _default;
@@ -37,7 +37,7 @@ var suit = component('GeoSearch');
37
37
  *
38
38
  * Don't forget to explicitly set the `height` of the map container (default class `.ais-geo-search--map`), otherwise it won't be shown (it's a requirement of Google Maps).
39
39
  */
40
- var geoSearch = function geoSearch(widgetParams) {
40
+ export default (function geoSearch(widgetParams) {
41
41
  var _ref = widgetParams || {},
42
42
  _ref$initialZoom = _ref.initialZoom,
43
43
  initialZoom = _ref$initialZoom === void 0 ? 1 : _ref$initialZoom,
@@ -150,12 +150,14 @@ var geoSearch = function geoSearch(widgetParams) {
150
150
  return render(null, containerNode);
151
151
  });
152
152
  return _objectSpread(_objectSpread({}, makeWidget(_objectSpread(_objectSpread({}, otherWidgetParams), {}, {
153
+ // @TODO: this type doesn't preserve the generic correctly,
154
+ // (but as they're internal only it's not a big problem)
155
+ templates: templates,
153
156
  renderState: {},
154
157
  container: containerNode,
155
158
  googleReference: googleReference,
156
159
  initialZoom: initialZoom,
157
160
  initialPosition: initialPosition,
158
- templates: templates,
159
161
  cssClasses: cssClasses,
160
162
  createMarker: createMarker,
161
163
  markerOptions: markerOptions,
@@ -165,5 +167,4 @@ var geoSearch = function geoSearch(widgetParams) {
165
167
  }))), {}, {
166
168
  $$widgetType: 'ais.geoSearch'
167
169
  });
168
- };
169
- export default geoSearch;
170
+ });
@@ -1,3 +1,33 @@
1
- import type { HitsTemplates } from './hits';
2
- declare const defaultTemplates: HitsTemplates;
1
+ declare const defaultTemplates: {
2
+ empty(): string;
3
+ item(data: {
4
+ __position: number;
5
+ __queryID?: string | undefined;
6
+ } & {
7
+ objectID: string;
8
+ _highlightResult?: import("../../types").HitHighlightResult | undefined;
9
+ _snippetResult?: import("../../types").HitSnippetResult | undefined;
10
+ _rankingInfo?: {
11
+ promoted: boolean;
12
+ nbTypos: number;
13
+ firstMatchedWord: number;
14
+ proximityDistance?: number | undefined;
15
+ geoDistance: number;
16
+ geoPrecision?: number | undefined;
17
+ nbExactWords: number;
18
+ words: number;
19
+ filters: number;
20
+ userScore: number;
21
+ matchedGeoLocation?: {
22
+ lat: number;
23
+ lng: number;
24
+ distance: number;
25
+ } | undefined;
26
+ } | undefined;
27
+ _distinctSeqID?: number | undefined;
28
+ _geoloc?: import("../../types").GeoLoc | undefined;
29
+ } & import("../../types").BaseHit & {
30
+ __hitIndex: number;
31
+ }): string;
32
+ };
3
33
  export default defaultTemplates;
@@ -1,4 +1,7 @@
1
1
  import { omit } from "../../lib/utils/index.js";
2
+
3
+ // false positive lint error
4
+ // eslint-disable-next-line @typescript-eslint/consistent-type-imports
2
5
  var defaultTemplates = {
3
6
  empty: function empty() {
4
7
  return 'No results';