1.2.127 • Published 9 months ago

@ballerine/react-pdf-toolkit v1.2.127

Weekly downloads
-
License
-
Repository
-
Last release
9 months ago

react-pdf-toolkit

react-pdf-toolkit is a package for generating PDF documents in React applications. Built on top of @react-pdf/renderer, it uses Tailwind CSS for styling, providing a set of components that simplify PDF creation.

Features

  • Core Integration: Utilizes @react-pdf/renderer for robust PDF rendering capabilities.
  • Tailwind CSS Styling: Applies Tailwind CSS for styling, ensuring a seamless and efficient design workflow.
  • Component-Based: Offers a collection of reusable components for quick and efficient PDF creation.

Components

  • Badge

  • Divider

  • Image

  • Link

  • Typography

  • List

Utils

tw - wrapper which converts tailwind classes to pdf styles.

Example:

tw('flex flex-row gap-4')

mergeStyles - merges set of style objects in to single one.

mergeStyles([tw('flex'), tw('flex-row')]) // {display: 'flex', flexDirection: 'row'}

sanitizeString - Removes emoji from string value.

toTitleCase - Converts string to Title case format.

Hocs

withDataValidation - Component wrapper to perform validation. Wraps provided component and performs validation. Accepts json schema or Typebox output.

import { Type } from "@sinclair/typebox";
import { Page, View } from "@react-pdf/renderer";
import {Typography} from "@ballerine/react-pdf-toolkit"

const Schema =  Type.Object({
title: Type.String()
});

interface IPDFElementProps {
	 data: Static<typeof Schema>
}

const PDFElement = withDataValidation(({data}) =>
<Page>
	<View>
		<Typography>{data.title}</Typography>
	</View>
</Page>,
Schema) // Will throw exception in case if props.data doesnt match schema.

Installation

pnpm install @ballerine/react-pdf-toolkit

Example PDF

import { Page, View, Document } from '@react-pdf/renderer';
import {Typography} from '@ballerine/react-pdf-toolkit'

const Example = () => {
	return <Document>
		<Page>
		<View style={tw('flex flex-col')}>
			<Typography weight="bold" size="heading">Hello world!</Typography>
			<View>
				<Typography>I am PDF document.</Typography>
			</View>
		</View>
		</Page>
	</Document>
}
1.2.81

12 months ago

1.2.82

12 months ago

1.2.80

12 months ago

1.2.85

12 months ago

1.2.86

12 months ago

1.2.83

12 months ago

1.2.84

12 months ago

1.2.89

12 months ago

1.2.87

12 months ago

1.2.88

12 months ago

1.2.92

11 months ago

1.2.93

11 months ago

1.2.90

12 months ago

1.2.91

12 months ago

1.2.96

11 months ago

1.2.97

11 months ago

1.2.94

11 months ago

1.2.95

11 months ago

1.2.98

11 months ago

1.2.99

11 months ago

1.2.60

1 year ago

1.2.63

1 year ago

1.2.64

1 year ago

1.2.61

1 year ago

1.2.62

1 year ago

1.2.67

1 year ago

1.2.68

1 year ago

1.2.65

1 year ago

1.2.66

1 year ago

1.2.69

1 year ago

1.2.70

1 year ago

1.2.71

1 year ago

1.2.74

1 year ago

1.2.75

1 year ago

1.2.72

1 year ago

1.2.73

1 year ago

1.2.78

1 year ago

1.2.79

1 year ago

1.2.76

1 year ago

1.2.77

1 year ago

1.2.41

1 year ago

1.2.42

1 year ago

1.2.45

1 year ago

1.2.46

1 year ago

1.2.43

1 year ago

1.2.44

1 year ago

1.2.49

1 year ago

1.2.47

1 year ago

1.2.48

1 year ago

1.2.101

11 months ago

1.2.100

11 months ago

1.2.103

11 months ago

1.2.102

11 months ago

1.2.105

11 months ago

1.2.104

11 months ago

1.2.107

10 months ago

1.2.106

11 months ago

1.2.52

1 year ago

1.2.53

1 year ago

1.2.50

1 year ago

1.2.51

1 year ago

1.2.56

1 year ago

1.2.57

1 year ago

1.2.54

1 year ago

1.2.55

1 year ago

1.2.58

1 year ago

1.2.59

1 year ago

1.2.112

10 months ago

1.2.111

10 months ago

1.2.114

10 months ago

1.2.113

10 months ago

1.2.116

9 months ago

1.2.115

9 months ago

1.2.118

9 months ago

1.2.117

9 months ago

1.2.110

10 months ago

1.2.109

10 months ago

1.2.108

10 months ago

1.2.123

9 months ago

1.2.122

9 months ago

1.2.125

9 months ago

1.2.124

9 months ago

1.2.127

9 months ago

1.2.126

9 months ago

1.2.120

9 months ago

1.2.119

9 months ago

1.2.40

1 year ago

1.2.39

1 year ago

1.2.34

1 year ago

1.2.35

1 year ago

1.2.33

1 year ago

1.2.38

1 year ago

1.2.36

1 year ago

1.2.37

1 year ago

1.2.19

1 year ago

1.2.20

1 year ago

1.2.23

1 year ago

1.2.24

1 year ago

1.2.21

1 year ago

1.2.22

1 year ago

1.2.27

1 year ago

1.2.28

1 year ago

1.2.25

1 year ago

1.2.26

1 year ago

1.2.29

1 year ago

1.2.30

1 year ago

1.2.31

1 year ago

1.2.32

1 year ago

1.2.18

2 years ago

1.2.8

2 years ago

1.2.6

2 years ago

1.2.5

2 years ago

1.2.4

2 years ago

1.2.3

2 years ago

1.2.9

2 years ago

1.2.12

2 years ago

1.2.13

2 years ago

1.2.10

2 years ago

1.2.11

2 years ago

1.2.16

2 years ago

1.2.17

2 years ago

1.2.14

2 years ago

1.2.15

2 years ago

1.2.2

2 years ago

1.2.1

2 years ago

1.1.0

2 years ago

1.0.16

2 years ago

1.0.15

2 years ago

1.0.14

2 years ago

1.0.13

2 years ago

1.0.12

2 years ago

1.0.11

2 years ago

1.0.10

2 years ago

1.0.9

2 years ago

1.0.8

2 years ago

1.0.7

2 years ago

1.0.6

2 years ago

1.0.5

2 years ago

1.0.4

2 years ago

1.0.3

2 years ago

1.0.2

2 years ago

1.0.1

2 years ago

1.0.0

2 years ago

0.0.1

2 years ago