|
|
@ -1,96 +1,88 @@ |
|
|
|
<template> |
|
|
|
<!-- CONTENT --> |
|
|
|
<section id="Content" class="relative w-[100vw] h-[100vh]"> |
|
|
|
<div |
|
|
|
class="p-6 bg-white w-full max-w-[calc((100vh-env(safe-area-inset-top)-env(safe-area-inset-bottom))*0.4)] mx-auto" |
|
|
|
> |
|
|
|
<div class="mb-4"> |
|
|
|
<h1 class="text-xl text-center font-semibold relative mb-4"> |
|
|
|
Redirecting to Time Safari |
|
|
|
</h1> |
|
|
|
|
|
|
|
<div v-if="destinationUrl" class="space-y-4"> |
|
|
|
<!-- Platform-specific messaging --> |
|
|
|
<div class="text-center text-gray-600 mb-4"> |
|
|
|
<p v-if="isMobile"> |
|
|
|
{{ |
|
|
|
isIOS |
|
|
|
? "Opening Time Safari app on your iPhone..." |
|
|
|
: "Opening Time Safari app on your Android device..." |
|
|
|
}} |
|
|
|
</p> |
|
|
|
<p v-else>Opening Time Safari app...</p> |
|
|
|
<p class="text-sm mt-2"> |
|
|
|
<span v-if="isMobile" |
|
|
|
>If the app doesn't open automatically, use one of these |
|
|
|
options:</span |
|
|
|
> |
|
|
|
<span v-else>Choose how you'd like to open this link:</span> |
|
|
|
</p> |
|
|
|
</div> |
|
|
|
|
|
|
|
<!-- Deep Link Button --> |
|
|
|
<div class="text-center"> |
|
|
|
<a |
|
|
|
:href="deepLinkUrl || '#'" |
|
|
|
class="inline-block bg-blue-600 text-white px-6 py-3 rounded-lg font-medium hover:bg-blue-700 transition-colors" |
|
|
|
@click="handleDeepLinkClick" |
|
|
|
<section id="Content" class="p-6 pb-24 max-w-3xl mx-auto"> |
|
|
|
<div class="mb-4"> |
|
|
|
<h1 class="text-2xl text-center font-semibold relative px-7"> |
|
|
|
Redirecting to Time Safari |
|
|
|
</h1> |
|
|
|
|
|
|
|
<div v-if="destinationUrl" class="space-y-4"> |
|
|
|
<!-- Platform-specific messaging --> |
|
|
|
<div class="text-center text-gray-600 mb-4"> |
|
|
|
<p v-if="isMobile"> |
|
|
|
{{ |
|
|
|
isIOS |
|
|
|
? "Opening Time Safari app on your iPhone..." |
|
|
|
: "Opening Time Safari app on your Android device..." |
|
|
|
}} |
|
|
|
</p> |
|
|
|
<p v-else>Opening Time Safari app...</p> |
|
|
|
<p class="text-sm mt-2"> |
|
|
|
<span v-if="isMobile" |
|
|
|
>If the app doesn't open automatically, use one of these |
|
|
|
options:</span |
|
|
|
> |
|
|
|
<span v-if="isMobile">Open in Time Safari App</span> |
|
|
|
<span v-else>Try Opening in Time Safari App</span> |
|
|
|
</a> |
|
|
|
</div> |
|
|
|
|
|
|
|
<!-- Web Fallback Link --> |
|
|
|
<div class="text-center"> |
|
|
|
<a |
|
|
|
:href="webUrl || '#'" |
|
|
|
target="_blank" |
|
|
|
class="inline-block bg-gray-600 text-white px-6 py-3 rounded-lg font-medium hover:bg-gray-700 transition-colors" |
|
|
|
@click="handleWebFallbackClick" |
|
|
|
> |
|
|
|
<span v-if="isMobile">Open in Web Browser Instead</span> |
|
|
|
<span v-else>Open in Web Browser</span> |
|
|
|
</a> |
|
|
|
</div> |
|
|
|
|
|
|
|
<!-- Manual Instructions --> |
|
|
|
<div class="text-center text-sm text-gray-500 mt-4"> |
|
|
|
<p v-if="isMobile"> |
|
|
|
Or manually open: |
|
|
|
<code class="bg-gray-100 px-2 py-1 rounded">{{ |
|
|
|
deepLinkUrl |
|
|
|
}}</code> |
|
|
|
</p> |
|
|
|
<p v-else> |
|
|
|
If you have the Time Safari app installed, you can also copy this |
|
|
|
link: |
|
|
|
<code class="bg-gray-100 px-2 py-1 rounded">{{ |
|
|
|
deepLinkUrl |
|
|
|
}}</code> |
|
|
|
</p> |
|
|
|
</div> |
|
|
|
|
|
|
|
<!-- Platform info for debugging --> |
|
|
|
<div |
|
|
|
v-if="isDevelopment" |
|
|
|
class="text-center text-xs text-gray-400 mt-4" |
|
|
|
<span v-else>Choose how you'd like to open this link:</span> |
|
|
|
</p> |
|
|
|
</div> |
|
|
|
|
|
|
|
<!-- Deep Link Button --> |
|
|
|
<div class="text-center"> |
|
|
|
<a |
|
|
|
:href="deepLinkUrl || '#'" |
|
|
|
class="inline-block bg-blue-600 text-white px-6 py-3 rounded-lg font-medium hover:bg-blue-700 transition-colors" |
|
|
|
@click="handleDeepLinkClick" |
|
|
|
> |
|
|
|
<span v-if="isMobile">Open in Time Safari App</span> |
|
|
|
<span v-else>Try Opening in Time Safari App</span> |
|
|
|
</a> |
|
|
|
</div> |
|
|
|
|
|
|
|
<!-- Web Fallback Link --> |
|
|
|
<div class="text-center"> |
|
|
|
<a |
|
|
|
:href="webUrl || '#'" |
|
|
|
target="_blank" |
|
|
|
class="inline-block bg-gray-600 text-white px-6 py-3 rounded-lg font-medium hover:bg-gray-700 transition-colors" |
|
|
|
@click="handleWebFallbackClick" |
|
|
|
> |
|
|
|
<p> |
|
|
|
Platform: {{ isMobile ? (isIOS ? "iOS" : "Android") : "Desktop" }} |
|
|
|
</p> |
|
|
|
<p>User Agent: {{ userAgent.substring(0, 50) }}...</p> |
|
|
|
</div> |
|
|
|
<span v-if="isMobile">Open in Web Browser Instead</span> |
|
|
|
<span v-else>Open in Web Browser</span> |
|
|
|
</a> |
|
|
|
</div> |
|
|
|
|
|
|
|
<div v-else-if="pageError" class="text-center text-red-500 mb-4"> |
|
|
|
{{ pageError }} |
|
|
|
<!-- Manual Instructions --> |
|
|
|
<div class="text-center text-sm text-gray-500 mt-4"> |
|
|
|
<p v-if="isMobile"> |
|
|
|
Or manually open: |
|
|
|
<code class="bg-gray-100 px-2 py-1 rounded">{{ deepLinkUrl }}</code> |
|
|
|
</p> |
|
|
|
<p v-else> |
|
|
|
If you have the Time Safari app installed, you can also copy this |
|
|
|
link: |
|
|
|
<code class="bg-gray-100 px-2 py-1 rounded">{{ deepLinkUrl }}</code> |
|
|
|
</p> |
|
|
|
</div> |
|
|
|
|
|
|
|
<div v-else class="text-center text-gray-600"> |
|
|
|
<p>Processing redirect...</p> |
|
|
|
<!-- Platform info for debugging --> |
|
|
|
<div |
|
|
|
v-if="isDevelopment" |
|
|
|
class="text-center text-xs text-gray-400 mt-4" |
|
|
|
> |
|
|
|
<p> |
|
|
|
Platform: {{ isMobile ? (isIOS ? "iOS" : "Android") : "Desktop" }} |
|
|
|
</p> |
|
|
|
<p>User Agent: {{ userAgent.substring(0, 50) }}...</p> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
|
|
|
|
<div v-else-if="pageError" class="text-center text-red-500 mb-4"> |
|
|
|
{{ pageError }} |
|
|
|
</div> |
|
|
|
|
|
|
|
<div v-else class="text-center text-gray-600"> |
|
|
|
<p>Processing redirect...</p> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</section> |
|
|
|
</template> |
|
|
|