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.
- package/dist/assets/styles/style.css +25347 -0
- package/dist/assets/styles/style.css.map +1 -0
- package/dist/cjs/Utils/index.d.ts +4 -0
- package/dist/cjs/Utils/index.js +8 -0
- package/dist/cjs/Utils/index.js.map +1 -0
- package/dist/cjs/components/Accordion.js +7 -6
- package/dist/cjs/components/Accordion.js.map +1 -1
- package/dist/cjs/components/Alert.d.ts +32 -0
- package/dist/cjs/components/Alert.js +50 -0
- package/dist/cjs/components/Alert.js.map +1 -0
- package/dist/cjs/components/Badge.d.ts +22 -0
- package/dist/cjs/components/Badge.js +36 -0
- package/dist/cjs/components/Badge.js.map +1 -0
- package/dist/cjs/components/BrokenPage.d.ts +35 -0
- package/dist/cjs/components/BrokenPage.js +59 -0
- package/dist/cjs/components/BrokenPage.js.map +1 -0
- package/dist/cjs/components/Button.d.ts +29 -2
- package/dist/cjs/components/Button.js +56 -4
- package/dist/cjs/components/Button.js.map +1 -1
- package/dist/cjs/components/Card.d.ts +77 -0
- package/dist/cjs/components/Card.js +77 -0
- package/dist/cjs/components/Card.js.map +1 -0
- package/dist/cjs/components/Checkbox.d.ts +25 -0
- package/dist/cjs/components/Checkbox.js +23 -0
- package/dist/cjs/components/Checkbox.js.map +1 -0
- package/dist/cjs/components/ConfirmPoup.d.ts +21 -0
- package/dist/cjs/components/ConfirmPoup.js +47 -0
- package/dist/cjs/components/ConfirmPoup.js.map +1 -0
- package/dist/cjs/components/Dropdown.d.ts +35 -0
- package/dist/cjs/components/Dropdown.js +54 -0
- package/dist/cjs/components/Dropdown.js.map +1 -0
- package/dist/cjs/components/Label.d.ts +1 -1
- package/dist/cjs/components/Label.js +8 -6
- package/dist/cjs/components/Label.js.map +1 -1
- package/dist/cjs/components/Layout/Footer.js +11 -2
- package/dist/cjs/components/Layout/Footer.js.map +1 -1
- package/dist/cjs/components/Layout/Header.d.ts +2 -1
- package/dist/cjs/components/Layout/Header.js +15 -4
- package/dist/cjs/components/Layout/Header.js.map +1 -1
- package/dist/cjs/components/Layout/Sidebar.d.ts +2 -1
- package/dist/cjs/components/Layout/Sidebar.js +5 -3
- package/dist/cjs/components/Layout/Sidebar.js.map +1 -1
- package/dist/cjs/components/MultiCheckbox.d.ts +39 -0
- package/dist/cjs/components/MultiCheckbox.js +56 -0
- package/dist/cjs/components/MultiCheckbox.js.map +1 -0
- package/dist/cjs/components/MultiRadio.d.ts +30 -0
- package/dist/cjs/components/MultiRadio.js +41 -0
- package/dist/cjs/components/MultiRadio.js.map +1 -0
- package/dist/cjs/components/NumberInput.d.ts +38 -0
- package/dist/cjs/components/NumberInput.js +34 -0
- package/dist/cjs/components/NumberInput.js.map +1 -0
- package/dist/cjs/components/Popover.d.ts +56 -0
- package/dist/cjs/components/Popover.js +34 -0
- package/dist/cjs/components/Popover.js.map +1 -0
- package/dist/cjs/components/Radio.d.ts +24 -0
- package/dist/cjs/components/Radio.js +24 -0
- package/dist/cjs/components/Radio.js.map +1 -0
- package/dist/cjs/components/RadioButtonGroup.d.ts +67 -0
- package/dist/cjs/components/RadioButtonGroup.js +141 -0
- package/dist/cjs/components/RadioButtonGroup.js.map +1 -0
- package/dist/cjs/components/RangeSlider.d.ts +30 -0
- package/dist/cjs/components/RangeSlider.js +48 -0
- package/dist/cjs/components/RangeSlider.js.map +1 -0
- package/dist/cjs/components/RatingDisplay.js +7 -4
- package/dist/cjs/components/RatingDisplay.js.map +1 -1
- package/dist/cjs/components/Search.d.ts +6 -0
- package/dist/cjs/components/Search.js +11 -0
- package/dist/cjs/components/Search.js.map +1 -0
- package/dist/cjs/components/Select.d.ts +41 -0
- package/dist/cjs/components/Select.js +48 -0
- package/dist/cjs/components/Select.js.map +1 -0
- package/dist/cjs/components/SkeletonLoader.d.ts +39 -0
- package/dist/cjs/components/SkeletonLoader.js +76 -0
- package/dist/cjs/components/SkeletonLoader.js.map +1 -0
- package/dist/cjs/components/Slider/SlickSlider.d.ts +74 -0
- package/dist/cjs/components/Slider/SlickSlider.js +211 -0
- package/dist/cjs/components/Slider/SlickSlider.js.map +1 -0
- package/dist/cjs/components/Slider/useCenterMode.d.ts +24 -0
- package/dist/cjs/components/Slider/useCenterMode.js +40 -0
- package/dist/cjs/components/Slider/useCenterMode.js.map +1 -0
- package/dist/cjs/components/Slider/useSlider.d.ts +65 -0
- package/dist/cjs/components/Slider/useSlider.js +158 -0
- package/dist/cjs/components/Slider/useSlider.js.map +1 -0
- package/dist/cjs/components/Slider/useSliderAutoPlay.d.ts +33 -0
- package/dist/cjs/components/Slider/useSliderAutoPlay.js +73 -0
- package/dist/cjs/components/Slider/useSliderAutoPlay.js.map +1 -0
- package/dist/cjs/components/Slider/useSliderBreakpoint.d.ts +23 -0
- package/dist/cjs/components/Slider/useSliderBreakpoint.js +92 -0
- package/dist/cjs/components/Slider/useSliderBreakpoint.js.map +1 -0
- package/dist/cjs/components/Slider/useSliderDimension.d.ts +41 -0
- package/dist/cjs/components/Slider/useSliderDimension.js +92 -0
- package/dist/cjs/components/Slider/useSliderDimension.js.map +1 -0
- package/dist/cjs/components/Slider/useSliderDraggable.d.ts +43 -0
- package/dist/cjs/components/Slider/useSliderDraggable.js +146 -0
- package/dist/cjs/components/Slider/useSliderDraggable.js.map +1 -0
- package/dist/cjs/components/Slider/useSliderNavigation.d.ts +41 -0
- package/dist/cjs/components/Slider/useSliderNavigation.js +136 -0
- package/dist/cjs/components/Slider/useSliderNavigation.js.map +1 -0
- package/dist/cjs/components/Slider/useSliderTransform.d.ts +17 -0
- package/dist/cjs/components/Slider/useSliderTransform.js +71 -0
- package/dist/cjs/components/Slider/useSliderTransform.js.map +1 -0
- package/dist/cjs/components/TextInput.d.ts +35 -4
- package/dist/cjs/components/TextInput.js +97 -11
- package/dist/cjs/components/TextInput.js.map +1 -1
- package/dist/cjs/components/ThreeDotsLoader.d.ts +24 -0
- package/dist/cjs/components/ThreeDotsLoader.js +25 -0
- package/dist/cjs/components/ThreeDotsLoader.js.map +1 -0
- package/dist/cjs/components/Tooltip.d.ts +32 -0
- package/dist/cjs/components/Tooltip.js +35 -0
- package/dist/cjs/components/Tooltip.js.map +1 -0
- package/dist/cjs/constants/app.d.ts +2 -0
- package/dist/cjs/constants/app.js +3 -1
- package/dist/cjs/constants/app.js.map +1 -1
- package/dist/cjs/constants/icons.d.ts +10 -0
- package/dist/cjs/constants/icons.js +14 -0
- package/dist/cjs/constants/icons.js.map +1 -0
- package/dist/cjs/helpers/app.d.ts +39 -2
- package/dist/cjs/helpers/app.js +83 -5
- package/dist/cjs/helpers/app.js.map +1 -1
- package/dist/cjs/helpers/index.d.ts +1 -0
- package/dist/cjs/helpers/index.js +3 -0
- package/dist/cjs/helpers/index.js.map +1 -1
- package/dist/cjs/hooks/index.d.ts +1 -0
- package/dist/cjs/hooks/index.js +4 -0
- package/dist/cjs/hooks/index.js.map +1 -1
- package/dist/cjs/hooks/useLocalStorage.d.ts +7 -0
- package/dist/cjs/hooks/useLocalStorage.js +57 -0
- package/dist/cjs/hooks/useLocalStorage.js.map +1 -0
- package/dist/cjs/index.d.ts +23 -5
- package/dist/cjs/index.js +47 -9
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/strings/en.d.ts +3 -1
- package/dist/cjs/strings/en.js +5 -3
- package/dist/cjs/strings/en.js.map +1 -1
- package/dist/cjs/subComponent/DateRange.js +2 -0
- package/dist/cjs/subComponent/DateRange.js.map +1 -0
- package/dist/cjs/subComponent/ToggleButton.d.ts +9 -0
- package/dist/cjs/subComponent/ToggleButton.js +19 -0
- package/dist/cjs/subComponent/ToggleButton.js.map +1 -0
- package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtn.d.ts +43 -0
- package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtn.js +43 -0
- package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtn.js.map +1 -0
- package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtnGroup.d.ts +43 -0
- package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtnGroup.js +53 -0
- package/dist/cjs/subComponent/toggleBtnGroup/ToggleBtnGroup.js.map +1 -0
- package/dist/esm/Utils/index.d.ts +4 -0
- package/dist/esm/Utils/index.js +5 -0
- package/dist/esm/Utils/index.js.map +1 -0
- package/dist/esm/components/Accordion.js +7 -6
- package/dist/esm/components/Accordion.js.map +1 -1
- package/dist/esm/components/Alert.d.ts +32 -0
- package/dist/esm/components/Alert.js +48 -0
- package/dist/esm/components/Alert.js.map +1 -0
- package/dist/esm/components/Badge.d.ts +22 -0
- package/dist/esm/components/Badge.js +34 -0
- package/dist/esm/components/Badge.js.map +1 -0
- package/dist/esm/components/BrokenPage.d.ts +35 -0
- package/dist/esm/components/BrokenPage.js +57 -0
- package/dist/esm/components/BrokenPage.js.map +1 -0
- package/dist/esm/components/Button.d.ts +29 -2
- package/dist/esm/components/Button.js +56 -3
- package/dist/esm/components/Button.js.map +1 -1
- package/dist/esm/components/Card.d.ts +77 -0
- package/dist/esm/components/Card.js +75 -0
- package/dist/esm/components/Card.js.map +1 -0
- package/dist/esm/components/Checkbox.d.ts +25 -0
- package/dist/esm/components/Checkbox.js +21 -0
- package/dist/esm/components/Checkbox.js.map +1 -0
- package/dist/esm/components/ConfirmPoup.d.ts +21 -0
- package/dist/esm/components/ConfirmPoup.js +45 -0
- package/dist/esm/components/ConfirmPoup.js.map +1 -0
- package/dist/esm/components/Dropdown.d.ts +35 -0
- package/dist/esm/components/Dropdown.js +52 -0
- package/dist/esm/components/Dropdown.js.map +1 -0
- package/dist/esm/components/Label.d.ts +1 -1
- package/dist/esm/components/Label.js +9 -7
- package/dist/esm/components/Label.js.map +1 -1
- package/dist/esm/components/Layout/Footer.js +10 -2
- package/dist/esm/components/Layout/Footer.js.map +1 -1
- package/dist/esm/components/Layout/Header.d.ts +2 -1
- package/dist/esm/components/Layout/Header.js +14 -3
- package/dist/esm/components/Layout/Header.js.map +1 -1
- package/dist/esm/components/Layout/Sidebar.d.ts +2 -1
- package/dist/esm/components/Layout/Sidebar.js +4 -3
- package/dist/esm/components/Layout/Sidebar.js.map +1 -1
- package/dist/esm/components/MultiCheckbox.d.ts +39 -0
- package/dist/esm/components/MultiCheckbox.js +54 -0
- package/dist/esm/components/MultiCheckbox.js.map +1 -0
- package/dist/esm/components/MultiRadio.d.ts +30 -0
- package/dist/esm/components/MultiRadio.js +39 -0
- package/dist/esm/components/MultiRadio.js.map +1 -0
- package/dist/esm/components/NumberInput.d.ts +38 -0
- package/dist/esm/components/NumberInput.js +32 -0
- package/dist/esm/components/NumberInput.js.map +1 -0
- package/dist/esm/components/Popover.d.ts +56 -0
- package/dist/esm/components/Popover.js +32 -0
- package/dist/esm/components/Popover.js.map +1 -0
- package/dist/esm/components/Radio.d.ts +24 -0
- package/dist/esm/components/Radio.js +22 -0
- package/dist/esm/components/Radio.js.map +1 -0
- package/dist/esm/components/RadioButtonGroup.d.ts +67 -0
- package/dist/esm/components/RadioButtonGroup.js +139 -0
- package/dist/esm/components/RadioButtonGroup.js.map +1 -0
- package/dist/esm/components/RangeSlider.d.ts +30 -0
- package/dist/esm/components/RangeSlider.js +46 -0
- package/dist/esm/components/RangeSlider.js.map +1 -0
- package/dist/esm/components/RatingDisplay.js +7 -4
- package/dist/esm/components/RatingDisplay.js.map +1 -1
- package/dist/esm/components/Search.d.ts +6 -0
- package/dist/esm/components/Search.js +8 -0
- package/dist/esm/components/Search.js.map +1 -0
- package/dist/esm/components/Select.d.ts +41 -0
- package/dist/esm/components/Select.js +46 -0
- package/dist/esm/components/Select.js.map +1 -0
- package/dist/esm/components/SkeletonLoader.d.ts +39 -0
- package/dist/esm/components/SkeletonLoader.js +74 -0
- package/dist/esm/components/SkeletonLoader.js.map +1 -0
- package/dist/esm/components/Slider/SlickSlider.d.ts +74 -0
- package/dist/esm/components/Slider/SlickSlider.js +208 -0
- package/dist/esm/components/Slider/SlickSlider.js.map +1 -0
- package/dist/esm/components/Slider/useCenterMode.d.ts +24 -0
- package/dist/esm/components/Slider/useCenterMode.js +38 -0
- package/dist/esm/components/Slider/useCenterMode.js.map +1 -0
- package/dist/esm/components/Slider/useSlider.d.ts +65 -0
- package/dist/esm/components/Slider/useSlider.js +156 -0
- package/dist/esm/components/Slider/useSlider.js.map +1 -0
- package/dist/esm/components/Slider/useSliderAutoPlay.d.ts +33 -0
- package/dist/esm/components/Slider/useSliderAutoPlay.js +71 -0
- package/dist/esm/components/Slider/useSliderAutoPlay.js.map +1 -0
- package/dist/esm/components/Slider/useSliderBreakpoint.d.ts +23 -0
- package/dist/esm/components/Slider/useSliderBreakpoint.js +90 -0
- package/dist/esm/components/Slider/useSliderBreakpoint.js.map +1 -0
- package/dist/esm/components/Slider/useSliderDimension.d.ts +41 -0
- package/dist/esm/components/Slider/useSliderDimension.js +90 -0
- package/dist/esm/components/Slider/useSliderDimension.js.map +1 -0
- package/dist/esm/components/Slider/useSliderDraggable.d.ts +43 -0
- package/dist/esm/components/Slider/useSliderDraggable.js +144 -0
- package/dist/esm/components/Slider/useSliderDraggable.js.map +1 -0
- package/dist/esm/components/Slider/useSliderNavigation.d.ts +41 -0
- package/dist/esm/components/Slider/useSliderNavigation.js +134 -0
- package/dist/esm/components/Slider/useSliderNavigation.js.map +1 -0
- package/dist/esm/components/Slider/useSliderTransform.d.ts +17 -0
- package/dist/esm/components/Slider/useSliderTransform.js +69 -0
- package/dist/esm/components/Slider/useSliderTransform.js.map +1 -0
- package/dist/esm/components/TextInput.d.ts +35 -4
- package/dist/esm/components/TextInput.js +99 -12
- package/dist/esm/components/TextInput.js.map +1 -1
- package/dist/esm/components/ThreeDotsLoader.d.ts +24 -0
- package/dist/esm/components/ThreeDotsLoader.js +23 -0
- package/dist/esm/components/ThreeDotsLoader.js.map +1 -0
- package/dist/esm/components/Tooltip.d.ts +32 -0
- package/dist/esm/components/Tooltip.js +33 -0
- package/dist/esm/components/Tooltip.js.map +1 -0
- package/dist/esm/constants/app.d.ts +2 -0
- package/dist/esm/constants/app.js +2 -0
- package/dist/esm/constants/app.js.map +1 -1
- package/dist/esm/constants/icons.d.ts +10 -0
- package/dist/esm/constants/icons.js +12 -0
- package/dist/esm/constants/icons.js.map +1 -0
- package/dist/esm/helpers/app.d.ts +39 -2
- package/dist/esm/helpers/app.js +73 -3
- package/dist/esm/helpers/app.js.map +1 -1
- package/dist/esm/helpers/index.d.ts +1 -0
- package/dist/esm/helpers/index.js +1 -1
- package/dist/esm/helpers/index.js.map +1 -1
- package/dist/esm/hooks/index.d.ts +1 -0
- package/dist/esm/hooks/index.js +1 -1
- package/dist/esm/hooks/index.js.map +1 -1
- package/dist/esm/hooks/useLocalStorage.d.ts +7 -0
- package/dist/esm/hooks/useLocalStorage.js +54 -0
- package/dist/esm/hooks/useLocalStorage.js.map +1 -0
- package/dist/esm/index.d.ts +23 -5
- package/dist/esm/index.js +23 -5
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/strings/en.d.ts +3 -1
- package/dist/esm/strings/en.js +4 -2
- package/dist/esm/strings/en.js.map +1 -1
- package/dist/esm/subComponent/DateRange.js +2 -0
- package/dist/esm/subComponent/DateRange.js.map +1 -0
- package/dist/esm/subComponent/ToggleButton.d.ts +9 -0
- package/dist/esm/subComponent/ToggleButton.js +17 -0
- package/dist/esm/subComponent/ToggleButton.js.map +1 -0
- package/dist/esm/subComponent/toggleBtnGroup/ToggleBtn.d.ts +43 -0
- package/dist/esm/subComponent/toggleBtnGroup/ToggleBtn.js +41 -0
- package/dist/esm/subComponent/toggleBtnGroup/ToggleBtn.js.map +1 -0
- package/dist/esm/subComponent/toggleBtnGroup/ToggleBtnGroup.d.ts +43 -0
- package/dist/esm/subComponent/toggleBtnGroup/ToggleBtnGroup.js +51 -0
- package/dist/esm/subComponent/toggleBtnGroup/ToggleBtnGroup.js.map +1 -0
- package/dist/package.json +1 -1
- package/package.json +6 -4
- package/dist/cjs/strings/index.js +0 -2
- package/dist/cjs/strings/index.js.map +0 -1
- package/dist/esm/strings/index.js +0 -2
- package/dist/esm/strings/index.js.map +0 -1
- /package/dist/cjs/{strings/index.d.ts → subComponent/DateRange.d.ts} +0 -0
- /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
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "farm-react",
|
|
3
|
-
"version": "1.0.
|
|
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 \"
|
|
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 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/strings/index.ts"],"names":[],"mappings":""}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/strings/index.ts"],"names":[],"mappings":""}
|
|
File without changes
|
|
File without changes
|