ALF the birthday modal and remove legacy one
This commit is contained in:
		
							parent
							
								
									4f8381678d
								
							
						
					
					
						commit
						577091d44d
					
				
					 6 changed files with 147 additions and 17 deletions
				
			
		|  | @ -24,6 +24,8 @@ import { | |||
|   CONFIGURABLE_LABEL_GROUPS, | ||||
|   UsePreferencesQueryResponse, | ||||
| } from '#/state/queries/preferences' | ||||
| import {useDialogControl} from '#/components/Dialog' | ||||
| import {BirthdaySettingsDialog} from '#/components/dialogs/BirthdaySettings' | ||||
| 
 | ||||
| export const snapPoints = ['90%'] | ||||
| 
 | ||||
|  | @ -107,11 +109,11 @@ function AdultContentEnabledPref() { | |||
|   const {_} = useLingui() | ||||
|   const {data: preferences} = usePreferencesQuery() | ||||
|   const {mutate, variables} = usePreferencesSetAdultContentMutation() | ||||
|   const {openModal} = useModalControls() | ||||
|   const bithdayDialogControl = useDialogControl() | ||||
| 
 | ||||
|   const onSetAge = React.useCallback( | ||||
|     () => openModal({name: 'birth-date-settings'}), | ||||
|     [openModal], | ||||
|     () => bithdayDialogControl.open(), | ||||
|     [bithdayDialogControl], | ||||
|   ) | ||||
| 
 | ||||
|   const onToggleAdultContent = React.useCallback(async () => { | ||||
|  | @ -135,6 +137,10 @@ function AdultContentEnabledPref() { | |||
| 
 | ||||
|   return ( | ||||
|     <View style={s.mb10}> | ||||
|       <BirthdaySettingsDialog | ||||
|         control={bithdayDialogControl} | ||||
|         preferences={preferences} | ||||
|       /> | ||||
|       {isIOS ? ( | ||||
|         preferences?.adultContentEnabled ? null : ( | ||||
|           <Text type="md" style={pal.textLight}> | ||||
|  |  | |||
|  | @ -25,7 +25,6 @@ import * as ContentFilteringSettingsModal from './ContentFilteringSettings' | |||
| import * as ContentLanguagesSettingsModal from './lang-settings/ContentLanguagesSettings' | ||||
| import * as PostLanguagesSettingsModal from './lang-settings/PostLanguagesSettings' | ||||
| import * as ModerationDetailsModal from './ModerationDetails' | ||||
| import * as BirthDateSettingsModal from './BirthDateSettings' | ||||
| import * as VerifyEmailModal from './VerifyEmail' | ||||
| import * as ChangeEmailModal from './ChangeEmail' | ||||
| import * as ChangePasswordModal from './ChangePassword' | ||||
|  | @ -122,9 +121,6 @@ export function ModalsContainer() { | |||
|   } else if (activeModal?.name === 'moderation-details') { | ||||
|     snapPoints = ModerationDetailsModal.snapPoints | ||||
|     element = <ModerationDetailsModal.Component {...activeModal} /> | ||||
|   } else if (activeModal?.name === 'birth-date-settings') { | ||||
|     snapPoints = BirthDateSettingsModal.snapPoints | ||||
|     element = <BirthDateSettingsModal.Component /> | ||||
|   } else if (activeModal?.name === 'verify-email') { | ||||
|     snapPoints = VerifyEmailModal.snapPoints | ||||
|     element = <VerifyEmailModal.Component {...activeModal} /> | ||||
|  |  | |||
|  | @ -27,7 +27,6 @@ import * as ContentFilteringSettingsModal from './ContentFilteringSettings' | |||
| import * as ContentLanguagesSettingsModal from './lang-settings/ContentLanguagesSettings' | ||||
| import * as PostLanguagesSettingsModal from './lang-settings/PostLanguagesSettings' | ||||
| import * as ModerationDetailsModal from './ModerationDetails' | ||||
| import * as BirthDateSettingsModal from './BirthDateSettings' | ||||
| import * as VerifyEmailModal from './VerifyEmail' | ||||
| import * as ChangeEmailModal from './ChangeEmail' | ||||
| import * as ChangePasswordModal from './ChangePassword' | ||||
|  | @ -117,8 +116,6 @@ function Modal({modal}: {modal: ModalIface}) { | |||
|     element = <EditImageModal.Component {...modal} /> | ||||
|   } else if (modal.name === 'moderation-details') { | ||||
|     element = <ModerationDetailsModal.Component {...modal} /> | ||||
|   } else if (modal.name === 'birth-date-settings') { | ||||
|     element = <BirthDateSettingsModal.Component /> | ||||
|   } else if (modal.name === 'verify-email') { | ||||
|     element = <VerifyEmailModal.Component {...modal} /> | ||||
|   } else if (modal.name === 'change-email') { | ||||
|  |  | |||
|  | @ -40,7 +40,10 @@ import { | |||
| } from '#/state/preferences' | ||||
| import {useSession, useSessionApi, SessionAccount} from '#/state/session' | ||||
| import {useProfileQuery} from '#/state/queries/profile' | ||||
| import {useClearPreferencesMutation} from '#/state/queries/preferences' | ||||
| import { | ||||
|   useClearPreferencesMutation, | ||||
|   usePreferencesQuery, | ||||
| } from '#/state/queries/preferences' | ||||
| // TODO import {useInviteCodesQuery} from '#/state/queries/invites'
 | ||||
| import {clear as clearStorage} from '#/state/persisted/store' | ||||
| import {clearLegacyStorage} from '#/state/persisted/legacy' | ||||
|  | @ -68,6 +71,7 @@ import {SelectableBtn} from 'view/com/util/forms/SelectableBtn' | |||
| import {AccountDropdownBtn} from 'view/com/util/AccountDropdownBtn' | ||||
| import {SimpleViewHeader} from 'view/com/util/SimpleViewHeader' | ||||
| import {ExportCarDialog} from './ExportCarDialog' | ||||
| import {BirthdaySettingsDialog} from '#/components/dialogs/BirthdaySettings' | ||||
| 
 | ||||
| function SettingsAccountCard({account}: {account: SessionAccount}) { | ||||
|   const pal = usePalette('default') | ||||
|  | @ -152,6 +156,7 @@ export function SettingsScreen({}: Props) { | |||
|   const {screen, track} = useAnalytics() | ||||
|   const {openModal} = useModalControls() | ||||
|   const {isSwitchingAccounts, accounts, currentAccount} = useSession() | ||||
|   const {data: preferences} = usePreferencesQuery() | ||||
|   const {mutate: clearPreferences} = useClearPreferencesMutation() | ||||
|   // TODO
 | ||||
|   // const {data: invites} = useInviteCodesQuery()
 | ||||
|  | @ -159,6 +164,7 @@ export function SettingsScreen({}: Props) { | |||
|   const {setShowLoggedOut} = useLoggedOutViewControls() | ||||
|   const closeAllActiveElements = useCloseAllActiveElements() | ||||
|   const exportCarControl = useDialogControl() | ||||
|   const birthdayControl = useDialogControl() | ||||
| 
 | ||||
|   // const primaryBg = useCustomPalette<ViewStyle>({
 | ||||
|   //   light: {backgroundColor: colors.blue0},
 | ||||
|  | @ -269,6 +275,10 @@ export function SettingsScreen({}: Props) { | |||
|     Linking.openURL(STATUS_PAGE_URL) | ||||
|   }, []) | ||||
| 
 | ||||
|   const onPressBirthday = React.useCallback(() => { | ||||
|     birthdayControl.open() | ||||
|   }, [birthdayControl]) | ||||
| 
 | ||||
|   const clearAllStorage = React.useCallback(async () => { | ||||
|     await clearStorage() | ||||
|     Toast.show(_(msg`Storage cleared, you need to restart the app now.`)) | ||||
|  | @ -281,6 +291,10 @@ export function SettingsScreen({}: Props) { | |||
|   return ( | ||||
|     <View style={s.hContentRegion} testID="settingsScreen"> | ||||
|       <ExportCarDialog control={exportCarControl} /> | ||||
|       <BirthdaySettingsDialog | ||||
|         control={birthdayControl} | ||||
|         preferences={preferences} | ||||
|       /> | ||||
| 
 | ||||
|       <SimpleViewHeader | ||||
|         showBackButton={isMobile} | ||||
|  | @ -339,7 +353,7 @@ export function SettingsScreen({}: Props) { | |||
|               <Text type="lg-medium" style={pal.text}> | ||||
|                 <Trans>Birthday:</Trans>{' '} | ||||
|               </Text> | ||||
|               <Link onPress={() => openModal({name: 'birth-date-settings'})}> | ||||
|               <Link onPress={onPressBirthday}> | ||||
|                 <Text type="lg" style={pal.link}> | ||||
|                   <Trans>Show</Trans> | ||||
|                 </Text> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue