diff --git a/packages/app/src/App.tsx b/packages/app/src/App.tsx
index e3f907dd..dd773e6e 100644
--- a/packages/app/src/App.tsx
+++ b/packages/app/src/App.tsx
@@ -13,7 +13,6 @@ import * as WebRoute from './routes/routing.web';
 import ActivityLogPage from './pages/ActivityLogPage';
 import { Providers } from './Providers';
 import DonatePage from './pages/DonatePage';
-import ModalTestPage from './pages/ModalTestPage';
 import { configureChains, createConfig, WagmiConfig } from 'wagmi';
 import { celo, mainnet } from 'wagmi/chains';
 import { publicProvider } from 'wagmi/providers/public';
@@ -95,7 +94,6 @@ function App(): JSX.Element {
                   <MobileRoute.Route path="/collective/:id/donors" element={<ViewDonorsPage />} />
                   <MobileRoute.Route path="/profile/:id" element={<WalletProfilePage />} />
                   <MobileRoute.Route path="/profile/:id/activity" element={<ActivityLogPage />} />
-                  <MobileRoute.Route path="/modalTest" element={<ModalTestPage />} />
                   <MobileRoute.Route path="/donate" element={<DonatePage />} />
                 </MobileRoute.Routes>
               </MobileRoute.Router>
@@ -113,7 +111,6 @@ function App(): JSX.Element {
                   <WebRoute.Route path="/profile/:id/activity" element={<ActivityLogPage />} />
                   <WebRoute.Route path="/profile/" element={<WalletProfilePage />} />
                   <WebRoute.Route path="/donate/:id" element={<DonatePage />} />
-                  <WebRoute.Route path="/modalTest" element={<ModalTestPage />} />
                 </WebRoute.Routes>
               </WebRoute.Router>
             )}
diff --git a/packages/app/src/components/DonateComponent.tsx b/packages/app/src/components/DonateComponent.tsx
index 500d039e..82c184dc 100644
--- a/packages/app/src/components/DonateComponent.tsx
+++ b/packages/app/src/components/DonateComponent.tsx
@@ -2,7 +2,7 @@ import { useCallback, useMemo, useState } from 'react';
 import { Image, StyleSheet, Text, TextInput, View } from 'react-native';
 import { InterRegular, InterSemiBold, InterSmall } from '../utils/webFonts';
 import RoundedButton from './RoundedButton';
-import CompleteDonationModal from './CompleteDonationModal';
+import CompleteDonationModal from './modals/CompleteDonationModal';
 import { Colors } from '../utils/colors';
 import { Link, useMediaQuery } from 'native-base';
 import Dropdown from './Dropdown';
@@ -16,14 +16,15 @@ import { InfoIconOrange } from '../assets';
 import { useLocation } from 'react-router-native';
 import Decimal from 'decimal.js';
 import { formatFiatCurrency } from '../lib/formatFiatCurrency';
-import ErrorModal from './ErrorModal';
+import ErrorModal from './modals/ErrorModal';
 import { SwapRouteState, useSwapRoute } from '../hooks/useSwapRoute';
 import { useApproveSwapTokenCallback } from '../hooks/useApproveSwapTokenCallback';
-import ApproveSwapModal from './ApproveSwapModal';
+import ApproveSwapModal from './modals/ApproveSwapModal';
 import { waitForTransaction } from '@wagmi/core';
 import { TransactionReceipt } from 'viem';
 import { useToken, useTokenList } from '../hooks/useTokenList';
 import { formatDecimalStringInput } from '../lib/formatDecimalStringInput';
+import ThankYouModal from './modals/ThankYouModal';
 
 interface DonateComponentProps {
   collective: IpfsCollective;
@@ -42,6 +43,7 @@ function DonateComponent({ collective }: DonateComponentProps) {
   const [completeDonationModalVisible, setCompleteDonationModalVisible] = useState(false);
   const [errorMessage, setErrorMessage] = useState<string | undefined>(undefined);
   const [approveSwapModalVisible, setApproveSwapModalVisible] = useState(false);
+  const [thankYouModalVisible, setThankYouModalVisible] = useState(false);
 
   const [currency, setCurrency] = useState<string>('G$');
   const [frequency, setFrequency] = useState<Frequency>(Frequency.OneTime);
@@ -84,6 +86,7 @@ function DonateComponent({ collective }: DonateComponentProps) {
     frequency,
     (error) => setErrorMessage(error),
     (value: boolean) => setCompleteDonationModalVisible(value),
+    (value: boolean) => setThankYouModalVisible(value),
     rawMinimumAmountOut,
     swapPath
   );
@@ -473,6 +476,7 @@ function DonateComponent({ collective }: DonateComponentProps) {
       <ErrorModal openModal={!!errorMessage} setOpenModal={onCloseErrorModal} message={errorMessage ?? ''} />
       <ApproveSwapModal openModal={approveSwapModalVisible} setOpenModal={setApproveSwapModalVisible} />
       <CompleteDonationModal openModal={completeDonationModalVisible} setOpenModal={setCompleteDonationModalVisible} />
+      <ThankYouModal openModal={thankYouModalVisible} setOpenModal={setThankYouModalVisible} collective={collective} />
     </View>
   );
 }
diff --git a/packages/app/src/components/ViewCollective.tsx b/packages/app/src/components/ViewCollective.tsx
index c19600e4..1d418831 100644
--- a/packages/app/src/components/ViewCollective.tsx
+++ b/packages/app/src/components/ViewCollective.tsx
@@ -6,8 +6,7 @@ import StewardList from './StewardsList/StewardsList';
 import TransactionList from './TransactionList/TransactionList';
 import { InterSemiBold, InterSmall } from '../utils/webFonts';
 import useCrossNavigate from '../routes/useCrossNavigate';
-import StopDonationModal from './StopDonationModal';
-import ThankYouModal from './ThankYouModal';
+import StopDonationModal from './modals/StopDonationModal';
 import { Colors } from '../utils/colors';
 import { Link, useMediaQuery } from 'native-base';
 import { formatTime } from '../lib/formatTime';
@@ -33,7 +32,7 @@ import {
 import { calculateGoodDollarAmounts } from '../lib/calculateGoodDollarAmounts';
 import FlowingDonationsRowItem from './FlowingDonationsRowItem';
 import { useDeleteFlow } from '../hooks/useContractCalls/useDeleteFlow';
-import ErrorModal from './ErrorModal';
+import ErrorModal from './modals/ErrorModal';
 import FlowingCurrentPoolRowItem from './FlowingCurrentPoolRowItem';
 
 interface ViewCollectiveProps {
@@ -69,7 +68,6 @@ function ViewCollective({ collective }: ViewCollectiveProps) {
   const isDonating = maybeDonorCollective && maybeDonorCollective.flowRate !== '0';
 
   const [stopDonationModalVisible, setStopDonationModalVisible] = useState(false);
-  const [donationModalVisible, setDonationModalVisible] = useState(false);
   const [errorMessage, setErrorMessage] = useState<string | undefined>(undefined);
 
   const handleStopDonation = useDeleteFlow(
@@ -234,7 +232,6 @@ function ViewCollective({ collective }: ViewCollectiveProps) {
           setOpenModal={() => setErrorMessage(undefined)}
           message={errorMessage ?? ''}
         />
-        <ThankYouModal openModal={donationModalVisible} setOpenModal={setDonationModalVisible} />
         <StopDonationModal openModal={stopDonationModalVisible} setOpenModal={setStopDonationModalVisible} />
       </View>
     );
@@ -367,7 +364,6 @@ function ViewCollective({ collective }: ViewCollectiveProps) {
           message={errorMessage ?? ''}
         />
         <StopDonationModal openModal={stopDonationModalVisible} setOpenModal={setStopDonationModalVisible} />
-        <ThankYouModal openModal={donationModalVisible} setOpenModal={setDonationModalVisible} />
       </View>
     </View>
   );
diff --git a/packages/app/src/components/ApproveSwapModal.tsx b/packages/app/src/components/modals/ApproveSwapModal.tsx
similarity index 63%
rename from packages/app/src/components/ApproveSwapModal.tsx
rename to packages/app/src/components/modals/ApproveSwapModal.tsx
index a10e2640..417f094e 100644
--- a/packages/app/src/components/ApproveSwapModal.tsx
+++ b/packages/app/src/components/modals/ApproveSwapModal.tsx
@@ -1,8 +1,8 @@
 import { Modal, StyleSheet, Text, View, Image, TouchableOpacity } from 'react-native';
-import { InterRegular, InterSemiBold } from '../utils/webFonts';
-import { Colors } from '../utils/colors';
-import { modalStyles } from './shared';
-import { CloseIcon, ApproveTokenImg } from '../assets';
+import { InterRegular, InterSemiBold } from '../../utils/webFonts';
+import { Colors } from '../../utils/colors';
+import { modalStyles } from '../shared';
+import { CloseIcon, ApproveTokenImg } from '../../assets';
 
 interface AproveSwapModalProps {
   openModal: boolean;
@@ -11,25 +11,23 @@ interface AproveSwapModalProps {
 
 const ApproveSwapModal = ({ openModal, setOpenModal }: AproveSwapModalProps) => {
   return (
-    <View style={styles.centeredView}>
-      <Modal animationType="slide" transparent={true} visible={openModal}>
-        <View style={styles.centeredView}>
-          <View style={styles.modalView}>
-            <View style={modalStyles.modalCloseIconWrapper}>
-              <TouchableOpacity style={modalStyles.modalCloseIcon} onPress={() => setOpenModal(false)}>
-                <Image source={CloseIcon} style={styles.closeIcon} />
-              </TouchableOpacity>
-            </View>
-            <Text style={styles.title}>APPROVE TOKEN SWAP</Text>
-            <Text style={styles.paragraph}>
-              To approve the exchange from your donation currency to this GoodCollective's currency, sign with your
-              wallet.
-            </Text>
-            <Image source={ApproveTokenImg} alt="woman" style={styles.image} />
+    <Modal style={styles.centeredView} animationType="slide" transparent={true} visible={openModal}>
+      <View style={styles.centeredView}>
+        <View style={styles.modalView}>
+          <View style={modalStyles.modalCloseIconWrapper}>
+            <TouchableOpacity style={modalStyles.modalCloseIcon} onPress={() => setOpenModal(false)}>
+              <Image source={CloseIcon} style={styles.closeIcon} />
+            </TouchableOpacity>
           </View>
+          <Text style={styles.title}>APPROVE TOKEN SWAP</Text>
+          <Text style={styles.paragraph}>
+            To approve the exchange from your donation currency to this GoodCollective's currency, sign with your
+            wallet.
+          </Text>
+          <Image source={ApproveTokenImg} alt="woman" style={styles.image} />
         </View>
-      </Modal>
-    </View>
+      </View>
+    </Modal>
   );
 };
 
diff --git a/packages/app/src/components/CompleteDonationModal.tsx b/packages/app/src/components/modals/CompleteDonationModal.tsx
similarity index 65%
rename from packages/app/src/components/CompleteDonationModal.tsx
rename to packages/app/src/components/modals/CompleteDonationModal.tsx
index c39cdef8..56d6051e 100644
--- a/packages/app/src/components/CompleteDonationModal.tsx
+++ b/packages/app/src/components/modals/CompleteDonationModal.tsx
@@ -1,9 +1,8 @@
 import { Modal, StyleSheet, Text, View, Image, TouchableOpacity } from 'react-native';
-import { InterRegular, InterSemiBold } from '../utils/webFonts';
-// import useCrossNavigate from '../routes/useCrossNavigate';
-import { Colors } from '../utils/colors';
-import { modalStyles } from './shared';
-import { CloseIcon, PhoneImg } from '../assets';
+import { InterRegular, InterSemiBold } from '../../utils/webFonts';
+import { Colors } from '../../utils/colors';
+import { modalStyles } from '../shared';
+import { CloseIcon, PhoneImg } from '../../assets';
 
 interface CompleteDonationModalProps {
   openModal: boolean;
@@ -14,22 +13,20 @@ const CompleteDonationModal = ({ openModal, setOpenModal }: CompleteDonationModa
   const onClickClose = () => setOpenModal(false);
 
   return (
-    <View style={styles.centeredView}>
-      <Modal animationType="slide" transparent={true} visible={openModal}>
-        <View style={styles.centeredView}>
-          <View style={styles.modalView}>
-            <View style={modalStyles.modalCloseIconWrapper}>
-              <TouchableOpacity style={modalStyles.modalCloseIcon} onPress={onClickClose}>
-                <Image source={CloseIcon} style={styles.closeIcon} />
-              </TouchableOpacity>
-            </View>
-            <Text style={styles.title}>COMPLETE YOUR DONATION</Text>
-            <Text style={styles.paragraph}>To complete your donation, sign with your wallet.</Text>
-            <Image source={PhoneImg} alt="woman" style={styles.image} />
+    <Modal style={styles.centeredView} animationType="slide" transparent={true} visible={openModal}>
+      <View style={styles.centeredView}>
+        <View style={styles.modalView}>
+          <View style={modalStyles.modalCloseIconWrapper}>
+            <TouchableOpacity style={modalStyles.modalCloseIcon} onPress={onClickClose}>
+              <Image source={CloseIcon} style={styles.closeIcon} />
+            </TouchableOpacity>
           </View>
+          <Text style={styles.title}>COMPLETE YOUR DONATION</Text>
+          <Text style={styles.paragraph}>To complete your donation, sign with your wallet.</Text>
+          <Image source={PhoneImg} alt="woman" style={styles.image} />
         </View>
-      </Modal>
-    </View>
+      </View>
+    </Modal>
   );
 };
 
diff --git a/packages/app/src/components/ErrorModal.tsx b/packages/app/src/components/modals/ErrorModal.tsx
similarity index 65%
rename from packages/app/src/components/ErrorModal.tsx
rename to packages/app/src/components/modals/ErrorModal.tsx
index 1a132d9e..8e6e3b72 100644
--- a/packages/app/src/components/ErrorModal.tsx
+++ b/packages/app/src/components/modals/ErrorModal.tsx
@@ -1,7 +1,7 @@
 import { Modal, StyleSheet, Text, View, Image, TouchableOpacity } from 'react-native';
-import { InterRegular, InterSemiBold } from '../utils/webFonts';
-import { Colors } from '../utils/colors';
-import { CloseIcon, ThankYouImg } from '../assets';
+import { InterRegular, InterSemiBold } from '../../utils/webFonts';
+import { Colors } from '../../utils/colors';
+import { CloseIcon, ThankYouImg } from '../../assets';
 
 interface ErrorModalProps {
   openModal: boolean;
@@ -12,27 +12,25 @@ interface ErrorModalProps {
 const ErrorModal = ({ openModal, setOpenModal, message }: ErrorModalProps) => {
   const onCloseClicked = () => setOpenModal(false);
   return (
-    <View style={styles.centeredView}>
-      <Modal animationType="slide" transparent={true} visible={openModal}>
-        <View style={styles.centeredView}>
-          <View style={styles.modalView}>
-            <View style={styles.modalCloseIconWrapper}>
-              <TouchableOpacity style={styles.modalCloseIcon} onPress={onCloseClicked}>
-                <Image source={CloseIcon} style={styles.closeIcon} />
-              </TouchableOpacity>
-            </View>
-
-            <Text style={styles.title}>SOMETHING WENT WRONG</Text>
-            <Text style={styles.paragraph}>Please try again later.</Text>
-            <Text style={styles.paragraph}>Reason: {message}</Text>
-            <Image source={ThankYouImg} alt="woman" style={styles.image} />
-            <TouchableOpacity style={styles.button} onPress={onCloseClicked}>
-              <Text style={styles.buttonText}>OK</Text>
+    <Modal style={styles.centeredView} animationType="slide" transparent={true} visible={openModal}>
+      <View style={styles.centeredView}>
+        <View style={styles.modalView}>
+          <View style={styles.modalCloseIconWrapper}>
+            <TouchableOpacity style={styles.modalCloseIcon} onPress={onCloseClicked}>
+              <Image source={CloseIcon} style={styles.closeIcon} />
             </TouchableOpacity>
           </View>
+
+          <Text style={styles.title}>SOMETHING WENT WRONG</Text>
+          <Text style={styles.paragraph}>Please try again later.</Text>
+          <Text style={styles.paragraph}>Reason: {message}</Text>
+          <Image source={ThankYouImg} alt="woman" style={styles.image} />
+          <TouchableOpacity style={styles.button} onPress={onCloseClicked}>
+            <Text style={styles.buttonText}>OK</Text>
+          </TouchableOpacity>
         </View>
-      </Modal>
-    </View>
+      </View>
+    </Modal>
   );
 };
 
diff --git a/packages/app/src/components/StopDonationModal.tsx b/packages/app/src/components/modals/StopDonationModal.tsx
similarity index 63%
rename from packages/app/src/components/StopDonationModal.tsx
rename to packages/app/src/components/modals/StopDonationModal.tsx
index af646dec..c6c45c40 100644
--- a/packages/app/src/components/StopDonationModal.tsx
+++ b/packages/app/src/components/modals/StopDonationModal.tsx
@@ -1,8 +1,7 @@
 import { Modal, StyleSheet, Text, View, Image, TouchableOpacity } from 'react-native';
-import { InterRegular, InterSemiBold } from '../utils/webFonts';
-// import useCrossNavigate from '../routes/useCrossNavigate';
-import { Colors } from '../utils/colors';
-import { QuestionImg } from '../assets';
+import { InterRegular, InterSemiBold } from '../../utils/webFonts';
+import { Colors } from '../../utils/colors';
+import { QuestionImg } from '../../assets';
 
 interface StopDonationModalProps {
   openModal: boolean;
@@ -10,26 +9,22 @@ interface StopDonationModalProps {
 }
 
 const StopDonationModal = ({ openModal, setOpenModal }: StopDonationModalProps) => {
-  // const { navigate } = useCrossNavigate();
   return (
-    <View style={styles.centeredView}>
-      <Modal animationType="slide" transparent={true} visible={openModal}>
-        <View style={styles.centeredView}>
-          <View style={styles.modalView}>
-            <Text style={styles.title}>ARE YOU SURE YOU WANT TO STOP YOUR DONATION?</Text>
-            <Text style={styles.paragraph}>
-              If so, please sign with your wallet. If not, please click below to return to the GoodCollective you
-              support.
-            </Text>
+    <Modal style={styles.centeredView} animationType="slide" transparent={true} visible={openModal}>
+      <View style={styles.centeredView}>
+        <View style={styles.modalView}>
+          <Text style={styles.title}>ARE YOU SURE YOU WANT TO STOP YOUR DONATION?</Text>
+          <Text style={styles.paragraph}>
+            If so, please sign with your wallet. If not, please click below to return to the GoodCollective you support.
+          </Text>
 
-            <Image source={QuestionImg} alt="woman" style={styles.image} />
-            <TouchableOpacity style={styles.button} onPress={() => setOpenModal(false)}>
-              <Text style={styles.buttonText}>GO BACK</Text>
-            </TouchableOpacity>
-          </View>
+          <Image source={QuestionImg} alt="woman" style={styles.image} />
+          <TouchableOpacity style={styles.button} onPress={() => setOpenModal(false)}>
+            <Text style={styles.buttonText}>GO BACK</Text>
+          </TouchableOpacity>
         </View>
-      </Modal>
-    </View>
+      </View>
+    </Modal>
   );
 };
 
diff --git a/packages/app/src/components/SwitchModal.tsx b/packages/app/src/components/modals/SwitchModal.tsx
similarity index 98%
rename from packages/app/src/components/SwitchModal.tsx
rename to packages/app/src/components/modals/SwitchModal.tsx
index 0a40c9b9..281947f7 100644
--- a/packages/app/src/components/SwitchModal.tsx
+++ b/packages/app/src/components/modals/SwitchModal.tsx
@@ -1,7 +1,6 @@
 import { Modal, StyleSheet, Text, View, Image, TouchableOpacity } from 'react-native';
-import { InterRegular, InterSemiBold } from '../utils/webFonts';
-// import useCrossNavigate from '../routes/useCrossNavigate';
-import { Colors } from '../utils/colors';
+import { InterRegular, InterSemiBold } from '../../utils/webFonts';
+import { Colors } from '../../utils/colors';
 
 const WomanUri = `data:image/svg+xml;utf8,<svg width="161" height="222" viewBox="0 0 161 222" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> <g clip-path="url(#clip0_5126_88370)"> <path d="M97.5933 55.5896L98.6261 51.0965C98.4496 50.6293 98.6384 50.0935 99.0918 49.8509C99.8907 48.5292 101.075 47.911 102.624 47.9611C103.038 47.7396 103.535 47.837 103.842 48.1634C104.576 47.1971 105.616 46.6803 106.901 46.5265C106.798 46.0913 106.991 45.6247 107.405 45.4031C108.22 44.1679 109.468 43.6418 110.937 43.5133C111.431 43.2491 112.046 43.4339 112.311 43.9261L112.51 44.2946L116.086 45.809L115.776 46.3419L112.804 44.8619C113.465 46.2949 112.905 48.0109 111.492 48.767C110.022 49.553 108.192 49.0031 107.403 47.5387L107.046 46.8758L104.054 48.4771L104.411 49.14C105.199 50.6044 104.647 52.4287 103.178 53.2148C101.709 54.0009 99.8787 53.451 99.0901 51.9866L98.9327 51.6943L98.4501 55.6121L97.5933 55.5896Z" fill="#3F3D56"/> <path d="M84.4328 215.48C83.6531 215.528 83.2222 214.563 83.8121 214L83.8708 213.768C83.8631 213.749 83.8553 213.73 83.8475 213.712C83.059 211.838 80.3867 211.851 79.6049 213.727C78.911 215.393 78.0275 217.062 77.81 218.823C77.7125 219.601 77.7564 220.393 77.9295 221.156C76.3036 217.616 75.4479 213.75 75.4479 209.862C75.4479 208.886 75.5016 207.909 75.6113 206.935C75.7015 206.138 75.8258 205.346 75.9867 204.561C76.8569 200.319 78.7412 196.278 81.4592 192.903C82.7657 192.191 83.8553 191.079 84.5135 189.745C84.7499 189.264 84.9352 188.746 85.023 188.219C84.8743 188.238 84.4623 185.981 84.5745 185.843C84.3672 185.529 83.9963 185.374 83.77 185.068C82.6445 183.547 81.0937 183.812 80.2842 185.879C78.5548 186.749 78.5381 188.192 79.5992 189.58C80.2743 190.462 80.3671 191.657 80.9594 192.602C80.8985 192.68 80.8351 192.755 80.7742 192.833C79.6566 194.262 78.6901 195.797 77.8753 197.41C78.1056 195.618 77.7656 193.458 77.186 192.065C76.5262 190.479 75.2895 189.143 74.2005 187.771C72.8924 186.124 70.21 186.843 69.9796 188.931C69.9773 188.951 69.9752 188.971 69.973 188.992C70.1348 189.083 70.2933 189.179 70.4481 189.281C71.331 189.863 71.0258 191.228 69.9797 191.388L69.956 191.392C70.0145 191.973 70.1144 192.549 70.2607 193.115C68.8636 198.5 71.8798 200.461 76.1865 200.55C76.2816 200.598 76.3743 200.647 76.4693 200.693C76.033 201.917 75.6844 203.174 75.426 204.447C75.1944 205.572 75.0335 206.709 74.9434 207.851C74.8312 209.291 74.841 210.74 74.9629 212.178L74.9556 212.127C74.646 210.543 73.7831 209.063 72.5301 208.038C70.6636 206.51 68.0265 205.947 66.0129 204.718C65.0436 204.127 63.8015 204.891 63.9707 206.011L63.9789 206.065C64.2787 206.186 64.5712 206.327 64.854 206.485C65.0158 206.576 65.1742 206.673 65.329 206.775C66.212 207.357 65.9068 208.721 64.8606 208.882L64.8369 208.886C64.8199 208.888 64.8052 208.891 64.7882 208.893C65.3025 210.11 66.0192 211.24 66.9162 212.214C67.7898 216.915 71.5418 217.361 75.5552 215.992H75.5576C75.9964 217.897 76.6375 219.759 77.4614 221.532H84.2624C84.2868 221.457 84.3087 221.379 84.3307 221.304C83.7018 221.343 83.068 221.306 82.4488 221.192C82.9534 220.575 83.458 219.953 83.9626 219.336C83.9748 219.324 83.9845 219.311 83.9943 219.299C84.2502 218.983 84.5086 218.67 84.7646 218.354L84.7647 218.354C84.7807 217.384 84.6639 216.418 84.4328 215.48Z" fill="#F2F2F2"/> <path d="M111.237 61.1397L115.353 66.0622L113.158 50.2007L112.344 50.6063C111.495 51.0293 110.953 51.8878 110.938 52.8334L111.237 61.1397Z" fill="#2F2E41"/> <path d="M102.954 194.69L105.599 199.714L105.603 199.728L106.482 201.4L107.896 204.083L107.897 204.086L108.491 205.217L109.376 206.898L111.613 206.051L112.28 205.795L112.631 205.663L112.038 204.112L110.473 199.997L107.756 192.872L107.725 192.883L107.057 193.135L104.39 194.147L103.722 194.399L102.954 194.69Z" fill="#FFB6B6"/> <path d="M104.246 214.841C104.555 215.642 105.453 216.045 106.255 215.741L107.323 215.336L107.991 215.083L110.66 214.075L111.331 213.822L112.726 213.292L112.963 210.57L113.533 211.498L113.534 211.501L114.275 212.704L114.667 212.558L116.717 211.781L112.908 203.841L112.038 204.112L111.721 204.21L111.038 204.422L108.494 205.216L108.491 205.217L108.313 205.272L107.631 205.485L107.348 205.574L108.235 207.896L106.395 210.556L105.893 211.282L104.421 213.411C104.131 213.831 104.064 214.365 104.246 214.841Z" fill="#2F2E41"/> <path d="M130.206 200.445L131.006 206.062V206.077L131.27 207.945L131.699 210.946V210.95L131.877 212.213L132.145 214.093L134.538 214.043L135.252 214.025L135.627 214.018L135.592 212.359L135.502 207.96L135.342 200.338H135.309L134.595 200.353L131.742 200.413L131.027 200.427L130.206 200.445Z" fill="#FFB6B6"/> <path d="M124.639 219.859C124.66 220.717 125.371 221.397 126.228 221.379L127.371 221.354L128.085 221.34L130.938 221.283L131.656 221.269L133.149 221.237L134.288 218.752L134.513 219.817V219.82L134.806 221.201L135.224 221.194L137.417 221.148L136.502 212.395L135.592 212.359L135.26 212.345L134.545 212.317L131.881 212.213H131.878L131.692 212.206L130.978 212.178L130.681 212.167L130.735 214.652L128.106 216.542L127.388 217.058L125.285 218.571C124.871 218.87 124.628 219.35 124.639 219.859Z" fill="#2F2E41"/> <path d="M138.526 126.588L135.978 111.555L141.447 109.362L142.59 125.984C143.103 126.295 143.534 126.753 143.81 127.333C144.569 128.924 143.89 130.826 142.294 131.581C140.699 132.337 138.791 131.66 138.032 130.07C137.465 128.88 137.703 127.516 138.526 126.588Z" fill="#FFB6B6"/> <path d="M96.3315 59.8188L86.4033 71.4161L81.2051 68.6442L93.2582 57.1006C93.1693 56.509 93.2442 55.8861 93.5132 55.3018C94.2499 53.7014 96.1487 52.9993 97.7544 53.7336C99.36 54.4679 100.064 56.3605 99.3277 57.9609C98.7764 59.1585 97.5745 59.8527 96.3315 59.8188Z" fill="#FFB6B6"/> <path d="M118.254 65.7142C122.794 65.7142 126.474 62.0459 126.474 57.5207C126.474 52.9955 122.794 49.3271 118.254 49.3271C113.714 49.3271 110.033 52.9955 110.033 57.5207C110.033 62.0459 113.714 65.7142 118.254 65.7142Z" fill="#FFB6B6"/> <path d="M106.919 109.495L129.071 107.083L129.894 110.912V111.829L130.367 112.376L130.54 113.063L130.992 113.1C130.992 113.1 130.729 113.564 130.917 113.816C131.063 114.01 131.626 113.943 131.856 114.277C134.182 117.658 140.21 127.962 137.302 140.447L137.714 161.095L137.333 162.718L137.773 163.773L138.088 165.352L138.537 198.014L139.634 201.842L137.988 206.765L128.111 207.312L126.464 201.022L127.288 193.091L124.818 169.846L124.124 168.737L124.522 167.609L124.879 166.104L124.118 164.549L121.42 144.146C120.717 142.508 120.426 140.725 120.573 138.95L120.634 138.202L120.154 134.567L106.847 156.171L102.404 163.839L102.869 167.111L105.801 185.657L109.953 190.172L110.707 196.19L104.669 199.952L97.8756 197.695V193.181L87.5154 164.976L99.3017 130.192L101.222 128.551L100.948 126.363L102.76 124.557L106.386 116.449L108.051 112.881L106.919 109.495Z" fill="#2F2E41"/> <path d="M114.392 66.1987H123.123L125.093 72.2152L137.439 77.9581L134.696 90.8115L131.403 102.024L130.433 102.991L130.854 104.759H128.723L129.071 107.083L131.403 110.502L106.309 109.966V104.387L108.273 96.5116C105.794 91.0758 107.177 87.802 107.518 81.8408L105.338 73.5826L112.197 72.9139L114.392 66.1987Z" fill="#6C63FF"/> <path d="M108.706 81.9387L110.626 77.2897C110.626 77.2897 110.352 74.008 104.59 73.1875C98.8284 72.3671 87.8895 71.5467 87.8895 71.5467L90.5349 68.6746L91.6672 65.6652L86.3834 63.032L83.354 64.5161L82.2319 66.4176L82.6094 67.1699L80.9708 68.1609C78.9311 71.3953 79.8031 75.6567 82.9508 77.8366L84.1747 79.0565L85.9689 80.0244L88.1639 79.7509L108.706 81.9387Z" fill="#6C63FF"/> <path d="M130.992 79.0523L135.656 77.1379C135.656 77.1379 138.948 77.4114 139.772 83.1544C140.595 88.8974 141.418 103.938 141.418 103.938L142.79 106.947V107.788L144.003 110.365L143.274 111.092L145.259 112.69L136.205 115.971L134.256 111.008L135.107 108.861L133.883 107.641L132.912 105.853L133.187 103.665L130.992 79.0523Z" fill="#6C63FF"/> <path d="M133.874 74.3156H131.624C130.873 73.2999 130.741 72.6303 130.805 71.3889C130.7 72.2278 128.911 69.6623 129.013 70.6328C129.035 70.8435 130.126 74.4886 130.164 74.6918C129.118 75.6435 127.907 76.1438 126.578 76.3168C127.001 75.0416 126.571 74.3532 125.269 74.466C125.337 75.1131 125.25 75.7751 125.035 76.3883C121.102 76.2566 116.354 73.9733 111.663 72.1827C111.493 71.0053 111.701 69.7714 112.278 68.7294C111.795 69.5344 111.323 70.3432 110.984 71.2159C110.908 71.4116 110.84 71.6109 110.78 71.8103C110.739 71.9532 110.701 72.0962 110.667 72.2354L108.493 72.352C110.339 69.6924 110.003 65.9645 112.248 63.9595C115.822 60.7733 112.807 56.135 111.312 51.8128C111.267 50.6918 111.958 49.6686 113.018 49.2887L115.92 48.2504C119.611 46.93 119.427 46.1739 122.993 48.3595C126.56 47.2686 132.806 53.073 132.806 57.3877C132.806 57.7639 132.851 58.1288 132.923 58.4786C132.504 58.5313 132.096 58.6667 131.734 58.8849C132.228 59.1633 132.711 59.4642 133.176 59.7914C133.538 62.0109 133.511 64.2755 132.994 66.4723C132.413 68.9438 133.47 73.1381 133.874 74.3156Z" fill="#2F2E41"/> <path d="M160.5 221.552C160.5 221.801 160.3 222 160.051 222H64.4569C64.2079 222 64.0078 221.801 64.0078 221.552C64.0078 221.304 64.2079 221.105 64.4569 221.105H160.051C160.3 221.105 160.5 221.304 160.5 221.552Z" fill="#CCCCCC"/> <rect x="8" y="2" width="56" height="56" rx="28" fill="url(#pattern0)"/> </g> <defs> <pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1"> <use xlink:href="#image0_5126_88370" transform="scale(0.0025)"/> </pattern> <clipPath id="clip0_5126_88370"> <rect width="160" height="222" fill="white" transform="translate(0.5)"/> </clipPath> <image id="image0_5126_88370" width="400" height="400" xlink:href=""/> </defs> </svg> `;
 
@@ -11,28 +10,25 @@ interface SwitchModalProps {
 }
 
 const SwitchModal = ({ openModal, setOpenModal }: SwitchModalProps) => {
-  // const { navigate } = useCrossNavigate();
   return (
-    <View style={styles.centeredView}>
-      <Modal animationType="slide" transparent={true} visible={openModal}>
-        <View style={styles.centeredView}>
-          <View style={styles.modalView}>
-            <Text style={styles.title}>PLEASE USE CELO</Text>
-            <Text style={styles.paragraph}>
-              GoodCollective only supports the CELO network at this time. Please use the CELO network.
-            </Text>
-            <Image source={{ uri: WomanUri }} alt="woman" style={styles.image} />
-            <TouchableOpacity
-              style={styles.button}
-              onPress={() => {
-                setOpenModal(false);
-              }}>
-              <Text style={styles.buttonText}>OK</Text>
-            </TouchableOpacity>
-          </View>
+    <Modal style={styles.centeredView} animationType="slide" transparent={true} visible={openModal}>
+      <View style={styles.centeredView}>
+        <View style={styles.modalView}>
+          <Text style={styles.title}>PLEASE USE CELO</Text>
+          <Text style={styles.paragraph}>
+            GoodCollective only supports the CELO network at this time. Please use the CELO network.
+          </Text>
+          <Image source={{ uri: WomanUri }} alt="woman" style={styles.image} />
+          <TouchableOpacity
+            style={styles.button}
+            onPress={() => {
+              setOpenModal(false);
+            }}>
+            <Text style={styles.buttonText}>OK</Text>
+          </TouchableOpacity>
         </View>
-      </Modal>
-    </View>
+      </View>
+    </Modal>
   );
 };
 
diff --git a/packages/app/src/components/ThankYouModal.tsx b/packages/app/src/components/modals/ThankYouModal.tsx
similarity index 55%
rename from packages/app/src/components/ThankYouModal.tsx
rename to packages/app/src/components/modals/ThankYouModal.tsx
index e9273110..5f6950f4 100644
--- a/packages/app/src/components/ThankYouModal.tsx
+++ b/packages/app/src/components/modals/ThankYouModal.tsx
@@ -1,37 +1,34 @@
 import { Modal, StyleSheet, Text, View, Image, TouchableOpacity } from 'react-native';
-import useCrossNavigate from '../routes/useCrossNavigate';
-import { InterRegular, InterSemiBold } from '../utils/webFonts';
-import { Colors } from '../utils/colors';
-import { useAccount } from 'wagmi';
-import { ThankYouImg } from '../assets';
+import { InterRegular, InterSemiBold } from '../../utils/webFonts';
+import { Colors } from '../../utils/colors';
+import { ThankYouImg } from '../../assets';
+import { IpfsCollective } from '../../models/models';
 
 interface ThankYouModalProps {
   openModal: boolean;
-  setOpenModal: any;
+  setOpenModal: (openModal: boolean) => void;
+  collective: IpfsCollective;
 }
 
-const ThankYouModal = ({ openModal }: ThankYouModalProps) => {
-  // const [modalVisible, setModalVisible] = useState(openModal);
-  const { navigate } = useCrossNavigate();
-  const { address } = useAccount();
+const ThankYouModal = ({ openModal, setOpenModal, collective }: ThankYouModalProps) => {
+  const onClick = () => setOpenModal(false);
+
   return (
-    <View style={styles.centeredView}>
-      <Modal animationType="slide" transparent={true} visible={openModal}>
-        <View style={styles.centeredView}>
-          <View style={styles.modalView}>
-            <Text style={styles.title}>THANK YOU!</Text>
-            <Text style={styles.paragraph}>You have just donated to Restoring the Kakamega Forest GoodCollective!</Text>
-            <Text style={styles.paragraph}>
-              To stop your donation, visit the Restoring the Kakamega Forest GoodCollective page.
-            </Text>
-            <Image source={ThankYouImg} alt="woman" style={styles.image} />
-            <TouchableOpacity style={styles.button} onPress={() => navigate('/walletProfile/' + address)}>
-              <Text style={styles.buttonText}>GO TO PROFILE</Text>
-            </TouchableOpacity>
-          </View>
+    <Modal style={styles.centeredView} animationType="slide" transparent={true} visible={openModal}>
+      <View style={styles.centeredView}>
+        <View style={styles.modalView}>
+          <Text style={styles.title}>THANK YOU!</Text>
+          <Text style={styles.paragraph}>{`You have just donated to ${collective.name} GoodCollective!`}</Text>
+          <Text style={styles.paragraph}>
+            {`To stop your donation, visit the ${collective.name} GoodCollective page.`}
+          </Text>
+          <Image source={ThankYouImg} alt="woman" style={styles.image} />
+          <TouchableOpacity style={styles.button} onPress={onClick}>
+            <Text style={styles.buttonText}>GO TO PROFILE</Text>
+          </TouchableOpacity>
         </View>
-      </Modal>
-    </View>
+      </View>
+    </Modal>
   );
 };
 
diff --git a/packages/app/src/hooks/useContractCalls/useContractCalls.tsx b/packages/app/src/hooks/useContractCalls/useContractCalls.tsx
index 4b9a6146..f4ac5e6a 100644
--- a/packages/app/src/hooks/useContractCalls/useContractCalls.tsx
+++ b/packages/app/src/hooks/useContractCalls/useContractCalls.tsx
@@ -20,6 +20,7 @@ export const useContractCalls = (
   frequency: Frequency,
   onError: (error: string) => void,
   toggleCompleteDonationModal: (value: boolean) => void,
+  toggleThankYouModal: (value: boolean) => void,
   minReturnFromSwap?: string,
   swapPath?: string
 ): ContractCalls => {
@@ -32,7 +33,8 @@ export const useContractCalls = (
     duration,
     frequency,
     onError,
-    toggleCompleteDonationModal
+    toggleCompleteDonationModal,
+    toggleThankYouModal
   );
   const supportFlowWithSwap = useSupportFlowWithSwap(
     collective,
@@ -42,6 +44,7 @@ export const useContractCalls = (
     frequency,
     onError,
     toggleCompleteDonationModal,
+    toggleThankYouModal,
     minReturnFromSwap,
     swapPath
   );
@@ -50,14 +53,16 @@ export const useContractCalls = (
     tokenIn.decimals,
     decimalAmountIn,
     onError,
-    toggleCompleteDonationModal
+    toggleCompleteDonationModal,
+    toggleThankYouModal
   );
   const supportSingleBatch = useSupportSingleBatch(
     collective,
     tokenIn.decimals,
     decimalAmountIn,
     onError,
-    toggleCompleteDonationModal
+    toggleCompleteDonationModal,
+    toggleThankYouModal
   );
 
   return {
diff --git a/packages/app/src/hooks/useContractCalls/useSupportFlow.ts b/packages/app/src/hooks/useContractCalls/useSupportFlow.ts
index 97cb638c..37d7ea9a 100644
--- a/packages/app/src/hooks/useContractCalls/useSupportFlow.ts
+++ b/packages/app/src/hooks/useContractCalls/useSupportFlow.ts
@@ -14,7 +14,8 @@ export function useSupportFlow(
   duration: number,
   frequency: Frequency,
   onError: (error: string) => void,
-  toggleCompleteDonationModal: (value: boolean) => void
+  toggleCompleteDonationModal: (value: boolean) => void,
+  toggleThankYouModal: (value: boolean) => void
 ) {
   const { address: maybeAddress } = useAccount();
   const { chain } = useNetwork();
@@ -42,25 +43,29 @@ export function useSupportFlow(
       const sdk = new GoodCollectiveSDK(chainIdString, signer.provider, { network });
       toggleCompleteDonationModal(true);
       const tx = await sdk.supportFlow(signer, collective, flowRate);
+      toggleCompleteDonationModal(false);
+      toggleThankYouModal(true);
       await tx.wait();
       navigate(`/profile/${address}`);
       return;
     } catch (error) {
       toggleCompleteDonationModal(false);
+      toggleThankYouModal(false);
       const message = printAndParseSupportError(error);
       onError(message);
     }
   }, [
     maybeAddress,
     chain?.id,
-    collective,
-    currencyDecimals,
+    maybeSigner,
     decimalAmountIn,
     duration,
     frequency,
-    navigate,
+    currencyDecimals,
     onError,
-    maybeSigner,
     toggleCompleteDonationModal,
+    collective,
+    toggleThankYouModal,
+    navigate,
   ]);
 }
diff --git a/packages/app/src/hooks/useContractCalls/useSupportFlowWithSwap.ts b/packages/app/src/hooks/useContractCalls/useSupportFlowWithSwap.ts
index 550c3080..9d168a37 100644
--- a/packages/app/src/hooks/useContractCalls/useSupportFlowWithSwap.ts
+++ b/packages/app/src/hooks/useContractCalls/useSupportFlowWithSwap.ts
@@ -18,6 +18,7 @@ export function useSupportFlowWithSwap(
   frequency: Frequency,
   onError: (error: string) => void,
   toggleCompleteDonationModal: (value: boolean) => void,
+  toggleThankYouModal: (value: boolean) => void,
   minReturnFromSwap?: string,
   swapPath?: string
 ) {
@@ -64,27 +65,32 @@ export function useSupportFlowWithSwap(
         swapFrom: tokenIn.address,
         deadline: Math.floor(Date.now() / 1000 + 1800).toString(),
       });
+      toggleCompleteDonationModal(false);
+      toggleThankYouModal(true);
       await tx.wait();
       navigate(`/profile/${address}`);
       return;
     } catch (error) {
       toggleCompleteDonationModal(false);
+      toggleThankYouModal(false);
       const message = printAndParseSupportError(error);
       onError(message);
     }
   }, [
     maybeAddress,
     chain?.id,
-    collective,
-    tokenIn,
+    maybeSigner,
+    minReturnFromSwap,
+    swapPath,
     decimalAmountIn,
     duration,
     frequency,
-    navigate,
+    tokenIn.decimals,
+    tokenIn.address,
     onError,
-    maybeSigner,
-    minReturnFromSwap,
-    swapPath,
     toggleCompleteDonationModal,
+    collective,
+    toggleThankYouModal,
+    navigate,
   ]);
 }
diff --git a/packages/app/src/hooks/useContractCalls/useSupportSingleBatch.ts b/packages/app/src/hooks/useContractCalls/useSupportSingleBatch.ts
index d725a052..d4fbc170 100644
--- a/packages/app/src/hooks/useContractCalls/useSupportSingleBatch.ts
+++ b/packages/app/src/hooks/useContractCalls/useSupportSingleBatch.ts
@@ -13,7 +13,8 @@ export function useSupportSingleBatch(
   currencyDecimals: number,
   decimalAmountIn: number,
   onError: (error: string) => void,
-  toggleCompleteDonationModal: (value: boolean) => void
+  toggleCompleteDonationModal: (value: boolean) => void,
+  toggleThankYouModal: (value: boolean) => void
 ) {
   const { address: maybeAddress } = useAccount();
   const { chain } = useNetwork();
@@ -40,23 +41,27 @@ export function useSupportSingleBatch(
       const sdk = new GoodCollectiveSDK(chainIdString, signer.provider, { network });
       toggleCompleteDonationModal(true);
       const tx = await sdk.supportSingleBatch(signer, collective, donationAmount);
+      toggleCompleteDonationModal(false);
+      toggleThankYouModal(true);
       await tx.wait();
       navigate(`/profile/${address}`);
       return;
     } catch (error) {
       toggleCompleteDonationModal(false);
+      toggleThankYouModal(false);
       const message = printAndParseSupportError(error);
       onError(message);
     }
   }, [
     maybeAddress,
     chain?.id,
-    collective,
-    currencyDecimals,
+    maybeSigner,
     decimalAmountIn,
-    navigate,
+    currencyDecimals,
     onError,
-    maybeSigner,
     toggleCompleteDonationModal,
+    collective,
+    toggleThankYouModal,
+    navigate,
   ]);
 }
diff --git a/packages/app/src/hooks/useContractCalls/useSupportSingleTransferAndCall.ts b/packages/app/src/hooks/useContractCalls/useSupportSingleTransferAndCall.ts
index 9380ab39..261df1b5 100644
--- a/packages/app/src/hooks/useContractCalls/useSupportSingleTransferAndCall.ts
+++ b/packages/app/src/hooks/useContractCalls/useSupportSingleTransferAndCall.ts
@@ -13,7 +13,8 @@ export function useSupportSingleTransferAndCall(
   currencyDecimals: number,
   decimalAmountIn: number,
   onError: (error: string) => void,
-  toggleCompleteDonationModal: (value: boolean) => void
+  toggleCompleteDonationModal: (value: boolean) => void,
+  toggleThankYouModal: (value: boolean) => void
 ) {
   const { address: maybeAddress } = useAccount();
   const { chain } = useNetwork();
@@ -40,23 +41,27 @@ export function useSupportSingleTransferAndCall(
       const sdk = new GoodCollectiveSDK(chainIdString, signer.provider, { network });
       toggleCompleteDonationModal(true);
       const tx = await sdk.supportSingleTransferAndCall(signer, collective, donationAmount);
+      toggleCompleteDonationModal(false);
+      toggleThankYouModal(true);
       await tx.wait();
       navigate(`/profile/${address}`);
       return;
     } catch (error) {
       toggleCompleteDonationModal(false);
+      toggleThankYouModal(false);
       const message = printAndParseSupportError(error);
       onError(message);
     }
   }, [
     maybeAddress,
     chain?.id,
-    collective,
-    currencyDecimals,
+    maybeSigner,
     decimalAmountIn,
-    navigate,
+    currencyDecimals,
     onError,
-    maybeSigner,
     toggleCompleteDonationModal,
+    collective,
+    toggleThankYouModal,
+    navigate,
   ]);
 }
diff --git a/packages/app/src/pages/ModalTestPage.tsx b/packages/app/src/pages/ModalTestPage.tsx
deleted file mode 100644
index 074b6659..00000000
--- a/packages/app/src/pages/ModalTestPage.tsx
+++ /dev/null
@@ -1,24 +0,0 @@
-import Layout from '../components/Layout';
-import SwitchModal from '../components/SwitchModal';
-import CompleteDonationModal from '../components/CompleteDonationModal';
-import ThankYouModal from '../components/ThankYouModal';
-import ErrorModal from '../components/ErrorModal';
-import ApproveSwapModal from '../components/ApproveSwapModal';
-import StopDonationModal from '../components/StopDonationModal';
-import { useState } from 'react';
-
-function ModalTestPage() {
-  const [openModal, setOpenModal] = useState(false);
-  return (
-    <Layout>
-      <SwitchModal openModal={openModal} setOpenModal={setOpenModal} />
-      <CompleteDonationModal openModal={openModal} setOpenModal={setOpenModal} />
-      <ThankYouModal openModal={openModal} setOpenModal={setOpenModal} />
-      <ErrorModal openModal={openModal} setOpenModal={setOpenModal} message={'Something went wrong'} />
-      <ApproveSwapModal openModal={openModal} setOpenModal={setOpenModal} />
-      <StopDonationModal openModal={openModal} setOpenModal={setOpenModal} />
-    </Layout>
-  );
-}
-
-export default ModalTestPage;