Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fusepilot/create-cep-extension
A near zero config approach to creating CEP extensions with Webpack and React.
https://github.com/fusepilot/create-cep-extension
adobe cep-extension extendscript react webpack
Last synced: 2 months ago
JSON representation
A near zero config approach to creating CEP extensions with Webpack and React.
- Host: GitHub
- URL: https://github.com/fusepilot/create-cep-extension
- Owner: fusepilot
- License: other
- Created: 2017-02-28T01:00:54.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2022-12-07T17:27:36.000Z (about 2 years ago)
- Last Synced: 2024-04-14T19:05:21.920Z (9 months ago)
- Topics: adobe, cep-extension, extendscript, react, webpack
- Language: JavaScript
- Size: 2.05 MB
- Stars: 87
- Watchers: 8
- Forks: 15
- Open Issues: 42
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
> Notice: I encourage you to check out [parcel-cep-plugin](https://github.com/fusepilot/parcel-plugin-cep). It's a more maintainable approach to the same problem that has a _much_ smaller codebase than a fork [create-react-app](https://github.com/facebookincubator/create-react-app) ever will. [Parcel](https://github.com/parcel-bundler/parcel) also has many [benefits](https://github.com/parcel-bundler/parcel#features) that should be enticing enough to consider switching.
# Create CEP Extension
Create CEP Extensions with no build configuration. Closely matches functionality from [Create React App](https://github.com/facebookincubator/create-react-app).
- [Getting Started](#getting-started) – How to create a new app.
- [User Guide](https://github.com/facebookincubator/create-react-app/blob/master/packages/create-cep-extension-scripts/template/README.md) – How to develop apps bootstrapped with Create React App.Create React App works on macOS, Windows, and Linux.
If something doesn’t work please [file an issue](https://github.com/facebookincubator/create-react-app/issues/new).## Quick Overview
```sh
npm install -g create-cep-extensioncreate-cep-extension my-cep-extension
cd my-cep-extension
npm start
```Then open [http://localhost:3000/](http://localhost:3000/) to see your app.
When you’re ready to deploy to production, create a minified bundle with `npm run build`.### Get Started Immediately
You **don’t** need to install or configure tools like Webpack or Babel.
They are preconfigured and hidden so that you can focus on the code.Just create a project, and you’re good to go.
## Getting Started
### Installation
Install it once globally:
```sh
npm install -g create-cep-extension
```**You’ll need to have Node >= 4 on your machine**.
**We strongly recommend to use Node >= 6 and npm >= 3 for faster installation speed and better disk usage.** You can use [nvm](https://github.com/creationix/nvm#usage) to easily switch Node versions between different projects.
**This tool doesn’t assume a Node backend**. The Node installation is only required for Create React App itself.
### Creating an App
To create a new app, run:
```sh
create-cep-extension my-cep-extension
cd my-cep-extension
```It will create a directory called `my-cep-extension` inside the current folder.
Once the installation is done, you can run some commands inside the project folder:### `npm start` or `yarn start`
Runs the app in development mode.
Open [http://localhost:3000](http://localhost:3000) to view it in the browser.The page will reload if you make edits.
You will see the build errors and lint warnings in the console.### `npm test` or `yarn test`
Runs the test watcher in an interactive mode.
By default, runs tests related to files changes since the last commit.[Read more about testing.](https://github.com/facebookincubator/create-react-app/blob/master/packages/create-cep-extension-scripts/template/README.md#running-tests)
### `npm run build` or `yarn build`
Builds the app for production to the `build` folder.
It correctly bundles React in production mode and optimizes the build for the best performance.The build is minified and the filenames include the hashes.
Your app is ready to be deployed!### `npm run archive` or `yarn archive`
Creates a ZXP archive of the `build` folder to the `archive` folder.
You can then send the ZXP archive to your users to install using a ZXP installer. For instance:
- [aescripts + aeplugins ZXP Installer](http://aescripts.com/learn/zxp-installer/)
- [ZXP Installer](http://zxpinstaller.com/)## Environment Variables
You can customize the name of the extension and multiple other variables by modifying the `.env` file.
```bash
NAME="My Extension"
BUNDLE_ID="com.mycompany.myextension"
```### Hosts
By default, the extension will target all known Adobe hosts. To target specific hosts, uncomment the `HOSTS` variable to `.env` and modify the list of the hosts you want to target.
For example, to target just Illustrator and After Effects, you would add this to your `.env` file:
```bash
HOSTS="ILST, AEFT"
```And to target specific versions:
```bash
HOSTS="ILST, IDSN@*, [email protected], AEFT@[5.0,10.0]"
```This will target all versions of Illustrator and In Design, Photoshop 6.0, and After Effects 5.0 - 10.0.
### Type
Sets the type of window. Options are `ModalDialog`, `Modeless`, `Panel` is default.
```bash
UI_TYPE=ModalDialog
```### Icon
To add a custom panel icon, add all [icon files](https://github.com/Adobe-CEP/CEP-Resources/blob/master/CEP_8.x/Documentation/CEP%208.0%20HTML%20Extension%20Cookbook.md#high-dpi-panel-icons) inside the `public` folder and set their paths inside your `.env` file:
```bash
ICON_NORMAL="./assets/icon-normal.png"
ICON_ROLLOVER="./assets/icon-rollover.png"
ICON_DARK_NORMAL="./assets/icon-dark.png"
ICON_DARK_ROLLOVER="./assets/icon-dark-rollover.png"
```### Cerificate Variables
In order to create a valid ZXP, you will need to provide the following variables replaced with the correct information inside your `.env`.
```bash
CERTIFICATE_COUNTRY="US"
CERTIFICATE_PROVINCE="CA"
CERTIFICATE_ORG="MyCompany"
CERTIFICATE_NAME="com.mycompany"
CERTIFICATE_PASSWORD="mypassword"
```## Communicating with Extendscript
There are few functions that you can import from the `cep-interface` package to ease Extendscript communication from CEP.
### `loadExtendscript(extendScriptFileName: string): Promise`
Loads and evaluates the specified file in the src/extendscript directory. Returns a promise with the result.
```javascript
import { loadExtendscript } from 'cep-interface';loadExtendscript('index.jsx');
```### `evalExtendscript(code: string): Promise`
Evaluates the specified code. Returns a Promise.
```javascript
import { evalExtendscript } from 'cep-interface';evalExtendscript('$.writeln("Hello Foo");'); // writes "Hello Foo" to the info panel
```If you return a JSON string using [json2](https://github.com/douglascrockford/JSON-js) or similar from Extendscript, you can get the parsed result.
```javascript
import { evalExtendscript } from 'cep-interface';evalExtendscript('JSON.stringifiy({foo: "bar"});')
.then(result => console.log(result)) // prints {foo: "bar"}
.catch(error => console.warn(error));
```## Other functions
There are a few other functions available in addition.
### `openURLInDefaultBrowser(url: string)`
```javascript
import { openURLInDefaultBrowser } from 'cep-interface';openURLInDefaultBrowser('www.google.com');
```Opens the url in the default browser. Will also work when viewing outside the target application in a browser.
## Contributing
We'd love to have your helping hand on `create-cep-extension`! See [CONTRIBUTING.md](CONTRIBUTING.md) for more information on what we're looking for and how to get started.
## Todo
- Improve target host configuration per [#4](https://github.com/fusepilot/create-cep-extension/pull/4).
- Create `.jsxbin`'s automatically and smoothly. Adobe has made this nearly impossible to do on macOS, so not sure if its worth the trouble. Especially since .jsxbin doesn't really deter hackers.
- Testing.