Create a new design

By default, nothing happens when a user selects a product or template via the product catalog. This is because an integration needs to explicitly define the behavior.

This part of the tutorial explains how to:

  • Detect when a user selects a product or template.
  • Create and open a new design in the Canva editor.

After the initialize method, create a function named onProductSelect:

const onProductSelect = (opts) => {
console.log("Product selected.");
};
javascript

Then pass this function into the showCatalog method:

api.showCatalog({
onProductSelect,
});
javascript

This function runs when a user selects a product. It receives an opts object that contains information about the selected product, such as its dimensions and category.

In the onProductSelect function, call the createDesign method.

const onProductSelect = (opts) => {
api.createDesign({
...opts,
});
};
javascript

The ...opts is an object spread operator that merges the opts object with any other properties. This enables the opts object from the onProductSelect function to be passed into the createDesign method. This ensures that the createDesign method can still access the relevant product and template data.

The createDesign method also requires an onBackClick callback function. This function runs when a user clicks the back button in the Canva editor's header. You should use this function to return the user to the previous screen.

For this tutorial, use the onBackClick function to log a message to the JavaScript Console:

const onBackClick = () => {
console.log("You clicked the 'Back' button in the Canva editor's header.");
};
const onProductSelect = (opts) => {
api.createDesign({
...opts,
onBackClick,
});
};
javascript
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta
name="viewport"
content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no, viewport-fit=cover"
/>
<title>Print Partnership Example</title>
<script src="https://sdk.canva.com/partnership.js"></script>
<style type="text/css">
body,
html {
margin: 0;
}
#container {
height: 100vh;
}
</style>
</head>
<body>
<div id="container"></div>
<script type="text/javascript">
(async () => {
const api = await Canva.Partnership.initialize({
apiKey: "<%= partnerApiKey %>",
container: document.getElementById("container"),
autoAuthToken: "<%= autoAuthToken %>",
});
const onBackClick = () => {
console.log(
"You clicked the 'Back' button in the Canva editor's header."
);
};
const onProductSelect = (opts) => {
api.createDesign({
...opts,
onBackClick,
});
};
api.showCatalog({
onProductSelect,
});
})();
</script>
</body>
</html>
html