@selwise/widget 0.0.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 (552) hide show
  1. package/dist/npm/cjs/constants.js +167 -0
  2. package/dist/npm/cjs/constants.js.map +1 -0
  3. package/dist/npm/cjs/core/conflict-resolver.js +203 -0
  4. package/dist/npm/cjs/core/conflict-resolver.js.map +1 -0
  5. package/dist/npm/cjs/core/event-batcher.js +977 -0
  6. package/dist/npm/cjs/core/event-batcher.js.map +1 -0
  7. package/dist/npm/cjs/core/experiment-overrides.js +178 -0
  8. package/dist/npm/cjs/core/experiment-overrides.js.map +1 -0
  9. package/dist/npm/cjs/core/experiments.js +317 -0
  10. package/dist/npm/cjs/core/experiments.js.map +1 -0
  11. package/dist/npm/cjs/core/frequency-caps.js +297 -0
  12. package/dist/npm/cjs/core/frequency-caps.js.map +1 -0
  13. package/dist/npm/cjs/core/index.js +27 -0
  14. package/dist/npm/cjs/core/index.js.map +1 -0
  15. package/dist/npm/cjs/core/indexeddb-queue.js +333 -0
  16. package/dist/npm/cjs/core/indexeddb-queue.js.map +1 -0
  17. package/dist/npm/cjs/core/journey-tracker.js +243 -0
  18. package/dist/npm/cjs/core/journey-tracker.js.map +1 -0
  19. package/dist/npm/cjs/core/page-targeting/index.js +72 -0
  20. package/dist/npm/cjs/core/page-targeting/index.js.map +1 -0
  21. package/dist/npm/cjs/core/script-executor.js +80 -0
  22. package/dist/npm/cjs/core/script-executor.js.map +1 -0
  23. package/dist/npm/cjs/core/segments.js +172 -0
  24. package/dist/npm/cjs/core/segments.js.map +1 -0
  25. package/dist/npm/cjs/core/tracker.js +798 -0
  26. package/dist/npm/cjs/core/tracker.js.map +1 -0
  27. package/dist/npm/cjs/datalayer/basket.js +385 -0
  28. package/dist/npm/cjs/datalayer/basket.js.map +1 -0
  29. package/dist/npm/cjs/datalayer/cart-association.js +226 -0
  30. package/dist/npm/cjs/datalayer/cart-association.js.map +1 -0
  31. package/dist/npm/cjs/datalayer/checkout.js +382 -0
  32. package/dist/npm/cjs/datalayer/checkout.js.map +1 -0
  33. package/dist/npm/cjs/datalayer/constants.js +163 -0
  34. package/dist/npm/cjs/datalayer/constants.js.map +1 -0
  35. package/dist/npm/cjs/datalayer/index.js +1010 -0
  36. package/dist/npm/cjs/datalayer/index.js.map +1 -0
  37. package/dist/npm/cjs/datalayer/listener.js +416 -0
  38. package/dist/npm/cjs/datalayer/listener.js.map +1 -0
  39. package/dist/npm/cjs/datalayer/page.js +343 -0
  40. package/dist/npm/cjs/datalayer/page.js.map +1 -0
  41. package/dist/npm/cjs/datalayer/product.js +517 -0
  42. package/dist/npm/cjs/datalayer/product.js.map +1 -0
  43. package/dist/npm/cjs/datalayer/reverse-mappings.js +139 -0
  44. package/dist/npm/cjs/datalayer/reverse-mappings.js.map +1 -0
  45. package/dist/npm/cjs/datalayer/search.js +363 -0
  46. package/dist/npm/cjs/datalayer/search.js.map +1 -0
  47. package/dist/npm/cjs/datalayer/types.js +134 -0
  48. package/dist/npm/cjs/datalayer/types.js.map +1 -0
  49. package/dist/npm/cjs/datalayer/user.js +372 -0
  50. package/dist/npm/cjs/datalayer/user.js.map +1 -0
  51. package/dist/npm/cjs/debug/index.js +679 -0
  52. package/dist/npm/cjs/debug/index.js.map +1 -0
  53. package/dist/npm/cjs/entries/cdn.js +72 -0
  54. package/dist/npm/cjs/entries/cdn.js.map +1 -0
  55. package/dist/npm/cjs/index.js +10 -0
  56. package/dist/npm/cjs/index.js.map +1 -0
  57. package/dist/npm/cjs/modules/contract/recommendation-contract.js +119 -0
  58. package/dist/npm/cjs/modules/contract/recommendation-contract.js.map +1 -0
  59. package/dist/npm/cjs/modules/contract/search-contract.js +18 -0
  60. package/dist/npm/cjs/modules/contract/search-contract.js.map +1 -0
  61. package/dist/npm/cjs/modules/contract/tracking-contract.js +16 -0
  62. package/dist/npm/cjs/modules/contract/tracking-contract.js.map +1 -0
  63. package/dist/npm/cjs/modules/contract/widget-contract.js +10 -0
  64. package/dist/npm/cjs/modules/contract/widget-contract.js.map +1 -0
  65. package/dist/npm/cjs/modules/products/tracking.js +214 -0
  66. package/dist/npm/cjs/modules/products/tracking.js.map +1 -0
  67. package/dist/npm/cjs/modules/recommendation/cart-handlers.js +52 -0
  68. package/dist/npm/cjs/modules/recommendation/cart-handlers.js.map +1 -0
  69. package/dist/npm/cjs/modules/recommendation/components/product-card-renderer.js +287 -0
  70. package/dist/npm/cjs/modules/recommendation/components/product-card-renderer.js.map +1 -0
  71. package/dist/npm/cjs/modules/recommendation/index.js +678 -0
  72. package/dist/npm/cjs/modules/recommendation/index.js.map +1 -0
  73. package/dist/npm/cjs/modules/recommendation/renderers/grid.js +21 -0
  74. package/dist/npm/cjs/modules/recommendation/renderers/grid.js.map +1 -0
  75. package/dist/npm/cjs/modules/recommendation/renderers/list.js +22 -0
  76. package/dist/npm/cjs/modules/recommendation/renderers/list.js.map +1 -0
  77. package/dist/npm/cjs/modules/recommendation/renderers/masonry.js +22 -0
  78. package/dist/npm/cjs/modules/recommendation/renderers/masonry.js.map +1 -0
  79. package/dist/npm/cjs/modules/recommendation/renderers/slider-renderer.js +145 -0
  80. package/dist/npm/cjs/modules/recommendation/renderers/slider-renderer.js.map +1 -0
  81. package/dist/npm/cjs/modules/recommendation/slider-controls.js +201 -0
  82. package/dist/npm/cjs/modules/recommendation/slider-controls.js.map +1 -0
  83. package/dist/npm/cjs/modules/recommendation/tracking.js +247 -0
  84. package/dist/npm/cjs/modules/recommendation/tracking.js.map +1 -0
  85. package/dist/npm/cjs/modules/recommendation/utils/dom.js +70 -0
  86. package/dist/npm/cjs/modules/recommendation/utils/dom.js.map +1 -0
  87. package/dist/npm/cjs/modules/recommendation/utils/format.js +13 -0
  88. package/dist/npm/cjs/modules/recommendation/utils/format.js.map +1 -0
  89. package/dist/npm/cjs/modules/recommendation/utils/index.js +22 -0
  90. package/dist/npm/cjs/modules/recommendation/utils/index.js.map +1 -0
  91. package/dist/npm/cjs/modules/renderer/helpers.js +16 -0
  92. package/dist/npm/cjs/modules/renderer/helpers.js.map +1 -0
  93. package/dist/npm/cjs/modules/renderer/index.js +52 -0
  94. package/dist/npm/cjs/modules/renderer/index.js.map +1 -0
  95. package/dist/npm/cjs/modules/renderer/style-resolver.js +11 -0
  96. package/dist/npm/cjs/modules/renderer/style-resolver.js.map +1 -0
  97. package/dist/npm/cjs/modules/renderer/styles/index.js +254 -0
  98. package/dist/npm/cjs/modules/renderer/styles/index.js.map +1 -0
  99. package/dist/npm/cjs/modules/renderer/styles.js +7 -0
  100. package/dist/npm/cjs/modules/renderer/styles.js.map +1 -0
  101. package/dist/npm/cjs/modules/renderer/utils/helpers.js +243 -0
  102. package/dist/npm/cjs/modules/renderer/utils/helpers.js.map +1 -0
  103. package/dist/npm/cjs/modules/renderer/utils/image-renderer.js +65 -0
  104. package/dist/npm/cjs/modules/renderer/utils/image-renderer.js.map +1 -0
  105. package/dist/npm/cjs/modules/renderer/utils/placement.js +34 -0
  106. package/dist/npm/cjs/modules/renderer/utils/placement.js.map +1 -0
  107. package/dist/npm/cjs/modules/renderer/utils.js +61 -0
  108. package/dist/npm/cjs/modules/renderer/utils.js.map +1 -0
  109. package/dist/npm/cjs/modules/renderer/widgets/announcement-bar.js +84 -0
  110. package/dist/npm/cjs/modules/renderer/widgets/announcement-bar.js.map +1 -0
  111. package/dist/npm/cjs/modules/renderer/widgets/cart-count.js +211 -0
  112. package/dist/npm/cjs/modules/renderer/widgets/cart-count.js.map +1 -0
  113. package/dist/npm/cjs/modules/renderer/widgets/cookie-consent.js +459 -0
  114. package/dist/npm/cjs/modules/renderer/widgets/cookie-consent.js.map +1 -0
  115. package/dist/npm/cjs/modules/renderer/widgets/countdown-timer.js +132 -0
  116. package/dist/npm/cjs/modules/renderer/widgets/countdown-timer.js.map +1 -0
  117. package/dist/npm/cjs/modules/renderer/widgets/custom.js +58 -0
  118. package/dist/npm/cjs/modules/renderer/widgets/custom.js.map +1 -0
  119. package/dist/npm/cjs/modules/renderer/widgets/embedded-card.js +97 -0
  120. package/dist/npm/cjs/modules/renderer/widgets/embedded-card.js.map +1 -0
  121. package/dist/npm/cjs/modules/renderer/widgets/exit-intent-popup.js +151 -0
  122. package/dist/npm/cjs/modules/renderer/widgets/exit-intent-popup.js.map +1 -0
  123. package/dist/npm/cjs/modules/renderer/widgets/floating-button.js +70 -0
  124. package/dist/npm/cjs/modules/renderer/widgets/floating-button.js.map +1 -0
  125. package/dist/npm/cjs/modules/renderer/widgets/helpers.js +87 -0
  126. package/dist/npm/cjs/modules/renderer/widgets/helpers.js.map +1 -0
  127. package/dist/npm/cjs/modules/renderer/widgets/index.js +39 -0
  128. package/dist/npm/cjs/modules/renderer/widgets/index.js.map +1 -0
  129. package/dist/npm/cjs/modules/renderer/widgets/inline-banner.js +124 -0
  130. package/dist/npm/cjs/modules/renderer/widgets/inline-banner.js.map +1 -0
  131. package/dist/npm/cjs/modules/renderer/widgets/newsletter.js +280 -0
  132. package/dist/npm/cjs/modules/renderer/widgets/newsletter.js.map +1 -0
  133. package/dist/npm/cjs/modules/renderer/widgets/product-view-count.js +197 -0
  134. package/dist/npm/cjs/modules/renderer/widgets/product-view-count.js.map +1 -0
  135. package/dist/npm/cjs/modules/renderer/widgets/slide-in.js +105 -0
  136. package/dist/npm/cjs/modules/renderer/widgets/slide-in.js.map +1 -0
  137. package/dist/npm/cjs/modules/renderer/widgets/sticky-footer.js +47 -0
  138. package/dist/npm/cjs/modules/renderer/widgets/sticky-footer.js.map +1 -0
  139. package/dist/npm/cjs/modules/search/cart/index.js +42 -0
  140. package/dist/npm/cjs/modules/search/cart/index.js.map +1 -0
  141. package/dist/npm/cjs/modules/search/components/index.js +13 -0
  142. package/dist/npm/cjs/modules/search/components/index.js.map +1 -0
  143. package/dist/npm/cjs/modules/search/components/search-box.js +28 -0
  144. package/dist/npm/cjs/modules/search/components/search-box.js.map +1 -0
  145. package/dist/npm/cjs/modules/search/components/search-item.js +197 -0
  146. package/dist/npm/cjs/modules/search/components/search-item.js.map +1 -0
  147. package/dist/npm/cjs/modules/search/components/suggestions.js +132 -0
  148. package/dist/npm/cjs/modules/search/components/suggestions.js.map +1 -0
  149. package/dist/npm/cjs/modules/search/index.js +646 -0
  150. package/dist/npm/cjs/modules/search/index.js.map +1 -0
  151. package/dist/npm/cjs/modules/search/renderers/position-renderers.js +229 -0
  152. package/dist/npm/cjs/modules/search/renderers/position-renderers.js.map +1 -0
  153. package/dist/npm/cjs/modules/search/renderers/results-renderer.js +180 -0
  154. package/dist/npm/cjs/modules/search/renderers/results-renderer.js.map +1 -0
  155. package/dist/npm/cjs/modules/search/services/api-service.js +121 -0
  156. package/dist/npm/cjs/modules/search/services/api-service.js.map +1 -0
  157. package/dist/npm/cjs/modules/search/services/tracking-service.js +263 -0
  158. package/dist/npm/cjs/modules/search/services/tracking-service.js.map +1 -0
  159. package/dist/npm/cjs/modules/search/styles.js +864 -0
  160. package/dist/npm/cjs/modules/search/styles.js.map +1 -0
  161. package/dist/npm/cjs/modules/search/utils/helpers.js +100 -0
  162. package/dist/npm/cjs/modules/search/utils/helpers.js.map +1 -0
  163. package/dist/npm/cjs/modules/search/utils/icons.js +41 -0
  164. package/dist/npm/cjs/modules/search/utils/icons.js.map +1 -0
  165. package/dist/npm/cjs/modules/search/utils/index.js +22 -0
  166. package/dist/npm/cjs/modules/search/utils/index.js.map +1 -0
  167. package/dist/npm/cjs/modules/search/utils/storage.js +58 -0
  168. package/dist/npm/cjs/modules/search/utils/storage.js.map +1 -0
  169. package/dist/npm/cjs/selwise.js +1160 -0
  170. package/dist/npm/cjs/selwise.js.map +1 -0
  171. package/dist/npm/cjs/sentry-test.js +118 -0
  172. package/dist/npm/cjs/sentry-test.js.map +1 -0
  173. package/dist/npm/cjs/sentry.js +451 -0
  174. package/dist/npm/cjs/sentry.js.map +1 -0
  175. package/dist/npm/cjs/shared/cart/handlers.js +259 -0
  176. package/dist/npm/cjs/shared/cart/handlers.js.map +1 -0
  177. package/dist/npm/cjs/shared/cart/index.js +23 -0
  178. package/dist/npm/cjs/shared/cart/index.js.map +1 -0
  179. package/dist/npm/cjs/shared/cart/types.js +7 -0
  180. package/dist/npm/cjs/shared/cart/types.js.map +1 -0
  181. package/dist/npm/cjs/shared/product-card/index.js +24 -0
  182. package/dist/npm/cjs/shared/product-card/index.js.map +1 -0
  183. package/dist/npm/cjs/shared/product-card/renderer.js +341 -0
  184. package/dist/npm/cjs/shared/product-card/renderer.js.map +1 -0
  185. package/dist/npm/cjs/shared/product-card/styles.js +195 -0
  186. package/dist/npm/cjs/shared/product-card/styles.js.map +1 -0
  187. package/dist/npm/cjs/shared/product-card/types.js +67 -0
  188. package/dist/npm/cjs/shared/product-card/types.js.map +1 -0
  189. package/dist/npm/cjs/types/config.js +6 -0
  190. package/dist/npm/cjs/types/config.js.map +1 -0
  191. package/dist/npm/cjs/types/experiments.js +17 -0
  192. package/dist/npm/cjs/types/experiments.js.map +1 -0
  193. package/dist/npm/cjs/types/global-api.js +3 -0
  194. package/dist/npm/cjs/types/global-api.js.map +1 -0
  195. package/dist/npm/cjs/types/index.js +27 -0
  196. package/dist/npm/cjs/types/index.js.map +1 -0
  197. package/dist/npm/cjs/types/recommendation.js +6 -0
  198. package/dist/npm/cjs/types/recommendation.js.map +1 -0
  199. package/dist/npm/cjs/types/renderer.js +6 -0
  200. package/dist/npm/cjs/types/renderer.js.map +1 -0
  201. package/dist/npm/cjs/types/search.js +6 -0
  202. package/dist/npm/cjs/types/search.js.map +1 -0
  203. package/dist/npm/cjs/utils/api-url.js +35 -0
  204. package/dist/npm/cjs/utils/api-url.js.map +1 -0
  205. package/dist/npm/cjs/utils/debounce.js +74 -0
  206. package/dist/npm/cjs/utils/debounce.js.map +1 -0
  207. package/dist/npm/cjs/utils/event-id.js +23 -0
  208. package/dist/npm/cjs/utils/event-id.js.map +1 -0
  209. package/dist/npm/cjs/utils/index.js +28 -0
  210. package/dist/npm/cjs/utils/index.js.map +1 -0
  211. package/dist/npm/cjs/utils/logger.js +74 -0
  212. package/dist/npm/cjs/utils/logger.js.map +1 -0
  213. package/dist/npm/cjs/utils/sanitize.js +159 -0
  214. package/dist/npm/cjs/utils/sanitize.js.map +1 -0
  215. package/dist/npm/cjs/utils/storage.js +285 -0
  216. package/dist/npm/cjs/utils/storage.js.map +1 -0
  217. package/dist/npm/cjs/utils/tracking-metadata.js +18 -0
  218. package/dist/npm/cjs/utils/tracking-metadata.js.map +1 -0
  219. package/dist/npm/cjs/utils/url-matcher.js +11 -0
  220. package/dist/npm/cjs/utils/url-matcher.js.map +1 -0
  221. package/dist/npm/esm/constants.d.ts +130 -0
  222. package/dist/npm/esm/constants.js +164 -0
  223. package/dist/npm/esm/constants.js.map +1 -0
  224. package/dist/npm/esm/core/conflict-resolver.d.ts +96 -0
  225. package/dist/npm/esm/core/conflict-resolver.js +198 -0
  226. package/dist/npm/esm/core/conflict-resolver.js.map +1 -0
  227. package/dist/npm/esm/core/event-batcher.d.ts +253 -0
  228. package/dist/npm/esm/core/event-batcher.js +973 -0
  229. package/dist/npm/esm/core/event-batcher.js.map +1 -0
  230. package/dist/npm/esm/core/experiment-overrides.d.ts +7 -0
  231. package/dist/npm/esm/core/experiment-overrides.js +172 -0
  232. package/dist/npm/esm/core/experiment-overrides.js.map +1 -0
  233. package/dist/npm/esm/core/experiments.d.ts +90 -0
  234. package/dist/npm/esm/core/experiments.js +313 -0
  235. package/dist/npm/esm/core/experiments.js.map +1 -0
  236. package/dist/npm/esm/core/frequency-caps.d.ts +124 -0
  237. package/dist/npm/esm/core/frequency-caps.js +292 -0
  238. package/dist/npm/esm/core/frequency-caps.js.map +1 -0
  239. package/dist/npm/esm/core/index.d.ts +10 -0
  240. package/dist/npm/esm/core/index.js +11 -0
  241. package/dist/npm/esm/core/index.js.map +1 -0
  242. package/dist/npm/esm/core/indexeddb-queue.d.ts +83 -0
  243. package/dist/npm/esm/core/indexeddb-queue.js +328 -0
  244. package/dist/npm/esm/core/indexeddb-queue.js.map +1 -0
  245. package/dist/npm/esm/core/journey-tracker.d.ts +102 -0
  246. package/dist/npm/esm/core/journey-tracker.js +237 -0
  247. package/dist/npm/esm/core/journey-tracker.js.map +1 -0
  248. package/dist/npm/esm/core/page-targeting/index.d.ts +8 -0
  249. package/dist/npm/esm/core/page-targeting/index.js +67 -0
  250. package/dist/npm/esm/core/page-targeting/index.js.map +1 -0
  251. package/dist/npm/esm/core/script-executor.d.ts +31 -0
  252. package/dist/npm/esm/core/script-executor.js +76 -0
  253. package/dist/npm/esm/core/script-executor.js.map +1 -0
  254. package/dist/npm/esm/core/segments.d.ts +39 -0
  255. package/dist/npm/esm/core/segments.js +168 -0
  256. package/dist/npm/esm/core/segments.js.map +1 -0
  257. package/dist/npm/esm/core/tracker.d.ts +182 -0
  258. package/dist/npm/esm/core/tracker.js +794 -0
  259. package/dist/npm/esm/core/tracker.js.map +1 -0
  260. package/dist/npm/esm/datalayer/basket.d.ts +104 -0
  261. package/dist/npm/esm/datalayer/basket.js +381 -0
  262. package/dist/npm/esm/datalayer/basket.js.map +1 -0
  263. package/dist/npm/esm/datalayer/cart-association.d.ts +65 -0
  264. package/dist/npm/esm/datalayer/cart-association.js +222 -0
  265. package/dist/npm/esm/datalayer/cart-association.js.map +1 -0
  266. package/dist/npm/esm/datalayer/checkout.d.ts +96 -0
  267. package/dist/npm/esm/datalayer/checkout.js +378 -0
  268. package/dist/npm/esm/datalayer/checkout.js.map +1 -0
  269. package/dist/npm/esm/datalayer/constants.d.ts +77 -0
  270. package/dist/npm/esm/datalayer/constants.js +160 -0
  271. package/dist/npm/esm/datalayer/constants.js.map +1 -0
  272. package/dist/npm/esm/datalayer/index.d.ts +212 -0
  273. package/dist/npm/esm/datalayer/index.js +991 -0
  274. package/dist/npm/esm/datalayer/index.js.map +1 -0
  275. package/dist/npm/esm/datalayer/listener.d.ts +108 -0
  276. package/dist/npm/esm/datalayer/listener.js +411 -0
  277. package/dist/npm/esm/datalayer/listener.js.map +1 -0
  278. package/dist/npm/esm/datalayer/page.d.ts +94 -0
  279. package/dist/npm/esm/datalayer/page.js +339 -0
  280. package/dist/npm/esm/datalayer/page.js.map +1 -0
  281. package/dist/npm/esm/datalayer/product.d.ts +133 -0
  282. package/dist/npm/esm/datalayer/product.js +513 -0
  283. package/dist/npm/esm/datalayer/product.js.map +1 -0
  284. package/dist/npm/esm/datalayer/reverse-mappings.d.ts +62 -0
  285. package/dist/npm/esm/datalayer/reverse-mappings.js +135 -0
  286. package/dist/npm/esm/datalayer/reverse-mappings.js.map +1 -0
  287. package/dist/npm/esm/datalayer/search.d.ts +108 -0
  288. package/dist/npm/esm/datalayer/search.js +359 -0
  289. package/dist/npm/esm/datalayer/search.js.map +1 -0
  290. package/dist/npm/esm/datalayer/types.d.ts +292 -0
  291. package/dist/npm/esm/datalayer/types.js +131 -0
  292. package/dist/npm/esm/datalayer/types.js.map +1 -0
  293. package/dist/npm/esm/datalayer/user.d.ts +104 -0
  294. package/dist/npm/esm/datalayer/user.js +368 -0
  295. package/dist/npm/esm/datalayer/user.js.map +1 -0
  296. package/dist/npm/esm/debug/index.d.ts +173 -0
  297. package/dist/npm/esm/debug/index.js +673 -0
  298. package/dist/npm/esm/debug/index.js.map +1 -0
  299. package/dist/npm/esm/entries/cdn.d.ts +1 -0
  300. package/dist/npm/esm/entries/cdn.js +35 -0
  301. package/dist/npm/esm/entries/cdn.js.map +1 -0
  302. package/dist/npm/esm/index.d.ts +4 -0
  303. package/dist/npm/esm/index.js +4 -0
  304. package/dist/npm/esm/index.js.map +1 -0
  305. package/dist/npm/esm/modules/contract/recommendation-contract.d.ts +5 -0
  306. package/dist/npm/esm/modules/contract/recommendation-contract.js +107 -0
  307. package/dist/npm/esm/modules/contract/recommendation-contract.js.map +1 -0
  308. package/dist/npm/esm/modules/contract/search-contract.d.ts +1 -0
  309. package/dist/npm/esm/modules/contract/search-contract.js +2 -0
  310. package/dist/npm/esm/modules/contract/search-contract.js.map +1 -0
  311. package/dist/npm/esm/modules/contract/tracking-contract.d.ts +1 -0
  312. package/dist/npm/esm/modules/contract/tracking-contract.js +2 -0
  313. package/dist/npm/esm/modules/contract/tracking-contract.js.map +1 -0
  314. package/dist/npm/esm/modules/contract/widget-contract.d.ts +1 -0
  315. package/dist/npm/esm/modules/contract/widget-contract.js +2 -0
  316. package/dist/npm/esm/modules/contract/widget-contract.js.map +1 -0
  317. package/dist/npm/esm/modules/products/tracking.d.ts +122 -0
  318. package/dist/npm/esm/modules/products/tracking.js +203 -0
  319. package/dist/npm/esm/modules/products/tracking.js.map +1 -0
  320. package/dist/npm/esm/modules/recommendation/cart-handlers.d.ts +10 -0
  321. package/dist/npm/esm/modules/recommendation/cart-handlers.js +49 -0
  322. package/dist/npm/esm/modules/recommendation/cart-handlers.js.map +1 -0
  323. package/dist/npm/esm/modules/recommendation/components/product-card-renderer.d.ts +37 -0
  324. package/dist/npm/esm/modules/recommendation/components/product-card-renderer.js +281 -0
  325. package/dist/npm/esm/modules/recommendation/components/product-card-renderer.js.map +1 -0
  326. package/dist/npm/esm/modules/recommendation/index.d.ts +11 -0
  327. package/dist/npm/esm/modules/recommendation/index.js +674 -0
  328. package/dist/npm/esm/modules/recommendation/index.js.map +1 -0
  329. package/dist/npm/esm/modules/recommendation/renderers/grid.d.ts +5 -0
  330. package/dist/npm/esm/modules/recommendation/renderers/grid.js +18 -0
  331. package/dist/npm/esm/modules/recommendation/renderers/grid.js.map +1 -0
  332. package/dist/npm/esm/modules/recommendation/renderers/list.d.ts +5 -0
  333. package/dist/npm/esm/modules/recommendation/renderers/list.js +19 -0
  334. package/dist/npm/esm/modules/recommendation/renderers/list.js.map +1 -0
  335. package/dist/npm/esm/modules/recommendation/renderers/masonry.d.ts +5 -0
  336. package/dist/npm/esm/modules/recommendation/renderers/masonry.js +19 -0
  337. package/dist/npm/esm/modules/recommendation/renderers/masonry.js.map +1 -0
  338. package/dist/npm/esm/modules/recommendation/renderers/slider-renderer.d.ts +10 -0
  339. package/dist/npm/esm/modules/recommendation/renderers/slider-renderer.js +140 -0
  340. package/dist/npm/esm/modules/recommendation/renderers/slider-renderer.js.map +1 -0
  341. package/dist/npm/esm/modules/recommendation/slider-controls.d.ts +17 -0
  342. package/dist/npm/esm/modules/recommendation/slider-controls.js +187 -0
  343. package/dist/npm/esm/modules/recommendation/slider-controls.js.map +1 -0
  344. package/dist/npm/esm/modules/recommendation/tracking.d.ts +28 -0
  345. package/dist/npm/esm/modules/recommendation/tracking.js +237 -0
  346. package/dist/npm/esm/modules/recommendation/tracking.js.map +1 -0
  347. package/dist/npm/esm/modules/recommendation/utils/dom.d.ts +10 -0
  348. package/dist/npm/esm/modules/recommendation/utils/dom.js +63 -0
  349. package/dist/npm/esm/modules/recommendation/utils/dom.js.map +1 -0
  350. package/dist/npm/esm/modules/recommendation/utils/format.d.ts +4 -0
  351. package/dist/npm/esm/modules/recommendation/utils/format.js +10 -0
  352. package/dist/npm/esm/modules/recommendation/utils/format.js.map +1 -0
  353. package/dist/npm/esm/modules/recommendation/utils/index.d.ts +5 -0
  354. package/dist/npm/esm/modules/recommendation/utils/index.js +6 -0
  355. package/dist/npm/esm/modules/recommendation/utils/index.js.map +1 -0
  356. package/dist/npm/esm/modules/renderer/helpers.d.ts +5 -0
  357. package/dist/npm/esm/modules/renderer/helpers.js +6 -0
  358. package/dist/npm/esm/modules/renderer/helpers.js.map +1 -0
  359. package/dist/npm/esm/modules/renderer/index.d.ts +8 -0
  360. package/dist/npm/esm/modules/renderer/index.js +48 -0
  361. package/dist/npm/esm/modules/renderer/index.js.map +1 -0
  362. package/dist/npm/esm/modules/renderer/style-resolver.d.ts +1 -0
  363. package/dist/npm/esm/modules/renderer/style-resolver.js +8 -0
  364. package/dist/npm/esm/modules/renderer/style-resolver.js.map +1 -0
  365. package/dist/npm/esm/modules/renderer/styles/index.d.ts +12 -0
  366. package/dist/npm/esm/modules/renderer/styles/index.js +250 -0
  367. package/dist/npm/esm/modules/renderer/styles/index.js.map +1 -0
  368. package/dist/npm/esm/modules/renderer/styles.d.ts +1 -0
  369. package/dist/npm/esm/modules/renderer/styles.js +2 -0
  370. package/dist/npm/esm/modules/renderer/styles.js.map +1 -0
  371. package/dist/npm/esm/modules/renderer/utils/helpers.d.ts +58 -0
  372. package/dist/npm/esm/modules/renderer/utils/helpers.js +225 -0
  373. package/dist/npm/esm/modules/renderer/utils/helpers.js.map +1 -0
  374. package/dist/npm/esm/modules/renderer/utils/image-renderer.d.ts +17 -0
  375. package/dist/npm/esm/modules/renderer/utils/image-renderer.js +60 -0
  376. package/dist/npm/esm/modules/renderer/utils/image-renderer.js.map +1 -0
  377. package/dist/npm/esm/modules/renderer/utils/placement.d.ts +6 -0
  378. package/dist/npm/esm/modules/renderer/utils/placement.js +31 -0
  379. package/dist/npm/esm/modules/renderer/utils/placement.js.map +1 -0
  380. package/dist/npm/esm/modules/renderer/utils.d.ts +11 -0
  381. package/dist/npm/esm/modules/renderer/utils.js +44 -0
  382. package/dist/npm/esm/modules/renderer/utils.js.map +1 -0
  383. package/dist/npm/esm/modules/renderer/widgets/announcement-bar.d.ts +5 -0
  384. package/dist/npm/esm/modules/renderer/widgets/announcement-bar.js +81 -0
  385. package/dist/npm/esm/modules/renderer/widgets/announcement-bar.js.map +1 -0
  386. package/dist/npm/esm/modules/renderer/widgets/cart-count.d.ts +6 -0
  387. package/dist/npm/esm/modules/renderer/widgets/cart-count.js +208 -0
  388. package/dist/npm/esm/modules/renderer/widgets/cart-count.js.map +1 -0
  389. package/dist/npm/esm/modules/renderer/widgets/cookie-consent.d.ts +18 -0
  390. package/dist/npm/esm/modules/renderer/widgets/cookie-consent.js +454 -0
  391. package/dist/npm/esm/modules/renderer/widgets/cookie-consent.js.map +1 -0
  392. package/dist/npm/esm/modules/renderer/widgets/countdown-timer.d.ts +5 -0
  393. package/dist/npm/esm/modules/renderer/widgets/countdown-timer.js +129 -0
  394. package/dist/npm/esm/modules/renderer/widgets/countdown-timer.js.map +1 -0
  395. package/dist/npm/esm/modules/renderer/widgets/custom.d.ts +5 -0
  396. package/dist/npm/esm/modules/renderer/widgets/custom.js +55 -0
  397. package/dist/npm/esm/modules/renderer/widgets/custom.js.map +1 -0
  398. package/dist/npm/esm/modules/renderer/widgets/embedded-card.d.ts +5 -0
  399. package/dist/npm/esm/modules/renderer/widgets/embedded-card.js +94 -0
  400. package/dist/npm/esm/modules/renderer/widgets/embedded-card.js.map +1 -0
  401. package/dist/npm/esm/modules/renderer/widgets/exit-intent-popup.d.ts +6 -0
  402. package/dist/npm/esm/modules/renderer/widgets/exit-intent-popup.js +147 -0
  403. package/dist/npm/esm/modules/renderer/widgets/exit-intent-popup.js.map +1 -0
  404. package/dist/npm/esm/modules/renderer/widgets/floating-button.d.ts +5 -0
  405. package/dist/npm/esm/modules/renderer/widgets/floating-button.js +67 -0
  406. package/dist/npm/esm/modules/renderer/widgets/floating-button.js.map +1 -0
  407. package/dist/npm/esm/modules/renderer/widgets/helpers.d.ts +29 -0
  408. package/dist/npm/esm/modules/renderer/widgets/helpers.js +82 -0
  409. package/dist/npm/esm/modules/renderer/widgets/helpers.js.map +1 -0
  410. package/dist/npm/esm/modules/renderer/widgets/index.d.ts +17 -0
  411. package/dist/npm/esm/modules/renderer/widgets/index.js +19 -0
  412. package/dist/npm/esm/modules/renderer/widgets/index.js.map +1 -0
  413. package/dist/npm/esm/modules/renderer/widgets/inline-banner.d.ts +5 -0
  414. package/dist/npm/esm/modules/renderer/widgets/inline-banner.js +121 -0
  415. package/dist/npm/esm/modules/renderer/widgets/inline-banner.js.map +1 -0
  416. package/dist/npm/esm/modules/renderer/widgets/newsletter.d.ts +6 -0
  417. package/dist/npm/esm/modules/renderer/widgets/newsletter.js +277 -0
  418. package/dist/npm/esm/modules/renderer/widgets/newsletter.js.map +1 -0
  419. package/dist/npm/esm/modules/renderer/widgets/product-view-count.d.ts +6 -0
  420. package/dist/npm/esm/modules/renderer/widgets/product-view-count.js +194 -0
  421. package/dist/npm/esm/modules/renderer/widgets/product-view-count.js.map +1 -0
  422. package/dist/npm/esm/modules/renderer/widgets/slide-in.d.ts +5 -0
  423. package/dist/npm/esm/modules/renderer/widgets/slide-in.js +102 -0
  424. package/dist/npm/esm/modules/renderer/widgets/slide-in.js.map +1 -0
  425. package/dist/npm/esm/modules/renderer/widgets/sticky-footer.d.ts +5 -0
  426. package/dist/npm/esm/modules/renderer/widgets/sticky-footer.js +44 -0
  427. package/dist/npm/esm/modules/renderer/widgets/sticky-footer.js.map +1 -0
  428. package/dist/npm/esm/modules/search/cart/index.d.ts +26 -0
  429. package/dist/npm/esm/modules/search/cart/index.js +39 -0
  430. package/dist/npm/esm/modules/search/cart/index.js.map +1 -0
  431. package/dist/npm/esm/modules/search/components/index.d.ts +6 -0
  432. package/dist/npm/esm/modules/search/components/index.js +7 -0
  433. package/dist/npm/esm/modules/search/components/index.js.map +1 -0
  434. package/dist/npm/esm/modules/search/components/search-box.d.ts +11 -0
  435. package/dist/npm/esm/modules/search/components/search-box.js +25 -0
  436. package/dist/npm/esm/modules/search/components/search-box.js.map +1 -0
  437. package/dist/npm/esm/modules/search/components/search-item.d.ts +20 -0
  438. package/dist/npm/esm/modules/search/components/search-item.js +193 -0
  439. package/dist/npm/esm/modules/search/components/search-item.js.map +1 -0
  440. package/dist/npm/esm/modules/search/components/suggestions.d.ts +10 -0
  441. package/dist/npm/esm/modules/search/components/suggestions.js +129 -0
  442. package/dist/npm/esm/modules/search/components/suggestions.js.map +1 -0
  443. package/dist/npm/esm/modules/search/index.d.ts +67 -0
  444. package/dist/npm/esm/modules/search/index.js +642 -0
  445. package/dist/npm/esm/modules/search/index.js.map +1 -0
  446. package/dist/npm/esm/modules/search/renderers/position-renderers.d.ts +23 -0
  447. package/dist/npm/esm/modules/search/renderers/position-renderers.js +221 -0
  448. package/dist/npm/esm/modules/search/renderers/position-renderers.js.map +1 -0
  449. package/dist/npm/esm/modules/search/renderers/results-renderer.d.ts +20 -0
  450. package/dist/npm/esm/modules/search/renderers/results-renderer.js +176 -0
  451. package/dist/npm/esm/modules/search/renderers/results-renderer.js.map +1 -0
  452. package/dist/npm/esm/modules/search/services/api-service.d.ts +18 -0
  453. package/dist/npm/esm/modules/search/services/api-service.js +115 -0
  454. package/dist/npm/esm/modules/search/services/api-service.js.map +1 -0
  455. package/dist/npm/esm/modules/search/services/tracking-service.d.ts +16 -0
  456. package/dist/npm/esm/modules/search/services/tracking-service.js +250 -0
  457. package/dist/npm/esm/modules/search/services/tracking-service.js.map +1 -0
  458. package/dist/npm/esm/modules/search/styles.d.ts +13 -0
  459. package/dist/npm/esm/modules/search/styles.js +860 -0
  460. package/dist/npm/esm/modules/search/styles.js.map +1 -0
  461. package/dist/npm/esm/modules/search/utils/helpers.d.ts +24 -0
  462. package/dist/npm/esm/modules/search/utils/helpers.js +93 -0
  463. package/dist/npm/esm/modules/search/utils/helpers.js.map +1 -0
  464. package/dist/npm/esm/modules/search/utils/icons.d.ts +16 -0
  465. package/dist/npm/esm/modules/search/utils/icons.js +36 -0
  466. package/dist/npm/esm/modules/search/utils/icons.js.map +1 -0
  467. package/dist/npm/esm/modules/search/utils/index.d.ts +6 -0
  468. package/dist/npm/esm/modules/search/utils/index.js +7 -0
  469. package/dist/npm/esm/modules/search/utils/index.js.map +1 -0
  470. package/dist/npm/esm/modules/search/utils/storage.d.ts +7 -0
  471. package/dist/npm/esm/modules/search/utils/storage.js +52 -0
  472. package/dist/npm/esm/modules/search/utils/storage.js.map +1 -0
  473. package/dist/npm/esm/package.json +1 -0
  474. package/dist/npm/esm/selwise.d.ts +209 -0
  475. package/dist/npm/esm/selwise.js +1123 -0
  476. package/dist/npm/esm/selwise.js.map +1 -0
  477. package/dist/npm/esm/sentry-test.d.ts +45 -0
  478. package/dist/npm/esm/sentry-test.js +109 -0
  479. package/dist/npm/esm/sentry-test.js.map +1 -0
  480. package/dist/npm/esm/sentry.d.ts +86 -0
  481. package/dist/npm/esm/sentry.js +441 -0
  482. package/dist/npm/esm/sentry.js.map +1 -0
  483. package/dist/npm/esm/shared/cart/handlers.d.ts +46 -0
  484. package/dist/npm/esm/shared/cart/handlers.js +249 -0
  485. package/dist/npm/esm/shared/cart/handlers.js.map +1 -0
  486. package/dist/npm/esm/shared/cart/index.d.ts +6 -0
  487. package/dist/npm/esm/shared/cart/index.js +7 -0
  488. package/dist/npm/esm/shared/cart/index.js.map +1 -0
  489. package/dist/npm/esm/shared/cart/types.d.ts +30 -0
  490. package/dist/npm/esm/shared/cart/types.js +6 -0
  491. package/dist/npm/esm/shared/cart/types.js.map +1 -0
  492. package/dist/npm/esm/shared/product-card/index.d.ts +7 -0
  493. package/dist/npm/esm/shared/product-card/index.js +8 -0
  494. package/dist/npm/esm/shared/product-card/index.js.map +1 -0
  495. package/dist/npm/esm/shared/product-card/renderer.d.ts +35 -0
  496. package/dist/npm/esm/shared/product-card/renderer.js +334 -0
  497. package/dist/npm/esm/shared/product-card/renderer.js.map +1 -0
  498. package/dist/npm/esm/shared/product-card/styles.d.ts +17 -0
  499. package/dist/npm/esm/shared/product-card/styles.js +190 -0
  500. package/dist/npm/esm/shared/product-card/styles.js.map +1 -0
  501. package/dist/npm/esm/shared/product-card/types.d.ts +84 -0
  502. package/dist/npm/esm/shared/product-card/types.js +63 -0
  503. package/dist/npm/esm/shared/product-card/types.js.map +1 -0
  504. package/dist/npm/esm/types/config.d.ts +26 -0
  505. package/dist/npm/esm/types/config.js +5 -0
  506. package/dist/npm/esm/types/config.js.map +1 -0
  507. package/dist/npm/esm/types/experiments.d.ts +47 -0
  508. package/dist/npm/esm/types/experiments.js +14 -0
  509. package/dist/npm/esm/types/experiments.js.map +1 -0
  510. package/dist/npm/esm/types/global-api.d.ts +40 -0
  511. package/dist/npm/esm/types/global-api.js +2 -0
  512. package/dist/npm/esm/types/global-api.js.map +1 -0
  513. package/dist/npm/esm/types/index.d.ts +9 -0
  514. package/dist/npm/esm/types/index.js +11 -0
  515. package/dist/npm/esm/types/index.js.map +1 -0
  516. package/dist/npm/esm/types/recommendation.d.ts +186 -0
  517. package/dist/npm/esm/types/recommendation.js +5 -0
  518. package/dist/npm/esm/types/recommendation.js.map +1 -0
  519. package/dist/npm/esm/types/renderer.d.ts +99 -0
  520. package/dist/npm/esm/types/renderer.js +5 -0
  521. package/dist/npm/esm/types/renderer.js.map +1 -0
  522. package/dist/npm/esm/types/search.d.ts +186 -0
  523. package/dist/npm/esm/types/search.js +5 -0
  524. package/dist/npm/esm/types/search.js.map +1 -0
  525. package/dist/npm/esm/utils/api-url.d.ts +1 -0
  526. package/dist/npm/esm/utils/api-url.js +32 -0
  527. package/dist/npm/esm/utils/api-url.js.map +1 -0
  528. package/dist/npm/esm/utils/debounce.d.ts +27 -0
  529. package/dist/npm/esm/utils/debounce.js +70 -0
  530. package/dist/npm/esm/utils/debounce.js.map +1 -0
  531. package/dist/npm/esm/utils/event-id.d.ts +5 -0
  532. package/dist/npm/esm/utils/event-id.js +20 -0
  533. package/dist/npm/esm/utils/event-id.js.map +1 -0
  534. package/dist/npm/esm/utils/index.d.ts +11 -0
  535. package/dist/npm/esm/utils/index.js +12 -0
  536. package/dist/npm/esm/utils/index.js.map +1 -0
  537. package/dist/npm/esm/utils/logger.d.ts +31 -0
  538. package/dist/npm/esm/utils/logger.js +66 -0
  539. package/dist/npm/esm/utils/logger.js.map +1 -0
  540. package/dist/npm/esm/utils/sanitize.d.ts +38 -0
  541. package/dist/npm/esm/utils/sanitize.js +148 -0
  542. package/dist/npm/esm/utils/sanitize.js.map +1 -0
  543. package/dist/npm/esm/utils/storage.d.ts +72 -0
  544. package/dist/npm/esm/utils/storage.js +271 -0
  545. package/dist/npm/esm/utils/storage.js.map +1 -0
  546. package/dist/npm/esm/utils/tracking-metadata.d.ts +1 -0
  547. package/dist/npm/esm/utils/tracking-metadata.js +15 -0
  548. package/dist/npm/esm/utils/tracking-metadata.js.map +1 -0
  549. package/dist/npm/esm/utils/url-matcher.d.ts +4 -0
  550. package/dist/npm/esm/utils/url-matcher.js +8 -0
  551. package/dist/npm/esm/utils/url-matcher.js.map +1 -0
  552. package/package.json +62 -0
@@ -0,0 +1,860 @@
1
+ /**
2
+ * Search Module Styles
3
+ * CSS injection for search widget
4
+ */
5
+ import { getShadow } from './utils/helpers.js';
6
+ /**
7
+ * Generate all CSS styles for the search module
8
+ */
9
+ export function generateSearchStyles(config, suggestionStyles) {
10
+ const c = config;
11
+ const s = c.styles || {};
12
+ const ss = suggestionStyles;
13
+ const imageSizes = { small: '40px', medium: '56px', large: '72px' };
14
+ const imgSize = imageSizes[c.imageSize] || '56px';
15
+ return `
16
+ /* Base Wrapper */
17
+ .ws-search-wrapper {
18
+ position: relative;
19
+ font-family: ${s.fontFamily || '-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif'};
20
+ z-index: 999999;
21
+ box-sizing: border-box;
22
+ }
23
+ .ws-search-wrapper * { box-sizing: border-box; }
24
+ .ws-search-wrapper svg {
25
+ display: inline-block;
26
+ vertical-align: middle;
27
+ overflow: visible;
28
+ }
29
+
30
+ /* Input */
31
+ .ws-search-input-wrap { position: relative; }
32
+ .ws-search-input {
33
+ width: 100%;
34
+ padding: 12px 16px 12px ${s.inputIcon !== false ? '44px' : '16px'};
35
+ border-width: ${s.inputBorderWidth || '2px'};
36
+ border-style: solid;
37
+ border-color: ${s.inputBorder || '#e5e7eb'};
38
+ border-radius: ${s.inputRadius || '8px'};
39
+ font-size: ${s.inputSize === 'large' ? '16px' : (s.inputSize === 'xlarge' ? '18px' : '14px')};
40
+ color: ${s.textColor || '#1f2937'};
41
+ background: ${s.inputBg || '#f9fafb'};
42
+ outline: none;
43
+ transition: all 0.2s ease;
44
+ }
45
+ .ws-search-input.no-icon { padding-left: 16px; }
46
+
47
+ .ws-search-input:focus {
48
+ border-color: ${s.inputFocus || s.accentColor || '#6366f1'};
49
+ background: ${s.backgroundColor || '#ffffff'};
50
+ box-shadow: 0 0 0 3px ${s.inputFocus || s.accentColor || '#6366f1'}20;
51
+ }
52
+ .ws-search-input::placeholder { color: #9ca3af; }
53
+
54
+ .ws-search-icon {
55
+ position: absolute;
56
+ left: 14px;
57
+ top: 50%;
58
+ transform: translateY(-50%);
59
+ width: 20px;
60
+ height: 20px;
61
+ color: ${s.accentColor || '#9ca3af'};
62
+ pointer-events: none;
63
+ display: ${s.inputIcon !== false ? 'block' : 'none'};
64
+ }
65
+
66
+ .ws-search-clear {
67
+ position: absolute;
68
+ right: 12px;
69
+ top: 50%;
70
+ transform: translateY(-50%);
71
+ width: 24px;
72
+ height: 24px;
73
+ background: #f3f4f6;
74
+ border: none;
75
+ border-radius: 50%;
76
+ cursor: pointer;
77
+ display: none;
78
+ align-items: center;
79
+ justify-content: center;
80
+ color: #6b7280;
81
+ }
82
+ .ws-search-clear:hover { background: #e5e7eb; color: #374151; }
83
+ .ws-search-wrapper.has-value .ws-search-clear { display: flex; }
84
+
85
+ /* Results Container */
86
+ .ws-search-results {
87
+ position: absolute;
88
+ top: 100%;
89
+ left: 0;
90
+ right: 0;
91
+ margin-top: 8px;
92
+ background: ${s.backgroundColor || '#ffffff'};
93
+ border-radius: ${s.containerRadius || '12px'};
94
+ box-shadow: ${getShadow(s.containerShadow || 'lg')};
95
+ max-height: ${s.maxHeight || '400px'};
96
+ overflow-y: auto;
97
+ display: none;
98
+ z-index: 1000000;
99
+ border: ${s.containerBorder ? '1px solid ' + (s.borderColor || '#e5e7eb') : 'none'};
100
+ }
101
+ .ws-search-results.open {
102
+ display: block;
103
+ animation: wsSearchFadeIn ${c.animationDuration}ms ease;
104
+ }
105
+
106
+ @keyframes wsSearchFadeIn {
107
+ from { opacity: 0; transform: translateY(-8px); }
108
+ to { opacity: 1; transform: translateY(0); }
109
+ }
110
+ @keyframes wsSearchSlideIn {
111
+ from { opacity: 0; transform: translateX(100%); }
112
+ to { opacity: 1; transform: translateX(0); }
113
+ }
114
+ @keyframes wsSearchScaleIn {
115
+ from { opacity: 0; transform: scale(0.95); }
116
+ to { opacity: 1; transform: scale(1); }
117
+ }
118
+
119
+ /* Result Items - Base Shared */
120
+ .ws-search-item {
121
+ display: flex;
122
+ align-items: center;
123
+ cursor: pointer;
124
+ transition: background 0.15s ease;
125
+ text-decoration: none;
126
+ color: inherit;
127
+ }
128
+ .ws-search-item:hover,
129
+ .ws-search-item.focused {
130
+ background: ${s.itemHoverBg || s.resultHoverBg || '#f9fafb'};
131
+ }
132
+ .ws-search-item:not(:last-child) {
133
+ border-bottom: ${s.resultDivider !== false ? '1px solid ' + (s.borderColor || '#f3f4f6') : 'none'};
134
+ }
135
+
136
+ /* Layout: List (Standard) */
137
+ .ws-search-results.layout-list .ws-search-item {
138
+ gap: ${s.itemGap || '12px'};
139
+ padding: ${s.itemPadding || '12px'} 16px;
140
+ }
141
+
142
+ /* Layout: Compact (Dense) */
143
+ .ws-search-results.layout-compact .ws-search-item {
144
+ gap: 8px;
145
+ padding: 8px 12px;
146
+ }
147
+ .ws-search-results.layout-compact .ws-search-img {
148
+ width: 32px;
149
+ height: 32px;
150
+ border-radius: ${s.imageRadius || '4px'};
151
+ }
152
+ .ws-search-results.layout-compact .ws-search-desc { display: none; }
153
+ .ws-search-results.layout-compact .ws-search-price { font-size: 13px; }
154
+ .ws-search-results.layout-compact .ws-search-name { font-size: 13px; margin: 0; }
155
+
156
+ /* Layout: Large (Prominent) */
157
+ .ws-search-results.layout-large .ws-search-item {
158
+ gap: 16px;
159
+ padding: 20px;
160
+ }
161
+ .ws-search-results.layout-large .ws-search-img {
162
+ width: 80px;
163
+ height: 80px;
164
+ }
165
+ .ws-search-results.layout-large .ws-search-name {
166
+ font-size: 16px;
167
+ margin-bottom: 6px;
168
+ }
169
+ .ws-search-results.layout-large .ws-search-desc {
170
+ -webkit-line-clamp: 3;
171
+ line-clamp: 3;
172
+ }
173
+
174
+ /* Grid Layout */
175
+ .ws-search-results.layout-grid .ws-search-items {
176
+ display: grid;
177
+ grid-template-columns: repeat(${s.gridColumns || 2}, 1fr);
178
+ gap: ${s.gridGap || '16px'};
179
+ padding: 12px;
180
+ }
181
+ .ws-search-results.layout-grid .ws-search-item {
182
+ flex-direction: column;
183
+ padding: ${s.itemPadding || '16px'};
184
+ border-radius: ${s.itemRadius || '12px'};
185
+ border: 1px solid ${s.borderColor || '#e5e7eb'};
186
+ box-shadow: ${getShadow(s.itemShadow || 'sm')};
187
+ }
188
+ .ws-search-results.layout-grid .ws-search-item:hover {
189
+ box-shadow: ${getShadow(s.itemHoverShadow || 'lg')};
190
+ ${s.itemHoverScale ? 'transform: scale(1.02);' : ''}
191
+ }
192
+
193
+ /* Image */
194
+ .ws-search-img {
195
+ width: ${imgSize};
196
+ height: ${imgSize};
197
+ height: ${imgSize};
198
+ object-fit: ${s.imageObjectFit || 'cover'};
199
+ border-radius: ${c.resultLayout === 'grid' ? '0' : (s.imageRadius || '8px')};
200
+ border: ${s.imageBorder ? '1px solid ' + (s.borderColor || '#e5e7eb') : 'none'};
201
+ aspect-ratio: ${s.cardAspect && s.cardAspect !== 'auto' ? s.cardAspect : 'auto'};
202
+ background: #f3f4f6;
203
+ flex-shrink: 0;
204
+ }
205
+ .ws-search-results.layout-grid .ws-search-img {
206
+ width: 100%;
207
+ height: ${s.imageHeight || '100px'};
208
+ }
209
+
210
+ /* Image Overlay & Text Overlay */
211
+ .ws-search-img-wrap {
212
+ position: relative;
213
+ overflow: hidden;
214
+ border-radius: ${c.resultLayout === 'grid' ? '0' : (s.imageRadius || '8px')};
215
+ flex-shrink: 0;
216
+ }
217
+ .ws-search-img-overlay {
218
+ position: absolute;
219
+ top: 0; left: 0; right: 0; bottom: 0;
220
+ background: rgba(0,0,0,0.4);
221
+ pointer-events: none;
222
+ }
223
+ .ws-search-text-overlay {
224
+ position: absolute;
225
+ left: 0; right: 0;
226
+ padding: 8px;
227
+ background: linear-gradient(to top, rgba(0,0,0,0.8), transparent);
228
+ color: #fff;
229
+ display: flex;
230
+ flex-direction: column;
231
+ justify-content: flex-end;
232
+ }
233
+ .ws-search-text-overlay.pos-bottom { bottom: 0; height: 50%; }
234
+ .ws-search-text-overlay.pos-full { top: 0; bottom: 0; justify-content: flex-end; }
235
+ .ws-search-text-overlay.pos-center { top: 0; bottom: 0; justify-content: center; align-items: center; text-align: center; }
236
+
237
+ /* Content */
238
+ .ws-search-content { flex: 1; min-width: 0; }
239
+ .ws-search-name {
240
+ font-weight: ${s.titleWeight || 'medium'};
241
+ font-size: ${s.titleSize || '14px'};
242
+ color: ${s.textColor || '#1f2937'};
243
+ margin: 0 0 4px 0;
244
+ white-space: nowrap;
245
+ overflow: hidden;
246
+ text-overflow: ellipsis;
247
+ }
248
+ .ws-search-name mark {
249
+ background: ${s.highlightBg || '#fef08a'};
250
+ color: ${s.highlightText || 'inherit'};
251
+ padding: 0 2px;
252
+ border-radius: ${s.highlightRadius || '2px'};
253
+ }
254
+ .ws-search-desc {
255
+ font-size: ${s.descSize || '12px'};
256
+ color: #6b7280;
257
+ margin: 0;
258
+ white-space: nowrap;
259
+ overflow: hidden;
260
+ text-overflow: ellipsis;
261
+ display: -webkit-box;
262
+ -webkit-line-clamp: ${c.resultLayout === 'large' ? 3 : 2};
263
+ -webkit-box-orient: vertical;
264
+ font-size: ${s.descSize || '12px'};
265
+ color: #6b7280;
266
+ }
267
+ .ws-search-price {
268
+ font-weight: 600;
269
+ font-size: ${s.priceSize || '14px'};
270
+ color: ${s.priceColor || s.accentColor || '#059669'};
271
+ }
272
+ .ws-search-old-price {
273
+ font-size: 12px;
274
+ color: ${s.originalPriceColor || '#9ca3af'};
275
+ text-decoration: line-through;
276
+ margin-left: 6px;
277
+ }
278
+ .ws-search-discount {
279
+ display: inline-block;
280
+ background: ${s.discountBadgeBg || '#dc2626'};
281
+ color: ${s.discountBadgeText || '#fff'};
282
+ font-size: 11px;
283
+ font-weight: 600;
284
+ padding: 2px 6px;
285
+ border-radius: ${s.badgeRadius || '4px'};
286
+ margin-left: 6px;
287
+ }
288
+ .ws-search-category {
289
+ font-size: 11px;
290
+ color: #9ca3af;
291
+ margin-top: 4px;
292
+ }
293
+ .ws-search-stock {
294
+ font-size: 11px;
295
+ padding: 2px 6px;
296
+ border-radius: 4px;
297
+ margin-top: 4px;
298
+ display: inline-block;
299
+ }
300
+ .ws-search-stock.in-stock { background: #dcfce7; color: #166534; }
301
+ .ws-search-stock.out-of-stock { background: #fee2e2; color: #991b1b; }
302
+
303
+ /* Loading & Empty */
304
+ .ws-search-loading, .ws-search-empty {
305
+ display: flex;
306
+ flex-direction: column;
307
+ align-items: center;
308
+ justify-content: center;
309
+ padding: 32px 24px;
310
+ color: #6b7280;
311
+ text-align: center;
312
+ }
313
+ .ws-search-spinner {
314
+ width: 24px;
315
+ height: 24px;
316
+ border: 2px solid #e5e7eb;
317
+ border-top-color: ${s.accentColor || '#6366f1'};
318
+ border-radius: 50%;
319
+ animation: wsSearchSpin 0.8s linear infinite;
320
+ margin-bottom: 12px;
321
+ }
322
+ @keyframes wsSearchSpin { to { transform: rotate(360deg); } }
323
+
324
+ /* Footer */
325
+ .ws-search-footer {
326
+ padding: 10px 16px;
327
+ background: #f9fafb;
328
+ border-top: 1px solid #f3f4f6;
329
+ font-size: 11px;
330
+ color: #9ca3af;
331
+ text-align: center;
332
+ }
333
+
334
+ /* Category Chips */
335
+ .ws-search-categories {
336
+ display: flex;
337
+ flex-wrap: wrap;
338
+ gap: 8px;
339
+ padding: 12px 16px;
340
+ border-bottom: 1px solid #f3f4f6;
341
+ }
342
+ .ws-search-cat-chip {
343
+ padding: 6px 12px;
344
+ border-radius: 9999px;
345
+ font-size: 12px;
346
+ font-weight: 500;
347
+ background: #f3f4f6;
348
+ color: #4b5563;
349
+ border: none;
350
+ cursor: pointer;
351
+ transition: all 0.15s;
352
+ }
353
+ .ws-search-cat-chip:hover { background: #e5e7eb; }
354
+ .ws-search-cat-chip.active {
355
+ background: ${s.categoryActiveBg || s.accentColor || '#6366f1'};
356
+ color: ${s.categoryActiveText || '#fff'};
357
+ }
358
+ .ws-search-cat-chip {
359
+ padding: ${s.categoryPadding || '6px 12px'};
360
+ border-radius: ${s.categoryRadius || '9999px'};
361
+ font-size: 12px;
362
+ font-weight: 500;
363
+ background: ${s.inputBg || '#f3f4f6'};
364
+ color: ${s.textColor || '#4b5563'};
365
+ border: none;
366
+ cursor: pointer;
367
+ transition: all 0.15s;
368
+ }
369
+
370
+ /* Overlay (Modal/Fullscreen/Sidebar) */
371
+ .ws-search-overlay {
372
+ position: fixed;
373
+ top: 0;
374
+ left: 0;
375
+ right: 0;
376
+ bottom: 0;
377
+ background: rgba(0,0,0,${(s.overlayOpacity || 50) / 100});
378
+ display: none;
379
+ align-items: flex-start;
380
+ justify-content: center;
381
+ padding-top: 100px;
382
+ z-index: 9999999;
383
+ }
384
+ .ws-search-overlay.open { display: flex; }
385
+ .ws-search-overlay.position-fullscreen {
386
+ padding: 0;
387
+ align-items: stretch;
388
+ z-index: 99999999; /* Higher for fullscreen */
389
+ }
390
+ .ws-search-overlay.position-sidebar {
391
+ justify-content: flex-end;
392
+ padding: 0;
393
+ }
394
+
395
+ /* Modal */
396
+ .ws-search-modal {
397
+ width: 90%;
398
+ max-width: ${s.modalWidth || '600px'};
399
+ max-height: ${s.modalMaxHeight || '80vh'};
400
+ background: ${s.backgroundColor || '#fff'};
401
+ border-radius: ${s.modalRadius || s.containerRadius || '12px'};
402
+ box-shadow: ${s.modalShadow || '0 25px 50px -12px rgba(0,0,0,0.25)'};
403
+ animation: wsSearchScaleIn ${c.animationDuration}ms ease;
404
+ overflow: hidden;
405
+ display: flex;
406
+ flex-direction: column;
407
+ position: relative; /* Context context */
408
+ }
409
+ .ws-search-modal .ws-search-results {
410
+ position: static;
411
+ margin: 0;
412
+ box-shadow: none;
413
+ border-top: 1px solid ${s.borderColor || '#e5e7eb'};
414
+ border-radius: 0;
415
+ flex: 1;
416
+ }
417
+
418
+ /* Inline Container for Inline Mode */
419
+ ${c.position === 'inline' ? `
420
+ ${c.selector || ''} .ws-search-container {
421
+ box-shadow: none;
422
+ max-width: 100%;
423
+ border-radius: ${s.inputRadius || '8px'};
424
+ padding: ${s.inputPaddingTop || 0} ${s.inputPaddingRight || 0} ${s.inputPaddingBottom || 0} ${s.inputPaddingLeft || 0};
425
+ margin: ${s.inputMarginTop || 0} ${s.inputMarginRight || 0} ${s.inputMarginBottom || 0} ${s.inputMarginLeft || 0};
426
+ border-width: ${s.inputBorderWidth || '1px'};
427
+ border-style: ${s.inputBorderStyle || 'solid'};
428
+ border-color: ${s.inputBorderColor || 'transparent'};
429
+ background: transparent;
430
+ position: relative;
431
+ }
432
+ ${c.selector || ''} .ws-search-results {
433
+ width: ${s.resultsWidth || '100%'};
434
+ ${s.resultsWidth ? 'right: auto;' : ''}
435
+ }
436
+ ` : ''}
437
+
438
+ /* Fullscreen */
439
+ .ws-search-fullscreen {
440
+ width: 100%;
441
+ height: 100%;
442
+ background: ${s.backgroundColor || '#fff'};
443
+ display: flex;
444
+ flex-direction: column;
445
+ animation: wsSearchFadeIn ${c.animationDuration}ms ease;
446
+ }
447
+ .ws-search-fullscreen .ws-search-input-wrap { padding: 24px; }
448
+ .ws-search-fullscreen .ws-search-results {
449
+ position: static;
450
+ margin: 0;
451
+ box-shadow: none;
452
+ flex: 1;
453
+ max-height: none;
454
+ border-radius: 0;
455
+ }
456
+
457
+ /* Sidebar Panel */
458
+ .ws-search-sidebar-panel {
459
+ width: ${s.sidebarWidth || s.panelWidth || '480px'};
460
+ max-width: 100%;
461
+ height: 100%;
462
+ background: ${s.backgroundColor || '#fff'};
463
+ box-shadow: ${s.sidebarShadow || '-10px 0 40px rgba(0,0,0,0.15)'};
464
+ animation: wsSearchSlideIn ${c.animationDuration}ms ease;
465
+ display: flex;
466
+ flex-direction: column;
467
+ }
468
+ .ws-search-sidebar-panel .ws-search-header {
469
+ display: flex;
470
+ align-items: center;
471
+ justify-content: space-between;
472
+ padding: 16px 20px;
473
+ border-bottom: 1px solid ${s.borderColor || '#e5e7eb'};
474
+ }
475
+ .ws-search-sidebar-panel .ws-search-input-wrap { padding: 16px 20px; }
476
+ .ws-search-sidebar-panel .ws-search-results {
477
+ position: static;
478
+ margin: 0;
479
+ box-shadow: none;
480
+ flex: 1;
481
+ max-height: none;
482
+ border-radius: 0;
483
+ }
484
+
485
+ /* Floating Button */
486
+ .ws-search-floating-btn {
487
+ position: fixed;
488
+ width: ${s.floatingButtonSize || '56px'};
489
+ height: ${s.floatingButtonSize || '56px'};
490
+ background: ${s.floatingButtonBg || s.accentColor || '#6366f1'};
491
+ border: ${s.floatingButtonBorder || 'none'};
492
+ border-radius: ${s.floatingButtonRadius || '50%'};
493
+ cursor: pointer;
494
+ display: flex;
495
+ align-items: center;
496
+ justify-content: center;
497
+ box-shadow: ${getShadow(s.floatingButtonShadow || 'lg', s.floatingButtonShadowColor)};
498
+ padding: ${s.floatingButtonPaddingTop || 0} ${s.floatingButtonPaddingRight || 0} ${s.floatingButtonPaddingBottom || 0} ${s.floatingButtonPaddingLeft || 0};
499
+ margin: ${s.floatingButtonMarginTop || 0} ${s.floatingButtonMarginRight || 0} ${s.floatingButtonMarginBottom || 0} ${s.floatingButtonMarginLeft || 0};
500
+ transition: all 0.2s ease;
501
+ z-index: 999998;
502
+ }
503
+ .ws-search-floating-btn.ws-embedded {
504
+ position: static;
505
+ transform: none !important;
506
+ z-index: auto;
507
+ /* Respect configured margin even if embedded, unless user explicitly sets it to 0 */
508
+ /* But wait, embedded might need resetting. Let's just inherit the margin defined above if it's not 0 */
509
+ }
510
+ .ws-search-floating-btn:hover {
511
+ transform: scale(1.05);
512
+ box-shadow: ${getShadow(s.floatingButtonHoverShadow || 'xl', s.floatingButtonShadowColor)};
513
+ }
514
+ .ws-search-floating-btn.ws-embedded:hover {
515
+ transform: scale(1.05);
516
+ }
517
+ .ws-search-floating-btn svg { width: 24px; height: 24px; color: ${s.floatingButtonIconColor || '#fff'}; }
518
+ .ws-search-floating-btn.bottom-right { bottom: ${s.floatingButtonOffset || '24px'}; right: ${s.floatingButtonOffset || '24px'}; }
519
+ .ws-search-floating-btn.bottom-left { bottom: ${s.floatingButtonOffset || '24px'}; left: ${s.floatingButtonOffset || '24px'}; }
520
+ .ws-search-floating-btn.top-right { top: ${s.floatingButtonOffset || '24px'}; right: ${s.floatingButtonOffset || '24px'}; }
521
+ .ws-search-floating-btn.top-left { top: ${s.floatingButtonOffset || '24px'}; left: ${s.floatingButtonOffset || '24px'}; }
522
+
523
+ /* Close Button */
524
+ .ws-search-close {
525
+ width: 32px;
526
+ height: 32px;
527
+ background: transparent;
528
+ border: none;
529
+ border-radius: 8px;
530
+ cursor: pointer;
531
+ display: flex;
532
+ align-items: center;
533
+ justify-content: center;
534
+ color: #6b7280;
535
+ transition: all 0.15s;
536
+ }
537
+ .ws-search-close:hover { background: #f3f4f6; color: #1f2937; }
538
+
539
+ /* Mobile Responsive */
540
+ @media (max-width: 640px) {
541
+ .ws-search-modal { max-width: 100%; width: 100%; margin: 0; border-radius: 0; }
542
+ .ws-search-sidebar-panel { width: 100%; }
543
+ }
544
+
545
+ /* Animations */
546
+ @keyframes ws-fade-in { from { opacity: 0; } to { opacity: 1; } }
547
+ @keyframes ws-slide-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
548
+ @keyframes ws-scale-up { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }
549
+
550
+ .ws-search-overlay.anim-fade { animation: ws-fade-in ${c.animationDuration || 200}ms ease-out forwards; }
551
+ .ws-search-overlay.anim-slide { animation: ws-slide-up ${c.animationDuration || 200}ms ease-out forwards; }
552
+ .ws-search-overlay.anim-scale { animation: ws-scale-up ${c.animationDuration || 200}ms ease-out forwards; }
553
+
554
+ /* Container specific animations for inline/dropdown */
555
+ .ws-search-results.anim-fade { animation: ws-fade-in ${c.animationDuration || 200}ms ease-out forwards; }
556
+ .ws-search-results.anim-slide { animation: ws-slide-up ${c.animationDuration || 200}ms ease-out forwards; }
557
+ .ws-search-results.anim-scale { animation: ws-scale-up ${c.animationDuration || 200}ms ease-out forwards; }
558
+
559
+ /* ========== Suggestions Styles (Modern & Beautiful) ========== */
560
+ .ws-suggestions {
561
+ padding: 0 !important;
562
+ margin: 0 !important;
563
+ box-sizing: border-box !important;
564
+ list-style: none !important;
565
+ background: transparent !important;
566
+ }
567
+ .ws-suggestions * {
568
+ box-sizing: border-box !important;
569
+ list-style: none !important;
570
+ }
571
+
572
+ .ws-suggestions-section {
573
+ padding: ${ss.sectionSpacing || '16px'} 0 !important;
574
+ border-bottom: ${ss.sectionDivider !== false ? '1px solid ' + (ss.sectionDividerColor || s.borderColor || '#f3f4f6') : 'none'} !important;
575
+ margin: 0 !important;
576
+ background: transparent !important;
577
+ }
578
+ .ws-suggestions-section:last-child {
579
+ border-bottom: none !important;
580
+ padding-bottom: 8px !important;
581
+ }
582
+ .ws-suggestions-section:first-child {
583
+ padding-top: 8px !important;
584
+ }
585
+
586
+ .ws-suggestions-header {
587
+ display: flex !important;
588
+ align-items: center !important;
589
+ justify-content: space-between !important;
590
+ padding: 0 ${ss.sectionHeaderPadding || '20px'} 12px !important;
591
+ margin: 0 0 4px 0 !important;
592
+ background: transparent !important;
593
+ border: none !important;
594
+ }
595
+ .ws-suggestions-header span {
596
+ font-size: ${ss.sectionHeaderSize || '11px'} !important;
597
+ font-weight: ${ss.sectionHeaderWeight || '600'} !important;
598
+ color: ${ss.sectionHeaderColor || '#9ca3af'} !important;
599
+ text-transform: uppercase !important;
600
+ letter-spacing: 0.08em !important;
601
+ margin: 0 !important;
602
+ padding: 0 !important;
603
+ line-height: 1.4 !important;
604
+ }
605
+
606
+ .ws-suggestions-clear {
607
+ font-size: 12px !important;
608
+ font-weight: 500 !important;
609
+ color: ${ss.recentClearColor || s.accentColor || '#6366f1'} !important;
610
+ background: transparent !important;
611
+ border: none !important;
612
+ cursor: pointer !important;
613
+ padding: 4px 10px !important;
614
+ border-radius: 6px !important;
615
+ text-transform: none !important;
616
+ letter-spacing: normal !important;
617
+ transition: all 0.15s ease !important;
618
+ margin: 0 !important;
619
+ line-height: 1.4 !important;
620
+ }
621
+ .ws-suggestions-clear:hover {
622
+ background: ${ss.recentClearColor || s.accentColor || '#6366f1'}15 !important;
623
+ }
624
+
625
+ /* Recent & Popular Search Items */
626
+ .ws-suggestion-item {
627
+ display: flex !important;
628
+ align-items: center !important;
629
+ gap: 14px !important;
630
+ padding: 12px 20px !important;
631
+ cursor: pointer !important;
632
+ transition: all 0.15s ease;
633
+ color: ${ss.recentTextColor || s.textColor || '#374151'};
634
+ text-decoration: none;
635
+ border-radius: 0;
636
+ margin: 0;
637
+ box-sizing: border-box;
638
+ }
639
+ .ws-suggestion-item:hover {
640
+ background: ${ss.recentHoverBg || s.itemHoverBg || '#f8fafc'};
641
+ }
642
+ .ws-suggestion-item svg {
643
+ width: 18px !important;
644
+ height: 18px !important;
645
+ min-width: 18px;
646
+ min-height: 18px;
647
+ max-width: 18px;
648
+ max-height: 18px;
649
+ color: ${ss.recentIconColor || '#d1d5db'};
650
+ flex-shrink: 0;
651
+ transition: color 0.15s ease;
652
+ }
653
+ .ws-suggestion-item:hover svg {
654
+ color: ${ss.recentIconColor || s.accentColor || '#6366f1'};
655
+ }
656
+ .ws-suggestion-text {
657
+ flex: 1;
658
+ font-size: 14px;
659
+ font-weight: 400;
660
+ color: ${ss.recentTextColor || s.textColor || '#374151'};
661
+ overflow: hidden;
662
+ text-overflow: ellipsis;
663
+ white-space: nowrap;
664
+ }
665
+ .ws-suggestion-remove {
666
+ opacity: 0;
667
+ padding: 6px;
668
+ border: none;
669
+ background: transparent;
670
+ cursor: pointer;
671
+ color: #9ca3af;
672
+ border-radius: 6px;
673
+ transition: all 0.15s ease;
674
+ display: flex;
675
+ align-items: center;
676
+ justify-content: center;
677
+ }
678
+ .ws-suggestion-item:hover .ws-suggestion-remove { opacity: 1; }
679
+ .ws-suggestion-remove:hover {
680
+ background: #fef2f2;
681
+ color: #ef4444;
682
+ }
683
+ .ws-suggestion-remove svg {
684
+ width: 14px !important;
685
+ height: 14px !important;
686
+ min-width: 14px;
687
+ min-height: 14px;
688
+ color: inherit !important;
689
+ }
690
+
691
+ /* Popular Search specific */
692
+ .ws-popular-search-item svg {
693
+ color: ${ss.popularSearchIconColor || '#fbbf24'} !important;
694
+ }
695
+ .ws-popular-search-item:hover svg {
696
+ color: ${ss.popularSearchIconColor || '#f59e0b'} !important;
697
+ }
698
+ .ws-popular-search-item .ws-suggestion-text {
699
+ color: ${ss.popularSearchTextColor || s.textColor || '#374151'};
700
+ }
701
+
702
+ /* Popular Categories Grid - Modern Card Style */
703
+ .ws-popular-categories {
704
+ display: grid;
705
+ grid-template-columns: repeat(${ss.categoryColumns || 'auto-fill'}, minmax(${ss.categoryColumns ? '1fr' : '90px'}, 1fr));
706
+ gap: ${ss.categoryGap || '10px'};
707
+ padding: 0 20px;
708
+ }
709
+ .ws-category-card {
710
+ display: flex;
711
+ flex-direction: column;
712
+ align-items: center;
713
+ gap: 10px;
714
+ padding: 16px 12px;
715
+ border-radius: ${ss.categoryCardRadius || '12px'};
716
+ background: ${ss.categoryCardBg || '#f8fafc'};
717
+ border: 1px solid ${ss.categoryCardBorder || 'transparent'};
718
+ cursor: pointer;
719
+ transition: all 0.2s ease;
720
+ text-decoration: none;
721
+ color: inherit;
722
+ box-shadow: ${ss.categoryCardShadow || 'none'};
723
+ }
724
+ .ws-category-card:hover {
725
+ background: ${ss.categoryCardHoverBg || '#f1f5f9'};
726
+ border-color: ${ss.categoryCardHoverBorder || s.accentColor || '#6366f1'};
727
+ transform: translateY(-2px);
728
+ box-shadow: 0 4px 12px rgba(0,0,0,0.08);
729
+ }
730
+ .ws-category-img {
731
+ width: ${ss.categoryImageSize || '48px'};
732
+ height: ${ss.categoryImageSize || '48px'};
733
+ border-radius: ${ss.categoryImageRadius || '10px'};
734
+ object-fit: cover;
735
+ background: ${ss.categoryImageBg || '#e2e8f0'};
736
+ display: flex;
737
+ align-items: center;
738
+ justify-content: center;
739
+ }
740
+ .ws-category-img svg {
741
+ width: 22px !important;
742
+ height: 22px !important;
743
+ color: #94a3b8;
744
+ }
745
+ .ws-category-name {
746
+ font-size: ${ss.categoryNameSize || '12px'};
747
+ font-weight: 500;
748
+ text-align: center;
749
+ color: ${ss.categoryNameColor || s.textColor || '#475569'};
750
+ line-height: 1.3;
751
+ max-width: 100%;
752
+ overflow: hidden;
753
+ text-overflow: ellipsis;
754
+ display: -webkit-box;
755
+ -webkit-line-clamp: 2;
756
+ -webkit-box-orient: vertical;
757
+ }
758
+
759
+ /* Popular Products - Premium Card Style */
760
+ .ws-popular-products {
761
+ display: grid;
762
+ grid-template-columns: repeat(${ss.productColumns || 'auto-fill'}, minmax(${ss.productColumns ? '1fr' : '140px'}, 1fr));
763
+ gap: ${ss.productGap || '12px'};
764
+ padding: 0 20px;
765
+ }
766
+ .ws-product-card {
767
+ display: flex;
768
+ flex-direction: column;
769
+ border-radius: ${ss.productCardRadius || '12px'};
770
+ background: ${ss.productCardBg || '#ffffff'};
771
+ border: 1px solid ${ss.productCardBorder || '#e2e8f0'};
772
+ overflow: hidden;
773
+ cursor: pointer;
774
+ transition: all 0.2s ease;
775
+ text-decoration: none;
776
+ color: inherit;
777
+ box-shadow: ${ss.productCardShadow || '0 1px 3px rgba(0,0,0,0.04)'};
778
+ }
779
+ .ws-product-card:hover {
780
+ border-color: ${ss.productCardHoverBorder || s.accentColor || '#6366f1'};
781
+ box-shadow: ${ss.productCardHoverShadow || '0 8px 24px rgba(0,0,0,0.12)'};
782
+ transform: translateY(-3px);
783
+ }
784
+ .ws-product-card-img {
785
+ width: 100%;
786
+ height: ${ss.productImageHeight || '100px'};
787
+ object-fit: cover;
788
+ background: ${ss.productImageBg || '#f8fafc'};
789
+ }
790
+ .ws-product-card-img svg {
791
+ width: 28px !important;
792
+ height: 28px !important;
793
+ }
794
+ .ws-product-card-info {
795
+ padding: 12px;
796
+ display: flex;
797
+ flex-direction: column;
798
+ gap: 6px;
799
+ }
800
+ .ws-product-card-name {
801
+ font-size: ${ss.productNameSize || '13px'};
802
+ font-weight: 500;
803
+ color: ${ss.productNameColor || s.textColor || '#1e293b'};
804
+ margin: 0;
805
+ line-height: 1.4;
806
+ display: -webkit-box;
807
+ -webkit-line-clamp: 2;
808
+ -webkit-box-orient: vertical;
809
+ overflow: hidden;
810
+ }
811
+ .ws-product-card-prices {
812
+ display: flex;
813
+ align-items: center;
814
+ gap: 8px;
815
+ flex-wrap: wrap;
816
+ }
817
+ .ws-product-card-price {
818
+ font-size: ${ss.productPriceSize || '15px'};
819
+ font-weight: 700;
820
+ color: ${ss.productPriceColor || s.priceColor || '#059669'};
821
+ }
822
+ .ws-product-card-old-price {
823
+ font-size: 12px;
824
+ font-weight: 400;
825
+ color: ${ss.productOldPriceColor || '#9ca3af'};
826
+ text-decoration: line-through;
827
+ }
828
+ .ws-product-card-discount {
829
+ position: absolute;
830
+ top: 8px;
831
+ left: 8px;
832
+ font-size: 11px;
833
+ font-weight: 600;
834
+ color: #ffffff;
835
+ background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
836
+ padding: 3px 8px;
837
+ border-radius: 6px;
838
+ box-shadow: 0 2px 4px rgba(239, 68, 68, 0.3);
839
+ }
840
+ .ws-product-card-img-wrap {
841
+ position: relative;
842
+ overflow: hidden;
843
+ }
844
+
845
+ /* Custom CSS */
846
+ ${s.customCss || ''}
847
+ `;
848
+ }
849
+ /**
850
+ * Inject search styles into the document
851
+ */
852
+ export function injectSearchStyles(config, suggestionStyles) {
853
+ if (document.getElementById('ws-search-styles'))
854
+ return;
855
+ const styles = document.createElement('style');
856
+ styles.id = 'ws-search-styles';
857
+ styles.textContent = generateSearchStyles(config, suggestionStyles);
858
+ document.head.appendChild(styles);
859
+ }
860
+ //# sourceMappingURL=styles.js.map