From 601b3f32dac1b4fdd1ddc71f782d04cb24758897 Mon Sep 17 00:00:00 2001 From: Melissa Liu Date: Wed, 3 Apr 2024 02:37:48 -0700 Subject: [PATCH 1/4] broken deep link for sharing --- assets/shareicon.svg | 3 ++ package-lock.json | 15 ++++++++++ package.json | 3 +- .../AllCases/CaseScreen/[caseUid].tsx | 30 +++++++++++++++++-- .../AllCases/CaseScreen/styles.ts | 15 ++++++++-- 5 files changed, 61 insertions(+), 5 deletions(-) create mode 100644 assets/shareicon.svg diff --git a/assets/shareicon.svg b/assets/shareicon.svg new file mode 100644 index 00000000..36a590fc --- /dev/null +++ b/assets/shareicon.svg @@ -0,0 +1,3 @@ + + + diff --git a/package-lock.json b/package-lock.json index 22331557..0961c7e9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,6 +28,7 @@ "expo-linking": "~5.0.2", "expo-notifications": "~0.20.1", "expo-router": "^2.0.0", + "expo-sharing": "~11.5.0", "expo-status-bar": "~1.6.0", "linking": "^0.1.0-beta.5", "react": "18.2.0", @@ -13167,6 +13168,14 @@ } } }, + "node_modules/expo-sharing": { + "version": "11.5.0", + "resolved": "https://registry.npmjs.org/expo-sharing/-/expo-sharing-11.5.0.tgz", + "integrity": "sha512-uerM5YH1FKDZXfkP9ORebvlMVOPP/AfoYgYBez6a8G9fztNYHnRCA6mgK+3aQmpnb3ltmjnAZC39kH18bTNcVw==", + "peerDependencies": { + "expo": "*" + } + }, "node_modules/expo-splash-screen": { "version": "0.20.5", "resolved": "https://registry.npmjs.org/expo-splash-screen/-/expo-splash-screen-0.20.5.tgz", @@ -33939,6 +33948,12 @@ "url": "^0.11.0" } }, + "expo-sharing": { + "version": "11.5.0", + "resolved": "https://registry.npmjs.org/expo-sharing/-/expo-sharing-11.5.0.tgz", + "integrity": "sha512-uerM5YH1FKDZXfkP9ORebvlMVOPP/AfoYgYBez6a8G9fztNYHnRCA6mgK+3aQmpnb3ltmjnAZC39kH18bTNcVw==", + "requires": {} + }, "expo-splash-screen": { "version": "0.20.5", "resolved": "https://registry.npmjs.org/expo-splash-screen/-/expo-splash-screen-0.20.5.tgz", diff --git a/package.json b/package.json index 7ea921b4..0939b316 100644 --- a/package.json +++ b/package.json @@ -53,7 +53,8 @@ "uri-scheme": "^1.2.0", "yargs": "^16.2.0", "yargs-parser": "^20.2.9", - "zod": "^3.22.4" + "zod": "^3.22.4", + "expo-sharing": "~11.5.0" }, "devDependencies": { "@babel/core": "^7.20.0", diff --git a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx index f4317fbd..91de3a4d 100644 --- a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx +++ b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx @@ -1,9 +1,18 @@ +<<<<<<< HEAD import { router, useLocalSearchParams, useNavigation } from 'expo-router'; import React, { useEffect, useState } from 'react'; import { View, ScrollView, Text, TouchableOpacity } from 'react-native'; +======= +import * as Linking from 'expo-linking'; +import { useLocalSearchParams, useNavigation } from 'expo-router'; +import * as Sharing from 'expo-sharing'; +import React, { useEffect, useState } from 'react'; +import { View, ScrollView, Text } from 'react-native'; +import { TouchableOpacity } from 'react-native-gesture-handler'; +>>>>>>> 38811db (broken deep link for sharing) import styles from './styles'; -// eslint-disable-next-line import/namespace +import Icon from '../../../../../assets/shareicon.svg'; import CaseStatusBar from '../../../../Components/CaseStatusBar/CaseStatusBar'; import CaseSummaryCard from '../../../../Components/CaseSummaryCard/CaseSummaryCard'; import EducationalBar from '../../../../Components/EducationalBar/EducationalBar'; @@ -18,13 +27,26 @@ function CaseScreen() { const [caseData, setCaseData] = useState(); const [isLoading, setIsLoading] = useState(true); const navigation = useNavigation(); + const url = Linking.useURL(); + const urle = Linking.getInitialURL(); const getCase = async (uid: string) => { const caseData = await getCaseById(uid); setCaseData(caseData); setIsLoading(false); }; - + const shareLink = async () => { + if (caseData) { + try { + console.log(url); + await Sharing.shareAsync( + 'exp://192.168.4.84:8082/--/AllCases/addCase/?caseUID=09a59710-706c-11ee-b5ff-87a607d233fc', + ); + } catch (error) { + console.error('Failed sharing:', error); + } + } + }; const getStatus = async (uid: string) => { const caseStatus = await getCaseStatus(uid); setStatus(caseStatus); @@ -54,6 +76,10 @@ function CaseScreen() { contentContainerStyle={styles.innerScroll} showsVerticalScrollIndicator={false} > + + Share + + {caseData.title} diff --git a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts index c052a71c..e7730bda 100644 --- a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts +++ b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts @@ -28,8 +28,7 @@ export default StyleSheet.create({ }, titleContainer: { flexDirection: 'row', - paddingVertical: 12, - marginTop: 20, + paddingBottom: 12, }, title: { flex: 1, @@ -38,4 +37,16 @@ export default StyleSheet.create({ fontWeight: 'bold', textAlign: 'center', }, + shareContainer: { + alignItems: 'flex-end', + flexDirection: 'row', + marginTop: 10, + //backgroundColor: colors.darkGrey, + }, + share: { + textAlign: 'right', + color: colors.midRed, + fontSize: 16, + marginHorizontal: 3, + }, }); From 37717df983bdd36d8fb7257b696b010c3961d0de Mon Sep 17 00:00:00 2001 From: Melissa Liu Date: Wed, 3 Apr 2024 15:18:49 -0700 Subject: [PATCH 2/4] sharing worksl link is broken --- .../AllCases/CaseScreen/[caseUid].tsx | 47 ++++++++----------- .../AllCases/CaseScreen/styles.ts | 5 +- 2 files changed, 23 insertions(+), 29 deletions(-) diff --git a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx index 91de3a4d..bf84e7a2 100644 --- a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx +++ b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx @@ -1,15 +1,8 @@ -<<<<<<< HEAD -import { router, useLocalSearchParams, useNavigation } from 'expo-router'; -import React, { useEffect, useState } from 'react'; -import { View, ScrollView, Text, TouchableOpacity } from 'react-native'; -======= import * as Linking from 'expo-linking'; import { useLocalSearchParams, useNavigation } from 'expo-router'; import * as Sharing from 'expo-sharing'; import React, { useEffect, useState } from 'react'; -import { View, ScrollView, Text } from 'react-native'; -import { TouchableOpacity } from 'react-native-gesture-handler'; ->>>>>>> 38811db (broken deep link for sharing) +import { View, ScrollView, Text, TouchableOpacity, Share } from 'react-native'; import styles from './styles'; import Icon from '../../../../../assets/shareicon.svg'; @@ -20,6 +13,7 @@ import EligibilityCard from '../../../../Components/EligibilityCard/EligibilityC import FormsCard from '../../../../Components/FormsCard/FormsCard'; import { getCaseStatus, getCaseById } from '../../../../supabase/queries/cases'; import { Case, Eligibility } from '../../../../types/types'; +import Deep from '../../AllCases'; function CaseScreen() { const { caseUid } = useLocalSearchParams<{ caseUid: string }>(); @@ -27,26 +21,33 @@ function CaseScreen() { const [caseData, setCaseData] = useState(); const [isLoading, setIsLoading] = useState(true); const navigation = useNavigation(); - const url = Linking.useURL(); - const urle = Linking.getInitialURL(); const getCase = async (uid: string) => { const caseData = await getCaseById(uid); setCaseData(caseData); setIsLoading(false); }; - const shareLink = async () => { - if (caseData) { + + const onShare = async () => { + const addCaseUrl = Linking.createURL('addCase/', { + queryParams: { caseUid }, + }); + console.log(addCaseUrl); + //Linking.openURL(addCaseUrl); + + const test = await Linking.getInitialURL(); + if (test) { try { - console.log(url); - await Sharing.shareAsync( - 'exp://192.168.4.84:8082/--/AllCases/addCase/?caseUID=09a59710-706c-11ee-b5ff-87a607d233fc', - ); + await Share.share({ + message: 'ADD CASE', + url: `${addCaseUrl}/`, + }); } catch (error) { - console.error('Failed sharing:', error); + console.log(error); } } }; + const getStatus = async (uid: string) => { const caseStatus = await getCaseStatus(uid); setStatus(caseStatus); @@ -76,22 +77,14 @@ function CaseScreen() { contentContainerStyle={styles.innerScroll} showsVerticalScrollIndicator={false} > - + Share - + {caseData.title} - { - router.push({ pathname: `AllCases/Updates/${caseUid}` }); - }} - > - View Updates - - {status === Eligibility.ELIGIBLE && ( )} diff --git a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts index e7730bda..e96ae664 100644 --- a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts +++ b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts @@ -38,13 +38,14 @@ export default StyleSheet.create({ textAlign: 'center', }, shareContainer: { - alignItems: 'flex-end', + justifyContent: 'flex-end', flexDirection: 'row', marginTop: 10, + marginLeft: 280, //backgroundColor: colors.darkGrey, }, share: { - textAlign: 'right', + alignText: 'right', color: colors.midRed, fontSize: 16, marginHorizontal: 3, From 788f70abb8385b25a75be0c2baac030b31126ff5 Mon Sep 17 00:00:00 2001 From: Melissa Liu Date: Thu, 4 Apr 2024 00:18:27 -0700 Subject: [PATCH 3/4] fixed link --- .../AllCases/CaseScreen/[caseUid].tsx | 26 +++++++------------ .../AllCases/CaseScreen/styles.ts | 2 +- 2 files changed, 11 insertions(+), 17 deletions(-) diff --git a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx index bf84e7a2..956931e6 100644 --- a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx +++ b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx @@ -1,6 +1,6 @@ import * as Linking from 'expo-linking'; import { useLocalSearchParams, useNavigation } from 'expo-router'; -import * as Sharing from 'expo-sharing'; +//import * as Sharing from 'expo-sharing'; import React, { useEffect, useState } from 'react'; import { View, ScrollView, Text, TouchableOpacity, Share } from 'react-native'; @@ -13,7 +13,6 @@ import EligibilityCard from '../../../../Components/EligibilityCard/EligibilityC import FormsCard from '../../../../Components/FormsCard/FormsCard'; import { getCaseStatus, getCaseById } from '../../../../supabase/queries/cases'; import { Case, Eligibility } from '../../../../types/types'; -import Deep from '../../AllCases'; function CaseScreen() { const { caseUid } = useLocalSearchParams<{ caseUid: string }>(); @@ -29,22 +28,17 @@ function CaseScreen() { }; const onShare = async () => { - const addCaseUrl = Linking.createURL('addCase/', { + const addCaseUrl = Linking.createURL('?event=addCase&', { queryParams: { caseUid }, }); console.log(addCaseUrl); - //Linking.openURL(addCaseUrl); - - const test = await Linking.getInitialURL(); - if (test) { - try { - await Share.share({ - message: 'ADD CASE', - url: `${addCaseUrl}/`, - }); - } catch (error) { - console.log(error); - } + try { + await Share.share({ + //message: 'ADD CASE', + url: `${addCaseUrl}/`, + }); + } catch (error) { + console.log(error); } }; @@ -79,7 +73,7 @@ function CaseScreen() { > Share - + {caseData.title} diff --git a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts index e96ae664..50a78ad5 100644 --- a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts +++ b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts @@ -45,7 +45,7 @@ export default StyleSheet.create({ //backgroundColor: colors.darkGrey, }, share: { - alignText: 'right', + // alignText: 'right', color: colors.midRed, fontSize: 16, marginHorizontal: 3, From 204e14cf5e676b4f68810edf9841c58b45fc3207 Mon Sep 17 00:00:00 2001 From: Melissa Liu Date: Mon, 8 Apr 2024 01:44:57 -0700 Subject: [PATCH 4/4] fixed styling, added image to share --- package.json | 3 +-- .../AllCases/CaseScreen/[caseUid].tsx | 10 +++++----- .../AllCases/CaseScreen/styles.ts | 1 + 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/package.json b/package.json index 0939b316..7ea921b4 100644 --- a/package.json +++ b/package.json @@ -53,8 +53,7 @@ "uri-scheme": "^1.2.0", "yargs": "^16.2.0", "yargs-parser": "^20.2.9", - "zod": "^3.22.4", - "expo-sharing": "~11.5.0" + "zod": "^3.22.4" }, "devDependencies": { "@babel/core": "^7.20.0", diff --git a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx index 956931e6..2d5a2f97 100644 --- a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx +++ b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/[caseUid].tsx @@ -28,14 +28,14 @@ function CaseScreen() { }; const onShare = async () => { - const addCaseUrl = Linking.createURL('?event=addCase&', { - queryParams: { caseUid }, + const addCaseUrl = Linking.createURL('', { + queryParams: { event: 'addCase', caseUid }, }); - console.log(addCaseUrl); try { await Share.share({ - //message: 'ADD CASE', - url: `${addCaseUrl}/`, + message: `${addCaseUrl}/`, + url: 'https://ibb.co/zQjtwGC', + // url: '', }); } catch (error) { console.log(error); diff --git a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts index 50a78ad5..435eeb6d 100644 --- a/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts +++ b/src/app/(BottomTabNavigation)/AllCases/CaseScreen/styles.ts @@ -39,6 +39,7 @@ export default StyleSheet.create({ }, shareContainer: { justifyContent: 'flex-end', + width: '22%', flexDirection: 'row', marginTop: 10, marginLeft: 280,