Changelog
2025-01-17
Added
- A new
Viewport
class has been added to the Document APIs.Viewport
represents the canvas area currently visible on-screen. - A new API
bringIntoView
have been added which adjusts the viewport to make the node's bounds visible on-screen, assuming all bounds are within the artboard bounds.
2025-01-13
Added
- Adds a new section in Listing Your Add-on guidelines which describes how to add trader details in the publisher profile.
Are you an existing developer?
You must provide trader details by February 16, 2025, to keep your add-on visible and available in Adobe Express for users in the European Union as of February 17, 2025. This trader information will be displayed publicly on your listing detail pages when viewed from EU countries.
2024-11-04
Added
- Adds a new Cross-origin Isolation Handling page which describes an upcoming change to how Adobe Express enforces cross-origin isolation, and the impact it may have on current add-ons, as well as those currently in-development.
- Updates the descriptions for the
importPdf()
andimportPresentation()
functions to clarify that when used, the associated PDF or presentation file will be imported as a new Adobe Express document.
2024-10-08
- Adds a brand new version of the UX Guidelines for Adobe Express add-ons.
- Removes the experimental warnings for
addAnimatedImage()
since it is now stable. - Adds the
author
property toMediaAttributes
to allow it to be used with theaddAudio()
API.
2024-09-30
New
- Added many new Text APIs for improved text management.
TextNode.fullContent
accessor: returns theTextContentModel
containing the complete text string and its styles associated to the Text Flow (Threaded Text or Overflow Text).TextNode.nextTextNode
accessor: gets the next node that overflowing text will spill into.TextNode.layout
accessor: gets and sets theTextType
of the text node frame.TextNode.visualEffects
accessor: list ofVisualEffectType
applied to the text node.TextContentModel.characterStyleRanges
accessor: list of character style ranges in the text content, controlling thecolor
,font
ranges in the text content, controlling thecolor
,fontSize
ranges in the text content, controlling thecolor
,tracking
ranges in the text content, controlling thecolor
andunderline
ranges in the text content, controlling thecolor
properties.- AvailableFont and UnavailableFont classes.
- Supporting interfaces, enumerations and type aliases.
- Added Per Element Metadata APIs: with this feature, add-ons can store private metadata to any node of the Express document. This metadata is accessible only to the add-on that has set it. See the
AddOnData
class and theaddOnData
accessor for the BaseNode class. - Added Selection Change Notification Events APIs: add-on can register to be notified when selection and properties in the selection changes on the document. The
Context
class will expose twoon()
andoff()
methods which can be used to register and un-register selection change and selection properties change notifications. - Added a new
GridCellNode
class that represents a cell in a grid.
IMPORTANT: This round of new APIs is currently experimental only with the exception of TextNode.fullContent.text
, and should not be used in any add-ons you will be distributing until it has been declared stable. To use them, you will first need to set the experimentalApis
flag to true
in the requirements
section of the manifest.json
.
Fixed
GridLayoutNode.allChildren
does not include rectangle nodes.
Deprecated
TextNode.text
is now deprecated; it is still working, but will be removed in a future update. Please useTextNode.fullContent.text
instead.
2024-09-24
- Adds a new
addAnimatedImage()
method which can be used to add animated GIF images to the document (as long as they fit within certain technical constraints). - Adds a new
importPdf()
method which can be used to import a PDF as a new Adobe Express document. - Adds a new
importPresentation()
method which can be used to import a Powerpoint as a new Adobe Express document. - Adds notes about specific support and handling for animated GIF images when importing and dragging content. This includes a new FAQ item summarizing the associated use cases.
- Adds all of the new methods mentioned above to the content management use case page with example code snippets for each.
IMPORTANT: The importPdf()
and importPresentation()
methods are currently experimental only and should not be used in any add-ons you will be distributing until it has been declared stable. To use this method, you will first need to set the experimentalApis
flag to true
in the requirements
section of the manifest.json
.
2024-09-10
- Added a new
replaceMedia()
method to theMediaContainerNode
class that can be used to replace existing media inline. - Refactoring done to the
Stroke
APIs.
2024-07-22
- Added a new
format
property to theaddOnUISdk.app.ui
object that reflects the format used to display dates, times, numbers, etc. in the user's environment. It supports a"formatchange"
event triggered when the format changes—see an example in the Locale, Supported Locales, and Format section. - Removed
mobile
andapp
assupportedDeviceClass
values in the Manifest'srequirements.apps
object.
2024-05-28
- Added a new experimental
openEditorPanel()
API to programmatically open and interact with the Editor panel. This method of theaddOnUISdk.app.ui
allows navigation to specific tabs and collections, as well as performing content searches. The Constants page has been updated accordingly. - Added a new
Cross-Origin-Embedder-Policy
FAQ.
2024-05-21
- The Quickstart and Distribute guides have been updated to reflect major UI/UX improvements for in-app workflows, particularly around distribution and listing management.
- The Add-ons tab is now active also in the Adobe Express home page, regardless of whether a project is open or not.
- A new section on Marketplace rejections has been added, highlighting the most common problems found during the add-on review process and how to avoid them.
- The Manifest Reference has been updated with two new permission properties:
microphone
andcamera
.
2024-04-10
A new
VisualNode
class has been added to the Document APIs, and represents any node that can be visually perceived in the content.New Document APIs have been added:
currentPage
Context accessor: returns the active page.visualRoot
accessor: the highest ancestor that still has visual presence in the document—typically, an Artboard.cloneInPlace()
method: clones a Page, all artboards within it, and all content within those artboards.- Support to Bounds has been added in several classes:
boundsInParent
;boundsLocal
(for both GroupNode and VisualNode);centerPointLocal
;topLeftLocal
;boundsInNode()
;localPointInNode()
;
The CLI has been updated to release version
2.0.0
, and includes the following:- Periodic login and EULA consent are no longer required.
- Two new templates for creating add-ons with built-in support to Spectrum Web Components have been added and documented:
swc-javascript
andswc-javascript-with-document-sandbox
. Typescript templates have been renamed toswc-typescript
andswc-typescript-with-document-sandbox
. See this page for details on all the available templates. - Typings have been updated to include the latest SDK changes, and other internal packages are now at version
2.0.0
.
NOTE: The new version should be installed by default when you create a new add-on. If, for any reason, it doesn't, you can force it to install by clearing the
npx
cache first withnpx clear-npx-cache
or by specifying the version in the command, i.e.:npx @adobe/create-ccweb-add-on@2.0.0 my-add-on
.The Samples page has been updated to document the existing add-ons in the
express-add-on-samples
repository, including a newly addedaudio-recording-addon
.The Common Use Cases section has been refactored as a sub-menu, grouping similar topics into individual pages. A new Login and Logout flows section has been added. Other minor fixes and improvements have been made to the documentation.
2024-03-19
- Support for Ps and Ai files to be added to the page via the
addImage()
method. (Note: there were no changes to the drag-n-drop APIs). - Adds new
MediaAttributes
parameter to theaddImage()
method for Ps/Ai file types to pass media attributes liketitle
. - Adds new
Mp4RenditionOptions
object to supportmp4
renditions. - Adds new
VideoResolution
constant to set video resolution options. - Adds
registerIframe()
method andunregisterIframe
type definition with example usage. NOTE: These APIs are currently experimental.
2024-03-08
getPagesMetadata()
,startPremiumUpgradeIfFreeUser
andisPremiumUser
have been moved to stable and no longer require theexperimentalApis
flag to be set.- New examples have been added to the use cases guide for handling premium content.
- A new video has been added to the grids tutorial to help guide developers in building the grids add-on.
2024-02-21
New support for monetization details has been added to the public distribution flow and allows you to provide details around monetization options your add-on supports. A selection will now be required when you submit a new add-on to the marketplace or update an existing one. The options include free, one-time payment, recurring subscription, micro-transactions, and other.
In addition, the monetization guidelines were updated with details to help guide you in communicating your monetization strategy, and include new branding badges you can use to visually indicate when content or features require a purchase or when they are paid and unlocked. Please ensure you review the updated monetization guidelines carefully for specific details. NOTE: Adobe does not currently provide a specific monetization feature, but with this update, provides a way for developers to communicate the monetization details of their add-ons.
The first phase of add-on analytics support has been released, and allows developers to download insights data for their published add-ons via the Download insights button in the in-app distribution modal.
A new Concepts guide was added to the Document APIs section to provide a deep-dive into the architecture and key elements of the Adobe Express Document Object Model (DOM).
2024-02-14
- A new
id
accessor has been added to theBaseNode
class in the Document APIs and is inherited by all classes that extend it. Theid
represents a unique identifier that stays the same when the file is closed and reopened, or if the node is moved to a different part of the document.
2024-02-07
- A new
createPath
method is now available for allowing you to create a path with the Document APIs. - Updates descriptions in various methods and classes in the Document APIs.
- Updates to the
createRenditions
API, including a newprint
option forRenditionIntent
to be be used for generating a print optimized pdf, and an update toPdfRenditionOptions
which exposes the ability to customize each PDF Page Box's (MediaBox
,BleedBox
,CropBox
,TrimBox
) dimensions using apageBoxes
property. - Updates to the Using Adobe Spectrum tutorial with additional details on why you should use Spectrum CSS variables to style your add-ons, and additional helpful guidelines for locating and using them.
- The table of contents in each Document API class/interface/constant has been removed since it was a duplicate of the right side navigation menu.
2024-01-31
Added a new tutorial - Building UIs using Adobe's Spectrum Design System.
2024-01-09
New Experimental APIs
startPremiumUpgradeIfFreeUser()
experimental API has been added to the addOnUISdk.app object to display the in-app monetization upgrade flow and returns a value indicating whether the user upgraded to premium or not.isPremiumUser()
experimental API has been added to the addOnUISdk.app.currentUser object to determine if the current user is a premium or free user.
IMPORTANT: The above new APIs are currently experimental only and should not be used in any add-ons you will be distributing until declared stable. To use these APIs, you will first need to set the experimentalApis
flag to true
in the requirements
section of the manifest.json
.
Additional Updates
- A new
PdfRenditionOptions
object is now available to be used with the thecreateRenditions()
export API and allows a user to specify an optional bleed object (for printing). - A new
isPrintReady
property has been added to thePageMetadata
API to indicate if the page is ready to print. - Updated the FAQ regarding the mime type for exported PDF files. It will now return
application/pdf
(as opposed totext/plain
from an earlier update).
2023-12-07
BREAKING NEWS: The Adobe Express Document Sandbox and all associated APIs have been deemed stable, and no longer require the experimentalApis
flag. As a result, some breaking changes with these experimental APIs were introduced before deeming them stable, and they are summarized below. Please read them thoroughly and update your in-development add-ons as needed. If you run into any issues, please reach out to us on our Adobe Express Add-on Developer’s Discord channel for help.
Breaking changes (experimental APIs)
Some items in the following list of changes may have been mentioned in recent updates but are being listed in this summary again to serve as a reminder.
The methods in the Document API Editor class to create a color fill and stroke have been renamed to
makeColorFill
andmakeStroke
respectively.strokes
andfills
have been renamed to their singular counterpart. (Express does not support multiple strokes or fills). You should usestroke
andfill
going forward to access them, and they will no longer beItemList
objects, since they represent only a single stroke or fill.Copied to your clipboard// Beforerectangle.fills.append(rectFill);ellipse.fills.append(ellipseFill);// Afterrectangle.fill = rectFill;ellipse.fill = ellipseFill;fill
andstroke.color
are just a color object of the form{ red, green, blue, alpha }
.stroke
is an object of the form{ color, width, dashPattern, dashOffset }
Color utilities have moved to
colorUtils
instead ofutils
.Old
Copied to your clipboardimport { utils } from "express-document-sdk";const color = utils.createColor(1, 0, 0);New
Copied to your clipboardimport { colorUtils } from "express-document-sdk";// any of:const color = colorUtils.fromRGB(1, 0, 0); // optional alphaconst color = colorUtils.fromRGB({ red: 1 , green: 0, blue: 0 };); // optional alphaconst color = colorUtils.fromHex("#ff0000");const color = { red: 1, green: 0, blue: 0, alpha: 1 }; // mandatory alphafromHex
returns a color from a Hex string -- e.g.,colorUtils.fromHex("#FF8040")
orcolorUtils.fromHex("#FF8040FF")
(including the optional alpha);fromRGB
returns a color from a set of RGB(A) values (0-1) -- e.g.,colorUtils.fromRGB(1,0.5,0.25,1)
.toHex
converts a color object to a Hex string -- e.g.,colorUtils.toHex(aColor)
.
allChildren
returns aniterator
, not anArray
. However if you want to use array methods (ie:Array#map
), you can useArray.from
to convert it to an array.Strokes and fills will no longer move if you add an existing
stroke
/fill
to another shape (previously the original shape would lose the correspondingstroke
orfill
). For example:Copied to your clipboard// Old wayconst greenFill = editor.createColorFill(colorUtils.fromRGB(0, 0, 1));someRect.fills.append(greenFill);anotherRect.fills.append(greenFill);/* oops, someRect no longer has a green fill, because anotherRect is its parent */versus:
Copied to your clipboard// New wayconst greenFill = editor.makeColorFill(colorUtils.fromRGB(0, 0, 1));someRect.fill = greenFill;anotherRect.fill = greenFill;/* both rectangles have a green fill */Some things that previously didn't make sense will now cause compile errors in typescript, or throw in javascript:
- Do not assume a node's parent is movable — e.g., an artboard can't be repositioned.
- Not all shapes support setting
opacity
orlocking
(e.g, the document root or an artboard).
The
translateX
andtranslateY
properties have been replaced by a single translation object.Copied to your clipboard// oldrectangle.translateX = 100;rectangle.translateY = 20;// newrectangle.translation = { x: 100, y: 20 }; // both x,y properties are requiredA new
BaseNode
class has been introduced, andContainerNode
has been moved from a class to an interface.The key to load APIs that use the Document APIs has changed, as well as the module names you import APIs from in the Document Sandbox. The old ones will still work, but the CLI and templates have all been updated to use the new names. Please update your add-ons to use the new ones shown below:
Adobe Express Document APIs SDK import
For access to the Express document and content authoring APIs:Copied to your clipboard// Oldimport { editor } from "express";Copied to your clipboard// Newimport { editor } from "express-document-sdk";Document Sandbox SDK import
For access to the document sandbox runtime APIs:Copied to your clipboard// Oldimport AddOnScriptSdk from "AddOnScriptSdk";Copied to your clipboard// Newimport addOnSandboxSdk from "add-on-sdk-document-sandbox";The
manifest.json
entry point for the document sandbox script code reference was renamed fromscript
todocumentSandbox
, as shown below:Copied to your clipboard"entryPoints": [{"type": "panel","id": "panel1","main": "index.html","documentSandbox": "code.js" // used to be "script": "code.js"}]The
apiProxy()
method in theaddOnSandboxSdk.instance.runtime
object now accepts"documentSandbox"
as a parameter when referring to the entry point in the manifest where your document sandbox code resides, instead of"script"
.The
RuntimeType
constant now uses the value of"documentSandbox"
in lieu of"script"
.IMPORTANT: The above updates should be considered breaking changes, so any add-ons in development that relied on the experimental APIs may not work correctly until you make changes to use the new/updated ones above. The intention was to ensure these important changes were made prior to marking the APIs stable to 1) make them more intuitive for developers, 2) significantly improve the process of working with colors, strokes and fills, and 3) prevent certain operations from corrupting the document.
The CLI has been updated to release version
1.1.1
, and includes the following:- The document sandbox templates have been updated to reflect all of the latest changes to the Document Sandbox APIs, and the
experimentalApis
flag has been removed. Please review the updated references and changelog entries thoroughly for details on all of the recent changes. You may also want to refer to the document sandbox code samples for additional help on how to use them. - Typings support has been added to the
javascript
templates to enable intellisense features. - Manifest property additions.
- General improvements and bug fixes.
NOTE: The new version should be installed by default when you create a new add-on. If, for any reason, it doesn't, you can force it to install by clearing the npx cache first with
npx clear-npx-cache
or by specifying the version in the command, i.e.:npx @adobe/create-ccweb-add-on@1.1.1 my-add-on
. You can update any existing add-ons to use this new version by updating the version of theccweb-add-on-scripts
in thepackage.json
to1.1.1
.- The document sandbox templates have been updated to reflect all of the latest changes to the Document Sandbox APIs, and the
All code samples and the Document API tutorial have also been updated to reflect all of the latest changes to the Adobe Express Document Sandbox APIs listed here.
Removed all experimental APIs notes/warnings around the Document Sandbox since they are now stable.
Known Issue: Please note, there is an edge case where removing a page with your add-on could potentially cause a problem where the UI needs to be reloaded. This will be resolved in the very near future, but please take caution and be aware that it would be best to avoid page removal in the short-term until it's resolved.
Additional Updates
- A new
getPagesMetadata()
method is now available in the Add-on UI SDKdocument
object and includes an example code snippet. NOTE: This method is still considered experimental only and should not be used in any add-ons you will be distributing until it has been declared stable. To use this method, you will first need to set theexperimentalApis
flag totrue
in therequirements
section of themanifest.json
. - The
createRenditions()
export API was updated with the following changes:- You can now choose to generate renditions of specific pages via a new
Range.specificPages
constant value. - The returned type now also includes page metadata (see
PageMetadata
) including useful information such as the id, page size, pixels per inch, and whether the page has premium or temporal (timeline) content or not, (in addition to the existing blob and title). An example is provided in the reference as well as in the use cases.
- You can now choose to generate renditions of specific pages via a new
- A new document metadata use case example has been added to show how to retrieve the document id and title (ie: name), including how to listen for the associated events.
- New tables have been added to the Communication API reference denoting the supported and unsupported data types that can be used across the Communication API layer.
2023-12-04
Updates
The Document API's were updated to add a new
ColorUtils
class, which replaces the previousutils
module that was used as a color helper with a more enhanced utlility. If you've used the oldutils
module in your add-ons, it will require you to update them to use the new named import ofcolorUtils
instead ofutils
. Color creation should now be done using the newcolorUtils
module. An example of the old way and new way to create a color are shown below for reference:Copied to your clipboard// Beforeimport { utils } from "express-document-sdk";const color = utils.createColor(1, 0, 0);// Afterimport { colorUtils } from "express-document-sdk";// any of:const color = colorUtils.fromRGB(1, 0, 0); // optional alphaconst color = colorUtils.fromRGB({ red: 1, green: 0, blue: 0 }); // optional alphaconst color = colorUtils.fromHex("#ff0000");const color = { red: 1, green: 0, blue: 0, alpha: 1 }; // mandatory alphaThe code samples have also been updated, so please also refer to those for further details on how to use it. Please note, the example code snippets and samples using
fills
orstrokes
off a node class were also updated to use a singularFill
orStroke
object instead of as anItemList
object.Copied to your clipboard// Beforerectangle.fills.append(rectFill);ellipse.fills.append(ellipseFill);// Afterrectangle.fill = rectFill;ellipse.fill = ellipseFill;A new release has landed for the In-App Developer Submission experience in Express. Some highlights from the release:
Create Add-on flow: You can now create an add-on "container" as your first step in building add-ons within the existing in-app distribution workflow. Creating the container gets you access to a few important settings and data (for instance your unique subdomain, see below) before you continue the development process in the CLI. All existing add-ons will automatically receive a parent container with the associated additional features today.
Unique Subdomain retrieval: As part of your add-on container, you will now be able to easily retrieve a unique subdomain for your add-on. Simply choose one of your add-ons in the distribution workflow and navigate to the new "Settings" tab and copy the Add-on URL. This URL is handy for addressing issues with CORS by adding the URL as an allowed origin. See our CORS guide for more details.
Delete Add-ons: The "container" concept allowed us to offer better management and cleanup of your add-ons. You will now find the option to delete an add-on container entirely from the new "Settings" tab of a given add-on.
NOTE: You can only delete add-ons that have not been published publicly or submitted to our Review team. Please contact us if you need to un-publish an add-on.
Supported Languages: The version details step for publishing add-ons publicly now includes fields to indicate which languages are supported by your add-ons (beyond the required English). You can choose from any of the languages Express supports, and your designation will be shown to users when they browse your listing details. See our sample for detecting a user's locale to localize your add-on.
Updated list of templates and details to include the Document Sandbox template options, and how to still scaffold from one when the
--template
parameter is not explicitly supplied.New FAQ item regarding the mime type for exported PDF files. This is due to an unexpected change made in Adobe Express core to the mime type returned when you generate a PDF using the export
createRenditions
method. In the past it would returnapplication/pdf
, but currently it returnstext/plain
. This is something to be aware of if you are inspecting the mime type in the response and failing if it's anything other thanapplication/pdf
.Removed NPS survey.
2023-11-30
Updates
Adds support to the Add-on UI SDK for retrieving the document id and title, as well as the ability for the add-on to be notified of the associated events.
Updates the names of the SDK imports for the Document Sandbox and the Document API's SDK:
Document Sandbox SDK import
from:
import AddOnScriptSdk from "AddOnScriptSdk";
to:
import addOnSandboxSdk from "add-on-sdk-document-sandbox";
which also requires the following line to change in the example code to use the new reference:
const { runtime } = addOnSandboxSdk.instance; // runtime object provides direct access to the comm methods
Express Document SDK Import (for accessing the Document APIs
from:
import { editor } from "express";
to:
import { editor } from "express-document-sdk";
NOTE: This includes the named imports for
utils
andconstants
modules as well if needed (ie:import { editor, utils, constants } from "express-document-sdk"
).Updates the
manifest.json
entry for the document sandbox script code reference fromscript
todocumentSandbox
, as shown below:Copied to your clipboard"entryPoints": [{"type": "panel","id": "panel1","main": "index.html","documentSandbox": "code.js"}]apiProxy()
now accepts"documentSandbox"
as a parameter when referring to the entry point in the manifest where your document sandbox code resides, instead of"script"
.The
RuntimeType
constant can now have a value of"documentSandbox"
in lieu of"script"
.
IMPORTANT: The old import names will continue to be supported for a period of time to allow developers to migrate to the new import names, but we encourage you to update as soon as possible to avoid any future issues.
2023-11-28
Updates
The Web API's in the Document Sandbox Reference were updated to remove the timer methods which are no longer supported (ie:
setTimeout()
,clearTimeout
andsetInterval()
,clearInterval
).The Document API References were updated with the following additions and changes:
New Classes/Interfaces
- New RestrictedItemList class
- New UnknownNode class
- New SolidColorShapeNode class
- New Point interface
- New
queueAsyncEdit
method added to the Editor class. - Renames the Constants to remove the
Value
suffix.
Updates to Node Classes
The accessors and methods below were removed or replaced with new names in the Node
class and classes that extend it. Please refer to the Document API References specifically to learn more about each.
- Removes
absoluteRotation
accessor - Removes
absoluteTransform
accessor - Removes
relativeRotation
accessor - Removes
relativeTransform
accessor - Removes
translateX
accessor - Removes
translateY
accessor - Adds
rotation
accessor - Adds
rotationInScreen
accessor - Adds
transformMatrix
accessor - Adds
translation
accessor - Adds
setPositionInParent
method - Adds
setRotationInParent
method
2023-11-27
Updated Document API references to include:
2023-11-6
- Added a new tutorial section to the Getting Started guides, including a new "Building your first add-on with the Document API" tutorial by Davide Barranca.
- Updated the naming conventions from Script Runtime to Document Sandbox and Editor APIs to Adobe Express Document APIs. The Document Sandbox now includes the Communication APIs, Web APIs and the Document APIs.
- Updated sample code snippets to use the
addOnUISdk
import name (vsAddOnSDK
) similar to what's generated in the templates for consistency.
2023-10-26
Updates
New questions and answers added to the FAQ regarding Adobe's use of add-on data, where to file feature requests and more.
2023-10-10
Updates
Updates to the OAuth APIs to allow for a new optional windowSize
parameter to be specified in the AuthorizationRequest
object and the AuthorizeWithOwnRedirectRequest
to set the desired size of the authorization window.
2023-10-09
Updates
Published new Guidelines and requirements section; including General guidelines, Developer brand guidelines, Monetization guidelines and Generative AI guidelines.
2023-10-03
Updates
New versions of the CLI packages:
Copied to your clipboard"@adobe-ccwebext/ccweb-add-on-manifest": "1.5.0""@adobe-ccwebext/ccweb-add-on-core": "1.5.0""@adobe-ccwebext/ccweb-add-on-ssl": "1.5.0""@adobe-ccwebext/ccweb-add-on-analytics": "1.5.0""@adobe-ccwebext/ccweb-add-on-developer-terms": "1.5.0""@adobe-ccwebext/create-ccweb-add-on": "1.5.0""@adobe-ccwebext/ccweb-add-on-scaffolder": "1.5.0""@adobe-ccwebext/ccweb-add-on-scripts": "1.5.0""@adobe-ccwebext/ccweb-add-on-sdk-types": "0.3.0"
which include:
Updated templates for both iframe and document sandbox add-ons:
- All new add-ons created (other than those based on javascript) use
spectrum-web-components
with the Express theme pre-set. - React-based templates include
swc-react
setup. - The
javascript-with-editor-apis
template has been removed from the initial template selection in this version but replaced with the option from the CLI to include the document sandbox when creating a new add-on.
- All new add-ons created (other than those based on javascript) use
New type support for typescript based add-ons.
Ability to recreate your SSL certificates.
Documentation updates
- Updated document sandbox Reference docs to reflect the new CLI prompt to include document sandbox (vs the specific template).
- Updated Getting Started guides documentation and screenshots to reflect the new Add-on Launchpad panel update to the new two-tab view for "Discover" and "Your Add-ons".
2023-09-26
Removed
- Removed the experimental APIs notes/warnings around the Audio APIs and User APIs since they are now stable.
- Removed references to the Dropbox sample since the import-images-from-oauth contains the same functionality.
Updated
- Updated the Express add-ons introduction video with a newly created version.
2023-09-25
Updates
The Editor API references have been updated with additional descriptions and details as well as some new and modified APIs:
- Artboard now has a single fill only. Note: it's possible that all node types will move to this model in the near future.
- The
name
property is now only available onPageNode
, not all node types. - New
Node.locked
&Context.selectionIncludingNonEditable
properties were added for the locking feature that recently shipped in Express.
If you're using the experimental Document Sandbox APIs in any add-ons currently, we encourage you to check the specific methods and objects you're using in these updated references to discover anything new or changed.
2023-09-19
Added
- New iframe Sandbox Context guide with details on the new
subdomain
support and CORS handling. - How-to videos embedded in various guides to help visually show how to use the information in those sections.
Updates
New Types Package Versions Released
- A new version
0.1.6
of the@adobe-ccwebext/ccweb-add-on-sdk-types
package with the latest typings for theAddOnSDK
(iframe), including new experimental APIs, as well as general improvements and bug fixes. - A new version
0.2.0
of the@adobe-ccwebext/ccweb-add-on-sdk-types
package with the latest typings for the document sandbox/Editor APIs.
IMPORTANT: Developers who are NOT using the document sandbox/Editor APIs should update to their types package to
0.1.6
at minimum by changing the version of it to@adobe-ccwebext/ccweb-add-on-sdk-types@0.1.6
in thepackage.json
.The new types
0.2.0
types package will be used automatically for any new add-ons created. If you would like to update an existing add-on to the0.2.0
version, you will need to update theccweb-add-on-sdk-typings.d.ts
file in your add-on with the content here.- A new version
Performance guide updates to include Task Manager and Memory Consumption details for add-ons.
2023-09-12
Updates
- Added supported file types for import and export to the FAQ.
2023-09-07
Updates
The Communication API in the document sandbox reference section was updated to change the example code importing the SDK to a default import rather than a named import as it was previously:
from:
import { AddOnSdkApi } from "AddOnSdkApi";
to:
import AddOnScriptSdk from "AddOnScriptSdk";
Note that you can now name the imported module whatever you'd like, but for simplicity in the examples, the name is kept the same. Since these APIs are currently experimental, this change will not impact any in-production add-ons, however, it will require you to update any existing usage of these APIs in progress.
- A new 1.4.2 version of the CLI was also released with an updated
javascript-with-editor-apis
template reflecting the default SDK import noted in the first bullet above. The new CLI version will install automatically when you create a new add-on, or you can update existing add-ons by changing the version of theccweb-add-on-scripts
in thepackage.json
to1.4.2
. - Updated the FAQ with details on Experimental APIs and suppported file types for exported content.
2023-09-05
Added
Added new Audio API documentation. You can now import audio to the current Adobe Express document in two different methods:
- Using the new
addAudio()
method, which requires aMediaAttributes
object containing thetitle
of the audio content. - Using drag and drop, and supplying the
MediaAttributes
object in theDragCompletionData
.
Please note, in both cases, the MediaAttributes
object is required for audio content, but optional for video and image content. A new code sample will be supplied in the near future, but in the meantime, please refer to the example usage snippets provided in the SDK Reference and Implementing Common Use Cases Guide.
2023-08-31
Added
Added new code sample to demonstrate how to use SWC-React and set theme properties in add-ons called swc-react-theme-sampler to the Code Samples.
Updated
- Updated the User Interface Guide to add more notes around the recommended use of
swc-react
over React Spectrum and to point to the new sample mentioned above.
Fixed
- Fixed bug in the locale example.
2023-08-29
- Added
currentUser
API details and usage example to the SDK References and Implementing Common Use Cases Guide. - Added a new licensed-addon code sample to illustrate how to implement monetization by leveraging the current userid.
- Added
devFlags
API details, which can be used to simulate certain behavior during development.
2023-08-17
Bugs and Fixes
There's currently a bug where
addArtboard
could crash the application or corrupt the document if there's nofill
specified on the artboard. Please ensure you always add a fill in the same frame as the artboard creation until this issue is resolved. Also note, when this bug is fixed, theArtboardNode
will accept a singlefill
object, rather than anItemList
offill
(s).Currently, in the
addPage
API, a new page is created, but the selected context is not changed to the newly addedartboard
. As a result, from a UI perspective, the user remains on the previous page. A change will be implemented this week which will change the default context to theartboard
child of the newly added page. This results in actual navigation to the newly added page, and all new content which is added using the Editor APIs will be added to this page.IMPORTANT: We recommend that you only test the use of these experimental Editor APIs against non-essential documents, due to the potential for loss or corruption.
Updates
- Premium Content handling details have been added to the Implementing Common Use Cases Guide. Note the warning for ensuring that you include the specified
permissions
in themanifest.json
toallow-popups
andallow-popups-to-escape-sandbox
to ensure the pricing page can be loaded when needed (and note the addition of therenditionPreview
flag in therequirements
of the manifest when you want to allow premium content to be previewed).
2023-08-09
Added
- Added new references section for the document sandbox APIs.
Important notes on document sandbox APIs (aka Document Sandbox)
These APIs are experimental!
- Do not test your add-ons on documents that you care about as these APIs are not currently considered stable.
- Be sure to only use documented APIs when writing your add-ons. Use of undocumented APIs (which may be prefixed with an underscore, but not always) is not supported and may cause your add-on to fail or lead to document corruption. Visibility of a method or property is visible via
console.log
is not an indication of whether that field is supported or documented.
Debugging & Console messages
- You may see "Empty transaction not added to pendingTransaction" while running code in the document sandbox. You can ignore this for now.
- You may see "Detected a possible stutter. Excessive ECS Frame duration of ## ms" in the console. You can ignore this for now.
- If your script code has a syntax error, the console will log an unhelpful error message (similar to
Uncaught (in promise) at adobe-internal.js:49
). Your add-on panel UI will be visible and continue to be interactive, but it won't be able to communicate with the document sandbox, resulting in what feels like non-responsive UI (e.g., clicking doesn't trigger the expected action). You'll want to configure your editor to highlight any syntax editors so that you can be sure your code is at least syntactically correct before you save.
Intermittent issues
- Auto reload of the add-on when a change is detected sometimes fails to work properly. This can result in changes to the UI HTML not being reflected, but can also cause the connection between the panel UI and the document sandbox to not be properly initialized (your UI may appear to be unresponsive as a result). If you encounter this situation, manually reloading the add-on from the developer panel will usually resolve the issue. We're working on a fix.
- It's occasionally possible to run into a race condition where the communications bridge between the two contexts (panel vs document sandbox) is not set up in time. If you interact with your panel UI immediately after it's reloaded, the click may appear do nothing instead of invoking your script code. We're working on a fix for this.
Common pitfalls
- If you split your work on a document over multiple frames, be sure to protect against reentrancy, otherwise you may end up corrupting the user's undo stack. You should disable elements on the panel UI that could allow the user to execute your code before it is complete and then re-enable those elements when the code is done. The issue will be fixed in a future release.
- When setting up communication between your panel UI code and your script sandbox code, calling
apiProxy()
with the wrong argument will do nothing without providing any error feedback. If communication is not working, carefully double-check your UI code is requesting the"script"
API proxy and your script sandbox code is requesting the"panel"
API proxy.
Unexpected behavior
If the user has a selection and your add-on creates new content, the selection is cleared. This will be addressed before release. An API will be added in the future that will allow you to change the selection to content your add-on creates.
When you add text content to a document, font substitution is not working correctly. This means that if you use Asian-language characters, the user may see square boxes instead. If the user were to type the content manually, however, they would see the correct rendering. This issue will be fixed before release.
Setting a blend mode on a media container node (e.g., after calling
editor.createImageContainer
) will be visually reflected, but doesn't currently update the "Blend mode" field in the property panel.Setting rotation on an empty group is ignored. Always add content (children) to a group first, and then set its rotation.
When removing elements from a parent element, the element may continue to show in the Adobe Express layer stack. This will be addressed in the future. This can also occur if you call
clear()
to remove all children from an element as well as when usingremoveFromParent()
.Shape elements added to the document by users (via the Media tab) do not support fill or stroke properties at this time. Furthermore, you should generally avoid making changes to these shapes (they'll appear as group nodes), as this could corrupt the document. We'll add protections around this in an upcoming release.
While the API supports adding multiple strokes to elements, Express currently only supports editing the first stroke added. If you want to change the stroke of an element, remove the existing strokes and then add the new stroke so that the element continues to have a single stroke. For example:
Copied to your clipboardelement.strokes.clear();element.strokes.append(newStroke);
Likely API changes
- Creating colors is currently done via
utils.createColor()
. We're likely to change how you assign colors to objects, so bear this in mind as you use the experimental APIs. Note that this means you cannot just pass a plain JS object of the form{red, green, blue}
to the Editor APIs — it must be a color created usingutils.createColor
. - Editor API constants may be renamed or may change how they are accessed.
- Fills and strokes can only be assigned to a single parent element. If you try to append a fill from one element to another element, the fill will be moved and not cloned (just like moving a scenenode object from one parent to another). This behavior may change in the future.
- There is no support for
fetch
in the document sandbox environment. You can work around this by exposing a method from your panel that your script code can call that does the work of fetching remote content. In the future we may abstract this for you automatically. - The
strokes
API is likely to be modified so that it only supports a single stroke.
- Creating colors is currently done via
Typings & Typescript
- Typings and samples showing how to use Typescript will be available in a future release.
2023-08-01
Added
- Added new properties to the manifest reference for
renditionPreview
in therequirements
section, and thescript
property to theentryPoints
section to support the new experimental document sandbox APIs. - Added
DisableDragToDocument
anddropCancelReason
support to theaddonsdk.app
reference.
2023-07-11
Added
- UX Guidelines are now available!
- A new
requestedSize
parameter can now be supplied as part of the JPG and PNG rendition options passed in when exporting content with thecreateRenditions
method. - A new
clipboard
permission can now be set with theclipboard-write
value in the manifest to allow an add-on to write data to the clipboard. - Information on using fonts.
- CORS / COEP header handling added to the CORS guide
2023-06-08
Added
- Initial release for the beta version of Adobe Express.