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 (
-
-
-
+ <>
+
+
+
+
+ >
);
};