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,41 @@
1
+ import { __assign, __rest } from "tslib";
2
+ /**
3
+ * -----------------------------------------------------------------------------
4
+ * @file ToggleButton
5
+ * -----------------------------------------------------------------------------
6
+ *
7
+ * @description A custom radio-style toggle button built using React-Bootstrap.
8
+ * This component renders:
9
+ * - A hidden radio input (`Form.Control` with `btn-check` class)
10
+ * - A styled label acting as the visible button
11
+ * - An optional description below the button
12
+ * It is designed to work inside `ToggleButtonGroup` and behaves as a
13
+ * controlled/uncontrolled radio button depending on the props passed.
14
+ *
15
+ * @features
16
+ * - Uses `defaultChecked` to set initial selection state
17
+ * - Triggers `onChange` when selected
18
+ * - Applies Bootstrap button variants dynamically
19
+ * - Supports disabled state
20
+ * - Optionally renders helper/description text
21
+ *
22
+ * -----------------------------------------------------------------------------
23
+ * Copyright © 2017-present BookingKoala. All rights reserved.
24
+ * -----------------------------------------------------------------------------
25
+ */
26
+ import React from 'react';
27
+ import { clsx } from 'clsx';
28
+ import { Form } from 'react-bootstrap';
29
+ import FormText from 'react-bootstrap/FormText';
30
+ import { destructObj, isStrNotEmpty } from '../../helpers';
31
+ function ToggleButton(_a) {
32
+ var _b = _a.checked, checked = _b === void 0 ? false : _b, _c = _a.children, children = _c === void 0 ? undefined : _c, _d = _a.className, className = _d === void 0 ? undefined : _d, _e = _a.descProps, descProps = _e === void 0 ? undefined : _e, _f = _a.disabled, disabled = _f === void 0 ? false : _f, _g = _a.id, id = _g === void 0 ? undefined : _g, _h = _a.isSpaced, isSpaced = _h === void 0 ? false : _h, _j = _a.name, name = _j === void 0 ? undefined : _j, _k = _a.onChange, onChange = _k === void 0 ? undefined : _k, value = _a.value, _l = _a.variant, variant = _l === void 0 ? 'outline-light' : _l, rest = __rest(_a, ["checked", "children", "className", "descProps", "disabled", "id", "isSpaced", "name", "onChange", "value", "variant"]);
33
+ // Destruct object
34
+ var _m = destructObj(descProps), descClass = _m.className, descContent = _m.description;
35
+ return (React.createElement("div", { className: clsx(!isSpaced && 'tjs-toggle-btn-group') },
36
+ React.createElement(Form.Control, { type: 'radio', id: id, name: name, value: value, defaultChecked: checked !== null && checked !== void 0 ? checked : false, disabled: disabled, onChange: onChange, className: 'btn-check' }),
37
+ React.createElement(Form.Label, __assign({ htmlFor: id, className: clsx('btn mb-0 w-100', "btn-".concat(variant), disabled && 'disabled', className) }, rest), children),
38
+ isStrNotEmpty(descContent) ? (React.createElement(FormText, { className: clsx('fs-12 mt-0 text-center d-block', descClass) }, descContent)) : null));
39
+ }
40
+ export default ToggleButton;
41
+ //# sourceMappingURL=ToggleBtn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToggleBtn.js","sourceRoot":"","sources":["../../../../src/subComponent/toggleBtnGroup/ToggleBtn.tsx"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,OAAO,KAA8D,MAAM,OAAO,CAAA;AAClF,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAA;AAC3B,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAA;AACtC,OAAO,QAAQ,MAAM,0BAA0B,CAAA;AAC/C,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,eAAe,CAAA;AAmB1D,SAAS,YAAY,CAAC,EAaQ;IAZ5B,IAAA,eAAe,EAAf,OAAO,mBAAG,KAAK,KAAA,EACf,gBAAoB,EAApB,QAAQ,mBAAG,SAAS,KAAA,EACpB,iBAAqB,EAArB,SAAS,mBAAG,SAAS,KAAA,EACrB,iBAAqB,EAArB,SAAS,mBAAG,SAAS,KAAA,EACrB,gBAAgB,EAAhB,QAAQ,mBAAG,KAAK,KAAA,EAChB,UAAc,EAAd,EAAE,mBAAG,SAAS,KAAA,EACd,gBAAgB,EAAhB,QAAQ,mBAAG,KAAK,KAAA,EAChB,YAAgB,EAAhB,IAAI,mBAAG,SAAS,KAAA,EAChB,gBAAoB,EAApB,QAAQ,mBAAG,SAAS,KAAA,EACpB,KAAK,WAAA,EACL,eAAyB,EAAzB,OAAO,mBAAG,eAAe,KAAA,EACtB,IAAI,cAZa,uHAarB,CADQ;IAEP,kBAAkB;IACZ,IAAA,KAAqD,WAAW,CAAC,SAAS,CAAC,EAA9D,SAAS,eAAA,EAAe,WAAW,iBAA2B,CAAA;IAEjF,OAAO,CACL,6BAAK,SAAS,EAAE,IAAI,CAAC,CAAC,QAAQ,IAAI,sBAAsB,CAAC;QACvD,oBAAC,IAAI,CAAC,OAAO,IACX,IAAI,EAAC,OAAO,EACZ,EAAE,EAAE,EAAE,EACN,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAe,EACtB,cAAc,EAAE,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,KAAK,EAChC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAC,WAAW,GACrB;QACF,oBAAC,IAAI,CAAC,KAAK,aACT,OAAO,EAAE,EAAE,EACX,SAAS,EAAE,IAAI,CAAC,gBAAgB,EAAE,cAAO,OAAO,CAAE,EAAE,QAAQ,IAAI,UAAU,EAAE,SAAS,CAAC,IAClF,IAAI,GAEP,QAAQ,CACE;QACZ,aAAa,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAC5B,oBAAC,QAAQ,IAAC,SAAS,EAAE,IAAI,CAAC,gCAAgC,EAAE,SAAS,CAAC,IAAG,WAAW,CAAY,CACjG,CAAC,CAAC,CAAC,IAAI,CACJ,CACP,CAAA;AACH,CAAC;AAED,eAAe,YAAY,CAAA"}
@@ -0,0 +1,43 @@
1
+ /**
2
+ * -----------------------------------------------------------------------------
3
+ * @component ToggleButtonGroup
4
+ * -----------------------------------------------------------------------------
5
+ *
6
+ * @description
7
+ * A controlled wrapper component around React-Bootstrap's `ButtonGroup`
8
+ * that manages a group of toggle able buttons (radio-like behavior).
9
+ *
10
+ * This component automatically:
11
+ * - Clones its children and injects `checked`, `name`, and `onChange` props
12
+ * - Synchronizes the active (checked) state based on the provided `value`
13
+ * - Ensures only one toggle button is selected at a time
14
+ * - Supports both horizontal and vertical layouts
15
+ *
16
+ * It is designed to work with custom ToggleButton components that accept:
17
+ * `value`, `checked`, `name`, and `onChange` props.
18
+ *
19
+ * @features
20
+ * - Controlled component behavior via `value` prop
21
+ * - Automatic child prop injection using `cloneElement`
22
+ * - Optimized re-rendering using `useMemo`
23
+ * - Supports `size` variations ('sm' | 'lg')
24
+ * - Optional vertical layout
25
+ * - Fully compatible with React-Bootstrap ButtonGroup
26
+ *
27
+ * -----------------------------------------------------------------------------
28
+ * Copyright © 2017-present BookingKoala. All rights reserved.
29
+ * -----------------------------------------------------------------------------
30
+ */
31
+ import { type ChangeEvent, type ReactNode, type ReactElement, type CSSProperties } from 'react';
32
+ export interface ToggleButtonGroupProps {
33
+ children?: ReactNode;
34
+ className?: string;
35
+ name?: string;
36
+ onChange?: (event: ChangeEvent<HTMLInputElement>) => void;
37
+ size?: 'lg' | 'sm';
38
+ style?: CSSProperties;
39
+ value?: number | string;
40
+ vertical?: boolean;
41
+ }
42
+ declare function ToggleButtonGroup({ children, className, name, onChange, size, style, value, vertical, ...rest }: Readonly<ToggleButtonGroupProps>): ReactElement;
43
+ export default ToggleButtonGroup;
@@ -0,0 +1,51 @@
1
+ import { __assign, __rest } from "tslib";
2
+ /**
3
+ * -----------------------------------------------------------------------------
4
+ * @component ToggleButtonGroup
5
+ * -----------------------------------------------------------------------------
6
+ *
7
+ * @description
8
+ * A controlled wrapper component around React-Bootstrap's `ButtonGroup`
9
+ * that manages a group of toggle able buttons (radio-like behavior).
10
+ *
11
+ * This component automatically:
12
+ * - Clones its children and injects `checked`, `name`, and `onChange` props
13
+ * - Synchronizes the active (checked) state based on the provided `value`
14
+ * - Ensures only one toggle button is selected at a time
15
+ * - Supports both horizontal and vertical layouts
16
+ *
17
+ * It is designed to work with custom ToggleButton components that accept:
18
+ * `value`, `checked`, `name`, and `onChange` props.
19
+ *
20
+ * @features
21
+ * - Controlled component behavior via `value` prop
22
+ * - Automatic child prop injection using `cloneElement`
23
+ * - Optimized re-rendering using `useMemo`
24
+ * - Supports `size` variations ('sm' | 'lg')
25
+ * - Optional vertical layout
26
+ * - Fully compatible with React-Bootstrap ButtonGroup
27
+ *
28
+ * -----------------------------------------------------------------------------
29
+ * Copyright © 2017-present BookingKoala. All rights reserved.
30
+ * -----------------------------------------------------------------------------
31
+ */
32
+ import React, { Children, useMemo, cloneElement, isValidElement, } from 'react';
33
+ import ButtonGroup from 'react-bootstrap/ButtonGroup';
34
+ function ToggleButtonGroup(_a) {
35
+ var _b = _a.children, children = _b === void 0 ? undefined : _b, _c = _a.className, className = _c === void 0 ? undefined : _c, _d = _a.name, name = _d === void 0 ? undefined : _d, _e = _a.onChange, onChange = _e === void 0 ? undefined : _e, _f = _a.size, size = _f === void 0 ? undefined : _f, _g = _a.style, style = _g === void 0 ? undefined : _g, _h = _a.value, value = _h === void 0 ? '' : _h, _j = _a.vertical, vertical = _j === void 0 ? false : _j, rest = __rest(_a, ["children", "className", "name", "onChange", "size", "style", "value", "vertical"]);
36
+ var clonedChildren = useMemo(function () {
37
+ return Children === null || Children === void 0 ? void 0 : Children.map(children, function (child) {
38
+ if (!isValidElement(child))
39
+ return child;
40
+ var childrenProps = child === null || child === void 0 ? void 0 : child.props;
41
+ return cloneElement(child, {
42
+ checked: (childrenProps === null || childrenProps === void 0 ? void 0 : childrenProps.value) === value,
43
+ name: name,
44
+ onChange: onChange,
45
+ });
46
+ });
47
+ }, [children, value, name, onChange]);
48
+ return (React.createElement(ButtonGroup, __assign({ vertical: vertical, size: size, className: className, style: style }, rest), clonedChildren));
49
+ }
50
+ export default ToggleButtonGroup;
51
+ //# sourceMappingURL=ToggleBtnGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToggleBtnGroup.js","sourceRoot":"","sources":["../../../../src/subComponent/toggleBtnGroup/ToggleBtnGroup.tsx"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,OAAO,KAAK,EAAE,EAKZ,QAAQ,EACR,OAAO,EACP,YAAY,EACZ,cAAc,GACf,MAAM,OAAO,CAAA;AACd,OAAO,WAAW,MAAM,6BAA6B,CAAA;AAoBrD,SAAS,iBAAiB,CAAC,EAUQ;IATjC,IAAA,gBAAoB,EAApB,QAAQ,mBAAG,SAAS,KAAA,EACpB,iBAAqB,EAArB,SAAS,mBAAG,SAAS,KAAA,EACrB,YAAgB,EAAhB,IAAI,mBAAG,SAAS,KAAA,EAChB,gBAAoB,EAApB,QAAQ,mBAAG,SAAS,KAAA,EACpB,YAAgB,EAAhB,IAAI,mBAAG,SAAS,KAAA,EAChB,aAAiB,EAAjB,KAAK,mBAAG,SAAS,KAAA,EACjB,aAAU,EAAV,KAAK,mBAAG,EAAE,KAAA,EACV,gBAAgB,EAAhB,QAAQ,mBAAG,KAAK,KAAA,EACb,IAAI,cATkB,mFAU1B,CADQ;IAEP,IAAM,cAAc,GAAG,OAAO,CAC5B;QACE,OAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,GAAG,CAAC,QAAQ,EAAE,UAAC,KAAK;YAC5B,IAAI,CAAC,cAAc,CAAyB,KAAK,CAAC;gBAAE,OAAO,KAAK,CAAA;YAChE,IAAM,aAAa,GAAG,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,KAAK,CAAA;YAClC,OAAO,YAAY,CAAC,KAAK,EAAE;gBACzB,OAAO,EAAE,CAAA,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,KAAK,MAAK,KAAK;gBACvC,IAAI,MAAA;gBACJ,QAAQ,UAAA;aACT,CAAC,CAAA;QACJ,CAAC,CAAC;IARF,CAQE,EACJ,CAAC,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,CAAC,CAClC,CAAA;IAED,OAAO,CACL,oBAAC,WAAW,aAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,IAAM,IAAI,GACtF,cAAc,CACH,CACf,CAAA;AACH,CAAC;AAED,eAAe,iBAAiB,CAAA"}
package/dist/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "farm-react",
3
- "version": "1.0.7",
3
+ "version": "1.0.9",
4
4
  "description": "",
5
5
  "main": "cjs/index.js",
6
6
  "module": "esm/index.js",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "farm-react",
3
- "version": "1.0.7",
3
+ "version": "1.0.9",
4
4
  "description": "",
5
5
  "main": "dist/cjs/index.js",
6
6
  "module": "dist/esm/index.js",
@@ -8,15 +8,15 @@
8
8
  "scripts": {
9
9
  "prepare": "npm run build",
10
10
  "prepublishOnly": "npm run test && npm run prettier && npm run lint",
11
- "build": "npm run build:esm && npm run build:cjs && npm run build:package-json",
11
+ "build": "npm run build:esm && npm run build:cjs && npm run build:package-json && npm run build:scss",
12
12
  "build:package-json": "node -e \"const fs=require('fs');const pkg=require('./package.json');const distPkg={name:pkg.name,version:pkg.version,description:pkg.description,main:'cjs/index.js',module:'esm/index.js',types:'esm/index.d.ts',peerDependencies:pkg.peerDependencies,author:pkg.author,license:pkg.license};fs.writeFileSync('dist/package.json',JSON.stringify(distPkg,null,2));\"",
13
13
  "build:esm": "tsc",
14
14
  "build:cjs": "tsc --module commonjs --outDir dist/cjs",
15
+ "build:scss": "sass src/assets/styles/style.scss dist/assets/styles/style.css --style=expanded",
15
16
  "test": "jest --config jestconfig.json",
16
- "lint": "eslint \"src/**/*.{js,ts,jsx,tsx}\"",
17
+ "lint": "eslint \"{**/*,*}.{js,ts,jsx,tsx}\"",
17
18
  "prettier": "prettier --write \"{src,tests,example/src}/**/*.{js,ts,jsx,tsx}\""
18
19
  },
19
- "type": "module",
20
20
  "peerDependencies": {
21
21
  "react": ">=18"
22
22
  },
@@ -36,6 +36,7 @@
36
36
  "@testing-library/react": "^16.0.0",
37
37
  "@types/jest": "^29.5.12",
38
38
  "@types/react": "^18.3.3",
39
+ "@types/react-dom": "^19.2.3",
39
40
  "@typescript-eslint/eslint-plugin": "^7.15.0",
40
41
  "@typescript-eslint/parser": "^7.15.0",
41
42
  "eslint-config-prettier": "^9.1.0",
@@ -57,6 +58,7 @@
57
58
  "clsx": "^2.1.1",
58
59
  "eslint": "^9.34.0",
59
60
  "react-bootstrap": "^2.10.10",
61
+ "react-hook-form": "^7.71.2",
60
62
  "react-router": "^7.8.2"
61
63
  }
62
64
  }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/strings/index.ts"],"names":[],"mappings":""}
@@ -1,2 +0,0 @@
1
- "use strict";
2
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/strings/index.ts"],"names":[],"mappings":""}