@alfalab/core-components-select 19.1.0 → 19.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Component.responsive.d.ts +1 -1
- package/Component.responsive.js.map +1 -1
- package/components/arrow/index.css +4 -4
- package/components/arrow/index.module.css.js +1 -1
- package/components/arrow/index.module.css.js.map +1 -1
- package/components/base-checkmark/index.css +12 -12
- package/components/base-checkmark/index.module.css.js +1 -1
- package/components/base-checkmark/index.module.css.js.map +1 -1
- package/components/base-option/index.css +14 -14
- package/components/base-option/index.module.css.js +1 -1
- package/components/base-option/index.module.css.js.map +1 -1
- package/components/base-select/Component.d.ts +5 -5
- package/components/base-select/Component.js.map +1 -1
- package/components/base-select/index.css +11 -11
- package/components/base-select/index.module.css.js +1 -1
- package/components/base-select/index.module.css.js.map +1 -1
- package/components/base-select/mobile.css +11 -11
- package/components/base-select/mobile.module.css.js +1 -1
- package/components/base-select/mobile.module.css.js.map +1 -1
- package/components/base-select/types/component-types.d.ts +4 -4
- package/components/checkmark/index.css +11 -11
- package/components/checkmark/index.module.css.js +1 -1
- package/components/checkmark/index.module.css.js.map +1 -1
- package/components/checkmark-mobile/index.css +6 -6
- package/components/checkmark-mobile/index.module.css.js +1 -1
- package/components/checkmark-mobile/index.module.css.js.map +1 -1
- package/components/clear-button/index.css +4 -4
- package/components/clear-button/index.module.css.js +1 -1
- package/components/field/Component.d.ts +1 -1
- package/components/field/index.css +13 -13
- package/components/field/index.module.css.js +1 -1
- package/components/field/index.module.css.js.map +1 -1
- package/components/footer/Component.d.ts +1 -1
- package/components/footer/index.css +4 -4
- package/components/footer/index.module.css.js +1 -1
- package/components/footer/index.module.css.js.map +1 -1
- package/components/native-select/Component.d.ts +1 -1
- package/components/optgroup/index.css +4 -4
- package/components/optgroup/index.module.css.js +1 -1
- package/components/optgroup/index.module.css.js.map +1 -1
- package/components/option/Component.d.ts +1 -2
- package/components/option/desktop/index.css +19 -19
- package/components/option/desktop/index.module.css.js +1 -1
- package/components/option/desktop/index.module.css.js.map +1 -1
- package/components/option/mobile/index.css +16 -16
- package/components/option/mobile/index.module.css.js +1 -1
- package/components/option/mobile/index.module.css.js.map +1 -1
- package/components/options-list/Component.d.ts +25 -25
- package/components/options-list/Component.js +3 -3
- package/components/options-list/Component.js.map +1 -1
- package/components/options-list/index.css +13 -13
- package/components/options-list/index.module.css.js +1 -1
- package/components/options-list/index.module.css.js.map +1 -1
- package/components/search/Component.js.map +1 -1
- package/components/search/index.css +1 -1
- package/components/search/index.module.css.js +1 -1
- package/components/search/index.module.css.js.map +1 -1
- package/components/virtual-options-list/Component.d.ts +25 -25
- package/components/virtual-options-list/Component.js.map +1 -1
- package/components/virtual-options-list/index.css +13 -13
- package/components/virtual-options-list/index.module.css.js +1 -1
- package/components/virtual-options-list/index.module.css.js.map +1 -1
- package/cssm/Component.responsive.d.ts +1 -1
- package/cssm/Component.responsive.js.map +1 -1
- package/cssm/components/base-select/Component.d.ts +5 -5
- package/cssm/components/base-select/Component.js.map +1 -1
- package/cssm/components/base-select/types/component-types.d.ts +4 -4
- package/cssm/components/field/Component.d.ts +1 -1
- package/cssm/components/footer/Component.d.ts +1 -1
- package/cssm/components/native-select/Component.d.ts +1 -1
- package/cssm/components/option/Component.d.ts +1 -2
- package/cssm/components/options-list/Component.d.ts +25 -25
- package/cssm/components/options-list/Component.js +3 -3
- package/cssm/components/options-list/Component.js.map +1 -1
- package/cssm/components/search/Component.js.map +1 -1
- package/cssm/components/virtual-options-list/Component.d.ts +25 -25
- package/cssm/components/virtual-options-list/Component.js.map +1 -1
- package/cssm/desktop/Component.desktop.d.ts +1 -1
- package/cssm/hooks/use-native-scrollbar.d.ts +1 -1
- package/cssm/hooks/use-native-scrollbar.js.map +1 -1
- package/cssm/presets/useLazyLoading/hook.d.ts +2 -2
- package/cssm/presets/useLazyLoading/hook.js.map +1 -1
- package/cssm/presets/useSelectWithApply/hook.d.ts +97 -131
- package/cssm/presets/useSelectWithApply/hook.js.map +1 -1
- package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
- package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
- package/cssm/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
- package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
- package/cssm/presets/useSelectWithLoading/hook.d.ts +1 -1
- package/cssm/typings.d.ts +21 -21
- package/cssm/utils.d.ts +4 -4
- package/cssm/utils.js.map +1 -1
- package/desktop/Component.desktop.d.ts +1 -1
- package/esm/Component.responsive.d.ts +1 -1
- package/esm/Component.responsive.js.map +1 -1
- package/esm/components/arrow/index.css +4 -4
- package/esm/components/arrow/index.module.css.js +1 -1
- package/esm/components/arrow/index.module.css.js.map +1 -1
- package/esm/components/base-checkmark/index.css +12 -12
- package/esm/components/base-checkmark/index.module.css.js +1 -1
- package/esm/components/base-checkmark/index.module.css.js.map +1 -1
- package/esm/components/base-option/index.css +14 -14
- package/esm/components/base-option/index.module.css.js +1 -1
- package/esm/components/base-option/index.module.css.js.map +1 -1
- package/esm/components/base-select/Component.d.ts +5 -5
- package/esm/components/base-select/Component.js.map +1 -1
- package/esm/components/base-select/index.css +11 -11
- package/esm/components/base-select/index.module.css.js +1 -1
- package/esm/components/base-select/index.module.css.js.map +1 -1
- package/esm/components/base-select/mobile.css +11 -11
- package/esm/components/base-select/mobile.module.css.js +1 -1
- package/esm/components/base-select/mobile.module.css.js.map +1 -1
- package/esm/components/base-select/types/component-types.d.ts +4 -4
- package/esm/components/checkmark/index.css +11 -11
- package/esm/components/checkmark/index.module.css.js +1 -1
- package/esm/components/checkmark/index.module.css.js.map +1 -1
- package/esm/components/checkmark-mobile/index.css +6 -6
- package/esm/components/checkmark-mobile/index.module.css.js +1 -1
- package/esm/components/checkmark-mobile/index.module.css.js.map +1 -1
- package/esm/components/clear-button/index.css +4 -4
- package/esm/components/clear-button/index.module.css.js +1 -1
- package/esm/components/field/Component.d.ts +1 -1
- package/esm/components/field/index.css +13 -13
- package/esm/components/field/index.module.css.js +1 -1
- package/esm/components/field/index.module.css.js.map +1 -1
- package/esm/components/footer/Component.d.ts +1 -1
- package/esm/components/footer/index.css +4 -4
- package/esm/components/footer/index.module.css.js +1 -1
- package/esm/components/footer/index.module.css.js.map +1 -1
- package/esm/components/native-select/Component.d.ts +1 -1
- package/esm/components/optgroup/index.css +4 -4
- package/esm/components/optgroup/index.module.css.js +1 -1
- package/esm/components/optgroup/index.module.css.js.map +1 -1
- package/esm/components/option/Component.d.ts +1 -2
- package/esm/components/option/desktop/index.css +19 -19
- package/esm/components/option/desktop/index.module.css.js +1 -1
- package/esm/components/option/desktop/index.module.css.js.map +1 -1
- package/esm/components/option/mobile/index.css +16 -16
- package/esm/components/option/mobile/index.module.css.js +1 -1
- package/esm/components/option/mobile/index.module.css.js.map +1 -1
- package/esm/components/options-list/Component.d.ts +25 -25
- package/esm/components/options-list/Component.js +3 -3
- package/esm/components/options-list/Component.js.map +1 -1
- package/esm/components/options-list/index.css +13 -13
- package/esm/components/options-list/index.module.css.js +1 -1
- package/esm/components/options-list/index.module.css.js.map +1 -1
- package/esm/components/search/Component.js.map +1 -1
- package/esm/components/search/index.css +1 -1
- package/esm/components/search/index.module.css.js +1 -1
- package/esm/components/search/index.module.css.js.map +1 -1
- package/esm/components/virtual-options-list/Component.d.ts +25 -25
- package/esm/components/virtual-options-list/Component.js.map +1 -1
- package/esm/components/virtual-options-list/index.css +13 -13
- package/esm/components/virtual-options-list/index.module.css.js +1 -1
- package/esm/components/virtual-options-list/index.module.css.js.map +1 -1
- package/esm/desktop/Component.desktop.d.ts +1 -1
- package/esm/hooks/use-native-scrollbar.d.ts +1 -1
- package/esm/hooks/use-native-scrollbar.js.map +1 -1
- package/esm/presets/useLazyLoading/hook.d.ts +2 -2
- package/esm/presets/useLazyLoading/hook.js.map +1 -1
- package/esm/presets/useSelectWithApply/hook.d.ts +97 -131
- package/esm/presets/useSelectWithApply/hook.js.map +1 -1
- package/esm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
- package/esm/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
- package/esm/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
- package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
- package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
- package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map +1 -1
- package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
- package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.css +4 -4
- package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
- package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
- package/esm/presets/useSelectWithLoading/hook.d.ts +1 -1
- package/esm/presets/useSelectWithLoading/index.css +1 -1
- package/esm/presets/useSelectWithLoading/index.module.css.js +1 -1
- package/esm/typings.d.ts +21 -21
- package/esm/utils.d.ts +4 -4
- package/esm/utils.js.map +1 -1
- package/hooks/use-native-scrollbar.d.ts +1 -1
- package/hooks/use-native-scrollbar.js.map +1 -1
- package/modern/Component.responsive.d.ts +1 -1
- package/modern/Component.responsive.js.map +1 -1
- package/modern/components/arrow/index.css +4 -4
- package/modern/components/arrow/index.module.css.js +1 -1
- package/modern/components/arrow/index.module.css.js.map +1 -1
- package/modern/components/base-checkmark/index.css +12 -12
- package/modern/components/base-checkmark/index.module.css.js +1 -1
- package/modern/components/base-checkmark/index.module.css.js.map +1 -1
- package/modern/components/base-option/index.css +14 -14
- package/modern/components/base-option/index.module.css.js +1 -1
- package/modern/components/base-option/index.module.css.js.map +1 -1
- package/modern/components/base-select/Component.d.ts +5 -5
- package/modern/components/base-select/Component.js.map +1 -1
- package/modern/components/base-select/index.css +11 -11
- package/modern/components/base-select/index.module.css.js +1 -1
- package/modern/components/base-select/index.module.css.js.map +1 -1
- package/modern/components/base-select/mobile.css +11 -11
- package/modern/components/base-select/mobile.module.css.js +1 -1
- package/modern/components/base-select/mobile.module.css.js.map +1 -1
- package/modern/components/base-select/types/component-types.d.ts +4 -4
- package/modern/components/checkmark/index.css +11 -11
- package/modern/components/checkmark/index.module.css.js +1 -1
- package/modern/components/checkmark/index.module.css.js.map +1 -1
- package/modern/components/checkmark-mobile/index.css +6 -6
- package/modern/components/checkmark-mobile/index.module.css.js +1 -1
- package/modern/components/checkmark-mobile/index.module.css.js.map +1 -1
- package/modern/components/clear-button/index.css +4 -4
- package/modern/components/clear-button/index.module.css.js +1 -1
- package/modern/components/field/Component.d.ts +1 -1
- package/modern/components/field/index.css +13 -13
- package/modern/components/field/index.module.css.js +1 -1
- package/modern/components/field/index.module.css.js.map +1 -1
- package/modern/components/footer/Component.d.ts +1 -1
- package/modern/components/footer/index.css +4 -4
- package/modern/components/footer/index.module.css.js +1 -1
- package/modern/components/footer/index.module.css.js.map +1 -1
- package/modern/components/native-select/Component.d.ts +1 -1
- package/modern/components/optgroup/index.css +4 -4
- package/modern/components/optgroup/index.module.css.js +1 -1
- package/modern/components/optgroup/index.module.css.js.map +1 -1
- package/modern/components/option/Component.d.ts +1 -2
- package/modern/components/option/desktop/index.css +19 -19
- package/modern/components/option/desktop/index.module.css.js +1 -1
- package/modern/components/option/desktop/index.module.css.js.map +1 -1
- package/modern/components/option/mobile/index.css +16 -16
- package/modern/components/option/mobile/index.module.css.js +1 -1
- package/modern/components/option/mobile/index.module.css.js.map +1 -1
- package/modern/components/options-list/Component.d.ts +25 -25
- package/modern/components/options-list/Component.js +3 -3
- package/modern/components/options-list/Component.js.map +1 -1
- package/modern/components/options-list/index.css +13 -13
- package/modern/components/options-list/index.module.css.js +1 -1
- package/modern/components/options-list/index.module.css.js.map +1 -1
- package/modern/components/search/Component.js.map +1 -1
- package/modern/components/search/index.css +1 -1
- package/modern/components/search/index.module.css.js +1 -1
- package/modern/components/search/index.module.css.js.map +1 -1
- package/modern/components/virtual-options-list/Component.d.ts +25 -25
- package/modern/components/virtual-options-list/Component.js.map +1 -1
- package/modern/components/virtual-options-list/index.css +13 -13
- package/modern/components/virtual-options-list/index.module.css.js +1 -1
- package/modern/components/virtual-options-list/index.module.css.js.map +1 -1
- package/modern/desktop/Component.desktop.d.ts +1 -1
- package/modern/hooks/use-native-scrollbar.d.ts +1 -1
- package/modern/hooks/use-native-scrollbar.js.map +1 -1
- package/modern/presets/useLazyLoading/hook.d.ts +2 -2
- package/modern/presets/useLazyLoading/hook.js.map +1 -1
- package/modern/presets/useSelectWithApply/hook.d.ts +97 -131
- package/modern/presets/useSelectWithApply/hook.js.map +1 -1
- package/modern/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
- package/modern/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
- package/modern/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
- package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
- package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
- package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map +1 -1
- package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
- package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.css +4 -4
- package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
- package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
- package/modern/presets/useSelectWithLoading/hook.d.ts +1 -1
- package/modern/presets/useSelectWithLoading/index.css +1 -1
- package/modern/presets/useSelectWithLoading/index.module.css.js +1 -1
- package/modern/typings.d.ts +21 -21
- package/modern/utils.d.ts +4 -4
- package/modern/utils.js.map +1 -1
- package/moderncssm/Component.responsive.d.ts +1 -1
- package/moderncssm/Component.responsive.js.map +1 -1
- package/moderncssm/components/base-select/Component.d.ts +5 -5
- package/moderncssm/components/base-select/Component.js.map +1 -1
- package/moderncssm/components/base-select/types/component-types.d.ts +4 -4
- package/moderncssm/components/field/Component.d.ts +1 -1
- package/moderncssm/components/footer/Component.d.ts +1 -1
- package/moderncssm/components/native-select/Component.d.ts +1 -1
- package/moderncssm/components/option/Component.d.ts +1 -2
- package/moderncssm/components/options-list/Component.d.ts +25 -25
- package/moderncssm/components/options-list/Component.js +3 -3
- package/moderncssm/components/options-list/Component.js.map +1 -1
- package/moderncssm/components/search/Component.js.map +1 -1
- package/moderncssm/components/virtual-options-list/Component.d.ts +25 -25
- package/moderncssm/components/virtual-options-list/Component.js.map +1 -1
- package/moderncssm/desktop/Component.desktop.d.ts +1 -1
- package/moderncssm/hooks/use-native-scrollbar.d.ts +1 -1
- package/moderncssm/hooks/use-native-scrollbar.js.map +1 -1
- package/moderncssm/presets/useLazyLoading/hook.d.ts +2 -2
- package/moderncssm/presets/useLazyLoading/hook.js.map +1 -1
- package/moderncssm/presets/useSelectWithApply/hook.d.ts +97 -131
- package/moderncssm/presets/useSelectWithApply/hook.js.map +1 -1
- package/moderncssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
- package/moderncssm/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
- package/moderncssm/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
- package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
- package/moderncssm/presets/useSelectWithLoading/hook.d.ts +1 -1
- package/moderncssm/typings.d.ts +21 -21
- package/moderncssm/utils.d.ts +4 -4
- package/moderncssm/utils.js.map +1 -1
- package/package.json +14 -14
- package/presets/useLazyLoading/hook.d.ts +2 -2
- package/presets/useLazyLoading/hook.js.map +1 -1
- package/presets/useSelectWithApply/hook.d.ts +97 -130
- package/presets/useSelectWithApply/hook.js.map +1 -1
- package/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
- package/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
- package/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
- package/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
- package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
- package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map +1 -1
- package/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
- package/presets/useSelectWithApply/options-list-with-apply/header/index.css +4 -4
- package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
- package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
- package/presets/useSelectWithLoading/hook.d.ts +1 -1
- package/presets/useSelectWithLoading/index.css +1 -1
- package/presets/useSelectWithLoading/index.module.css.js +1 -1
- package/src/components/arrow/index.module.css +1 -1
- package/src/components/base-checkmark/index.module.css +1 -1
- package/src/components/base-option/index.module.css +1 -1
- package/src/components/base-select/index.module.css +1 -1
- package/src/components/base-select/mobile.module.css +1 -1
- package/src/components/checkmark/index.module.css +1 -1
- package/src/components/checkmark-mobile/index.module.css +1 -1
- package/src/components/field/index.module.css +1 -1
- package/src/components/footer/index.module.css +1 -1
- package/src/components/optgroup/index.module.css +1 -1
- package/src/components/option/desktop/index.module.css +1 -1
- package/src/components/option/index.module.css +1 -1
- package/src/components/option/mobile/index.module.css +1 -1
- package/src/components/options-list/Component.tsx +3 -3
- package/src/components/options-list/index.module.css +1 -1
- package/src/components/search/index.module.css +1 -1
- package/src/components/virtual-options-list/index.module.css +1 -1
- package/src/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css +1 -1
- package/src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +1 -1
- package/typings.d.ts +21 -21
- package/utils.d.ts +4 -4
- package/utils.js.map +1 -1
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
1
|
import { type AnyObject, type BaseSelectProps, type OptionShape } from '../../typings';
|
|
3
|
-
export
|
|
2
|
+
export type UseSelectWithApplyProps = {
|
|
4
3
|
/**
|
|
5
4
|
* Список выбранных пунктов
|
|
6
5
|
*/
|
|
@@ -63,116 +62,83 @@ export declare type UseSelectWithApplyProps = {
|
|
|
63
62
|
};
|
|
64
63
|
export declare function useSelectWithApply({ options, selected, onChange, onSelectAllClick, OptionsList, optionsListProps, showClear, showSelectAll, showHeaderWithSelectAll, checkmarkPosition, showSearch, searchProps, applyName, resetName, }: UseSelectWithApplyProps): {
|
|
65
64
|
OptionsList: import("react").ForwardRefExoticComponent<Pick<import("../../typings").SelectProps, "client"> & {
|
|
66
|
-
className?: string
|
|
67
|
-
optionGroupClassName?: string
|
|
68
|
-
scrollbarClassName?: string
|
|
69
|
-
footerClassName?: string
|
|
70
|
-
size?: 40 | 48 | 56 | 64 | 72
|
|
65
|
+
className?: string;
|
|
66
|
+
optionGroupClassName?: string;
|
|
67
|
+
scrollbarClassName?: string;
|
|
68
|
+
footerClassName?: string;
|
|
69
|
+
size?: 40 | 48 | 56 | 64 | 72;
|
|
71
70
|
Option: import("react").ComponentType<import("../../typings").OptionProps>;
|
|
72
71
|
getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
|
|
73
|
-
groupOptionProps?: AnyObject
|
|
74
|
-
selectedItems?: OptionShape[]
|
|
72
|
+
groupOptionProps?: AnyObject;
|
|
73
|
+
selectedItems?: OptionShape[];
|
|
75
74
|
setSelectedItems: (selected: OptionShape[]) => void;
|
|
76
75
|
toggleMenu: () => void;
|
|
77
76
|
header?: import("react").ReactNode;
|
|
78
77
|
footer?: import("react").ReactNode;
|
|
79
|
-
options?:
|
|
80
|
-
flatOptions?: OptionShape[]
|
|
81
|
-
highlightedIndex?: number
|
|
82
|
-
open?: boolean
|
|
83
|
-
Optgroup?:
|
|
78
|
+
options?: Array<OptionShape | import("../../typings").GroupShape>;
|
|
79
|
+
flatOptions?: OptionShape[];
|
|
80
|
+
highlightedIndex?: number;
|
|
81
|
+
open?: boolean;
|
|
82
|
+
Optgroup?: BaseSelectProps["Optgroup"];
|
|
84
83
|
emptyPlaceholder?: import("react").ReactNode;
|
|
85
|
-
visibleOptions?: number
|
|
86
|
-
onScroll?: (
|
|
87
|
-
dataTestId?: string
|
|
88
|
-
inputProps?: import("@alfalab/core-components-input").InputProps
|
|
89
|
-
showFooter?: boolean
|
|
90
|
-
nativeScrollbar?: boolean
|
|
91
|
-
optionsListWidth?: "
|
|
92
|
-
onApply?: (
|
|
93
|
-
onClear?: (
|
|
94
|
-
setHighlightedIndex?: (
|
|
95
|
-
search?: string
|
|
96
|
-
multiple?: boolean
|
|
97
|
-
limitDynamicOptionGroupSize?:
|
|
84
|
+
visibleOptions?: number;
|
|
85
|
+
onScroll?: (event: import("react").MouseEvent<HTMLDivElement>) => void;
|
|
86
|
+
dataTestId?: string;
|
|
87
|
+
inputProps?: import("@alfalab/core-components-input").InputProps;
|
|
88
|
+
showFooter?: boolean;
|
|
89
|
+
nativeScrollbar?: boolean;
|
|
90
|
+
optionsListWidth?: BaseSelectProps["optionsListWidth"];
|
|
91
|
+
onApply?: () => void;
|
|
92
|
+
onClear?: () => void;
|
|
93
|
+
setHighlightedIndex?: (index: number) => void;
|
|
94
|
+
search?: string;
|
|
95
|
+
multiple?: boolean;
|
|
96
|
+
limitDynamicOptionGroupSize?: BaseSelectProps["limitDynamicOptionGroupSize"];
|
|
98
97
|
} & {
|
|
99
|
-
showClear?: boolean
|
|
100
|
-
onClose?: (
|
|
101
|
-
selectedDraft?: OptionShape[]
|
|
102
|
-
OptionsList?: import("react").FC<
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
Option: import("react").ComponentType<import("../../typings").OptionProps>;
|
|
109
|
-
getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
|
|
110
|
-
groupOptionProps?: AnyObject | undefined;
|
|
111
|
-
selectedItems?: OptionShape[] | undefined;
|
|
112
|
-
setSelectedItems: (selected: OptionShape[]) => void;
|
|
113
|
-
toggleMenu: () => void;
|
|
114
|
-
header?: import("react").ReactNode;
|
|
115
|
-
footer?: import("react").ReactNode;
|
|
116
|
-
options?: (OptionShape | import("../../typings").GroupShape)[] | undefined;
|
|
117
|
-
flatOptions?: OptionShape[] | undefined;
|
|
118
|
-
highlightedIndex?: number | undefined;
|
|
119
|
-
open?: boolean | undefined;
|
|
120
|
-
Optgroup?: import("react").ComponentType<import("../../typings").OptgroupProps> | undefined;
|
|
121
|
-
emptyPlaceholder?: import("react").ReactNode;
|
|
122
|
-
visibleOptions?: number | undefined;
|
|
123
|
-
onScroll?: ((event: import("react").MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
|
|
124
|
-
dataTestId?: string | undefined;
|
|
125
|
-
inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
|
|
126
|
-
showFooter?: boolean | undefined;
|
|
127
|
-
nativeScrollbar?: boolean | undefined;
|
|
128
|
-
optionsListWidth?: "field" | "content" | undefined;
|
|
129
|
-
onApply?: (() => void) | undefined;
|
|
130
|
-
onClear?: (() => void) | undefined;
|
|
131
|
-
setHighlightedIndex?: ((index: number) => void) | undefined;
|
|
132
|
-
search?: string | undefined;
|
|
133
|
-
multiple?: boolean | undefined;
|
|
134
|
-
limitDynamicOptionGroupSize?: boolean | undefined;
|
|
135
|
-
} & import("react").RefAttributes<HTMLDivElement>> | undefined;
|
|
136
|
-
Footer?: import("react").FC<import("./options-list-with-apply/footer/Component").FooterProps> | undefined;
|
|
137
|
-
Header?: import("react").FC<import("./options-list-with-apply/header/Component").HeaderProps> | undefined;
|
|
138
|
-
headerProps?: import("./options-list-with-apply/header/Component").HeaderProps | undefined;
|
|
139
|
-
showHeaderWithSelectAll?: boolean | undefined;
|
|
140
|
-
setSelectedDraft?: ((selectedDraft: OptionShape[]) => void) | undefined;
|
|
98
|
+
showClear?: boolean;
|
|
99
|
+
onClose?: () => void;
|
|
100
|
+
selectedDraft?: OptionShape[];
|
|
101
|
+
OptionsList?: import("react").FC<import("../../typings").OptionsListProps & import("react").RefAttributes<HTMLDivElement>>;
|
|
102
|
+
Footer?: import("react").FC<import("./options-list-with-apply/footer/Component").FooterProps>;
|
|
103
|
+
Header?: import("react").FC<import("./options-list-with-apply/header/Component").HeaderProps>;
|
|
104
|
+
headerProps?: import("./options-list-with-apply/header/Component").HeaderProps;
|
|
105
|
+
showHeaderWithSelectAll?: boolean;
|
|
106
|
+
setSelectedDraft?: (selectedDraft: OptionShape[]) => void;
|
|
141
107
|
} & import("react").RefAttributes<HTMLDivElement>>;
|
|
142
108
|
optionsListProps: {
|
|
143
109
|
OptionsList: import("react").ComponentType<Pick<import("../../typings").SelectProps, "client"> & {
|
|
144
|
-
className?: string
|
|
145
|
-
optionGroupClassName?: string
|
|
146
|
-
scrollbarClassName?: string
|
|
147
|
-
footerClassName?: string
|
|
148
|
-
size?: 40 | 48 | 56 | 64 | 72
|
|
110
|
+
className?: string;
|
|
111
|
+
optionGroupClassName?: string;
|
|
112
|
+
scrollbarClassName?: string;
|
|
113
|
+
footerClassName?: string;
|
|
114
|
+
size?: 40 | 48 | 56 | 64 | 72;
|
|
149
115
|
Option: import("react").ComponentType<import("../../typings").OptionProps>;
|
|
150
116
|
getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
|
|
151
|
-
groupOptionProps?: AnyObject
|
|
152
|
-
selectedItems?: OptionShape[]
|
|
117
|
+
groupOptionProps?: AnyObject;
|
|
118
|
+
selectedItems?: OptionShape[];
|
|
153
119
|
setSelectedItems: (selected: OptionShape[]) => void;
|
|
154
120
|
toggleMenu: () => void;
|
|
155
121
|
header?: import("react").ReactNode;
|
|
156
122
|
footer?: import("react").ReactNode;
|
|
157
|
-
options?:
|
|
158
|
-
flatOptions?: OptionShape[]
|
|
159
|
-
highlightedIndex?: number
|
|
160
|
-
open?: boolean
|
|
161
|
-
Optgroup?:
|
|
123
|
+
options?: Array<OptionShape | import("../../typings").GroupShape>;
|
|
124
|
+
flatOptions?: OptionShape[];
|
|
125
|
+
highlightedIndex?: number;
|
|
126
|
+
open?: boolean;
|
|
127
|
+
Optgroup?: BaseSelectProps["Optgroup"];
|
|
162
128
|
emptyPlaceholder?: import("react").ReactNode;
|
|
163
|
-
visibleOptions?: number
|
|
164
|
-
onScroll?: (
|
|
165
|
-
dataTestId?: string
|
|
166
|
-
inputProps?: import("@alfalab/core-components-input").InputProps
|
|
167
|
-
showFooter?: boolean
|
|
168
|
-
nativeScrollbar?: boolean
|
|
169
|
-
optionsListWidth?: "
|
|
170
|
-
onApply?: (
|
|
171
|
-
onClear?: (
|
|
172
|
-
setHighlightedIndex?: (
|
|
173
|
-
search?: string
|
|
174
|
-
multiple?: boolean
|
|
175
|
-
limitDynamicOptionGroupSize?:
|
|
129
|
+
visibleOptions?: number;
|
|
130
|
+
onScroll?: (event: import("react").MouseEvent<HTMLDivElement>) => void;
|
|
131
|
+
dataTestId?: string;
|
|
132
|
+
inputProps?: import("@alfalab/core-components-input").InputProps;
|
|
133
|
+
showFooter?: boolean;
|
|
134
|
+
nativeScrollbar?: boolean;
|
|
135
|
+
optionsListWidth?: BaseSelectProps["optionsListWidth"];
|
|
136
|
+
onApply?: () => void;
|
|
137
|
+
onClear?: () => void;
|
|
138
|
+
setHighlightedIndex?: (index: number) => void;
|
|
139
|
+
search?: string;
|
|
140
|
+
multiple?: boolean;
|
|
141
|
+
limitDynamicOptionGroupSize?: BaseSelectProps["limitDynamicOptionGroupSize"];
|
|
176
142
|
} & import("react").RefAttributes<HTMLDivElement>> | undefined;
|
|
177
143
|
showClear: boolean;
|
|
178
144
|
onClear: () => void;
|
|
@@ -194,49 +160,49 @@ export declare function useSelectWithApply({ options, selected, onChange, onSele
|
|
|
194
160
|
searchProps: {
|
|
195
161
|
value: string;
|
|
196
162
|
onChange: ((value: string) => void) | undefined;
|
|
197
|
-
componentProps?: import("../../typings").SearchProps
|
|
198
|
-
accessor?: (
|
|
199
|
-
filterFn?: (
|
|
200
|
-
filterGroup?: boolean
|
|
201
|
-
groupAccessor?: (
|
|
163
|
+
componentProps?: import("../../typings").SearchProps;
|
|
164
|
+
accessor?: (option: OptionShape) => string;
|
|
165
|
+
filterFn?: (optionText: string, search: string) => boolean;
|
|
166
|
+
filterGroup?: boolean;
|
|
167
|
+
groupAccessor?: (group: import("../../typings").GroupShape) => string | undefined;
|
|
202
168
|
} | undefined;
|
|
203
169
|
originalProps: {
|
|
204
170
|
options: (OptionShape | import("../../typings").GroupShape)[];
|
|
205
171
|
selected: string | OptionShape | (string | OptionShape)[] | null | undefined;
|
|
206
172
|
onChange: (payload: import("../../typings").BaseSelectChangePayload) => void;
|
|
207
173
|
OptionsList: import("react").ComponentType<Pick<import("../../typings").SelectProps, "client"> & {
|
|
208
|
-
className?: string
|
|
209
|
-
optionGroupClassName?: string
|
|
210
|
-
scrollbarClassName?: string
|
|
211
|
-
footerClassName?: string
|
|
212
|
-
size?: 40 | 48 | 56 | 64 | 72
|
|
174
|
+
className?: string;
|
|
175
|
+
optionGroupClassName?: string;
|
|
176
|
+
scrollbarClassName?: string;
|
|
177
|
+
footerClassName?: string;
|
|
178
|
+
size?: 40 | 48 | 56 | 64 | 72;
|
|
213
179
|
Option: import("react").ComponentType<import("../../typings").OptionProps>;
|
|
214
180
|
getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
|
|
215
|
-
groupOptionProps?: AnyObject
|
|
216
|
-
selectedItems?: OptionShape[]
|
|
181
|
+
groupOptionProps?: AnyObject;
|
|
182
|
+
selectedItems?: OptionShape[];
|
|
217
183
|
setSelectedItems: (selected: OptionShape[]) => void;
|
|
218
184
|
toggleMenu: () => void;
|
|
219
185
|
header?: import("react").ReactNode;
|
|
220
186
|
footer?: import("react").ReactNode;
|
|
221
|
-
options?:
|
|
222
|
-
flatOptions?: OptionShape[]
|
|
223
|
-
highlightedIndex?: number
|
|
224
|
-
open?: boolean
|
|
225
|
-
Optgroup?:
|
|
187
|
+
options?: Array<OptionShape | import("../../typings").GroupShape>;
|
|
188
|
+
flatOptions?: OptionShape[];
|
|
189
|
+
highlightedIndex?: number;
|
|
190
|
+
open?: boolean;
|
|
191
|
+
Optgroup?: BaseSelectProps["Optgroup"];
|
|
226
192
|
emptyPlaceholder?: import("react").ReactNode;
|
|
227
|
-
visibleOptions?: number
|
|
228
|
-
onScroll?: (
|
|
229
|
-
dataTestId?: string
|
|
230
|
-
inputProps?: import("@alfalab/core-components-input").InputProps
|
|
231
|
-
showFooter?: boolean
|
|
232
|
-
nativeScrollbar?: boolean
|
|
233
|
-
optionsListWidth?: "
|
|
234
|
-
onApply?: (
|
|
235
|
-
onClear?: (
|
|
236
|
-
setHighlightedIndex?: (
|
|
237
|
-
search?: string
|
|
238
|
-
multiple?: boolean
|
|
239
|
-
limitDynamicOptionGroupSize?:
|
|
193
|
+
visibleOptions?: number;
|
|
194
|
+
onScroll?: (event: import("react").MouseEvent<HTMLDivElement>) => void;
|
|
195
|
+
dataTestId?: string;
|
|
196
|
+
inputProps?: import("@alfalab/core-components-input").InputProps;
|
|
197
|
+
showFooter?: boolean;
|
|
198
|
+
nativeScrollbar?: boolean;
|
|
199
|
+
optionsListWidth?: BaseSelectProps["optionsListWidth"];
|
|
200
|
+
onApply?: () => void;
|
|
201
|
+
onClear?: () => void;
|
|
202
|
+
setHighlightedIndex?: (index: number) => void;
|
|
203
|
+
search?: string;
|
|
204
|
+
multiple?: boolean;
|
|
205
|
+
limitDynamicOptionGroupSize?: BaseSelectProps["limitDynamicOptionGroupSize"];
|
|
240
206
|
} & import("react").RefAttributes<HTMLDivElement>> | undefined;
|
|
241
207
|
optionsListProps: unknown;
|
|
242
208
|
showClear: boolean;
|
|
@@ -245,13 +211,13 @@ export declare function useSelectWithApply({ options, selected, onChange, onSele
|
|
|
245
211
|
checkmarkPosition: "before" | "after";
|
|
246
212
|
showSearch: boolean;
|
|
247
213
|
searchProps: {
|
|
248
|
-
componentProps?: import("../../typings").SearchProps
|
|
249
|
-
accessor?: (
|
|
250
|
-
filterFn?: (
|
|
251
|
-
value?: string
|
|
252
|
-
onChange?: (
|
|
253
|
-
filterGroup?: boolean
|
|
254
|
-
groupAccessor?: (
|
|
214
|
+
componentProps?: import("../../typings").SearchProps;
|
|
215
|
+
accessor?: (option: OptionShape) => string;
|
|
216
|
+
filterFn?: (optionText: string, search: string) => boolean;
|
|
217
|
+
value?: string;
|
|
218
|
+
onChange?: (value: string) => void;
|
|
219
|
+
filterGroup?: boolean;
|
|
220
|
+
groupAccessor?: (group: import("../../typings").GroupShape) => string | undefined;
|
|
255
221
|
};
|
|
256
222
|
applyName: string;
|
|
257
223
|
resetName: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hook.js","sources":["../../../src/presets/useSelectWithApply/hook.ts"],"sourcesContent":["import { useEffect, useMemo, useRef, useState } from 'react';\nimport reactFastCompare from 'react-fast-compare';\n\nimport { SELECT_ALL_KEY } from '../../consts';\nimport { type AnyObject, type BaseSelectProps, type OptionShape } from '../../typings';\nimport {\n defaultAccessor,\n defaultFilterFn,\n defaultGroupAccessor,\n isGroup,\n processOptions,\n} from '../../utils';\n\nimport { OptionsListWithApply } from './options-list-with-apply';\n\nexport type UseSelectWithApplyProps = {\n /**\n * Список выбранных пунктов\n */\n selected: BaseSelectProps['selected'];\n\n /**\n * Список вариантов выбора\n */\n options: BaseSelectProps['options'];\n\n /**\n * Обработчик выбора\n */\n onChange: BaseSelectProps['onChange'];\n\n /**\n * Дополнительный обработчик клика на чекбокс выбрать все\n */\n onSelectAllClick?: (selectedMultiple: OptionShape[]) => void;\n\n /**\n * Компонент выпадающего меню\n */\n OptionsList?: BaseSelectProps['OptionsList'];\n\n /**\n * Пропсы, которые будут прокинуты в компонент списка\n */\n optionsListProps?: BaseSelectProps['optionsListProps'];\n\n /**\n * Включает отображение поиска\n */\n showSearch?: BaseSelectProps['showSearch'];\n\n /**\n * Настройки поиска\n */\n searchProps?: BaseSelectProps['searchProps'];\n\n /**\n * Показывать кнопку очистки\n */\n showClear?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\"\n */\n showSelectAll?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\" в заголовке списка\n */\n showHeaderWithSelectAll?: boolean;\n\n /**\n * Значение name при применении выбора\n * @default 'apply-footer'\n */\n applyName?: string;\n\n /**\n * Значение name при сбросе выбора\n * @default 'reset-footer'\n */\n resetName?: string;\n\n /**\n * Позиция чекбокса \"Выбрать все\" в Header\n * @default 'before'\n */\n checkmarkPosition?: 'before' | 'after';\n};\n\nconst selectAllOption = { key: SELECT_ALL_KEY, content: 'Выбрать все' };\n\nexport function useSelectWithApply({\n options,\n selected,\n onChange = () => null,\n onSelectAllClick = () => null,\n OptionsList,\n optionsListProps = {},\n showClear = true,\n showSelectAll = false,\n showHeaderWithSelectAll = false,\n checkmarkPosition = 'before',\n showSearch = false,\n searchProps = {},\n applyName = 'apply-footer',\n resetName = 'reset-footer',\n}: UseSelectWithApplyProps) {\n const [searchState, setSearchState] = useState('');\n\n const [search, setSearch] =\n typeof searchProps?.value === 'string'\n ? [searchProps.value, searchProps.onChange]\n : [searchState, setSearchState];\n\n const accessor = searchProps.accessor || defaultAccessor;\n const filterFn = searchProps.filterFn || defaultFilterFn;\n const groupAccessor = searchProps.groupAccessor ?? defaultGroupAccessor;\n const filterGroup = searchProps.filterGroup ?? false;\n\n const { flatOptions, filteredOptions, selectedOptions } = useMemo(\n () =>\n processOptions(\n options,\n selected,\n showSearch\n ? (option) => {\n if (isGroup(option)) {\n const groupAccessorValue = groupAccessor(option);\n\n return (\n typeof groupAccessorValue === 'string' &&\n filterFn(groupAccessorValue, search)\n );\n }\n\n return filterFn(accessor(option), search);\n }\n : undefined,\n filterGroup,\n ),\n [options, selected, showSearch, filterGroup, filterFn, accessor, search, groupAccessor],\n );\n const [selectedDraft, setSelectedDraft] = useState<OptionShape[]>(selectedOptions);\n\n const selectedOptionsRef = useRef<OptionShape[]>(selectedOptions);\n\n const handleApply = () => {\n onChange({\n selected: selectedDraft[0],\n selectedMultiple: selectedDraft,\n initiator: null,\n name: applyName,\n });\n };\n\n const handleClear = () => {\n setSelectedDraft([]);\n onChange({\n selected: null,\n selectedMultiple: [],\n initiator: null,\n name: resetName,\n });\n };\n\n const handleToggleAll = () => {\n const optionsToSet = flatOptions.length === selectedDraft.length ? [] : flatOptions;\n\n onSelectAllClick(optionsToSet);\n setSelectedDraft(optionsToSet);\n };\n\n const selectedKeys = useMemo(() => selectedDraft.map(({ key }) => key), [selectedDraft]);\n\n const handleChange: Required<BaseSelectProps>['onChange'] = ({ initiator, ...restArgs }) => {\n if (!initiator) {\n onChange({\n initiator: null,\n ...restArgs,\n });\n\n return;\n }\n\n const initiatorSelected =\n selectedDraft.some(\n (selectedDraftOption) => selectedDraftOption.key === initiator.key,\n ) ||\n (initiator.key === SELECT_ALL_KEY &&\n (selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key))));\n\n if (initiator.key === SELECT_ALL_KEY) {\n setSelectedDraft(initiatorSelected ? [] : flatOptions);\n } else {\n setSelectedDraft(\n initiatorSelected\n ? selectedDraft.filter((o) => o.key !== initiator.key)\n : selectedDraft.concat(initiator),\n );\n }\n };\n\n const handleClose = () => setSelectedDraft(selectedOptionsRef.current);\n\n useEffect(() => {\n // устанавливать selectedDraft если selectedOptions изменились\n if (!reactFastCompare(selectedOptionsRef.current, selectedOptions)) {\n setSelectedDraft(selectedOptions);\n }\n selectedOptionsRef.current = selectedOptions;\n }, [selectedOptions]);\n\n const memoizedOptions = useMemo(\n () =>\n filteredOptions.length && showSelectAll\n ? [selectAllOption, ...filteredOptions]\n : filteredOptions,\n [filteredOptions, showSelectAll],\n );\n\n return {\n OptionsList: OptionsListWithApply,\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n OptionsList,\n showClear,\n onClear: handleClear,\n onApply: handleApply,\n onClose: handleClose,\n selectedDraft,\n setSelectedDraft,\n showHeaderWithSelectAll,\n headerProps: {\n ...(optionsListProps as AnyObject)?.headerProps,\n indeterminate: selectedDraft.length > 0,\n checked:\n selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key)),\n onChange: handleToggleAll,\n checkmarkPosition,\n },\n },\n multiple: true,\n options: memoizedOptions,\n onChange: handleChange,\n selected,\n showSearch,\n searchProps: showSearch\n ? {\n ...searchProps,\n value: search,\n onChange: setSearch,\n }\n : undefined,\n /* Костыль для респонсив селекта. В мобильную версию хук уже зашит, и это единственный передать в мобилку оригинальные пропсы */\n originalProps: {\n options,\n selected,\n onChange,\n OptionsList,\n optionsListProps,\n showClear,\n showSelectAll,\n showHeaderWithSelectAll,\n checkmarkPosition,\n showSearch,\n searchProps,\n applyName,\n resetName,\n },\n };\n}\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"hook.js","sources":["../../../src/presets/useSelectWithApply/hook.ts"],"sourcesContent":["import { useEffect, useMemo, useRef, useState } from 'react';\nimport reactFastCompare from 'react-fast-compare';\n\nimport { SELECT_ALL_KEY } from '../../consts';\nimport { type AnyObject, type BaseSelectProps, type OptionShape } from '../../typings';\nimport {\n defaultAccessor,\n defaultFilterFn,\n defaultGroupAccessor,\n isGroup,\n processOptions,\n} from '../../utils';\n\nimport { OptionsListWithApply } from './options-list-with-apply';\n\nexport type UseSelectWithApplyProps = {\n /**\n * Список выбранных пунктов\n */\n selected: BaseSelectProps['selected'];\n\n /**\n * Список вариантов выбора\n */\n options: BaseSelectProps['options'];\n\n /**\n * Обработчик выбора\n */\n onChange: BaseSelectProps['onChange'];\n\n /**\n * Дополнительный обработчик клика на чекбокс выбрать все\n */\n onSelectAllClick?: (selectedMultiple: OptionShape[]) => void;\n\n /**\n * Компонент выпадающего меню\n */\n OptionsList?: BaseSelectProps['OptionsList'];\n\n /**\n * Пропсы, которые будут прокинуты в компонент списка\n */\n optionsListProps?: BaseSelectProps['optionsListProps'];\n\n /**\n * Включает отображение поиска\n */\n showSearch?: BaseSelectProps['showSearch'];\n\n /**\n * Настройки поиска\n */\n searchProps?: BaseSelectProps['searchProps'];\n\n /**\n * Показывать кнопку очистки\n */\n showClear?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\"\n */\n showSelectAll?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\" в заголовке списка\n */\n showHeaderWithSelectAll?: boolean;\n\n /**\n * Значение name при применении выбора\n * @default 'apply-footer'\n */\n applyName?: string;\n\n /**\n * Значение name при сбросе выбора\n * @default 'reset-footer'\n */\n resetName?: string;\n\n /**\n * Позиция чекбокса \"Выбрать все\" в Header\n * @default 'before'\n */\n checkmarkPosition?: 'before' | 'after';\n};\n\nconst selectAllOption = { key: SELECT_ALL_KEY, content: 'Выбрать все' };\n\nexport function useSelectWithApply({\n options,\n selected,\n onChange = () => null,\n onSelectAllClick = () => null,\n OptionsList,\n optionsListProps = {},\n showClear = true,\n showSelectAll = false,\n showHeaderWithSelectAll = false,\n checkmarkPosition = 'before',\n showSearch = false,\n searchProps = {},\n applyName = 'apply-footer',\n resetName = 'reset-footer',\n}: UseSelectWithApplyProps) {\n const [searchState, setSearchState] = useState('');\n\n const [search, setSearch] =\n typeof searchProps?.value === 'string'\n ? [searchProps.value, searchProps.onChange]\n : [searchState, setSearchState];\n\n const accessor = searchProps.accessor || defaultAccessor;\n const filterFn = searchProps.filterFn || defaultFilterFn;\n const groupAccessor = searchProps.groupAccessor ?? defaultGroupAccessor;\n const filterGroup = searchProps.filterGroup ?? false;\n\n const { flatOptions, filteredOptions, selectedOptions } = useMemo(\n () =>\n processOptions(\n options,\n selected,\n showSearch\n ? (option) => {\n if (isGroup(option)) {\n const groupAccessorValue = groupAccessor(option);\n\n return (\n typeof groupAccessorValue === 'string' &&\n filterFn(groupAccessorValue, search)\n );\n }\n\n return filterFn(accessor(option), search);\n }\n : undefined,\n filterGroup,\n ),\n [options, selected, showSearch, filterGroup, filterFn, accessor, search, groupAccessor],\n );\n const [selectedDraft, setSelectedDraft] = useState<OptionShape[]>(selectedOptions);\n\n const selectedOptionsRef = useRef<OptionShape[]>(selectedOptions);\n\n const handleApply = () => {\n onChange({\n selected: selectedDraft[0],\n selectedMultiple: selectedDraft,\n initiator: null,\n name: applyName,\n });\n };\n\n const handleClear = () => {\n setSelectedDraft([]);\n onChange({\n selected: null,\n selectedMultiple: [],\n initiator: null,\n name: resetName,\n });\n };\n\n const handleToggleAll = () => {\n const optionsToSet = flatOptions.length === selectedDraft.length ? [] : flatOptions;\n\n onSelectAllClick(optionsToSet);\n setSelectedDraft(optionsToSet);\n };\n\n const selectedKeys = useMemo(() => selectedDraft.map(({ key }) => key), [selectedDraft]);\n\n const handleChange: Required<BaseSelectProps>['onChange'] = ({ initiator, ...restArgs }) => {\n if (!initiator) {\n onChange({\n initiator: null,\n ...restArgs,\n });\n\n return;\n }\n\n const initiatorSelected =\n selectedDraft.some(\n (selectedDraftOption) => selectedDraftOption.key === initiator.key,\n ) ||\n (initiator.key === SELECT_ALL_KEY &&\n (selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key))));\n\n if (initiator.key === SELECT_ALL_KEY) {\n setSelectedDraft(initiatorSelected ? [] : flatOptions);\n } else {\n setSelectedDraft(\n initiatorSelected\n ? selectedDraft.filter((o) => o.key !== initiator.key)\n : selectedDraft.concat(initiator),\n );\n }\n };\n\n const handleClose = () => setSelectedDraft(selectedOptionsRef.current);\n\n useEffect(() => {\n // устанавливать selectedDraft если selectedOptions изменились\n if (!reactFastCompare(selectedOptionsRef.current, selectedOptions)) {\n setSelectedDraft(selectedOptions);\n }\n selectedOptionsRef.current = selectedOptions;\n }, [selectedOptions]);\n\n const memoizedOptions = useMemo(\n () =>\n filteredOptions.length && showSelectAll\n ? [selectAllOption, ...filteredOptions]\n : filteredOptions,\n [filteredOptions, showSelectAll],\n );\n\n return {\n OptionsList: OptionsListWithApply,\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n OptionsList,\n showClear,\n onClear: handleClear,\n onApply: handleApply,\n onClose: handleClose,\n selectedDraft,\n setSelectedDraft,\n showHeaderWithSelectAll,\n headerProps: {\n ...(optionsListProps as AnyObject)?.headerProps,\n indeterminate: selectedDraft.length > 0,\n checked:\n selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key)),\n onChange: handleToggleAll,\n checkmarkPosition,\n },\n },\n multiple: true,\n options: memoizedOptions,\n onChange: handleChange,\n selected,\n showSearch,\n searchProps: showSearch\n ? {\n ...searchProps,\n value: search,\n onChange: setSearch,\n }\n : undefined,\n /* Костыль для респонсив селекта. В мобильную версию хук уже зашит, и это единственный передать в мобилку оригинальные пропсы */\n originalProps: {\n options,\n selected,\n onChange,\n OptionsList,\n optionsListProps,\n showClear,\n showSelectAll,\n showHeaderWithSelectAll,\n checkmarkPosition,\n showSearch,\n searchProps,\n applyName,\n resetName,\n },\n };\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,81 +1,48 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import { type OptionShape } from '../../../typings';
|
|
1
|
+
import React, { type FC, type RefAttributes } from 'react';
|
|
2
|
+
import { type OptionShape, type OptionsListProps } from '../../../typings';
|
|
3
3
|
import { type FooterProps } from './footer/Component';
|
|
4
4
|
import { type HeaderProps } from './header/Component';
|
|
5
5
|
export declare const OptionsListWithApply: React.ForwardRefExoticComponent<Pick<import("../../../typings").SelectProps, "client"> & {
|
|
6
|
-
className?: string
|
|
7
|
-
optionGroupClassName?: string
|
|
8
|
-
scrollbarClassName?: string
|
|
9
|
-
footerClassName?: string
|
|
10
|
-
size?: 40 | 48 | 56 | 64 | 72
|
|
6
|
+
className?: string;
|
|
7
|
+
optionGroupClassName?: string;
|
|
8
|
+
scrollbarClassName?: string;
|
|
9
|
+
footerClassName?: string;
|
|
10
|
+
size?: 40 | 48 | 56 | 64 | 72;
|
|
11
11
|
Option: React.ComponentType<import("../../../typings").OptionProps>;
|
|
12
12
|
getOptionProps: (option: OptionShape, index: number) => import("../../../typings").OptionProps;
|
|
13
|
-
groupOptionProps?: import("../../../typings").AnyObject
|
|
14
|
-
selectedItems?: OptionShape[]
|
|
13
|
+
groupOptionProps?: import("../../../typings").AnyObject;
|
|
14
|
+
selectedItems?: OptionShape[];
|
|
15
15
|
setSelectedItems: (selected: OptionShape[]) => void;
|
|
16
16
|
toggleMenu: () => void;
|
|
17
17
|
header?: React.ReactNode;
|
|
18
18
|
footer?: React.ReactNode;
|
|
19
|
-
options?:
|
|
20
|
-
flatOptions?: OptionShape[]
|
|
21
|
-
highlightedIndex?: number
|
|
22
|
-
open?: boolean
|
|
23
|
-
Optgroup?:
|
|
19
|
+
options?: Array<OptionShape | import("../../../typings").GroupShape>;
|
|
20
|
+
flatOptions?: OptionShape[];
|
|
21
|
+
highlightedIndex?: number;
|
|
22
|
+
open?: boolean;
|
|
23
|
+
Optgroup?: import("../../../typings").BaseSelectProps["Optgroup"];
|
|
24
24
|
emptyPlaceholder?: React.ReactNode;
|
|
25
|
-
visibleOptions?: number
|
|
26
|
-
onScroll?: (
|
|
27
|
-
dataTestId?: string
|
|
28
|
-
inputProps?: import("@alfalab/core-components-input").InputProps
|
|
29
|
-
showFooter?: boolean
|
|
30
|
-
nativeScrollbar?: boolean
|
|
31
|
-
optionsListWidth?: "
|
|
32
|
-
onApply?: (
|
|
33
|
-
onClear?: (
|
|
34
|
-
setHighlightedIndex?: (
|
|
35
|
-
search?: string
|
|
36
|
-
multiple?: boolean
|
|
37
|
-
limitDynamicOptionGroupSize?:
|
|
25
|
+
visibleOptions?: number;
|
|
26
|
+
onScroll?: (event: React.MouseEvent<HTMLDivElement>) => void;
|
|
27
|
+
dataTestId?: string;
|
|
28
|
+
inputProps?: import("@alfalab/core-components-input").InputProps;
|
|
29
|
+
showFooter?: boolean;
|
|
30
|
+
nativeScrollbar?: boolean;
|
|
31
|
+
optionsListWidth?: import("../../../typings").BaseSelectProps["optionsListWidth"];
|
|
32
|
+
onApply?: () => void;
|
|
33
|
+
onClear?: () => void;
|
|
34
|
+
setHighlightedIndex?: (index: number) => void;
|
|
35
|
+
search?: string;
|
|
36
|
+
multiple?: boolean;
|
|
37
|
+
limitDynamicOptionGroupSize?: import("../../../typings").BaseSelectProps["limitDynamicOptionGroupSize"];
|
|
38
38
|
} & {
|
|
39
|
-
showClear?: boolean
|
|
40
|
-
onClose?: (
|
|
41
|
-
selectedDraft?: OptionShape[]
|
|
42
|
-
OptionsList?: React.FC<
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
Option: React.ComponentType<import("../../../typings").OptionProps>;
|
|
49
|
-
getOptionProps: (option: OptionShape, index: number) => import("../../../typings").OptionProps;
|
|
50
|
-
groupOptionProps?: import("../../../typings").AnyObject | undefined;
|
|
51
|
-
selectedItems?: OptionShape[] | undefined;
|
|
52
|
-
setSelectedItems: (selected: OptionShape[]) => void;
|
|
53
|
-
toggleMenu: () => void;
|
|
54
|
-
header?: React.ReactNode;
|
|
55
|
-
footer?: React.ReactNode;
|
|
56
|
-
options?: (OptionShape | import("../../../typings").GroupShape)[] | undefined;
|
|
57
|
-
flatOptions?: OptionShape[] | undefined;
|
|
58
|
-
highlightedIndex?: number | undefined;
|
|
59
|
-
open?: boolean | undefined;
|
|
60
|
-
Optgroup?: React.ComponentType<import("../../../typings").OptgroupProps> | undefined;
|
|
61
|
-
emptyPlaceholder?: React.ReactNode;
|
|
62
|
-
visibleOptions?: number | undefined;
|
|
63
|
-
onScroll?: ((event: React.MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
|
|
64
|
-
dataTestId?: string | undefined;
|
|
65
|
-
inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
|
|
66
|
-
showFooter?: boolean | undefined;
|
|
67
|
-
nativeScrollbar?: boolean | undefined;
|
|
68
|
-
optionsListWidth?: "field" | "content" | undefined;
|
|
69
|
-
onApply?: (() => void) | undefined;
|
|
70
|
-
onClear?: (() => void) | undefined;
|
|
71
|
-
setHighlightedIndex?: ((index: number) => void) | undefined;
|
|
72
|
-
search?: string | undefined;
|
|
73
|
-
multiple?: boolean | undefined;
|
|
74
|
-
limitDynamicOptionGroupSize?: boolean | undefined;
|
|
75
|
-
} & React.RefAttributes<HTMLDivElement>> | undefined;
|
|
76
|
-
Footer?: React.FC<FooterProps> | undefined;
|
|
77
|
-
Header?: React.FC<HeaderProps> | undefined;
|
|
78
|
-
headerProps?: HeaderProps | undefined;
|
|
79
|
-
showHeaderWithSelectAll?: boolean | undefined;
|
|
80
|
-
setSelectedDraft?: ((selectedDraft: OptionShape[]) => void) | undefined;
|
|
39
|
+
showClear?: boolean;
|
|
40
|
+
onClose?: () => void;
|
|
41
|
+
selectedDraft?: OptionShape[];
|
|
42
|
+
OptionsList?: React.FC<OptionsListProps & RefAttributes<HTMLDivElement>>;
|
|
43
|
+
Footer?: FC<FooterProps>;
|
|
44
|
+
Header?: FC<HeaderProps>;
|
|
45
|
+
headerProps?: HeaderProps;
|
|
46
|
+
showHeaderWithSelectAll?: boolean;
|
|
47
|
+
setSelectedDraft?: (selectedDraft: OptionShape[]) => void;
|
|
81
48
|
} & React.RefAttributes<HTMLDivElement>>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Component.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/Component.tsx"],"sourcesContent":["import React, { type FC, forwardRef, type RefAttributes, useCallback, useEffect } from 'react';\n\nimport { OptionsList as DefaultOptionsList } from '../../../components/options-list';\nimport { DEFAULT_VISIBLE_OPTIONS, SELECT_ALL_KEY } from '../../../consts';\nimport { type OptionShape, type OptionsListProps } from '../../../typings';\n\nimport { Footer as DefaultFooter, type FooterProps } from './footer/Component';\nimport { Header as DefaultHeader, type HeaderProps } from './header/Component';\n\ntype OptionsListWithApplyProps = OptionsListProps & {\n showClear?: boolean;\n onClose?: () => void;\n selectedDraft?: OptionShape[];\n OptionsList?: React.FC<OptionsListProps & RefAttributes<HTMLDivElement>>;\n Footer?: FC<FooterProps>;\n Header?: FC<HeaderProps>;\n headerProps?: HeaderProps;\n showHeaderWithSelectAll?: boolean;\n setSelectedDraft?: (selectedDraft: OptionShape[]) => void;\n};\n\nexport const OptionsListWithApply = forwardRef<HTMLDivElement, OptionsListWithApplyProps>(\n (\n {\n toggleMenu,\n getOptionProps: defaultGetOptionProps,\n showClear = true,\n showHeaderWithSelectAll,\n selectedDraft = [],\n flatOptions = [],\n OptionsList = DefaultOptionsList,\n onApply = () => null,\n onClear = () => null,\n onClose = () => null,\n visibleOptions = DEFAULT_VISIBLE_OPTIONS,\n Footer = DefaultFooter,\n Header = DefaultHeader,\n header,\n headerProps,\n setSelectedDraft,\n size,\n ...restProps\n }: OptionsListWithApplyProps,\n ref,\n ) => {\n const getOptionProps = useCallback(\n (option: OptionShape, index: number) => {\n const optionProps = defaultGetOptionProps(option, index);\n\n const selected =\n option.key === SELECT_ALL_KEY\n ? selectedDraft.length === flatOptions.length - 1\n : selectedDraft.some(({ key }) => key === option.key);\n\n return {\n ...optionProps,\n selected,\n };\n },\n [defaultGetOptionProps, flatOptions.length, selectedDraft],\n );\n\n const handleApply = useCallback(() => {\n onApply();\n\n toggleMenu();\n }, [onApply, toggleMenu]);\n\n const handleClear = useCallback(() => {\n onClear();\n\n toggleMenu();\n }, [onClear, toggleMenu]);\n\n const handleSelectedItems = useCallback(\n (items: OptionShape[]) => {\n setSelectedDraft?.(items);\n },\n [setSelectedDraft],\n );\n\n useEffect(() => {\n const activeElement = document.activeElement as HTMLElement;\n\n return () => {\n onClose();\n if (activeElement) {\n activeElement.focus();\n }\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const renderHeader = () => {\n if (!showHeaderWithSelectAll && !header) return undefined;\n\n return (\n <React.Fragment>\n {header}\n {showHeaderWithSelectAll && flatOptions.length > 0 && (\n <Header {...headerProps} size={size} />\n )}\n </React.Fragment>\n );\n };\n\n return (\n <OptionsList\n {...restProps}\n size={size}\n ref={ref}\n visibleOptions={visibleOptions}\n toggleMenu={toggleMenu}\n flatOptions={flatOptions}\n getOptionProps={getOptionProps}\n onApply={handleApply}\n onClear={handleClear}\n header={renderHeader()}\n selectedItems={selectedDraft}\n setSelectedItems={handleSelectedItems}\n footer={\n <Footer\n handleApply={handleApply}\n handleClear={handleClear}\n showClear={showClear}\n selectedDraft={selectedDraft}\n dataTestId={restProps?.dataTestId}\n size={size}\n />\n }\n />\n );\n },\n);\n"],"names":["OptionsList","DefaultOptionsList","Footer","DefaultFooter","Header","DefaultHeader"],"mappings":";;;;;;AAqBa,MAAA,oBAAoB,GAAG,UAAU,CAC1C,CACI,EACI,UAAU,EACV,cAAc,EAAE,qBAAqB,EACrC,SAAS,GAAG,IAAI,EAChB,uBAAuB,EACvB,aAAa,GAAG,EAAE,EAClB,WAAW,GAAG,EAAE,eAChBA,aAAW,GAAGC,WAAkB,EAChC,OAAO,GAAG,MAAM,IAAI,EACpB,OAAO,GAAG,MAAM,IAAI,EACpB,OAAO,GAAG,MAAM,IAAI,EACpB,cAAc,GAAG,uBAAuB,UACxCC,QAAM,GAAGC,MAAa,UACtBC,QAAM,GAAGC,MAAa,EACtB,MAAM,EACN,WAAW,EACX,gBAAgB,EAChB,IAAI,EACJ,GAAG,SAAS,EACY,EAC5B,GAAG,KACH;IACA,MAAM,cAAc,GAAG,WAAW,CAC9B,CAAC,MAAmB,EAAE,KAAa,KAAI;QACnC,MAAM,WAAW,GAAG,qBAAqB,CAAC,MAAM,EAAE,KAAK,CAAC;AAExD,QAAA,MAAM,QAAQ,GACV,MAAM,CAAC,GAAG,KAAK;cACT,aAAa,CAAC,MAAM,KAAK,WAAW,CAAC,MAAM,GAAG;AAChD,cAAE,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,GAAG,KAAK,MAAM,CAAC,GAAG,CAAC;QAE7D,OAAO;AACH,YAAA,GAAG,WAAW;YACd,QAAQ;SACX;KACJ,EACD,CAAC,qBAAqB,EAAE,WAAW,CAAC,MAAM,EAAE,aAAa,CAAC,CAC7D;AAED,IAAA,MAAM,WAAW,GAAG,WAAW,CAAC,MAAK;AACjC,QAAA,OAAO,EAAE;AAET,QAAA,UAAU,EAAE;AAChB,KAAC,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;AAEzB,IAAA,MAAM,WAAW,GAAG,WAAW,CAAC,MAAK;AACjC,QAAA,OAAO,EAAE;AAET,QAAA,UAAU,EAAE;AAChB,KAAC,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;AAEzB,IAAA,MAAM,mBAAmB,GAAG,WAAW,CACnC,CAAC,KAAoB,KAAI;AACrB,QAAA,gBAAgB,GAAG,KAAK,CAAC;AAC7B,KAAC,EACD,CAAC,gBAAgB,CAAC,CACrB;IAED,SAAS,CAAC,MAAK;AACX,QAAA,MAAM,aAAa,GAAG,QAAQ,CAAC,aAA4B;AAE3D,QAAA,OAAO,MAAK;AACR,YAAA,OAAO,EAAE;
|
|
1
|
+
{"version":3,"file":"Component.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/Component.tsx"],"sourcesContent":["import React, { type FC, forwardRef, type RefAttributes, useCallback, useEffect } from 'react';\n\nimport { OptionsList as DefaultOptionsList } from '../../../components/options-list';\nimport { DEFAULT_VISIBLE_OPTIONS, SELECT_ALL_KEY } from '../../../consts';\nimport { type OptionShape, type OptionsListProps } from '../../../typings';\n\nimport { Footer as DefaultFooter, type FooterProps } from './footer/Component';\nimport { Header as DefaultHeader, type HeaderProps } from './header/Component';\n\ntype OptionsListWithApplyProps = OptionsListProps & {\n showClear?: boolean;\n onClose?: () => void;\n selectedDraft?: OptionShape[];\n OptionsList?: React.FC<OptionsListProps & RefAttributes<HTMLDivElement>>;\n Footer?: FC<FooterProps>;\n Header?: FC<HeaderProps>;\n headerProps?: HeaderProps;\n showHeaderWithSelectAll?: boolean;\n setSelectedDraft?: (selectedDraft: OptionShape[]) => void;\n};\n\nexport const OptionsListWithApply = forwardRef<HTMLDivElement, OptionsListWithApplyProps>(\n (\n {\n toggleMenu,\n getOptionProps: defaultGetOptionProps,\n showClear = true,\n showHeaderWithSelectAll,\n selectedDraft = [],\n flatOptions = [],\n OptionsList = DefaultOptionsList,\n onApply = () => null,\n onClear = () => null,\n onClose = () => null,\n visibleOptions = DEFAULT_VISIBLE_OPTIONS,\n Footer = DefaultFooter,\n Header = DefaultHeader,\n header,\n headerProps,\n setSelectedDraft,\n size,\n ...restProps\n }: OptionsListWithApplyProps,\n ref,\n ) => {\n const getOptionProps = useCallback(\n (option: OptionShape, index: number) => {\n const optionProps = defaultGetOptionProps(option, index);\n\n const selected =\n option.key === SELECT_ALL_KEY\n ? selectedDraft.length === flatOptions.length - 1\n : selectedDraft.some(({ key }) => key === option.key);\n\n return {\n ...optionProps,\n selected,\n };\n },\n [defaultGetOptionProps, flatOptions.length, selectedDraft],\n );\n\n const handleApply = useCallback(() => {\n onApply();\n\n toggleMenu();\n }, [onApply, toggleMenu]);\n\n const handleClear = useCallback(() => {\n onClear();\n\n toggleMenu();\n }, [onClear, toggleMenu]);\n\n const handleSelectedItems = useCallback(\n (items: OptionShape[]) => {\n setSelectedDraft?.(items);\n },\n [setSelectedDraft],\n );\n\n useEffect(() => {\n const activeElement = document.activeElement as HTMLElement;\n\n return () => {\n onClose();\n if (activeElement) {\n activeElement.focus();\n }\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const renderHeader = () => {\n if (!showHeaderWithSelectAll && !header) return undefined;\n\n return (\n <React.Fragment>\n {header}\n {showHeaderWithSelectAll && flatOptions.length > 0 && (\n <Header {...headerProps} size={size} />\n )}\n </React.Fragment>\n );\n };\n\n return (\n <OptionsList\n {...restProps}\n size={size}\n ref={ref}\n visibleOptions={visibleOptions}\n toggleMenu={toggleMenu}\n flatOptions={flatOptions}\n getOptionProps={getOptionProps}\n onApply={handleApply}\n onClear={handleClear}\n header={renderHeader()}\n selectedItems={selectedDraft}\n setSelectedItems={handleSelectedItems}\n footer={\n <Footer\n handleApply={handleApply}\n handleClear={handleClear}\n showClear={showClear}\n selectedDraft={selectedDraft}\n dataTestId={restProps?.dataTestId}\n size={size}\n />\n }\n />\n );\n },\n);\n"],"names":["OptionsList","DefaultOptionsList","Footer","DefaultFooter","Header","DefaultHeader"],"mappings":"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"}
|
|
@@ -12,14 +12,14 @@
|
|
|
12
12
|
:root {
|
|
13
13
|
--select-option-list-footer-button-gap: var(--gap-8);
|
|
14
14
|
}
|
|
15
|
-
.
|
|
15
|
+
.select__footer_1rukc {
|
|
16
16
|
background-color: var(--color-light-base-bg-primary);
|
|
17
17
|
padding: var(--gap-12);
|
|
18
18
|
outline: none;
|
|
19
19
|
}
|
|
20
|
-
.
|
|
20
|
+
.select__footer_1rukc.select__size-72_1rukc {
|
|
21
21
|
padding: var(--gap-12) var(--gap-16);
|
|
22
22
|
}
|
|
23
|
-
.
|
|
23
|
+
.select__footer_1rukc > .select__button_1rukc + .select__button_1rukc {
|
|
24
24
|
margin-left: var(--select-option-list-footer-button-gap);
|
|
25
25
|
}
|
package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import './index.css';
|
|
2
2
|
|
|
3
|
-
const styles = {"footer":"
|
|
3
|
+
const styles = {"footer":"select__footer_1rukc","size-72":"select__size-72_1rukc","button":"select__button_1rukc"};
|
|
4
4
|
|
|
5
5
|
export { styles as default };
|
|
6
6
|
//# sourceMappingURL=index.module.css.js.map
|
package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.module.css.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/
|
|
1
|
+
{"version":3,"file":"index.module.css.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/index.css';\n@import './vars.css';\n\n.footer {\n background-color: var(--color-light-base-bg-primary);\n padding: var(--gap-12);\n outline: none;\n\n &.size-72 {\n padding: var(--gap-12) var(--gap-16);\n }\n\n & > .button + .button {\n margin-left: var(--select-option-list-footer-button-gap);\n }\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,QAAQ,CAAC,sBAAsB,CAAC,SAAS,CAAC,uBAAuB,CAAC,QAAQ,CAAC,sBAAsB,CAAC;;;;"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { type CheckboxProps } from '@alfalab/core-components-checkbox/modern';
|
|
3
3
|
import { type OptionsListProps } from '../../../../typings';
|
|
4
|
-
export
|
|
4
|
+
export type HeaderProps = {
|
|
5
5
|
checked?: boolean;
|
|
6
6
|
indeterminate?: boolean;
|
|
7
7
|
onChange?: CheckboxProps['onChange'];
|
|
@@ -6,16 +6,16 @@
|
|
|
6
6
|
--gap-12: var(--gap-s);
|
|
7
7
|
--gap-16: var(--gap-m);
|
|
8
8
|
}
|
|
9
|
-
.
|
|
9
|
+
.select__desktop_lewy0 {
|
|
10
10
|
padding: var(--gap-12);
|
|
11
11
|
}
|
|
12
|
-
.
|
|
12
|
+
.select__desktop_lewy0.select__size-72_lewy0 {
|
|
13
13
|
padding-left: var(--gap-16);
|
|
14
14
|
}
|
|
15
|
-
.
|
|
15
|
+
.select__mobile_lewy0 {
|
|
16
16
|
padding: var(--gap-12) var(--gap-12) var(--gap-12) var(--gap-8);
|
|
17
17
|
}
|
|
18
|
-
.
|
|
18
|
+
.select__positionAfter_lewy0 {
|
|
19
19
|
margin-left: 0;
|
|
20
20
|
margin-left: initial;
|
|
21
21
|
}
|
package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import './index.css';
|
|
2
2
|
|
|
3
|
-
const styles = {"desktop":"
|
|
3
|
+
const styles = {"desktop":"select__desktop_lewy0","size-72":"select__size-72_lewy0","mobile":"select__mobile_lewy0","positionAfter":"select__positionAfter_lewy0"};
|
|
4
4
|
|
|
5
5
|
export { styles as default };
|
|
6
6
|
//# sourceMappingURL=index.module.css.js.map
|
package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.module.css.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/
|
|
1
|
+
{"version":3,"file":"index.module.css.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/index.css';\n\n.desktop {\n padding: var(--gap-12);\n &.size-72 {\n padding-left: var(--gap-16);\n }\n}\n\n.mobile {\n padding: var(--gap-12) var(--gap-12) var(--gap-12) var(--gap-8);\n}\n\n.positionAfter {\n margin-left: unset;\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,uBAAuB,CAAC,QAAQ,CAAC,sBAAsB,CAAC,eAAe,CAAC,6BAA6B,CAAC;;;;"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { type BaseSelectProps, type OptionProps, type OptionShape } from '../../typings';
|
|
3
|
-
|
|
3
|
+
type useSelectWithLoadingProps = {
|
|
4
4
|
loading?: boolean;
|
|
5
5
|
visibleOptions?: BaseSelectProps['visibleOptions'];
|
|
6
6
|
Option?: React.FC<OptionProps>;
|