Skip to content

Commit

Permalink
fix: fixed popup errors on app startup, and in profile section
Browse files Browse the repository at this point in the history
    *ft(booking):add FlutteWave payment method
    *ft: allow user to end chats and leave a review
    *ft: patient notification context
    *feature: populate initial notifications and add new ones upon being added to the db
    *ft: fetched notifications and reworked on the notifications screen and notification Listing component
    *fix: device notification on notification creation
    *rf: refactored some erros
    *ft(notifications):add logic to insert notifications on every key action
    *ft(notifications):add logic to insert notifications on every booking
  • Loading branch information
mr3nz1 committed Jul 23, 2024
1 parent ca4e979 commit 8696017
Show file tree
Hide file tree
Showing 23 changed files with 2,001 additions and 1,113 deletions.
562 changes: 289 additions & 273 deletions app/(app)/ActionMenu/AllDoctorScreen.tsx

Large diffs are not rendered by default.

44 changes: 33 additions & 11 deletions app/(app)/ActionMenu/Booking/EnterYourPin.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,26 +22,51 @@ import { supabase } from "@/lib/supabase";
export default function EnterYourPin() {
const [isDark, setIsDark] = useState(false);
const modal = useModal();
const {doctor_id,hour,date,packageTitle,packagePrice,problem,user_id,patient_id,duration} = useLocalSearchParams()
const {
doctor_id,
hour,
date,
packageTitle,
packagePrice,
problem,
user_id,
patient_id,
duration,
} = useLocalSearchParams();

const { theme, changeTheme } = useContext(ThemeContext);
async function bookAppointment() {
const { error } = await supabase
.from('appointment')
.insert({ doctor_id: doctor_id, time:hour,date:date, package: packageTitle, price: packagePrice, illness_descr: problem,user_id:patient_id,duration:duration});
.from("appointment")
.insert({
doctor_id: doctor_id,
time: hour,
date: date,
package: packageTitle,
price: packagePrice,
illness_descr: problem,
user_id: patient_id,
duration: duration,
});
if (error) {
console.error("Error booking appointment:", error);
}
}
console.log("this is from lastpage",doctor_id,hour,packageTitle,packagePrice,problem)
console.log(
"this is from lastpage",
doctor_id,
hour,
packageTitle,
packagePrice,
problem
);

function successBooking() {
router.push("ActionMenu");;
router.push("ActionMenu");
modal.hide();
}
async function handlePIN() {

await bookAppointment()
await bookAppointment();
modal.show({
children: (
<View
Expand Down Expand Up @@ -96,10 +121,7 @@ export default function EnterYourPin() {
justifyContent: "center",
}}
></View>
<Button
title="View Appointment"
onPress={successBooking}
/>
<Button title="View Appointment" onPress={successBooking} />
<TouchableOpacity
onPress={() => {
router.push("ActionMenu");
Expand Down
202 changes: 123 additions & 79 deletions app/(app)/ActionMenu/Booking/SelectPayment.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { Colors } from "@/constants/Colors";
import { StatusBar } from "expo-status-bar";
import { useContext, useState } from "react";
import { ScrollView,TouchableOpacity,View,Image } from "react-native";
import { useContext, useState } from "react";
import { ScrollView, TouchableOpacity, View, Image } from "react-native";
import { Text } from "react-native";
import { ThemeContext } from "@/ctx/ThemeContext";
import Typography from "@/constants/Typography";
Expand All @@ -12,76 +12,118 @@ import PaymentChooseContainer from "@/components/UI/PaymentChooseContainer/Index
import { router } from "expo-router";
import React from "react";
import { useLocalSearchParams } from "expo-router";
import { PayWithFlutterwave } from 'flutterwave-react-native'
import { PayWithFlutterwave } from "flutterwave-react-native";
import { supabase } from "@/lib/supabase";
import { useModal } from "@/ctx/ModalContext";
export default function SelectPayment() {
const { theme, changeTheme } = useContext(ThemeContext);
const [selected, setSelected] = useState(false);
const [loggedEmail,setLoggedEmail]=useState<string>("")
const { doctor_id, hour, date, packageTitle, packagePrice, problem, user_id, patient_id, duration } = useLocalSearchParams()
const [loggedEmail, setLoggedEmail] = useState<string>("");
const {
doctor_id,
hour,
date,
packageTitle,
packagePrice,
problem,
user_id,
patient_id,
duration,
} = useLocalSearchParams();

const modal = useModal();
const flutterKey = process.env.EXPO_PUBLIC_FLUTTERWAVE_KEY ?? "";
console.log("this is packageprice from slect Payment:", packagePrice);

const modal = useModal()
const flutterKey = process.env.EXPO_PUBLIC_FLUTTERWAVE_KEY ?? ""

interface RedirectParams {
status: "successful" | "cancelled";
transaction_id?: string;
tx_ref: string;
status: "successful" | "cancelled";
transaction_id?: string;
tx_ref: string;
}
let num:number=1;
let num: number = 1;
if (duration === "30 minutes") {
num=1
num = 1;
} else {
num=2
num = 2;
}
let price: number = 0;
if (packagePrice === "Rwf20") {
price=20
price = 20;
} else if (packagePrice === "Rwf40") {
price=40
price = 40;
} else if (packagePrice === "Rwf60") {
price =60
price = 60;
}
const total:number=price*num
const total: number = price * num;

useEffect(() => {
const fetchUser = async () => {

const { data: { user },error } = await supabase.auth.getUser()
const {
data: { user },
error,
} = await supabase.auth.getUser();
if (error) {
console.error("error fetching user")
console.error("error fetching user");
} else {
setLoggedEmail(user?.email||"logged Email")
setLoggedEmail(user?.email || "logged Email");
}
}
fetchUser()

}, [loggedEmail])
};
fetchUser();
}, [loggedEmail]);
async function bookAppointment() {
try {
const { error } = await supabase
.from('appointment')
.insert({
const { error } = await supabase.from("appointment").insert({
doctor_id: doctor_id,
time: hour, date: date,
time: hour,
date: date,
package: packageTitle,
price: packagePrice,
illness_descr: problem,
user_id: patient_id,
duration: duration
duration: duration,
});
} catch (error) {
console.log("Error while inserting data in booking ",error)
}

console.log("Error while inserting data in booking ", error);
}
}
const addNotification = async (doctorName: string) => {
try {
const { error } = await supabase.from("notifications").insert({
title: "Appointment Booked",
description: `You have successfully booked an appointment with Dr. ${doctorName}`,
patient_id: patient_id,
type: "appointment_booked",
doctor_id: doctor_id,
viewed: false,
});
console.log("Notification will be pushed");
if (error) {
console.log("Error while inserting notification ", error);
}
} catch (error) {
console.log("Error while inserting notification ", error);
}
};
const fetchDoctorName = async (doctorId: string) => {
const { data, error } = await supabase
.from("doctors")
.select("first_name")
.eq("id", doctorId)
.single();

if (error) {
console.log("Error fetching doctor's name: ", error);
return "";
}

return data.first_name;
};
function successBooking() {
router.push("ActionMenu");;
router.push("ActionMenu");
modal.hide();
}
const showSuccefulModal = () => {
modal.show({
modal.show({
children: (
<View
style={{
Expand Down Expand Up @@ -135,13 +177,7 @@ const total:number=price*num
justifyContent: "center",
}}
></View>
<Button
title="View Appointment"
onPress={()=> {
successBooking()
router.push("(app)/Appointments")
}}
/>
<Button title="View Appointment" onPress={successBooking} />
<TouchableOpacity
onPress={() => {
router.push("ActionMenu");
Expand Down Expand Up @@ -173,29 +209,31 @@ const total:number=price*num
</View>
),
});
}
const handleOnRedirect = (data: RedirectParams) => {

console.log("redire data:", data)
};
const handleOnRedirect = async (data: RedirectParams) => {
if (data.status === "successful") {
bookAppointment()
showSuccefulModal()
bookAppointment();
if (typeof doctor_id === "string") {
const doctorName = await fetchDoctorName(doctor_id);
await addNotification(doctorName);
}
showSuccefulModal();
} else {
alert("Payment Failed or cancelled ,please try again")
alert("Payment Failed or cancelled ,please try again");
}
}
};
const generateRef = (length: number): string => {
const characters = flutterKey;
const charactersArray = characters.split('');
let result = '';
const characters = flutterKey;
const charactersArray = characters.split("");
let result = "";

for (let i = 0; i < length; i++) {
const randomIndex = Math.floor(Math.random() * charactersArray.length);
result += charactersArray[randomIndex];
}
for (let i = 0; i < length; i++) {
const randomIndex = Math.floor(Math.random() * charactersArray.length);
result += charactersArray[randomIndex];
}

return result;
};
return result;
};

return (
<>
Expand All @@ -222,25 +260,31 @@ const total:number=price*num
>
Comfirm the payment by click the button below.
</Text>
<View style={{width:"100%",height:"70%",display:"flex",flexDirection:"row",alignItems:"center",justifyContent:"center"}}>
<PayWithFlutterwave
onRedirect={handleOnRedirect}
options={{
tx_ref: generateRef(11),
authorization: 'FLWPUBK_TEST-3c390392d62e44fc5788cb0859823f05-X',
customer: {
email: loggedEmail
},
amount: total,
currency: 'RWF',
payment_options: 'card'
}}
/>

<View
style={{
width: "100%",
height: "70%",
display: "flex",
flexDirection: "row",
alignItems: "center",
justifyContent: "center",
}}
>
<PayWithFlutterwave
onRedirect={handleOnRedirect}
options={{
tx_ref: generateRef(11),
authorization: "FLWPUBK_TEST-3c390392d62e44fc5788cb0859823f05-X",
customer: {
email: loggedEmail,
},
amount: total,
currency: "RWF",
payment_options: "card",
}}
/>
</View>


</ScrollView>
</>
);
}
}
3 changes: 2 additions & 1 deletion app/(app)/ActionMenu/Booking/SelectPaymentFlutter.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -46,10 +46,11 @@ class MyCart extends React.Component<{}, MyCartState> {
this.abortController.signal
);
// use payment link

this.usePaymentLink(paymentLink);
} catch (error: any) {
// do nothing if our payment initialization was aborted
if (error.code === 'ABORTERROR') {
if (error.code === "ABORTERROR") {
return;
}
// handle other errors
Expand Down
4 changes: 2 additions & 2 deletions app/(app)/ActionMenu/Booking/_layout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -53,10 +53,10 @@ export default function BookingLayout() {
name="SelectPayment"
options={{ header: () => <Header title="Payments" /> }}
/>
{/* <Stack.Screen
<Stack.Screen
name="SelectPaymentFlutter"
options={{ header: () => <Header title="Payments" /> }}
/> */}
/>
</Stack>
</>
);
Expand Down
Loading

0 comments on commit 8696017

Please sign in to comment.