import { Banner, Button, IconInfo32, LoadingIndicator } from '@create-figma-plugin/ui'; import { useEffect, useState } from 'react'; import { FormProvider, useForm } from 'react-hook-form'; import { Stack } from '@ui/components/Stack'; import { parse } from '@ui/parser'; import { PenpotDocument } from '@ui/types'; import { ExporterProgress } from './ExporterProgress'; import { MissingFontsSection } from './MissingFontsSection'; type FormValues = Record; export const PenpotExporter = () => { const [missingFonts, setMissingFonts] = useState(); const [needsReload, setNeedsReload] = useState(false); const [loading, setLoading] = useState(true); const [exporting, setExporting] = useState(false); const methods = useForm(); methods.getValues(); const onMessage = (event: MessageEvent<{ pluginMessage: { type: string; data: unknown } }>) => { if (event.data.pluginMessage?.type == 'PENPOT_DOCUMENT') { 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); setNeedsReload(false); } else if (event.data.pluginMessage?.type == 'CHANGES_DETECTED') { setNeedsReload(true); } }; const exportPenpot = (data: FormValues) => { setExporting(true); parent.postMessage( { pluginMessage: { type: 'export', data } }, '*' ); }; const cancel = () => { parent.postMessage({ pluginMessage: { type: 'cancel' } }, '*'); }; const reload = () => { setLoading(true); parent.postMessage({ pluginMessage: { type: 'reload' } }, '*'); }; useEffect(() => { window.addEventListener('message', onMessage); parent.postMessage({ pluginMessage: { type: 'ready' } }, '*'); return () => { window.removeEventListener('message', onMessage); }; }, []); if (loading) return ; if (exporting) return ; if (needsReload) { return ( }> Changes detected. Please reload the plug-in to ensure all modifications are included in the exported file. ); } return (
); };