From 28ffd4866743e27768dd9fa002bb513916dab3a8 Mon Sep 17 00:00:00 2001 From: Matthew Wall Date: Tue, 14 Jan 2025 10:48:24 -0500 Subject: [PATCH] fix invalid time format due to invalid strings (#6396) --- src/components/backup/ChooseBackupStep.tsx | 19 +++++++------ .../components/Backups/ViewCloudBackups.tsx | 27 ++++++++++++------- src/screens/SettingsSheet/utils.ts | 9 +++++++ 3 files changed, 37 insertions(+), 18 deletions(-) diff --git a/src/components/backup/ChooseBackupStep.tsx b/src/components/backup/ChooseBackupStep.tsx index d08d4cdb0e2..3f47c51fee3 100644 --- a/src/components/backup/ChooseBackupStep.tsx +++ b/src/components/backup/ChooseBackupStep.tsx @@ -11,7 +11,6 @@ import { sharedCoolModalTopOffset } from '@/navigation/config'; import { ImgixImage } from '@/components/images'; import MenuContainer from '@/screens/SettingsSheet/components/MenuContainer'; import Menu from '@/screens/SettingsSheet/components/Menu'; -import { format } from 'date-fns'; import MenuItem from '@/screens/SettingsSheet/components/MenuItem'; import Routes from '@/navigation/routesNames'; import { BackupFile, parseTimestampFromFilename } from '@/model/backup'; @@ -23,7 +22,7 @@ import Spinner from '@/components/Spinner'; import ActivityIndicator from '@/components/ActivityIndicator'; import { useTheme } from '@/theme'; import { backupsStore, CloudBackupState, LoadingStates } from '@/state/backups/backups'; -import { titleForBackupState } from '@/screens/SettingsSheet/utils'; +import { dateFormatter, titleForBackupState } from '@/screens/SettingsSheet/utils'; const Title = styled(RNText).attrs({ align: 'left', @@ -148,7 +147,7 @@ export function ChooseBackupStep() { backup.name !== mostRecentBackup?.name) .sort((a, b) => { - const timestampA = new Date(parseTimestampFromFilename(a.name)).getTime(); - const timestampB = new Date(parseTimestampFromFilename(b.name)).getTime(); - return timestampB - timestampA; + try { + const timestampA = new Date(parseTimestampFromFilename(a.name)).getTime(); + const timestampB = new Date(parseTimestampFromFilename(b.name)).getTime(); + return timestampB - timestampA; + } catch (error) { + return 0; + } }) .map(backup => ( } diff --git a/src/screens/SettingsSheet/components/Backups/ViewCloudBackups.tsx b/src/screens/SettingsSheet/components/Backups/ViewCloudBackups.tsx index 90cbdddeff3..1f449b6a417 100644 --- a/src/screens/SettingsSheet/components/Backups/ViewCloudBackups.tsx +++ b/src/screens/SettingsSheet/components/Backups/ViewCloudBackups.tsx @@ -6,19 +6,22 @@ import Menu from '../Menu'; import MenuContainer from '../MenuContainer'; import MenuItem from '../MenuItem'; import { BackupFile, parseTimestampFromFilename } from '@/model/backup'; -import { format } from 'date-fns'; import { useNavigation } from '@/navigation'; import Routes from '@/navigation/routesNames'; import walletBackupStepTypes from '@/helpers/walletBackupStepTypes'; import { Page } from '@/components/layout'; import Spinner from '@/components/Spinner'; import ActivityIndicator from '@/components/ActivityIndicator'; -import { useTheme } from '@/theme'; +import { ThemeContextProps, useTheme } from '@/theme'; import { CloudBackupState, LoadingStates, backupsStore } from '@/state/backups/backups'; -import { titleForBackupState } from '../../utils'; +import { titleForBackupState, dateFormatter } from '@/screens/SettingsSheet/utils'; import { Box } from '@/design-system'; -const LoadingText = styled(RNText).attrs(({ theme: { colors } }: any) => ({ +type LoadingTextProps = { + theme: ThemeContextProps; +}; + +const LoadingText = styled(RNText).attrs(({ theme: { colors } }: LoadingTextProps) => ({ color: colors.blueGreyDark, lineHeight: ios ? 'none' : 24, size: 'large', @@ -64,7 +67,7 @@ const ViewCloudBackups = () => { { {backups.files .filter(backup => backup.name !== mostRecentBackup?.name) .sort((a, b) => { - const timestampA = new Date(parseTimestampFromFilename(a.name)).getTime(); - const timestampB = new Date(parseTimestampFromFilename(b.name)).getTime(); - return timestampB - timestampA; + try { + const timestampA = new Date(parseTimestampFromFilename(a.name)).getTime(); + const timestampB = new Date(parseTimestampFromFilename(b.name)).getTime(); + return timestampB - timestampA; + } catch (error) { + return 0; + } }) .map(backup => ( { } diff --git a/src/screens/SettingsSheet/utils.ts b/src/screens/SettingsSheet/utils.ts index cda0da5ef72..6a407816b4b 100644 --- a/src/screens/SettingsSheet/utils.ts +++ b/src/screens/SettingsSheet/utils.ts @@ -9,6 +9,7 @@ import { backupsStore, CloudBackupState } from '@/state/backups/backups'; import { RainbowWallet } from '@/model/wallet'; import { IS_ANDROID, IS_IOS } from '@/env'; import { normalizeAndroidBackupFilename } from '@/handlers/cloudBackup'; +import { format } from 'date-fns'; type WalletBackupStatus = { allBackedUp: boolean; @@ -119,3 +120,11 @@ export const isWalletBackedUpForCurrentAccount = ({ backupType, backedUp, backup const backupFiles = backupsStore.getState().backups; return backupFiles.files.some(file => normalizeAndroidBackupFilename(file.name) === normalizeAndroidBackupFilename(backupFile)); }; + +export const dateFormatter = (date: string | number, formatString = "M/d/yy 'at' h:mm a") => { + try { + return format(new Date(date), formatString); + } catch (error) { + return 'Unknown Date'; + } +};