mirror of
https://github.com/zimplexing/OrionTV.git
synced 2026-02-15 12:24:44 +08:00
25 lines
688 B
TypeScript
25 lines
688 B
TypeScript
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);
|
|
}
|
|
}}
|
|
/>
|
|
);
|
|
}
|