Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/sketch-hq/sketchapi

The JavaScript plugin library embedded in Sketch
https://github.com/sketch-hq/sketchapi

sketch sketch-plugin

Last synced: 5 days ago
JSON representation

The JavaScript plugin library embedded in Sketch

Awesome Lists containing this project

README

        

# Sketch JavaScript API

JavaScript API for [Sketch](https://sketch.com) for writing scripts and creating plugins.

Sketch JavaScript API Architecture

## Usage

For guides, concepts and regular updates on what's new in the latest version of Sketch, see the [Plugin Developer Documentation](https://developer.sketch.com/plugins/).

- ℹ️ [**API Reference**](https://developer.sketch.com/reference/api/)
- 🐛 [**Issues**](https://github.com/sketch-hq/SketchAPI/issue) for bug reports and API feature requests

### Example

Try the following script within the _Plugins_ › _Run Script…_ panel.

```js
// The Sketch JavaScript API is bundled with the Sketch Mac app
// and must be imported before it can be used.
const sketch = require('sketch')
const { Group, Shape, Rectangle } = sketch

// Get the current Document and Page
const doc = sketch.getSelectedDocument()
const page = doc.selectedPage

// Create and select a new Group within the current Page
var group = new Group({
parent: page,
frame: new Rectangle(0, 0, 100, 100),
name: 'Test',
selected: true,
})

// Add a new Rectangle Shape Layer to newly created Group
var rect = new Shape({
parent: group,
frame: new Rectangle(10, 10, 80, 80),
})

// Get and log the current selection
var sel = doc.selectedLayers
console.log(sel.isEmpty)

sel.forEach(function (elem) {
console.log(elem.name)
})
```

## Development

### Prerequisits

- Have [Node](https://nodejs.org) installed
- [Visual Studio Code](https://code.visualstudio.com) (recommended)

### Overview

The Sketch API is written in JavaScript/CocoaScript and gets bundled as part of the build process using webpack.

In addition to the API, this project also defines core modules to be included in Sketch as part of the official release process. Both are written to the `build` output folder when the build script is run:

```sh
./build.sh
```

#### Scripts

The following npm scripts are available for development of the API.

| Script | Description |
| ----------------------------- | --------------------------------------- |
| `npm run build` | Build SketchAPI into the `build` folder |
| `npm run test:build` | Build integration test plugin |
| `npm run lint` | Lint the source code |
| `npm run format-check` | Check the format with Prettier |
| `npm run api-location:write` | Tell Sketch to use your local SketchAPI |
| `npm run api-location:delete` | Undo `npm run api-location:write` |

### Build and run

Follow the steps below to use a local copy of the API with your installation of Sketch.

Note, any plugins you have installed or code you invoke in Sketch's _Plugins_ › _Run Script…_ sheet will use your local copy of the API.

1. Checkout this repository.
1. Configure Sketch to use your local version of `SketchAPI` instead of the built-in.
```sh
npm run api-location:write
```
1. Ensure you've installed the dependencies with npm, and then build SketchAPI.
```sh
npm install
npm run build
```
1. Start Sketch and your changes will be picked up.

> ⚠️ Sketch must be restarted for API changes to take effect after running `npm run build`.

> ⚠️ You must remove the custom location configuration to make your installation of Sketch use the version of the API included with the app.
>
> ```
> npm run api-location:delete
>
> ```

### Testing

The SketchAPI builds on top of macOS and internal Sketch APIs via CocoaScript. To ensure the API works for a specific Sketch version or build, this repository includes `*.test.js` files containing integration tests.

These integration tests are compiled into a single test plugin using Webpack and can run by the `run_tests.py` Python script, or from the Sketch application menu.

**Build test plugin**

To build the plugin separately, e.g. to install and run it manually, run the following command.

```sh
npm install # if you haven't installed dependencies already
npm run test:build --identifier=IDENTIFIER
```

To build the plugin including only one spec file, e.g. run tests from one spec only, run this command:

```sh
npm run test:build --identifier=IDENTIFIER
```

Use different `IDENTIFIER` values if you are testing different versions of Sketch or want to run integration tests concurrently on the same machine.

> **Note:** The Sketch JavaScript API does not need to be rebuilt. The integration tests use the API bundled within Sketch or the custom API location specified in the user defaults.

**Run test plugin**

To run the integration test plugin from the command-line, you must provide the path to the plugin and a file path to be used by the plugin to write the test results and can be watched by the Python script for changes.

```sh
python run_tests.py -p /path/to/SketchIntegrationTests-$UUID.sketchplugin -o FILE_PATH [-s SKETCH_PATH] [-t TIMEOUT]
```

Optionally, specify the Sketch installation to be used for the tests. If none is provided the default installation path `/Applications/Sketch.app` is going to be used.

> **Note:** Tests can be run concurrently but only for different Sketch installations. Only one test run per Sketch installation location is supported because the Sketch process is terminated at the end of the test run based on its path on disk.

Tests can also be run manually from within Sketch:

1. Doubleclick to install the `SketchIntegrationTests-$UUID.sketchplugin`.
2. Open Sketch version to test.
3. Select _Test Sketch API_ from the application menu in _Plugins_ › _Sketch Integration Tests (`$UUID`)_

The test results are written to the specified output file or, if no dedicated path is provided, to a temporary file. Use macOS' _Console.app_ to view Sketch's logs containing information on the file location and test progress in general.

## Acknowledgements

We would like to thank:

- [Logan Collins](https://github.com/logancollins) for [Mocha](https://github.com/logancollins/Mocha), which powers Cocoascript.
- [Gus Mueller](https://github.com/ccgus) for [Cocoascript](https://github.com/ccgus/CocoaScript), which powers our plugin engine.
- [Andrey Shakhmin](https://github.com/turbobabr), for his inspiration during the [Hamburg Hackathon](http://designtoolshackday.com), where he showed us a clean way to use node modules inside Sketch.
- The Sketch plugin community everywhere, for such awesome work.