@seekora-ai/ui-sdk-react 0.0.0-stage-20260517092419

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 (357) hide show
  1. package/dist/components/Breadcrumb.d.ts +43 -0
  2. package/dist/components/Breadcrumb.d.ts.map +1 -0
  3. package/dist/components/Breadcrumb.js +119 -0
  4. package/dist/components/ClearRefinements.d.ts +42 -0
  5. package/dist/components/ClearRefinements.d.ts.map +1 -0
  6. package/dist/components/ClearRefinements.js +81 -0
  7. package/dist/components/CurrentRefinements.d.ts +63 -0
  8. package/dist/components/CurrentRefinements.d.ts.map +1 -0
  9. package/dist/components/CurrentRefinements.js +302 -0
  10. package/dist/components/FacetDropdown.d.ts +94 -0
  11. package/dist/components/FacetDropdown.d.ts.map +1 -0
  12. package/dist/components/FacetDropdown.js +396 -0
  13. package/dist/components/Facets.d.ts +118 -0
  14. package/dist/components/Facets.d.ts.map +1 -0
  15. package/dist/components/Facets.js +785 -0
  16. package/dist/components/FederatedDropdown.d.ts +98 -0
  17. package/dist/components/FederatedDropdown.d.ts.map +1 -0
  18. package/dist/components/FederatedDropdown.js +526 -0
  19. package/dist/components/HierarchicalMenu.d.ts +55 -0
  20. package/dist/components/HierarchicalMenu.d.ts.map +1 -0
  21. package/dist/components/HierarchicalMenu.js +276 -0
  22. package/dist/components/Highlight.d.ts +51 -0
  23. package/dist/components/Highlight.d.ts.map +1 -0
  24. package/dist/components/Highlight.js +155 -0
  25. package/dist/components/HitsPerPage.d.ts +41 -0
  26. package/dist/components/HitsPerPage.d.ts.map +1 -0
  27. package/dist/components/HitsPerPage.js +82 -0
  28. package/dist/components/InfiniteHits.d.ts +51 -0
  29. package/dist/components/InfiniteHits.d.ts.map +1 -0
  30. package/dist/components/InfiniteHits.js +173 -0
  31. package/dist/components/MobileFilters.d.ts +71 -0
  32. package/dist/components/MobileFilters.d.ts.map +1 -0
  33. package/dist/components/MobileFilters.js +242 -0
  34. package/dist/components/Pagination.d.ts +90 -0
  35. package/dist/components/Pagination.d.ts.map +1 -0
  36. package/dist/components/Pagination.js +298 -0
  37. package/dist/components/QuerySuggestions.d.ts +36 -0
  38. package/dist/components/QuerySuggestions.d.ts.map +1 -0
  39. package/dist/components/QuerySuggestions.js +71 -0
  40. package/dist/components/QuerySuggestionsDropdown.d.ts +82 -0
  41. package/dist/components/QuerySuggestionsDropdown.d.ts.map +1 -0
  42. package/dist/components/QuerySuggestionsDropdown.js +394 -0
  43. package/dist/components/RangeInput.d.ts +58 -0
  44. package/dist/components/RangeInput.d.ts.map +1 -0
  45. package/dist/components/RangeInput.js +203 -0
  46. package/dist/components/RangeSlider.d.ts +51 -0
  47. package/dist/components/RangeSlider.d.ts.map +1 -0
  48. package/dist/components/RangeSlider.js +262 -0
  49. package/dist/components/Recommendations.d.ts +89 -0
  50. package/dist/components/Recommendations.d.ts.map +1 -0
  51. package/dist/components/Recommendations.js +256 -0
  52. package/dist/components/RichQuerySuggestions.d.ts +88 -0
  53. package/dist/components/RichQuerySuggestions.d.ts.map +1 -0
  54. package/dist/components/RichQuerySuggestions.js +498 -0
  55. package/dist/components/SearchBar.d.ts +57 -0
  56. package/dist/components/SearchBar.d.ts.map +1 -0
  57. package/dist/components/SearchBar.js +361 -0
  58. package/dist/components/SearchBarWithSuggestions.d.ts +105 -0
  59. package/dist/components/SearchBarWithSuggestions.d.ts.map +1 -0
  60. package/dist/components/SearchBarWithSuggestions.js +275 -0
  61. package/dist/components/SearchLayout.d.ts +35 -0
  62. package/dist/components/SearchLayout.d.ts.map +1 -0
  63. package/dist/components/SearchLayout.js +61 -0
  64. package/dist/components/SearchProvider.d.ts +35 -0
  65. package/dist/components/SearchProvider.d.ts.map +1 -0
  66. package/dist/components/SearchProvider.js +53 -0
  67. package/dist/components/SearchResults.d.ts +57 -0
  68. package/dist/components/SearchResults.d.ts.map +1 -0
  69. package/dist/components/SearchResults.js +456 -0
  70. package/dist/components/SortBy.d.ts +84 -0
  71. package/dist/components/SortBy.d.ts.map +1 -0
  72. package/dist/components/SortBy.js +183 -0
  73. package/dist/components/Stats.d.ts +51 -0
  74. package/dist/components/Stats.d.ts.map +1 -0
  75. package/dist/components/Stats.js +201 -0
  76. package/dist/components/primitives/ActionButtons.d.ts +27 -0
  77. package/dist/components/primitives/ActionButtons.d.ts.map +1 -0
  78. package/dist/components/primitives/ActionButtons.js +102 -0
  79. package/dist/components/primitives/AnalyticsProvider.d.ts +22 -0
  80. package/dist/components/primitives/AnalyticsProvider.d.ts.map +1 -0
  81. package/dist/components/primitives/AnalyticsProvider.js +87 -0
  82. package/dist/components/primitives/BadgeList.d.ts +14 -0
  83. package/dist/components/primitives/BadgeList.d.ts.map +1 -0
  84. package/dist/components/primitives/BadgeList.js +65 -0
  85. package/dist/components/primitives/CustomSelect.d.ts +40 -0
  86. package/dist/components/primitives/CustomSelect.d.ts.map +1 -0
  87. package/dist/components/primitives/CustomSelect.js +196 -0
  88. package/dist/components/primitives/ImageDisplay.d.ts +28 -0
  89. package/dist/components/primitives/ImageDisplay.d.ts.map +1 -0
  90. package/dist/components/primitives/ImageDisplay.js +127 -0
  91. package/dist/components/primitives/ImageZoom.d.ts +33 -0
  92. package/dist/components/primitives/ImageZoom.d.ts.map +1 -0
  93. package/dist/components/primitives/ImageZoom.js +433 -0
  94. package/dist/components/primitives/PriceDisplay.d.ts +21 -0
  95. package/dist/components/primitives/PriceDisplay.d.ts.map +1 -0
  96. package/dist/components/primitives/PriceDisplay.js +44 -0
  97. package/dist/components/primitives/RatingDisplay.d.ts +43 -0
  98. package/dist/components/primitives/RatingDisplay.d.ts.map +1 -0
  99. package/dist/components/primitives/RatingDisplay.js +114 -0
  100. package/dist/components/primitives/VariantSelector.d.ts +30 -0
  101. package/dist/components/primitives/VariantSelector.d.ts.map +1 -0
  102. package/dist/components/primitives/VariantSelector.js +155 -0
  103. package/dist/components/primitives/VariantSwatches.d.ts +28 -0
  104. package/dist/components/primitives/VariantSwatches.d.ts.map +1 -0
  105. package/dist/components/primitives/VariantSwatches.js +188 -0
  106. package/dist/components/primitives/index.d.ts +12 -0
  107. package/dist/components/primitives/index.d.ts.map +1 -0
  108. package/dist/components/primitives/index.js +11 -0
  109. package/dist/components/primitives/withAnalytics.d.ts +24 -0
  110. package/dist/components/primitives/withAnalytics.d.ts.map +1 -0
  111. package/dist/components/primitives/withAnalytics.js +73 -0
  112. package/dist/components/product-page/ProductGallery.d.ts +26 -0
  113. package/dist/components/product-page/ProductGallery.d.ts.map +1 -0
  114. package/dist/components/product-page/ProductGallery.js +13 -0
  115. package/dist/components/product-page/ProductInfo.d.ts +44 -0
  116. package/dist/components/product-page/ProductInfo.d.ts.map +1 -0
  117. package/dist/components/product-page/ProductInfo.js +34 -0
  118. package/dist/components/product-page/ProductRecommendations.d.ts +21 -0
  119. package/dist/components/product-page/ProductRecommendations.d.ts.map +1 -0
  120. package/dist/components/product-page/ProductRecommendations.js +17 -0
  121. package/dist/components/product-page/index.d.ts +4 -0
  122. package/dist/components/product-page/index.d.ts.map +1 -0
  123. package/dist/components/product-page/index.js +3 -0
  124. package/dist/components/section-primitives/SectionError.d.ts +11 -0
  125. package/dist/components/section-primitives/SectionError.d.ts.map +1 -0
  126. package/dist/components/section-primitives/SectionError.js +13 -0
  127. package/dist/components/section-primitives/SectionItemGrid.d.ts +18 -0
  128. package/dist/components/section-primitives/SectionItemGrid.d.ts.map +1 -0
  129. package/dist/components/section-primitives/SectionItemGrid.js +14 -0
  130. package/dist/components/section-primitives/SectionLoading.d.ts +11 -0
  131. package/dist/components/section-primitives/SectionLoading.d.ts.map +1 -0
  132. package/dist/components/section-primitives/SectionLoading.js +11 -0
  133. package/dist/components/section-primitives/SectionSearchContext.d.ts +17 -0
  134. package/dist/components/section-primitives/SectionSearchContext.d.ts.map +1 -0
  135. package/dist/components/section-primitives/SectionSearchContext.js +17 -0
  136. package/dist/components/section-primitives/SectionSearchProvider.d.ts +25 -0
  137. package/dist/components/section-primitives/SectionSearchProvider.d.ts.map +1 -0
  138. package/dist/components/section-primitives/SectionSearchProvider.js +106 -0
  139. package/dist/components/section-primitives/index.d.ts +5 -0
  140. package/dist/components/section-primitives/index.d.ts.map +1 -0
  141. package/dist/components/section-primitives/index.js +4 -0
  142. package/dist/components/suggestions/AmazonDropdown.d.ts +30 -0
  143. package/dist/components/suggestions/AmazonDropdown.d.ts.map +1 -0
  144. package/dist/components/suggestions/AmazonDropdown.js +509 -0
  145. package/dist/components/suggestions/GoogleDropdown.d.ts +31 -0
  146. package/dist/components/suggestions/GoogleDropdown.d.ts.map +1 -0
  147. package/dist/components/suggestions/GoogleDropdown.js +349 -0
  148. package/dist/components/suggestions/MinimalDropdown.d.ts +24 -0
  149. package/dist/components/suggestions/MinimalDropdown.d.ts.map +1 -0
  150. package/dist/components/suggestions/MinimalDropdown.js +312 -0
  151. package/dist/components/suggestions/MobileSheetDropdown.d.ts +31 -0
  152. package/dist/components/suggestions/MobileSheetDropdown.d.ts.map +1 -0
  153. package/dist/components/suggestions/MobileSheetDropdown.js +483 -0
  154. package/dist/components/suggestions/PinterestDropdown.d.ts +29 -0
  155. package/dist/components/suggestions/PinterestDropdown.d.ts.map +1 -0
  156. package/dist/components/suggestions/PinterestDropdown.js +446 -0
  157. package/dist/components/suggestions/ShopifyDropdown.d.ts +27 -0
  158. package/dist/components/suggestions/ShopifyDropdown.d.ts.map +1 -0
  159. package/dist/components/suggestions/ShopifyDropdown.js +448 -0
  160. package/dist/components/suggestions/SpotlightDropdown.d.ts +33 -0
  161. package/dist/components/suggestions/SpotlightDropdown.d.ts.map +1 -0
  162. package/dist/components/suggestions/SpotlightDropdown.js +544 -0
  163. package/dist/components/suggestions/SuggestionSearchBar.d.ts +127 -0
  164. package/dist/components/suggestions/SuggestionSearchBar.d.ts.map +1 -0
  165. package/dist/components/suggestions/SuggestionSearchBar.js +644 -0
  166. package/dist/components/suggestions/index.d.ts +37 -0
  167. package/dist/components/suggestions/index.d.ts.map +1 -0
  168. package/dist/components/suggestions/index.js +59 -0
  169. package/dist/components/suggestions/styles/index.d.ts +11 -0
  170. package/dist/components/suggestions/styles/index.d.ts.map +1 -0
  171. package/dist/components/suggestions/styles/index.js +289 -0
  172. package/dist/components/suggestions/styles/responsive.d.ts +107 -0
  173. package/dist/components/suggestions/styles/responsive.d.ts.map +1 -0
  174. package/dist/components/suggestions/styles/responsive.js +237 -0
  175. package/dist/components/suggestions/types.d.ts +511 -0
  176. package/dist/components/suggestions/types.d.ts.map +1 -0
  177. package/dist/components/suggestions/types.js +6 -0
  178. package/dist/components/suggestions/utils.d.ts +259 -0
  179. package/dist/components/suggestions/utils.d.ts.map +1 -0
  180. package/dist/components/suggestions/utils.js +668 -0
  181. package/dist/components/suggestions-primitives/CategoriesTabs.d.ts +13 -0
  182. package/dist/components/suggestions-primitives/CategoriesTabs.d.ts.map +1 -0
  183. package/dist/components/suggestions-primitives/CategoriesTabs.js +35 -0
  184. package/dist/components/suggestions-primitives/DropdownPanel.d.ts +24 -0
  185. package/dist/components/suggestions-primitives/DropdownPanel.d.ts.map +1 -0
  186. package/dist/components/suggestions-primitives/DropdownPanel.js +67 -0
  187. package/dist/components/suggestions-primitives/ItemCard.d.ts +48 -0
  188. package/dist/components/suggestions-primitives/ItemCard.d.ts.map +1 -0
  189. package/dist/components/suggestions-primitives/ItemCard.js +103 -0
  190. package/dist/components/suggestions-primitives/ItemGrid.d.ts +28 -0
  191. package/dist/components/suggestions-primitives/ItemGrid.d.ts.map +1 -0
  192. package/dist/components/suggestions-primitives/ItemGrid.js +55 -0
  193. package/dist/components/suggestions-primitives/ProductCard.d.ts +45 -0
  194. package/dist/components/suggestions-primitives/ProductCard.d.ts.map +1 -0
  195. package/dist/components/suggestions-primitives/ProductCard.js +177 -0
  196. package/dist/components/suggestions-primitives/ProductCardLayouts.d.ts +44 -0
  197. package/dist/components/suggestions-primitives/ProductCardLayouts.d.ts.map +1 -0
  198. package/dist/components/suggestions-primitives/ProductCardLayouts.js +137 -0
  199. package/dist/components/suggestions-primitives/ProductGrid.d.ts +22 -0
  200. package/dist/components/suggestions-primitives/ProductGrid.d.ts.map +1 -0
  201. package/dist/components/suggestions-primitives/ProductGrid.js +41 -0
  202. package/dist/components/suggestions-primitives/RecentSearchesList.d.ts +17 -0
  203. package/dist/components/suggestions-primitives/RecentSearchesList.d.ts.map +1 -0
  204. package/dist/components/suggestions-primitives/RecentSearchesList.js +46 -0
  205. package/dist/components/suggestions-primitives/SearchInput.d.ts +23 -0
  206. package/dist/components/suggestions-primitives/SearchInput.d.ts.map +1 -0
  207. package/dist/components/suggestions-primitives/SearchInput.js +114 -0
  208. package/dist/components/suggestions-primitives/SuggestionItem.d.ts +31 -0
  209. package/dist/components/suggestions-primitives/SuggestionItem.d.ts.map +1 -0
  210. package/dist/components/suggestions-primitives/SuggestionItem.js +47 -0
  211. package/dist/components/suggestions-primitives/SuggestionList.d.ts +26 -0
  212. package/dist/components/suggestions-primitives/SuggestionList.d.ts.map +1 -0
  213. package/dist/components/suggestions-primitives/SuggestionList.js +35 -0
  214. package/dist/components/suggestions-primitives/SuggestionsContext.d.ts +44 -0
  215. package/dist/components/suggestions-primitives/SuggestionsContext.d.ts.map +1 -0
  216. package/dist/components/suggestions-primitives/SuggestionsContext.js +18 -0
  217. package/dist/components/suggestions-primitives/SuggestionsDropdownComposition.d.ts +24 -0
  218. package/dist/components/suggestions-primitives/SuggestionsDropdownComposition.d.ts.map +1 -0
  219. package/dist/components/suggestions-primitives/SuggestionsDropdownComposition.js +30 -0
  220. package/dist/components/suggestions-primitives/SuggestionsError.d.ts +11 -0
  221. package/dist/components/suggestions-primitives/SuggestionsError.d.ts.map +1 -0
  222. package/dist/components/suggestions-primitives/SuggestionsError.js +19 -0
  223. package/dist/components/suggestions-primitives/SuggestionsLoading.d.ts +11 -0
  224. package/dist/components/suggestions-primitives/SuggestionsLoading.d.ts.map +1 -0
  225. package/dist/components/suggestions-primitives/SuggestionsLoading.js +17 -0
  226. package/dist/components/suggestions-primitives/SuggestionsProvider.d.ts +38 -0
  227. package/dist/components/suggestions-primitives/SuggestionsProvider.d.ts.map +1 -0
  228. package/dist/components/suggestions-primitives/SuggestionsProvider.js +259 -0
  229. package/dist/components/suggestions-primitives/TrendingList.d.ts +17 -0
  230. package/dist/components/suggestions-primitives/TrendingList.d.ts.map +1 -0
  231. package/dist/components/suggestions-primitives/TrendingList.js +48 -0
  232. package/dist/components/suggestions-primitives/highlightMarkup.d.ts +31 -0
  233. package/dist/components/suggestions-primitives/highlightMarkup.d.ts.map +1 -0
  234. package/dist/components/suggestions-primitives/highlightMarkup.js +70 -0
  235. package/dist/components/suggestions-primitives/index.d.ts +39 -0
  236. package/dist/components/suggestions-primitives/index.d.ts.map +1 -0
  237. package/dist/components/suggestions-primitives/index.js +24 -0
  238. package/dist/docsearch/components/DocSearch.d.ts +4 -0
  239. package/dist/docsearch/components/DocSearch.d.ts.map +1 -0
  240. package/dist/docsearch/components/DocSearch.js +93 -0
  241. package/dist/docsearch/components/DocSearchButton.d.ts +4 -0
  242. package/dist/docsearch/components/DocSearchButton.d.ts.map +1 -0
  243. package/dist/docsearch/components/DocSearchButton.js +12 -0
  244. package/dist/docsearch/components/Footer.d.ts +8 -0
  245. package/dist/docsearch/components/Footer.d.ts.map +1 -0
  246. package/dist/docsearch/components/Footer.js +40 -0
  247. package/dist/docsearch/components/Highlight.d.ts +9 -0
  248. package/dist/docsearch/components/Highlight.d.ts.map +1 -0
  249. package/dist/docsearch/components/Highlight.js +48 -0
  250. package/dist/docsearch/components/Hit.d.ts +15 -0
  251. package/dist/docsearch/components/Hit.d.ts.map +1 -0
  252. package/dist/docsearch/components/Hit.js +96 -0
  253. package/dist/docsearch/components/Modal.d.ts +10 -0
  254. package/dist/docsearch/components/Modal.d.ts.map +1 -0
  255. package/dist/docsearch/components/Modal.js +57 -0
  256. package/dist/docsearch/components/Results.d.ts +23 -0
  257. package/dist/docsearch/components/Results.d.ts.map +1 -0
  258. package/dist/docsearch/components/Results.js +141 -0
  259. package/dist/docsearch/components/SearchBox.d.ts +11 -0
  260. package/dist/docsearch/components/SearchBox.d.ts.map +1 -0
  261. package/dist/docsearch/components/SearchBox.js +16 -0
  262. package/dist/docsearch/hooks/useDocSearch.d.ts +33 -0
  263. package/dist/docsearch/hooks/useDocSearch.d.ts.map +1 -0
  264. package/dist/docsearch/hooks/useDocSearch.js +224 -0
  265. package/dist/docsearch/hooks/useKeyboard.d.ts +17 -0
  266. package/dist/docsearch/hooks/useKeyboard.d.ts.map +1 -0
  267. package/dist/docsearch/hooks/useKeyboard.js +71 -0
  268. package/dist/docsearch/hooks/useSeekoraSearch.d.ts +27 -0
  269. package/dist/docsearch/hooks/useSeekoraSearch.d.ts.map +1 -0
  270. package/dist/docsearch/hooks/useSeekoraSearch.js +213 -0
  271. package/dist/docsearch/index.d.ts +13 -0
  272. package/dist/docsearch/index.d.ts.map +1 -0
  273. package/dist/docsearch/index.js +11 -0
  274. package/dist/docsearch/types.d.ts +175 -0
  275. package/dist/docsearch/types.d.ts.map +1 -0
  276. package/dist/docsearch/types.js +4 -0
  277. package/dist/docsearch.css +234 -0
  278. package/dist/hooks/useAnalytics.d.ts +24 -0
  279. package/dist/hooks/useAnalytics.d.ts.map +1 -0
  280. package/dist/hooks/useAnalytics.js +67 -0
  281. package/dist/hooks/useClickTracking.d.ts +36 -0
  282. package/dist/hooks/useClickTracking.d.ts.map +1 -0
  283. package/dist/hooks/useClickTracking.js +89 -0
  284. package/dist/hooks/useExperiment.d.ts +25 -0
  285. package/dist/hooks/useExperiment.d.ts.map +1 -0
  286. package/dist/hooks/useExperiment.js +123 -0
  287. package/dist/hooks/useFilters.d.ts +27 -0
  288. package/dist/hooks/useFilters.d.ts.map +1 -0
  289. package/dist/hooks/useFilters.js +86 -0
  290. package/dist/hooks/useKeyboardNavigation.d.ts +51 -0
  291. package/dist/hooks/useKeyboardNavigation.d.ts.map +1 -0
  292. package/dist/hooks/useKeyboardNavigation.js +113 -0
  293. package/dist/hooks/useNaturalLanguageFilters.d.ts +48 -0
  294. package/dist/hooks/useNaturalLanguageFilters.d.ts.map +1 -0
  295. package/dist/hooks/useNaturalLanguageFilters.js +221 -0
  296. package/dist/hooks/useProductAnalytics.d.ts +49 -0
  297. package/dist/hooks/useProductAnalytics.d.ts.map +1 -0
  298. package/dist/hooks/useProductAnalytics.js +116 -0
  299. package/dist/hooks/useQuerySuggestions.d.ts +21 -0
  300. package/dist/hooks/useQuerySuggestions.d.ts.map +1 -0
  301. package/dist/hooks/useQuerySuggestions.js +84 -0
  302. package/dist/hooks/useQuerySuggestionsEnhanced.d.ts +120 -0
  303. package/dist/hooks/useQuerySuggestionsEnhanced.d.ts.map +1 -0
  304. package/dist/hooks/useQuerySuggestionsEnhanced.js +444 -0
  305. package/dist/hooks/useSearchState.d.ts +35 -0
  306. package/dist/hooks/useSearchState.d.ts.map +1 -0
  307. package/dist/hooks/useSearchState.js +68 -0
  308. package/dist/hooks/useSeekoraSearch.d.ts +20 -0
  309. package/dist/hooks/useSeekoraSearch.d.ts.map +1 -0
  310. package/dist/hooks/useSeekoraSearch.js +63 -0
  311. package/dist/hooks/useSmartSuggestions.d.ts +55 -0
  312. package/dist/hooks/useSmartSuggestions.d.ts.map +1 -0
  313. package/dist/hooks/useSmartSuggestions.js +236 -0
  314. package/dist/hooks/useSuggestionsAnalytics.d.ts +93 -0
  315. package/dist/hooks/useSuggestionsAnalytics.d.ts.map +1 -0
  316. package/dist/hooks/useSuggestionsAnalytics.js +239 -0
  317. package/dist/hooks/useVariantSelection.d.ts +28 -0
  318. package/dist/hooks/useVariantSelection.d.ts.map +1 -0
  319. package/dist/hooks/useVariantSelection.js +44 -0
  320. package/dist/index.d.ts +105 -0
  321. package/dist/index.d.ts.map +1 -0
  322. package/dist/index.js +110 -0
  323. package/dist/index.umd.js +1 -0
  324. package/dist/src/index.d.ts +4469 -0
  325. package/dist/src/index.esm.js +18952 -0
  326. package/dist/src/index.esm.js.map +1 -0
  327. package/dist/src/index.js +19086 -0
  328. package/dist/src/index.js.map +1 -0
  329. package/dist/themes/createTheme.d.ts +8 -0
  330. package/dist/themes/createTheme.d.ts.map +1 -0
  331. package/dist/themes/createTheme.js +10 -0
  332. package/dist/themes/dark.d.ts +6 -0
  333. package/dist/themes/dark.d.ts.map +1 -0
  334. package/dist/themes/dark.js +34 -0
  335. package/dist/themes/default.d.ts +6 -0
  336. package/dist/themes/default.d.ts.map +1 -0
  337. package/dist/themes/default.js +71 -0
  338. package/dist/themes/mergeThemes.d.ts +7 -0
  339. package/dist/themes/mergeThemes.d.ts.map +1 -0
  340. package/dist/themes/mergeThemes.js +6 -0
  341. package/dist/themes/minimal.d.ts +6 -0
  342. package/dist/themes/minimal.d.ts.map +1 -0
  343. package/dist/themes/minimal.js +34 -0
  344. package/dist/themes/suggestions.d.ts +216 -0
  345. package/dist/themes/suggestions.d.ts.map +1 -0
  346. package/dist/themes/suggestions.js +546 -0
  347. package/dist/themes/types.d.ts +7 -0
  348. package/dist/themes/types.d.ts.map +1 -0
  349. package/dist/themes/types.js +6 -0
  350. package/dist/types/index.d.ts +33 -0
  351. package/dist/types/index.d.ts.map +1 -0
  352. package/dist/types/index.js +4 -0
  353. package/dist/utils/responsive.d.ts +130 -0
  354. package/dist/utils/responsive.d.ts.map +1 -0
  355. package/dist/utils/responsive.js +225 -0
  356. package/package.json +68 -0
  357. package/src/docsearch/docsearch.css +234 -0
@@ -0,0 +1,51 @@
1
+ /**
2
+ * InfiniteHits Component
3
+ *
4
+ * Displays search results with infinite scroll or "Show More" button
5
+ * Accumulates results as user loads more pages
6
+ */
7
+ import React from 'react';
8
+ import type { ResultItem, FieldMapping } from '@seekora-ai/ui-sdk-types';
9
+ export interface InfiniteHitsTheme {
10
+ root?: string;
11
+ list?: string;
12
+ item?: string;
13
+ loadMore?: string;
14
+ loadMoreDisabled?: string;
15
+ empty?: string;
16
+ sentinel?: string;
17
+ }
18
+ export interface InfiniteHitsProps {
19
+ /** Custom render function for each hit */
20
+ renderHit?: (hit: ResultItem, index: number) => React.ReactNode;
21
+ /** Custom render for empty state */
22
+ renderEmpty?: () => React.ReactNode;
23
+ /** Custom render for "Show More" button */
24
+ renderShowMore?: (props: {
25
+ isLoading: boolean;
26
+ isLastPage: boolean;
27
+ onClick: () => void;
28
+ }) => React.ReactNode;
29
+ /** Whether to show the "Show More" button (default: true) */
30
+ showMoreButton?: boolean;
31
+ /** Whether to use infinite scroll with IntersectionObserver (default: false) */
32
+ useInfiniteScroll?: boolean;
33
+ /** Threshold for IntersectionObserver (default: 0.1) */
34
+ scrollThreshold?: number;
35
+ /** Field mapping for extracting data from hits */
36
+ fieldMapping?: FieldMapping;
37
+ /** Text for "Show More" button */
38
+ showMoreLabel?: string;
39
+ /** Callback when a hit is clicked */
40
+ onHitClick?: (hit: ResultItem, index: number) => void;
41
+ /** Custom className */
42
+ className?: string;
43
+ /** Custom styles */
44
+ style?: React.CSSProperties;
45
+ /** Custom theme */
46
+ theme?: InfiniteHitsTheme;
47
+ /** Whether to sync with SearchStateManager (default: true) */
48
+ syncWithState?: boolean;
49
+ }
50
+ export declare const InfiniteHits: React.FC<InfiniteHitsProps>;
51
+ //# sourceMappingURL=InfiniteHits.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InfiniteHits.d.ts","sourceRoot":"","sources":["../../src/components/InfiniteHits.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAA4D,MAAM,OAAO,CAAC;AAIjF,OAAO,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAEzE,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,iBAAiB;IAChC,0CAA0C;IAC1C,SAAS,CAAC,EAAE,CAAC,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,KAAK,KAAK,CAAC,SAAS,CAAC;IAChE,oCAAoC;IACpC,WAAW,CAAC,EAAE,MAAM,KAAK,CAAC,SAAS,CAAC;IACpC,2CAA2C;IAC3C,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE;QACvB,SAAS,EAAE,OAAO,CAAC;QACnB,UAAU,EAAE,OAAO,CAAC;QACpB,OAAO,EAAE,MAAM,IAAI,CAAC;KACrB,KAAK,KAAK,CAAC,SAAS,CAAC;IACtB,6DAA6D;IAC7D,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,gFAAgF;IAChF,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,wDAAwD;IACxD,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,kDAAkD;IAClD,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,kCAAkC;IAClC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,qCAAqC;IACrC,UAAU,CAAC,EAAE,CAAC,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACtD,uBAAuB;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,oBAAoB;IACpB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAC5B,mBAAmB;IACnB,KAAK,CAAC,EAAE,iBAAiB,CAAC;IAC1B,8DAA8D;IAC9D,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAED,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CA4QpD,CAAC"}
@@ -0,0 +1,173 @@
1
+ /**
2
+ * InfiniteHits Component
3
+ *
4
+ * Displays search results with infinite scroll or "Show More" button
5
+ * Accumulates results as user loads more pages
6
+ */
7
+ import React, { useState, useEffect, useRef, useCallback, useMemo } from 'react';
8
+ import { useSearchContext } from './SearchProvider';
9
+ import { useSearchState } from '../hooks/useSearchState';
10
+ import { clsx } from 'clsx';
11
+ export const InfiniteHits = ({ renderHit, renderEmpty, renderShowMore, showMoreButton = true, useInfiniteScroll = false, scrollThreshold = 0.1, fieldMapping, showMoreLabel = 'Show more', onHitClick, className, style, theme: customTheme, syncWithState = true, }) => {
12
+ const { theme, stateManager } = useSearchContext();
13
+ const { results, loading, currentPage, setPage } = useSearchState();
14
+ const infiniteHitsTheme = customTheme || {};
15
+ // Accumulated hits across pages
16
+ const [accumulatedHits, setAccumulatedHits] = useState([]);
17
+ const [isLoadingMore, setIsLoadingMore] = useState(false);
18
+ const sentinelRef = useRef(null);
19
+ const prevPageRef = useRef(currentPage);
20
+ // Extract hits from results
21
+ const extractHits = useCallback((response) => {
22
+ if (!response)
23
+ return [];
24
+ if (response.results)
25
+ return response.results;
26
+ if (response.hits)
27
+ return response.hits;
28
+ if (Array.isArray(response))
29
+ return response;
30
+ return [];
31
+ }, []);
32
+ // Get current hits
33
+ const currentHits = useMemo(() => extractHits(results), [results, extractHits]);
34
+ // Calculate if we're on the last page
35
+ const totalResults = results?.totalResults || results?.found || 0;
36
+ const itemsPerPage = stateManager.getState().itemsPerPage || 10;
37
+ const totalPages = Math.ceil(totalResults / itemsPerPage);
38
+ const isLastPage = currentPage >= totalPages;
39
+ // Accumulate hits when results change
40
+ useEffect(() => {
41
+ if (!currentHits.length)
42
+ return;
43
+ if (currentPage === 1) {
44
+ // Reset accumulated hits on new search
45
+ setAccumulatedHits(currentHits);
46
+ }
47
+ else if (currentPage > prevPageRef.current) {
48
+ // Append new hits
49
+ setAccumulatedHits(prev => [...prev, ...currentHits]);
50
+ }
51
+ prevPageRef.current = currentPage;
52
+ setIsLoadingMore(false);
53
+ }, [currentHits, currentPage]);
54
+ // Reset when query changes
55
+ useEffect(() => {
56
+ if (currentPage === 1) {
57
+ setAccumulatedHits(currentHits);
58
+ prevPageRef.current = 1;
59
+ }
60
+ }, [results]);
61
+ // Handle "Show More" click
62
+ const handleShowMore = useCallback(() => {
63
+ if (isLastPage || loading || isLoadingMore)
64
+ return;
65
+ setIsLoadingMore(true);
66
+ if (syncWithState) {
67
+ setPage(currentPage + 1);
68
+ }
69
+ }, [isLastPage, loading, isLoadingMore, syncWithState, setPage, currentPage]);
70
+ // Infinite scroll with IntersectionObserver
71
+ useEffect(() => {
72
+ if (!useInfiniteScroll || !sentinelRef.current)
73
+ return;
74
+ const observer = new IntersectionObserver((entries) => {
75
+ const entry = entries[0];
76
+ if (entry.isIntersecting && !isLastPage && !loading && !isLoadingMore) {
77
+ handleShowMore();
78
+ }
79
+ }, { threshold: scrollThreshold });
80
+ observer.observe(sentinelRef.current);
81
+ return () => observer.disconnect();
82
+ }, [useInfiniteScroll, scrollThreshold, isLastPage, loading, isLoadingMore, handleShowMore]);
83
+ // Extract field from hit
84
+ const extractField = (hit, field) => {
85
+ if (!fieldMapping || !fieldMapping[field]) {
86
+ return hit[field] || '';
87
+ }
88
+ const mappedField = fieldMapping[field];
89
+ return hit[mappedField] || '';
90
+ };
91
+ // Default hit renderer
92
+ const defaultRenderHit = (hit, index) => {
93
+ const title = extractField(hit, 'title') || hit.title || '';
94
+ const description = extractField(hit, 'description') || hit.description || '';
95
+ const image = extractField(hit, 'image') || hit.image || hit.imageUrl || '';
96
+ const price = extractField(hit, 'price') || hit.price;
97
+ return (React.createElement("div", { key: hit.id || index, className: infiniteHitsTheme.item, style: {
98
+ display: 'flex',
99
+ gap: theme.spacing.medium,
100
+ padding: theme.spacing.medium,
101
+ borderBottom: `1px solid ${theme.colors.border}`,
102
+ cursor: onHitClick ? 'pointer' : 'default',
103
+ transition: theme.transitions?.fast || '150ms ease-in-out',
104
+ }, onClick: () => onHitClick?.(hit, index), role: onHitClick ? 'button' : undefined, tabIndex: onHitClick ? 0 : undefined },
105
+ image && (React.createElement("img", { src: image, alt: title, style: {
106
+ width: '80px',
107
+ height: '80px',
108
+ objectFit: 'cover',
109
+ borderRadius: typeof theme.borderRadius === 'string'
110
+ ? theme.borderRadius
111
+ : theme.borderRadius.small,
112
+ } })),
113
+ React.createElement("div", { style: { flex: 1 } },
114
+ React.createElement("h3", { style: {
115
+ margin: 0,
116
+ marginBottom: theme.spacing.small,
117
+ fontSize: theme.typography.fontSize.medium,
118
+ fontWeight: theme.typography.fontWeight?.semibold || 600,
119
+ color: theme.colors.text,
120
+ } }, title),
121
+ description && (React.createElement("p", { style: {
122
+ margin: 0,
123
+ fontSize: theme.typography.fontSize.small,
124
+ color: theme.colors.textSecondary,
125
+ lineHeight: theme.typography.lineHeight?.normal || 1.5,
126
+ } }, description)),
127
+ price && (React.createElement("span", { style: {
128
+ display: 'inline-block',
129
+ marginTop: theme.spacing.small,
130
+ fontSize: theme.typography.fontSize.medium,
131
+ fontWeight: theme.typography.fontWeight?.bold || 700,
132
+ color: theme.colors.primary,
133
+ } },
134
+ "$",
135
+ typeof price === 'number' ? price.toFixed(2) : price)))));
136
+ };
137
+ // Default empty state
138
+ const defaultRenderEmpty = () => (React.createElement("div", { className: infiniteHitsTheme.empty, style: {
139
+ padding: theme.spacing.large,
140
+ textAlign: 'center',
141
+ color: theme.colors.textSecondary,
142
+ } }, "No results found"));
143
+ // Default "Show More" button
144
+ const defaultRenderShowMore = () => (React.createElement("button", { type: "button", onClick: handleShowMore, disabled: isLastPage || isLoadingMore, className: clsx(infiniteHitsTheme.loadMore, (isLastPage || isLoadingMore) && infiniteHitsTheme.loadMoreDisabled), style: {
145
+ display: 'block',
146
+ width: '100%',
147
+ padding: theme.spacing.medium,
148
+ marginTop: theme.spacing.medium,
149
+ fontSize: theme.typography.fontSize.medium,
150
+ fontWeight: theme.typography.fontWeight?.medium || 500,
151
+ backgroundColor: isLastPage || isLoadingMore ? theme.colors.hover : theme.colors.primary,
152
+ color: isLastPage || isLoadingMore ? theme.colors.textSecondary : '#ffffff',
153
+ border: 'none',
154
+ borderRadius: typeof theme.borderRadius === 'string'
155
+ ? theme.borderRadius
156
+ : theme.borderRadius.medium,
157
+ cursor: isLastPage || isLoadingMore ? 'not-allowed' : 'pointer',
158
+ transition: theme.transitions?.fast || '150ms ease-in-out',
159
+ } }, isLastPage ? 'No more results' : showMoreLabel));
160
+ if (loading && accumulatedHits.length === 0) {
161
+ return React.createElement("div", { className: clsx(infiniteHitsTheme.root, className), style: style });
162
+ }
163
+ // Empty state
164
+ if (!loading && accumulatedHits.length === 0) {
165
+ return (React.createElement("div", { className: clsx(infiniteHitsTheme.root, className), style: style }, renderEmpty ? renderEmpty() : defaultRenderEmpty()));
166
+ }
167
+ return (React.createElement("div", { className: clsx(infiniteHitsTheme.root, className), style: style },
168
+ React.createElement("div", { className: infiniteHitsTheme.list }, accumulatedHits.map((hit, index) => renderHit ? renderHit(hit, index) : defaultRenderHit(hit, index))),
169
+ showMoreButton && !useInfiniteScroll && !isLastPage && (renderShowMore
170
+ ? renderShowMore({ isLoading: isLoadingMore, isLastPage, onClick: handleShowMore })
171
+ : defaultRenderShowMore()),
172
+ useInfiniteScroll && !isLastPage && (React.createElement("div", { ref: sentinelRef, className: infiniteHitsTheme.sentinel, style: { height: '1px', visibility: 'hidden' }, "aria-hidden": "true" }))));
173
+ };
@@ -0,0 +1,71 @@
1
+ /**
2
+ * MobileFilters Component
3
+ *
4
+ * A full-screen filter drawer optimized for mobile devices
5
+ * Slides in from the side or bottom to display facets and filters
6
+ */
7
+ import React from 'react';
8
+ export interface MobileFiltersTheme {
9
+ overlay?: string;
10
+ drawer?: string;
11
+ header?: string;
12
+ title?: string;
13
+ closeButton?: string;
14
+ content?: string;
15
+ footer?: string;
16
+ applyButton?: string;
17
+ clearButton?: string;
18
+ filterCount?: string;
19
+ }
20
+ export interface MobileFiltersProps {
21
+ /** Whether the drawer is open */
22
+ isOpen: boolean;
23
+ /** Callback when drawer should close */
24
+ onClose: () => void;
25
+ /** Callback when filters are applied */
26
+ onApply?: () => void;
27
+ /** Title text */
28
+ title?: string;
29
+ /** Apply button text */
30
+ applyButtonText?: string;
31
+ /** Clear button text */
32
+ clearButtonText?: string;
33
+ /** Position of the drawer */
34
+ position?: 'left' | 'right' | 'bottom';
35
+ /** Children (filter components) */
36
+ children: React.ReactNode;
37
+ /** Custom className */
38
+ className?: string;
39
+ /** Custom theme */
40
+ theme?: MobileFiltersTheme;
41
+ /** Show header */
42
+ showHeader?: boolean;
43
+ /** Show footer with apply/clear buttons */
44
+ showFooter?: boolean;
45
+ /** Show filter count badge */
46
+ showFilterCount?: boolean;
47
+ /** Close on backdrop click */
48
+ closeOnBackdropClick?: boolean;
49
+ /** Close on escape key */
50
+ closeOnEscape?: boolean;
51
+ }
52
+ export declare const MobileFilters: React.FC<MobileFiltersProps>;
53
+ /**
54
+ * MobileFiltersButton Component
55
+ *
56
+ * A button to toggle the MobileFilters drawer
57
+ */
58
+ export interface MobileFiltersButtonProps {
59
+ /** Callback when clicked */
60
+ onClick: () => void;
61
+ /** Button text */
62
+ text?: string;
63
+ /** Show filter count */
64
+ showCount?: boolean;
65
+ /** Custom className */
66
+ className?: string;
67
+ /** Custom styles */
68
+ style?: React.CSSProperties;
69
+ }
70
+ export declare const MobileFiltersButton: React.FC<MobileFiltersButtonProps>;
71
+ //# sourceMappingURL=MobileFilters.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MobileFilters.d.ts","sourceRoot":"","sources":["../../src/components/MobileFilters.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAmD,MAAM,OAAO,CAAC;AAKxE,MAAM,WAAW,kBAAkB;IACjC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,kBAAkB;IACjC,iCAAiC;IACjC,MAAM,EAAE,OAAO,CAAC;IAChB,wCAAwC;IACxC,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,wCAAwC;IACxC,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,iBAAiB;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wBAAwB;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,wBAAwB;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,6BAA6B;IAC7B,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAC;IACvC,mCAAmC;IACnC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,uBAAuB;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,mBAAmB;IACnB,KAAK,CAAC,EAAE,kBAAkB,CAAC;IAC3B,kBAAkB;IAClB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,2CAA2C;IAC3C,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,8BAA8B;IAC9B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,8BAA8B;IAC9B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,0BAA0B;IAC1B,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAED,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CA4StD,CAAC;AAEF;;;;GAIG;AAEH,MAAM,WAAW,wBAAwB;IACvC,4BAA4B;IAC5B,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,kBAAkB;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,wBAAwB;IACxB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,uBAAuB;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,oBAAoB;IACpB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;CAC7B;AAED,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,wBAAwB,CAuDlE,CAAC"}
@@ -0,0 +1,242 @@
1
+ /**
2
+ * MobileFilters Component
3
+ *
4
+ * A full-screen filter drawer optimized for mobile devices
5
+ * Slides in from the side or bottom to display facets and filters
6
+ */
7
+ import React, { useEffect, useCallback, useRef } from 'react';
8
+ import { useSearchContext } from './SearchProvider';
9
+ import { useSearchState } from '../hooks/useSearchState';
10
+ import { clsx } from 'clsx';
11
+ export const MobileFilters = ({ isOpen, onClose, onApply, title = 'Filters', applyButtonText = 'Apply', clearButtonText = 'Clear all', position = 'right', children, className, theme: customTheme, showHeader = true, showFooter = true, showFilterCount = true, closeOnBackdropClick = true, closeOnEscape = true, }) => {
12
+ const { theme } = useSearchContext();
13
+ const { refinements, clearRefinements } = useSearchState();
14
+ const mobileFiltersTheme = customTheme || {};
15
+ const drawerRef = useRef(null);
16
+ // Lock body scroll when open
17
+ useEffect(() => {
18
+ if (isOpen) {
19
+ document.body.style.overflow = 'hidden';
20
+ }
21
+ else {
22
+ document.body.style.overflow = '';
23
+ }
24
+ return () => {
25
+ document.body.style.overflow = '';
26
+ };
27
+ }, [isOpen]);
28
+ // Handle escape key
29
+ useEffect(() => {
30
+ if (!closeOnEscape)
31
+ return;
32
+ const handleKeyDown = (e) => {
33
+ if (e.key === 'Escape' && isOpen) {
34
+ onClose();
35
+ }
36
+ };
37
+ document.addEventListener('keydown', handleKeyDown);
38
+ return () => document.removeEventListener('keydown', handleKeyDown);
39
+ }, [isOpen, onClose, closeOnEscape]);
40
+ // Focus trap
41
+ useEffect(() => {
42
+ if (isOpen && drawerRef.current) {
43
+ const focusableElements = drawerRef.current.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
44
+ const firstElement = focusableElements[0];
45
+ const lastElement = focusableElements[focusableElements.length - 1];
46
+ const handleTab = (e) => {
47
+ if (e.key !== 'Tab')
48
+ return;
49
+ if (e.shiftKey) {
50
+ if (document.activeElement === firstElement) {
51
+ e.preventDefault();
52
+ lastElement?.focus();
53
+ }
54
+ }
55
+ else {
56
+ if (document.activeElement === lastElement) {
57
+ e.preventDefault();
58
+ firstElement?.focus();
59
+ }
60
+ }
61
+ };
62
+ document.addEventListener('keydown', handleTab);
63
+ firstElement?.focus();
64
+ return () => document.removeEventListener('keydown', handleTab);
65
+ }
66
+ }, [isOpen]);
67
+ const handleBackdropClick = useCallback(() => {
68
+ if (closeOnBackdropClick) {
69
+ onClose();
70
+ }
71
+ }, [closeOnBackdropClick, onClose]);
72
+ const handleApply = useCallback(() => {
73
+ if (onApply) {
74
+ onApply();
75
+ }
76
+ onClose();
77
+ }, [onApply, onClose]);
78
+ const handleClear = useCallback(() => {
79
+ clearRefinements(true);
80
+ }, [clearRefinements]);
81
+ // Get drawer transform based on position
82
+ const getTransform = (isVisible) => {
83
+ if (isVisible)
84
+ return 'translate(0, 0)';
85
+ switch (position) {
86
+ case 'left':
87
+ return 'translateX(-100%)';
88
+ case 'right':
89
+ return 'translateX(100%)';
90
+ case 'bottom':
91
+ return 'translateY(100%)';
92
+ default:
93
+ return 'translateX(100%)';
94
+ }
95
+ };
96
+ // Get drawer styles based on position
97
+ const getDrawerPositionStyles = () => {
98
+ const base = {
99
+ position: 'fixed',
100
+ backgroundColor: theme.colors.background,
101
+ display: 'flex',
102
+ flexDirection: 'column',
103
+ transition: 'transform 300ms ease-in-out',
104
+ transform: getTransform(isOpen),
105
+ zIndex: (theme.zIndex?.modal || 1050) + 1,
106
+ };
107
+ switch (position) {
108
+ case 'left':
109
+ return { ...base, top: 0, left: 0, bottom: 0, width: '80%', maxWidth: '320px' };
110
+ case 'right':
111
+ return { ...base, top: 0, right: 0, bottom: 0, width: '80%', maxWidth: '320px' };
112
+ case 'bottom':
113
+ return { ...base, left: 0, right: 0, bottom: 0, maxHeight: '80vh', borderTopLeftRadius: '16px', borderTopRightRadius: '16px' };
114
+ default:
115
+ return base;
116
+ }
117
+ };
118
+ if (!isOpen)
119
+ return null;
120
+ return (React.createElement(React.Fragment, null,
121
+ React.createElement("div", { className: mobileFiltersTheme.overlay, onClick: handleBackdropClick, style: {
122
+ position: 'fixed',
123
+ top: 0,
124
+ left: 0,
125
+ right: 0,
126
+ bottom: 0,
127
+ backgroundColor: 'rgba(0, 0, 0, 0.5)',
128
+ zIndex: theme.zIndex?.modal || 1050,
129
+ opacity: isOpen ? 1 : 0,
130
+ transition: 'opacity 300ms ease-in-out',
131
+ }, "aria-hidden": "true" }),
132
+ React.createElement("div", { ref: drawerRef, className: clsx(mobileFiltersTheme.drawer, className), style: getDrawerPositionStyles(), role: "dialog", "aria-modal": "true", "aria-label": title },
133
+ showHeader && (React.createElement("div", { className: mobileFiltersTheme.header, style: {
134
+ display: 'flex',
135
+ alignItems: 'center',
136
+ justifyContent: 'space-between',
137
+ padding: theme.spacing.medium,
138
+ borderBottom: `1px solid ${theme.colors.border}`,
139
+ } },
140
+ React.createElement("div", { style: { display: 'flex', alignItems: 'center', gap: theme.spacing.small } },
141
+ React.createElement("h2", { className: mobileFiltersTheme.title, style: {
142
+ margin: 0,
143
+ fontSize: theme.typography.fontSize.large,
144
+ fontWeight: theme.typography.fontWeight?.semibold || 600,
145
+ color: theme.colors.text,
146
+ } }, title),
147
+ showFilterCount && refinements.length > 0 && (React.createElement("span", { className: mobileFiltersTheme.filterCount, style: {
148
+ display: 'inline-flex',
149
+ alignItems: 'center',
150
+ justifyContent: 'center',
151
+ minWidth: '24px',
152
+ height: '24px',
153
+ padding: '0 6px',
154
+ fontSize: theme.typography.fontSize.small,
155
+ fontWeight: theme.typography.fontWeight?.bold || 700,
156
+ color: '#ffffff',
157
+ backgroundColor: theme.colors.primary,
158
+ borderRadius: '12px',
159
+ } }, refinements.length))),
160
+ React.createElement("button", { type: "button", onClick: onClose, className: mobileFiltersTheme.closeButton, style: {
161
+ padding: theme.spacing.small,
162
+ background: 'none',
163
+ border: 'none',
164
+ cursor: 'pointer',
165
+ fontSize: '1.5rem',
166
+ color: theme.colors.text,
167
+ }, "aria-label": "Close filters" }, "\u00D7"))),
168
+ React.createElement("div", { className: mobileFiltersTheme.content, style: {
169
+ flex: 1,
170
+ overflow: 'auto',
171
+ padding: theme.spacing.medium,
172
+ } }, children),
173
+ showFooter && (React.createElement("div", { className: mobileFiltersTheme.footer, style: {
174
+ display: 'flex',
175
+ gap: theme.spacing.small,
176
+ padding: theme.spacing.medium,
177
+ borderTop: `1px solid ${theme.colors.border}`,
178
+ } },
179
+ React.createElement("button", { type: "button", onClick: handleClear, className: mobileFiltersTheme.clearButton, style: {
180
+ flex: 1,
181
+ padding: theme.spacing.medium,
182
+ fontSize: theme.typography.fontSize.medium,
183
+ fontWeight: theme.typography.fontWeight?.medium || 500,
184
+ color: theme.colors.text,
185
+ backgroundColor: 'transparent',
186
+ border: `1px solid ${theme.colors.border}`,
187
+ borderRadius: typeof theme.borderRadius === 'string'
188
+ ? theme.borderRadius
189
+ : theme.borderRadius.medium,
190
+ cursor: 'pointer',
191
+ } }, clearButtonText),
192
+ React.createElement("button", { type: "button", onClick: handleApply, className: mobileFiltersTheme.applyButton, style: {
193
+ flex: 2,
194
+ padding: theme.spacing.medium,
195
+ fontSize: theme.typography.fontSize.medium,
196
+ fontWeight: theme.typography.fontWeight?.medium || 500,
197
+ color: '#ffffff',
198
+ backgroundColor: theme.colors.primary,
199
+ border: 'none',
200
+ borderRadius: typeof theme.borderRadius === 'string'
201
+ ? theme.borderRadius
202
+ : theme.borderRadius.medium,
203
+ cursor: 'pointer',
204
+ } },
205
+ applyButtonText,
206
+ showFilterCount && refinements.length > 0 && ` (${refinements.length})`))))));
207
+ };
208
+ export const MobileFiltersButton = ({ onClick, text = 'Filters', showCount = true, className, style, }) => {
209
+ const { theme } = useSearchContext();
210
+ const { refinements } = useSearchState();
211
+ return (React.createElement("button", { type: "button", onClick: onClick, className: className, style: {
212
+ display: 'inline-flex',
213
+ alignItems: 'center',
214
+ gap: theme.spacing.small,
215
+ padding: `${theme.spacing.small} ${theme.spacing.medium}`,
216
+ fontSize: theme.typography.fontSize.medium,
217
+ fontWeight: theme.typography.fontWeight?.medium || 500,
218
+ color: theme.colors.text,
219
+ backgroundColor: theme.colors.background,
220
+ border: `1px solid ${theme.colors.border}`,
221
+ borderRadius: typeof theme.borderRadius === 'string'
222
+ ? theme.borderRadius
223
+ : theme.borderRadius.medium,
224
+ cursor: 'pointer',
225
+ ...style,
226
+ } },
227
+ React.createElement("span", null, "\u2630"),
228
+ React.createElement("span", null, text),
229
+ showCount && refinements.length > 0 && (React.createElement("span", { style: {
230
+ display: 'inline-flex',
231
+ alignItems: 'center',
232
+ justifyContent: 'center',
233
+ minWidth: '20px',
234
+ height: '20px',
235
+ padding: '0 4px',
236
+ fontSize: theme.typography.fontSize.small,
237
+ fontWeight: theme.typography.fontWeight?.bold || 700,
238
+ color: '#ffffff',
239
+ backgroundColor: theme.colors.primary,
240
+ borderRadius: '10px',
241
+ } }, refinements.length))));
242
+ };
@@ -0,0 +1,90 @@
1
+ /**
2
+ * Pagination Component
3
+ *
4
+ * Displays pagination controls for search results.
5
+ * Supports three display variants: numbered, load-more, and simple.
6
+ *
7
+ * CSS Variables (applied to the container element):
8
+ * --seekora-pagination-bg
9
+ * --seekora-pagination-color
10
+ * --seekora-pagination-active-bg
11
+ * --seekora-pagination-active-color
12
+ * --seekora-pagination-border
13
+ * --seekora-pagination-radius
14
+ */
15
+ import React from 'react';
16
+ import type { SearchResponse } from '@seekora-ai/search-sdk';
17
+ export interface PaginationTheme {
18
+ container?: string;
19
+ list?: string;
20
+ item?: string;
21
+ itemActive?: string;
22
+ itemDisabled?: string;
23
+ link?: string;
24
+ ellipsis?: string;
25
+ /** Class for the Load More button */
26
+ loadMoreButton?: string;
27
+ /** Class for the Load More descriptive text (e.g. "X remaining") */
28
+ loadMoreText?: string;
29
+ /** Class for the simple variant outer container */
30
+ simpleContainer?: string;
31
+ /** Class for the "Page X of Y" text in the simple variant */
32
+ simpleText?: string;
33
+ /** Class for Previous/Next buttons in the simple variant */
34
+ simpleButton?: string;
35
+ /** Class for the "Page X of Y" info text (usable in any variant) */
36
+ pageInfo?: string;
37
+ }
38
+ export interface PaginationProps {
39
+ /** Search results response */
40
+ results?: SearchResponse | null;
41
+ /** Current page number (1-indexed) */
42
+ currentPage?: number;
43
+ /** Items per page */
44
+ itemsPerPage?: number;
45
+ /** Total number of pages */
46
+ totalPages?: number;
47
+ /** Callback when page changes */
48
+ onPageChange?: (page: number) => void;
49
+ /** Maximum number of page buttons to show */
50
+ maxPages?: number;
51
+ /** Show first/last page buttons */
52
+ showFirstLast?: boolean;
53
+ /** Show previous/next buttons */
54
+ showPrevNext?: boolean;
55
+ /** Custom render function for page button */
56
+ renderPageButton?: (page: number, isActive: boolean, isDisabled: boolean) => React.ReactNode;
57
+ /** Custom className */
58
+ className?: string;
59
+ /** Custom styles */
60
+ style?: React.CSSProperties;
61
+ /** Custom theme */
62
+ theme?: PaginationTheme;
63
+ /**
64
+ * Display variant.
65
+ * - 'numbered' (default): numbered page buttons with prev/next
66
+ * - 'load-more': single "Load More" button
67
+ * - 'simple': Previous / Next buttons with "Page X of Y" text
68
+ */
69
+ variant?: 'numbered' | 'load-more' | 'simple';
70
+ /** Label for the Load More button (default: "Load More") */
71
+ loadMoreText?: string;
72
+ /**
73
+ * Button / text sizing.
74
+ * - 'small': compact
75
+ * - 'medium' (default): standard
76
+ * - 'large': spacious
77
+ */
78
+ size?: 'small' | 'medium' | 'large';
79
+ /**
80
+ * Show "Page X of Y" text.
81
+ * Defaults to false for numbered, true for simple.
82
+ */
83
+ showPageInfo?: boolean;
84
+ /** Label for the Previous button (default: "Previous") */
85
+ previousLabel?: string;
86
+ /** Label for the Next button (default: "Next") */
87
+ nextLabel?: string;
88
+ }
89
+ export declare const Pagination: React.FC<PaginationProps>;
90
+ //# sourceMappingURL=Pagination.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Pagination.d.ts","sourceRoot":"","sources":["../../src/components/Pagination.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAG7D,MAAM,WAAW,eAAe;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,qCAAqC;IACrC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,oEAAoE;IACpE,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,mDAAmD;IACnD,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,6DAA6D;IAC7D,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,4DAA4D;IAC5D,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,oEAAoE;IACpE,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,eAAe;IAC9B,8BAA8B;IAC9B,OAAO,CAAC,EAAE,cAAc,GAAG,IAAI,CAAC;IAChC,sCAAsC;IACtC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,qBAAqB;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,4BAA4B;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,iCAAiC;IACjC,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,6CAA6C;IAC7C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,mCAAmC;IACnC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,iCAAiC;IACjC,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,6CAA6C;IAC7C,gBAAgB,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,KAAK,KAAK,CAAC,SAAS,CAAC;IAC7F,uBAAuB;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,oBAAoB;IACpB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAC5B,mBAAmB;IACnB,KAAK,CAAC,EAAE,eAAe,CAAC;IACxB;;;;;OAKG;IACH,OAAO,CAAC,EAAE,UAAU,GAAG,WAAW,GAAG,QAAQ,CAAC;IAC9C,4DAA4D;IAC5D,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB;;;;;OAKG;IACH,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC;IACpC;;;OAGG;IACH,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,0DAA0D;IAC1D,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,kDAAkD;IAClD,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAmBD,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CA0bhD,CAAC"}