0
Fork 0
mirror of https://github.com/penpot/penpot-exporter-figma-plugin.git synced 2025-01-18 05:22:28 -05:00

Move to function component (#11)

This commit is contained in:
Jordi Sala Morales 2024-04-09 10:15:21 +02:00 committed by GitHub
parent 0d10f51238
commit bbaaeaebcc
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 67 additions and 80 deletions

View file

@ -1,110 +1,97 @@
import { Component } from 'react'; import { useEffect, useState } from 'react';
import slugify from 'slugify'; import slugify from 'slugify';
import { createPenpotFile } from './converters'; import { createPenpotFile } from './converters';
import { validateFont } from './validators'; import { validateFont } from './validators';
type PenpotExporterState = { export const PenpotExporter = () => {
missingFonts: Set<string>; const [missingFonts, setMissingFonts] = useState(new Set<string>());
exporting: boolean; const [exporting, setExporting] = useState(false);
};
export default class PenpotExporter extends Component<unknown, PenpotExporterState> { const addFontWarning = (font: string) => {
state: PenpotExporterState = { setMissingFonts(missingFonts => missingFonts.add(font));
missingFonts: new Set(),
exporting: false
};
componentDidMount = () => {
window.addEventListener('message', this.onMessage);
};
componentDidUpdate = () => {
this.setDimensions();
};
componentWillUnmount = () => {
window.removeEventListener('message', this.onMessage);
};
addFontWarning(font: string) {
const newMissingFonts = this.state.missingFonts;
newMissingFonts.add(font);
this.setState(() => ({ missingFonts: newMissingFonts }));
}
onCreatePenpot = () => {
this.setState(() => ({ exporting: true }));
parent.postMessage({ pluginMessage: { type: 'export' } }, '*');
};
onCancel = () => {
parent.postMessage({ pluginMessage: { type: 'cancel' } }, '*');
}; };
// eslint-disable-next-line @typescript-eslint/no-explicit-any // eslint-disable-next-line @typescript-eslint/no-explicit-any
onMessage = (event: any) => { const onMessage = (event: any) => {
if (event.data.pluginMessage.type == 'FIGMAFILE') { if (event.data.pluginMessage.type == 'FIGMAFILE') {
const file = createPenpotFile(event.data.pluginMessage.data); const file = createPenpotFile(event.data.pluginMessage.data);
// validate file.fontNames
file.fontNames.forEach(font => { file.fontNames.forEach(font => {
if (!validateFont(font)) { if (!validateFont(font)) {
this.addFontWarning(slugify(font.family.toLowerCase())); addFontWarning(slugify(font.family.toLowerCase()));
} }
}); });
file.penpotFile.export(); file.penpotFile.export();
this.setState(() => ({ exporting: false }));
setExporting(false);
} }
}; };
setDimensions = () => { const onCreatePenpot = () => {
const isMissingFonts = this.state.missingFonts.size > 0; setExporting(true);
parent.postMessage({ pluginMessage: { type: 'export' } }, '*');
};
const onCancel = () => {
parent.postMessage({ pluginMessage: { type: 'cancel' } }, '*');
};
const setDimensions = () => {
const isMissingFonts = missingFonts.size > 0;
let width = 300; let width = 300;
let height = 280; let height = 280;
if (isMissingFonts) { if (isMissingFonts) {
height += this.state.missingFonts.size * 20; height += missingFonts.size * 20;
width = 400; width = 400;
parent.postMessage({ pluginMessage: { type: 'resize', width: width, height: height } }, '*'); parent.postMessage({ pluginMessage: { type: 'resize', width: width, height: height } }, '*');
} }
}; };
renderFontWarnings = () => { useEffect(() => {
return ( window.addEventListener('message', onMessage);
<ul>
{Array.from(this.state.missingFonts).map(font => (
<li key={font}>{font}</li>
))}
</ul>
);
};
render() { return () => {
// Update the dimensions of the plugin window based on available data and selections window.removeEventListener('message', onMessage);
return ( };
<main> }, []);
<header>
<img src={require('./logo.svg')} /> useEffect(() => {
<h2>Penpot Exporter</h2> setDimensions();
</header> }, [missingFonts]);
<section>
<div style={{ display: this.state.missingFonts.size > 0 ? 'inline' : 'none' }}> return (
<div id="missing-fonts"> <main>
{this.state.missingFonts.size} non-default font <header>
{this.state.missingFonts.size > 1 ? 's' : ''}:{' '} <img src={require('./logo.svg')} />
</div> <h2>Penpot Exporter</h2>
<small>Ensure fonts are installed in Penpot before importing.</small> </header>
<div id="missing-fonts-list">{this.renderFontWarnings()}</div> <section>
<div style={{ display: missingFonts.size > 0 ? 'inline' : 'none' }}>
<div id="missing-fonts">
{missingFonts.size} non-default font
{missingFonts.size > 1 ? 's' : ''}:{' '}
</div> </div>
</section> <small>Ensure fonts are installed in Penpot before importing.</small>
<footer> <div id="missing-fonts-list">
<button className="brand" disabled={this.state.exporting} onClick={this.onCreatePenpot}> <ul>
{this.state.exporting ? 'Exporting...' : 'Export to Penpot'} {Array.from(missingFonts).map(font => (
</button> <li key={font}>{font}</li>
<button onClick={this.onCancel}>Cancel</button> ))}
</footer> </ul>
</main> </div>
); </div>
} </section>
} <footer>
<button className="brand" disabled={exporting} onClick={onCreatePenpot}>
{exporting ? 'Exporting...' : 'Export to Penpot'}
</button>
<button onClick={onCancel}>Cancel</button>
</footer>
</main>
);
};

View file

@ -1,7 +1,7 @@
import { StrictMode } from 'react'; import { StrictMode } from 'react';
import { createRoot } from 'react-dom/client'; import { createRoot } from 'react-dom/client';
import PenpotExporter from './PenpotExporter'; import { PenpotExporter } from './PenpotExporter';
import './ui.css'; import './ui.css';
createRoot(document.getElementById('penpot-export-page') as HTMLElement).render( createRoot(document.getElementById('penpot-export-page') as HTMLElement).render(