Skip to content

Latest commit

 

History

History
92 lines (50 loc) · 2.41 KB

readme.md

File metadata and controls

92 lines (50 loc) · 2.41 KB

mac-open-with

Open a file with an installed app on macOS

Requires macOS 10.12 or later. macOS 10.13 or earlier needs to download the Swift runtime support libraries.

Install

$ npm install mac-open-with

Usage

const openWith = require('mac-open-with');

const apps = openWith.getAppsThatOpenFile.sync('/some/file.mov');

// or

const apps = openWith.getAppsThatOpenType.sync('com.apple.quicktime-movie');

// or

const apps = openWith.getAppsThatOpenExtension.sync('mov');


// [
//     { url: 'file:///Applications/iTunes.app/', isDefault: true, icon: '...' },
//     { url: 'file:///Applications/Gifski.app/', isDefault: false, icon: '...' },
//     { url: 'file:///Applications/Kap.app/', isDefault: false, icon: '...' },
//     { url: 'file:///Applications/QuickTime%20Player.app/', isDefault: false, icon: '...' }
// ]

openWith.open('/some/file.mov', apps[0]);

// true

API

openWith

.getAppsThatOpenFile(filePath: string): Promise<App[]>

Get a list of app URLs that can open the file type of the given file.

.getAppsThatOpenFile.sync(filePath: string): App[]

Synchronous version of the method above.

.getAppsThatOpenType(fileType: string): Promise<App[]>

Get a list of app URLs that can open the given file type.

fileType has to be a Uniform Type Identifier

.getAppsThatOpenType.sync(fileType: string): App[]

Synchronous version of the method above.

.getAppsThatOpenExtension(extension: string): Promise<App[]>

Get a list of app URLs that can open the given file extension.

.getAppsThatOpenExtension.sync(extension: string): App[]

Synchronous version of the method above.

.open(filePath: string, appUrl: string): boolean

Open the given file with the given app URL. appUrl needs to be one of the URLs returned from getAppsThatOpenFile or getAppsThatOpenType.

Returns true if the file was successfully opened, false otherwise.

App

Object type returned by the following three methods.

app.url: string

The URL of the app.

app.isDefault: boolean

Whether this app is the default app for that file/content type/extension.

app.icon: string

The icon of the app in a base64 encoded Data URL.