Merge branch 'bluesky-social:main' into patch-3
This commit is contained in:
		
						commit
						6d57094c6a
					
				
					 10 changed files with 337 additions and 171 deletions
				
			
		|  | @ -23,6 +23,7 @@ import { | |||
|   DialogInnerProps, | ||||
| } from '#/components/Dialog/types' | ||||
| import {Context} from '#/components/Dialog/context' | ||||
| import {isNative} from 'platform/detection' | ||||
| 
 | ||||
| export {useDialogControl, useDialogContext} from '#/components/Dialog/context' | ||||
| export * from '#/components/Dialog/types' | ||||
|  | @ -221,7 +222,8 @@ export function ScrollableInner({children, style}: DialogInnerProps) { | |||
|           borderTopRightRadius: 40, | ||||
|         }, | ||||
|         flatten(style), | ||||
|       ]}> | ||||
|       ]} | ||||
|       contentContainerStyle={isNative ? a.pb_4xl : undefined}> | ||||
|       {children} | ||||
|       <View style={{height: insets.bottom + a.pt_5xl.paddingTop}} /> | ||||
|     </BottomSheetScrollView> | ||||
|  |  | |||
|  | @ -3,7 +3,6 @@ import {View} from 'react-native' | |||
| import {msg} from '@lingui/macro' | ||||
| import {useLingui} from '@lingui/react' | ||||
| 
 | ||||
| import {isNative} from '#/platform/detection' | ||||
| import {useTheme, atoms as a, useBreakpoints} from '#/alf' | ||||
| import {Text} from '#/components/Typography' | ||||
| import {Button, ButtonColor, ButtonText} from '#/components/Button' | ||||
|  | @ -86,7 +85,6 @@ export function Actions({children}: React.PropsWithChildren<{}>) { | |||
|         gtMobile | ||||
|           ? [a.flex_row, a.flex_row_reverse, a.justify_start] | ||||
|           : [a.flex_col], | ||||
|         isNative && [a.pb_4xl], | ||||
|       ]}> | ||||
|       {children} | ||||
|     </View> | ||||
|  |  | |||
							
								
								
									
										124
									
								
								src/components/dialogs/BirthDateSettings.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								src/components/dialogs/BirthDateSettings.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -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> | ||||
|   ) | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue