Skip to content

GoodBoyNinja/Your-First-CEP-Panel

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

47 Commits
 
 
 
 
 
 

Repository files navigation

A year ago I wrote a long detailed post in an attempt to help ExtendScript developers to jump ship and start developing CEP panels. While it accurately describes my experience building my first CEP panel, the advice given is wrong, dated and misleading. Please read my updated version:

First, admit that you are NOT ready

Admittedly, online information about CEP development is lacking. If you are coming from ExtendScript background (meaning, you basically just learned how to program and created a couple of script panels for After-Effects), I recommend you to keep in mind this:

  🧠 All CEP resources online, even Adobe's cookbook-so-called-"getting started"-guide,
  are written for web developers.
  Since you are not a web developer (yet), trying to follow even the most
  basic guides will be a discouraging and long struggle
  that will result in you giving up.

You are currently at a point where you are used to making scripts, which just work. CEP development is the opposite. At first, nothing works, and you have to slowly build things together piece by piece to make things work. Incredible projects such as Bolt-CEP help making the experience more pleasant, but you as an ExtendScript developer will still have to learn a lot of new things just to get things to work.

So, where do I start?

   📆 Clear up the next two weeks of your schedule. We are becoming web developers!

My advice to you is to expect building your first CEP panel in a couple of weeks from today. For the next two weeks you are going to learn the basics of modern web development instead by building a static website from start to finish.

The topics you want to cover are:

  • Visual Studio Code
  • HTML
  • CSS
  • Modern JavaScript
    • ES6 Modules (import/export) Learn how to work with multiple files
    • Package Managers (npm, yarn, etc) Learn how to install and use packages from the internet
  • Git & Github Version control for your project, as well as a place to store your code online
  • A little bit of XML (it's very similar to HTML)
  • A little bit of JSON (it's very similar to JavaScript objects)
  • Some basic Node.js terminal commands (Making a folder, moving files, etc)

Why are there so many things to learn?

This Video does a great job at explaining the complexity of modern web development.

I learned it all, what now?

Now that you have the skills, you can choose between the easy way and the hard way.

The easy way

Use one of the following:

  • ⚡ Bolt-CEP - A great tool that will help you get started with CEP development. This is probably the most production ready starting point you can find. The downside is that it relies on frameworks such as React, Vue and Svelte. It's totally doable to learn one of these (Probably Svelte would be the fastest to learn), but it's still some extra work.
  • My 🌼 CEP-Vite-Template. This is what I use for my projects, it's a simpler lo-fi solution that also uses Vite but without any frameworks. You might find it easier to start with, but it's not as production ready as Bolt-CEP.

The hard way

So you made it here... The hard way (or as I like to call it: my way because I was a stubborn idiot) is to set up everything from scratch. It is not worth it if you are just dying to start building your first CEP panel. However, if you are curious and want to learn how everything works, this is a good way to do it.

  • Symlink (MacOS / Windows / Node.JS) Place your extension file anywhere on your machine, but have a symlink to it in the CEP extensions folder, which will live update to your changes
  • ./CSXS/manifest.xml This is the file that tells CEP where to find your extension, what it's called, what it's icon is, etc. If this file is not set up correctly, your extension will show up at all in the extensions list in the app you are developing for. It must be placed inside a folder names CSXS, which must be placed in the root of your extension folder.
  • CSInterface.js A module Adobe provides to help you run ExtendScript from your CEP panel, as well as other useful functions
  • evalScript() A function provided by CSInterface.js that allows you to run ExtendScript from your CEP panel. This function is asynchronous, meaning it will not wait for the ExtendScript to finish running before continuing.
  • CEP versions Both manifest.xml and CSInterface.js are provided by Adobe. However, different versions exist online. Usually you want to work with the latest versions, but those may not be compatible with older versions of the app you are developing for.
  • Namespacing your JSX Files - To avoid clashes with other extensions and scripts, you should namespace the content of your JSX files. This is not mandatory, but it will help you keep your sanity later on.
  • Signing your extension - This is the last step before publishing your extension and is mandatory. You want to integrate it with your build process, so that it happens automatically.
  • Debugging - Adobe's way to let you use Chrome DevTools while your extension is running.

In general, after you acquired the knowledge of web development it will not be too hard to follow online guides, including the Adobe CEP CookBook

  💡 Important note: Don't go the hard way. Just use Bolt-CEP.

A word of encouragement

There is a lot to learn before you can start creating sleak and beautiful CEP panels. However, it is not as hard as it seems.

If anything, modern web development is easier than it has ever been. The tooling, resources and documentation available for web development is so good, it will make you hate ExtendScript even more.

If I did it (and I am not a web developer), you can do it too. Take as much time as you need to learn the basics of web development. It will be worth it in the end.



🤖 If you still wish to read my unsorted thoughts from last year, feel free!

About

How to create an After-Effects extensions without losing your mind

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published