From 65088bf2a7dd0c5b0fad5cea5972b9e40fe66f75 Mon Sep 17 00:00:00 2001 From: Jordi Sala Morales Date: Tue, 4 Jun 2024 10:40:54 +0000 Subject: [PATCH 1/2] Improve UX for larger files, when the download also takes time to process --- .../transformers/transformDocumentNode.ts | 11 ++++--- ui-src/components/ExporterProgress.tsx | 29 ++++++++++++++----- ui-src/components/PenpotExporter.tsx | 7 +++-- 3 files changed, 33 insertions(+), 14 deletions(-) diff --git a/plugin-src/transformers/transformDocumentNode.ts b/plugin-src/transformers/transformDocumentNode.ts index 251f1c7c..b8600885 100644 --- a/plugin-src/transformers/transformDocumentNode.ts +++ b/plugin-src/transformers/transformDocumentNode.ts @@ -1,5 +1,6 @@ import { componentsLibrary } from '@plugin/ComponentLibrary'; import { imagesLibrary } from '@plugin/ImageLibrary'; +import { sleep } from '@plugin/utils'; import { PenpotDocument } from '@ui/types'; @@ -7,7 +8,7 @@ import { transformPageNode } from '.'; export const transformDocumentNode = async (node: DocumentNode): Promise => { const children = []; - let currentPage = 0; + let currentPage = 1; figma.ui.postMessage({ type: 'PROGRESS_TOTAL_PAGES', @@ -15,14 +16,16 @@ export const transformDocumentNode = async (node: DocumentNode): Promise { +type ExporterProgressProps = { + downloading: boolean; +}; + +export const ExporterProgress = ({ downloading }: ExporterProgressProps) => { const [currentNode, setCurrentNode] = useState(); const [totalPages, setTotalPages] = useState(); const [processedPages, setProcessedPages] = useState(); @@ -13,6 +17,7 @@ export const ExporterProgress = () => { setCurrentNode(event.data.pluginMessage.data as string); } else if (event.data.pluginMessage?.type === 'PROGRESS_TOTAL_PAGES') { setTotalPages(event.data.pluginMessage.data as number); + setProcessedPages(0); } else if (event.data.pluginMessage?.type === 'PROGRESS_PROCESSED_PAGES') { setProcessedPages(event.data.pluginMessage.data as number); } @@ -38,15 +43,25 @@ export const ExporterProgress = () => { - {processedPages} of {totalPages} pages exported 💪 - {currentNode ? ( + {!downloading ? ( <> + {processedPages} of {totalPages} pages exported 💪 + {currentNode ? ( + <> +
+ Currently exporting layer +
+ {'“' + truncateText(currentNode, 35) + '”'} + + ) : undefined} + + ) : ( + <> + Generating Penpot file 🚀
- Currently exporting layer -
- {'“' + truncateText(currentNode, 40) + '”'} + Please wait, this process might take a while... - ) : undefined} + )}
); diff --git a/ui-src/components/PenpotExporter.tsx b/ui-src/components/PenpotExporter.tsx index 2ac40d6d..4061d346 100644 --- a/ui-src/components/PenpotExporter.tsx +++ b/ui-src/components/PenpotExporter.tsx @@ -16,18 +16,19 @@ export const PenpotExporter = () => { const [needsReload, setNeedsReload] = useState(false); const [loading, setLoading] = useState(true); const [exporting, setExporting] = useState(false); + const [downloading, setDownloading] = useState(false); const methods = useForm(); methods.getValues(); const onMessage = (event: MessageEvent<{ pluginMessage: { type: string; data: unknown } }>) => { if (event.data.pluginMessage?.type == 'PENPOT_DOCUMENT') { + setDownloading(true); + const document = event.data.pluginMessage.data as PenpotDocument; const file = parse(document); file.export(); - - setExporting(false); } else if (event.data.pluginMessage?.type == 'CUSTOM_FONTS') { setMissingFonts(event.data.pluginMessage.data as string[]); setLoading(false); @@ -72,7 +73,7 @@ export const PenpotExporter = () => { if (loading) return ; - if (exporting) return ; + if (exporting) return ; if (needsReload) { return ( From cdd11d3ed0255b2ca5f949b84facb899e7dfc527 Mon Sep 17 00:00:00 2001 From: Jordi Sala Morales Date: Tue, 4 Jun 2024 10:41:40 +0000 Subject: [PATCH 2/2] add changelog --- .changeset/two-cougars-allow.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/two-cougars-allow.md diff --git a/.changeset/two-cougars-allow.md b/.changeset/two-cougars-allow.md new file mode 100644 index 00000000..9ca25235 --- /dev/null +++ b/.changeset/two-cougars-allow.md @@ -0,0 +1,5 @@ +--- +"penpot-exporter": minor +--- + +Add loader when generating really large files after the page processing loader