React renderer for creating PDF files on the browser and server
How to install
yarn add @react-18-pdf/renderer
How it works
import React from 'react';
import { Document, Page, Text, View, StyleSheet } from '@react-18-pdf/renderer';
const styles = StyleSheet.create({
page: {
flexDirection: 'row',
backgroundColor: '#E4E4E4'
},
section: {
margin: 10,
padding: 10,
flexGrow: 1
}
});
const MyDocument = () => (
<Document>
<Page size="A4" style={styles.page}>
<View style={styles.section}>
<Text>Section #1</Text>
</View>
<View style={styles.section}>
<Text>Section #2</Text>
</View>
</Page>
</Document>
);
Web.
Render in DOM
import React from 'react';
import ReactDOM from 'react-dom';
import { PDFViewer } from '@react-18-pdf/renderer';
const App = () => (
<PDFViewer>
<MyDocument />
</PDFViewer>
);
ReactDOM.render(<App />, document.getElementById('root'));
Node.
Save in a file
import React from 'react';
import ReactPDF from '@react-18-pdf/renderer';
ReactPDF.render(<MyDocument />, `${__dirname}/example.pdf`);
Examples
For each example, try opening output.pdf
to see the result.
Contributors
This project exists thanks to all the people who contribute. [Contribute].
data:image/s3,"s3://crabby-images/1cdf5/1cdf5b0e1128415422ada0dcdc0f2776ff4a7978" alt=""
Thank you to all our sponsors! [Become a sponsors]
data:image/s3,"s3://crabby-images/48352/48352e4a93646be5d9103577649d396a0f8684c7" alt=""
Backers
Thank you to all our backers! [Become a backer]
data:image/s3,"s3://crabby-images/a38a5/a38a5b7bac62077d6e83a27e7c6007db38f326e0" alt=""
License
MIT © Diego Muracciole
data:image/s3,"s3://crabby-images/3f052/3f05223fa1809d66ba354d28aff0324a11abf0e3" alt="FOSSA Status"
data:image/s3,"s3://crabby-images/424db/424db35137f5ba058eb3f22d45a8d0ee5e7338ec" alt=""