Launching app OR app store from Safari?
Asked Answered
A

4

49

I already know how to launch an app from safari, but is it possible to check if the app is installed before launching? I'm thinking to launch the app store if the app isn't currently installed on the iPhone.

Adriell answered 6/8, 2011 at 3:14 Comment(1)
While working on my last app, I built a linking tool called branch.io that gives you a hosted link that does this really well - for Android or iOS.Drum
P
88

It's not possible to check if app is installed from a web page. You could do it inside an other app by checking if your url scheme can be opened using UIApplication's -canOpenURL: method, but there is no javascript equivalent to this.

However, you can use the following workaround:

<script language="javascript">
    function open_appstore() {
        window.location='http://itunes.com/';
    }

    function try_to_open_app() {
        setTimeout('open_appstore()', 300);
    }
</script>

<a onClick="javascript:try_to_open_app();" href="yourappurl:">App name</a>

This code will set a timeout on the link that will call the open_appstore function if this timeout ends. Since your link is pointed at the app's custom url, Safari will try to open that link and if it can, it will open the app and stop the timer, so AppStore link will not be opened.

If the app link can't be opened, when timer runs out it will display an error popup saying it can't open the page (can't get rid of that), but it will immediately go to AppStore and dismiss that error.


iOS 9 adds a really nice feature that lets your app open a http/s url: Universal Links


In iOS 10 there is a popup saying "Open in [App Name]" when you tap the link and the app is installed. If the user does not tap on "Open" in the given timeout, this solution will use the fallback. As 300ms is too short to tap anything, this solution always fails on iOS 10.

Prop answered 6/8, 2011 at 8:24 Comment(11)
I tried this. However, if the "yourappurl:" successfully launches your app, then when the user returns to Safari the timeout will eventually fire anyway and send the user to itunes.Seaddon
@Seaddon In what version of iOS and on what device is this happening?Prop
Have some downsides, however right now, is the best solution I found... +1Ragtime
@Seaddon You can clear the time out. So when he comes back nothing happensTart
This still shows the warning saying "Cannot Open Page". Is there any way to prevent this from happening. Also, I would like to remain on the same page rather than redirecting if the app isn't installed.Remitter
@Filip Radelic. How to use this code in Objective c. I mean when i am sending mail using MailControllerArmenia
@ReddyBasha, in iOS MFMailComposeViewController has a method canSendMail. And you should check it like this, if([MFMailComposeViewController canSendMail]) {...}Scout
Universal Links solution is what I was looking for!Perception
As @Remitter said, there'll be a popup confirm saying "Cannot Open Page", at least there'll be in iOS 9. Isn't it happen in iOS 8 or earlier versions? Any solutions to prevent that?Marbles
in iOS 10 there is a popup saying "Open in [App Name]" when the app is installed. If the user does not tap on "open" in the given timeout, this solution will use the fallback. As 300ms is too short to tap anything, this solution always fails. In my opinion, the answer should mention this.Adventuress
@Adventuress you are right, feel free to edit the answer :)Prop
K
11

This worked for me with a similar situation: wherein I wanted to open gmaps app if it was supported - otherwise go to gmap site directly.

function mapLink(addy) {     
  addy = encodeURIComponent(addy);

  var fallback = 'http://maps.google.com/?q=' + addy
  , link = 'comgooglemaps://?q=' + addy;

  try {
    document.location = link;
  } catch(err) {
    document.location = fallback;
  }
}

Seems to work pretty well for my use case.

Update: If you want to do a new window on fallback, this still allowed the ios error message to pop up. To get around it try this.

  try {
    document.location = link;
  } catch(err) {
    window.location.reload(true);
    window.open(fallback, '_blank');
  }
Knapweed answered 27/3, 2014 at 15:36 Comment(4)
Did you mean that you are doing this? try {document.location=link;} catch(x) {document.location=fallback;}Zwolle
Just a small update, your code does still work in Mac OS, awesome.. tyDerby
The code will work on any OS which supports system-wide URI protocol handlers. Windows, OS X, iOS, Android, Linux.Haimes
This code won't work for iOS 9. It won't ever hit the catch block because the link url will fail silently if the app isn't installed.Ypsilanti
N
10

The Solution from Apple:

From Apple Documentation

https://developer.apple.com/library/ios/documentation/AppleApplications/Reference/SafariWebContent/PromotingAppswithAppBanners/PromotingAppswithAppBanners.html

If the app is already installed on a user's device, the banner intelligently changes its action, and tapping the banner will simply open the app. If the user doesn’t have your app on his device, tapping on the banner will take him to the app’s entry in the App Store. When he returns to your website, a progress bar appears in the banner, indicating how much longer the download will take to complete. When the app finishes downloading, the View button changes to an Open button, and tapping the banner will open the app while preserving the user’s context from your website.

Smart App Banners automatically determine whether the app is supported on the user’s device. If the device loading the banner does not support your app, or if your app is not available in the user's location, the banner will not display.

To add a Smart App Banner to our webpage, include the following meta tag in the head of each page where you’d like the banner to appear:

NOTE: We can also pass the app-argument: like myName,etc.,

Check that Providing Navigational Context to Your App Header in this Page

Updates:

1. Once you have closed the banner that showing up, then that will not be displayed again even though you had that meta tag in our html.

2. To reset that launch the settings App then navigate to General>Resent>Reset all settings

Nosography answered 26/3, 2014 at 6:48 Comment(1)
That's cool, but by example: I need do the same thing that Smart Banners does, with the difference that I need n numbers of links with different deep links. I understand that I can add some more data to Smart Banner but the link of Smart Banner is unique for page. If you have any idea, its graceful received!Comedietta
H
1

You can simply read the return value from the method -(BOOL)openURL:(NSURL)url*, if it's NO, it means that the target application isn't installed. Following code snipped gives an example using the navigon url scheme:

NSString *stringURL = @"navigon://coordinate/NaviCard/19.084443/47.573305";
NSURL *url = [NSURL URLWithString:stringURL];
if([[UIApplication sharedApplication] openURL:url]) {
    NSLog(@"Well done!");
} else {
    stringURL = @"https://itunes.apple.com/it/app/id320279293?mt=8";
    url = [NSURL URLWithString:stringURL];
    [[UIApplication sharedApplication] openURL:url];
}

Thanks to zszen for the correction.

Honour answered 9/1, 2014 at 15:32 Comment(1)
itunes.apple.com/it/app/id320279293?mt=8 Removed app name it can work well.Physiologist

© 2022 - 2024 — McMap. All rights reserved.