* Revert other base PR changes, switch date picker library rm expo-linear-gradient Revert "remove unused packages, switch to `expo-linear-gradient`" This reverts commit 20a0ffcf Revert "upgrade expo deps" This reverts commit a43dca92caa120d45fb771431752dd2db3b37ab5. Revert other library changes This reverts commit 5219f66e Revert "re-add normalize-url" This reverts commit 654019c4babe2e455f6069a6c725eb51140ab1ab. Revert "add `expo-haptics`" This reverts commit ff3a0399b1c7eae07b83946f13543eedf7cdfe82. Revert "add `expo-clipboard`" This reverts commit 440ae91632153e22ff79050d8ac803a7305e88a0. Revert "add `expo-file-system`" This reverts commit c0fe0c94534564982399c22299a8a19052bf3e54. fix android alf use modal on android migrate to `react-native-date-picker` rm `@reactnativecommunity/datetimepicker` add `react-native-date-picker` add `expo-file-system` add `expo-clipboard` add `expo-haptics` re-add normalize-url rm blur view upgrade expo deps remove unused packages, switch to `expo-linear-gradient` * rm old library * Use UTC for dates --------- Co-authored-by: Eric Bailey <git@esb.lol>
52 lines
1.4 KiB
TypeScript
52 lines
1.4 KiB
TypeScript
import React from 'react'
|
|
import {View} from 'react-native'
|
|
|
|
import {useTheme, atoms} from '#/alf'
|
|
import * as TextField from '#/components/forms/TextField'
|
|
import {toSimpleDateString} from '#/components/forms/DateField/utils'
|
|
import {DateFieldProps} from '#/components/forms/DateField/types'
|
|
import DatePicker from 'react-native-date-picker'
|
|
|
|
export * as utils from '#/components/forms/DateField/utils'
|
|
export const Label = TextField.Label
|
|
|
|
/**
|
|
* Date-only input. Accepts a date in the format YYYY-MM-DD, and reports date
|
|
* changes in the same format.
|
|
*
|
|
* For dates of unknown format, convert with the
|
|
* `utils.toSimpleDateString(Date)` export of this file.
|
|
*/
|
|
export function DateField({
|
|
value,
|
|
onChangeDate,
|
|
testID,
|
|
label,
|
|
}: DateFieldProps) {
|
|
const t = useTheme()
|
|
|
|
const onChangeInternal = React.useCallback(
|
|
(date: Date | undefined) => {
|
|
if (date) {
|
|
const formatted = toSimpleDateString(date)
|
|
onChangeDate(formatted)
|
|
}
|
|
},
|
|
[onChangeDate],
|
|
)
|
|
|
|
return (
|
|
<View style={[atoms.relative, atoms.w_full]}>
|
|
<DatePicker
|
|
theme={t.name === 'light' ? 'light' : 'dark'}
|
|
date={new Date(value)}
|
|
onDateChange={onChangeInternal}
|
|
mode="date"
|
|
testID={`${testID}-datepicker`}
|
|
aria-label={label}
|
|
accessibilityLabel={label}
|
|
accessibilityHint={undefined}
|
|
/>
|
|
</View>
|
|
)
|
|
}
|