How to handle if the src given in docx Hyperlink image is not available.
-
Hi, We are using docx report to generate the report. But when hyperlink is given to image and if the image is not available it Throws error 'Error: Error while executing docx recipe. getaddrinfo ENOTFOUND picsm.photos\n at module.exports ...........'.
Is there any other methods I can render images ? for example with base64?
and if the image is not available can I show nothing?
-
hi! yes the image also accepts base64 input but in the shape of a base64 data uri, see this example that uses base64 data uri for the image.
-
What happens when the image is not available? It's giving Error: Error while executing docx recipe. getaddrinfo ENOTFOUND image.
Is there any way around so that I can render remaining part of the report if image is not available. Please help..its urgent
-
yes, right now it just throws an error, there is no special handling on this. perhaps we can consider implementing some kind of
fallbackSrc
when this happens, but this can also be done right now using helpers.here is link that shows how to implement a custom fallback https://playground.jsreport.net/w/anon/qM203vEC
you need to update the helper call in your hyperlink to be like this
and in your template have this helper:
const jsreport = require('jsreport-proxy') const axios = await jsreport.npm.require('axios@0.24.0') async function docxImageWithFallback (options) { const src = options.hash.src if (src.startsWith('data:')) { return src } try { console.log('sending request...') const response = await axios({ url: src, responseType: 'arraybuffer', method: 'GET' }) const contentType = response.headers['content-type'] || response.headers['Content-Type'] if (!contentType) { throw new Error(`Empty content-type for remote image at "${src}"`) } const extensionsParts = contentType.split(';')[0].split('/').filter((p) => p) if (extensionsParts.length === 0 || extensionsParts.length > 2) { throw new Error(`Invalid content-type "${contentType}" for remote image at "${src}"`) } // some servers returns the image content type without the "image/" prefix imageExtension = extensionsParts.length === 1 ? extensionsParts[0] : extensionsParts[1] imageBuffer = Buffer.from(response.data) imgDataUri = `data:image/${imageExtension};base64,${imageBuffer.toString('base64')}` } catch (err) { imgDataUri = '' } return docxImage.call(this, { ...options, hash: { ...options.hash, src: imgDataUri } }) }