Edit in GitHubLog an issue

addOnUISdk.instance.runtime

Represents the runtime of the current add-on.

Properties

type

The RuntimeType constant representing the entrypoint creating this backend object (ie: "panel", "dialog" or "documentSandbox").

Dialog

(Optional) When the RuntimeType is "dialog", this object will contain the reference to the modal dialog the add-on invoked, and can be used to programmatically close the dialog and send results back to the caller. Will be undefined when no modal dialog is present. Check out the modal dialogs use case examples for more details on using dialogs, as well as the related showModalDialog method.

Methods

The following methods allow you to communicate bidirectionally between the add-on running in the iframe and the document sandbox environments.

exposeApi()

Use this method to expose an API from your UI code running in the iframe to another runtime (ie: the document sandbox code defined in your code.js for instance).

Signature

exposeApi<T>(obj: T): void

Parameters

NameTypeDescription
obj
object
The concrete object/class instance to expose to other runtimes. This method call is allowed only once. Subsequent calls are ignored. Note: you cannot expose entire classes from one runtime and create an instance of that class in another.

apiProxy()

Requests a promise-based proxy object from another runtime to be used to call the APIs exposed by that other runtime via the exposeApi method.

Signature

async apiProxy(runtimeType: RuntimeType): Promise<Remote<unknown>>

Parameters

NameTypeDescription
runtimeType
RuntimeType
The runtime type to create the proxy object from (ie: "documentSandbox" for instance, which maps to the code referenced in the documentSandbox entryPoint in your add-on's manifest.js file).

Return

A promise which resolves to an API proxy object exposed by the desired runtime as soon as the other runtime is finished initializing.

Note: Calling the method again for the same runtime type will return a new proxy object without any behavior difference.

Example Usage

Copied to your clipboard
addOnUISdk.ready.then(async () => {
console.log("addOnUISdk is ready for use.");
const { runtime } = addOnUISdk.instance;
let createShapesButton = document.getElementById("createShapesButton");
createShapesButton.addEventListener("click", async (e) => {
const sandboxProxy = await runtime.apiProxy("documentSandbox");
try {
let result = await sandboxProxy.createShapes();
console.log(result);
} catch (exc) {
console.error(exc.message, exc.stack);
}
});
});
  • Privacy
  • Terms of Use
  • Do not sell or share my personal information
  • AdChoices
Copyright © 2025 Adobe. All rights reserved.