mirror of
https://github.com/penpot/penpot-plugins.git
synced 2025-01-07 15:39:49 -05:00
1.2 KiB
1.2 KiB
Plugin usage
If you want your plugin to be opened in a modal, then use open UI:
penpot.ui.open('Plugin name', 'http://localhost:4201', {
width: 500,
height: 600,
});
Get state:
// file file state
penpot.ui.getFileState();
// file page state
penpot.ui.getPageState();
// selection id
penpot.ui.getSelection();
// current theme (dark/light)
penpot.ui.getTheme();
Messages
Receive message from iframe:
penpot.ui.onMessage((message) => {
penpot.log('Received message:', message);
});
Send message from iframe:
parent.postMessage({ content: 'text' }, '*');
Send message from plugin
penpot.ui.sendMessage({ type: 'hello' });
Send message from plugin:
window.addEventListener('message', function (event) {
console.log('Message received from plugin: ', event.data);
});
Events
Current events pagechange
, filechange
,selectionchange
and themechange
.
const event = (page) => {
penpot.log(page.name);
};
penpot.on('pagechange', event);
penpot.off('pagechange', event);
Requests
Same as the browser fetch API.
penpot.fetch('http://example.com/movies.json');