Search
 
SCRIPT & CODE EXAMPLE
 

JAVASCRIPT

react open pdf in new tab

<a href='/api/v1/print/example.pdf' target='_blank' rel='noopener noreferrer'>
Comment

react open pdf in new tab

Server:________________________________________

const express = require('express')
const router = express.Router()

const puppeteer = require('puppeteer')

const generatePDF = async (html = '') => {
  const browser = await puppeteer.launch()
  const page = await browser.newPage()
  await page.setContent(html, { waitUntil: 'networkidle0' })
  const pdfBuffer = await page.pdf({ format: 'a4' })

  await page.close()
  await browser.close()

  return pdfBuffer
}

router.post('/', async (req, res) => {
  // console.log(req.body)
  const pdf = await generatePDF(req.body.html)
  // res.contentType('application/pdf')
  res.set({ 'Content-Type': 'application/pdf', 'Content-Length': pdf.length })
  res.send(pdf)
})

module.exports = router

Client:___________________________________________________

const GeneratePDF = () => {
const names = ['John', 'Alexander', ' Alex', 'Allan', 'Jacob']

  const renderRows = (names) => {
    return (
      <ul>
        {names.map((row, index) => {
          return (
            <li key={index}>
              <p>{row}</p>
            </li>
          )
        })}
      </ul>
    )
  }

  const pdfClickHandler = async () => {
    const html = ReactDOMServer.renderToStaticMarkup(renderRows(names))
    try {
      const response = await axios.post(
        '/api/services/pdf',
        { html },
        {
          responseType: 'arraybuffer',
          headers: {
            Accept: 'application/pdf',
          },
        }
      )

      const file = new Blob([response.data], { type: 'application/pdf' })

      const fileURL = URL.createObjectURL(file)

      const pdfWindow = window.open()

      pdfWindow.location.href = fileURL

    } catch (err) {
      console.log(err.messaes)
    }
  }

  return (  
      <Button variant='contained' onClick={pdfClickHandler}>
        Generate PDF
      </Button>
  )
}

export default GeneratePDF
Comment

PREVIOUS NEXT
Code Example
Javascript :: How to remove title in material-table 
Javascript :: javascript get image width and height 
Javascript :: How to write inside a div using javascript 
Javascript :: useeffect with cleanup 
Javascript :: prevent multiple form submissions javascript 
Javascript :: javascript string to float 
Javascript :: jquery find children not working 
Javascript :: foreach reverse javascript 
Javascript :: how to add two attay into object in javascript 
Javascript :: get date javascript 
Javascript :: javascript integer to string 
Javascript :: discord.js v13 client 
Javascript :: how to reset node command prompt 
Javascript :: check if any property of object is null javascript 
Javascript :: convert file to blob in angular 
Javascript :: remove array item from localStorage 
Javascript :: javascript allow only numeric characters 
Javascript :: javascript click coordinates on page 
Javascript :: javascript base 10 to base 2 
Javascript :: how to hide component in react 
Javascript :: javascript on keypu 
Javascript :: export html table data to excel using javascript 
Javascript :: createrouter vue 3 history remove Hash 
Javascript :: append element in a div as first child 
Javascript :: jquery noconflict 
Javascript :: get data from url in angular 
Javascript :: what are native node modules 
Javascript :: compare 2 array element 
Javascript :: window bind load jquery 
Javascript :: ajax done 
ADD CONTENT
Topic
Content
Source link
Name
6+4 =