The show()
function is the one lifecycle method in panel objects that is required. XD calls show()
each time the user opens your panel.
To populate the panel with UI elements, add DOM nodes to the event.node
root node that is provided. There are two ways you can use show()
to create your panel UI:
For simple panels, you can create the panel UI each time it's shown and throw it away each time it's hidden:
Here is a simple example:
function show(event) {
const content = "<p>Hello, World</p>";
const panel = document.createElement("div");
panel.innerHTML = content;
event.node.appendChild(panel);
}
function hide(event) {
event.node.firstChild.remove();
}
For panels with more complex state, it may be simpler to continue reusing the same panel DOM nodes:
let panel;
function show(event) {
if (panel) { return; }
const content = "<p>Hello, World</p>";
panel = document.createElement("div");
panel.innerHTML = content;
event.node.appendChild(panel);
}
function hide(event) {
// nothing to do here
}
Note: once the panel has been created you don't need to touch the DOM at all for hide & show to work correctly -- XD takes care of closing and reopening the panel UI's container automatically.
Whichever method you use, you'll typically also need to implement the update() callback in order to update your panel UI if the selection or XD document content changes while the panel is already open.