UNPKG

@replace5/electron-localshortcut

Version:

register/unregister a keyboard shortcut locally to a BrowserWindow instance, without using a Menu

126 lines (76 loc) 4.58 kB
# electron-localshortcut A module to register/unregister a keyboard shortcut locally to a BrowserWindow instance, without using a Menu. This is built to circumvent [this Electron issue](https://github.com/atom/electron/issues/1334). **Forked from [parro-it/electron-localshortcut](https://github.com/parro-it/electron-localshortcut) to add support for windows' child webviews.** [![Travis Build Status](https://img.shields.io/travis/parro-it/electron-localshortcut/master.svg)](http://travis-ci.org/parro-it/electron-localshortcut) [![NPM module](https://img.shields.io/npm/v/electron-localshortcut.svg)](https://npmjs.org/package/electron-localshortcut) [![NPM downloads](https://img.shields.io/npm/dt/electron-localshortcut.svg)](https://npmjs.org/package/electron-localshortcut) [![Greenkeeper badge](https://badges.greenkeeper.io/parro-it/electron-localshortcut.svg)](https://greenkeeper.io/) # Installation ```bash npm install --save electron-localshortcut ``` # Usage ```javascript const electronLocalshortcut = require('electron-localshortcut'); const BrowserWindow = require('electron').BrowserWindow; const win = new BrowserWindow(); win.loadUrl('https://github.com'); win.show(); electronLocalshortcut.register(win, 'Ctrl+A', () => { console.log('You pressed ctrl & A'); }); electronLocalshortcut.register(win, 'Ctrl+B', () => { console.log('You pressed ctrl & B'); }); electronLocalshortcut.register(win, ['Ctrl+R', 'F5'], () => { console.log('You pressed ctrl & R or F5'); }); electronLocalshortcut.unregister(win, 'Ctrl+A'); electronLocalshortcut.unregisterAll(win); ``` # App shortcuts. They differ from native [global-shortcuts](https://github.com/atom/electron/blob/master/docs/api/global-shortcut.md) because they doesn't interfere with other apps running on the same machine. # Shortcut behaviour. If you register a shortcut for a window, this module unregister the shortcut when the window is hidden, unfocused or minimized, and automatically restore them when the window is restored and focused again. If you register an app shortcut, this module unregister the shortcut when all windows of your app are hidden, unfocused or minimized, and automatically restore it when any window of your app is restored and focused again. # API <!-- Generated by documentation.js. Update this documentation by updating the source code. --> ## register Registers the shortcut `accelerator`on the BrowserWindow instance. **Parameters** - `win` **BrowserWindow** BrowserWindow instance to register. - `accelerator` **[String](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** the shortcut to register - `callback` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)** This function is called when the shortcut is pressed and the window is focused and not minimized. Returns **[Undefined](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined)** ## unregister Unregisters the shortcut of `accelerator` registered on the BrowserWindow instance. **Parameters** - `win` **BrowserWindow** BrowserWindow instance to unregister. - `accelerator` **[String](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** the shortcut to unregister Returns **[Undefined](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined)** ## disableAll Disable all of the shortcuts registered on the BrowserWindow instance. Registered shortcuts no more works on the `window` instance, but the module keep a reference on them. You can reactivate them later by calling `enableAll` method on the same window instance. **Parameters** - `win` **BrowserWindow** BrowserWindow instance Returns **[Undefined](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined)** ## enableAll Enable all of the shortcuts registered on the BrowserWindow instance that you had previously disabled calling `disableAll` method. **Parameters** - `win` **BrowserWindow** BrowserWindow instance Returns **[Undefined](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined)** ## unregisterAll Unregisters all of the shortcuts registered on any focused BrowserWindow instance. **Parameters** - `win` **BrowserWindow** BrowserWindow instance Returns **[Undefined](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined)** # License The MIT License (MIT) Copyright (c) 2017 Andrea Parodi