diff options
author | Samuel Newman <mozzius@protonmail.com> | 2024-03-15 16:45:17 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-03-15 16:45:17 +0000 |
commit | e30b3d9b3c8c45df16bd60e73a86dda28cd65073 (patch) | |
tree | 88e4b4c82d3c89e4decdb1b242d5ff6eee850e2a /src/components/dialogs | |
parent | 4f8381678da505737a96b7420c0f1ea8329f3672 (diff) | |
parent | 39da1cd465953d2c7dcc0d111f540e306cdb0108 (diff) | |
download | voidsky-e30b3d9b3c8c45df16bd60e73a86dda28cd65073.tar.zst |
Merge pull request #3218 from bluesky-social/samuel/alf-birthday
Use ALF for the birthday modal and remove legacy one
Diffstat (limited to 'src/components/dialogs')
-rw-r--r-- | src/components/dialogs/BirthDateSettings.tsx | 124 |
1 files changed, 124 insertions, 0 deletions
diff --git a/src/components/dialogs/BirthDateSettings.tsx b/src/components/dialogs/BirthDateSettings.tsx new file mode 100644 index 000000000..62c95c78d --- /dev/null +++ b/src/components/dialogs/BirthDateSettings.tsx @@ -0,0 +1,124 @@ +import React from 'react' +import {useLingui} from '@lingui/react' +import {Trans, msg} from '@lingui/macro' + +import * as Dialog from '#/components/Dialog' +import {Text} from '../Typography' +import {DateInput} from '#/view/com/util/forms/DateInput' +import {logger} from '#/logger' +import { + usePreferencesSetBirthDateMutation, + UsePreferencesQueryResponse, +} from '#/state/queries/preferences' +import {Button, ButtonText} from '../Button' +import {atoms as a, useTheme} from '#/alf' +import {ErrorMessage} from '#/view/com/util/error/ErrorMessage' +import {cleanError} from '#/lib/strings/errors' +import {ActivityIndicator, View} from 'react-native' +import {isIOS, isWeb} from '#/platform/detection' + +export function BirthDateSettingsDialog({ + control, + preferences, +}: { + control: Dialog.DialogControlProps + preferences: UsePreferencesQueryResponse | undefined +}) { + const {_} = useLingui() + const {isPending, isError, error, mutateAsync} = + usePreferencesSetBirthDateMutation() + + return ( + <Dialog.Outer control={control}> + <Dialog.Handle /> + <Dialog.ScrollableInner label={_(msg`My Birthday`)}> + {preferences && !isPending ? ( + <BirthdayInner + control={control} + preferences={preferences} + isError={isError} + error={error} + setBirthDate={mutateAsync} + /> + ) : ( + <ActivityIndicator size="large" style={a.my_5xl} /> + )} + </Dialog.ScrollableInner> + </Dialog.Outer> + ) +} + +function BirthdayInner({ + control, + preferences, + isError, + error, + setBirthDate, +}: { + control: Dialog.DialogControlProps + preferences: UsePreferencesQueryResponse + isError: boolean + error: unknown + setBirthDate: (args: {birthDate: Date}) => Promise<unknown> +}) { + const {_} = useLingui() + const [date, setDate] = React.useState(preferences.birthDate || new Date()) + const t = useTheme() + + const hasChanged = date !== preferences.birthDate + + const onSave = React.useCallback(async () => { + try { + // skip if date is the same + if (hasChanged) { + await setBirthDate({birthDate: date}) + } + control.close() + } catch (e) { + logger.error(`setBirthDate failed`, {message: e}) + } + }, [date, setBirthDate, control, hasChanged]) + + return ( + <View style={a.gap_lg} testID="birthDateSettingsDialog"> + <View style={[a.gap_sm]}> + <Text style={[a.text_2xl, a.font_bold]}> + <Trans>My Birthday</Trans> + </Text> + <Text style={t.atoms.text_contrast_medium}> + <Trans>This information is not shared with other users.</Trans> + </Text> + </View> + <View style={isIOS && [a.w_full, a.align_center]}> + <DateInput + handleAsUTC + testID="birthdayInput" + value={date} + onChange={setDate} + buttonType="default-light" + buttonStyle={[a.rounded_sm]} + buttonLabelType="lg" + accessibilityLabel={_(msg`Birthday`)} + accessibilityHint={_(msg`Enter your birth date`)} + accessibilityLabelledBy="birthDate" + /> + </View> + {isError ? ( + <ErrorMessage message={cleanError(error)} style={[a.rounded_sm]} /> + ) : undefined} + + <View style={isWeb && [a.flex_row, a.justify_end]}> + <Button + label={hasChanged ? _(msg`Save birthday`) : _(msg`Done`)} + size={isWeb ? 'small' : 'medium'} + onPress={onSave} + variant="solid" + color="primary"> + <ButtonText> + {hasChanged ? <Trans>Save</Trans> : <Trans>Done</Trans>} + </ButtonText> + </Button> + </View> + </View> + ) +} |