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
}
})
}