1. Application
  2. App Protocols and Deeplinks


App Protocols and Deeplinks

App protocols provide an easy way for you to launch your application from inside another application.

You've probably seen app protocols before. Perhaps you've seen them with iTunes (itmss://) or Spotify (spotify://) or Slack (slack://).

One common use-cases is to launch a desktop application from a website.

        <a href="spotify://">Open Spotify App</a>


We can also add more information to go to a specific part of a desktop application. We call this a ‘deeplink’.

        <a href="spotify://track:1mIBixqmt8vbDNXiKqLTGJ">
  Play “Broken Together” by “Mani Obeya” on Spotify


Enabling App Protocols

You can enable App Protocols for your app by selecting the “Support App Protocol (deeplink)” option in the “App Options” box. You can then type the App Protocol that you wish to use. In the example below, we have chosen clickup:// as the app protocol.

Editing the app protocol of your desktop app

Using App Protocols

Let's use the app protocol of clickup:// in our examples below.

Simple App Protocol


This will open ClickUp app at the default location. If the app is already opened then the window will gain focus.


Deeplinks allow you to specify a path to navigate to in your app. This will open ClickUp app at the foo/bar path.


So, if you wanted to link from a website to a deeplink within ClickUp app then you could do something like this:

        <a href="clickup://foo/bar">Open FooBar on ClickUp app</a>


Manually handling App Protocols

You may wish to opt-out of the default behaviour for App Protocols. For example, you may wish to pass data to your app through a URL but not load a new page.

Let's say that we want to handle the URL spotify://pause. When this link is opened we want to pause the music but we don't want to change the current URL of our app. We can prevent navigation by calling preventDefault() on our event object. Here's an example:

        window.todesktop.on('open-protocol-url', (_, event) => {
   * If URL contains 'pause' then prevent navigation
   * and pause the audio player.
  if (event.url.includes('pause')) {



AppImage Support

Your users should use AppImageLauncher to install and integrate your app into their desktop environment. Otherwise this feature may not work.