@codeleap/web 7.0.0 → 7.0.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/dist/components/ActivityIndicator/index.js +28 -0
- package/dist/components/ActivityIndicator/index.js.map +1 -0
- package/dist/components/ActivityIndicator/styles.js +2 -0
- package/dist/components/ActivityIndicator/styles.js.map +1 -0
- package/dist/components/ActivityIndicator/types.js +2 -0
- package/dist/components/ActivityIndicator/types.js.map +1 -0
- package/dist/components/Badge/index.js +68 -0
- package/dist/components/Badge/index.js.map +1 -0
- package/dist/components/Badge/styles.js +2 -0
- package/dist/components/Badge/styles.js.map +1 -0
- package/dist/components/Badge/types.js +2 -0
- package/dist/components/Badge/types.js.map +1 -0
- package/dist/components/Button/index.js +52 -0
- package/dist/components/Button/index.js.map +1 -0
- package/dist/components/Button/styles.js +2 -0
- package/dist/components/Button/styles.js.map +1 -0
- package/dist/components/Button/types.js +2 -0
- package/dist/components/Button/types.js.map +1 -0
- package/dist/components/Calendar/index.js +50 -0
- package/dist/components/Calendar/index.js.map +1 -0
- package/dist/components/Calendar/styles.js +2 -0
- package/dist/components/Calendar/styles.js.map +1 -0
- package/dist/components/Calendar/types.js +2 -0
- package/dist/components/Calendar/types.js.map +1 -0
- package/dist/components/Carousel/index.js +129 -0
- package/dist/components/Carousel/index.js.map +1 -0
- package/dist/components/Carousel/styles.js +2 -0
- package/dist/components/Carousel/styles.js.map +1 -0
- package/dist/components/Carousel/types.js +2 -0
- package/dist/components/Carousel/types.js.map +1 -0
- package/dist/components/Checkbox/index.js +44 -0
- package/dist/components/Checkbox/index.js.map +1 -0
- package/dist/components/Checkbox/styles.js +2 -0
- package/dist/components/Checkbox/styles.js.map +1 -0
- package/dist/components/Checkbox/types.js +2 -0
- package/dist/components/Checkbox/types.js.map +1 -0
- package/dist/components/Collapse/index.js +27 -0
- package/dist/components/Collapse/index.js.map +1 -0
- package/dist/components/Collapse/styles.js +2 -0
- package/dist/components/Collapse/styles.js.map +1 -0
- package/dist/components/Collapse/types.js +2 -0
- package/dist/components/Collapse/types.js.map +1 -0
- package/dist/components/ColorPicker/index.js +65 -0
- package/dist/components/ColorPicker/index.js.map +1 -0
- package/dist/components/ColorPicker/styles.js +2 -0
- package/dist/components/ColorPicker/styles.js.map +1 -0
- package/dist/components/ColorPicker/types.js +2 -0
- package/dist/components/ColorPicker/types.js.map +1 -0
- package/dist/components/CropPicker/hooks.js +130 -0
- package/dist/components/CropPicker/hooks.js.map +1 -0
- package/dist/components/CropPicker/index.js +38 -0
- package/dist/components/CropPicker/index.js.map +1 -0
- package/dist/components/CropPicker/styles.js +2 -0
- package/dist/components/CropPicker/styles.js.map +1 -0
- package/dist/components/CropPicker/types.js +2 -0
- package/dist/components/CropPicker/types.js.map +1 -0
- package/dist/components/CropPicker/utils.js +70 -0
- package/dist/components/CropPicker/utils.js.map +1 -0
- package/dist/components/DatePicker/index.js +70 -0
- package/dist/components/DatePicker/index.js.map +1 -0
- package/dist/components/DatePicker/styles.js +2 -0
- package/dist/components/DatePicker/styles.js.map +1 -0
- package/dist/components/DatePicker/types.js +2 -0
- package/dist/components/DatePicker/types.js.map +1 -0
- package/dist/components/Drawer/index.js +50 -0
- package/dist/components/Drawer/index.js.map +1 -0
- package/dist/components/Drawer/styles.js +2 -0
- package/dist/components/Drawer/styles.js.map +1 -0
- package/dist/components/Drawer/types.js +2 -0
- package/dist/components/Drawer/types.js.map +1 -0
- package/dist/components/Dropzone/context.js +39 -0
- package/dist/components/Dropzone/context.js.map +1 -0
- package/dist/components/Dropzone/elements.js +51 -0
- package/dist/components/Dropzone/elements.js.map +1 -0
- package/dist/components/Dropzone/index.js +71 -0
- package/dist/components/Dropzone/index.js.map +1 -0
- package/dist/components/Dropzone/styles.js +2 -0
- package/dist/components/Dropzone/styles.js.map +1 -0
- package/dist/components/Dropzone/types.js +2 -0
- package/dist/components/Dropzone/types.js.map +1 -0
- package/dist/components/Dropzone/useDropzone.js +17 -0
- package/dist/components/Dropzone/useDropzone.js.map +1 -0
- package/dist/components/EmptyPlaceholder/index.js +65 -0
- package/dist/components/EmptyPlaceholder/index.js.map +1 -0
- package/dist/components/EmptyPlaceholder/styles.js +2 -0
- package/dist/components/EmptyPlaceholder/styles.js.map +1 -0
- package/dist/components/EmptyPlaceholder/types.js +2 -0
- package/dist/components/EmptyPlaceholder/types.js.map +1 -0
- package/dist/components/Field/context.js +52 -0
- package/dist/components/Field/context.js.map +1 -0
- package/dist/components/Field/elements.js +84 -0
- package/dist/components/Field/elements.js.map +1 -0
- package/dist/components/Field/index.js +37 -0
- package/dist/components/Field/index.js.map +1 -0
- package/dist/components/Field/styles.js +2 -0
- package/dist/components/Field/styles.js.map +1 -0
- package/dist/components/Field/types.js +2 -0
- package/dist/components/Field/types.js.map +1 -0
- package/dist/components/Field/useFieldInput.js +47 -0
- package/dist/components/Field/useFieldInput.js.map +1 -0
- package/dist/components/FileInput/index.js +55 -0
- package/dist/components/FileInput/index.js.map +1 -0
- package/dist/components/FileInput/types.js +2 -0
- package/dist/components/FileInput/types.js.map +1 -0
- package/dist/components/Icon/index.js +51 -0
- package/dist/components/Icon/index.js.map +1 -0
- package/dist/components/Icon/styles.js +2 -0
- package/dist/components/Icon/styles.js.map +1 -0
- package/dist/components/Icon/types.js +2 -0
- package/dist/components/Icon/types.js.map +1 -0
- package/dist/components/List/context.js +76 -0
- package/dist/components/List/context.js.map +1 -0
- package/dist/components/List/elements.js +123 -0
- package/dist/components/List/elements.js.map +1 -0
- package/dist/components/List/index.js +35 -0
- package/dist/components/List/index.js.map +1 -0
- package/dist/components/List/scroll.js +75 -0
- package/dist/components/List/scroll.js.map +1 -0
- package/dist/components/List/styles.js +2 -0
- package/dist/components/List/styles.js.map +1 -0
- package/dist/components/List/types.js +2 -0
- package/dist/components/List/types.js.map +1 -0
- package/dist/components/LoadingOverlay/index.js +32 -0
- package/dist/components/LoadingOverlay/index.js.map +1 -0
- package/dist/components/LoadingOverlay/styles.js +2 -0
- package/dist/components/LoadingOverlay/styles.js.map +1 -0
- package/dist/components/LoadingOverlay/types.js +2 -0
- package/dist/components/LoadingOverlay/types.js.map +1 -0
- package/dist/components/MaskedTextInput/index.js +34 -0
- package/dist/components/MaskedTextInput/index.js.map +1 -0
- package/dist/components/MaskedTextInput/mask.js +34 -0
- package/dist/components/MaskedTextInput/mask.js.map +1 -0
- package/dist/components/MaskedTextInput/types.js +2 -0
- package/dist/components/MaskedTextInput/types.js.map +1 -0
- package/dist/components/Modal/context.js +36 -0
- package/dist/components/Modal/context.js.map +1 -0
- package/dist/components/Modal/elements.js +66 -0
- package/dist/components/Modal/elements.js.map +1 -0
- package/dist/components/Modal/index.js +34 -0
- package/dist/components/Modal/index.js.map +1 -0
- package/dist/components/Modal/styles.js +2 -0
- package/dist/components/Modal/styles.js.map +1 -0
- package/dist/components/Modal/types.js +2 -0
- package/dist/components/Modal/types.js.map +1 -0
- package/dist/components/NumberIncrement/index.js +65 -0
- package/dist/components/NumberIncrement/index.js.map +1 -0
- package/dist/components/NumberIncrement/styles.js +2 -0
- package/dist/components/NumberIncrement/styles.js.map +1 -0
- package/dist/components/NumberIncrement/types.js +2 -0
- package/dist/components/NumberIncrement/types.js.map +1 -0
- package/dist/components/NumberIncrement/useNumberIncrement.js +113 -0
- package/dist/components/NumberIncrement/useNumberIncrement.js.map +1 -0
- package/dist/components/Overlay/index.js +44 -0
- package/dist/components/Overlay/index.js.map +1 -0
- package/dist/components/Overlay/styles.js +2 -0
- package/dist/components/Overlay/styles.js.map +1 -0
- package/dist/components/Overlay/types.js +2 -0
- package/dist/components/Overlay/types.js.map +1 -0
- package/dist/components/PaginationButtons/index.js +100 -0
- package/dist/components/PaginationButtons/index.js.map +1 -0
- package/dist/components/PaginationButtons/styles.js +2 -0
- package/dist/components/PaginationButtons/styles.js.map +1 -0
- package/dist/components/PaginationButtons/types.js +2 -0
- package/dist/components/PaginationButtons/types.js.map +1 -0
- package/dist/components/PaginationIndicator/index.js +41 -0
- package/dist/components/PaginationIndicator/index.js.map +1 -0
- package/dist/components/PaginationIndicator/styles.js +2 -0
- package/dist/components/PaginationIndicator/styles.js.map +1 -0
- package/dist/components/PaginationIndicator/types.js +2 -0
- package/dist/components/PaginationIndicator/types.js.map +1 -0
- package/dist/components/Progress/Bar/Segmented.js +37 -0
- package/dist/components/Progress/Bar/Segmented.js.map +1 -0
- package/dist/components/Progress/Bar/index.js +44 -0
- package/dist/components/Progress/Bar/index.js.map +1 -0
- package/dist/components/Progress/Bar/styles.js +2 -0
- package/dist/components/Progress/Bar/styles.js.map +1 -0
- package/dist/components/Progress/Bar/types.js +2 -0
- package/dist/components/Progress/Bar/types.js.map +1 -0
- package/dist/components/Progress/Circle/Segmented.js +60 -0
- package/dist/components/Progress/Circle/Segmented.js.map +1 -0
- package/dist/components/Progress/Circle/index.js +65 -0
- package/dist/components/Progress/Circle/index.js.map +1 -0
- package/dist/components/Progress/Circle/styles.js +2 -0
- package/dist/components/Progress/Circle/styles.js.map +1 -0
- package/dist/components/Progress/Circle/types.js +2 -0
- package/dist/components/Progress/Circle/types.js.map +1 -0
- package/dist/components/Progress/index.js +3 -0
- package/dist/components/Progress/index.js.map +1 -0
- package/dist/components/Progress/utils.js +4 -0
- package/dist/components/Progress/utils.js.map +1 -0
- package/dist/components/RadioInput/index.js +47 -0
- package/dist/components/RadioInput/index.js.map +1 -0
- package/dist/components/RadioInput/styles.js +2 -0
- package/dist/components/RadioInput/styles.js.map +1 -0
- package/dist/components/RadioInput/types.js +2 -0
- package/dist/components/RadioInput/types.js.map +1 -0
- package/dist/components/SearchInput/index.js +61 -0
- package/dist/components/SearchInput/index.js.map +1 -0
- package/dist/components/SectionFilters/index.js +148 -0
- package/dist/components/SectionFilters/index.js.map +1 -0
- package/dist/components/SectionFilters/styles.js +2 -0
- package/dist/components/SectionFilters/styles.js.map +1 -0
- package/dist/components/SectionFilters/types.js +2 -0
- package/dist/components/SectionFilters/types.js.map +1 -0
- package/dist/components/Select/context.js +156 -0
- package/dist/components/Select/context.js.map +1 -0
- package/dist/components/Select/elements.js +47 -0
- package/dist/components/Select/elements.js.map +1 -0
- package/dist/components/Select/index.js +53 -0
- package/dist/components/Select/index.js.map +1 -0
- package/dist/components/Select/styles.js +2 -0
- package/dist/components/Select/styles.js.map +1 -0
- package/dist/components/Select/types.js +2 -0
- package/dist/components/Select/types.js.map +1 -0
- package/dist/components/Select/useTriggerWidth.js +27 -0
- package/dist/components/Select/useTriggerWidth.js.map +1 -0
- package/dist/components/Slider/index.js +139 -0
- package/dist/components/Slider/index.js.map +1 -0
- package/dist/components/Slider/styles.js +2 -0
- package/dist/components/Slider/styles.js.map +1 -0
- package/dist/components/Slider/types.js +2 -0
- package/dist/components/Slider/types.js.map +1 -0
- package/dist/components/Switch/index.js +48 -0
- package/dist/components/Switch/index.js.map +1 -0
- package/dist/components/Switch/styles.js +2 -0
- package/dist/components/Switch/styles.js.map +1 -0
- package/dist/components/Switch/types.js +2 -0
- package/dist/components/Switch/types.js.map +1 -0
- package/dist/components/Tag/index.js +53 -0
- package/dist/components/Tag/index.js.map +1 -0
- package/dist/components/Tag/styles.js +2 -0
- package/dist/components/Tag/styles.js.map +1 -0
- package/dist/components/Tag/types.js +2 -0
- package/dist/components/Tag/types.js.map +1 -0
- package/dist/components/Text/index.js +94 -0
- package/dist/components/Text/index.js.map +1 -0
- package/dist/components/Text/styles.js +2 -0
- package/dist/components/Text/styles.js.map +1 -0
- package/dist/components/Text/types.js +2 -0
- package/dist/components/Text/types.js.map +1 -0
- package/dist/components/TextEditor/index.js +90 -0
- package/dist/components/TextEditor/index.js.map +1 -0
- package/dist/components/TextEditor/styles.js +2 -0
- package/dist/components/TextEditor/styles.js.map +1 -0
- package/dist/components/TextEditor/types.js +2 -0
- package/dist/components/TextEditor/types.js.map +1 -0
- package/dist/components/TextInput/index.js +65 -0
- package/dist/components/TextInput/index.js.map +1 -0
- package/dist/components/TextInput/styles.js +2 -0
- package/dist/components/TextInput/styles.js.map +1 -0
- package/dist/components/TextInput/types.js +2 -0
- package/dist/components/TextInput/types.js.map +1 -0
- package/dist/components/TextInput/useTextInput.js +64 -0
- package/dist/components/TextInput/useTextInput.js.map +1 -0
- package/dist/components/Tooltip/index.js +94 -0
- package/dist/components/Tooltip/index.js.map +1 -0
- package/dist/components/Tooltip/styles.js +2 -0
- package/dist/components/Tooltip/styles.js.map +1 -0
- package/dist/components/Tooltip/types.js +2 -0
- package/dist/components/Tooltip/types.js.map +1 -0
- package/dist/components/Touchable/index.js +80 -0
- package/dist/components/Touchable/index.js.map +1 -0
- package/dist/components/Touchable/styles.js +2 -0
- package/dist/components/Touchable/styles.js.map +1 -0
- package/dist/components/Touchable/types.js +2 -0
- package/dist/components/Touchable/types.js.map +1 -0
- package/dist/components/View/index.js +39 -0
- package/dist/components/View/index.js.map +1 -0
- package/dist/components/View/styles.js +2 -0
- package/dist/components/View/styles.js.map +1 -0
- package/dist/components/View/types.js +2 -0
- package/dist/components/View/types.js.map +1 -0
- package/dist/components/components.js +42 -0
- package/dist/components/components.js.map +1 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/ListMasonry.js +86 -0
- package/dist/lib/ListMasonry.js.map +1 -0
- package/dist/lib/ThemeVariables.js +22 -0
- package/dist/lib/ThemeVariables.js.map +1 -0
- package/dist/lib/WebStyleRegistry.js +69 -0
- package/dist/lib/WebStyleRegistry.js.map +1 -0
- package/dist/lib/hooks/index.js +23 -0
- package/dist/lib/hooks/index.js.map +1 -0
- package/dist/lib/hooks/useAnimatedStyle.js +23 -0
- package/dist/lib/hooks/useAnimatedStyle.js.map +1 -0
- package/dist/lib/hooks/useAnimatedVariantStyles.js +20 -0
- package/dist/lib/hooks/useAnimatedVariantStyles.js.map +1 -0
- package/dist/lib/hooks/useAsyncSelect.js +57 -0
- package/dist/lib/hooks/useAsyncSelect.js.map +1 -0
- package/dist/lib/hooks/useBreakpointMatch.js +108 -0
- package/dist/lib/hooks/useBreakpointMatch.js.map +1 -0
- package/dist/lib/hooks/useClick.js +38 -0
- package/dist/lib/hooks/useClick.js.map +1 -0
- package/dist/lib/hooks/useClickOutside.js +31 -0
- package/dist/lib/hooks/useClickOutside.js.map +1 -0
- package/dist/lib/hooks/useFileInput.js +17 -0
- package/dist/lib/hooks/useFileInput.js.map +1 -0
- package/dist/lib/hooks/useIsomorphicEffect.js +7 -0
- package/dist/lib/hooks/useIsomorphicEffect.js.map +1 -0
- package/dist/lib/hooks/useKeydown.js +39 -0
- package/dist/lib/hooks/useKeydown.js.map +1 -0
- package/dist/lib/hooks/useListFocus.js +46 -0
- package/dist/lib/hooks/useListFocus.js.map +1 -0
- package/dist/lib/hooks/useMediaQuery.js +25 -0
- package/dist/lib/hooks/useMediaQuery.js.map +1 -0
- package/dist/lib/hooks/usePageExitBlocker.js +44 -0
- package/dist/lib/hooks/usePageExitBlocker.js.map +1 -0
- package/dist/lib/hooks/usePagination.js +90 -0
- package/dist/lib/hooks/usePagination.js.map +1 -0
- package/dist/lib/hooks/usePopState.js +31 -0
- package/dist/lib/hooks/usePopState.js.map +1 -0
- package/dist/lib/hooks/usePopoverDismiss.js +32 -0
- package/dist/lib/hooks/usePopoverDismiss.js.map +1 -0
- package/dist/lib/hooks/useRefresh.js +67 -0
- package/dist/lib/hooks/useRefresh.js.map +1 -0
- package/dist/lib/hooks/useScrollEffect.js +19 -0
- package/dist/lib/hooks/useScrollEffect.js.map +1 -0
- package/dist/lib/hooks/useSearchParams.js +48 -0
- package/dist/lib/hooks/useSearchParams.js.map +1 -0
- package/dist/lib/hooks/useStaticAnimationStyles.js +16 -0
- package/dist/lib/hooks/useStaticAnimationStyles.js.map +1 -0
- package/dist/lib/hooks/useStylesFor.js +36 -0
- package/dist/lib/hooks/useStylesFor.js.map +1 -0
- package/dist/lib/hooks/useTouchableEvents.js +34 -0
- package/dist/lib/hooks/useTouchableEvents.js.map +1 -0
- package/dist/lib/hooks/useWindowFocus.js +30 -0
- package/dist/lib/hooks/useWindowFocus.js.map +1 -0
- package/dist/lib/hooks/useWindowSize.js +29 -0
- package/dist/lib/hooks/useWindowSize.js.map +1 -0
- package/dist/lib/index.js +7 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/tools/index.js +4 -0
- package/dist/lib/tools/index.js.map +1 -0
- package/dist/lib/tools/localStorage.js +155 -0
- package/dist/lib/tools/localStorage.js.map +1 -0
- package/dist/lib/tools/mediaQuery.js +33 -0
- package/dist/lib/tools/mediaQuery.js.map +1 -0
- package/dist/lib/tools/modal.js +55 -0
- package/dist/lib/tools/modal.js.map +1 -0
- package/dist/lib/utils/attributes.js +23 -0
- package/dist/lib/utils/attributes.js.map +1 -0
- package/dist/lib/utils/cache.js +10 -0
- package/dist/lib/utils/cache.js.map +1 -0
- package/dist/lib/utils/index.js +6 -0
- package/dist/lib/utils/index.js.map +1 -0
- package/dist/lib/utils/pollyfils/scroll.js +66 -0
- package/dist/lib/utils/pollyfils/scroll.js.map +1 -0
- package/dist/lib/utils/stopPropagation.js +19 -0
- package/dist/lib/utils/stopPropagation.js.map +1 -0
- package/dist/lib/utils/test.js +14 -0
- package/dist/lib/utils/test.js.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/utility.js +2 -0
- package/dist/types/utility.js.map +1 -0
- package/package.json +18 -18
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { useCallback } from 'react';
|
|
3
|
+
import { Button } from '../Button';
|
|
4
|
+
import { Collapse } from '../Collapse';
|
|
5
|
+
import { View } from '../View';
|
|
6
|
+
import { HexColorPicker } from 'react-colorful';
|
|
7
|
+
import { TypeGuards } from '@codeleap/types';
|
|
8
|
+
import { useConditionalState, useState } from '@codeleap/hooks';
|
|
9
|
+
import { useStylesFor } from '../../lib/hooks/useStylesFor';
|
|
10
|
+
import { WebStyleRegistry } from '../../lib/WebStyleRegistry';
|
|
11
|
+
export * from './styles';
|
|
12
|
+
export * from './types';
|
|
13
|
+
const DefaultFooter = (props) => {
|
|
14
|
+
const { styles, clearIcon, handleClear, confirmIcon, handleConfirmation } = props;
|
|
15
|
+
return (_jsxs(View, { style: styles.footerWrapper, children: [_jsx(Button, { debugName: 'ColorPicker footer trash', name: clearIcon, onPress: handleClear, style: styles.clearIcon }), _jsx(Button, { debugName: 'ColorPicker footer check', name: confirmIcon, onPress: handleConfirmation, style: styles.confirmIcon })] }));
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Color selection control that wraps any `react-colorful` picker in either an inline (`isPlain`) or collapsible-dropdown layout with optional confirm/clear footer actions.
|
|
19
|
+
* Internal color state is initialised from `initialColor`; `onConfirm` fires only when the user explicitly confirms (not on every picker drag).
|
|
20
|
+
* Uses: `Button`, `Collapse`, `View`
|
|
21
|
+
*/
|
|
22
|
+
export const ColorPicker = (props) => {
|
|
23
|
+
const { isPlain, initialColor, showFooter, icon, style, clearIcon, confirmIcon, onConfirm, onClear, closeOnConfirm, pickerComponent: PickerComponent, openPickerComponent: OpenPickerComponent, footerComponent: FooterComponent, openPickerProps, } = {
|
|
24
|
+
...ColorPicker.defaultProps,
|
|
25
|
+
...props,
|
|
26
|
+
};
|
|
27
|
+
const styles = useStylesFor(ColorPicker.styleRegistryName, style);
|
|
28
|
+
const [visible, toggle] = useConditionalState(props?.visible, props?.toggle, { initialValue: false });
|
|
29
|
+
const [color, setColor] = useState(initialColor);
|
|
30
|
+
const handleConfirmation = useCallback((color) => {
|
|
31
|
+
onConfirm?.(color);
|
|
32
|
+
if (closeOnConfirm)
|
|
33
|
+
toggle(false);
|
|
34
|
+
}, []);
|
|
35
|
+
const handleClear = useCallback((initialColor) => {
|
|
36
|
+
setColor(initialColor);
|
|
37
|
+
if (TypeGuards.isFunction(onClear))
|
|
38
|
+
onClear?.();
|
|
39
|
+
}, []);
|
|
40
|
+
// Dragging to change the color in any other way does not seem to work for some reason.
|
|
41
|
+
const picker = _jsx(View, { style: styles.picker, children: _jsx(PickerComponent, { color: color, onChange: setColor }) });
|
|
42
|
+
const openColorPickerBtn = !!OpenPickerComponent ? (_jsx(OpenPickerComponent, { color: color, visible: visible, toggle: () => toggle(!visible) })) : (_jsx(Button, { onPress: () => toggle(!visible), icon: icon, ...openPickerProps }));
|
|
43
|
+
return (_jsx(View, { style: styles.wrapper, children: isPlain ? picker : (_jsxs(_Fragment, { children: [openColorPickerBtn, _jsx(Collapse, { open: visible, style: [
|
|
44
|
+
styles.dropdown,
|
|
45
|
+
visible && styles['dropdown:open'],
|
|
46
|
+
], children: _jsxs(View, { style: styles.dropdownInnerWrapper, children: [picker, showFooter ? (_jsx(FooterComponent, { color: color, handleConfirmation: () => handleConfirmation(color), handleClear: () => handleClear(initialColor), styles: styles, clearIcon: clearIcon, confirmIcon: confirmIcon })) : null] }) })] })) }));
|
|
47
|
+
};
|
|
48
|
+
ColorPicker.styleRegistryName = 'ColorPicker';
|
|
49
|
+
ColorPicker.elements = ['wrapper', 'picker', 'dropdown', 'dropdownInnerWrapper', 'footerWrapper', 'clearIcon', 'confirmIcon'];
|
|
50
|
+
ColorPicker.rootElement = 'wrapper';
|
|
51
|
+
ColorPicker.withVariantTypes = (styles) => {
|
|
52
|
+
return ColorPicker;
|
|
53
|
+
};
|
|
54
|
+
ColorPicker.defaultProps = {
|
|
55
|
+
pickerComponent: (props) => _jsx(HexColorPicker, { ...props }),
|
|
56
|
+
footerComponent: DefaultFooter,
|
|
57
|
+
icon: 'edit',
|
|
58
|
+
clearIcon: 'trash',
|
|
59
|
+
confirmIcon: 'check',
|
|
60
|
+
showFooter: true,
|
|
61
|
+
isPlain: false,
|
|
62
|
+
closeOnConfirm: true,
|
|
63
|
+
};
|
|
64
|
+
WebStyleRegistry.registerComponent(ColorPicker);
|
|
65
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/ColorPicker/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/components/ColorPicker/styles.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/components/ColorPicker/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { useMemo } from 'react';
|
|
2
|
+
import { useCallback, useEffect, useState } from 'react';
|
|
3
|
+
import { calculateProportionalDimensions, cropImage, readImage } from './utils';
|
|
4
|
+
/**
|
|
5
|
+
* Manages crop state for a `CropPicker`, including image loading, crop selection with minimum-size enforcement, confirm/cancel handlers, and display-size calculation.
|
|
6
|
+
* Pass the return value to `CropPicker` via the `handle` prop.
|
|
7
|
+
*/
|
|
8
|
+
export function useCropPicker({ aspect, minWidth: minW, minHeight: minH, file, onCrop, }) {
|
|
9
|
+
const [image, setImage] = useState(null);
|
|
10
|
+
const [crop, setCrop] = useState();
|
|
11
|
+
const [relativeCrop, setRelativeCrop] = useState();
|
|
12
|
+
const [imageDimensions, setImageDimensions] = useState(null);
|
|
13
|
+
const cleanup = () => {
|
|
14
|
+
setRelativeCrop(null);
|
|
15
|
+
setCrop(undefined);
|
|
16
|
+
setImageDimensions(null);
|
|
17
|
+
setTimeout(() => setImage(null), 500);
|
|
18
|
+
};
|
|
19
|
+
const handleConfirmCrop = async () => {
|
|
20
|
+
const [preview, croppedBlob] = await cropImage(image, relativeCrop);
|
|
21
|
+
const newImage = {
|
|
22
|
+
file: new File([croppedBlob], 'cropped.jpg', {
|
|
23
|
+
type: 'image/jpeg',
|
|
24
|
+
lastModified: Date.now(),
|
|
25
|
+
}),
|
|
26
|
+
preview,
|
|
27
|
+
};
|
|
28
|
+
onCrop(newImage);
|
|
29
|
+
setTimeout(() => cleanup());
|
|
30
|
+
};
|
|
31
|
+
const handleCancelCrop = () => {
|
|
32
|
+
onCrop(null);
|
|
33
|
+
setTimeout(() => cleanup());
|
|
34
|
+
};
|
|
35
|
+
const loadFile = useCallback(async (toReadFile) => {
|
|
36
|
+
const imageData = await readImage(toReadFile);
|
|
37
|
+
const { naturalWidth, naturalHeight } = imageData;
|
|
38
|
+
const dimensions = calculateProportionalDimensions(naturalWidth, naturalHeight);
|
|
39
|
+
setImageDimensions(dimensions);
|
|
40
|
+
const targetAspect = aspect || dimensions.aspectRatio;
|
|
41
|
+
const imageAspect = dimensions.aspectRatio;
|
|
42
|
+
let initialCrop;
|
|
43
|
+
if (aspect) {
|
|
44
|
+
const v = imageAspect >= targetAspect
|
|
45
|
+
? {
|
|
46
|
+
width: ((naturalHeight * targetAspect) / naturalWidth) * 100,
|
|
47
|
+
height: 100,
|
|
48
|
+
}
|
|
49
|
+
: {
|
|
50
|
+
width: 100,
|
|
51
|
+
height: (naturalWidth / targetAspect / naturalHeight) * 100,
|
|
52
|
+
};
|
|
53
|
+
initialCrop = {
|
|
54
|
+
...v,
|
|
55
|
+
x: (100 - v.width) / 2,
|
|
56
|
+
y: (100 - v.height) / 2,
|
|
57
|
+
unit: '%',
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
initialCrop = {
|
|
62
|
+
width: 100,
|
|
63
|
+
height: 100,
|
|
64
|
+
x: 0,
|
|
65
|
+
y: 0,
|
|
66
|
+
unit: '%',
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
setCrop(initialCrop);
|
|
70
|
+
setRelativeCrop(initialCrop);
|
|
71
|
+
setImage(imageData);
|
|
72
|
+
}, []);
|
|
73
|
+
const getMinDimensions = useCallback(() => {
|
|
74
|
+
if (!imageDimensions)
|
|
75
|
+
return { minWidth: minW ?? 100, minHeight: minH ?? 100 };
|
|
76
|
+
const targetAspect = aspect || imageDimensions.aspectRatio;
|
|
77
|
+
const calculatedMinWidth = (minW ?? 100) * targetAspect;
|
|
78
|
+
const calculatedMinHeight = minH ?? 100;
|
|
79
|
+
return {
|
|
80
|
+
minWidth: Math.max(calculatedMinWidth, 50),
|
|
81
|
+
minHeight: Math.max(calculatedMinHeight, 50),
|
|
82
|
+
};
|
|
83
|
+
}, [aspect, imageDimensions, minW, minH]);
|
|
84
|
+
const handleCropChange = useCallback((newCrop) => {
|
|
85
|
+
if (!imageDimensions) {
|
|
86
|
+
setCrop(newCrop);
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
const { minWidth, minHeight } = getMinDimensions();
|
|
90
|
+
setCrop({
|
|
91
|
+
...newCrop,
|
|
92
|
+
width: newCrop.width < minWidth ? minWidth : newCrop.width,
|
|
93
|
+
height: newCrop.height < minHeight ? minHeight : newCrop.height,
|
|
94
|
+
});
|
|
95
|
+
}, [imageDimensions, getMinDimensions]);
|
|
96
|
+
const containerStyles = useMemo(() => {
|
|
97
|
+
if (!imageDimensions)
|
|
98
|
+
return {};
|
|
99
|
+
return {
|
|
100
|
+
width: imageDimensions.displayWidth,
|
|
101
|
+
height: imageDimensions.displayHeight,
|
|
102
|
+
maxWidth: '90vw',
|
|
103
|
+
maxHeight: '70vh',
|
|
104
|
+
margin: '0 auto',
|
|
105
|
+
};
|
|
106
|
+
}, [imageDimensions]);
|
|
107
|
+
const imageStyles = useMemo(() => {
|
|
108
|
+
if (!imageDimensions)
|
|
109
|
+
return {};
|
|
110
|
+
return {
|
|
111
|
+
width: imageDimensions.displayWidth,
|
|
112
|
+
height: imageDimensions.displayHeight,
|
|
113
|
+
objectFit: 'contain',
|
|
114
|
+
};
|
|
115
|
+
}, [imageDimensions]);
|
|
116
|
+
useEffect(() => {
|
|
117
|
+
loadFile(file);
|
|
118
|
+
}, []);
|
|
119
|
+
return {
|
|
120
|
+
containerStyles,
|
|
121
|
+
imageStyles,
|
|
122
|
+
handleCropChange,
|
|
123
|
+
handleConfirmCrop,
|
|
124
|
+
handleCancelCrop,
|
|
125
|
+
setRelativeCrop,
|
|
126
|
+
crop,
|
|
127
|
+
image,
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
//# sourceMappingURL=hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/components/CropPicker/hooks.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { useCompositionStyles } from '@codeleap/styles';
|
|
3
|
+
import { WebStyleRegistry } from '../../lib/WebStyleRegistry';
|
|
4
|
+
import { useStylesFor } from '../../lib/hooks/useStylesFor';
|
|
5
|
+
import { View } from '../View';
|
|
6
|
+
import { ActivityIndicator } from '../ActivityIndicator';
|
|
7
|
+
import 'react-image-crop/dist/ReactCrop.css';
|
|
8
|
+
const ReactCrop = require('react-image-crop').Component;
|
|
9
|
+
export * from './styles';
|
|
10
|
+
export * from './types';
|
|
11
|
+
export * from './hooks';
|
|
12
|
+
/**
|
|
13
|
+
* Image crop editor that wraps react-image-crop and delegates all crop state to a `useCropPicker` handle.
|
|
14
|
+
* Renders a loading spinner while the image is being decoded; renders nothing when `handle` is not provided.
|
|
15
|
+
*/
|
|
16
|
+
export const CropPicker = (props) => {
|
|
17
|
+
const { style, handle, reactCrop, aspect, children, } = {
|
|
18
|
+
...CropPicker.defaultProps,
|
|
19
|
+
...props,
|
|
20
|
+
};
|
|
21
|
+
const styles = useStylesFor(CropPicker.styleRegistryName, style);
|
|
22
|
+
const compositionStyles = useCompositionStyles(['indicator'], styles);
|
|
23
|
+
if (!handle)
|
|
24
|
+
return null;
|
|
25
|
+
const { image, crop, setRelativeCrop, handleCropChange, } = handle;
|
|
26
|
+
return (_jsxs(View, { style: styles.wrapper, children: [!image?.src ? (_jsx(ActivityIndicator, { style: compositionStyles.indicator, debugName: 'CropPickerLoading' })) : (_jsx(ReactCrop, { ...reactCrop, crop: crop, onChange: handleCropChange, onComplete: (_, relCrop) => setRelativeCrop(relCrop), style: styles.crop, aspect: aspect ?? reactCrop?.aspect, children: _jsx("img", { src: image.src,
|
|
27
|
+
// @ts-ignore
|
|
28
|
+
css: [styles?.image] }) })), children] }));
|
|
29
|
+
};
|
|
30
|
+
CropPicker.styleRegistryName = 'CropPicker';
|
|
31
|
+
CropPicker.elements = ['crop', 'image', 'wrapper', 'indicator'];
|
|
32
|
+
CropPicker.rootElement = 'crop';
|
|
33
|
+
CropPicker.withVariantTypes = (styles) => {
|
|
34
|
+
return CropPicker;
|
|
35
|
+
};
|
|
36
|
+
CropPicker.defaultProps = {};
|
|
37
|
+
WebStyleRegistry.registerComponent(CropPicker);
|
|
38
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/CropPicker/index.tsx"],"names":[],"mappings":";AACA,OAAO,EAAyC,oBAAoB,EAAE,MAAM,kBAAkB,CAAA;AAC9F,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAC3D,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AAC9B,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAA;AAIxD,OAAO,qCAAqC,CAAA;AAC5C,MAAM,SAAS,GAAsB,OAAO,CAAC,kBAAkB,CAAC,CAAC,SAAS,CAAA;AAE1E,cAAc,UAAU,CAAA;AACxB,cAAc,SAAS,CAAA;AACvB,cAAc,SAAS,CAAA;AAEvB;;;GAGG;AACH,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,KAAsB,EAAE,EAAE;IACnD,MAAM,EACJ,KAAK,EACL,MAAM,EACN,SAAS,EACT,MAAM,EACN,QAAQ,GACT,GAAG;QACF,GAAG,UAAU,CAAC,YAAY;QAC1B,GAAG,KAAK;KACT,CAAA;IAED,MAAM,MAAM,GAAG,YAAY,CAAC,UAAU,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAA;IAChE,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC,CAAA;IAErE,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAA;IAExB,MAAM,EACJ,KAAK,EACL,IAAI,EACJ,eAAe,EACf,gBAAgB,GACjB,GAAG,MAAM,CAAA;IAEV,OAAO,CACL,MAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,OAAO,aACxB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,CACb,KAAC,iBAAiB,IAAC,KAAK,EAAE,iBAAiB,CAAC,SAAS,EAAE,SAAS,EAAC,mBAAmB,GAAG,CACxF,CAAC,CAAC,CAAC,CACF,KAAC,SAAS,OACJ,SAAS,EACb,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,gBAAgB,EAC1B,UAAU,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,eAAe,CAAC,OAAO,CAAC,EACpD,KAAK,EAAE,MAAM,CAAC,IAAI,EAClB,MAAM,EAAE,MAAM,IAAI,SAAS,EAAE,MAAM,YAEnC,cACE,GAAG,EAAE,KAAK,CAAC,GAAG;oBACd,aAAa;oBACb,GAAG,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,GACpB,GACQ,CACb,EACA,QAAQ,IACJ,CACR,CAAA;AACH,CAAC,CAAA;AAED,UAAU,CAAC,iBAAiB,GAAG,YAAY,CAAA;AAC3C,UAAU,CAAC,QAAQ,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,WAAW,CAAC,CAAA;AAC/D,UAAU,CAAC,WAAW,GAAG,MAAM,CAAA;AAC/B,UAAU,CAAC,gBAAgB,GAAG,CAAsB,MAAS,EAAE,EAAE;IAC/D,OAAO,UAAmF,CAAA;AAC5F,CAAC,CAAA;AAED,UAAU,CAAC,YAAY,GAAG,EAA8B,CAAA;AAExD,gBAAgB,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/components/CropPicker/styles.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/components/CropPicker/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
/** Reads a `File` or `Blob` as a data-URL and resolves with a loaded `HTMLImageElement`. */
|
|
2
|
+
export function readImage(file) {
|
|
3
|
+
return new Promise((resolve, reject) => {
|
|
4
|
+
const reader = new FileReader();
|
|
5
|
+
reader.onload = () => {
|
|
6
|
+
const image = new Image();
|
|
7
|
+
image.onload = () => resolve(image);
|
|
8
|
+
image.onerror = () => reject(new Error('Failed to load image'));
|
|
9
|
+
image.src = reader.result;
|
|
10
|
+
};
|
|
11
|
+
reader.onerror = () => reject(new Error('Failed to read file'));
|
|
12
|
+
reader.readAsDataURL(file);
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Renders the specified percentage-unit `crop` region of `image` onto an off-screen canvas and returns a `[dataURL, Blob]` tuple.
|
|
17
|
+
* The output blob is always `image/png` at quality 1.
|
|
18
|
+
*/
|
|
19
|
+
export async function cropImage(image, crop) {
|
|
20
|
+
if (!crop.width || !crop.height) {
|
|
21
|
+
throw new Error('Invalid crop dimensions');
|
|
22
|
+
}
|
|
23
|
+
const canvas = document.createElement('canvas');
|
|
24
|
+
const ctx = canvas.getContext('2d', { willReadFrequently: true });
|
|
25
|
+
if (!ctx) {
|
|
26
|
+
throw new Error('Could not get canvas 2d context');
|
|
27
|
+
}
|
|
28
|
+
const scaleX = image.naturalWidth / 100;
|
|
29
|
+
const scaleY = image.naturalHeight / 100;
|
|
30
|
+
canvas.width = crop.width * scaleX;
|
|
31
|
+
canvas.height = crop.height * scaleY;
|
|
32
|
+
ctx.drawImage(image, crop.x * scaleX, crop.y * scaleY, canvas.width, canvas.height, 0, 0, canvas.width, canvas.height);
|
|
33
|
+
try {
|
|
34
|
+
const blob = await new Promise((resolve, reject) => {
|
|
35
|
+
canvas.toBlob(blob => blob ? resolve(blob) : reject(new Error('Canvas is empty')), 'image/png', 1);
|
|
36
|
+
});
|
|
37
|
+
const croppedImage = await readImage(blob);
|
|
38
|
+
return [croppedImage.src, blob];
|
|
39
|
+
}
|
|
40
|
+
catch (error) {
|
|
41
|
+
throw new Error(`Failed to crop image: ${error instanceof Error ? error.message : String(error)}`);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Scales natural image dimensions down to fit within a 600×400 display budget while preserving aspect ratio.
|
|
46
|
+
* Returns both the original natural dimensions and the calculated display dimensions.
|
|
47
|
+
*/
|
|
48
|
+
export const calculateProportionalDimensions = (naturalWidth, naturalHeight) => {
|
|
49
|
+
const aspectRatio = naturalWidth / naturalHeight;
|
|
50
|
+
const maxWidth = 600;
|
|
51
|
+
const maxHeight = 400;
|
|
52
|
+
let displayWidth = naturalWidth;
|
|
53
|
+
let displayHeight = naturalHeight;
|
|
54
|
+
if (displayHeight > maxHeight) {
|
|
55
|
+
displayHeight = maxHeight;
|
|
56
|
+
displayWidth = displayHeight * aspectRatio;
|
|
57
|
+
}
|
|
58
|
+
if (displayWidth > maxWidth) {
|
|
59
|
+
displayWidth = maxWidth;
|
|
60
|
+
displayHeight = displayWidth / aspectRatio;
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
naturalWidth,
|
|
64
|
+
naturalHeight,
|
|
65
|
+
displayWidth: Math.round(displayWidth),
|
|
66
|
+
displayHeight: Math.round(displayHeight),
|
|
67
|
+
aspectRatio,
|
|
68
|
+
};
|
|
69
|
+
};
|
|
70
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/components/CropPicker/utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { useRef } from 'react';
|
|
3
|
+
import { Popover } from 'react-aria-components';
|
|
4
|
+
import { CalendarDate, getLocalTimeZone } from '@internationalized/date';
|
|
5
|
+
import { useConditionalState } from '@codeleap/hooks';
|
|
6
|
+
import { fields } from '@codeleap/form';
|
|
7
|
+
import { View } from '../View';
|
|
8
|
+
import { Calendar } from '../Calendar';
|
|
9
|
+
import { WebStyleRegistry } from '../../lib/WebStyleRegistry';
|
|
10
|
+
import { useStylesFor } from '../../lib/hooks/useStylesFor';
|
|
11
|
+
import { useFieldInput } from '../Field';
|
|
12
|
+
export * from './styles';
|
|
13
|
+
export * from './types';
|
|
14
|
+
function dateToCalendarDate(date) {
|
|
15
|
+
if (!date)
|
|
16
|
+
return null;
|
|
17
|
+
return new CalendarDate(date.getFullYear(), date.getMonth() + 1, date.getDate());
|
|
18
|
+
}
|
|
19
|
+
function calendarDateToDate(cal) {
|
|
20
|
+
return cal.toDate(getLocalTimeZone());
|
|
21
|
+
}
|
|
22
|
+
function defaultFormatDate(date) {
|
|
23
|
+
return date.toLocaleDateString(undefined, { day: '2-digit', month: '2-digit', year: 'numeric' });
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Date selection control that pairs a fully custom trigger element with a `react-aria-components` `Popover` containing a `Calendar`.
|
|
27
|
+
* Converts native `Date` values to/from `@internationalized/date` `CalendarDate` for the calendar; closes the popover after a date is selected.
|
|
28
|
+
* Uses: `View`, `Calendar`
|
|
29
|
+
*/
|
|
30
|
+
export function DatePicker(props) {
|
|
31
|
+
const { value, onValueChange, field, style, defaultValue, renderTrigger, calendarProps, minDate, maxDate, disabled, visible: providedVisible, toggle: providedToggle, formatDate, label, helper, placeholder, forceError, } = { ...DatePicker.defaultProps, ...props };
|
|
32
|
+
const styles = useStylesFor(DatePicker.styleRegistryName, style);
|
|
33
|
+
const triggerRef = useRef(null);
|
|
34
|
+
const [isOpen, setIsOpen] = useConditionalState(providedVisible, providedToggle, { initialValue: false });
|
|
35
|
+
const { inputValue, onInputValueChange, validation } = useFieldInput(field, fields.date, { value, onValueChange });
|
|
36
|
+
const hasError = validation?.showError || !!forceError;
|
|
37
|
+
const errorMessage = validation?.message || forceError;
|
|
38
|
+
const formattedValue = inputValue ? (formatDate ?? defaultFormatDate)(inputValue) : '';
|
|
39
|
+
const handleCalendarChange = (date) => {
|
|
40
|
+
onInputValueChange(calendarDateToDate(date));
|
|
41
|
+
setIsOpen(false);
|
|
42
|
+
};
|
|
43
|
+
return (_jsxs(View, { style: styles.wrapper, children: [renderTrigger?.({
|
|
44
|
+
ref: triggerRef,
|
|
45
|
+
value: inputValue ?? null,
|
|
46
|
+
formattedValue,
|
|
47
|
+
isOpen,
|
|
48
|
+
onPress: () => setIsOpen(!isOpen),
|
|
49
|
+
disabled: !!disabled,
|
|
50
|
+
style: styles.trigger,
|
|
51
|
+
label,
|
|
52
|
+
placeholder,
|
|
53
|
+
helper,
|
|
54
|
+
error: hasError ? errorMessage : undefined,
|
|
55
|
+
hasValue: !!inputValue,
|
|
56
|
+
}), _jsx(Popover, { triggerRef: triggerRef, isOpen: isOpen, onOpenChange: setIsOpen, css: styles.popover, children: _jsx(Calendar, { value: dateToCalendarDate(inputValue) ?? undefined, onChange: handleCalendarChange, minValue: dateToCalendarDate(minDate) ?? undefined, maxValue: dateToCalendarDate(maxDate) ?? undefined, defaultValue: dateToCalendarDate(defaultValue) ?? undefined, ...calendarProps }) })] }));
|
|
57
|
+
}
|
|
58
|
+
DatePicker.styleRegistryName = 'DatePicker';
|
|
59
|
+
DatePicker.elements = ['wrapper', 'popover', 'trigger'];
|
|
60
|
+
DatePicker.rootElement = 'wrapper';
|
|
61
|
+
DatePicker.withVariantTypes = (styles) => {
|
|
62
|
+
return DatePicker;
|
|
63
|
+
};
|
|
64
|
+
DatePicker.defaultProps = {
|
|
65
|
+
minDate: new Date(1910, 0, 1),
|
|
66
|
+
maxDate: new Date(),
|
|
67
|
+
disabled: false,
|
|
68
|
+
};
|
|
69
|
+
WebStyleRegistry.registerComponent(DatePicker);
|
|
70
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/DatePicker/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/components/DatePicker/styles.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/components/DatePicker/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { Modal as RACModal, Dialog } from 'react-aria-components';
|
|
3
|
+
import { ModalContext, useModalContext } from '../Modal/context';
|
|
4
|
+
import { ModalBackdrop, ModalBody, ModalFooter, ModalHeader } from '../Modal/elements';
|
|
5
|
+
import { useStylesFor } from '../../lib/hooks/useStylesFor';
|
|
6
|
+
import { WebStyleRegistry } from '../../lib/WebStyleRegistry';
|
|
7
|
+
export * from './styles';
|
|
8
|
+
export * from './types';
|
|
9
|
+
const DrawerProvider = ({ children, position: _position, ...props }) => {
|
|
10
|
+
const styles = useStylesFor(Drawer.styleRegistryName, props.style);
|
|
11
|
+
const close = () => {
|
|
12
|
+
props.toggle?.();
|
|
13
|
+
props.onClose?.();
|
|
14
|
+
};
|
|
15
|
+
const value = {
|
|
16
|
+
props,
|
|
17
|
+
styles: styles,
|
|
18
|
+
close,
|
|
19
|
+
};
|
|
20
|
+
return (_jsx(ModalContext.Provider, { value: value, children: children }));
|
|
21
|
+
};
|
|
22
|
+
const DrawerBox = ({ children, position }) => {
|
|
23
|
+
const { styles, props } = useModalContext();
|
|
24
|
+
const resolvedAriaLabel = !props.title ? (props.debugName ?? 'Dialog') : undefined;
|
|
25
|
+
return (_jsx(RACModal, { css: styles.box, "data-position": position, children: _jsx(Dialog, { "aria-label": resolvedAriaLabel, children: children }) }));
|
|
26
|
+
};
|
|
27
|
+
/**
|
|
28
|
+
* Side-panel overlay that slides in from a configurable edge of the viewport.
|
|
29
|
+
* Shares the same dismiss mechanics as `Modal` (backdrop click, Escape key), controlled by `closable` et al.
|
|
30
|
+
* Uses: `ModalBackdrop`, `ModalBody`, `ModalFooter`, `ModalHeader`
|
|
31
|
+
*/
|
|
32
|
+
export const Drawer = (props) => {
|
|
33
|
+
const { children, position, ...rest } = { ...Drawer.defaultProps, ...props };
|
|
34
|
+
return (_jsx(DrawerProvider, { ...rest, position: position, children: _jsx(ModalBackdrop, { children: _jsxs(DrawerBox, { position: position, children: [_jsx(ModalHeader, {}), _jsx(ModalBody, { children: children }), _jsx(ModalFooter, {})] }) }) }));
|
|
35
|
+
};
|
|
36
|
+
Drawer.styleRegistryName = 'Drawer';
|
|
37
|
+
Drawer.elements = ['backdrop', 'box', 'header', 'body', 'footer', 'title', 'description'];
|
|
38
|
+
Drawer.rootElement = 'backdrop';
|
|
39
|
+
Drawer.withVariantTypes = (styles) => {
|
|
40
|
+
return Drawer;
|
|
41
|
+
};
|
|
42
|
+
Drawer.defaultProps = {
|
|
43
|
+
position: 'left',
|
|
44
|
+
closable: true,
|
|
45
|
+
showClose: false,
|
|
46
|
+
dismissOnBackdrop: true,
|
|
47
|
+
closeOnEscape: true,
|
|
48
|
+
};
|
|
49
|
+
WebStyleRegistry.registerComponent(Drawer);
|
|
50
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Drawer/index.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,KAAK,IAAI,QAAQ,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAA;AACjE,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAChE,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA;AAEtF,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAA;AAI7D,cAAc,UAAU,CAAA;AACxB,cAAc,SAAS,CAAA;AAEvB,MAAM,cAAc,GAAG,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,KAAK,EAAe,EAAE,EAAE;IAClF,MAAM,MAAM,GAAG,YAAY,CAAC,MAAM,CAAC,iBAAiB,EAAE,KAAK,CAAC,KAAK,CAAC,CAAA;IAClE,MAAM,KAAK,GAAG,GAAG,EAAE;QACjB,KAAK,CAAC,MAAM,EAAE,EAAE,CAAA;QAChB,KAAK,CAAC,OAAO,EAAE,EAAE,CAAA;IACnB,CAAC,CAAA;IACD,MAAM,KAAK,GAAG;QACZ,KAAK;QACL,MAAM,EAAE,MAAuC;QAC/C,KAAK;KACN,CAAA;IACD,OAAO,CACL,KAAC,YAAY,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,YAChC,QAAQ,GACa,CACzB,CAAA;AACH,CAAC,CAAA;AAED,MAAM,SAAS,GAAG,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAmE,EAAE,EAAE;IAC5G,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,eAAe,EAAE,CAAA;IAC3C,MAAM,iBAAiB,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;IAClF,OAAO,CACL,KAAC,QAAQ,IAAC,GAAG,EAAG,MAAc,CAAC,GAAG,mBAAiB,QAAQ,YACzD,KAAC,MAAM,kBAAa,iBAAiB,YAClC,QAAQ,GACF,GACA,CACZ,CAAA;AACH,CAAC,CAAA;AAED;;;;GAIG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,KAAkB,EAAE,EAAE;IAC3C,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,MAAM,CAAC,YAAY,EAAE,GAAG,KAAK,EAAE,CAAA;IAC5E,OAAO,CACL,KAAC,cAAc,OAAK,IAAI,EAAE,QAAQ,EAAE,QAAQ,YAC1C,KAAC,aAAa,cACZ,MAAC,SAAS,IAAC,QAAQ,EAAE,QAAQ,aAC3B,KAAC,WAAW,KAAG,EACf,KAAC,SAAS,cAAE,QAAQ,GAAa,EACjC,KAAC,WAAW,KAAG,IACL,GACE,GACD,CAClB,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,iBAAiB,GAAG,QAAQ,CAAA;AACnC,MAAM,CAAC,QAAQ,GAAG,CAAC,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,aAAa,CAAC,CAAA;AACzF,MAAM,CAAC,WAAW,GAAG,UAAU,CAAA;AAE/B,MAAM,CAAC,gBAAgB,GAAG,CAAsB,MAAS,EAAE,EAAE;IAC3D,OAAO,MAA2E,CAAA;AACpF,CAAC,CAAA;AAED,MAAM,CAAC,YAAY,GAAG;IACpB,QAAQ,EAAE,MAAM;IAChB,QAAQ,EAAE,IAAI;IACd,SAAS,EAAE,KAAK;IAChB,iBAAiB,EAAE,IAAI;IACvB,aAAa,EAAE,IAAI;CACI,CAAA;AAEzB,gBAAgB,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/components/Drawer/styles.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/components/Drawer/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { createContext, useContext } from 'react';
|
|
3
|
+
import { useStylesFor } from '../../lib/hooks/useStylesFor';
|
|
4
|
+
import { useDropzone } from './useDropzone';
|
|
5
|
+
function useDropzoneProvider(props) {
|
|
6
|
+
const { handle: externalHandle, style, children: _children, extensionProps = {}, ...dropzoneOptions } = props;
|
|
7
|
+
// Always call the hook — satisfies Rules of Hooks.
|
|
8
|
+
// When an external handle is provided its result is discarded.
|
|
9
|
+
const internalHandle = useDropzone(dropzoneOptions);
|
|
10
|
+
const handle = externalHandle ?? internalHandle;
|
|
11
|
+
const styles = useStylesFor('Dropzone', style);
|
|
12
|
+
return {
|
|
13
|
+
handle,
|
|
14
|
+
styles: styles,
|
|
15
|
+
extensionProps,
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export const DropzoneContext = createContext(null);
|
|
19
|
+
/**
|
|
20
|
+
* Reads the nearest `Dropzone.Provider` context value.
|
|
21
|
+
* Throws if called outside a `Dropzone.Provider` tree.
|
|
22
|
+
*/
|
|
23
|
+
export const useDropzoneContext = () => {
|
|
24
|
+
const ctx = useContext(DropzoneContext);
|
|
25
|
+
if (!ctx)
|
|
26
|
+
throw new Error('useDropzoneContext must be used inside Dropzone.Provider');
|
|
27
|
+
return ctx;
|
|
28
|
+
};
|
|
29
|
+
/**
|
|
30
|
+
* Wires a `DropzoneHandle` and resolved styles into React context for all
|
|
31
|
+
* Dropzone sub-components. Accepts either a pre-built `handle` prop (external
|
|
32
|
+
* control) or raw `UseDropzoneOptions` to have the Provider create a handle
|
|
33
|
+
* internally.
|
|
34
|
+
*/
|
|
35
|
+
export const DropzoneProvider = (props) => {
|
|
36
|
+
const value = useDropzoneProvider(props);
|
|
37
|
+
return (_jsx(DropzoneContext.Provider, { value: value, children: props.children }));
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../src/components/Dropzone/context.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAIjD,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,SAAS,mBAAmB,CAAC,KAA4B;IACvD,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,GAAG,EAA+B,EAAE,GAAG,eAAe,EAAE,GAAG,KAAK,CAAA;IAE1I,mDAAmD;IACnD,+DAA+D;IAC/D,MAAM,cAAc,GAAG,WAAW,CAAC,eAAe,CAAC,CAAA;IACnD,MAAM,MAAM,GAAG,cAAc,IAAI,cAAc,CAAA;IAE/C,MAAM,MAAM,GAAG,YAAY,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;IAE9C,OAAO;QACL,MAAM;QACN,MAAM,EAAE,MAA0C;QAClD,cAAc;KACf,CAAA;AACH,CAAC;AAID,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAA8B,IAAI,CAAC,CAAA;AAE/E;;;GAGG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAyB,EAAE;IAC3D,MAAM,GAAG,GAAG,UAAU,CAAC,eAAe,CAAC,CAAA;IACvC,IAAI,CAAC,GAAG;QAAE,MAAM,IAAI,KAAK,CAAC,0DAA0D,CAAC,CAAA;IACrF,OAAO,GAAG,CAAA;AACZ,CAAC,CAAA;AAED;;;;;GAKG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,KAA4B,EAAE,EAAE;IAC/D,MAAM,KAAK,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAA;IACxC,OAAO,CACL,KAAC,eAAe,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,YACnC,KAAK,CAAC,QAAQ,GACU,CAC5B,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { createPortal } from 'react-dom';
|
|
3
|
+
import { View } from '../View';
|
|
4
|
+
import { useDropzoneContext } from './context';
|
|
5
|
+
/**
|
|
6
|
+
* Droppable zone element. Applies `getRootProps` and `getInputProps` from the
|
|
7
|
+
* nearest `Dropzone.Provider` handle to a root `View` and a hidden `<input>`.
|
|
8
|
+
*
|
|
9
|
+
* Must be rendered inside `Dropzone.Provider`.
|
|
10
|
+
*/
|
|
11
|
+
export const DropzoneWrapper = ({ children }) => {
|
|
12
|
+
const { handle, styles } = useDropzoneContext();
|
|
13
|
+
return (_jsxs(View, { ...handle.dropzone.getRootProps(), style: styles.dropzone, children: [children, _jsx("input", { ...handle.dropzone.getInputProps() })] }));
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* Overlay rendered on top of `Dropzone.Wrapper` while a file is being dragged
|
|
17
|
+
* over this specific zone (`isDragActive`). Place it as a child of
|
|
18
|
+
* `Dropzone.Wrapper` so it inherits the wrapper's positioning context.
|
|
19
|
+
*
|
|
20
|
+
* For a page-wide overlay that activates when dragging anywhere on the
|
|
21
|
+
* document, use `Dropzone.FullscreenOverlay` instead.
|
|
22
|
+
*
|
|
23
|
+
* Must be rendered inside `Dropzone.Provider`.
|
|
24
|
+
*/
|
|
25
|
+
export const DropzoneOverlay = ({ children }) => {
|
|
26
|
+
const { handle, styles } = useDropzoneContext();
|
|
27
|
+
if (!handle.dropzone.isDragActive)
|
|
28
|
+
return null;
|
|
29
|
+
return (_jsx(View, { style: styles.overlay, children: _jsx(View, { style: styles.overlayInner, children: children }) }));
|
|
30
|
+
};
|
|
31
|
+
/**
|
|
32
|
+
* Full-page overlay rendered via a React portal into `document.body` while
|
|
33
|
+
* a file is being dragged anywhere on the document (`isDragGlobal`).
|
|
34
|
+
*
|
|
35
|
+
* Unlike `Dropzone.Overlay`, this component is not scoped to the wrapper zone —
|
|
36
|
+
* it activates the moment a drag enters the browser window. Position it with
|
|
37
|
+
* `position: fixed; inset: 0` in the `overlay` style key.
|
|
38
|
+
*
|
|
39
|
+
* Must be rendered inside `Dropzone.Provider`.
|
|
40
|
+
*/
|
|
41
|
+
export const DropzoneFullscreenOverlay = ({ children }) => {
|
|
42
|
+
const { handle, styles } = useDropzoneContext();
|
|
43
|
+
if (!handle.dropzone.isDragGlobal)
|
|
44
|
+
return null;
|
|
45
|
+
if (typeof document === 'undefined')
|
|
46
|
+
return null;
|
|
47
|
+
// Spread getRootProps (minus ref) so drops on the fullscreen overlay are captured by this dropzone.
|
|
48
|
+
const { ref: _ref, ...rootProps } = handle.dropzone.getRootProps();
|
|
49
|
+
return createPortal(_jsx(View, { ...rootProps, style: styles.fullscreenOverlay, children: _jsx(View, { style: styles.fullscreenOverlayInner, children: children }) }), document.body);
|
|
50
|
+
};
|
|
51
|
+
//# sourceMappingURL=elements.js.map
|