@bodynarf/react.components 1.12.5 → 1.13.0
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/changelog.md +54 -0
- package/components/accordion/component/index.d.ts +6 -6
- package/components/accordion/component/index.d.ts.map +1 -1
- package/components/accordion/component/index.js +33 -35
- package/components/accordion/index.d.ts +2 -2
- package/components/accordion/index.js +2 -2
- package/components/accordion/types.d.ts +16 -17
- package/components/accordion/types.d.ts.map +1 -1
- package/components/accordion/types.js +1 -1
- package/components/anchor/component/index.d.ts +7 -5
- package/components/anchor/component/index.d.ts.map +1 -1
- package/components/anchor/component/index.js +23 -20
- package/components/anchor/components/anchorWithIcon/index.d.ts +10 -11
- package/components/anchor/components/anchorWithIcon/index.d.ts.map +1 -1
- package/components/anchor/components/anchorWithIcon/index.js +24 -21
- package/components/anchor/components/simpleAnchor/index.d.ts +4 -5
- package/components/anchor/components/simpleAnchor/index.d.ts.map +1 -1
- package/components/anchor/components/simpleAnchor/index.js +11 -11
- package/components/anchor/index.d.ts +2 -2
- package/components/anchor/index.js +2 -2
- package/components/anchor/types.d.ts +19 -16
- package/components/anchor/types.d.ts.map +1 -1
- package/components/anchor/types.js +1 -1
- package/components/breadcrumbs/component/index.d.ts +8 -8
- package/components/breadcrumbs/component/index.d.ts.map +1 -1
- package/components/breadcrumbs/component/index.js +38 -37
- package/components/breadcrumbs/index.d.ts +2 -2
- package/components/breadcrumbs/index.js +2 -2
- package/components/breadcrumbs/types.d.ts +54 -46
- package/components/breadcrumbs/types.d.ts.map +1 -1
- package/components/breadcrumbs/types.js +1 -1
- package/components/button/component/index.d.ts +9 -8
- package/components/button/component/index.d.ts.map +1 -1
- package/components/button/component/index.js +35 -33
- package/components/button/components/buttonWithIcon/index.d.ts +5 -5
- package/components/button/components/buttonWithIcon/index.d.ts.map +1 -1
- package/components/button/components/buttonWithIcon/index.js +27 -24
- package/components/button/components/simpleButton/index.d.ts +5 -5
- package/components/button/components/simpleButton/index.d.ts.map +1 -1
- package/components/button/components/simpleButton/index.js +11 -11
- package/components/button/index.d.ts +2 -2
- package/components/button/index.js +2 -2
- package/components/button/types.d.ts +71 -37
- package/components/button/types.d.ts.map +1 -1
- package/components/button/types.js +30 -1
- package/components/dropdown/component/index.d.ts +6 -6
- package/components/dropdown/component/index.d.ts.map +1 -1
- package/components/dropdown/component/index.js +12 -12
- package/components/dropdown/components/compact/index.d.ts +10 -10
- package/components/dropdown/components/compact/index.d.ts.map +1 -1
- package/components/dropdown/components/compact/index.js +80 -80
- package/components/dropdown/components/item/index.d.ts +14 -14
- package/components/dropdown/components/item/index.d.ts.map +1 -1
- package/components/dropdown/components/item/index.js +39 -38
- package/components/dropdown/components/label/component/index.d.ts +26 -26
- package/components/dropdown/components/label/component/index.d.ts.map +1 -1
- package/components/dropdown/components/label/component/index.js +16 -16
- package/components/dropdown/components/label/components/empty/index.d.ts +7 -7
- package/components/dropdown/components/label/components/empty/index.d.ts.map +1 -1
- package/components/dropdown/components/label/components/empty/index.js +16 -16
- package/components/dropdown/components/label/components/selected/index.d.ts +7 -7
- package/components/dropdown/components/label/components/selected/index.d.ts.map +1 -1
- package/components/dropdown/components/label/components/selected/index.js +20 -20
- package/components/dropdown/components/label/components/selectedWithIcon/index.d.ts +7 -7
- package/components/dropdown/components/label/components/selectedWithIcon/index.d.ts.map +1 -1
- package/components/dropdown/components/label/components/selectedWithIcon/index.js +28 -28
- package/components/dropdown/components/label/components/withSearch/index.d.ts +15 -15
- package/components/dropdown/components/label/components/withSearch/index.d.ts.map +1 -1
- package/components/dropdown/components/label/components/withSearch/index.js +33 -33
- package/components/dropdown/components/label/index.d.ts +1 -1
- package/components/dropdown/components/label/index.js +1 -1
- package/components/dropdown/components/withLabel/index.d.ts +5 -5
- package/components/dropdown/components/withLabel/index.js +11 -11
- package/components/dropdown/index.d.ts +2 -2
- package/components/dropdown/index.js +2 -2
- package/components/dropdown/types.d.ts +65 -64
- package/components/dropdown/types.d.ts.map +1 -1
- package/components/dropdown/types.js +1 -1
- package/components/file/component/index.d.ts +6 -6
- package/components/file/component/index.d.ts.map +1 -1
- package/components/file/component/index.js +51 -50
- package/components/file/component/styles.scss +13 -0
- package/components/file/index.d.ts +2 -2
- package/components/file/index.js +2 -2
- package/components/file/types.d.ts +31 -31
- package/components/file/types.d.ts.map +1 -1
- package/components/file/types.js +1 -1
- package/components/icon/component/index.d.ts +8 -8
- package/components/icon/component/index.d.ts.map +1 -1
- package/components/icon/component/index.js +23 -28
- package/components/icon/component/style.scss +3 -3
- package/components/icon/index.d.ts +2 -2
- package/components/icon/index.js +2 -2
- package/components/icon/types.d.ts +13 -15
- package/components/icon/types.d.ts.map +1 -1
- package/components/icon/types.js +1 -1
- package/components/index.d.ts +10 -10
- package/components/index.js +10 -10
- package/components/multiselect/component/index.d.ts +7 -7
- package/components/multiselect/component/index.js +13 -13
- package/components/multiselect/components/item/index.d.ts +24 -24
- package/components/multiselect/components/item/index.d.ts.map +1 -1
- package/components/multiselect/components/item/index.js +63 -62
- package/components/multiselect/components/label/component/index.d.ts +19 -19
- package/components/multiselect/components/label/component/index.d.ts.map +1 -1
- package/components/multiselect/components/label/component/index.js +12 -12
- package/components/multiselect/components/label/components/empty/index.d.ts +7 -7
- package/components/multiselect/components/label/components/empty/index.d.ts.map +1 -1
- package/components/multiselect/components/label/components/empty/index.js +16 -16
- package/components/multiselect/components/label/components/nonEmpty/index.d.ts +7 -7
- package/components/multiselect/components/label/components/nonEmpty/index.d.ts.map +1 -1
- package/components/multiselect/components/label/components/nonEmpty/index.js +16 -16
- package/components/multiselect/components/label/index.d.ts +1 -1
- package/components/multiselect/components/label/index.js +1 -1
- package/components/multiselect/components/withLabel/index.d.ts +5 -5
- package/components/multiselect/components/withLabel/index.js +11 -11
- package/components/multiselect/components/withoutLabel/index.d.ts +9 -9
- package/components/multiselect/components/withoutLabel/index.d.ts.map +1 -1
- package/components/multiselect/components/withoutLabel/index.js +85 -84
- package/components/multiselect/index.d.ts +2 -2
- package/components/multiselect/index.js +2 -2
- package/components/multiselect/types.d.ts +32 -40
- package/components/multiselect/types.d.ts.map +1 -1
- package/components/multiselect/types.js +1 -1
- package/components/paginator/component/index.d.ts +8 -8
- package/components/paginator/component/index.d.ts.map +1 -1
- package/components/paginator/component/index.js +65 -70
- package/components/paginator/index.d.ts +2 -2
- package/components/paginator/index.js +2 -2
- package/components/paginator/types.d.ts +54 -54
- package/components/paginator/types.d.ts.map +1 -1
- package/components/paginator/types.js +1 -1
- package/components/primitives/checkbox/component/index.d.ts +5 -6
- package/components/primitives/checkbox/component/index.d.ts.map +1 -1
- package/components/primitives/checkbox/component/index.js +43 -41
- package/components/primitives/checkbox/index.d.ts +2 -2
- package/components/primitives/checkbox/index.js +2 -2
- package/components/primitives/checkbox/types.d.ts +26 -24
- package/components/primitives/checkbox/types.d.ts.map +1 -1
- package/components/primitives/checkbox/types.js +1 -1
- package/components/primitives/color/component/index.d.ts +5 -6
- package/components/primitives/color/component/index.d.ts.map +1 -1
- package/components/primitives/color/component/index.js +10 -10
- package/components/primitives/color/components/picker/index.d.ts +19 -19
- package/components/primitives/color/components/picker/index.d.ts.map +1 -1
- package/components/primitives/color/components/picker/index.js +43 -42
- package/components/primitives/color/components/withLabel/index.d.ts +5 -5
- package/components/primitives/color/components/withLabel/index.d.ts.map +1 -1
- package/components/primitives/color/components/withLabel/index.js +25 -25
- package/components/primitives/color/components/withoutLabel/index.d.ts +5 -5
- package/components/primitives/color/components/withoutLabel/index.d.ts.map +1 -1
- package/components/primitives/color/components/withoutLabel/index.js +21 -21
- package/components/primitives/color/index.d.ts +2 -2
- package/components/primitives/color/index.js +2 -2
- package/components/primitives/color/types.d.ts +23 -23
- package/components/primitives/color/types.d.ts.map +1 -1
- package/components/primitives/color/types.js +1 -1
- package/components/primitives/date/component/index.d.ts +5 -6
- package/components/primitives/date/component/index.d.ts.map +1 -1
- package/components/primitives/date/component/index.js +31 -31
- package/components/primitives/date/index.d.ts +2 -2
- package/components/primitives/date/index.js +2 -2
- package/components/primitives/date/types.d.ts +3 -8
- package/components/primitives/date/types.d.ts.map +1 -1
- package/components/primitives/date/types.js +1 -1
- package/components/primitives/index.d.ts +7 -7
- package/components/primitives/index.js +7 -7
- package/components/primitives/internal/componentWithLabel/index.d.ts +16 -16
- package/components/primitives/internal/componentWithLabel/index.d.ts.map +1 -1
- package/components/primitives/internal/componentWithLabel/index.js +30 -30
- package/components/primitives/internal/hint/index.d.ts +8 -8
- package/components/primitives/internal/hint/index.d.ts.map +1 -1
- package/components/primitives/internal/hint/index.js +49 -48
- package/components/primitives/multiline/component/index.d.ts +4 -5
- package/components/primitives/multiline/component/index.d.ts.map +1 -1
- package/components/primitives/multiline/component/index.js +11 -11
- package/components/primitives/multiline/components/withLabel/index.d.ts +4 -5
- package/components/primitives/multiline/components/withLabel/index.d.ts.map +1 -1
- package/components/primitives/multiline/components/withLabel/index.js +27 -27
- package/components/primitives/multiline/components/withoutLabel/index.d.ts +4 -5
- package/components/primitives/multiline/components/withoutLabel/index.d.ts.map +1 -1
- package/components/primitives/multiline/components/withoutLabel/index.js +27 -27
- package/components/primitives/multiline/index.d.ts +2 -2
- package/components/primitives/multiline/index.js +2 -2
- package/components/primitives/multiline/types.d.ts +8 -10
- package/components/primitives/multiline/types.d.ts.map +1 -1
- package/components/primitives/multiline/types.js +1 -1
- package/components/primitives/number/component/index.d.ts +4 -5
- package/components/primitives/number/component/index.d.ts.map +1 -1
- package/components/primitives/number/component/index.js +11 -11
- package/components/primitives/number/components/withLabel/index.d.ts +4 -5
- package/components/primitives/number/components/withLabel/index.d.ts.map +1 -1
- package/components/primitives/number/components/withLabel/index.js +27 -27
- package/components/primitives/number/components/withoutLabel/index.d.ts +4 -5
- package/components/primitives/number/components/withoutLabel/index.d.ts.map +1 -1
- package/components/primitives/number/components/withoutLabel/index.js +27 -27
- package/components/primitives/number/index.d.ts +2 -2
- package/components/primitives/number/index.js +2 -2
- package/components/primitives/number/types.d.ts +10 -12
- package/components/primitives/number/types.d.ts.map +1 -1
- package/components/primitives/number/types.js +1 -1
- package/components/primitives/password/component/index.d.ts +5 -5
- package/components/primitives/password/component/index.d.ts.map +1 -1
- package/components/primitives/password/component/index.js +12 -12
- package/components/primitives/password/components/withLabel/index.d.ts +3 -3
- package/components/primitives/password/components/withLabel/index.d.ts.map +1 -1
- package/components/primitives/password/components/withLabel/index.js +34 -34
- package/components/primitives/password/components/withoutLabel/index.d.ts +3 -3
- package/components/primitives/password/components/withoutLabel/index.d.ts.map +1 -1
- package/components/primitives/password/components/withoutLabel/index.js +34 -34
- package/components/primitives/password/index.d.ts +2 -2
- package/components/primitives/password/index.js +2 -2
- package/components/primitives/password/types.d.ts +14 -14
- package/components/primitives/password/types.d.ts.map +1 -1
- package/components/primitives/password/types.js +1 -1
- package/components/primitives/text/component/index.d.ts +4 -5
- package/components/primitives/text/component/index.d.ts.map +1 -1
- package/components/primitives/text/component/index.js +11 -11
- package/components/primitives/text/components/withLabel/index.d.ts +4 -5
- package/components/primitives/text/components/withLabel/index.d.ts.map +1 -1
- package/components/primitives/text/components/withLabel/index.js +27 -27
- package/components/primitives/text/components/withoutLabel/index.d.ts +4 -5
- package/components/primitives/text/components/withoutLabel/index.d.ts.map +1 -1
- package/components/primitives/text/components/withoutLabel/index.js +27 -27
- package/components/primitives/text/index.d.ts +2 -2
- package/components/primitives/text/index.js +2 -2
- package/components/primitives/text/types.d.ts +3 -6
- package/components/primitives/text/types.d.ts.map +1 -1
- package/components/primitives/text/types.js +1 -1
- package/components/search/component/index.d.ts +6 -5
- package/components/search/component/index.d.ts.map +1 -1
- package/components/search/component/index.js +41 -40
- package/components/search/index.d.ts +2 -2
- package/components/search/index.js +2 -2
- package/components/search/types.d.ts +41 -41
- package/components/search/types.d.ts.map +1 -1
- package/components/search/types.js +1 -1
- package/components/table/component/index.d.ts +8 -9
- package/components/table/component/index.d.ts.map +1 -1
- package/components/table/component/index.js +28 -29
- package/components/table/components/heading/index.d.ts +14 -12
- package/components/table/components/heading/index.d.ts.map +1 -1
- package/components/table/components/heading/index.js +21 -21
- package/components/table/index.d.ts +2 -2
- package/components/table/index.js +2 -2
- package/components/table/types.d.ts +52 -52
- package/components/table/types.d.ts.map +1 -1
- package/components/table/types.js +1 -1
- package/components/tabs/component/index.d.ts +9 -9
- package/components/tabs/component/index.d.ts.map +1 -1
- package/components/tabs/component/index.js +68 -74
- package/components/tabs/components/item/index.d.ts +11 -12
- package/components/tabs/components/item/index.d.ts.map +1 -1
- package/components/tabs/components/item/index.js +28 -28
- package/components/tabs/index.d.ts +2 -2
- package/components/tabs/index.js +2 -2
- package/components/tabs/types.d.ts +54 -54
- package/components/tabs/types.js +22 -22
- package/components/tag/component/index.d.ts +6 -6
- package/components/tag/component/index.d.ts.map +1 -1
- package/components/tag/component/index.js +32 -32
- package/components/tag/index.d.ts +2 -2
- package/components/tag/index.js +2 -2
- package/components/tag/types.d.ts +24 -26
- package/components/tag/types.d.ts.map +1 -1
- package/components/tag/types.js +1 -1
- package/hooks/index.d.ts +11 -5
- package/hooks/index.d.ts.map +1 -1
- package/hooks/index.js +11 -5
- package/hooks/useComponentOutsideClick.d.ts +11 -11
- package/hooks/useComponentOutsideClick.d.ts.map +1 -1
- package/hooks/useComponentOutsideClick.js +31 -31
- package/hooks/useDebounceHandler.d.ts +17 -17
- package/hooks/useDebounceHandler.d.ts.map +1 -1
- package/hooks/useDebounceHandler.js +30 -30
- package/hooks/useEventListener.d.ts +13 -0
- package/hooks/useEventListener.d.ts.map +1 -0
- package/hooks/useEventListener.js +23 -0
- package/hooks/useInterval.d.ts +12 -0
- package/hooks/useInterval.d.ts.map +1 -0
- package/hooks/useInterval.js +23 -0
- package/hooks/useLocalStorage.d.ts +13 -0
- package/hooks/useLocalStorage.d.ts.map +1 -0
- package/hooks/useLocalStorage.js +23 -0
- package/hooks/useMount.d.ts +11 -11
- package/hooks/useMount.d.ts.map +1 -1
- package/hooks/useMount.js +16 -16
- package/hooks/usePagination.d.ts +19 -19
- package/hooks/usePagination.d.ts.map +1 -1
- package/hooks/usePagination.js +37 -37
- package/hooks/usePrevious.d.ts +12 -0
- package/hooks/usePrevious.d.ts.map +1 -0
- package/hooks/usePrevious.js +18 -0
- package/hooks/useTimeout.d.ts +12 -0
- package/hooks/useTimeout.d.ts.map +1 -0
- package/hooks/useTimeout.js +23 -0
- package/hooks/useUnmount.d.ts +8 -8
- package/hooks/useUnmount.d.ts.map +1 -1
- package/hooks/useUnmount.js +22 -22
- package/hooks/useUpdateEffect.d.ts +16 -0
- package/hooks/useUpdateEffect.d.ts.map +1 -0
- package/hooks/useUpdateEffect.js +25 -0
- package/index.d.ts +4 -4
- package/index.js +4 -4
- package/package.json +12 -10
- package/tsconfig.tsbuildinfo +1 -1
- package/types/{baseElementProps.d.ts → base/baseElementProps.d.ts} +10 -10
- package/types/base/baseElementProps.d.ts.map +1 -0
- package/types/{baseElementProps.js → base/baseElementProps.js} +1 -1
- package/types/{baseInputElementProps.d.ts → base/baseInputElementProps.d.ts} +49 -41
- package/types/base/baseInputElementProps.d.ts.map +1 -0
- package/types/{baseInputElementProps.js → base/baseInputElementProps.js} +1 -1
- package/types/base/blurableElement.d.ts +9 -0
- package/types/base/blurableElement.d.ts.map +1 -0
- package/types/base/blurableElement.js +1 -0
- package/types/base/clickableElement.d.ts +7 -0
- package/types/base/clickableElement.d.ts.map +1 -0
- package/types/base/clickableElement.js +1 -0
- package/types/base/index.d.ts +5 -0
- package/types/base/index.d.ts.map +1 -0
- package/types/base/index.js +4 -0
- package/types/dataAttributes.d.ts +8 -8
- package/types/dataAttributes.d.ts.map +1 -1
- package/types/dataAttributes.js +1 -1
- package/types/elementIcon.d.ts +21 -21
- package/types/elementIcon.d.ts.map +1 -1
- package/types/elementIcon.js +1 -1
- package/types/{elementColor.d.ts → enums/elementColor.d.ts} +17 -17
- package/types/enums/elementColor.d.ts.map +1 -0
- package/types/{elementColor.js → enums/elementColor.js} +18 -18
- package/types/{elementPosition.d.ts → enums/elementPosition.d.ts} +11 -11
- package/types/enums/elementPosition.d.ts.map +1 -0
- package/types/{elementPosition.js → enums/elementPosition.js} +10 -10
- package/types/{elementSize.d.ts → enums/elementSize.d.ts} +11 -11
- package/types/enums/elementSize.d.ts.map +1 -0
- package/types/{elementSize.js → enums/elementSize.js} +12 -12
- package/types/enums/index.d.ts +4 -0
- package/types/enums/index.d.ts.map +1 -0
- package/types/enums/index.js +3 -0
- package/types/hintConfiguration.d.ts +12 -12
- package/types/hintConfiguration.d.ts.map +1 -1
- package/types/hintConfiguration.js +1 -1
- package/types/index.d.ts +7 -10
- package/types/index.d.ts.map +1 -1
- package/types/index.js +7 -10
- package/types/labelConfiguration.d.ts +14 -14
- package/types/labelConfiguration.d.ts.map +1 -1
- package/types/labelConfiguration.js +1 -1
- package/types/validation/index.d.ts +2 -2
- package/types/validation/index.js +2 -2
- package/types/validation/state.d.ts +8 -8
- package/types/validation/state.js +1 -1
- package/types/validation/status.d.ts +9 -9
- package/types/validation/status.js +10 -10
- package/utils/dataAttributes.d.ts +7 -7
- package/utils/dataAttributes.d.ts.map +1 -1
- package/utils/dataAttributes.js +22 -21
- package/utils/index.d.ts +3 -2
- package/utils/index.d.ts.map +1 -1
- package/utils/index.js +3 -2
- package/utils/styles.d.ts +14 -0
- package/utils/styles.d.ts.map +1 -0
- package/utils/styles.js +33 -0
- package/utils/validation.d.ts +10 -10
- package/utils/validation.d.ts.map +1 -1
- package/utils/validation.js +20 -20
- package/bodynarf-react.components-1.12.2.tgz +0 -0
- package/bodynarf-react.components-1.12.3.tgz +0 -0
- package/bodynarf-react.components-1.12.4.tgz +0 -0
- package/types/baseElementProps.d.ts.map +0 -1
- package/types/baseInputElementProps.d.ts.map +0 -1
- package/types/elementColor.d.ts.map +0 -1
- package/types/elementPosition.d.ts.map +0 -1
- package/types/elementSize.d.ts.map +0 -1
|
@@ -1,80 +1,80 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
-
import { useCallback, useId, useState } from "react";
|
|
3
|
-
import { getClassName, isNullOrEmpty,
|
|
4
|
-
import { getStyleClassName, mapDataAttributes } from "../../../../utils";
|
|
5
|
-
import { useComponentOutsideClick } from "../../../../hooks";
|
|
6
|
-
import InternalHint from "../../../primitives/internal/hint";
|
|
7
|
-
import DropdownItem from "../../components/item";
|
|
8
|
-
import DropdownLabel from "../../components/label";
|
|
9
|
-
/** Dropdown component without label */
|
|
10
|
-
const DropdownCompact = ({ items, value, onSelect, hideOnOuterClick, listMaxHeight, placeholder, noDataText = "No items found", noDataByQuery = "No items found by specified search", compact = false, disabled = false, deselectable = false, searchable = false, validationState, className, title, data, hint, id: propsId, }) => {
|
|
11
|
-
const generatedId = useId();
|
|
12
|
-
const id = propsId ?? generatedId;
|
|
13
|
-
const [isListVisible, setListVisible] = useState(false);
|
|
14
|
-
const [searchValue, setSearchValue] = useState(
|
|
15
|
-
const onItemClick = useCallback((event) => {
|
|
16
|
-
if (disabled) {
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
const target = event.target;
|
|
20
|
-
if (
|
|
21
|
-
return;
|
|
22
|
-
}
|
|
23
|
-
const dataValue = target.dataset["dropdownItemValue"];
|
|
24
|
-
if (
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
const item = items.find(x => x.value === dataValue);
|
|
28
|
-
if (
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
if (value === item) {
|
|
32
|
-
setListVisible(false);
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
onSelect(item);
|
|
36
|
-
setSearchValue(
|
|
37
|
-
setListVisible(false);
|
|
38
|
-
}, [setListVisible, value, items, onSelect, disabled]);
|
|
39
|
-
const onLabelClick = useCallback((event) => {
|
|
40
|
-
if (disabled) {
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
const target = event.target;
|
|
44
|
-
if (
|
|
45
|
-
return;
|
|
46
|
-
}
|
|
47
|
-
if (target.classList.contains("bi-plus-lg")) {
|
|
48
|
-
onSelect(undefined);
|
|
49
|
-
setSearchValue(
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
setListVisible(state => !state);
|
|
53
|
-
}
|
|
54
|
-
}, [onSelect, setListVisible, disabled]);
|
|
55
|
-
const onSearchChange = useCallback((value) => {
|
|
56
|
-
setSearchValue(value
|
|
57
|
-
onSelect(undefined);
|
|
58
|
-
}, [setSearchValue, onSelect]);
|
|
59
|
-
useComponentOutsideClick(`[data-dropdown-id="${id}"]`, isListVisible, () => setListVisible(false), hideOnOuterClick);
|
|
60
|
-
const classNames = getClassName([
|
|
61
|
-
"bbr-dropdown",
|
|
62
|
-
className,
|
|
63
|
-
disabled ? "bbr-dropdown--disabled" : "",
|
|
64
|
-
compact ? "bbr-dropdown--compact" : "",
|
|
65
|
-
isListVisible ? "is-active" : "",
|
|
66
|
-
isNullOrEmpty(listMaxHeight) ? "bbr-dropdown--height-default" : "",
|
|
67
|
-
"dropdown",
|
|
68
|
-
]);
|
|
69
|
-
const labelComponentClassName = getStyleClassName(undefined, validationState);
|
|
70
|
-
const filteredItems =
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
};
|
|
80
|
-
export default DropdownCompact;
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useCallback, useId, useState, useMemo } from "react";
|
|
3
|
+
import { getClassName, isNullOrEmpty, isNullish } from "@bodynarf/utils";
|
|
4
|
+
import { getStyleClassName, mapDataAttributes } from "../../../../utils";
|
|
5
|
+
import { useComponentOutsideClick } from "../../../../hooks";
|
|
6
|
+
import InternalHint from "../../../primitives/internal/hint";
|
|
7
|
+
import DropdownItem from "../../components/item";
|
|
8
|
+
import DropdownLabel from "../../components/label";
|
|
9
|
+
/** Dropdown component without label */
|
|
10
|
+
const DropdownCompact = ({ items, value, onSelect, hideOnOuterClick = false, listMaxHeight, placeholder = "", noDataText = "No items found", noDataByQuery = "No items found by specified search", compact = false, disabled = false, deselectable = false, searchable = false, validationState, className, title, data, hint, id: propsId, }) => {
|
|
11
|
+
const generatedId = useId();
|
|
12
|
+
const id = propsId ?? generatedId;
|
|
13
|
+
const [isListVisible, setListVisible] = useState(false);
|
|
14
|
+
const [searchValue, setSearchValue] = useState("");
|
|
15
|
+
const onItemClick = useCallback((event) => {
|
|
16
|
+
if (disabled) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
const target = event.target;
|
|
20
|
+
if (isNullish(target)) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const dataValue = target.dataset["dropdownItemValue"];
|
|
24
|
+
if (isNullish(dataValue)) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
const item = items.find(x => x.value === dataValue);
|
|
28
|
+
if (isNullish(item)) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
if (value === item) {
|
|
32
|
+
setListVisible(false);
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
onSelect(item);
|
|
36
|
+
setSearchValue("");
|
|
37
|
+
setListVisible(false);
|
|
38
|
+
}, [setListVisible, value, items, onSelect, disabled]);
|
|
39
|
+
const onLabelClick = useCallback((event) => {
|
|
40
|
+
if (disabled) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const target = event.target;
|
|
44
|
+
if (isNullish(target)) {
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
if (target.classList.contains("bi-plus-lg")) {
|
|
48
|
+
onSelect(undefined);
|
|
49
|
+
setSearchValue("");
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
setListVisible(state => !state);
|
|
53
|
+
}
|
|
54
|
+
}, [onSelect, setListVisible, disabled]);
|
|
55
|
+
const onSearchChange = useCallback((value) => {
|
|
56
|
+
setSearchValue(value);
|
|
57
|
+
onSelect(undefined);
|
|
58
|
+
}, [setSearchValue, onSelect]);
|
|
59
|
+
useComponentOutsideClick(`[data-dropdown-id="${id}"]`, isListVisible, () => setListVisible(false), hideOnOuterClick);
|
|
60
|
+
const classNames = getClassName([
|
|
61
|
+
"bbr-dropdown",
|
|
62
|
+
className,
|
|
63
|
+
disabled ? "bbr-dropdown--disabled" : "",
|
|
64
|
+
compact ? "bbr-dropdown--compact" : "",
|
|
65
|
+
isListVisible ? "is-active" : "",
|
|
66
|
+
isNullOrEmpty(listMaxHeight) ? "bbr-dropdown--height-default" : "",
|
|
67
|
+
"dropdown",
|
|
68
|
+
]);
|
|
69
|
+
const labelComponentClassName = getStyleClassName(undefined, validationState);
|
|
70
|
+
const filteredItems = useMemo(() => items.filter(({ displayValue }) => displayValue.toLocaleLowerCase().includes(searchValue.toLocaleLowerCase())), [items, searchValue]);
|
|
71
|
+
const dataAttributes = isNullish(data)
|
|
72
|
+
? undefined
|
|
73
|
+
: mapDataAttributes(data);
|
|
74
|
+
return (_jsxs(_Fragment, { children: [_jsxs("div", { className: classNames, "data-dropdown-id": id, title: title, ...dataAttributes, children: [_jsx(DropdownLabel, { selectedItem: value, caption: placeholder, onClick: onLabelClick, searchable: searchable, lastSearch: searchValue, deselectable: deselectable, isListVisible: isListVisible, onSearchChange: onSearchChange, className: labelComponentClassName }), _jsx("div", { className: "dropdown-menu", children: filteredItems.length > 0
|
|
75
|
+
?
|
|
76
|
+
_jsx("ul", { className: "dropdown-content", style: { maxHeight: listMaxHeight }, children: filteredItems.map(item => _jsx(DropdownItem, { item: item, onClick: onItemClick, selected: value?.value === item.value }, item.id)) })
|
|
77
|
+
:
|
|
78
|
+
_jsx("span", { className: "dropdown-content dropdown-item is-italic has-text-grey", children: isNullOrEmpty(searchValue) ? noDataText : noDataByQuery }) })] }, id), _jsx(InternalHint, { hint: hint, validationState: validationState })] }));
|
|
79
|
+
};
|
|
80
|
+
export default DropdownCompact;
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
import { SelectableItem } from "../..";
|
|
3
|
-
/** Dropdown item props */
|
|
4
|
-
|
|
5
|
-
/** Item to present in dropdown */
|
|
6
|
-
item: SelectableItem;
|
|
7
|
-
/** Is item selected*/
|
|
8
|
-
selected: boolean;
|
|
9
|
-
/** Item click handler */
|
|
10
|
-
onClick: (event: React.MouseEvent<HTMLLIElement>) => void;
|
|
11
|
-
}
|
|
12
|
-
/** Single item in dropdown component */
|
|
13
|
-
declare const DropdownItem:
|
|
14
|
-
export default DropdownItem;
|
|
1
|
+
import { FC } from "react";
|
|
2
|
+
import { SelectableItem } from "../..";
|
|
3
|
+
/** Dropdown item props */
|
|
4
|
+
type DropdownItemProps = {
|
|
5
|
+
/** Item to present in dropdown */
|
|
6
|
+
item: SelectableItem;
|
|
7
|
+
/** Is item selected*/
|
|
8
|
+
selected: boolean;
|
|
9
|
+
/** Item click handler */
|
|
10
|
+
onClick: (event: React.MouseEvent<HTMLLIElement>) => void;
|
|
11
|
+
};
|
|
12
|
+
/** Single item in dropdown component */
|
|
13
|
+
declare const DropdownItem: FC<DropdownItemProps>;
|
|
14
|
+
export default DropdownItem;
|
|
15
15
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/dropdown/components/item/index.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/dropdown/components/item/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAO3B,OAAO,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAEvC,0BAA0B;AAC1B,KAAK,iBAAiB,GAAG;IACrB,kCAAkC;IAClC,IAAI,EAAE,cAAc,CAAC;IAErB,sBAAsB;IACtB,QAAQ,EAAE,OAAO,CAAC;IAElB,yBAAyB;IACzB,OAAO,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,IAAI,CAAC;CAC7D,CAAC;AAEF,wCAAwC;AACxC,QAAA,MAAM,YAAY,EAAE,EAAE,CAAC,iBAAiB,CAgCvC,CAAC;AAEF,eAAe,YAAY,CAAC"}
|
|
@@ -1,38 +1,39 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { getClassName, isNullOrUndefined } from "@bodynarf/utils";
|
|
3
|
-
import { ElementPosition } from "../../../../types";
|
|
4
|
-
import Icon from "../../../icon/component";
|
|
5
|
-
/** Single item in dropdown component */
|
|
6
|
-
const DropdownItem = ({ item, selected, onClick }) => {
|
|
7
|
-
if (!isNullOrUndefined(item.icon)) {
|
|
8
|
-
return _jsx(DropdownItemWithIcon, { item: item, selected: selected, onClick: onClick });
|
|
9
|
-
}
|
|
10
|
-
const className = getClassName([
|
|
11
|
-
"bbr-dropdown-item",
|
|
12
|
-
"dropdown-item",
|
|
13
|
-
selected ? "is-active" : "",
|
|
14
|
-
"is-flex is-align-items-center",
|
|
15
|
-
]);
|
|
16
|
-
return (_jsx("li", { onClick: onClick, className: className, "data-dropdown-item-value": item.value, title: item.title, children: item.displayValue }, item.id));
|
|
17
|
-
};
|
|
18
|
-
export default DropdownItem;
|
|
19
|
-
/** Single item in dropdown component with icon */
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
const
|
|
23
|
-
|
|
24
|
-
"dropdown-item",
|
|
25
|
-
|
|
26
|
-
"is-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
icon.
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
};
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName, isNullOrUndefined } from "@bodynarf/utils";
|
|
3
|
+
import { ElementPosition } from "../../../../types";
|
|
4
|
+
import Icon from "../../../icon/component";
|
|
5
|
+
/** Single item in dropdown component */
|
|
6
|
+
const DropdownItem = ({ item, selected, onClick }) => {
|
|
7
|
+
if (!isNullOrUndefined(item.icon)) {
|
|
8
|
+
return (_jsx(DropdownItemWithIcon, { item: item, selected: selected, onClick: onClick }));
|
|
9
|
+
}
|
|
10
|
+
const className = getClassName([
|
|
11
|
+
"bbr-dropdown-item",
|
|
12
|
+
"dropdown-item",
|
|
13
|
+
selected ? "is-active" : "",
|
|
14
|
+
"is-flex is-align-items-center",
|
|
15
|
+
]);
|
|
16
|
+
return (_jsx("li", { onClick: onClick, className: className, "data-dropdown-item-value": item.value, title: item.title, children: item.displayValue }, item.id));
|
|
17
|
+
};
|
|
18
|
+
export default DropdownItem;
|
|
19
|
+
/** Single item in dropdown component with icon */
|
|
20
|
+
// eslint-disable-next-line react/no-multi-comp
|
|
21
|
+
const DropdownItemWithIcon = ({ item, selected, onClick }) => {
|
|
22
|
+
const icon = item.icon;
|
|
23
|
+
const className = getClassName([
|
|
24
|
+
"bbr-dropdown-item",
|
|
25
|
+
"dropdown-item",
|
|
26
|
+
selected ? "is-active" : "",
|
|
27
|
+
"is-flex is-align-items-center",
|
|
28
|
+
]);
|
|
29
|
+
const iconClassName = getClassName([
|
|
30
|
+
icon.className,
|
|
31
|
+
icon.position === ElementPosition.Right
|
|
32
|
+
? "bbr-icon--right"
|
|
33
|
+
: "bbr-icon--left",
|
|
34
|
+
]);
|
|
35
|
+
if (icon.position === ElementPosition.Right) {
|
|
36
|
+
return (_jsxs("li", { onClick: onClick, className: className, "data-dropdown-item-value": item.value, title: item.title, children: [item.displayValue, _jsx(Icon, { name: icon.name, size: icon.size, className: iconClassName })] }, item.id));
|
|
37
|
+
}
|
|
38
|
+
return (_jsxs("li", { onClick: onClick, className: className, "data-dropdown-item-value": item.value, title: item.title, children: [_jsx(Icon, { name: icon.name, size: icon.size, className: iconClassName }), item.displayValue] }, item.id));
|
|
39
|
+
};
|
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
import { FC, MouseEvent } from "react";
|
|
2
|
-
import { SelectableItem } from "../../../..";
|
|
3
|
-
/** Props type of `DropdownLabel` */
|
|
4
|
-
export
|
|
5
|
-
/** Caption when no items selected */
|
|
6
|
-
caption: string;
|
|
7
|
-
/** Can user deselect */
|
|
8
|
-
deselectable: boolean;
|
|
9
|
-
/** Is search through items enabled */
|
|
10
|
-
searchable: boolean;
|
|
11
|
-
/** Selected item */
|
|
12
|
-
selectedItem?: SelectableItem;
|
|
13
|
-
/** Element classnames */
|
|
14
|
-
className?: string;
|
|
15
|
-
/** Click handler*/
|
|
16
|
-
onClick: (event: MouseEvent<HTMLElement>) => void;
|
|
17
|
-
/** Last user search */
|
|
18
|
-
lastSearch: string
|
|
19
|
-
/** Is items list visible */
|
|
20
|
-
isListVisible: boolean;
|
|
21
|
-
/** Handler of search value change by user */
|
|
22
|
-
onSearchChange: (value: string) => void;
|
|
23
|
-
}
|
|
24
|
-
/** Label component */
|
|
25
|
-
declare const DropdownLabel: FC<DropdownLabelProps>;
|
|
26
|
-
export default DropdownLabel;
|
|
1
|
+
import { FC, MouseEvent } from "react";
|
|
2
|
+
import { SelectableItem } from "../../../..";
|
|
3
|
+
/** Props type of `DropdownLabel` */
|
|
4
|
+
export type DropdownLabelProps = {
|
|
5
|
+
/** Caption when no items selected */
|
|
6
|
+
caption: string;
|
|
7
|
+
/** Can user deselect */
|
|
8
|
+
deselectable: boolean;
|
|
9
|
+
/** Is search through items enabled */
|
|
10
|
+
searchable: boolean;
|
|
11
|
+
/** Selected item */
|
|
12
|
+
selectedItem?: SelectableItem;
|
|
13
|
+
/** Element classnames */
|
|
14
|
+
className?: string;
|
|
15
|
+
/** Click handler*/
|
|
16
|
+
onClick: (event: MouseEvent<HTMLElement>) => void;
|
|
17
|
+
/** Last user search */
|
|
18
|
+
lastSearch: string;
|
|
19
|
+
/** Is items list visible */
|
|
20
|
+
isListVisible: boolean;
|
|
21
|
+
/** Handler of search value change by user */
|
|
22
|
+
onSearchChange: (value: string) => void;
|
|
23
|
+
};
|
|
24
|
+
/** Label component */
|
|
25
|
+
declare const DropdownLabel: FC<DropdownLabelProps>;
|
|
26
|
+
export default DropdownLabel;
|
|
27
27
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/components/dropdown/components/label/component/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAIvC,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAMjD,oCAAoC;AACpC,MAAM,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/components/dropdown/components/label/component/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAIvC,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAMjD,oCAAoC;AACpC,MAAM,MAAM,kBAAkB,GAAG;IAC7B,qCAAqC;IACrC,OAAO,EAAE,MAAM,CAAC;IAEhB,wBAAwB;IACxB,YAAY,EAAE,OAAO,CAAC;IAEtB,sCAAsC;IACtC,UAAU,EAAE,OAAO,CAAC;IAEpB,oBAAoB;IACpB,YAAY,CAAC,EAAE,cAAc,CAAC;IAE9B,yBAAyB;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,mBAAmB;IACnB,OAAO,EAAE,CAAC,KAAK,EAAE,UAAU,CAAC,WAAW,CAAC,KAAK,IAAI,CAAC;IAElD,uBAAuB;IACvB,UAAU,EAAE,MAAM,CAAC;IAEnB,4BAA4B;IAC5B,aAAa,EAAE,OAAO,CAAC;IAEvB,6CAA6C;IAC7C,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CAC3C,CAAC;AAEF,sBAAsB;AACtB,QAAA,MAAM,aAAa,EAAE,EAAE,CAAC,kBAAkB,CAwCzC,CAAC;AAEF,eAAe,aAAa,CAAC"}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import { isNullOrUndefined } from "@bodynarf/utils";
|
|
3
|
-
import SelectedItemLabel from "../components/selected";
|
|
4
|
-
import EmptyLabel from "../components/empty";
|
|
5
|
-
import DropdownLabelWithSearch from "../components/withSearch";
|
|
6
|
-
/** Label component */
|
|
7
|
-
const DropdownLabel = ({ caption, selectedItem, onClick, deselectable, className, searchable, onSearchChange, lastSearch, isListVisible, }) => {
|
|
8
|
-
if (searchable) {
|
|
9
|
-
return _jsx(DropdownLabelWithSearch, { caption: caption, onClick: onClick, className: className, onSearchChange: onSearchChange, deselectable: deselectable, selectedItem: selectedItem, lastSearch: lastSearch, isListVisible: isListVisible });
|
|
10
|
-
}
|
|
11
|
-
if (isNullOrUndefined(selectedItem)) {
|
|
12
|
-
return _jsx(EmptyLabel, { caption: caption, onClick: onClick, className: className });
|
|
13
|
-
}
|
|
14
|
-
return _jsx(SelectedItemLabel, { deselectable: deselectable, className: className, onClick: onClick, selectedItem: selectedItem });
|
|
15
|
-
};
|
|
16
|
-
export default DropdownLabel;
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { isNullOrUndefined } from "@bodynarf/utils";
|
|
3
|
+
import SelectedItemLabel from "../components/selected";
|
|
4
|
+
import EmptyLabel from "../components/empty";
|
|
5
|
+
import DropdownLabelWithSearch from "../components/withSearch";
|
|
6
|
+
/** Label component */
|
|
7
|
+
const DropdownLabel = ({ caption, selectedItem, onClick, deselectable, className, searchable, onSearchChange, lastSearch, isListVisible, }) => {
|
|
8
|
+
if (searchable) {
|
|
9
|
+
return (_jsx(DropdownLabelWithSearch, { caption: caption, onClick: onClick, className: className, onSearchChange: onSearchChange, deselectable: deselectable, selectedItem: selectedItem, lastSearch: lastSearch, isListVisible: isListVisible }));
|
|
10
|
+
}
|
|
11
|
+
if (isNullOrUndefined(selectedItem)) {
|
|
12
|
+
return (_jsx(EmptyLabel, { caption: caption, onClick: onClick, className: className }));
|
|
13
|
+
}
|
|
14
|
+
return (_jsx(SelectedItemLabel, { deselectable: deselectable, className: className, onClick: onClick, selectedItem: selectedItem }));
|
|
15
|
+
};
|
|
16
|
+
export default DropdownLabel;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { FC } from "react";
|
|
2
|
-
import { DropdownLabelProps } from "../../component";
|
|
3
|
-
/** Props type of `EmptyLabel` */
|
|
4
|
-
|
|
5
|
-
/** Empty dropdown label component (no item selected) */
|
|
6
|
-
declare const EmptyLabel: FC<EmptyLabelProps>;
|
|
7
|
-
export default EmptyLabel;
|
|
1
|
+
import { FC } from "react";
|
|
2
|
+
import { DropdownLabelProps } from "../../component";
|
|
3
|
+
/** Props type of `EmptyLabel` */
|
|
4
|
+
type EmptyLabelProps = Pick<DropdownLabelProps, "caption" | "onClick" | "className">;
|
|
5
|
+
/** Empty dropdown label component (no item selected) */
|
|
6
|
+
declare const EmptyLabel: FC<EmptyLabelProps>;
|
|
7
|
+
export default EmptyLabel;
|
|
8
8
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/dropdown/components/label/components/empty/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAO3B,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAErD,iCAAiC;AACjC,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/dropdown/components/label/components/empty/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAO3B,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAErD,iCAAiC;AACjC,KAAK,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,CAAC,CAAC;AAErF,wDAAwD;AACxD,QAAA,MAAM,UAAU,EAAE,EAAE,CAAC,eAAe,CAyBnC,CAAC;AAEF,eAAe,UAAU,CAAC"}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { getClassName, isNullOrEmpty } from "@bodynarf/utils";
|
|
3
|
-
import { ElementSize } from "../../../../../../types";
|
|
4
|
-
import Icon from "../../../../../icon";
|
|
5
|
-
/** Empty dropdown label component (no item selected) */
|
|
6
|
-
const EmptyLabel = ({ caption, onClick, className, }) => {
|
|
7
|
-
const elClassName = getClassName([
|
|
8
|
-
"
|
|
9
|
-
"
|
|
10
|
-
|
|
11
|
-
"
|
|
12
|
-
"
|
|
13
|
-
]);
|
|
14
|
-
return (_jsxs("label", { className: elClassName, onClick: onClick, children: [_jsx("span", { className: "mr-2", children: caption }), _jsx(Icon, { name: "arrow-down", size: ElementSize.Medium })] }));
|
|
15
|
-
};
|
|
16
|
-
export default EmptyLabel;
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName, isNullOrEmpty } from "@bodynarf/utils";
|
|
3
|
+
import { ElementSize } from "../../../../../../types";
|
|
4
|
+
import Icon from "../../../../../icon";
|
|
5
|
+
/** Empty dropdown label component (no item selected) */
|
|
6
|
+
const EmptyLabel = ({ caption, onClick, className, }) => {
|
|
7
|
+
const elClassName = getClassName([
|
|
8
|
+
"button",
|
|
9
|
+
"dropdown-trigger",
|
|
10
|
+
"bbr-dropdown__label",
|
|
11
|
+
isNullOrEmpty(className) ? "" : `${className}--md`,
|
|
12
|
+
"bbr-dropdown__label--default",
|
|
13
|
+
]);
|
|
14
|
+
return (_jsxs("label", { className: elClassName, onClick: onClick, children: [_jsx("span", { className: "mr-2", children: caption }), _jsx(Icon, { name: "arrow-down", size: ElementSize.Medium })] }));
|
|
15
|
+
};
|
|
16
|
+
export default EmptyLabel;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { FC } from "react";
|
|
2
|
-
import { DropdownLabelProps } from "../../component";
|
|
3
|
-
/** Props type of `SelectedItemLabel` */
|
|
4
|
-
|
|
5
|
-
/** Dropdown label when item is selected */
|
|
6
|
-
declare const SelectedItemLabel: FC<SelectedItemLabelProps>;
|
|
7
|
-
export default SelectedItemLabel;
|
|
1
|
+
import { FC } from "react";
|
|
2
|
+
import { DropdownLabelProps } from "../../component";
|
|
3
|
+
/** Props type of `SelectedItemLabel` */
|
|
4
|
+
type SelectedItemLabelProps = Pick<DropdownLabelProps, "selectedItem" | "onClick" | "deselectable" | "className">;
|
|
5
|
+
/** Dropdown label when item is selected */
|
|
6
|
+
declare const SelectedItemLabel: FC<SelectedItemLabelProps>;
|
|
7
|
+
export default SelectedItemLabel;
|
|
8
8
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/dropdown/components/label/components/selected/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAQ3B,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAErD,wCAAwC;AACxC,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/dropdown/components/label/components/selected/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAQ3B,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAErD,wCAAwC;AACxC,KAAK,sBAAsB,GAAG,IAAI,CAC9B,kBAAkB,EAChB,cAAc,GAAG,SAAS,GAC1B,cAAc,GAAG,WAAW,CACjC,CAAC;AAEF,2CAA2C;AAC3C,QAAA,MAAM,iBAAiB,EAAE,EAAE,CAAC,sBAAsB,CA6CjD,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
|
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { getClassName, isNullOrEmpty, isNullOrUndefined } from "@bodynarf/utils";
|
|
3
|
-
import { ElementSize } from "../../../../../../types";
|
|
4
|
-
import Icon from "../../../../../icon";
|
|
5
|
-
import SelectedItemLabelWithIcon from "../selectedWithIcon";
|
|
6
|
-
/** Dropdown label when item is selected */
|
|
7
|
-
const SelectedItemLabel = ({ selectedItem, onClick, deselectable, className, }) => {
|
|
8
|
-
if (!isNullOrUndefined(selectedItem.icon)) {
|
|
9
|
-
return _jsx(SelectedItemLabelWithIcon, { deselectable: deselectable, onClick: onClick, className: className, selectedItem: selectedItem });
|
|
10
|
-
}
|
|
11
|
-
const elClassName = getClassName([
|
|
12
|
-
"
|
|
13
|
-
"
|
|
14
|
-
|
|
15
|
-
"
|
|
16
|
-
]);
|
|
17
|
-
return (_jsxs("label", { className: elClassName, onClick: onClick, children: [deselectable &&
|
|
18
|
-
_jsx(Icon, { name: "plus-lg", size: ElementSize.Medium }), _jsx("span", { className: deselectable ? "px-2" : "pr-2", title: selectedItem.title, children: selectedItem.displayValue }), _jsx(Icon, { name: "arrow-down", size: ElementSize.Medium })] }));
|
|
19
|
-
};
|
|
20
|
-
export default SelectedItemLabel;
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName, isNullOrEmpty, isNullOrUndefined } from "@bodynarf/utils";
|
|
3
|
+
import { ElementSize } from "../../../../../../types";
|
|
4
|
+
import Icon from "../../../../../icon";
|
|
5
|
+
import SelectedItemLabelWithIcon from "../selectedWithIcon";
|
|
6
|
+
/** Dropdown label when item is selected */
|
|
7
|
+
const SelectedItemLabel = ({ selectedItem, onClick, deselectable, className, }) => {
|
|
8
|
+
if (!isNullOrUndefined(selectedItem.icon)) {
|
|
9
|
+
return (_jsx(SelectedItemLabelWithIcon, { deselectable: deselectable, onClick: onClick, className: className, selectedItem: selectedItem }));
|
|
10
|
+
}
|
|
11
|
+
const elClassName = getClassName([
|
|
12
|
+
"button",
|
|
13
|
+
"dropdown-trigger",
|
|
14
|
+
"bbr-dropdown__label",
|
|
15
|
+
isNullOrEmpty(className) ? "" : `${className}--md`,
|
|
16
|
+
]);
|
|
17
|
+
return (_jsxs("label", { className: elClassName, onClick: onClick, children: [!!deselectable &&
|
|
18
|
+
_jsx(Icon, { name: "plus-lg", size: ElementSize.Medium }), _jsx("span", { className: deselectable ? "px-2" : "pr-2", title: selectedItem.title, children: selectedItem.displayValue }), _jsx(Icon, { name: "arrow-down", size: ElementSize.Medium })] }));
|
|
19
|
+
};
|
|
20
|
+
export default SelectedItemLabel;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { FC } from "react";
|
|
2
|
-
import { DropdownLabelProps } from "../../component";
|
|
3
|
-
/** Props type of `SelectedItemLabelWithIcon` */
|
|
4
|
-
|
|
5
|
-
/** Dropdown label when item is selected and it's have icon */
|
|
6
|
-
declare const SelectedItemLabelWithIcon: FC<SelectedItemLabelWithIconProps>;
|
|
7
|
-
export default SelectedItemLabelWithIcon;
|
|
1
|
+
import { FC } from "react";
|
|
2
|
+
import { DropdownLabelProps } from "../../component";
|
|
3
|
+
/** Props type of `SelectedItemLabelWithIcon` */
|
|
4
|
+
type SelectedItemLabelWithIconProps = Pick<DropdownLabelProps, "selectedItem" | "onClick" | "deselectable" | "className">;
|
|
5
|
+
/** Dropdown label when item is selected and it's have icon */
|
|
6
|
+
declare const SelectedItemLabelWithIcon: FC<SelectedItemLabelWithIconProps>;
|
|
7
|
+
export default SelectedItemLabelWithIcon;
|
|
8
8
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/dropdown/components/label/components/selectedWithIcon/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAO3B,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAErD,gDAAgD;AAChD,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/dropdown/components/label/components/selectedWithIcon/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAO3B,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAErD,gDAAgD;AAChD,KAAK,8BAA8B,GAAG,IAAI,CACtC,kBAAkB,EAChB,cAAc,GAAG,SAAS,GAC1B,cAAc,GAAG,WAAW,CACjC,CAAC;AAEF,8DAA8D;AAC9D,QAAA,MAAM,yBAAyB,EAAE,EAAE,CAAC,8BAA8B,CAgFjE,CAAC;AAEF,eAAe,yBAAyB,CAAC"}
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { getClassName, isNullOrEmpty } from "@bodynarf/utils";
|
|
3
|
-
import { ElementPosition, ElementSize } from "../../../../../../types";
|
|
4
|
-
import Icon from "../../../../../icon";
|
|
5
|
-
/** Dropdown label when item is selected and it's have icon */
|
|
6
|
-
const SelectedItemLabelWithIcon = ({ selectedItem, onClick, deselectable, className, }) => {
|
|
7
|
-
const elClassName = getClassName([
|
|
8
|
-
"
|
|
9
|
-
"
|
|
10
|
-
|
|
11
|
-
"
|
|
12
|
-
]);
|
|
13
|
-
const icon = selectedItem.icon;
|
|
14
|
-
const iconClassName = getClassName([
|
|
15
|
-
icon.className,
|
|
16
|
-
icon.position === ElementPosition.Right
|
|
17
|
-
? "bbr-icon--right"
|
|
18
|
-
: "bbr-icon--left",
|
|
19
|
-
"bbr-dropdown-item__icon"
|
|
20
|
-
]);
|
|
21
|
-
if (icon.position === ElementPosition.Right) {
|
|
22
|
-
return (_jsxs("label", { className: elClassName, onClick: onClick, children: [deselectable &&
|
|
23
|
-
_jsx(Icon, { name: "plus-lg", size: ElementSize.Medium }), _jsxs("span", { className: deselectable ? "px-2" : "pr-2", title: selectedItem.title, children: [selectedItem.displayValue, _jsx(Icon, { name: icon.name, size: icon.size, className: iconClassName })] }), _jsx(Icon, { name: "arrow-down", size: ElementSize.Medium })] }));
|
|
24
|
-
}
|
|
25
|
-
return (_jsxs("label", { className: elClassName, onClick: onClick, children: [deselectable &&
|
|
26
|
-
_jsx(Icon, { name: "plus-lg", size: ElementSize.Medium }), _jsxs("span", { className: deselectable ? "mx-2" : "mr-2", title: selectedItem.title, children: [_jsx(Icon, { name: icon.name, size: icon.size, className: iconClassName }), selectedItem.displayValue] }), _jsx(Icon, { name: "arrow-down", size: ElementSize.Medium })] }));
|
|
27
|
-
};
|
|
28
|
-
export default SelectedItemLabelWithIcon;
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName, isNullOrEmpty } from "@bodynarf/utils";
|
|
3
|
+
import { ElementPosition, ElementSize } from "../../../../../../types";
|
|
4
|
+
import Icon from "../../../../../icon";
|
|
5
|
+
/** Dropdown label when item is selected and it's have icon */
|
|
6
|
+
const SelectedItemLabelWithIcon = ({ selectedItem, onClick, deselectable, className, }) => {
|
|
7
|
+
const elClassName = getClassName([
|
|
8
|
+
"button",
|
|
9
|
+
"dropdown-trigger",
|
|
10
|
+
"bbr-dropdown__label",
|
|
11
|
+
isNullOrEmpty(className) ? "" : `${className}--md`,
|
|
12
|
+
]);
|
|
13
|
+
const icon = selectedItem.icon;
|
|
14
|
+
const iconClassName = getClassName([
|
|
15
|
+
icon.className,
|
|
16
|
+
icon.position === ElementPosition.Right
|
|
17
|
+
? "bbr-icon--right"
|
|
18
|
+
: "bbr-icon--left",
|
|
19
|
+
"bbr-dropdown-item__icon"
|
|
20
|
+
]);
|
|
21
|
+
if (icon.position === ElementPosition.Right) {
|
|
22
|
+
return (_jsxs("label", { className: elClassName, onClick: onClick, children: [!!deselectable &&
|
|
23
|
+
_jsx(Icon, { name: "plus-lg", size: ElementSize.Medium }), _jsxs("span", { className: deselectable ? "px-2" : "pr-2", title: selectedItem.title, children: [selectedItem.displayValue, _jsx(Icon, { name: icon.name, size: icon.size, className: iconClassName })] }), _jsx(Icon, { name: "arrow-down", size: ElementSize.Medium })] }));
|
|
24
|
+
}
|
|
25
|
+
return (_jsxs("label", { className: elClassName, onClick: onClick, children: [!!deselectable &&
|
|
26
|
+
_jsx(Icon, { name: "plus-lg", size: ElementSize.Medium }), _jsxs("span", { className: deselectable ? "mx-2" : "mr-2", title: selectedItem.title, children: [_jsx(Icon, { name: icon.name, size: icon.size, className: iconClassName }), selectedItem.displayValue] }), _jsx(Icon, { name: "arrow-down", size: ElementSize.Medium })] }));
|
|
27
|
+
};
|
|
28
|
+
export default SelectedItemLabelWithIcon;
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { FC } from "react";
|
|
2
|
-
import { DropdownLabelProps } from "../../component";
|
|
3
|
-
import "./style.scss";
|
|
4
|
-
/** Props type of `DropdownLabelWithSearch` */
|
|
5
|
-
|
|
6
|
-
/** Last user search */
|
|
7
|
-
lastSearch: string
|
|
8
|
-
/** Is items list visible */
|
|
9
|
-
isListVisible: boolean;
|
|
10
|
-
/** Handler of search value change by user */
|
|
11
|
-
onSearchChange: (value: string) => void;
|
|
12
|
-
};
|
|
13
|
-
/** Label component with search */
|
|
14
|
-
declare const DropdownLabelWithSearch: FC<DropdownLabelWithSearchProps>;
|
|
15
|
-
export default DropdownLabelWithSearch;
|
|
1
|
+
import { FC } from "react";
|
|
2
|
+
import { DropdownLabelProps } from "../../component";
|
|
3
|
+
import "./style.scss";
|
|
4
|
+
/** Props type of `DropdownLabelWithSearch` */
|
|
5
|
+
type DropdownLabelWithSearchProps = Pick<DropdownLabelProps, "caption" | "className" | "onClick" | "selectedItem" | "deselectable"> & {
|
|
6
|
+
/** Last user search */
|
|
7
|
+
lastSearch: string;
|
|
8
|
+
/** Is items list visible */
|
|
9
|
+
isListVisible: boolean;
|
|
10
|
+
/** Handler of search value change by user */
|
|
11
|
+
onSearchChange: (value: string) => void;
|
|
12
|
+
};
|
|
13
|
+
/** Label component with search */
|
|
14
|
+
declare const DropdownLabelWithSearch: FC<DropdownLabelWithSearchProps>;
|
|
15
|
+
export default DropdownLabelWithSearch;
|
|
16
16
|
//# sourceMappingURL=index.d.ts.map
|