@seekora-ai/ui-sdk-react 0.1.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 (169) 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 +80 -0
  7. package/dist/components/CurrentRefinements.d.ts +41 -0
  8. package/dist/components/CurrentRefinements.d.ts.map +1 -0
  9. package/dist/components/CurrentRefinements.js +83 -0
  10. package/dist/components/Facets.d.ts +53 -0
  11. package/dist/components/Facets.d.ts.map +1 -0
  12. package/dist/components/Facets.js +195 -0
  13. package/dist/components/FederatedDropdown.d.ts +92 -0
  14. package/dist/components/FederatedDropdown.d.ts.map +1 -0
  15. package/dist/components/FederatedDropdown.js +510 -0
  16. package/dist/components/HierarchicalMenu.d.ts +55 -0
  17. package/dist/components/HierarchicalMenu.d.ts.map +1 -0
  18. package/dist/components/HierarchicalMenu.js +168 -0
  19. package/dist/components/Highlight.d.ts +51 -0
  20. package/dist/components/Highlight.d.ts.map +1 -0
  21. package/dist/components/Highlight.js +155 -0
  22. package/dist/components/HitsPerPage.d.ts +41 -0
  23. package/dist/components/HitsPerPage.d.ts.map +1 -0
  24. package/dist/components/HitsPerPage.js +72 -0
  25. package/dist/components/InfiniteHits.d.ts +56 -0
  26. package/dist/components/InfiniteHits.d.ts.map +1 -0
  27. package/dist/components/InfiniteHits.js +181 -0
  28. package/dist/components/MobileFilters.d.ts +71 -0
  29. package/dist/components/MobileFilters.d.ts.map +1 -0
  30. package/dist/components/MobileFilters.js +242 -0
  31. package/dist/components/Pagination.d.ts +44 -0
  32. package/dist/components/Pagination.d.ts.map +1 -0
  33. package/dist/components/Pagination.js +142 -0
  34. package/dist/components/QuerySuggestions.d.ts +38 -0
  35. package/dist/components/QuerySuggestions.d.ts.map +1 -0
  36. package/dist/components/QuerySuggestions.js +86 -0
  37. package/dist/components/QuerySuggestionsDropdown.d.ts +86 -0
  38. package/dist/components/QuerySuggestionsDropdown.d.ts.map +1 -0
  39. package/dist/components/QuerySuggestionsDropdown.js +395 -0
  40. package/dist/components/RangeInput.d.ts +58 -0
  41. package/dist/components/RangeInput.d.ts.map +1 -0
  42. package/dist/components/RangeInput.js +203 -0
  43. package/dist/components/RangeSlider.d.ts +51 -0
  44. package/dist/components/RangeSlider.d.ts.map +1 -0
  45. package/dist/components/RangeSlider.js +193 -0
  46. package/dist/components/Recommendations.d.ts +90 -0
  47. package/dist/components/Recommendations.d.ts.map +1 -0
  48. package/dist/components/Recommendations.js +270 -0
  49. package/dist/components/RichQuerySuggestions.d.ts +77 -0
  50. package/dist/components/RichQuerySuggestions.d.ts.map +1 -0
  51. package/dist/components/RichQuerySuggestions.js +492 -0
  52. package/dist/components/SearchBar.d.ts +40 -0
  53. package/dist/components/SearchBar.d.ts.map +1 -0
  54. package/dist/components/SearchBar.js +217 -0
  55. package/dist/components/SearchBarWithSuggestions.d.ts +99 -0
  56. package/dist/components/SearchBarWithSuggestions.d.ts.map +1 -0
  57. package/dist/components/SearchBarWithSuggestions.js +275 -0
  58. package/dist/components/SearchLayout.d.ts +35 -0
  59. package/dist/components/SearchLayout.d.ts.map +1 -0
  60. package/dist/components/SearchLayout.js +56 -0
  61. package/dist/components/SearchProvider.d.ts +28 -0
  62. package/dist/components/SearchProvider.d.ts.map +1 -0
  63. package/dist/components/SearchProvider.js +43 -0
  64. package/dist/components/SearchResults.d.ts +51 -0
  65. package/dist/components/SearchResults.d.ts.map +1 -0
  66. package/dist/components/SearchResults.js +485 -0
  67. package/dist/components/SortBy.d.ts +44 -0
  68. package/dist/components/SortBy.d.ts.map +1 -0
  69. package/dist/components/SortBy.js +61 -0
  70. package/dist/components/Stats.d.ts +37 -0
  71. package/dist/components/Stats.d.ts.map +1 -0
  72. package/dist/components/Stats.js +52 -0
  73. package/dist/components/suggestions/AmazonDropdown.d.ts +30 -0
  74. package/dist/components/suggestions/AmazonDropdown.d.ts.map +1 -0
  75. package/dist/components/suggestions/AmazonDropdown.js +529 -0
  76. package/dist/components/suggestions/GoogleDropdown.d.ts +31 -0
  77. package/dist/components/suggestions/GoogleDropdown.d.ts.map +1 -0
  78. package/dist/components/suggestions/GoogleDropdown.js +370 -0
  79. package/dist/components/suggestions/MinimalDropdown.d.ts +24 -0
  80. package/dist/components/suggestions/MinimalDropdown.d.ts.map +1 -0
  81. package/dist/components/suggestions/MinimalDropdown.js +314 -0
  82. package/dist/components/suggestions/MobileSheetDropdown.d.ts +31 -0
  83. package/dist/components/suggestions/MobileSheetDropdown.d.ts.map +1 -0
  84. package/dist/components/suggestions/MobileSheetDropdown.js +485 -0
  85. package/dist/components/suggestions/PinterestDropdown.d.ts +29 -0
  86. package/dist/components/suggestions/PinterestDropdown.d.ts.map +1 -0
  87. package/dist/components/suggestions/PinterestDropdown.js +450 -0
  88. package/dist/components/suggestions/ShopifyDropdown.d.ts +27 -0
  89. package/dist/components/suggestions/ShopifyDropdown.d.ts.map +1 -0
  90. package/dist/components/suggestions/ShopifyDropdown.js +451 -0
  91. package/dist/components/suggestions/SpotlightDropdown.d.ts +33 -0
  92. package/dist/components/suggestions/SpotlightDropdown.d.ts.map +1 -0
  93. package/dist/components/suggestions/SpotlightDropdown.js +547 -0
  94. package/dist/components/suggestions/SuggestionSearchBar.d.ts +123 -0
  95. package/dist/components/suggestions/SuggestionSearchBar.d.ts.map +1 -0
  96. package/dist/components/suggestions/SuggestionSearchBar.js +652 -0
  97. package/dist/components/suggestions/index.d.ts +37 -0
  98. package/dist/components/suggestions/index.d.ts.map +1 -0
  99. package/dist/components/suggestions/index.js +59 -0
  100. package/dist/components/suggestions/styles/index.d.ts +11 -0
  101. package/dist/components/suggestions/styles/index.d.ts.map +1 -0
  102. package/dist/components/suggestions/styles/index.js +289 -0
  103. package/dist/components/suggestions/styles/responsive.d.ts +107 -0
  104. package/dist/components/suggestions/styles/responsive.d.ts.map +1 -0
  105. package/dist/components/suggestions/styles/responsive.js +237 -0
  106. package/dist/components/suggestions/types.d.ts +489 -0
  107. package/dist/components/suggestions/types.d.ts.map +1 -0
  108. package/dist/components/suggestions/types.js +6 -0
  109. package/dist/components/suggestions/utils.d.ts +213 -0
  110. package/dist/components/suggestions/utils.d.ts.map +1 -0
  111. package/dist/components/suggestions/utils.js +514 -0
  112. package/dist/hooks/useAnalytics.d.ts +20 -0
  113. package/dist/hooks/useAnalytics.d.ts.map +1 -0
  114. package/dist/hooks/useAnalytics.js +62 -0
  115. package/dist/hooks/useNaturalLanguageFilters.d.ts +48 -0
  116. package/dist/hooks/useNaturalLanguageFilters.d.ts.map +1 -0
  117. package/dist/hooks/useNaturalLanguageFilters.js +221 -0
  118. package/dist/hooks/useQuerySuggestions.d.ts +21 -0
  119. package/dist/hooks/useQuerySuggestions.d.ts.map +1 -0
  120. package/dist/hooks/useQuerySuggestions.js +68 -0
  121. package/dist/hooks/useQuerySuggestionsEnhanced.d.ts +114 -0
  122. package/dist/hooks/useQuerySuggestionsEnhanced.d.ts.map +1 -0
  123. package/dist/hooks/useQuerySuggestionsEnhanced.js +376 -0
  124. package/dist/hooks/useSearchState.d.ts +35 -0
  125. package/dist/hooks/useSearchState.d.ts.map +1 -0
  126. package/dist/hooks/useSearchState.js +68 -0
  127. package/dist/hooks/useSeekoraSearch.d.ts +20 -0
  128. package/dist/hooks/useSeekoraSearch.d.ts.map +1 -0
  129. package/dist/hooks/useSeekoraSearch.js +63 -0
  130. package/dist/hooks/useSmartSuggestions.d.ts +55 -0
  131. package/dist/hooks/useSmartSuggestions.d.ts.map +1 -0
  132. package/dist/hooks/useSmartSuggestions.js +236 -0
  133. package/dist/hooks/useSuggestionsAnalytics.d.ts +91 -0
  134. package/dist/hooks/useSuggestionsAnalytics.d.ts.map +1 -0
  135. package/dist/hooks/useSuggestionsAnalytics.js +226 -0
  136. package/dist/index.d.ts +80 -0
  137. package/dist/index.d.ts.map +1 -0
  138. package/dist/index.js +86 -0
  139. package/dist/index.umd.js +1 -0
  140. package/dist/src/index.d.ts +2849 -0
  141. package/dist/src/index.esm.js +11679 -0
  142. package/dist/src/index.esm.js.map +1 -0
  143. package/dist/src/index.js +11761 -0
  144. package/dist/src/index.js.map +1 -0
  145. package/dist/themes/createTheme.d.ts +8 -0
  146. package/dist/themes/createTheme.d.ts.map +1 -0
  147. package/dist/themes/createTheme.js +10 -0
  148. package/dist/themes/dark.d.ts +6 -0
  149. package/dist/themes/dark.d.ts.map +1 -0
  150. package/dist/themes/dark.js +34 -0
  151. package/dist/themes/default.d.ts +6 -0
  152. package/dist/themes/default.d.ts.map +1 -0
  153. package/dist/themes/default.js +71 -0
  154. package/dist/themes/mergeThemes.d.ts +7 -0
  155. package/dist/themes/mergeThemes.d.ts.map +1 -0
  156. package/dist/themes/mergeThemes.js +6 -0
  157. package/dist/themes/minimal.d.ts +6 -0
  158. package/dist/themes/minimal.d.ts.map +1 -0
  159. package/dist/themes/minimal.js +34 -0
  160. package/dist/themes/suggestions.d.ts +216 -0
  161. package/dist/themes/suggestions.d.ts.map +1 -0
  162. package/dist/themes/suggestions.js +546 -0
  163. package/dist/themes/types.d.ts +7 -0
  164. package/dist/themes/types.d.ts.map +1 -0
  165. package/dist/themes/types.js +6 -0
  166. package/dist/types/index.d.ts +33 -0
  167. package/dist/types/index.d.ts.map +1 -0
  168. package/dist/types/index.js +4 -0
  169. package/package.json +65 -0
@@ -0,0 +1,314 @@
1
+ /**
2
+ * MinimalDropdown - Ultra-Clean Minimalist Style
3
+ *
4
+ * Features:
5
+ * - Stripped-down, distraction-free design
6
+ * - Focus on typography and whitespace
7
+ * - Subtle animations
8
+ * - Perfect for editorial/content sites
9
+ */
10
+ import React, { useState, useRef, useCallback, forwardRef, useImperativeHandle, useMemo, useEffect, } from 'react';
11
+ import { extractSuggestion, extractProduct, formatPrice, highlightText, cx, mergeStyles, generateCSSVariables, scrollIntoViewIfNeeded, } from './utils';
12
+ import { useResponsive } from './styles/responsive';
13
+ import { useInjectResponsiveStyles } from './styles';
14
+ // ============================================================================
15
+ // Styles
16
+ // ============================================================================
17
+ const createStyles = () => ({
18
+ root: {
19
+ position: 'absolute',
20
+ top: '100%',
21
+ left: 0,
22
+ right: 0,
23
+ marginTop: '4px',
24
+ backgroundColor: 'var(--seekora-bg-surface, #ffffff)',
25
+ border: '1px solid var(--seekora-border-color, #e5e5e5)',
26
+ fontFamily: 'var(--seekora-font-family, "Inter", -apple-system, sans-serif)',
27
+ fontSize: 'var(--seekora-font-size, 15px)',
28
+ letterSpacing: '-0.01em',
29
+ },
30
+ item: {
31
+ display: 'flex',
32
+ alignItems: 'center',
33
+ padding: '16px 20px',
34
+ cursor: 'pointer',
35
+ transition: 'background-color 150ms ease, padding-left 150ms ease',
36
+ borderBottom: '1px solid var(--seekora-border-color, #e8e8e8)',
37
+ gap: '16px',
38
+ color: 'var(--seekora-text-primary, #111)',
39
+ },
40
+ itemLast: {
41
+ borderBottom: 'none',
42
+ },
43
+ itemActive: {
44
+ backgroundColor: 'var(--seekora-bg-hover, #f5f5f5)',
45
+ color: 'var(--seekora-text-primary, #111)',
46
+ paddingLeft: '24px',
47
+ },
48
+ itemIndex: {
49
+ fontSize: '11px',
50
+ fontWeight: 500,
51
+ color: 'var(--seekora-text-tertiary, #999)',
52
+ fontFamily: 'monospace',
53
+ minWidth: '20px',
54
+ },
55
+ itemContent: {
56
+ flex: 1,
57
+ minWidth: 0,
58
+ },
59
+ itemQuery: {
60
+ fontSize: '15px',
61
+ fontWeight: 500,
62
+ color: 'var(--seekora-text-primary, #111)',
63
+ },
64
+ itemMeta: {
65
+ fontSize: '13px',
66
+ color: 'var(--seekora-text-secondary, #666)',
67
+ marginTop: '4px',
68
+ fontWeight: 400,
69
+ },
70
+ itemType: {
71
+ fontSize: '10px',
72
+ fontWeight: 600,
73
+ color: 'var(--seekora-text-tertiary, #999)',
74
+ textTransform: 'uppercase',
75
+ letterSpacing: '0.1em',
76
+ padding: '4px 8px',
77
+ backgroundColor: 'var(--seekora-bg-secondary, #f5f5f5)',
78
+ },
79
+ productRow: {
80
+ display: 'flex',
81
+ alignItems: 'center',
82
+ padding: '16px 20px',
83
+ cursor: 'pointer',
84
+ transition: 'background-color 150ms ease',
85
+ borderBottom: '1px solid var(--seekora-border-color, #e8e8e8)',
86
+ gap: '16px',
87
+ color: 'var(--seekora-text-primary, #111)',
88
+ },
89
+ productRowActive: {
90
+ backgroundColor: 'var(--seekora-bg-hover, #f5f5f5)',
91
+ color: 'var(--seekora-text-primary, #111)',
92
+ },
93
+ productImage: {
94
+ width: '56px',
95
+ height: '56px',
96
+ objectFit: 'cover',
97
+ backgroundColor: 'var(--seekora-bg-secondary, #f5f5f5)',
98
+ flexShrink: 0,
99
+ },
100
+ productContent: {
101
+ flex: 1,
102
+ minWidth: 0,
103
+ },
104
+ productTitle: {
105
+ fontSize: '14px',
106
+ fontWeight: 500,
107
+ color: 'var(--seekora-text-primary, #111)',
108
+ marginBottom: '4px',
109
+ },
110
+ productPrice: {
111
+ fontSize: '14px',
112
+ color: 'var(--seekora-text-secondary, #666)',
113
+ },
114
+ divider: {
115
+ padding: '12px 20px 8px',
116
+ fontSize: '10px',
117
+ fontWeight: 600,
118
+ color: 'var(--seekora-text-tertiary, #999)',
119
+ textTransform: 'uppercase',
120
+ letterSpacing: '0.15em',
121
+ backgroundColor: 'var(--seekora-bg-surface, #ffffff)',
122
+ borderBottom: '1px solid var(--seekora-border-color, #f0f0f0)',
123
+ },
124
+ footer: {
125
+ padding: '12px 20px',
126
+ display: 'flex',
127
+ alignItems: 'center',
128
+ justifyContent: 'space-between',
129
+ backgroundColor: 'var(--seekora-bg-secondary, #fafafa)',
130
+ fontSize: '12px',
131
+ color: 'var(--seekora-text-tertiary, #999)',
132
+ borderTop: '1px solid var(--seekora-border-color, #e5e5e5)',
133
+ },
134
+ footerHint: {
135
+ display: 'flex',
136
+ alignItems: 'center',
137
+ gap: '12px',
138
+ },
139
+ kbd: {
140
+ display: 'inline-flex',
141
+ alignItems: 'center',
142
+ justifyContent: 'center',
143
+ padding: '2px 6px',
144
+ backgroundColor: 'var(--seekora-bg-surface, #ffffff)',
145
+ border: '1px solid var(--seekora-border-color, #ddd)',
146
+ fontSize: '10px',
147
+ fontFamily: 'monospace',
148
+ },
149
+ loading: {
150
+ padding: '40px 20px',
151
+ textAlign: 'center',
152
+ color: 'var(--seekora-text-secondary, #666)',
153
+ fontSize: '14px',
154
+ },
155
+ empty: {
156
+ padding: '40px 20px',
157
+ textAlign: 'center',
158
+ color: 'var(--seekora-text-secondary, #666)',
159
+ fontSize: '14px',
160
+ },
161
+ highlight: {
162
+ backgroundColor: 'var(--seekora-highlight-bg, #fff3cd)',
163
+ padding: '0 2px',
164
+ },
165
+ });
166
+ export const MinimalDropdown = forwardRef(function MinimalDropdown(props, ref) {
167
+ const { query, isOpen = true, loading = false, suggestions = [], products = [], recentSearches = [], suggestionFields = { query: 'query' }, productFields = { id: 'id', title: 'title' }, productDisplay = {}, theme = {}, showIndices = false, showTypeLabels = false, showSectionDividers = true, width = '100%', maxHeight = '400px', zIndex = 1000, className, style, classNames = {}, onSuggestionSelect, onProductClick, onRecentClick, onClose, onSearchSubmit, header, footer, renderLoading, renderEmpty, } = props;
168
+ // Inject global responsive styles
169
+ useInjectResponsiveStyles();
170
+ // Responsive state
171
+ const responsive = useResponsive();
172
+ const { isMobile } = responsive;
173
+ const styles = useMemo(() => createStyles(), []);
174
+ const containerRef = useRef(null);
175
+ const listRef = useRef(null);
176
+ const [activeIndex, setActiveIndex] = useState(-1);
177
+ // Process data
178
+ const processedSuggestions = useMemo(() => suggestions.map(s => extractSuggestion(s, suggestionFields)), [suggestions, suggestionFields]);
179
+ const processedProducts = useMemo(() => products.map(p => extractProduct(p, productFields)), [products, productFields]);
180
+ const recentQueries = useMemo(() => recentSearches.map(r => typeof r === 'string' ? r : r.query).slice(0, 3), [recentSearches]);
181
+ // All items for navigation
182
+ const allItems = useMemo(() => {
183
+ const items = [];
184
+ if (!query && recentQueries.length > 0) {
185
+ recentQueries.forEach(q => items.push({ type: 'recent', data: q }));
186
+ }
187
+ processedSuggestions.forEach(s => items.push({ type: 'suggestion', data: s }));
188
+ processedProducts.forEach(p => items.push({ type: 'product', data: p }));
189
+ return items;
190
+ }, [query, recentQueries, processedSuggestions, processedProducts]);
191
+ // Navigation
192
+ const navigateNext = useCallback(() => {
193
+ setActiveIndex(prev => Math.min(prev + 1, allItems.length - 1));
194
+ }, [allItems.length]);
195
+ const navigatePrevious = useCallback(() => {
196
+ setActiveIndex(prev => Math.max(prev - 1, -1));
197
+ }, []);
198
+ const selectActive = useCallback(() => {
199
+ const item = allItems[activeIndex];
200
+ if (!item) {
201
+ if (query)
202
+ onSearchSubmit?.(query);
203
+ return;
204
+ }
205
+ switch (item.type) {
206
+ case 'recent':
207
+ onRecentClick?.(item.data);
208
+ break;
209
+ case 'suggestion':
210
+ onSuggestionSelect?.(item.data._raw, activeIndex);
211
+ break;
212
+ case 'product':
213
+ onProductClick?.(item.data._raw, activeIndex);
214
+ break;
215
+ }
216
+ }, [activeIndex, allItems, query, onSearchSubmit, onRecentClick, onSuggestionSelect, onProductClick]);
217
+ // Expose ref
218
+ useImperativeHandle(ref, () => ({
219
+ getActiveIndex: () => activeIndex,
220
+ setActiveIndex,
221
+ selectActive,
222
+ navigateNext,
223
+ navigatePrevious,
224
+ focus: () => containerRef.current?.focus(),
225
+ close: () => onClose?.(),
226
+ }), [activeIndex, selectActive, navigateNext, navigatePrevious, onClose]);
227
+ // Scroll active into view
228
+ useEffect(() => {
229
+ if (listRef.current && activeIndex >= 0) {
230
+ const activeEl = listRef.current.querySelector(`[data-index="${activeIndex}"]`);
231
+ if (activeEl) {
232
+ scrollIntoViewIfNeeded(activeEl, listRef.current);
233
+ }
234
+ }
235
+ }, [activeIndex]);
236
+ // Reset on query change
237
+ useEffect(() => {
238
+ setActiveIndex(-1);
239
+ }, [query]);
240
+ if (!isOpen)
241
+ return null;
242
+ const cssVariables = generateCSSVariables(theme);
243
+ const showRecent = !query && recentQueries.length > 0;
244
+ let globalIndex = 0;
245
+ return (React.createElement("div", { ref: containerRef, role: "listbox", "aria-label": "Search suggestions", className: cx('seekora-minimal-dropdown', className, classNames.root), style: mergeStyles(styles.root, { width, zIndex }, cssVariables, style), tabIndex: -1 },
246
+ React.createElement("style", null, `
247
+ .seekora-minimal-dropdown mark {
248
+ background-color: var(--seekora-highlight-bg, #fff3cd);
249
+ padding: 0 2px;
250
+ }
251
+ `),
252
+ header,
253
+ React.createElement("div", { ref: listRef, style: { maxHeight, overflowY: 'auto' } }, loading ? (renderLoading ? renderLoading() : (React.createElement("div", { style: styles.loading }, "Loading..."))) : allItems.length === 0 ? (renderEmpty ? renderEmpty(query) : (React.createElement("div", { style: styles.empty }, query ? `No results for "${query}"` : 'Start typing to search'))) : (React.createElement(React.Fragment, null,
254
+ showRecent && (React.createElement(React.Fragment, null,
255
+ showSectionDividers && (React.createElement("div", { style: styles.divider }, "Recent")),
256
+ recentQueries.map((q, idx) => {
257
+ const itemIdx = globalIndex++;
258
+ const isActive = activeIndex === itemIdx;
259
+ const isLast = idx === recentQueries.length - 1 && !processedSuggestions.length && !processedProducts.length;
260
+ return (React.createElement("div", { key: `recent-${q}`, "data-index": itemIdx, style: mergeStyles(styles.item, isActive ? styles.itemActive : undefined, isLast ? styles.itemLast : undefined), onClick: () => onRecentClick?.(q), onMouseEnter: () => setActiveIndex(itemIdx) },
261
+ showIndices && (React.createElement("span", { style: styles.itemIndex }, itemIdx + 1)),
262
+ React.createElement("div", { style: styles.itemContent },
263
+ React.createElement("div", { style: styles.itemQuery }, q)),
264
+ showTypeLabels && (React.createElement("span", { style: styles.itemType }, "Recent"))));
265
+ }))),
266
+ processedSuggestions.length > 0 && (React.createElement(React.Fragment, null,
267
+ showSectionDividers && (showRecent || false) && (React.createElement("div", { style: styles.divider }, "Suggestions")),
268
+ processedSuggestions.map((s, idx) => {
269
+ const itemIdx = globalIndex++;
270
+ const isActive = activeIndex === itemIdx;
271
+ const isLast = idx === processedSuggestions.length - 1 && !processedProducts.length;
272
+ return (React.createElement("div", { key: s.id || `suggestion-${idx}`, "data-index": itemIdx, style: mergeStyles(styles.item, isActive ? styles.itemActive : undefined, isLast ? styles.itemLast : undefined), onClick: () => onSuggestionSelect?.(s._raw, idx), onMouseEnter: () => setActiveIndex(itemIdx) },
273
+ showIndices && (React.createElement("span", { style: styles.itemIndex }, itemIdx + 1)),
274
+ React.createElement("div", { style: styles.itemContent },
275
+ React.createElement("div", { style: styles.itemQuery, dangerouslySetInnerHTML: {
276
+ __html: highlightText(s.query, query, { tag: 'mark' })
277
+ } }),
278
+ s.count && (React.createElement("div", { style: styles.itemMeta },
279
+ s.count.toLocaleString(),
280
+ " results"))),
281
+ showTypeLabels && (React.createElement("span", { style: styles.itemType }, "Search"))));
282
+ }))),
283
+ processedProducts.length > 0 && (React.createElement(React.Fragment, null,
284
+ showSectionDividers && (React.createElement("div", { style: styles.divider }, "Products")),
285
+ processedProducts.slice(0, 4).map((p, idx) => {
286
+ const itemIdx = globalIndex++;
287
+ const isActive = activeIndex === itemIdx;
288
+ return (React.createElement("div", { key: p.id, "data-index": itemIdx, style: mergeStyles(styles.productRow, isActive ? styles.productRowActive : undefined), onClick: () => onProductClick?.(p._raw, idx), onMouseEnter: () => setActiveIndex(itemIdx) },
289
+ p.image && (React.createElement("img", { src: p.image, alt: p.title, style: styles.productImage, loading: "lazy" })),
290
+ React.createElement("div", { style: styles.productContent },
291
+ React.createElement("div", { style: styles.productTitle }, p.title),
292
+ p.price !== undefined && (React.createElement("div", { style: styles.productPrice }, formatPrice(p.price, {
293
+ currency: productDisplay.currency || p.currency || '$'
294
+ })))),
295
+ showTypeLabels && (React.createElement("span", { style: styles.itemType }, "Product"))));
296
+ })))))),
297
+ footer !== undefined ? footer : (React.createElement("div", { style: styles.footer },
298
+ React.createElement("div", { style: styles.footerHint },
299
+ React.createElement("span", null,
300
+ React.createElement("span", { style: styles.kbd }, "\u2191"),
301
+ " ",
302
+ React.createElement("span", { style: styles.kbd }, "\u2193"),
303
+ " navigate"),
304
+ React.createElement("span", null,
305
+ React.createElement("span", { style: styles.kbd }, "\u21B5"),
306
+ " select"),
307
+ React.createElement("span", null,
308
+ React.createElement("span", { style: styles.kbd }, "esc"),
309
+ " close")),
310
+ React.createElement("span", null,
311
+ allItems.length,
312
+ " results")))));
313
+ });
314
+ export default MinimalDropdown;
@@ -0,0 +1,31 @@
1
+ /**
2
+ * MobileSheetDropdown - Mobile-First Bottom Sheet Style
3
+ *
4
+ * Features:
5
+ * - iOS-style bottom sheet with drag handle
6
+ * - Full-screen overlay with smooth transitions
7
+ * - Touch-friendly large tap targets
8
+ * - Swipe to dismiss
9
+ * - Optimized for small screens
10
+ */
11
+ import React from 'react';
12
+ import type { BaseDropdownProps, DropdownRef } from './types';
13
+ export interface MobileSheetDropdownProps extends BaseDropdownProps {
14
+ /** Show search input in header */
15
+ showSearchInput?: boolean;
16
+ /** Show cancel button */
17
+ showCancel?: boolean;
18
+ /** Cancel button text */
19
+ cancelText?: string;
20
+ /** Show drag handle */
21
+ showDragHandle?: boolean;
22
+ /** Enable swipe to dismiss */
23
+ swipeToDismiss?: boolean;
24
+ /** Footer button text */
25
+ footerButtonText?: string;
26
+ /** Show footer button */
27
+ showFooterButton?: boolean;
28
+ }
29
+ export declare const MobileSheetDropdown: React.ForwardRefExoticComponent<MobileSheetDropdownProps & React.RefAttributes<DropdownRef>>;
30
+ export default MobileSheetDropdown;
31
+ //# sourceMappingURL=MobileSheetDropdown.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MobileSheetDropdown.d.ts","sourceRoot":"","sources":["../../../src/components/suggestions/MobileSheetDropdown.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAQN,MAAM,OAAO,CAAC;AACf,OAAO,KAAK,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAuS9D,MAAM,WAAW,wBAAyB,SAAQ,iBAAiB;IACjE,kCAAkC;IAClC,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,yBAAyB;IACzB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,yBAAyB;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,uBAAuB;IACvB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,8BAA8B;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,yBAAyB;IACzB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,yBAAyB;IACzB,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED,eAAO,MAAM,mBAAmB,8FA+b/B,CAAC;AAEF,eAAe,mBAAmB,CAAC"}