0
Fork 0
mirror of https://github.com/penpot/penpot-plugins.git synced 2025-01-21 06:02:34 -05:00

feat(poc-state-plugin): add new functions to the plugin to test comments and rulers

This commit is contained in:
alonso.torres 2024-09-24 14:44:19 +02:00 committed by Alonso Torres
parent 2f0f7a601c
commit 6adee1116a
5 changed files with 120 additions and 6 deletions

View file

@ -90,6 +90,28 @@ import type { Shape } from '@penpot/plugin-types';
> >
Rotate Rotate
</button> </button>
<button
type="button"
data-appearance="secondary"
(click)="createMargins()"
>
Add Margins
</button>
<button
type="button"
data-appearance="secondary"
(click)="addComment()"
>
Add comment
</button>
<button
type="button"
data-appearance="secondary"
(click)="exportFile()"
>
Export File
</button>
<input type="file" class="file-upload" (change)="uploadImage($event)" /> <input type="file" class="file-upload" (change)="uploadImage($event)" />
</div> </div>
@ -146,6 +168,8 @@ export class AppComponent {
this.theme.set(event.data.content); this.theme.set(event.data.content);
} else if (event.data.type === 'update-counter') { } else if (event.data.type === 'update-counter') {
this.counter.set(event.data.content.counter); this.counter.set(event.data.content.counter);
} else if (event.data.type === 'start-download') {
this.#startDownload(event.data.content);
} }
}); });
@ -218,6 +242,18 @@ export class AppComponent {
this.#sendMessage({ content: 'rotate-selection' }); this.#sendMessage({ content: 'rotate-selection' });
} }
createMargins() {
this.#sendMessage({ content: 'create-margins' });
}
addComment() {
this.#sendMessage({ content: 'add-comment' });
}
exportFile() {
this.#sendMessage({ content: 'export-file' });
}
async uploadImage(event: Event) { async uploadImage(event: Event) {
const input = event.target as HTMLInputElement; const input = event.target as HTMLInputElement;
if (input?.files?.length) { if (input?.files?.length) {
@ -253,4 +289,22 @@ export class AppComponent {
this.form.get('name')?.setValue(''); this.form.get('name')?.setValue('');
} }
} }
#startDownload(data: Uint8Array) {
const blob = new Blob([data], { type: 'application/octet-stream' });
// We need to start a download with this URL
const downloadURL = URL.createObjectURL(blob);
// Download
var a = document.createElement('a');
document.body.appendChild(a);
a.href = downloadURL;
a.download = 'Export.penpot';
a.click();
// Remove temporary
URL.revokeObjectURL(a.href);
a.remove();
}
} }

View file

@ -3,10 +3,10 @@
"description": "Sandbox plugin for plugins development", "description": "Sandbox plugin for plugins development",
"code": "/assets/plugin.js", "code": "/assets/plugin.js",
"permissions": [ "permissions": [
"content:read",
"content:write", "content:write",
"library:read",
"library:write", "library:write",
"user:read" "comment:write",
"user:read",
"allow:downloads"
] ]
} }

View file

@ -5,7 +5,7 @@ penpot.ui.open('Plugin name', '', {
height: 600, height: 600,
}); });
penpot.ui.onMessage<{ content: string; data: unknown }>((message) => { penpot.ui.onMessage<{ content: string; data: unknown }>(async (message) => {
if (message.content === 'close') { if (message.content === 'close') {
penpot.closePlugin(); penpot.closePlugin();
} else if (message.content === 'ready') { } else if (message.content === 'ready') {
@ -42,6 +42,12 @@ penpot.ui.onMessage<{ content: string; data: unknown }>((message) => {
mimeType: string; mimeType: string;
}; };
createImage(data, mimeType); createImage(data, mimeType);
} else if (message.content === 'create-margins') {
createMargins();
} else if (message.content === 'add-comment') {
addComment();
} else if (message.content === 'export-file') {
exportFile();
} }
}); });
@ -432,3 +438,56 @@ function createImage(data: Uint8Array, mimeType: string) {
}) })
.catch((err) => console.error(err)); .catch((err) => console.error(err));
} }
function createMargins() {
const page = penpot.currentPage;
const selected = penpot.selection && penpot.selection[0];
if (selected && penpot.utils.types.isBoard(selected)) {
const { width, height } = selected;
selected.addRulerGuide('vertical', 10);
selected.addRulerGuide('vertical', width - 10);
selected.addRulerGuide('horizontal', 10);
selected.addRulerGuide('horizontal', height - 10);
} else {
console.log('bound', penpot.viewport.bounds);
const { x, y, width, height } = penpot.viewport.bounds;
page.addRulerGuide('vertical', x + 100);
page.addRulerGuide('vertical', x + width - 50);
page.addRulerGuide('horizontal', y + 100);
page.addRulerGuide('horizontal', y + height - 50);
}
}
async function addComment() {
const shape = penpot.selection[0];
if (shape) {
const content = shape.name + ' - ' + Date.now();
const cthr = await penpot.currentPage.findCommentThreads();
const th = cthr && cthr[0];
if (th) {
const comms = await th.findComments();
const first = comms && comms[0];
if (first) {
console.log('Reply to thread', content);
th.reply(content);
}
} else {
console.log('Create new thread', content);
await penpot.currentPage.addCommentThread(content, shape.center);
}
}
}
async function exportFile() {
const data = await penpot.getFile()?.export('penpot');
if (data) {
penpot.ui.sendMessage({
type: 'start-download',
content: data,
});
}
}

View file

@ -2850,7 +2850,7 @@ export interface Page extends PluginData {
/** /**
* Removes the comment thread. * Removes the comment thread.
* Requires the `comment:read` or `comment:write` permission. * Requires the `comment:write` permission.
*/ */
removeCommentThread(commentThread: CommentThread): Promise<void>; removeCommentThread(commentThread: CommentThread): Promise<void>;

View file

@ -114,7 +114,8 @@ describe('createPluginManager', () => {
'Test Modal', 'Test Modal',
'https://example.com/plugin', 'https://example.com/plugin',
'light', 'light',
{ width: 400, height: 300 } { width: 400, height: 300 },
true
); );
expect(mockModal.setTheme).toHaveBeenCalledWith('light'); expect(mockModal.setTheme).toHaveBeenCalledWith('light');
expect(mockModal.addEventListener).toHaveBeenCalledWith( expect(mockModal.addEventListener).toHaveBeenCalledWith(