farm-react 1.0.7 → 1.0.9

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 (296) hide show
  1. package/dist/assets/styles/style.css +25347 -0
  2. package/dist/assets/styles/style.css.map +1 -0
  3. package/dist/cjs/Utils/index.d.ts +4 -0
  4. package/dist/cjs/Utils/index.js +8 -0
  5. package/dist/cjs/Utils/index.js.map +1 -0
  6. package/dist/cjs/components/Accordion.js +7 -6
  7. package/dist/cjs/components/Accordion.js.map +1 -1
  8. package/dist/cjs/components/Alert.d.ts +32 -0
  9. package/dist/cjs/components/Alert.js +50 -0
  10. package/dist/cjs/components/Alert.js.map +1 -0
  11. package/dist/cjs/components/Badge.d.ts +22 -0
  12. package/dist/cjs/components/Badge.js +36 -0
  13. package/dist/cjs/components/Badge.js.map +1 -0
  14. package/dist/cjs/components/BrokenPage.d.ts +35 -0
  15. package/dist/cjs/components/BrokenPage.js +59 -0
  16. package/dist/cjs/components/BrokenPage.js.map +1 -0
  17. package/dist/cjs/components/Button.d.ts +29 -2
  18. package/dist/cjs/components/Button.js +56 -4
  19. package/dist/cjs/components/Button.js.map +1 -1
  20. package/dist/cjs/components/Card.d.ts +77 -0
  21. package/dist/cjs/components/Card.js +77 -0
  22. package/dist/cjs/components/Card.js.map +1 -0
  23. package/dist/cjs/components/Checkbox.d.ts +25 -0
  24. package/dist/cjs/components/Checkbox.js +23 -0
  25. package/dist/cjs/components/Checkbox.js.map +1 -0
  26. package/dist/cjs/components/ConfirmPoup.d.ts +21 -0
  27. package/dist/cjs/components/ConfirmPoup.js +47 -0
  28. package/dist/cjs/components/ConfirmPoup.js.map +1 -0
  29. package/dist/cjs/components/Dropdown.d.ts +35 -0
  30. package/dist/cjs/components/Dropdown.js +54 -0
  31. package/dist/cjs/components/Dropdown.js.map +1 -0
  32. package/dist/cjs/components/Label.d.ts +1 -1
  33. package/dist/cjs/components/Label.js +8 -6
  34. package/dist/cjs/components/Label.js.map +1 -1
  35. package/dist/cjs/components/Layout/Footer.js +11 -2
  36. package/dist/cjs/components/Layout/Footer.js.map +1 -1
  37. package/dist/cjs/components/Layout/Header.d.ts +2 -1
  38. package/dist/cjs/components/Layout/Header.js +15 -4
  39. package/dist/cjs/components/Layout/Header.js.map +1 -1
  40. package/dist/cjs/components/Layout/Sidebar.d.ts +2 -1
  41. package/dist/cjs/components/Layout/Sidebar.js +5 -3
  42. package/dist/cjs/components/Layout/Sidebar.js.map +1 -1
  43. package/dist/cjs/components/MultiCheckbox.d.ts +39 -0
  44. package/dist/cjs/components/MultiCheckbox.js +56 -0
  45. package/dist/cjs/components/MultiCheckbox.js.map +1 -0
  46. package/dist/cjs/components/MultiRadio.d.ts +30 -0
  47. package/dist/cjs/components/MultiRadio.js +41 -0
  48. package/dist/cjs/components/MultiRadio.js.map +1 -0
  49. package/dist/cjs/components/NumberInput.d.ts +38 -0
  50. package/dist/cjs/components/NumberInput.js +34 -0
  51. package/dist/cjs/components/NumberInput.js.map +1 -0
  52. package/dist/cjs/components/Popover.d.ts +56 -0
  53. package/dist/cjs/components/Popover.js +34 -0
  54. package/dist/cjs/components/Popover.js.map +1 -0
  55. package/dist/cjs/components/Radio.d.ts +24 -0
  56. package/dist/cjs/components/Radio.js +24 -0
  57. package/dist/cjs/components/Radio.js.map +1 -0
  58. package/dist/cjs/components/RadioButtonGroup.d.ts +67 -0
  59. package/dist/cjs/components/RadioButtonGroup.js +141 -0
  60. package/dist/cjs/components/RadioButtonGroup.js.map +1 -0
  61. package/dist/cjs/components/RangeSlider.d.ts +30 -0
  62. package/dist/cjs/components/RangeSlider.js +48 -0
  63. package/dist/cjs/components/RangeSlider.js.map +1 -0
  64. package/dist/cjs/components/RatingDisplay.js +7 -4
  65. package/dist/cjs/components/RatingDisplay.js.map +1 -1
  66. package/dist/cjs/components/Search.d.ts +6 -0
  67. package/dist/cjs/components/Search.js +11 -0
  68. package/dist/cjs/components/Search.js.map +1 -0
  69. package/dist/cjs/components/Select.d.ts +41 -0
  70. package/dist/cjs/components/Select.js +48 -0
  71. package/dist/cjs/components/Select.js.map +1 -0
  72. package/dist/cjs/components/SkeletonLoader.d.ts +39 -0
  73. package/dist/cjs/components/SkeletonLoader.js +76 -0
  74. package/dist/cjs/components/SkeletonLoader.js.map +1 -0
  75. package/dist/cjs/components/Slider/SlickSlider.d.ts +74 -0
  76. package/dist/cjs/components/Slider/SlickSlider.js +211 -0
  77. package/dist/cjs/components/Slider/SlickSlider.js.map +1 -0
  78. package/dist/cjs/components/Slider/useCenterMode.d.ts +24 -0
  79. package/dist/cjs/components/Slider/useCenterMode.js +40 -0
  80. package/dist/cjs/components/Slider/useCenterMode.js.map +1 -0
  81. package/dist/cjs/components/Slider/useSlider.d.ts +65 -0
  82. package/dist/cjs/components/Slider/useSlider.js +158 -0
  83. package/dist/cjs/components/Slider/useSlider.js.map +1 -0
  84. package/dist/cjs/components/Slider/useSliderAutoPlay.d.ts +33 -0
  85. package/dist/cjs/components/Slider/useSliderAutoPlay.js +73 -0
  86. package/dist/cjs/components/Slider/useSliderAutoPlay.js.map +1 -0
  87. package/dist/cjs/components/Slider/useSliderBreakpoint.d.ts +23 -0
  88. package/dist/cjs/components/Slider/useSliderBreakpoint.js +92 -0
  89. package/dist/cjs/components/Slider/useSliderBreakpoint.js.map +1 -0
  90. package/dist/cjs/components/Slider/useSliderDimension.d.ts +41 -0
  91. package/dist/cjs/components/Slider/useSliderDimension.js +92 -0
  92. package/dist/cjs/components/Slider/useSliderDimension.js.map +1 -0
  93. package/dist/cjs/components/Slider/useSliderDraggable.d.ts +43 -0
  94. package/dist/cjs/components/Slider/useSliderDraggable.js +146 -0
  95. package/dist/cjs/components/Slider/useSliderDraggable.js.map +1 -0
  96. package/dist/cjs/components/Slider/useSliderNavigation.d.ts +41 -0
  97. package/dist/cjs/components/Slider/useSliderNavigation.js +136 -0
  98. package/dist/cjs/components/Slider/useSliderNavigation.js.map +1 -0
  99. package/dist/cjs/components/Slider/useSliderTransform.d.ts +17 -0
  100. package/dist/cjs/components/Slider/useSliderTransform.js +71 -0
  101. package/dist/cjs/components/Slider/useSliderTransform.js.map +1 -0
  102. package/dist/cjs/components/TextInput.d.ts +35 -4
  103. package/dist/cjs/components/TextInput.js +97 -11
  104. package/dist/cjs/components/TextInput.js.map +1 -1
  105. package/dist/cjs/components/ThreeDotsLoader.d.ts +24 -0
  106. package/dist/cjs/components/ThreeDotsLoader.js +25 -0
  107. package/dist/cjs/components/ThreeDotsLoader.js.map +1 -0
  108. package/dist/cjs/components/Tooltip.d.ts +32 -0
  109. package/dist/cjs/components/Tooltip.js +35 -0
  110. package/dist/cjs/components/Tooltip.js.map +1 -0
  111. package/dist/cjs/constants/app.d.ts +2 -0
  112. package/dist/cjs/constants/app.js +3 -1
  113. package/dist/cjs/constants/app.js.map +1 -1
  114. package/dist/cjs/constants/icons.d.ts +10 -0
  115. package/dist/cjs/constants/icons.js +14 -0
  116. package/dist/cjs/constants/icons.js.map +1 -0
  117. package/dist/cjs/helpers/app.d.ts +39 -2
  118. package/dist/cjs/helpers/app.js +83 -5
  119. package/dist/cjs/helpers/app.js.map +1 -1
  120. package/dist/cjs/helpers/index.d.ts +1 -0
  121. package/dist/cjs/helpers/index.js +3 -0
  122. package/dist/cjs/helpers/index.js.map +1 -1
  123. package/dist/cjs/hooks/index.d.ts +1 -0
  124. package/dist/cjs/hooks/index.js +4 -0
  125. package/dist/cjs/hooks/index.js.map +1 -1
  126. package/dist/cjs/hooks/useLocalStorage.d.ts +7 -0
  127. package/dist/cjs/hooks/useLocalStorage.js +57 -0
  128. package/dist/cjs/hooks/useLocalStorage.js.map +1 -0
  129. package/dist/cjs/index.d.ts +23 -5
  130. package/dist/cjs/index.js +47 -9
  131. package/dist/cjs/index.js.map +1 -1
  132. package/dist/cjs/strings/en.d.ts +3 -1
  133. package/dist/cjs/strings/en.js +5 -3
  134. package/dist/cjs/strings/en.js.map +1 -1
  135. package/dist/cjs/subComponent/DateRange.js +2 -0
  136. package/dist/cjs/subComponent/DateRange.js.map +1 -0
  137. package/dist/cjs/subComponent/ToggleButton.d.ts +9 -0
  138. package/dist/cjs/subComponent/ToggleButton.js +19 -0
  139. package/dist/cjs/subComponent/ToggleButton.js.map +1 -0
  140. package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtn.d.ts +43 -0
  141. package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtn.js +43 -0
  142. package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtn.js.map +1 -0
  143. package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtnGroup.d.ts +43 -0
  144. package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtnGroup.js +53 -0
  145. package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtnGroup.js.map +1 -0
  146. package/dist/esm/Utils/index.d.ts +4 -0
  147. package/dist/esm/Utils/index.js +5 -0
  148. package/dist/esm/Utils/index.js.map +1 -0
  149. package/dist/esm/components/Accordion.js +7 -6
  150. package/dist/esm/components/Accordion.js.map +1 -1
  151. package/dist/esm/components/Alert.d.ts +32 -0
  152. package/dist/esm/components/Alert.js +48 -0
  153. package/dist/esm/components/Alert.js.map +1 -0
  154. package/dist/esm/components/Badge.d.ts +22 -0
  155. package/dist/esm/components/Badge.js +34 -0
  156. package/dist/esm/components/Badge.js.map +1 -0
  157. package/dist/esm/components/BrokenPage.d.ts +35 -0
  158. package/dist/esm/components/BrokenPage.js +57 -0
  159. package/dist/esm/components/BrokenPage.js.map +1 -0
  160. package/dist/esm/components/Button.d.ts +29 -2
  161. package/dist/esm/components/Button.js +56 -3
  162. package/dist/esm/components/Button.js.map +1 -1
  163. package/dist/esm/components/Card.d.ts +77 -0
  164. package/dist/esm/components/Card.js +75 -0
  165. package/dist/esm/components/Card.js.map +1 -0
  166. package/dist/esm/components/Checkbox.d.ts +25 -0
  167. package/dist/esm/components/Checkbox.js +21 -0
  168. package/dist/esm/components/Checkbox.js.map +1 -0
  169. package/dist/esm/components/ConfirmPoup.d.ts +21 -0
  170. package/dist/esm/components/ConfirmPoup.js +45 -0
  171. package/dist/esm/components/ConfirmPoup.js.map +1 -0
  172. package/dist/esm/components/Dropdown.d.ts +35 -0
  173. package/dist/esm/components/Dropdown.js +52 -0
  174. package/dist/esm/components/Dropdown.js.map +1 -0
  175. package/dist/esm/components/Label.d.ts +1 -1
  176. package/dist/esm/components/Label.js +9 -7
  177. package/dist/esm/components/Label.js.map +1 -1
  178. package/dist/esm/components/Layout/Footer.js +10 -2
  179. package/dist/esm/components/Layout/Footer.js.map +1 -1
  180. package/dist/esm/components/Layout/Header.d.ts +2 -1
  181. package/dist/esm/components/Layout/Header.js +14 -3
  182. package/dist/esm/components/Layout/Header.js.map +1 -1
  183. package/dist/esm/components/Layout/Sidebar.d.ts +2 -1
  184. package/dist/esm/components/Layout/Sidebar.js +4 -3
  185. package/dist/esm/components/Layout/Sidebar.js.map +1 -1
  186. package/dist/esm/components/MultiCheckbox.d.ts +39 -0
  187. package/dist/esm/components/MultiCheckbox.js +54 -0
  188. package/dist/esm/components/MultiCheckbox.js.map +1 -0
  189. package/dist/esm/components/MultiRadio.d.ts +30 -0
  190. package/dist/esm/components/MultiRadio.js +39 -0
  191. package/dist/esm/components/MultiRadio.js.map +1 -0
  192. package/dist/esm/components/NumberInput.d.ts +38 -0
  193. package/dist/esm/components/NumberInput.js +32 -0
  194. package/dist/esm/components/NumberInput.js.map +1 -0
  195. package/dist/esm/components/Popover.d.ts +56 -0
  196. package/dist/esm/components/Popover.js +32 -0
  197. package/dist/esm/components/Popover.js.map +1 -0
  198. package/dist/esm/components/Radio.d.ts +24 -0
  199. package/dist/esm/components/Radio.js +22 -0
  200. package/dist/esm/components/Radio.js.map +1 -0
  201. package/dist/esm/components/RadioButtonGroup.d.ts +67 -0
  202. package/dist/esm/components/RadioButtonGroup.js +139 -0
  203. package/dist/esm/components/RadioButtonGroup.js.map +1 -0
  204. package/dist/esm/components/RangeSlider.d.ts +30 -0
  205. package/dist/esm/components/RangeSlider.js +46 -0
  206. package/dist/esm/components/RangeSlider.js.map +1 -0
  207. package/dist/esm/components/RatingDisplay.js +7 -4
  208. package/dist/esm/components/RatingDisplay.js.map +1 -1
  209. package/dist/esm/components/Search.d.ts +6 -0
  210. package/dist/esm/components/Search.js +8 -0
  211. package/dist/esm/components/Search.js.map +1 -0
  212. package/dist/esm/components/Select.d.ts +41 -0
  213. package/dist/esm/components/Select.js +46 -0
  214. package/dist/esm/components/Select.js.map +1 -0
  215. package/dist/esm/components/SkeletonLoader.d.ts +39 -0
  216. package/dist/esm/components/SkeletonLoader.js +74 -0
  217. package/dist/esm/components/SkeletonLoader.js.map +1 -0
  218. package/dist/esm/components/Slider/SlickSlider.d.ts +74 -0
  219. package/dist/esm/components/Slider/SlickSlider.js +208 -0
  220. package/dist/esm/components/Slider/SlickSlider.js.map +1 -0
  221. package/dist/esm/components/Slider/useCenterMode.d.ts +24 -0
  222. package/dist/esm/components/Slider/useCenterMode.js +38 -0
  223. package/dist/esm/components/Slider/useCenterMode.js.map +1 -0
  224. package/dist/esm/components/Slider/useSlider.d.ts +65 -0
  225. package/dist/esm/components/Slider/useSlider.js +156 -0
  226. package/dist/esm/components/Slider/useSlider.js.map +1 -0
  227. package/dist/esm/components/Slider/useSliderAutoPlay.d.ts +33 -0
  228. package/dist/esm/components/Slider/useSliderAutoPlay.js +71 -0
  229. package/dist/esm/components/Slider/useSliderAutoPlay.js.map +1 -0
  230. package/dist/esm/components/Slider/useSliderBreakpoint.d.ts +23 -0
  231. package/dist/esm/components/Slider/useSliderBreakpoint.js +90 -0
  232. package/dist/esm/components/Slider/useSliderBreakpoint.js.map +1 -0
  233. package/dist/esm/components/Slider/useSliderDimension.d.ts +41 -0
  234. package/dist/esm/components/Slider/useSliderDimension.js +90 -0
  235. package/dist/esm/components/Slider/useSliderDimension.js.map +1 -0
  236. package/dist/esm/components/Slider/useSliderDraggable.d.ts +43 -0
  237. package/dist/esm/components/Slider/useSliderDraggable.js +144 -0
  238. package/dist/esm/components/Slider/useSliderDraggable.js.map +1 -0
  239. package/dist/esm/components/Slider/useSliderNavigation.d.ts +41 -0
  240. package/dist/esm/components/Slider/useSliderNavigation.js +134 -0
  241. package/dist/esm/components/Slider/useSliderNavigation.js.map +1 -0
  242. package/dist/esm/components/Slider/useSliderTransform.d.ts +17 -0
  243. package/dist/esm/components/Slider/useSliderTransform.js +69 -0
  244. package/dist/esm/components/Slider/useSliderTransform.js.map +1 -0
  245. package/dist/esm/components/TextInput.d.ts +35 -4
  246. package/dist/esm/components/TextInput.js +99 -12
  247. package/dist/esm/components/TextInput.js.map +1 -1
  248. package/dist/esm/components/ThreeDotsLoader.d.ts +24 -0
  249. package/dist/esm/components/ThreeDotsLoader.js +23 -0
  250. package/dist/esm/components/ThreeDotsLoader.js.map +1 -0
  251. package/dist/esm/components/Tooltip.d.ts +32 -0
  252. package/dist/esm/components/Tooltip.js +33 -0
  253. package/dist/esm/components/Tooltip.js.map +1 -0
  254. package/dist/esm/constants/app.d.ts +2 -0
  255. package/dist/esm/constants/app.js +2 -0
  256. package/dist/esm/constants/app.js.map +1 -1
  257. package/dist/esm/constants/icons.d.ts +10 -0
  258. package/dist/esm/constants/icons.js +12 -0
  259. package/dist/esm/constants/icons.js.map +1 -0
  260. package/dist/esm/helpers/app.d.ts +39 -2
  261. package/dist/esm/helpers/app.js +73 -3
  262. package/dist/esm/helpers/app.js.map +1 -1
  263. package/dist/esm/helpers/index.d.ts +1 -0
  264. package/dist/esm/helpers/index.js +1 -1
  265. package/dist/esm/helpers/index.js.map +1 -1
  266. package/dist/esm/hooks/index.d.ts +1 -0
  267. package/dist/esm/hooks/index.js +1 -1
  268. package/dist/esm/hooks/index.js.map +1 -1
  269. package/dist/esm/hooks/useLocalStorage.d.ts +7 -0
  270. package/dist/esm/hooks/useLocalStorage.js +54 -0
  271. package/dist/esm/hooks/useLocalStorage.js.map +1 -0
  272. package/dist/esm/index.d.ts +23 -5
  273. package/dist/esm/index.js +23 -5
  274. package/dist/esm/index.js.map +1 -1
  275. package/dist/esm/strings/en.d.ts +3 -1
  276. package/dist/esm/strings/en.js +4 -2
  277. package/dist/esm/strings/en.js.map +1 -1
  278. package/dist/esm/subComponent/DateRange.js +2 -0
  279. package/dist/esm/subComponent/DateRange.js.map +1 -0
  280. package/dist/esm/subComponent/ToggleButton.d.ts +9 -0
  281. package/dist/esm/subComponent/ToggleButton.js +17 -0
  282. package/dist/esm/subComponent/ToggleButton.js.map +1 -0
  283. package/dist/esm/subComponent/toggleBtnGroup/ToggleBtn.d.ts +43 -0
  284. package/dist/esm/subComponent/toggleBtnGroup/ToggleBtn.js +41 -0
  285. package/dist/esm/subComponent/toggleBtnGroup/ToggleBtn.js.map +1 -0
  286. package/dist/esm/subComponent/toggleBtnGroup/ToggleBtnGroup.d.ts +43 -0
  287. package/dist/esm/subComponent/toggleBtnGroup/ToggleBtnGroup.js +51 -0
  288. package/dist/esm/subComponent/toggleBtnGroup/ToggleBtnGroup.js.map +1 -0
  289. package/dist/package.json +1 -1
  290. package/package.json +6 -4
  291. package/dist/cjs/strings/index.js +0 -2
  292. package/dist/cjs/strings/index.js.map +0 -1
  293. package/dist/esm/strings/index.js +0 -2
  294. package/dist/esm/strings/index.js.map +0 -1
  295. /package/dist/cjs/{strings/index.d.ts → subComponent/DateRange.d.ts} +0 -0
  296. /package/dist/esm/{strings/index.d.ts → subComponent/DateRange.d.ts} +0 -0
@@ -0,0 +1,39 @@
1
+ import React, { type ReactElement } from 'react';
2
+ import { type SpinnerProps } from 'react-bootstrap';
3
+ interface Classnames {
4
+ wrapper?: string;
5
+ text?: string;
6
+ circle?: string;
7
+ square?: string;
8
+ table?: string;
9
+ list?: string;
10
+ spinnerWrapper?: string;
11
+ textWrapper?: string;
12
+ }
13
+ interface Attributes {
14
+ wrapper?: object;
15
+ text?: object;
16
+ circle?: object;
17
+ square?: object;
18
+ table?: object;
19
+ list?: object;
20
+ spinnerWrapper?: object;
21
+ textWrapper?: object;
22
+ }
23
+ export interface SkeletonLoaderProps {
24
+ loading: boolean;
25
+ variant: 'text' | 'circle' | 'square' | 'table' | 'list' | 'spinner';
26
+ spinnerProps?: SpinnerProps;
27
+ xs?: number;
28
+ as?: keyof React.JSX.IntrinsicElements;
29
+ animation?: 'glow' | 'wave';
30
+ width?: number | string | null;
31
+ height?: number | string | null;
32
+ rows?: number;
33
+ cols?: number;
34
+ size?: 'xs' | 'sm' | 'lg';
35
+ classnames?: Classnames;
36
+ attributes?: Attributes;
37
+ }
38
+ declare function SkeletonLoader({ loading, variant, spinnerProps, xs, as: Component, animation, width, height, rows, cols, size, classnames, attributes, }: SkeletonLoaderProps): ReactElement | null;
39
+ export default SkeletonLoader;
@@ -0,0 +1,74 @@
1
+ import { __assign } from "tslib";
2
+ import React from 'react';
3
+ import clsx from 'clsx';
4
+ import { Spinner } from 'react-bootstrap';
5
+ import { destructObj } from '../helpers';
6
+ var sizeHeightMap = {
7
+ xs: 8,
8
+ sm: 16,
9
+ lg: 24,
10
+ };
11
+ function getComputedHeight(height, size) {
12
+ return height !== null && height !== void 0 ? height : (size ? sizeHeightMap[size] : undefined);
13
+ }
14
+ function getCommonStyle(width, height) {
15
+ return {
16
+ width: width !== null && width !== void 0 ? width : undefined,
17
+ height: height,
18
+ };
19
+ }
20
+ function SkeletonLoader(_a) {
21
+ var loading = _a.loading, variant = _a.variant, _b = _a.spinnerProps, spinnerProps = _b === void 0 ? {} : _b, _c = _a.xs, xs = _c === void 0 ? 12 : _c, _d = _a.as, Component = _d === void 0 ? 'span' : _d, _e = _a.animation, animation = _e === void 0 ? 'glow' : _e, _f = _a.width, width = _f === void 0 ? null : _f, _g = _a.height, height = _g === void 0 ? null : _g, _h = _a.rows, rows = _h === void 0 ? 1 : _h, _j = _a.cols, cols = _j === void 0 ? 1 : _j, size = _a.size, _k = _a.classnames, classnames = _k === void 0 ? {} : _k, _l = _a.attributes, attributes = _l === void 0 ? {} : _l;
22
+ if (!loading)
23
+ return null;
24
+ var computedHeight = getComputedHeight(height, size);
25
+ var commonStyle = getCommonStyle(width, computedHeight);
26
+ var baseAnimationClass = "placeholder-".concat(animation);
27
+ var _m = destructObj(classnames), wrapperClass = _m.wrapper, textClass = _m.text, circleClass = _m.circle, squareClass = _m.square, tableClass = _m.table, listClass = _m.list, spinnerWrapperClass = _m.spinnerWrapper, textWrapperClass = _m.textWrapper;
28
+ var _o = destructObj(attributes), wrapperAttr = _o.wrapper, textAttr = _o.text, circleAttr = _o.circle, squareAttr = _o.square, tableAttr = _o.table, listAttr = _o.list, spinnerWrapperAttr = _o.spinnerWrapper, textWrapperAttr = _o.textWrapper;
29
+ function renderText() {
30
+ return (React.createElement("div", __assign({ className: clsx(baseAnimationClass, textWrapperClass) }, textWrapperAttr),
31
+ React.createElement(Component, __assign({ className: clsx("placeholder rounded col-".concat(xs), textClass), style: commonStyle }, textAttr))));
32
+ }
33
+ function renderCircle() {
34
+ var _a;
35
+ return (React.createElement("div", { className: baseAnimationClass },
36
+ React.createElement(Component, __assign({ className: clsx('placeholder rounded-circle', circleClass), style: {
37
+ width: width !== null && width !== void 0 ? width : 40,
38
+ height: (_a = computedHeight !== null && computedHeight !== void 0 ? computedHeight : width) !== null && _a !== void 0 ? _a : 40,
39
+ } }, circleAttr))));
40
+ }
41
+ function renderSquare() {
42
+ return (React.createElement("div", { className: baseAnimationClass },
43
+ React.createElement(Component, __assign({ className: clsx('placeholder rounded', squareClass), style: commonStyle }, squareAttr))));
44
+ }
45
+ function renderTable() {
46
+ return (React.createElement("div", __assign({ className: clsx(tableClass) }, tableAttr), Array.from({ length: rows }).map(function (_, rowIndex) { return (React.createElement("div", { key: rowIndex, className: 'd-flex gap-50 mb-2' }, Array.from({ length: cols }).map(function (_, colIndex) { return (React.createElement(Component, { key: colIndex, className: 'placeholder rounded col mb-10', style: { height: computedHeight !== null && computedHeight !== void 0 ? computedHeight : 16 } })); }))); })));
47
+ }
48
+ function renderList() {
49
+ return (React.createElement("div", __assign({ className: clsx(listClass) }, listAttr), Array.from({ length: rows }).map(function (_, index) {
50
+ var _a;
51
+ return (React.createElement("div", { key: index, className: 'd-flex align-items-center gap-3 mb-2' },
52
+ React.createElement(Component, __assign({ className: clsx('placeholder rounded-circle flex-shrink-0', circleClass), style: {
53
+ width: width !== null && width !== void 0 ? width : 40,
54
+ height: (_a = computedHeight !== null && computedHeight !== void 0 ? computedHeight : width) !== null && _a !== void 0 ? _a : 40,
55
+ } }, circleAttr)),
56
+ React.createElement(Component, { className: 'placeholder rounded col-12', style: { height: computedHeight !== null && computedHeight !== void 0 ? computedHeight : 16 } })));
57
+ })));
58
+ }
59
+ function renderSpinner() {
60
+ return (React.createElement("div", __assign({ className: clsx(spinnerWrapperClass) }, spinnerWrapperAttr),
61
+ React.createElement(Spinner, __assign({ animation: 'border' }, spinnerProps))));
62
+ }
63
+ var renderMap = {
64
+ text: renderText,
65
+ circle: renderCircle,
66
+ square: renderSquare,
67
+ table: renderTable,
68
+ list: renderList,
69
+ spinner: renderSpinner,
70
+ };
71
+ return (React.createElement("div", __assign({ className: clsx(wrapperClass) }, wrapperAttr), renderMap[variant]()));
72
+ }
73
+ export default SkeletonLoader;
74
+ //# sourceMappingURL=SkeletonLoader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SkeletonLoader.js","sourceRoot":"","sources":["../../../src/components/SkeletonLoader.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,74 @@
1
+ /**
2
+ * -----------------------------------------------------------------------------
3
+ * @component SlickSlider
4
+ * -----------------------------------------------------------------------------
5
+ *
6
+ * @description A highly customizable and reusable React slider/carousel component.
7
+ * Supports autoplay, looping, center mode, custom navigation buttons,
8
+ * slide indicators, and flexible rendering through render props.
9
+ *
10
+ * Features:
11
+ * - Configurable slide animation (speed, easing)
12
+ * - Autoplay support with interval and pause-on-hover options
13
+ * - Looping with seamless slide cloning
14
+ * - Center mode with active slide highlighting
15
+ * - Custom next/previous navigation buttons
16
+ * - Optional slide indicators (dots)
17
+ * - Custom slide rendering via render props
18
+ * - Click handling for individual slides
19
+ *
20
+ * Note: tjs-slick-slider this class only added for sample
21
+ * -----------------------------------------------------------------------------
22
+ * Copyright © 2025 BookingKoala. All rights reserved.
23
+ * -----------------------------------------------------------------------------
24
+ */
25
+ import { type MouseEvent, type ReactElement } from 'react';
26
+ import { SlickSliderConfig } from './useSliderBreakpoint';
27
+ export interface SlickSliderDataProps {
28
+ id: number;
29
+ label: string;
30
+ url: string;
31
+ }
32
+ export interface SlickSliderAutoPlayConfig {
33
+ enable?: boolean;
34
+ interval?: number;
35
+ pauseOnHover?: boolean;
36
+ }
37
+ export interface SlickSliderAnimationConfig {
38
+ easing?: string;
39
+ speed?: number;
40
+ }
41
+ export interface SlickSliderProps {
42
+ activeSlide?: number;
43
+ animationConfig?: SlickSliderAnimationConfig;
44
+ autoPlayConfig?: SlickSliderAutoPlayConfig;
45
+ breakpoints?: SlickSliderConfig[];
46
+ btnsLabel?: {
47
+ next?: string;
48
+ prev?: string;
49
+ };
50
+ data: SlickSliderDataProps[];
51
+ draggable?: {
52
+ dragThreshold?: number;
53
+ enableDrag?: boolean;
54
+ };
55
+ gap?: number;
56
+ icons?: {
57
+ activeDot?: string;
58
+ dots?: string;
59
+ next?: string;
60
+ prev?: string;
61
+ };
62
+ loop?: boolean;
63
+ onSlideClick?: (item: SlickSliderDataProps, index: number, event: MouseEvent<HTMLButtonElement>) => void;
64
+ renderNextBtn?: (handleNextSlide: () => void, hasNextBtnDisabled: () => boolean) => ReactElement;
65
+ renderPrevBtn?: (handlePrevSlide: () => void, hasPrevBtnDisabled: () => boolean) => ReactElement;
66
+ renderSlide?: (slideItem: SlickSliderDataProps, index?: number) => null | ReactElement;
67
+ showCtrlBtns?: boolean;
68
+ showIndicator?: boolean;
69
+ slideToScroll?: number;
70
+ slideToShow?: number;
71
+ variant?: 'horizontal' | 'vertical';
72
+ }
73
+ declare function SlickSlider({ activeSlide, animationConfig, autoPlayConfig, breakpoints, btnsLabel, data, draggable, gap, icons, loop, onSlideClick, renderNextBtn, renderPrevBtn, renderSlide, showCtrlBtns, showIndicator, slideToScroll, slideToShow, variant, }: Readonly<SlickSliderProps>): ReactElement;
74
+ export default SlickSlider;
@@ -0,0 +1,208 @@
1
+ /**
2
+ * -----------------------------------------------------------------------------
3
+ * @component SlickSlider
4
+ * -----------------------------------------------------------------------------
5
+ *
6
+ * @description A highly customizable and reusable React slider/carousel component.
7
+ * Supports autoplay, looping, center mode, custom navigation buttons,
8
+ * slide indicators, and flexible rendering through render props.
9
+ *
10
+ * Features:
11
+ * - Configurable slide animation (speed, easing)
12
+ * - Autoplay support with interval and pause-on-hover options
13
+ * - Looping with seamless slide cloning
14
+ * - Center mode with active slide highlighting
15
+ * - Custom next/previous navigation buttons
16
+ * - Optional slide indicators (dots)
17
+ * - Custom slide rendering via render props
18
+ * - Click handling for individual slides
19
+ *
20
+ * Note: tjs-slick-slider this class only added for sample
21
+ * -----------------------------------------------------------------------------
22
+ * Copyright © 2025 BookingKoala. All rights reserved.
23
+ * -----------------------------------------------------------------------------
24
+ */
25
+ import React, { useMemo } from 'react';
26
+ import { clsx } from 'clsx';
27
+ import Button from '../Button';
28
+ import { useLocalStorage } from '../../hooks';
29
+ import { createDynamicArray, destructObj, getArrayLength, getKeyString, isArrayEmpty, isNullOrUndefined, } from '../../helpers';
30
+ import { EMPTY_ARRAY, EMPTY_OBJECT } from '../../constants/app';
31
+ import ICONS from '../../constants/icons';
32
+ import useSlider from './useSlider';
33
+ // Destruct icons
34
+ var angleLeft = ICONS.angleLeft, angleRight = ICONS.angleRight, circle = ICONS.circle, dotCircle = ICONS.dotCircle;
35
+ // Default props value
36
+ var defAutoPlayConfig = {
37
+ enable: false,
38
+ interval: 2000,
39
+ pauseOnHover: false,
40
+ };
41
+ var defAnimationConfig = {
42
+ easing: 'ease',
43
+ speed: 500,
44
+ };
45
+ var defaultDraggable = {
46
+ dragThreshold: 200,
47
+ enableDrag: true,
48
+ };
49
+ function SlickSlider(_a) {
50
+ var _b = _a.activeSlide, activeSlide = _b === void 0 ? 1 : _b, _c = _a.animationConfig, animationConfig = _c === void 0 ? defAnimationConfig : _c, _d = _a.autoPlayConfig, autoPlayConfig = _d === void 0 ? defAutoPlayConfig : _d, _e = _a.breakpoints, breakpoints = _e === void 0 ? EMPTY_ARRAY : _e, _f = _a.btnsLabel, btnsLabel = _f === void 0 ? EMPTY_OBJECT : _f, data = _a.data, _g = _a.draggable, draggable = _g === void 0 ? defaultDraggable : _g, _h = _a.gap, gap = _h === void 0 ? 20 : _h, _j = _a.icons, icons = _j === void 0 ? EMPTY_OBJECT : _j, _k = _a.loop, loop = _k === void 0 ? false : _k, _l = _a.onSlideClick, onSlideClick = _l === void 0 ? undefined : _l, _m = _a.renderNextBtn, renderNextBtn = _m === void 0 ? undefined : _m, _o = _a.renderPrevBtn, renderPrevBtn = _o === void 0 ? undefined : _o, _p = _a.renderSlide, renderSlide = _p === void 0 ? undefined : _p, _q = _a.showCtrlBtns, showCtrlBtns = _q === void 0 ? true : _q, _r = _a.showIndicator, showIndicator = _r === void 0 ? true : _r, _s = _a.slideToScroll, slideToScroll = _s === void 0 ? 1 : _s, _t = _a.slideToShow, slideToShow = _t === void 0 ? 1 : _t, _u = _a.variant, variant = _u === void 0 ? 'horizontal' : _u;
51
+ // Constants
52
+ var hasUseExtendedSlides = getArrayLength(data) > slideToShow;
53
+ var isRTL = useLocalStorage('tjsReactRTL')[0];
54
+ var isRTLMode = isRTL !== null && isRTL !== void 0 ? isRTL : false;
55
+ var nextBtnIconPrimary = isRTLMode ? angleLeft : angleRight;
56
+ var prevBtnIconPrimary = isRTLMode ? angleRight : angleLeft;
57
+ // Destruct props
58
+ var _v = destructObj(icons), _w = _v.activeDot, activeDot = _w === void 0 ? dotCircle : _w, _x = _v.dots, dots = _x === void 0 ? circle : _x, _y = _v.next, nextBtnIcon = _y === void 0 ? nextBtnIconPrimary : _y, _z = _v.prev, prevBtnIcon = _z === void 0 ? prevBtnIconPrimary : _z;
59
+ var _0 = destructObj(btnsLabel), _1 = _0.next, nextBtnLabel = _1 === void 0 ? '' : _1, _2 = _0.prev, prevBtnLabel = _2 === void 0 ? '' : _2;
60
+ // Hooks
61
+ var _3 = useSlider({
62
+ activeSlide: activeSlide - 1,
63
+ animationConfig: animationConfig,
64
+ autoPlayConfig: autoPlayConfig,
65
+ breakpoints: breakpoints,
66
+ draggable: draggable,
67
+ gap: gap,
68
+ isRTLMode: isRTLMode,
69
+ loop: loop,
70
+ slideToScroll: slideToScroll,
71
+ slideToShow: slideToShow,
72
+ totalSlides: getArrayLength(data),
73
+ variant: variant,
74
+ }), getActiveIndicatorIndex = _3.getActiveIndicatorIndex, getIndicatorCount = _3.getIndicatorCount, goToSlideIndicator = _3.goToSlideIndicator, handleNextSlide = _3.handleNextSlide, handlePrevSlide = _3.handlePrevSlide, hasNextBtnDisabled = _3.hasNextBtnDisabled, hasPrevBtnDisabled = _3.hasPrevBtnDisabled, sliderWrapperRef = _3.sliderWrapperRef;
75
+ var renderSlideItem = isNullOrUndefined(renderSlide)
76
+ ? renderDefSlide
77
+ : function (item, index) {
78
+ var result = renderSlide(item, index);
79
+ return result !== null && result !== void 0 ? result : renderDefSlide(item);
80
+ };
81
+ function renderDefSlide(item) {
82
+ return (React.createElement("div", { className: 'w-100 p-6 bg-primary' },
83
+ React.createElement("p", { className: 'fs-40' }, item.label)));
84
+ }
85
+ /**
86
+ * This helper function render the button based on the different label and custom icons.
87
+ * @param param0 takes a common property of btn
88
+ */
89
+ function renderNavBtn(_a) {
90
+ var disabled = _a.disabled, icon = _a.icon, label = _a.label, onClick = _a.onClick;
91
+ return (React.createElement(Button, { disabled: disabled, icon: icon, label: label, variant: 'ghost', classnames: { button: 'fs-16 p-5 px-10' }, onClick: onClick }));
92
+ }
93
+ function renderDefPrevBtn() {
94
+ return renderNavBtn({
95
+ disabled: hasPrevBtnDisabled(),
96
+ icon: prevBtnIcon,
97
+ label: prevBtnLabel,
98
+ onClick: handlePrevSlide,
99
+ });
100
+ }
101
+ /**
102
+ * Determines which previous button to render based on whether a custom renderPrevBtn prop is provided.
103
+ * Falls back to the default previous button if no custom renderer is specified.
104
+ */
105
+ function prevButtonElem() {
106
+ if (isNullOrUndefined(renderPrevBtn)) {
107
+ return renderDefPrevBtn();
108
+ }
109
+ var result = renderPrevBtn(handlePrevSlide, hasPrevBtnDisabled);
110
+ return result !== null && result !== void 0 ? result : renderDefPrevBtn();
111
+ }
112
+ /**
113
+ * Creates an extended slides array to support seamless looping.
114
+ *
115
+ * - Prepends the last `slideToShow` slides to allow backward looping
116
+ * - Appends the full slides array to allow forward looping
117
+ * - Results in a continuous sequence that prevents visual gaps
118
+ * when transitioning across boundaries
119
+ *
120
+ * Example:
121
+ * data = [A, B, C, D]
122
+ * extendedSlides = [D, A, B, C, D, A, B, C, D] slideToShow = 1
123
+ * extendedSlides = [C,D, A, B, C, D, A, B, C, D] slideToShow = 2
124
+ */
125
+ var extendedSlides = useMemo(function () { return [data.slice(-slideToShow), data, data].flat(); }, [data, slideToShow]);
126
+ /**
127
+ * Creates a click handler for a slide item.
128
+ * Returns a function that invokes the onSlideClick callback with the item data.
129
+ * @param item - The slide data item
130
+ */
131
+ function onSlideClickHandler(item, index) {
132
+ return function () {
133
+ onSlideClick === null || onSlideClick === void 0 ? void 0 : onSlideClick(item, index, {});
134
+ };
135
+ }
136
+ /**
137
+ * Renders all slide items in the slider.
138
+ * Uses extended slides array for looping mode, otherwise uses the original data array.
139
+ * Each slide is wrapped in a button that handles click events.
140
+ */
141
+ function renderSlides() {
142
+ if (isArrayEmpty(data))
143
+ return null;
144
+ var sliderArray = hasUseExtendedSlides ? extendedSlides : data;
145
+ return (React.createElement("div", { ref: sliderWrapperRef, className: 'd-flex' }, sliderArray === null || sliderArray === void 0 ? void 0 : sliderArray.map(function (item, index) { return (React.createElement(Button, { variant: 'ghost', key: getKeyString('slide', index), attributes: {
146
+ button: {
147
+ id: getKeyString('slide', index + 1),
148
+ 'data-index': index,
149
+ },
150
+ }, classnames: {
151
+ button: clsx('p-0 rounded-100 bg-transparent', variant === 'vertical' && 'vertical'),
152
+ }, onClick: onSlideClickHandler(item, index) }, renderSlideItem(item))); })));
153
+ }
154
+ function renderDefNextBtn() {
155
+ return renderNavBtn({
156
+ disabled: hasNextBtnDisabled(),
157
+ icon: nextBtnIcon,
158
+ label: nextBtnLabel,
159
+ onClick: handleNextSlide,
160
+ });
161
+ }
162
+ /**
163
+ * Determines which next button to render based on whether a custom renderNextBtn prop is provided.
164
+ * Falls back to the default next button if no custom renderer is specified.
165
+ */
166
+ function nextButtonElem() {
167
+ if (isNullOrUndefined(renderNextBtn)) {
168
+ return renderDefNextBtn();
169
+ }
170
+ var result = renderNextBtn(handleNextSlide, hasNextBtnDisabled);
171
+ return result !== null && result !== void 0 ? result : renderDefNextBtn();
172
+ }
173
+ /** This callback function handle the indicator click event and call the go to indicator. */
174
+ function handleIndicatorEvent(idx) {
175
+ return function () {
176
+ goToSlideIndicator(idx);
177
+ };
178
+ }
179
+ /**
180
+ * Function is render the indicator item and add the active indicator icons based active slide index.
181
+ * @param index index of the indicator items.
182
+ */
183
+ function renderIndicator(index) {
184
+ if (!hasUseExtendedSlides)
185
+ return undefined;
186
+ var isActive = index === getActiveIndicatorIndex();
187
+ var indicatorIcon = isActive ? activeDot : dots;
188
+ return (React.createElement(Button, { key: getKeyString('ctrl-dot', index), icon: indicatorIcon, variant: 'ghost', onClick: handleIndicatorEvent(index), classnames: { button: 'fs-16' } }));
189
+ }
190
+ /**
191
+ * Function responsible for render the indication icons based on the indicator count.
192
+ * create dynamic array based on the number for indicators.
193
+ */
194
+ function renderIndicators() {
195
+ var numberOfIndictor = getIndicatorCount();
196
+ if (isNullOrUndefined(numberOfIndictor))
197
+ return undefined;
198
+ return (React.createElement("div", { className: 'd-flex justify-content-center gap-10' }, createDynamicArray(numberOfIndictor).map(function (_, index) { return renderIndicator(index); })));
199
+ }
200
+ return (React.createElement("div", { className: 'tjs-slick-slider' },
201
+ React.createElement("div", { className: 'd-flex align-items-center justify-content-between mb-10' },
202
+ showCtrlBtns ? prevButtonElem() : null,
203
+ React.createElement("div", { className: 'overflow-hidden w-100' }, renderSlides()),
204
+ showCtrlBtns ? nextButtonElem() : null),
205
+ showIndicator ? renderIndicators() : null));
206
+ }
207
+ export default SlickSlider;
208
+ //# sourceMappingURL=SlickSlider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SlickSlider.js","sourceRoot":"","sources":["../../../../src/components/Slider/SlickSlider.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * -----------------------------------------------------------------------------
3
+ * @file useCenterMode
4
+ * -----------------------------------------------------------------------------
5
+ *
6
+ * @description Utility file - add description here
7
+ *
8
+ * Features:
9
+ * - Add key features here
10
+ *
11
+ * -----------------------------------------------------------------------------
12
+ * Copyright © 2026 BookingKoala. All rights reserved.
13
+ * -----------------------------------------------------------------------------
14
+ */
15
+ interface UseCenterMode {
16
+ activeSlideIndex?: number;
17
+ slideToShow: number;
18
+ }
19
+ declare function useCenterMode({ activeSlideIndex, slideToShow }: UseCenterMode): number[];
20
+ export default useCenterMode;
21
+ /**
22
+ * Returns active slide indexes based on slideToShow and active indicator
23
+ * Works only when slideToShow is odd
24
+ */
@@ -0,0 +1,38 @@
1
+ function useCenterMode(_a) {
2
+ var _b = _a.activeSlideIndex, activeSlideIndex = _b === void 0 ? 0 : _b, slideToShow = _a.slideToShow;
3
+ var centerOffset = Math.floor(slideToShow / 2);
4
+ var centerIndex = slideToShow + activeSlideIndex + centerOffset;
5
+ // even slideToShow → two active slides
6
+ if (slideToShow === 1 || slideToShow === 2)
7
+ return [];
8
+ if (slideToShow % 2 === 0) {
9
+ return [centerIndex - 1, centerIndex];
10
+ }
11
+ // odd slideToShow
12
+ if (slideToShow === 3) {
13
+ return [centerIndex];
14
+ }
15
+ return [centerIndex - 1, centerIndex, centerIndex + 1];
16
+ }
17
+ export default useCenterMode;
18
+ /**
19
+ * Returns active slide indexes based on slideToShow and active indicator
20
+ * Works only when slideToShow is odd
21
+ */
22
+ // function getActiveSlideIndexes(): number[] {
23
+ // const activeSlideIndex = getActiveIndicatorIndex();
24
+ // if (isNullOrUndefined(activeSlideIndex)) return [];
25
+ // const centerOffset = Math.floor(slideToShow / 2);
26
+ // const centerIndex = slideToShow + activeSlideIndex + centerOffset;
27
+ // // even slideToShow → two active slides
28
+ // if (slideToShow === 1 || slideToShow === 2) return [];
29
+ // if (slideToShow % 2 === 0) {
30
+ // return [centerIndex - 1, centerIndex];
31
+ // }
32
+ // // odd slideToShow
33
+ // if (slideToShow === 3) {
34
+ // return [centerIndex];
35
+ // }
36
+ // return [centerIndex - 1, centerIndex, centerIndex + 1];
37
+ // }
38
+ //# sourceMappingURL=useCenterMode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCenterMode.js","sourceRoot":"","sources":["../../../../src/components/Slider/useCenterMode.ts"],"names":[],"mappings":"AAkBA,SAAS,aAAa,CAAC,EAAoD;QAAlD,wBAAoB,EAApB,gBAAgB,mBAAG,CAAC,KAAA,EAAE,WAAW,iBAAA;IACxD,IAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,CAAC,CAAC,CAAA;IAChD,IAAM,WAAW,GAAG,WAAW,GAAG,gBAAgB,GAAG,YAAY,CAAA;IACjE,uCAAuC;IACvC,IAAI,WAAW,KAAK,CAAC,IAAI,WAAW,KAAK,CAAC;QAAE,OAAO,EAAE,CAAA;IACrD,IAAI,WAAW,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,CAAC,WAAW,GAAG,CAAC,EAAE,WAAW,CAAC,CAAA;IACvC,CAAC;IAED,kBAAkB;IAClB,IAAI,WAAW,KAAK,CAAC,EAAE,CAAC;QACtB,OAAO,CAAC,WAAW,CAAC,CAAA;IACtB,CAAC;IACD,OAAO,CAAC,WAAW,GAAG,CAAC,EAAE,WAAW,EAAE,WAAW,GAAG,CAAC,CAAC,CAAA;AACxD,CAAC;AACD,eAAe,aAAa,CAAA;AAC5B;;;GAGG;AACH,+CAA+C;AAC/C,uDAAuD;AACvD,uDAAuD;AAEvD,qDAAqD;AACrD,sEAAsE;AACtE,2CAA2C;AAC3C,0DAA0D;AAC1D,gCAAgC;AAChC,2CAA2C;AAC3C,KAAK;AAEL,sBAAsB;AACtB,4BAA4B;AAC5B,0BAA0B;AAC1B,KAAK;AACL,2DAA2D;AAC3D,IAAI"}
@@ -0,0 +1,65 @@
1
+ /**
2
+ * -----------------------------------------------------------------------------
3
+ * @file useSlider
4
+ * -----------------------------------------------------------------------------
5
+ *
6
+ * @description
7
+ * Main hook that controls all slider behavior.
8
+ *
9
+ * This hook connects multiple smaller slider hooks and makes them work
10
+ * together. It handles slide size calculation, navigation, animations,
11
+ * autoplay, draggable interactions, breakpoint-based configuration,
12
+ * and window resize updates.
13
+ *
14
+ * The UI layer only needs to use the values and functions returned from
15
+ * this hook.
16
+ *
17
+ * -----------------------------------------------------------------------------
18
+ * Copyright © 2025 BookingKoala. All rights reserved.
19
+ * -----------------------------------------------------------------------------
20
+ */
21
+ import { type Ref } from 'react';
22
+ import { type SlickSliderAnimationConfig, type SlickSliderAutoPlayConfig } from './SlickSlider';
23
+ import { SlickSliderConfig } from './useSliderBreakpoint';
24
+ export interface UseSlickSliderReturn {
25
+ getActiveIndicatorIndex: () => number | undefined;
26
+ getIndicatorCount: () => number | undefined;
27
+ goToSlideIndicator: (index: number) => void;
28
+ handleNextSlide: () => void;
29
+ handlePrevSlide: () => void;
30
+ hasNextBtnDisabled: () => boolean;
31
+ hasPrevBtnDisabled: () => boolean;
32
+ sliderWrapperRef: Ref<HTMLDivElement>;
33
+ }
34
+ export interface UseSlickSliderProps {
35
+ activeSlide: number;
36
+ animationConfig: SlickSliderAnimationConfig;
37
+ autoPlayConfig: SlickSliderAutoPlayConfig;
38
+ breakpoints: SlickSliderConfig[];
39
+ draggable?: {
40
+ dragThreshold?: number;
41
+ enableDrag?: boolean;
42
+ };
43
+ gap: number;
44
+ isRTLMode: boolean;
45
+ loop: boolean;
46
+ slideToScroll: number;
47
+ slideToShow: number;
48
+ totalSlides: number;
49
+ variant: 'horizontal' | 'vertical';
50
+ }
51
+ export interface SlickSliderRefs {
52
+ containerHeight: number;
53
+ containerWidth: number;
54
+ currentIndex: number;
55
+ drag: {
56
+ isDragging: boolean;
57
+ startX: number;
58
+ startY: number;
59
+ translate: number;
60
+ };
61
+ isTransitionComplete: boolean;
62
+ totalSlides: number;
63
+ }
64
+ declare function useSlider({ activeSlide, animationConfig, autoPlayConfig, breakpoints, draggable, gap, isRTLMode, loop, slideToScroll, slideToShow, totalSlides, variant, }: Readonly<UseSlickSliderProps>): UseSlickSliderReturn;
65
+ export default useSlider;