@codeleap/mobile 7.0.0 → 7.0.2
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/Registry.js +47 -0
- package/dist/Registry.js.map +1 -0
- 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/Autocomplete/index.js +150 -0
- package/dist/components/Autocomplete/index.js.map +1 -0
- package/dist/components/Autocomplete/styles.js +2 -0
- package/dist/components/Autocomplete/styles.js.map +1 -0
- package/dist/components/Autocomplete/types.js +2 -0
- package/dist/components/Autocomplete/types.js.map +1 -0
- package/dist/components/Avatar/components/Badge.js +13 -0
- package/dist/components/Avatar/components/Badge.js.map +1 -0
- package/dist/components/Avatar/components/Content.js +19 -0
- package/dist/components/Avatar/components/Content.js.map +1 -0
- package/dist/components/Avatar/components/Illustration.js +11 -0
- package/dist/components/Avatar/components/Illustration.js.map +1 -0
- package/dist/components/Avatar/components/OverlayIcon.js +11 -0
- package/dist/components/Avatar/components/OverlayIcon.js.map +1 -0
- package/dist/components/Avatar/components/Text.js +19 -0
- package/dist/components/Avatar/components/Text.js.map +1 -0
- package/dist/components/Avatar/components/Wrapper.js +30 -0
- package/dist/components/Avatar/components/Wrapper.js.map +1 -0
- package/dist/components/Avatar/context.js +13 -0
- package/dist/components/Avatar/context.js.map +1 -0
- package/dist/components/Avatar/index.js +35 -0
- package/dist/components/Avatar/index.js.map +1 -0
- package/dist/components/Avatar/styles.js +2 -0
- package/dist/components/Avatar/styles.js.map +1 -0
- package/dist/components/Avatar/types.js +2 -0
- package/dist/components/Avatar/types.js.map +1 -0
- package/dist/components/AvatarGroup/index.js +36 -0
- package/dist/components/AvatarGroup/index.js.map +1 -0
- package/dist/components/AvatarGroup/styles.js +2 -0
- package/dist/components/AvatarGroup/styles.js.map +1 -0
- package/dist/components/AvatarGroup/types.js +2 -0
- package/dist/components/AvatarGroup/types.js.map +1 -0
- package/dist/components/Backdrop/index.js +34 -0
- package/dist/components/Backdrop/index.js.map +1 -0
- package/dist/components/Backdrop/styles.js +2 -0
- package/dist/components/Backdrop/styles.js.map +1 -0
- package/dist/components/Backdrop/types.js +2 -0
- package/dist/components/Backdrop/types.js.map +1 -0
- package/dist/components/Badge/index.js +66 -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 +73 -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 +100 -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/CalendarInput/index.js +67 -0
- package/dist/components/CalendarInput/index.js.map +1 -0
- package/dist/components/CalendarInput/styles.js +2 -0
- package/dist/components/CalendarInput/styles.js.map +1 -0
- package/dist/components/CalendarInput/types.js +2 -0
- package/dist/components/CalendarInput/types.js.map +1 -0
- package/dist/components/Checkbox/index.js +85 -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 +45 -0
- package/dist/components/Collapse/index.js.map +1 -0
- package/dist/components/Collapse/types.js +2 -0
- package/dist/components/Collapse/types.js.map +1 -0
- package/dist/components/DatePickerModal/index.js +107 -0
- package/dist/components/DatePickerModal/index.js.map +1 -0
- package/dist/components/DatePickerModal/styles.js +2 -0
- package/dist/components/DatePickerModal/styles.js.map +1 -0
- package/dist/components/DatePickerModal/types.js +2 -0
- package/dist/components/DatePickerModal/types.js.map +1 -0
- package/dist/components/EmptyPlaceholder/components/Button.js +15 -0
- package/dist/components/EmptyPlaceholder/components/Button.js.map +1 -0
- package/dist/components/EmptyPlaceholder/components/Content.js +36 -0
- package/dist/components/EmptyPlaceholder/components/Content.js.map +1 -0
- package/dist/components/EmptyPlaceholder/components/Illustration.js +9 -0
- package/dist/components/EmptyPlaceholder/components/Illustration.js.map +1 -0
- package/dist/components/EmptyPlaceholder/components/Info.js +9 -0
- package/dist/components/EmptyPlaceholder/components/Info.js.map +1 -0
- package/dist/components/EmptyPlaceholder/components/Loading.js +20 -0
- package/dist/components/EmptyPlaceholder/components/Loading.js.map +1 -0
- package/dist/components/EmptyPlaceholder/context.js +13 -0
- package/dist/components/EmptyPlaceholder/context.js.map +1 -0
- package/dist/components/EmptyPlaceholder/index.js +38 -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/FileInput/index.js +126 -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/Grid/index.js +65 -0
- package/dist/components/Grid/index.js.map +1 -0
- package/dist/components/Grid/styles.js +2 -0
- package/dist/components/Grid/styles.js.map +1 -0
- package/dist/components/Grid/types.js +2 -0
- package/dist/components/Grid/types.js.map +1 -0
- package/dist/components/Icon/index.js +59 -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/Image/index.js +108 -0
- package/dist/components/Image/index.js.map +1 -0
- package/dist/components/Image/styles.js +2 -0
- package/dist/components/Image/styles.js.map +1 -0
- package/dist/components/Image/types.js +2 -0
- package/dist/components/Image/types.js.map +1 -0
- package/dist/components/ImageView/Spotlight.js +139 -0
- package/dist/components/ImageView/Spotlight.js.map +1 -0
- package/dist/components/ImageView/component.js +17 -0
- package/dist/components/ImageView/component.js.map +1 -0
- package/dist/components/ImageView/index.js +3 -0
- package/dist/components/ImageView/index.js.map +1 -0
- package/dist/components/InputBase/index.js +37 -0
- package/dist/components/InputBase/index.js.map +1 -0
- package/dist/components/InputBase/styles.js +98 -0
- package/dist/components/InputBase/styles.js.map +1 -0
- package/dist/components/InputBase/types.js +2 -0
- package/dist/components/InputBase/types.js.map +1 -0
- package/dist/components/InputBase/useInputBase.js +48 -0
- package/dist/components/InputBase/useInputBase.js.map +1 -0
- package/dist/components/InputBase/useInputBasePartialStyles.js +35 -0
- package/dist/components/InputBase/useInputBasePartialStyles.js.map +1 -0
- package/dist/components/InputBase/utils.js +31 -0
- package/dist/components/InputBase/utils.js.map +1 -0
- package/dist/components/InputOverlay/index.js +68 -0
- package/dist/components/InputOverlay/index.js.map +1 -0
- package/dist/components/InputOverlay/store.js +49 -0
- package/dist/components/InputOverlay/store.js.map +1 -0
- package/dist/components/InputOverlay/types.js +2 -0
- package/dist/components/InputOverlay/types.js.map +1 -0
- package/dist/components/List/index.js +66 -0
- package/dist/components/List/index.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 +51 -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/Modal/index.js +76 -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 +120 -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 +116 -0
- package/dist/components/NumberIncrement/useNumberIncrement.js.map +1 -0
- package/dist/components/Pager/PagerDots.js +19 -0
- package/dist/components/Pager/PagerDots.js.map +1 -0
- package/dist/components/Pager/PagerItem.js +14 -0
- package/dist/components/Pager/PagerItem.js.map +1 -0
- package/dist/components/Pager/index.js +78 -0
- package/dist/components/Pager/index.js.map +1 -0
- package/dist/components/Pager/styles.js +2 -0
- package/dist/components/Pager/styles.js.map +1 -0
- package/dist/components/Pager/types.js +2 -0
- package/dist/components/Pager/types.js.map +1 -0
- package/dist/components/PaginationIndicator/index.js +36 -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/PlacesAutocomplete/index.js +71 -0
- package/dist/components/PlacesAutocomplete/index.js.map +1 -0
- package/dist/components/PlacesAutocomplete/styles.js +2 -0
- package/dist/components/PlacesAutocomplete/styles.js.map +1 -0
- package/dist/components/PlacesAutocomplete/types.js +2 -0
- package/dist/components/PlacesAutocomplete/types.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/RefreshControl/index.js +27 -0
- package/dist/components/RefreshControl/index.js.map +1 -0
- package/dist/components/RefreshControl/styles.js +2 -0
- package/dist/components/RefreshControl/styles.js.map +1 -0
- package/dist/components/RefreshControl/types.js +2 -0
- package/dist/components/RefreshControl/types.js.map +1 -0
- package/dist/components/Scroll/index.js +40 -0
- package/dist/components/Scroll/index.js.map +1 -0
- package/dist/components/Scroll/styles.js +2 -0
- package/dist/components/Scroll/styles.js.map +1 -0
- package/dist/components/Scroll/types.js +2 -0
- package/dist/components/Scroll/types.js.map +1 -0
- package/dist/components/SearchInput/index.js +48 -0
- package/dist/components/SearchInput/index.js.map +1 -0
- package/dist/components/SectionFilters/context.js +6 -0
- package/dist/components/SectionFilters/context.js.map +1 -0
- package/dist/components/SectionFilters/index.js +47 -0
- package/dist/components/SectionFilters/index.js.map +1 -0
- package/dist/components/SectionFilters/types.js +2 -0
- package/dist/components/SectionFilters/types.js.map +1 -0
- package/dist/components/SectionFilters/useSectionFilters.js +148 -0
- package/dist/components/SectionFilters/useSectionFilters.js.map +1 -0
- package/dist/components/Sections/index.js +105 -0
- package/dist/components/Sections/index.js.map +1 -0
- package/dist/components/Sections/styles.js +2 -0
- package/dist/components/Sections/styles.js.map +1 -0
- package/dist/components/Sections/types.js +2 -0
- package/dist/components/Sections/types.js.map +1 -0
- package/dist/components/SegmentedControl/Option.js +20 -0
- package/dist/components/SegmentedControl/Option.js.map +1 -0
- package/dist/components/SegmentedControl/index.js +130 -0
- package/dist/components/SegmentedControl/index.js.map +1 -0
- package/dist/components/SegmentedControl/styles.js +2 -0
- package/dist/components/SegmentedControl/styles.js.map +1 -0
- package/dist/components/SegmentedControl/types.js +2 -0
- package/dist/components/SegmentedControl/types.js.map +1 -0
- package/dist/components/Select/index.js +204 -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/Slider/index.js +99 -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/SortablePhotos/index.js +85 -0
- package/dist/components/SortablePhotos/index.js.map +1 -0
- package/dist/components/SortablePhotos/styles.js +2 -0
- package/dist/components/SortablePhotos/styles.js.map +1 -0
- package/dist/components/SortablePhotos/types.js +2 -0
- package/dist/components/SortablePhotos/types.js.map +1 -0
- package/dist/components/SortablePhotos/useSortablePhotos.js +143 -0
- package/dist/components/SortablePhotos/useSortablePhotos.js.map +1 -0
- package/dist/components/Switch/index.js +81 -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/Tabs/Context.js +44 -0
- package/dist/components/Tabs/Context.js.map +1 -0
- package/dist/components/Tabs/Panel.js +21 -0
- package/dist/components/Tabs/Panel.js.map +1 -0
- package/dist/components/Tabs/Tab.js +28 -0
- package/dist/components/Tabs/Tab.js.map +1 -0
- package/dist/components/Tabs/TabList.js +16 -0
- package/dist/components/Tabs/TabList.js.map +1 -0
- package/dist/components/Tabs/index.js +34 -0
- package/dist/components/Tabs/index.js.map +1 -0
- package/dist/components/Tabs/styles.js +2 -0
- package/dist/components/Tabs/styles.js.map +1 -0
- package/dist/components/Tabs/types.js +2 -0
- package/dist/components/Tabs/types.js.map +1 -0
- package/dist/components/Text/index.js +82 -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/TextInput/index.js +99 -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 +66 -0
- package/dist/components/TextInput/useTextInput.js.map +1 -0
- package/dist/components/TimeInput/index.js +50 -0
- package/dist/components/TimeInput/index.js.map +1 -0
- package/dist/components/TimeInput/styles.js +2 -0
- package/dist/components/TimeInput/styles.js.map +1 -0
- package/dist/components/TimeInput/types.js +2 -0
- package/dist/components/TimeInput/types.js.map +1 -0
- package/dist/components/Touchable/index.js +170 -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 +28 -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 +46 -0
- package/dist/components/components.js.map +1 -0
- package/dist/hooks/index.js +6 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/useAnimatedState.js +28 -0
- package/dist/hooks/useAnimatedState.js.map +1 -0
- package/dist/hooks/useAppState.js +16 -0
- package/dist/hooks/useAppState.js.map +1 -0
- package/dist/hooks/useKeyboardController.js +22 -0
- package/dist/hooks/useKeyboardController.js.map +1 -0
- package/dist/hooks/useStatusBar.js +18 -0
- package/dist/hooks/useStatusBar.js.map +1 -0
- package/dist/hooks/useStylesFor.js +13 -0
- package/dist/hooks/useStylesFor.js.map +1 -0
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -0
- package/dist/modules/PressableRipple/index.js +3 -0
- package/dist/modules/PressableRipple/index.js.map +1 -0
- package/dist/modules/PressableRipple/ripple.js +168 -0
- package/dist/modules/PressableRipple/ripple.js.map +1 -0
- package/dist/modules/PressableRipple/styles.js +18 -0
- package/dist/modules/PressableRipple/styles.js.map +1 -0
- package/dist/modules/PressableRipple/type.js +2 -0
- package/dist/modules/PressableRipple/type.js.map +1 -0
- package/dist/modules/backgroundTimer.js +33 -0
- package/dist/modules/backgroundTimer.js.map +1 -0
- package/dist/modules/formConfig.js +26 -0
- package/dist/modules/formConfig.js.map +1 -0
- package/dist/modules/index.js +3 -0
- package/dist/modules/index.js.map +1 -0
- package/dist/modules/reactNavigation.js +39 -0
- package/dist/modules/reactNavigation.js.map +1 -0
- package/dist/modules/scroll.js +59 -0
- package/dist/modules/scroll.js.map +1 -0
- package/dist/modules/textInputMask.js +7 -0
- package/dist/modules/textInputMask.js.map +1 -0
- package/dist/modules/types/textInputMask.js +2 -0
- package/dist/modules/types/textInputMask.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/dist/utils/NotificationManager/index.js +170 -0
- package/dist/utils/NotificationManager/index.js.map +1 -0
- package/dist/utils/NotificationManager/types.js +2 -0
- package/dist/utils/NotificationManager/types.js.map +1 -0
- package/dist/utils/OSAlert.js +128 -0
- package/dist/utils/OSAlert.js.map +1 -0
- package/dist/utils/StorageManager.js +84 -0
- package/dist/utils/StorageManager.js.map +1 -0
- package/dist/utils/Subscription.js +48 -0
- package/dist/utils/Subscription.js.map +1 -0
- package/dist/utils/hooks.js +199 -0
- package/dist/utils/hooks.js.map +1 -0
- package/dist/utils/index.js +11 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/input.js +45 -0
- package/dist/utils/input.js.map +1 -0
- package/dist/utils/locale.js +11 -0
- package/dist/utils/locale.js.map +1 -0
- package/dist/utils/misc.js +111 -0
- package/dist/utils/misc.js.map +1 -0
- package/dist/utils/theme.js +37 -0
- package/dist/utils/theme.js.map +1 -0
- package/dist/utils/useQueryListRefresh.js +33 -0
- package/dist/utils/useQueryListRefresh.js.map +1 -0
- package/package.json +19 -19
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useCompositionStyles } from '@codeleap/styles';
|
|
3
|
+
import dayjs from 'dayjs';
|
|
4
|
+
import { fields } from '@codeleap/form';
|
|
5
|
+
import DatePicker from 'react-native-date-picker';
|
|
6
|
+
import { useStylesFor } from '../../hooks';
|
|
7
|
+
import { useInputBase } from '../InputBase';
|
|
8
|
+
import { View } from '../View';
|
|
9
|
+
import { TextInput } from '../TextInput';
|
|
10
|
+
import { MobileStyleRegistry } from '../../Registry';
|
|
11
|
+
import { InputOverlay, inputOverlayManager } from '../InputOverlay';
|
|
12
|
+
export * from './styles';
|
|
13
|
+
export * from './types';
|
|
14
|
+
/**
|
|
15
|
+
* The picker is always rendered in `mode='time'` and `theme='light'` regardless of system theme;
|
|
16
|
+
* dark mode is not forwarded to the native `react-native-date-picker` wheel.
|
|
17
|
+
* Default format `'hh:mm A'` is 12-hour with AM/PM — pass `format='HH:mm'` for 24-hour display.
|
|
18
|
+
*/
|
|
19
|
+
export const TimeInput = (props) => {
|
|
20
|
+
const { style, value, onValueChange, disabled, gap, timePickerPosition, rightIcon, leftIcon, autoClosePeersOverlays, field, format, overlay, timePickerProps, ...textInputProps } = {
|
|
21
|
+
...TimeInput.defaultProps,
|
|
22
|
+
...props
|
|
23
|
+
};
|
|
24
|
+
const styles = useStylesFor(TimeInput.styleRegistryName, style);
|
|
25
|
+
const compositionStyles = useCompositionStyles(['input'], styles);
|
|
26
|
+
const { inputValue, onInputValueChange, } = useInputBase(field, fields.date, { value, onValueChange });
|
|
27
|
+
const { isOpen, toggle, id } = inputOverlayManager.use();
|
|
28
|
+
return (_jsx(InputOverlay.Layout, { style: styles.wrapper, position: timePickerPosition, gap: gap, isOpen: isOpen, mode: overlay ? 'overlay' : 'content', hideOverlay: disabled, id: id, content: _jsx(View, { style: styles.timePicker, children: _jsx(DatePicker, { mode: 'time', theme: 'light', ...timePickerProps, onDateChange: onInputValueChange, date: inputValue ?? new Date() }) }), children: _jsx(TextInput, { placeholder: 'Select a time', disabled: disabled, ...textInputProps, style: compositionStyles.input, value: !inputValue ? '' : dayjs(inputValue).format(format), onValueChange: () => inputValue, onPress: disabled ? undefined : toggle, focused: isOpen, leftIcon: !leftIcon ? null : {
|
|
29
|
+
...leftIcon,
|
|
30
|
+
onPress: toggle,
|
|
31
|
+
}, rightIcon: !rightIcon ? null : {
|
|
32
|
+
...rightIcon,
|
|
33
|
+
onPress: toggle,
|
|
34
|
+
} }) }));
|
|
35
|
+
};
|
|
36
|
+
TimeInput.styleRegistryName = 'TimeInput';
|
|
37
|
+
TimeInput.elements = ['wrapper', 'timePicker', 'input'];
|
|
38
|
+
TimeInput.rootElement = 'wrapper';
|
|
39
|
+
TimeInput.withVariantTypes = (styles) => {
|
|
40
|
+
return TimeInput;
|
|
41
|
+
};
|
|
42
|
+
TimeInput.defaultProps = {
|
|
43
|
+
gap: 8,
|
|
44
|
+
timerPickerPosition: 'left',
|
|
45
|
+
autoClosePeersCalendars: false,
|
|
46
|
+
format: 'hh:mm A',
|
|
47
|
+
overlay: true,
|
|
48
|
+
};
|
|
49
|
+
MobileStyleRegistry.registerComponent(TimeInput);
|
|
50
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/TimeInput/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/components/TimeInput/styles.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/components/TimeInput/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React, { forwardRef } from 'react';
|
|
3
|
+
import { TypeGuards } from '@codeleap/types';
|
|
4
|
+
import { onMount, useComponentTestId } from '@codeleap/hooks';
|
|
5
|
+
import { Pressable, StyleSheet, Platform } from 'react-native';
|
|
6
|
+
import { View } from '../View';
|
|
7
|
+
import { usePressableFeedback } from '../../utils';
|
|
8
|
+
import { Keyboard } from 'react-native';
|
|
9
|
+
import { PressableRipple } from '../../modules/PressableRipple';
|
|
10
|
+
import { MobileStyleRegistry } from '../../Registry';
|
|
11
|
+
import { useStylesFor } from '../../hooks';
|
|
12
|
+
import { logger } from '@codeleap/logger';
|
|
13
|
+
export * from './styles';
|
|
14
|
+
export * from './types';
|
|
15
|
+
export const Touchable = forwardRef((touchableProps, ref) => {
|
|
16
|
+
const { children, onPress, style, debugName, debugComponent, debounce, leadingDebounce, noFeedback, setPressed, rippleDisabled, analyticsEnabled, analyticsName, analyticsData = {}, dismissKeyboard, ...props } = {
|
|
17
|
+
...Touchable.defaultProps,
|
|
18
|
+
...touchableProps,
|
|
19
|
+
};
|
|
20
|
+
// Start locked when leadingDebounce is true so the very first render is immune to ghost taps
|
|
21
|
+
// (e.g. a list item that mounts directly under the user's finger on Android).
|
|
22
|
+
const pressed = React.useRef(!!leadingDebounce);
|
|
23
|
+
onMount(() => {
|
|
24
|
+
if (!!leadingDebounce && !!debounce) {
|
|
25
|
+
setTimeout(() => {
|
|
26
|
+
pressed.current = false;
|
|
27
|
+
}, debounce);
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
const styles = useStylesFor(Touchable.styleRegistryName, style);
|
|
31
|
+
const testId = useComponentTestId(Touchable, touchableProps, ['style', 'children', 'debounce']);
|
|
32
|
+
const press = () => {
|
|
33
|
+
if (!onPress)
|
|
34
|
+
return;
|
|
35
|
+
const _onPress = () => {
|
|
36
|
+
logger.log(`<${debugComponent || 'Touchable'}/> pressed:`, debugName);
|
|
37
|
+
if (dismissKeyboard) {
|
|
38
|
+
Keyboard.dismiss();
|
|
39
|
+
}
|
|
40
|
+
// if (analyticsEnabled) {
|
|
41
|
+
// const name = analyticsName || debugName
|
|
42
|
+
// if (!!name?.trim?.()) {
|
|
43
|
+
// logger.analytics?.interaction(name, analyticsData)
|
|
44
|
+
// }
|
|
45
|
+
// }
|
|
46
|
+
onPress();
|
|
47
|
+
};
|
|
48
|
+
if (TypeGuards.isNumber(debounce)) {
|
|
49
|
+
if (pressed.current) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
setPressed?.(true);
|
|
53
|
+
pressed.current = true;
|
|
54
|
+
_onPress();
|
|
55
|
+
setTimeout(() => {
|
|
56
|
+
setPressed?.(false);
|
|
57
|
+
pressed.current = false;
|
|
58
|
+
}, debounce);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
_onPress();
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
const _styles = StyleSheet.flatten([styles?.wrapper, props?.disabled && styles?.['wrapper:disabled']]);
|
|
65
|
+
const disableFeedback = !onPress || noFeedback;
|
|
66
|
+
const { rippleConfig, getFeedbackStyle } = usePressableFeedback(_styles, {
|
|
67
|
+
hightlightPropertyIn: 'backgroundColor',
|
|
68
|
+
hightlightPropertyOut: 'backgroundColor',
|
|
69
|
+
disabled: disableFeedback,
|
|
70
|
+
feedbackConfig: styles?.feedback,
|
|
71
|
+
});
|
|
72
|
+
const Wrapper = View;
|
|
73
|
+
// Style properties are split between the outer View (wrapperStyle) and the inner Pressable/Ripple
|
|
74
|
+
// (pressableStyle) so that margin/position are owned by the layout parent while the pressable
|
|
75
|
+
// touch area matches the visual surface. Radius is copied to both so clipping stays consistent.
|
|
76
|
+
const { radiusStyle, wrapperStyle, pressableStyle } = React.useMemo(() => {
|
|
77
|
+
const wrapperkeys = [
|
|
78
|
+
'margin',
|
|
79
|
+
'alignSelf',
|
|
80
|
+
'top!',
|
|
81
|
+
'left!',
|
|
82
|
+
'right!',
|
|
83
|
+
'bottom!',
|
|
84
|
+
'position!',
|
|
85
|
+
'transform!',
|
|
86
|
+
];
|
|
87
|
+
const radiusKey = [
|
|
88
|
+
'Radius#',
|
|
89
|
+
];
|
|
90
|
+
const sharedKeys = [
|
|
91
|
+
'width!',
|
|
92
|
+
'height!',
|
|
93
|
+
'flex!',
|
|
94
|
+
'backgroundColor!',
|
|
95
|
+
];
|
|
96
|
+
const wrapperStyle = {};
|
|
97
|
+
const pressableStyle = {};
|
|
98
|
+
const radiusStyle = {};
|
|
99
|
+
const match = (k, key) => {
|
|
100
|
+
if (k.endsWith('#')) {
|
|
101
|
+
return key.includes(k.substring(0, k.length - 1));
|
|
102
|
+
}
|
|
103
|
+
else if (k.endsWith('!')) {
|
|
104
|
+
return key === k.substring(0, k.length - 1);
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
return key.startsWith(k);
|
|
108
|
+
}
|
|
109
|
+
};
|
|
110
|
+
Object.entries(_styles).forEach(([key, value]) => {
|
|
111
|
+
if (radiusKey.some(k => match(k, key))) {
|
|
112
|
+
wrapperStyle[key] = value;
|
|
113
|
+
pressableStyle[key] = value;
|
|
114
|
+
radiusStyle[key] = value;
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
if (wrapperkeys.some(k => match(k, key))) {
|
|
118
|
+
wrapperStyle[key] = value;
|
|
119
|
+
}
|
|
120
|
+
else if (sharedKeys.some(k => match(k, key))) {
|
|
121
|
+
wrapperStyle[key] = value;
|
|
122
|
+
pressableStyle[key] = value;
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
pressableStyle[key] = value;
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
if (wrapperStyle.position === 'absolute') {
|
|
129
|
+
pressableStyle.width = '100%';
|
|
130
|
+
pressableStyle.height = '100%';
|
|
131
|
+
}
|
|
132
|
+
wrapperStyle.overflow = 'visible';
|
|
133
|
+
return {
|
|
134
|
+
wrapperStyle,
|
|
135
|
+
pressableStyle,
|
|
136
|
+
radiusStyle,
|
|
137
|
+
};
|
|
138
|
+
}, [JSON.stringify(_styles)]);
|
|
139
|
+
const hitSlop = TypeGuards.isNumber(props.hitSlop) ? {
|
|
140
|
+
top: props.hitSlop,
|
|
141
|
+
left: props.hitSlop,
|
|
142
|
+
right: props.hitSlop,
|
|
143
|
+
bottom: props.hitSlop,
|
|
144
|
+
} : props.hitSlop;
|
|
145
|
+
// Ripple is Android-only; iOS uses Pressable's built-in opacity/color feedback via getFeedbackStyle.
|
|
146
|
+
const disableRipple = disableFeedback || rippleDisabled || Platform.OS !== 'android';
|
|
147
|
+
return (_jsx(Wrapper, { style: wrapperStyle, hitSlop: hitSlop, children: !disableRipple ? (_jsx(PressableRipple, { onPress: press, testID: testId, ...props, style: [pressableStyle, styles?.pressable], rippleFades: false, rippleDuration: 350, rippleOpacity: 0.1, ...rippleConfig, radiusStyles: radiusStyle,
|
|
148
|
+
// @ts-ignore
|
|
149
|
+
ref: ref, children: children })) : (_jsx(Pressable, { onPress: press, style: ({ pressed }) => ([
|
|
150
|
+
pressableStyle,
|
|
151
|
+
getFeedbackStyle(pressed),
|
|
152
|
+
styles?.pressable,
|
|
153
|
+
]), testID: testId, ...props, ref: ref, children: children })) }));
|
|
154
|
+
});
|
|
155
|
+
Touchable.styleRegistryName = 'Touchable';
|
|
156
|
+
Touchable.elements = ['wrapper', 'feedback', 'pressable'];
|
|
157
|
+
Touchable.rootElement = 'wrapper';
|
|
158
|
+
Touchable.withVariantTypes = (styles) => {
|
|
159
|
+
return Touchable;
|
|
160
|
+
};
|
|
161
|
+
Touchable.defaultProps = {
|
|
162
|
+
debounce: 500,
|
|
163
|
+
noFeedback: false,
|
|
164
|
+
rippleDisabled: false,
|
|
165
|
+
analyticsEnabled: false,
|
|
166
|
+
analyticsName: null,
|
|
167
|
+
dismissKeyboard: true,
|
|
168
|
+
};
|
|
169
|
+
MobileStyleRegistry.registerComponent(Touchable);
|
|
170
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Touchable/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/components/Touchable/styles.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/components/Touchable/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef } from 'react';
|
|
3
|
+
import { View as RNView } from 'react-native';
|
|
4
|
+
import { MobileStyleRegistry } from '../../Registry';
|
|
5
|
+
import Animated from 'react-native-reanimated';
|
|
6
|
+
import { useStylesFor } from '../../hooks';
|
|
7
|
+
import { useComponentTestId } from '@codeleap/hooks';
|
|
8
|
+
export * from './types';
|
|
9
|
+
export * from './styles';
|
|
10
|
+
/** `View.Animated` is a convenience alias that passes `animated` as true; prefer it over setting the prop manually so variant types stay correct. */
|
|
11
|
+
export const View = forwardRef((props, ref) => {
|
|
12
|
+
const { style, animated = false, animatedStyle, ...viewProps } = props;
|
|
13
|
+
const styles = useStylesFor(View.styleRegistryName, style);
|
|
14
|
+
const testId = useComponentTestId(View, props, ['style', 'children', 'animated']);
|
|
15
|
+
const Component = animated ? Animated.View : RNView;
|
|
16
|
+
return (_jsx(Component, { testID: testId, ...viewProps, style: [styles.wrapper, animatedStyle], ref: ref }));
|
|
17
|
+
});
|
|
18
|
+
View.Animated = (props) => {
|
|
19
|
+
return _jsx(View, { ...props });
|
|
20
|
+
};
|
|
21
|
+
View.styleRegistryName = 'View';
|
|
22
|
+
View.elements = ['wrapper'];
|
|
23
|
+
View.rootElement = 'wrapper';
|
|
24
|
+
View.withVariantTypes = (styles) => {
|
|
25
|
+
return View;
|
|
26
|
+
};
|
|
27
|
+
MobileStyleRegistry.registerComponent(View);
|
|
28
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/View/index.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,IAAI,IAAI,MAAM,EAAE,MAAM,cAAc,CAAA;AAE7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAA;AACpD,OAAO,QAAQ,MAAM,yBAAyB,CAAA;AAE9C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAC1C,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AAEpD,cAAc,SAAS,CAAA;AACvB,cAAc,UAAU,CAAA;AAExB,qJAAqJ;AACrJ,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAoB,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;IAC/D,MAAM,EACJ,KAAK,EACL,QAAQ,GAAG,KAAK,EAChB,aAAa,EACb,GAAG,SAAS,EACb,GAAG,KAAK,CAAA;IAET,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAA;IAE1D,MAAM,MAAM,GAAG,kBAAkB,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,OAAO,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC,CAAA;IAEjF,MAAM,SAAS,GAAmC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAA;IAEnF,OAAO,CACL,KAAC,SAAS,IACR,MAAM,EAAE,MAAM,KACV,SAAS,EACb,KAAK,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,aAAa,CAAC,EACtC,GAAG,EAAE,GAAG,GACR,CACH,CAAA;AACH,CAAC,CAA0G,CAAA;AAE3G,IAAI,CAAC,QAAQ,GAAG,CAAC,KAAwB,EAAE,EAAE;IAC3C,OAAO,KAAC,IAAI,OAAK,KAAK,GAAI,CAAA;AAC5B,CAAC,CAAA;AAED,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAA;AAC/B,IAAI,CAAC,QAAQ,GAAG,CAAC,SAAS,CAAC,CAAA;AAC3B,IAAI,CAAC,WAAW,GAAG,SAAS,CAAA;AAE5B,IAAI,CAAC,gBAAgB,GAAG,CAAsB,MAAS,EAAE,EAAE;IACzD,OAAO,IAAuE,CAAA;AAChF,CAAC,CAAA;AAED,mBAAmB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/components/View/styles.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/components/View/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
export * from './View';
|
|
2
|
+
export * from './Icon';
|
|
3
|
+
export * from './Touchable';
|
|
4
|
+
export * from './Text';
|
|
5
|
+
export * from './Image';
|
|
6
|
+
export * from './Checkbox';
|
|
7
|
+
export * from './TextInput';
|
|
8
|
+
export * from './RadioInput';
|
|
9
|
+
export * from './Switch';
|
|
10
|
+
export * from './Sections';
|
|
11
|
+
export * from './Select';
|
|
12
|
+
export * from './FileInput';
|
|
13
|
+
export * from './Slider';
|
|
14
|
+
export * from './SegmentedControl';
|
|
15
|
+
export * from './Scroll';
|
|
16
|
+
export * from './List';
|
|
17
|
+
export * from './ActivityIndicator';
|
|
18
|
+
export * from './Button';
|
|
19
|
+
export * from './Modal';
|
|
20
|
+
export * from './Calendar';
|
|
21
|
+
export * from './ImageView';
|
|
22
|
+
export * from './Pager';
|
|
23
|
+
export * from './EmptyPlaceholder';
|
|
24
|
+
export * from './Backdrop';
|
|
25
|
+
export * from './SegmentedControl';
|
|
26
|
+
export * from './Autocomplete';
|
|
27
|
+
export * from './Grid';
|
|
28
|
+
export * from './LoadingOverlay';
|
|
29
|
+
export * from './InputBase';
|
|
30
|
+
export * from './DatePickerModal';
|
|
31
|
+
export * from './RefreshControl';
|
|
32
|
+
export * from './Avatar';
|
|
33
|
+
export * from './AvatarGroup';
|
|
34
|
+
export * from './NumberIncrement';
|
|
35
|
+
export * from './Badge';
|
|
36
|
+
export * from './SearchInput';
|
|
37
|
+
export * from './PaginationIndicator';
|
|
38
|
+
export * from './PlacesAutocomplete';
|
|
39
|
+
export * from './SortablePhotos';
|
|
40
|
+
export * from './SectionFilters';
|
|
41
|
+
export * from './Tabs';
|
|
42
|
+
export * from './CalendarInput';
|
|
43
|
+
export * from './TimeInput';
|
|
44
|
+
export * from './InputOverlay';
|
|
45
|
+
export * from './Collapse';
|
|
46
|
+
//# sourceMappingURL=components.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"components.js","sourceRoot":"","sources":["../../src/components/components.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA;AACtB,cAAc,QAAQ,CAAA;AACtB,cAAc,aAAa,CAAA;AAC3B,cAAc,QAAQ,CAAA;AACtB,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA;AAC5B,cAAc,UAAU,CAAA;AACxB,cAAc,YAAY,CAAA;AAC1B,cAAc,UAAU,CAAA;AACxB,cAAc,aAAa,CAAA;AAC3B,cAAc,UAAU,CAAA;AACxB,cAAc,oBAAoB,CAAA;AAClC,cAAc,UAAU,CAAA;AACxB,cAAc,QAAQ,CAAA;AACtB,cAAc,qBAAqB,CAAA;AACnC,cAAc,UAAU,CAAA;AACxB,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,aAAa,CAAA;AAC3B,cAAc,SAAS,CAAA;AACvB,cAAc,oBAAoB,CAAA;AAClC,cAAc,YAAY,CAAA;AAC1B,cAAc,oBAAoB,CAAA;AAClC,cAAc,gBAAgB,CAAA;AAC9B,cAAc,QAAQ,CAAA;AACtB,cAAc,kBAAkB,CAAA;AAChC,cAAc,aAAa,CAAA;AAC3B,cAAc,mBAAmB,CAAA;AACjC,cAAc,kBAAkB,CAAA;AAChC,cAAc,UAAU,CAAA;AACxB,cAAc,eAAe,CAAA;AAC7B,cAAc,mBAAmB,CAAA;AACjC,cAAc,SAAS,CAAA;AACvB,cAAc,eAAe,CAAA;AAC7B,cAAc,uBAAuB,CAAA;AACrC,cAAc,sBAAsB,CAAA;AACpC,cAAc,kBAAkB,CAAA;AAChC,cAAc,kBAAkB,CAAA;AAChC,cAAc,QAAQ,CAAA;AACtB,cAAc,iBAAiB,CAAA;AAC/B,cAAc,aAAa,CAAA;AAC3B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA;AAC9B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,yBAAyB,CAAA;AACvC,cAAc,eAAe,CAAA;AAC7B,cAAc,oBAAoB,CAAA"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
import { useSharedValue, useDerivedValue, runOnJS, isSharedValue } from 'react-native-reanimated';
|
|
3
|
+
/**
|
|
4
|
+
* `runOnJS(_setValue)` is required because `useDerivedValue` runs on the UI thread — calling a React state setter directly from a worklet would crash. The derived value callback fires synchronously after the shared value changes, then bounces the update back to the JS thread via `runOnJS`.
|
|
5
|
+
*
|
|
6
|
+
* Closures inside the `useDerivedValue` callback must only reference serializable values; capturing non-serializable JS objects here will silently break on the UI thread.
|
|
7
|
+
*/
|
|
8
|
+
export function useAnimatedState(initialValue) {
|
|
9
|
+
const sharedValue = isSharedValue(initialValue)
|
|
10
|
+
? initialValue
|
|
11
|
+
: useSharedValue(initialValue);
|
|
12
|
+
const [value, _setValue] = useState(isSharedValue(initialValue) ? initialValue.value : initialValue);
|
|
13
|
+
useDerivedValue(() => {
|
|
14
|
+
runOnJS(_setValue)(sharedValue.value);
|
|
15
|
+
});
|
|
16
|
+
const setValue = useCallback((newValue) => {
|
|
17
|
+
sharedValue.value = newValue;
|
|
18
|
+
if (isSharedValue(initialValue))
|
|
19
|
+
initialValue.value = newValue;
|
|
20
|
+
_setValue(newValue);
|
|
21
|
+
}, []);
|
|
22
|
+
return [value, setValue, sharedValue];
|
|
23
|
+
}
|
|
24
|
+
export function useAnimatedValue(initialValue) {
|
|
25
|
+
const [value] = useAnimatedState(initialValue);
|
|
26
|
+
return value;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=useAnimatedState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAnimatedState.js","sourceRoot":"","sources":["../../src/hooks/useAnimatedState.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AAC7C,OAAO,EAAe,cAAc,EAAE,eAAe,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAA;AAE9G;;;;GAIG;AACH,MAAM,UAAU,gBAAgB,CAAI,YAAgC;IAClE,MAAM,WAAW,GAAG,aAAa,CAAC,YAAY,CAAC;QAC7C,CAAC,CAAC,YAAY;QACd,CAAC,CAAC,cAAc,CAAI,YAAY,CAAC,CAAA;IAEnC,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,GAAG,QAAQ,CACjC,aAAa,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAChE,CAAA;IAED,eAAe,CAAC,GAAG,EAAE;QACnB,OAAO,CAAC,SAAS,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAA;IACvC,CAAC,CAAC,CAAA;IAEF,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,QAAW,EAAE,EAAE;QAC3C,WAAW,CAAC,KAAK,GAAG,QAAQ,CAAA;QAC5B,IAAI,aAAa,CAAC,YAAY,CAAC;YAAE,YAAY,CAAC,KAAK,GAAG,QAAQ,CAAA;QAC9D,SAAS,CAAC,QAAQ,CAAC,CAAA;IACrB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,WAAW,CAAU,CAAA;AAChD,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAI,YAAgC;IAClE,MAAM,CAAC,KAAK,CAAC,GAAG,gBAAgB,CAAC,YAAY,CAAC,CAAA;IAC9C,OAAO,KAAK,CAAA;AACd,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { AppState } from 'react-native';
|
|
3
|
+
export function useAppState(callbackFn, deps = []) {
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
const listener = AppState.addEventListener('change', callbackFn);
|
|
6
|
+
return () => {
|
|
7
|
+
listener.remove();
|
|
8
|
+
};
|
|
9
|
+
}, deps);
|
|
10
|
+
}
|
|
11
|
+
export function useAppStateStatus() {
|
|
12
|
+
const [status, setStatus] = useState(AppState.currentState);
|
|
13
|
+
useAppState((newStatus) => setStatus(newStatus));
|
|
14
|
+
return status;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=useAppState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAppState.js","sourceRoot":"","sources":["../../src/hooks/useAppState.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAC3D,OAAO,EAAE,QAAQ,EAAkB,MAAM,cAAc,CAAA;AAEvD,MAAM,UAAU,WAAW,CACzB,UAA2C,EAC3C,OAAuB,EAAE;IAEzB,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,QAAQ,GAAG,QAAQ,CAAC,gBAAgB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAA;QAEhE,OAAO,GAAG,EAAE;YACV,QAAQ,CAAC,MAAM,EAAE,CAAA;QACnB,CAAC,CAAA;IACH,CAAC,EAAE,IAAI,CAAC,CAAA;AACV,CAAC;AAED,MAAM,UAAU,iBAAiB;IAC/B,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAiB,QAAQ,CAAC,YAAY,CAAC,CAAA;IAE3E,WAAW,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAA;IAEhD,OAAO,MAAM,CAAA;AACf,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { KeyboardEvents } from 'react-native-keyboard-controller';
|
|
3
|
+
/**
|
|
4
|
+
* Uses `react-native-keyboard-controller` `KeyboardEvents` rather than the standard RN `Keyboard` API because it fires `keyboardWillShow`/`keyboardWillHide` on both platforms with accurate animated height values; the native `KeyboardProvider` must wrap the app tree or these events will never fire.
|
|
5
|
+
*/
|
|
6
|
+
export function useKeyboardController() {
|
|
7
|
+
const [keyboardState, setKeyboardState] = useState({ isVisible: false, height: 0 });
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
const show = KeyboardEvents.addListener('keyboardWillShow', event => {
|
|
10
|
+
setKeyboardState({ isVisible: true, height: event?.height });
|
|
11
|
+
});
|
|
12
|
+
const hide = KeyboardEvents.addListener('keyboardWillHide', event => {
|
|
13
|
+
setKeyboardState(prev => ({ isVisible: false, height: prev?.height }));
|
|
14
|
+
});
|
|
15
|
+
return () => {
|
|
16
|
+
show.remove();
|
|
17
|
+
hide.remove();
|
|
18
|
+
};
|
|
19
|
+
}, []);
|
|
20
|
+
return keyboardState;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=useKeyboardController.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useKeyboardController.js","sourceRoot":"","sources":["../../src/hooks/useKeyboardController.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAA;AAOjE;;GAEG;AACH,MAAM,UAAU,qBAAqB;IACnC,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAA0B,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAA;IAE5G,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,IAAI,GAAG,cAAc,CAAC,WAAW,CAAC,kBAAkB,EAAE,KAAK,CAAC,EAAE;YAClE,gBAAgB,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;QAC9D,CAAC,CAAC,CAAA;QAEF,MAAM,IAAI,GAAG,cAAc,CAAC,WAAW,CAAC,kBAAkB,EAAE,KAAK,CAAC,EAAE;YAClE,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC,CAAA;QACxE,CAAC,CAAC,CAAA;QAEF,OAAO,GAAG,EAAE;YACV,IAAI,CAAC,MAAM,EAAE,CAAA;YACb,IAAI,CAAC,MAAM,EAAE,CAAA;QACf,CAAC,CAAA;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,aAAa,CAAA;AACtB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useIsFocused } from '@react-navigation/native';
|
|
2
|
+
import { useLayoutEffect } from '@codeleap/hooks';
|
|
3
|
+
import { StatusBar } from 'react-native';
|
|
4
|
+
/**
|
|
5
|
+
* Uses the stack-based `pushStackEntry`/`popStackEntry` API so that nested screens can each set a style and restore the parent's style on unmount — imperative `setBarStyle` calls would stomp each other. On Android the background colour of the status bar is controlled separately via the system theme; only `barStyle` (light/dark content) is affected here.
|
|
6
|
+
*/
|
|
7
|
+
export function useStatusBar({ statusBarColor }) {
|
|
8
|
+
const focused = useIsFocused();
|
|
9
|
+
useLayoutEffect(() => {
|
|
10
|
+
if (!focused || !statusBarColor)
|
|
11
|
+
return;
|
|
12
|
+
const statusBarEntry = StatusBar.pushStackEntry({ barStyle: statusBarColor });
|
|
13
|
+
return () => {
|
|
14
|
+
StatusBar.popStackEntry(statusBarEntry);
|
|
15
|
+
};
|
|
16
|
+
}, [statusBarColor, focused]);
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=useStatusBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useStatusBar.js","sourceRoot":"","sources":["../../src/hooks/useStatusBar.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACjD,OAAO,EAAE,SAAS,EAAkB,MAAM,cAAc,CAAA;AAMxD;;GAEG;AACH,MAAM,UAAU,YAAY,CAAC,EAAE,cAAc,EAAuB;IAClE,MAAM,OAAO,GAAG,YAAY,EAAE,CAAA;IAE9B,eAAe,CAAC,GAAG,EAAE;QACnB,IAAI,CAAC,OAAO,IAAI,CAAC,cAAc;YAAE,OAAM;QAEvC,MAAM,cAAc,GAAG,SAAS,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,cAAc,EAAE,CAAC,CAAA;QAE7E,OAAO,GAAG,EAAE;YACV,SAAS,CAAC,aAAa,CAAC,cAAc,CAAC,CAAA;QACzC,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC,CAAA;AAC/B,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { useStyleObserver } from '@codeleap/styles';
|
|
2
|
+
import { useStableReference } from '@codeleap/hooks';
|
|
3
|
+
import { useMemo } from 'react';
|
|
4
|
+
import { MobileStyleRegistry } from '../Registry';
|
|
5
|
+
export const useStylesFor = (componentName, style, context) => {
|
|
6
|
+
const styleObserver = useStyleObserver(style);
|
|
7
|
+
const stableContext = useStableReference(context ?? {});
|
|
8
|
+
const styles = useMemo(() => {
|
|
9
|
+
return MobileStyleRegistry.current.styleFor(componentName, style, true, stableContext);
|
|
10
|
+
}, [styleObserver, stableContext]);
|
|
11
|
+
return styles;
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=useStylesFor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useStylesFor.js","sourceRoot":"","sources":["../../src/hooks/useStylesFor.ts"],"names":[],"mappings":"AAAA,OAAO,EAA+B,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AAChF,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AACpD,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAC/B,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAA;AAEjD,MAAM,CAAC,MAAM,YAAY,GAAG,CAAc,aAAqB,EAAE,KAA4B,EAAE,OAA0B,EAAK,EAAE;IAC9H,MAAM,aAAa,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAA;IAC7C,MAAM,aAAa,GAAG,kBAAkB,CAAC,OAAO,IAAI,EAAE,CAAC,CAAA;IAEvD,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,EAAE;QAC1B,OAAO,mBAAmB,CAAC,OAAO,CAAC,QAAQ,CAAC,aAAa,EAAE,KAAK,EAAE,IAAI,EAAE,aAAa,CAAC,CAAA;IACxF,CAAC,EAAE,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC,CAAA;IAElC,OAAO,MAAM,CAAA;AACf,CAAC,CAAA"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export * from './components/components';
|
|
2
|
+
export * from './utils';
|
|
3
|
+
export * from './hooks';
|
|
4
|
+
export * from './modules';
|
|
5
|
+
export { Linking } from 'react-native';
|
|
6
|
+
export { MobileStyleRegistry } from './Registry';
|
|
7
|
+
import uuid from 'react-native-uuid';
|
|
8
|
+
export { uuid };
|
|
9
|
+
/** Side-effect import that patches `Field` with native measurement/scroll methods — must remain at the bottom so it runs after all named exports are resolved. */
|
|
10
|
+
import './modules/formConfig';
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAA;AACvC,cAAc,SAAS,CAAA;AACvB,cAAc,SAAS,CAAA;AACvB,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACtC,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAA;AAEhD,OAAO,IAAI,MAAM,mBAAmB,CAAA;AAEpC,OAAO,EAAE,IAAI,EAAE,CAAA;AAEf,kKAAkK;AAClK,OAAO,sBAAsB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/modules/PressableRipple/index.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,UAAU,CAAA;AAEtC,OAAO,EACL,eAAe,EAChB,CAAA"}
|