diff --git a/src/components/toasts/appIconToast.js b/src/components/toasts/appIconToast.js new file mode 100644 index 00000000000..e434f18058b --- /dev/null +++ b/src/components/toasts/appIconToast.js @@ -0,0 +1,12 @@ +// UnlockToast.tsx +import React from 'react'; +import Toast from './Toast'; +import { magicMemo } from '@/utils'; + +const UnlockToast = () => { + const isVisible = true; + + return ; +}; + +export default magicMemo(UnlockToast, []); diff --git a/src/screens/SettingsSheet/components/AppIconSection.tsx b/src/screens/SettingsSheet/components/AppIconSection.tsx index 318aaf62ffa..78778d999c0 100644 --- a/src/screens/SettingsSheet/components/AppIconSection.tsx +++ b/src/screens/SettingsSheet/components/AppIconSection.tsx @@ -1,4 +1,4 @@ -import React, { useCallback, useMemo } from 'react'; +import React, { useCallback, useMemo, useState } from 'react'; import { Source } from 'react-native-fast-image'; import Menu from './Menu'; import MenuContainer from './MenuContainer'; @@ -11,13 +11,25 @@ import { logger } from '@/logger'; import { analytics } from '@/analytics'; import { AppIcon, AppIconKey, UnlockableAppIcon, UnlockableAppIconKey, freeAppIcons, unlockableAppIcons } from '@/appIcons/appIcons'; import { unlockableAppIconStorage } from '@/featuresToUnlock/unlockableAppIconCheck'; +import UnlockToast from '@/components/toasts/appIconToast'; + +type UnlockStatusMap = { [key in AppIconKey | UnlockableAppIconKey]: boolean }; const AppIconSection = () => { const { appIcon, settingsChangeAppIcon } = useAccountSettings(); const { colors, isDarkMode } = useTheme(); + const [showUnlockMessage, setShowUnlockMessage] = useState(false); + const [messageCount, setMessageCount] = useState(0); + const onSelectIcon = useCallback( - (icon: string) => { + (icon: string, isUnlocked: boolean) => { + if (!isUnlocked) { + setShowUnlockMessage(true); + setMessageCount(count => count + 1); + return; + } + logger.debug(`[AppIconSection]: onSelectIcon: ${icon}`); analytics.track('Set App Icon', { appIcon: icon }); settingsChangeAppIcon(icon); @@ -25,60 +37,84 @@ const AppIconSection = () => { [settingsChangeAppIcon] ); - const unlockedAppIcons: Record = useMemo( + // Get mapping of which icons are unlocked + const unlockedStatus: UnlockStatusMap = useMemo(() => { + const freeIconsStatus = Object.keys(freeAppIcons).reduce>( + (acc, key) => ({ + ...acc, + [key as AppIconKey]: true, + }), + {} + ); + + const unlockableIconsStatus = (Object.keys(unlockableAppIcons) as UnlockableAppIconKey[]).reduce>( + (acc, appIconKey) => ({ + ...acc, + [appIconKey]: unlockableAppIconStorage.getBoolean(appIconKey), + }), + {} + ); + + return { + ...freeIconsStatus, + ...unlockableIconsStatus, + } as UnlockStatusMap; + }, []); + + // Combine all icons into one object + const allAppIcons: Record = useMemo( () => ({ ...freeAppIcons, - ...(Object.keys(unlockableAppIcons) as UnlockableAppIconKey[]).reduce( - (unlockedAppIcons, appIconKey) => { - const appIcon = unlockableAppIcons[appIconKey]; - const unlocked = unlockableAppIconStorage.getBoolean(appIconKey); - logger.debug(`[AppIconSection]: checking if unlocked ${appIcon.displayName} ${unlocked} ${appIconKey}`); - if (unlocked) { - logger.debug(`[AppIconSection]: unlocked ${appIcon.displayName}`); - unlockedAppIcons[appIconKey] = appIcon; - } - return unlockedAppIcons; - }, - {} as Record - ), + ...unlockableAppIcons, }), [] ); + console.log('showUnlockMessage', showUnlockMessage); + console.log('messageCount', messageCount); + return ( - - - {Object.entries(unlockedAppIcons).map(([key, { displayName, image, accentColor }]) => ( - - - - } - onPress={() => onSelectIcon(key)} - rightComponent={key === appIcon && } - size={60} - titleComponent={} - /> - ))} - - + <> + + + + {Object.entries(allAppIcons).map(([key, { displayName, image, accentColor }]) => { + const isUnlocked = unlockedStatus[key as AppIconKey | UnlockableAppIconKey]; + + return ( + + + + } + onPress={() => onSelectIcon(key, isUnlocked)} + rightComponent={key === appIcon && isUnlocked && } + size={60} + titleComponent={} + /> + ); + })} + + + ); };