0
Fork 0
mirror of https://github.com/penpot/penpot-exporter-figma-plugin.git synced 2025-01-08 16:10:07 -05:00
penpot-exporter-figma-plugin/ui-src/components/ExporterProgress.tsx

88 lines
1.9 KiB
TypeScript
Raw Normal View History

import { LoadingIndicator } from '@create-figma-plugin/ui';
import { JSX } from 'react';
import { Steps, useFigmaContext } from '@ui/context';
import { Stack } from './Stack';
type Messages = {
total: string;
current?: string;
};
const stepMessages: Record<Steps, Messages> = {
processing: {
total: 'pages processed 💪',
current: 'Currently processing layer'
},
remote: {
total: 'remote components processed 📦',
current: 'Currently processing layer'
},
images: {
total: 'images downloaded 📸'
},
optimization: {
total: 'images optimized 📸'
},
downloading: {
total: 'Generating Penpot file 🚀',
current: 'Please wait, this process might take a while...'
}
};
const StepProgress = (): JSX.Element | null => {
const { currentItem, totalItems, processedItems, step } = useFigmaContext();
const truncateText = (text: string, maxChars: number) => {
if (text.length <= maxChars) {
return text;
}
return text.slice(0, maxChars) + '...';
};
if (!step) return null;
const currentText = stepMessages[step].current;
switch (step) {
case 'processing':
case 'remote':
case 'images':
case 'optimization':
return (
<>
{processedItems} of {totalItems} {stepMessages[step].total}
{currentItem && currentText ? (
<>
<br />
{currentText}
<br />
{'“' + truncateText(currentItem, 35) + '”'}
</>
) : undefined}
</>
);
case 'downloading':
return (
<>
{stepMessages[step].total}
<br />
{currentText}
</>
);
}
};
export const ExporterProgress = () => {
return (
<Stack space="small" horizontalAlign="center">
<LoadingIndicator />
<span style={{ textAlign: 'center' }}>
<StepProgress />
</span>
</Stack>
);
};