The Canva Button is only available for users in China. If your users aren't in China, you can't use the Canva Button. There are no plans to make the Canva Button available outside of China.

Editing designs

Edit an existing design with the JavaScript API.

After a user creates a design, they may want to edit that design at a later point in time. To enable this, Canva provides your website with the ID of the user's design. You can use this ID to re-open a design in the Canva editor.

This part of the tutorial series explains how to open an existing design in the Canva editor.

Step 1: Get the ID of the user's design

To get the ID of the user's design, register callbacks with the onDesignOpen and onDesignPublish methods:

api.createDesign({
design: {
type: "Poster",
},
onDesignOpen: (opts) => {
console.log(opts.designId);
},
onDesignPublish: (opts) => {
console.log(opts.designId);
},
});
JAVASCRIPT

The onDesignOpen callback runs when the user opens a design via the Canva Button. The onDesignPublish callback runs when the user publishes a design via the Canva editor. Both of these callbacks receive an opts.designId argument that contains the ID of the user's design.

When your website receives the ID of a user's design, it can save the ID for later use, but it doesn't particularly matter how the website saves the ID. Some common patterns are persisting the ID to a database or storing it locally via localStorage.

Step 2: Open an existing design in the Canva editor

To open an existing design in the Canva editor, call the editDesign method:

api.editDesign({
design: {
id: "DESIGN ID GOES HERE",
},
});
JAVASCRIPT

At a minimum, the editDesign method expects an opts.design.id argument. This argument must contain the ID of a design that Canva can open in the editor.

The editDesign method accepts many of the same arguments as the createDesign method, but the arguments are not identical. The main difference is that the editDesign method doesn't accept the opts.design.type argument. This is because the design type of an existing design can't be changed.

You can pass the onDesignOpen and onDesignPublish methods into the createDesign and editDesign methods.

Example

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Canva Button</title>
<script src="https://sdk.canva.com/designbutton/v2/api.js"></script>
</head>
<body>
<button id="create-design">Create design</button>
<button id="edit-design" disabled="true">Edit design</button>
<button id="download-design" disabled="true">Download design</button>
<script type="text/javascript">
(async () => {
if (!window.Canva || !window.Canva.DesignButton) {
return;
}
const api = await window.Canva.DesignButton.initialize({
apiKey: "API KEY GOES HERE",
});
let previousDesignId;
const createDesignButton = document.querySelector("#create-design");
const editDesignButton = document.querySelector("#edit-design");
const downloadDesignButton = document.querySelector("#download-design");
const handleDesignOpen = (opts) => {
previousDesignId = opts.designId;
editDesignButton.disabled = false;
};
const handleDesignPublish = (opts) => {
previousDesignId = opts.designId;
downloadDesignButton.disabled = false;
downloadDesignButton.onclick = () => {
window.location.href = opts.exportUrl;
};
};
createDesignButton.onclick = () => {
api.createDesign({
design: {
type: "Poster",
},
onDesignOpen: handleDesignOpen,
onDesignPublish: handleDesignPublish,
});
};
editDesignButton.onclick = () => {
api.editDesign({
design: {
id: previousDesignId,
},
onDesignOpen: handleDesignOpen,
onDesignPublish: handleDesignPublish,
});
};
})();
</script>
</body>
</html>
MARKUP