Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tootallnate/node-applescript
A Node.js module to easily execute arbitrary AppleScript code on Mac OS X.
https://github.com/tootallnate/node-applescript
Last synced: 4 days ago
JSON representation
A Node.js module to easily execute arbitrary AppleScript code on Mac OS X.
- Host: GitHub
- URL: https://github.com/tootallnate/node-applescript
- Owner: TooTallNate
- License: mit
- Created: 2010-08-05T01:08:24.000Z (over 14 years ago)
- Default Branch: master
- Last Pushed: 2020-06-01T21:05:59.000Z (over 4 years ago)
- Last Synced: 2024-12-21T13:05:47.135Z (5 days ago)
- Language: JavaScript
- Homepage:
- Size: 23.4 KB
- Stars: 386
- Watchers: 10
- Forks: 31
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: History.md
- License: LICENSE
Awesome Lists containing this project
README
node-applescript
================A high-level way to execute AppleScript code through Node.js, and retrieve
the result as a native JavaScript object. Underneath the hood, this
module is just a simple wrapper around the macOS `osascript` command.### Why?
AppleScripts are the only way to communicate and interact with certain
external macOS processes, for example [iTunes](http://www.itunes.com).Easy Install
------------``` bash
$ npm install applescript
```Requirements
------------* Mac (or Hackintosh) running [macOS](https://www.apple.com/macos) (tested with High Sierra)
* [Node.js](https://nodejs.org) (v0.2.0 or newer)Usage
-----The `node-applescript` module provides `execString` and `execFile` functions
to easily execute AppleScript commands and buffer the output into a calback.``` js
const applescript = require('applescript');// Very basic AppleScript command. Returns the song name of each
// currently selected track in iTunes as an 'Array' of 'String's.
const script = 'tell application "iTunes" to get name of selection';applescript.execString(script, (err, rtn) => {
if (err) {
// Something went wrong!
}
if (Array.isArray(rtn)) {
for (const songName of rtn) {
console.log(songName);
}
}
});
````execFile` works the exact same way, except you pass the _path_ of the AppleScript
(`*.applescript`) file as the first argument instead of the command itself, and you
may pass an optional Array of String arguments to send to the applescript file.Licence
-------The `node-applescript` module is licensed under the MIT license, of course!