Skip to content

Node module for Electron apps that sets the default handler for a given protocol (deep links) in both development and production environments.

Notifications You must be signed in to change notification settings

mochi-cards/electron-deeplink

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

61 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MIT license ts glawson

electron-deeplink

Node module for Electron apps that sets the default handler for a given protocol (deep links) in both development and production environments.

This module was inspired due to the lack of protocol support when running non packaged apps on macOS (see app.setAsDefaultProtocolClient for explanation). This module provides full support for running and testing the given protocol in the development environment. It also provides the same protocol support for the production envronment. In other words, protocol management is completly controlled with this module.

Please Note

  • For Production: While electron-deeplink handles setting app.setAsDefaultProtocolClient, you still need to make sure setup the mac bundleId correctly for electron-builder or electron-forge.

Example App

A full working example can be found here

Installation

# If you use npm:
npm install electron-deeplink

# If you use yarn:
$ yarn add electron-deeplink

Usage

In main.js, include the electron-deeplink module and instantiate the Deeplink class towards to begining of main.js.

// main.js
const { app, BrowserWindow } = require('electron');
const { Deeplink } = require('electron-deeplink');
const isDev = require('electron-is-dev');

let mainWindow;
const protocol = isDev ? 'dev-app' : 'prod-app';
const deeplink = new Deeplink({ app, mainWindow, protocol, isDev });

Setup a watch on the deeplink 'received' event

// main.js
deeplink.on('received', (link) => {
    // do stuff here
});

API

creating an instance

const deeplink = new Deeplink([config]);

config

{
    // required
    // type: electron app
    app: [electron.app]

    // required
    // type: app.BrowserWindow
    // Reference to the apps main window
    mainWindow: [main window reference]

    // required
    // type: string
    // String representing the protocol to use. For production, this should be the same as the bundleId set in the build config.
    protocol: [protocol string]

    // optional, default: false
    // type: boolean
    // Represents the app environment
    isDev: boolean

    // optional, default: false
    // type: boolean
    // If true, outputs logging.  Uses electron-log, so files are appened/created for prod.
    debugLogging: boolean

    // optional, default: '/node_modules/electron/dist/Electron.app'
    // type: string
    // String representing the location of Electron relative to the app root.
    electronPath: [string]
}

events

// 'recieved'
// When a "deeplink" is recieved by the module, this event is emitted.

deeplink.on('received', (link) => {
    // do something here
});

Contributors

This repo uses semantic-release for versioning, which uses Angular Commit Message Conventions.

semantic-release is hooked up to CircleCI

About

Node module for Electron apps that sets the default handler for a given protocol (deep links) in both development and production environments.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 82.9%
  • Objective-C++ 13.4%
  • Python 3.7%