Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/JXA-userland/JXA
JavaScript for Automation(JXA) packages for TypeScript/Node.js.
https://github.com/JXA-userland/JXA
applescript autocomplete javascript jxa typescript
Last synced: 3 months ago
JSON representation
JavaScript for Automation(JXA) packages for TypeScript/Node.js.
- Host: GitHub
- URL: https://github.com/JXA-userland/JXA
- Owner: JXA-userland
- License: mit
- Created: 2018-04-14T13:01:37.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-02-28T03:26:33.000Z (11 months ago)
- Last Synced: 2024-10-01T22:53:28.531Z (4 months ago)
- Topics: applescript, autocomplete, javascript, jxa, typescript
- Language: TypeScript
- Homepage:
- Size: 3.99 MB
- Stars: 429
- Watchers: 9
- Forks: 22
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-jxa - JXA - JavaScript for Automation(JXA) packages (including TS types for modules and set of satellite packages to build/run), example is included (Node.js helpers)
- awesome-jxa - JXA - JavaScript for Automation(JXA) packages (including TS types for modules and set of satellite packages to build/run), example is included (Node.js helpers)
README
# JXA [![Actions Status: test](https://github.com/JXA-userland/JXA/workflows/test/badge.svg)](https://github.com/JXA-userland/JXA/actions?query=workflow%3A"test")
JavaScript for Automation(JXA) packages.
[![auto complete example](./packages/@jxa/global-type/docs/example.gif)](./packages/@jxa/global-type)
## Features
- Integration JXA with [TypeScript](https://www.typescriptlang.org/index.html)
- Run JXA from [Node.js](https://nodejs.org/)
- See [@jxa/run](./packages/@jxa/run) and [@jxa/repl](./packages/@jxa/repl)
- Support Auto complete for editor/IDE via [TypeScript](https://www.typescriptlang.org/index.html) definition file(`.d.ts`)
- See [@jxa/types](./packages/@jxa/types) and [@jxa/global-type](./packages/@jxa/global-type)## Packages
- [@jxa/run](./packages/@jxa/run)
- [@jxa/repl](./packages/@jxa/repl)
- [@jxa/types](./packages/@jxa/types)
- [@jxa/global-type](./packages/@jxa/global-type)
- [@jxa/sdef-to-dts](./packages/@jxa/sdef-to-dts)## Example
If you want to improve your editor for JXA, use [@jxa/global-type](./packages/@jxa/global-type).
You can just import `@jxa/global-type` and you can introduce typing and auto complete for JXA.:memo: Your editor should support TypeScript. For more details, see [TypeScript Editor Support](https://github.com/Microsoft/TypeScript/wiki/TypeScript-Editor-Support)
```ts
// Your .ts file require @jxa/global-type
import "@jxa/global-type";// your JXA application
const userName = Application("System Events").currentUser().name();
```If you want to run JXA from Node.js, use [@jxa/run](./packages/@jxa/run).
```ts
import "@jxa/global-type";
import { run } from "@jxa/run";
export const currentUserName = () => {
// This callback function is run as JXA
return run(() => {
const sys = Application("System Events");
return sys.currentUser().name();
});
};// Main code is Node.js
export const example = async () => {
const userName = await currentUserName();
return `User: ${userName}`;
};
```For more details, see [example/](./example/).
## Contributing
Issue and PR is always welcome!
For more details, see [CONTRIBUTING guide](./CONTRIBUTING.md).