diff options
author | Santo Cariotti <santo@dcariotti.me> | 2024-08-28 15:53:21 +0200 |
---|---|---|
committer | Santo Cariotti <santo@dcariotti.me> | 2024-08-28 15:53:21 +0200 |
commit | 83643a78b73dee5610be6ad9837fb72e9b944cb7 (patch) | |
tree | 1eca6bad452656f78879c829181362f3b586d697 /components/ExternalLink.tsx |
Initial commit
Generated by create-expo-app 3.0.0.
Diffstat (limited to 'components/ExternalLink.tsx')
-rw-r--r-- | components/ExternalLink.tsx | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/components/ExternalLink.tsx b/components/ExternalLink.tsx new file mode 100644 index 0000000..8f05675 --- /dev/null +++ b/components/ExternalLink.tsx @@ -0,0 +1,24 @@ +import { Link } from 'expo-router'; +import { openBrowserAsync } from 'expo-web-browser'; +import { type ComponentProps } from 'react'; +import { Platform } from 'react-native'; + +type Props = Omit<ComponentProps<typeof Link>, 'href'> & { href: string }; + +export function ExternalLink({ href, ...rest }: Props) { + return ( + <Link + target="_blank" + {...rest} + href={href} + onPress={async (event) => { + if (Platform.OS !== 'web') { + // Prevent the default behavior of linking to the default browser on native. + event.preventDefault(); + // Open the link in an in-app browser. + await openBrowserAsync(href); + } + }} + /> + ); +} |