GitXplorerGitXplorer
j

broken-assistant

public
0 stars
0 forks
0 issues

Commits

List of commits on branch main.
Unverified
c7e14ed94969f44876623627db646b0aed272389

Version

jjedrichards committed 4 years ago
Unverified
399a3e0fccd8de3244051c42b786f1356dc82bb8

Update

jjedrichards committed 4 years ago
Unverified
6fbf71a7fe10a3e6b537ceea06a40d8beeec7c4d

add homepage value

jjedrichards committed 5 years ago
Unverified
205b44ecc51f3469042e3319cea0c105bf946a36

implement

jjedrichards committed 5 years ago
Unverified
9147cfe4d7a7422170cb60befc6461c6d257c6f2

Initial commit

jjedrichards committed 5 years ago

README

The README file for this repository.

sketch-assistant-template

💁‍♀️ This repository contains a starter project for developing a new Assistant.

👉 Click here to generate a new project using this repository as a template

Skills needed

  • JavaScript and TypeScript
  • npm
  • Git

Tools

These tools are required to work on the Assistant locally.

  • Node 12
  • Yarn
  • Visual Studio Code (recommended)

Getting started

  1. Generate a new repository using this template.
  2. Check out your new repository locally.
  3. Install the dependencies with yarn install.
  4. Open the folder in Visual Studio Code.
  5. Find and replace all instances of the sketch-assistant-template string with the name of your new Assistant project. Name your Assistant as you would an npm package, i.e. all lower case, no spaces.
  6. Update the Assistant metadata under the sketch-assistant field in package.json to reflect your project.
  7. Update the homepage field in package.json to point to your Assistant's homepage - this is likely just the GitHub repository page for now. Sketch will direct users to this page for rule documentation, so make sure to explain rule uses and configuration on this page.
  8. Review whether the MIT license applied to the repository is right for your purposes, and if necessary change or remove it.
  9. You are now ready to implement your Assistant.

⚠️ How to write rules, configure Assistants, extend from existing Assistants and many other activities are out of scope of this README. For more information on these topics consult the Assistant Developer Documentation.

Testing the Assistant

The Sketch Mac app isn't required to test the Assistant and run the Jest tests. So a TDD approach using Sketch files as fixtures represents the fastest route to running your Assistant and checking that it's working as expected.

The tests can be run in watch mode for live feedback as you work.

yarn test --watch

Testing using Github Actions

If you want to run the tests automatically whenever a pull request is opened then enable the included "Test Pull Requests" Github Action.

  1. Ensure Github Actions are enabled for your repository.
  2. Rename .github/workflows/test-pull-requests.yml.sample to .github/workflows/test-pull-requests.yml.
  3. Open a pull request, and the test status should be reported.

Building a local development Assistant

The next quickest way to get the Assistant running is to build it locally and add it directly to a Sketch document.

  1. Run yarn package-tarball.
  2. Note that a *.tgz tarball has been built to the repository root.
  3. Use the Install from disk option in Sketch's Assistants menu to add the freshly built Assistant to a document.
  4. Sketch will check the disk location for updates to the tarball, so you can continue to re-build the Assistant to the same location and see live updates in Sketch

⚠️ Assistants must be published to be used across multiple devices or within a team. Sketch documents with local Assistants added to them are not portable because the Assistant is referenced using a file path.

Publish the Assistant

In order for others to use your Assistant via the Install from URL option in Sketch its *.tgz tarball package needs to be hosted publically on the web.

Following is a guide describing how to publish an Assistant to npm.

  1. Review the npm documentation to familiarize yourself about publishing packages, but read on for a quick guide.
  2. Ensure you have an npm account and are logged-in to npm on the command line via npm login.
  3. Update your Assistant code as needed, implement any rules you want to and ensure any tests are passing.
  4. Ensure the name field in package.json has been set to a valid, unique npm package name.
  5. Ensure the version field in package.json is updated to reflect the version you want to publish.
  6. Run yarn build to prepare the Assistant for publishing.
  7. Run npm publish.
  8. After publishing is complete run npm info <your-package-name>, and take note of the distribution tarball url ending *.tgz. Copy and pasting this into the Install from URL dialogue box in Sketch will result in a shareable Sketch document with your Assistant added and ready-to-go.