@lighthouse/common 4.38.0-canary-3 → 4.38.0-canary-5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -53,11 +53,11 @@ function fetchImage(url, options = {}) {
53
53
  if (shouldUseCloudfront && isWebContext) {
54
54
  const {
55
55
  Signature,
56
- Expires,
56
+ Policy,
57
57
  KeyPairId
58
58
  } = options;
59
59
  const firstParamConnector = new URL(url).searchParams.size > 0 ? '&' : '?';
60
- const urlToEncode = `${url}${firstParamConnector}Signature=${Signature}&Expires=${Expires}&Key-Pair-Id=${KeyPairId}`;
60
+ const urlToEncode = `${url}${firstParamConnector}Signature=${Signature}&Policy=${Policy}&Key-Pair-Id=${KeyPairId}`;
61
61
  const encodedUrl = encodeURI(urlToEncode);
62
62
  console.info('Fetching image via CloudFront For Web');
63
63
  return fetch(encodedUrl).then(response => {
@@ -35,7 +35,7 @@ const fetchImageForPdfGeneratorService = async function (url) {
35
35
 
36
36
  const key = url.split(applicationId)[1];
37
37
  const alreadyTransformedImage = await fetchResourceFromS3({
38
- bucketName: process.env.TRANSFORMED_IMAGES_S3_BUCKET,
38
+ bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,
39
39
  key
40
40
  });
41
41
 
@@ -58,7 +58,7 @@ const fetchImageForPdfGeneratorService = async function (url) {
58
58
 
59
59
  if (redirectLocation) {
60
60
  const newlyTransformedImage = await fetchResourceFromS3({
61
- bucketName: process.env.TRANSFORMED_IMAGES_S3_BUCKET,
61
+ bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,
62
62
  key
63
63
  });
64
64
  console.log('Image successfully fetched from S3 at:', redirectLocation);
@@ -26,7 +26,7 @@ const buildAuditContent = _bluebird.default.method((items, settings = {}) => {
26
26
  }) => {
27
27
  return (0, _helpers.fetchImage)(assetUrl, {
28
28
  Signature: settings.Signature,
29
- Expires: settings.Expires,
29
+ Policy: settings.Policy,
30
30
  KeyPairId: settings.KeyPairId
31
31
  }).then(base64String => ({
32
32
  alignment: 'center',
@@ -9,7 +9,7 @@ var _helpers = require("../../../helpers");
9
9
 
10
10
  function defaultFooter({
11
11
  Signature,
12
- Expires,
12
+ Policy,
13
13
  KeyPairId,
14
14
  logoUrl,
15
15
  timestamp,
@@ -27,7 +27,7 @@ function defaultFooter({
27
27
 
28
28
  return (0, _helpers.fetchImage)(logoUrl, {
29
29
  Signature,
30
- Expires,
30
+ Policy,
31
31
  KeyPairId,
32
32
  isHeader: true
33
33
  }).then(image => _page => ({
@@ -9,7 +9,7 @@ var _helpers = require("../../../helpers");
9
9
 
10
10
  function defaultHeader({
11
11
  Signature,
12
- Expires,
12
+ Policy,
13
13
  KeyPairId,
14
14
  logoUrl,
15
15
  timestamp,
@@ -23,7 +23,7 @@ function defaultHeader({
23
23
  });
24
24
  return (0, _helpers.fetchImage)(logoUrl, {
25
25
  Signature,
26
- Expires,
26
+ Policy,
27
27
  KeyPairId,
28
28
  isHeader: true
29
29
  }).then(image => ({
@@ -53,7 +53,7 @@ function buildImage(options) {
53
53
  cloudinaryBaseUrl,
54
54
  cloudfrontBaseUrl,
55
55
  Signature,
56
- Expires,
56
+ Policy,
57
57
  KeyPairId
58
58
  } = settings || {};
59
59
  const isVideoType = new RegExp('.mp4$').test(filepath);
@@ -79,7 +79,7 @@ function buildImage(options) {
79
79
  });
80
80
  return (0, _helpers.fetchImage)(url, {
81
81
  Signature,
82
- Expires,
82
+ Policy,
83
83
  KeyPairId
84
84
  }).then(base64String => ({
85
85
  alignment,
@@ -264,7 +264,7 @@ function buildTemplateFieldRow({
264
264
  if (!value) return [labelText, ''];
265
265
  return (0, _helpers.fetchImage)(value, {
266
266
  Signature: settings.Signature,
267
- Expires: settings.Expires,
267
+ Policy: settings.Policy,
268
268
  KeyPairId: settings.KeyPairId
269
269
  }).then(base64String => {
270
270
  const values = {
@@ -40,10 +40,10 @@ export function fetchImage(url) {
40
40
 
41
41
  if (shouldUseCloudfront && isWebContext) {
42
42
  var Signature = options.Signature,
43
- Expires = options.Expires,
43
+ Policy = options.Policy,
44
44
  KeyPairId = options.KeyPairId;
45
45
  var firstParamConnector = new URL(url).searchParams.size > 0 ? '&' : '?';
46
- var urlToEncode = "".concat(url).concat(firstParamConnector, "Signature=").concat(Signature, "&Expires=").concat(Expires, "&Key-Pair-Id=").concat(KeyPairId);
46
+ var urlToEncode = "".concat(url).concat(firstParamConnector, "Signature=").concat(Signature, "&Policy=").concat(Policy, "&Key-Pair-Id=").concat(KeyPairId);
47
47
 
48
48
  var _encodedUrl = encodeURI(urlToEncode);
49
49
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/fetch-image/index.js"],"names":["atob","btoa","fetchPonyfill","Promise","LIGHTHOUSE_LOGO_URL","imageNotFound","fetchImageForPdfGeneratorService","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","isWebContext","window","isHeader","shouldUseCloudfront","includes","Signature","Expires","KeyPairId","firstParamConnector","URL","searchParams","size","urlToEncode","encodedUrl","encodeURI","console","info","then","response","contentHeader","headers","get","contentType","reject","Error","ok","imageType","arrayBuffer","buffer","base64Flag","imageStr","arrayBufferToBase64","base64","isValid","validateBase64Image","catch","error","fetchOptions","binary","bytes","slice","call","Uint8Array","forEach","b","String","fromCharCode","base64String","isJpeg","startsWith","validateJpegImage","isPng","validatePngImage","base64string","src","imageData","from","replace","c","charCodeAt","imageCorrupted","length","sequence","i"],"mappings":"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","sourcesContent":["import { atob, btoa } from '@lighthouse/abab'\nimport fetchPonyfill from 'fetch-ponyfill'\nimport Promise from 'bluebird'\nimport { LIGHTHOUSE_LOGO_URL } from '../../constants'\nimport { imageNotFound } from '../../images'\nimport { fetchImageForPdfGeneratorService } from '../fetch-image-for-pdf-generator-service'\n\n// NOTE use the native fetch if it's available in the browser, because the\n// ponyfill (which actually uses the github polyfill) does not support all the\n// same options as native fetch\nconst fetch =\n (typeof self === 'object' && self.fetch) || fetchPonyfill({ Promise }).fetch\n\nconst contentTypes = {\n 'image/png': 'png',\n 'image/jpeg': 'jpeg',\n}\n\nconst defaultOptions = {\n // NOTE The cache: no-cache option is important to avoid an issue with CORS\n // and caching on Chrome. Here's a good explanation of the issue:\n // https://stackoverflow.com/a/37455118\n // In our case, when loading the web version of a form, the signature image is\n // cached without the correct CORS headers. If the pdf is then generated,\n // there's a mismatch between the cached image headers and the CORS headers\n // sent from the fetch request, causing an error\n cache: 'no-cache',\n}\n\nexport function fetchImage(url, options = {}) {\n const isWebContext = typeof window === 'object'\n\n const { isHeader = false } = options\n\n const shouldUseCloudfront = url && url.includes('.cloudfront.net')\n\n if (shouldUseCloudfront && isWebContext) {\n const { Signature, Expires, KeyPairId } = options\n\n const firstParamConnector = new URL(url).searchParams.size > 0 ? '&' : '?'\n const urlToEncode = `${url}${firstParamConnector}Signature=${Signature}&Expires=${Expires}&Key-Pair-Id=${KeyPairId}`\n\n const encodedUrl = encodeURI(urlToEncode)\n\n console.info('Fetching image via CloudFront For Web')\n\n return fetch(encodedUrl)\n .then(response => {\n const contentHeader = response.headers.get('content-length')\n const contentType = response.headers.get('content-type')\n\n // NOTE: the response will be ok but we won't be able to render any\n // image meaning pdfmake will error. Raise error here and return early.\n if (contentHeader === '0') {\n return Promise.reject(\n new Error(\n `Failed to fetch image as no content length: ${encodedUrl}`\n )\n )\n }\n\n if (!response.ok) {\n return Promise.reject(\n new Error(`Failed to fetch image: ${encodedUrl}`)\n )\n }\n\n const imageType = contentTypes[contentType]\n\n return response.arrayBuffer().then(buffer => ({\n buffer,\n imageType,\n }))\n })\n .then(({ buffer, imageType }) => {\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(buffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (!isValid) {\n return Promise.reject(new Error('InvalidImageError'))\n }\n\n return base64\n })\n .catch(error => {\n if (isHeader) {\n // NOTE: Replace failed headers with LH logo\n console.error('FetchImageHeaderError', error)\n return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions)\n }\n\n console.error(error)\n return imageNotFound\n })\n } else if (shouldUseCloudfront && !isWebContext) {\n return fetchImageForPdfGeneratorService(url)\n }\n\n const encodedUrl = encodeURI(url)\n\n const fetchOptions = {\n ...defaultOptions,\n ...options,\n headers: {\n ...(options.headers || {}),\n },\n }\n\n return fetch(encodedUrl, fetchOptions)\n .then(response => {\n const contentHeader = response.headers.get('content-length')\n const contentType = response.headers.get('content-type')\n\n // NOTE: the response will be ok but we won't be able to render any\n // image meaning pdfmake will error. Raise error here and return early.\n if (contentHeader === '0') {\n return Promise.reject(\n new Error(`Failed to fetch image as no content length: ${encodedUrl}`)\n )\n }\n\n if (!response.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${encodedUrl}`))\n }\n\n const imageType = contentTypes[contentType]\n\n return response.arrayBuffer().then(buffer => ({\n buffer,\n imageType,\n }))\n })\n .then(({ buffer, imageType }) => {\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(buffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (!isValid) {\n return Promise.reject(new Error('InvalidImageError'))\n }\n\n return base64\n })\n .catch(error => {\n if (isHeader) {\n // NOTE: Replace failed headers with LH logo\n console.error('FetchImageHeaderError', error)\n return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions)\n }\n\n console.error(error)\n return imageNotFound\n })\n}\n\nfunction arrayBufferToBase64(buffer) {\n let binary = ''\n const bytes = [].slice.call(new Uint8Array(buffer))\n\n bytes.forEach(b => (binary += String.fromCharCode(b)))\n\n return btoa(binary)\n}\n\nexport function validateBase64Image(base64String) {\n const isJpeg = base64String.startsWith('data:image/jpeg;base64,')\n\n if (isJpeg) return validateJpegImage(base64String)\n\n const isPng = base64String.startsWith('data:image/png;base64,')\n\n if (isPng) return validatePngImage(base64String)\n\n return false\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validateJpegImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/jpeg;base64,', '')),\n c => c.charCodeAt(0)\n )\n const imageCorrupted =\n imageData[imageData.length - 1] === 217 &&\n imageData[imageData.length - 2] === 255\n\n return imageCorrupted\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validatePngImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/png;base64,', '')),\n c => c.charCodeAt(0)\n )\n const sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130] // in hex:\n\n //check last 12 elements of array so they contains needed values\n for (let i = 12; i > 0; i--) {\n if (imageData[imageData.length - i] !== sequence[12 - i]) {\n return false\n }\n }\n\n return true\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/helpers/fetch-image/index.js"],"names":["atob","btoa","fetchPonyfill","Promise","LIGHTHOUSE_LOGO_URL","imageNotFound","fetchImageForPdfGeneratorService","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","isWebContext","window","isHeader","shouldUseCloudfront","includes","Signature","Policy","KeyPairId","firstParamConnector","URL","searchParams","size","urlToEncode","encodedUrl","encodeURI","console","info","then","response","contentHeader","headers","get","contentType","reject","Error","ok","imageType","arrayBuffer","buffer","base64Flag","imageStr","arrayBufferToBase64","base64","isValid","validateBase64Image","catch","error","fetchOptions","binary","bytes","slice","call","Uint8Array","forEach","b","String","fromCharCode","base64String","isJpeg","startsWith","validateJpegImage","isPng","validatePngImage","base64string","src","imageData","from","replace","c","charCodeAt","imageCorrupted","length","sequence","i"],"mappings":"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","sourcesContent":["import { atob, btoa } from '@lighthouse/abab'\nimport fetchPonyfill from 'fetch-ponyfill'\nimport Promise from 'bluebird'\nimport { LIGHTHOUSE_LOGO_URL } from '../../constants'\nimport { imageNotFound } from '../../images'\nimport { fetchImageForPdfGeneratorService } from '../fetch-image-for-pdf-generator-service'\n\n// NOTE use the native fetch if it's available in the browser, because the\n// ponyfill (which actually uses the github polyfill) does not support all the\n// same options as native fetch\nconst fetch =\n (typeof self === 'object' && self.fetch) || fetchPonyfill({ Promise }).fetch\n\nconst contentTypes = {\n 'image/png': 'png',\n 'image/jpeg': 'jpeg',\n}\n\nconst defaultOptions = {\n // NOTE The cache: no-cache option is important to avoid an issue with CORS\n // and caching on Chrome. Here's a good explanation of the issue:\n // https://stackoverflow.com/a/37455118\n // In our case, when loading the web version of a form, the signature image is\n // cached without the correct CORS headers. If the pdf is then generated,\n // there's a mismatch between the cached image headers and the CORS headers\n // sent from the fetch request, causing an error\n cache: 'no-cache',\n}\n\nexport function fetchImage(url, options = {}) {\n const isWebContext = typeof window === 'object'\n\n const { isHeader = false } = options\n\n const shouldUseCloudfront = url && url.includes('.cloudfront.net')\n\n if (shouldUseCloudfront && isWebContext) {\n const { Signature, Policy, KeyPairId } = options\n\n const firstParamConnector = new URL(url).searchParams.size > 0 ? '&' : '?'\n const urlToEncode = `${url}${firstParamConnector}Signature=${Signature}&Policy=${Policy}&Key-Pair-Id=${KeyPairId}`\n\n const encodedUrl = encodeURI(urlToEncode)\n\n console.info('Fetching image via CloudFront For Web')\n\n return fetch(encodedUrl)\n .then(response => {\n const contentHeader = response.headers.get('content-length')\n const contentType = response.headers.get('content-type')\n\n // NOTE: the response will be ok but we won't be able to render any\n // image meaning pdfmake will error. Raise error here and return early.\n if (contentHeader === '0') {\n return Promise.reject(\n new Error(\n `Failed to fetch image as no content length: ${encodedUrl}`\n )\n )\n }\n\n if (!response.ok) {\n return Promise.reject(\n new Error(`Failed to fetch image: ${encodedUrl}`)\n )\n }\n\n const imageType = contentTypes[contentType]\n\n return response.arrayBuffer().then(buffer => ({\n buffer,\n imageType,\n }))\n })\n .then(({ buffer, imageType }) => {\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(buffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (!isValid) {\n return Promise.reject(new Error('InvalidImageError'))\n }\n\n return base64\n })\n .catch(error => {\n if (isHeader) {\n // NOTE: Replace failed headers with LH logo\n console.error('FetchImageHeaderError', error)\n return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions)\n }\n\n console.error(error)\n return imageNotFound\n })\n } else if (shouldUseCloudfront && !isWebContext) {\n return fetchImageForPdfGeneratorService(url)\n }\n\n const encodedUrl = encodeURI(url)\n\n const fetchOptions = {\n ...defaultOptions,\n ...options,\n headers: {\n ...(options.headers || {}),\n },\n }\n\n return fetch(encodedUrl, fetchOptions)\n .then(response => {\n const contentHeader = response.headers.get('content-length')\n const contentType = response.headers.get('content-type')\n\n // NOTE: the response will be ok but we won't be able to render any\n // image meaning pdfmake will error. Raise error here and return early.\n if (contentHeader === '0') {\n return Promise.reject(\n new Error(`Failed to fetch image as no content length: ${encodedUrl}`)\n )\n }\n\n if (!response.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${encodedUrl}`))\n }\n\n const imageType = contentTypes[contentType]\n\n return response.arrayBuffer().then(buffer => ({\n buffer,\n imageType,\n }))\n })\n .then(({ buffer, imageType }) => {\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(buffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (!isValid) {\n return Promise.reject(new Error('InvalidImageError'))\n }\n\n return base64\n })\n .catch(error => {\n if (isHeader) {\n // NOTE: Replace failed headers with LH logo\n console.error('FetchImageHeaderError', error)\n return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions)\n }\n\n console.error(error)\n return imageNotFound\n })\n}\n\nfunction arrayBufferToBase64(buffer) {\n let binary = ''\n const bytes = [].slice.call(new Uint8Array(buffer))\n\n bytes.forEach(b => (binary += String.fromCharCode(b)))\n\n return btoa(binary)\n}\n\nexport function validateBase64Image(base64String) {\n const isJpeg = base64String.startsWith('data:image/jpeg;base64,')\n\n if (isJpeg) return validateJpegImage(base64String)\n\n const isPng = base64String.startsWith('data:image/png;base64,')\n\n if (isPng) return validatePngImage(base64String)\n\n return false\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validateJpegImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/jpeg;base64,', '')),\n c => c.charCodeAt(0)\n )\n const imageCorrupted =\n imageData[imageData.length - 1] === 217 &&\n imageData[imageData.length - 2] === 255\n\n return imageCorrupted\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validatePngImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/png;base64,', '')),\n c => c.charCodeAt(0)\n )\n const sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130] // in hex:\n\n //check last 12 elements of array so they contains needed values\n for (let i = 12; i > 0; i--) {\n if (imageData[imageData.length - i] !== sequence[12 - i]) {\n return false\n }\n }\n\n return true\n}\n"],"file":"index.js"}
@@ -40,7 +40,7 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
40
40
  key = url.split(applicationId)[1];
41
41
  _context.next = 10;
42
42
  return fetchResourceFromS3({
43
- bucketName: process.env.TRANSFORMED_IMAGES_S3_BUCKET,
43
+ bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
44
44
  key: key
45
45
  });
46
46
 
@@ -80,7 +80,7 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
80
80
 
81
81
  _context.next = 27;
82
82
  return fetchResourceFromS3({
83
- bucketName: process.env.TRANSFORMED_IMAGES_S3_BUCKET,
83
+ bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
84
84
  key: key
85
85
  });
86
86
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/fetch-image-for-pdf-generator-service/index.js"],"names":["AWS","REGION","process","env","AWS_REGION","lambda","Lambda","region","s3","S3","fetchImageForPdfGeneratorService","url","console","info","Error","urlMatch","match","applicationId","key","split","fetchResourceFromS3","bucketName","TRANSFORMED_IMAGES_S3_BUCKET","alreadyTransformedImage","body","toString","requestImageTransformation","transformerResponse","statusCode","log","redirectLocation","headers","Location","newlyTransformedImage","lambdaEvent","requestContext","http","method","path","params","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","invoke","promise","result","response","parse","errorMessage","message","error","Bucket","Key","getObject","Body","contentType","ContentType","contentLength","ContentLength","lastModified","LastModified","etag","ETag","code"],"mappings":"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","sourcesContent":["import AWS from 'aws-sdk'\n\nconst REGION = process.env.AWS_REGION\n\nconst lambda = new AWS.Lambda({\n region: REGION,\n})\nconst s3 = new AWS.S3({\n region: REGION,\n})\n\nexport const fetchImageForPdfGeneratorService = async function(url) {\n console.info(\n 'Fetching image via CloudFront For Serverless Pdf Generator Service'\n )\n\n if (!url) {\n throw new Error('URL is required to fetch image for PDF generator service')\n }\n\n const urlMatch = url && url.match(/([a-f0-9]{24})\\//)\n const applicationId = urlMatch && urlMatch[1]\n\n if (!applicationId) {\n throw new Error('Requestor has insufficient permissions')\n }\n\n const key = url.split(applicationId)[1]\n\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: process.env.TRANSFORMED_IMAGES_S3_BUCKET,\n key,\n })\n\n if (alreadyTransformedImage && alreadyTransformedImage.body) {\n return alreadyTransformedImage.body.toString('base64')\n }\n\n const transformerResponse = await requestImageTransformation(key)\n\n const statusCode = transformerResponse.statusCode\n\n switch (statusCode) {\n case 200:\n console.log('Image transformation successful')\n return transformerResponse.body\n case 302: {\n console.log(\n 'Image transformation successful but image is too big for lambda delivery, fetching directly from S3'\n )\n const redirectLocation = transformerResponse.headers?.Location\n if (redirectLocation) {\n const newlyTransformedImage = await fetchResourceFromS3({\n bucketName: process.env.TRANSFORMED_IMAGES_S3_BUCKET,\n key,\n })\n console.log('Image successfully fetched from S3 at:', redirectLocation)\n\n return newlyTransformedImage.body.toString('base64')\n }\n throw new Error('Redirect response received but no location provided')\n }\n case 400:\n throw new Error(\n `Bad request to image transformer: ${transformerResponse.body}`\n )\n case 403:\n throw new Error('Requested transformed image is too big')\n case 404:\n throw new Error('The requested image does not exist')\n case 500:\n throw new Error(\n `Image transformation failed: ${transformerResponse.body}`\n )\n default:\n throw new Error(\n `Unexpected response from image transformer: ${statusCode} - ${transformerResponse.body}`\n )\n }\n}\n\nexport async function requestImageTransformation(key) {\n if (!key) {\n throw new Error('Image Path is required for image transformation')\n }\n\n console.log(\n 'ImageTransformation: Invoking image transformer lambda for path:',\n key\n )\n\n const lambdaEvent = {\n requestContext: {\n http: {\n method: 'GET',\n path: key,\n },\n },\n }\n\n const params = {\n FunctionName: process.env.IMAGE_TRANSFORMER_ARN,\n InvocationType: 'RequestResponse',\n Payload: JSON.stringify(lambdaEvent),\n }\n\n try {\n const result = await lambda.invoke(params).promise()\n\n const response = JSON.parse(result.Payload)\n\n return response\n } catch (error) {\n const errorMessage = `Failed to invoke image transformer lambda: ${error.message}`\n console.error(errorMessage, error)\n throw new Error(errorMessage)\n }\n}\n\nexport async function fetchResourceFromS3({ bucketName, key }) {\n console.log(\n `Fetching resource from S3 Bucket: '${bucketName}' at path: '${key}'`\n )\n if (!bucketName || !key) {\n throw new Error(\n 'bucketName and key are required for S3 resource fetch ' +\n JSON.stringify({ bucketName, key })\n )\n }\n\n const params = {\n Bucket: bucketName,\n Key: key,\n }\n\n try {\n const result = await s3.getObject(params).promise()\n\n return {\n body: result.Body,\n contentType: result.ContentType,\n contentLength: result.ContentLength,\n lastModified: result.LastModified,\n etag: result.ETag,\n }\n } catch (error) {\n if (error.code !== 'NoSuchKey') {\n throw new Error(`Failed to fetch image: ${bucketName}/${key}`)\n }\n\n console.log('Image not found in transformed bucket, invoking transformer')\n }\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/helpers/fetch-image-for-pdf-generator-service/index.js"],"names":["AWS","REGION","process","env","AWS_REGION","lambda","Lambda","region","s3","S3","fetchImageForPdfGeneratorService","url","console","info","Error","urlMatch","match","applicationId","key","split","fetchResourceFromS3","bucketName","S3_BUCKET_UPLOADS","alreadyTransformedImage","body","toString","requestImageTransformation","transformerResponse","statusCode","log","redirectLocation","headers","Location","newlyTransformedImage","lambdaEvent","requestContext","http","method","path","params","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","invoke","promise","result","response","parse","errorMessage","message","error","Bucket","Key","getObject","Body","contentType","ContentType","contentLength","ContentLength","lastModified","LastModified","etag","ETag","code"],"mappings":"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","sourcesContent":["import AWS from 'aws-sdk'\n\nconst REGION = process.env.AWS_REGION\n\nconst lambda = new AWS.Lambda({\n region: REGION,\n})\nconst s3 = new AWS.S3({\n region: REGION,\n})\n\nexport const fetchImageForPdfGeneratorService = async function(url) {\n console.info(\n 'Fetching image via CloudFront For Serverless Pdf Generator Service'\n )\n\n if (!url) {\n throw new Error('URL is required to fetch image for PDF generator service')\n }\n\n const urlMatch = url && url.match(/([a-f0-9]{24})\\//)\n const applicationId = urlMatch && urlMatch[1]\n\n if (!applicationId) {\n throw new Error('Requestor has insufficient permissions')\n }\n\n const key = url.split(applicationId)[1]\n\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,\n key,\n })\n\n if (alreadyTransformedImage && alreadyTransformedImage.body) {\n return alreadyTransformedImage.body.toString('base64')\n }\n\n const transformerResponse = await requestImageTransformation(key)\n\n const statusCode = transformerResponse.statusCode\n\n switch (statusCode) {\n case 200:\n console.log('Image transformation successful')\n return transformerResponse.body\n case 302: {\n console.log(\n 'Image transformation successful but image is too big for lambda delivery, fetching directly from S3'\n )\n const redirectLocation = transformerResponse.headers?.Location\n if (redirectLocation) {\n const newlyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,\n key,\n })\n console.log('Image successfully fetched from S3 at:', redirectLocation)\n\n return newlyTransformedImage.body.toString('base64')\n }\n throw new Error('Redirect response received but no location provided')\n }\n case 400:\n throw new Error(\n `Bad request to image transformer: ${transformerResponse.body}`\n )\n case 403:\n throw new Error('Requested transformed image is too big')\n case 404:\n throw new Error('The requested image does not exist')\n case 500:\n throw new Error(\n `Image transformation failed: ${transformerResponse.body}`\n )\n default:\n throw new Error(\n `Unexpected response from image transformer: ${statusCode} - ${transformerResponse.body}`\n )\n }\n}\n\nexport async function requestImageTransformation(key) {\n if (!key) {\n throw new Error('Image Path is required for image transformation')\n }\n\n console.log(\n 'ImageTransformation: Invoking image transformer lambda for path:',\n key\n )\n\n const lambdaEvent = {\n requestContext: {\n http: {\n method: 'GET',\n path: key,\n },\n },\n }\n\n const params = {\n FunctionName: process.env.IMAGE_TRANSFORMER_ARN,\n InvocationType: 'RequestResponse',\n Payload: JSON.stringify(lambdaEvent),\n }\n\n try {\n const result = await lambda.invoke(params).promise()\n\n const response = JSON.parse(result.Payload)\n\n return response\n } catch (error) {\n const errorMessage = `Failed to invoke image transformer lambda: ${error.message}`\n console.error(errorMessage, error)\n throw new Error(errorMessage)\n }\n}\n\nexport async function fetchResourceFromS3({ bucketName, key }) {\n console.log(\n `Fetching resource from S3 Bucket: '${bucketName}' at path: '${key}'`\n )\n if (!bucketName || !key) {\n throw new Error(\n 'bucketName and key are required for S3 resource fetch ' +\n JSON.stringify({ bucketName, key })\n )\n }\n\n const params = {\n Bucket: bucketName,\n Key: key,\n }\n\n try {\n const result = await s3.getObject(params).promise()\n\n return {\n body: result.Body,\n contentType: result.ContentType,\n contentLength: result.ContentLength,\n lastModified: result.LastModified,\n etag: result.ETag,\n }\n } catch (error) {\n if (error.code !== 'NoSuchKey') {\n throw new Error(`Failed to fetch image: ${bucketName}/${key}`)\n }\n\n console.log('Image not found in transformed bucket, invoking transformer')\n }\n}\n"],"file":"index.js"}
@@ -13,7 +13,7 @@ export var buildAuditContent = Promise.method(function (items) {
13
13
  link = _ref.link;
14
14
  return fetchImage(assetUrl, {
15
15
  Signature: settings.Signature,
16
- Expires: settings.Expires,
16
+ Policy: settings.Policy,
17
17
  KeyPairId: settings.KeyPairId
18
18
  }).then(function (base64String) {
19
19
  return {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/pdf/helpers/build-audit-content/index.js"],"names":["flatten","isEmpty","round","Promise","fetchImage","fourColumnTable","horizontalLine","imageTables","table","text","LIGHT_BLUE","WHITE","buildAuditContent","method","items","settings","map","group","item","index","assets","assetUrl","link","Signature","Expires","KeyPairId","then","base64String","alignment","fit","image","rowImages","rows","fillColor","hasImages","hasComments","comments","label","id","questionId","push","scoreLabel","weight","scoreWeight","imageRow","colSpan","stack","commentsRow","margin","style","groupTableRows","actual","groupActualScore","max","groupMaximumScore","resultText","groupPercentageResultScore","skipped","groupScoreText","bold","headerText","title","groupHeaderTable","body","layout","widths","groupTableHeader","groupTable","headerRows","hLine"],"mappings":"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","sourcesContent":["import { flatten, isEmpty, round } from 'lodash'\nimport Promise from 'bluebird'\n\nimport { fetchImage } from '../../../helpers'\nimport { fourColumnTable, horizontalLine, imageTables, table, text } from '../'\nimport { LIGHT_BLUE, WHITE } from '../table'\n\nexport const buildAuditContent = Promise.method((items, settings = {}) => {\n return Promise.map(items, group => {\n return Promise.map(group.items, (item, index) => {\n return Promise.map(item.assets, ({ assetUrl, link }) => {\n return fetchImage(assetUrl, {\n Signature: settings.Signature,\n Expires: settings.Expires,\n KeyPairId: settings.KeyPairId,\n }).then(base64String => ({\n alignment: 'center',\n fit: [210, 210],\n image: base64String,\n link,\n }))\n }).then(rowImages => {\n const rows = []\n\n const fillColor = index % 2 === 0 ? WHITE : LIGHT_BLUE\n const hasImages = !isEmpty(rowImages)\n const hasComments = !isEmpty(item.comments)\n\n // Some audits use questionId to link a follow-up issue and its question\n const label = { text: item.label, fillColor, id: item.questionId }\n\n rows.push([\n label,\n { text: item.scoreLabel, fillColor },\n { alignment: 'center', text: item.weight, fillColor },\n { alignment: 'right', text: item.scoreWeight, fillColor },\n ])\n\n if (hasImages) {\n const imageRow = [\n {\n colSpan: 4,\n fillColor,\n stack: imageTables(rowImages),\n },\n ]\n\n rows.push(imageRow)\n }\n\n if (hasComments) {\n const commentsRow = [\n {\n colSpan: 4,\n fillColor,\n margin: [0, -10, 0, 0],\n stack: [\n { text: 'Comments:', style: 'commentsHeader' },\n { text: item.comments },\n ],\n },\n ]\n\n rows.push(commentsRow)\n }\n\n return rows\n })\n }).then(groupTableRows => {\n const actual = round(group.groupActualScore, 2)\n const max = round(group.groupMaximumScore, 2)\n const resultText = `${group.groupPercentageResultScore}%`\n\n const { skipped } = group\n\n const groupScoreText = skipped\n ? null\n : text(`${actual} / ${max} (${resultText})`, {\n alignment: 'right',\n bold: true,\n })\n const headerText = text(group.title)\n\n const groupHeaderTable = table({\n body: [[headerText, groupScoreText]],\n layout: 'noBorders',\n style: 'groupHeaderTable',\n widths: ['*', '*'],\n })\n\n const groupTableHeader = [\n text('Question', { bold: true }),\n text('Answer', { bold: true }),\n text('Weight', { alignment: 'center', bold: true }),\n text('Score', { alignment: 'right', bold: true }),\n ]\n\n const groupTable = fourColumnTable({\n headerRows: 0,\n // NOTE: must flatten here as we have arrays of rows\n body: [groupTableHeader, ...flatten(groupTableRows)],\n widths: ['60%', '24%', '8%', '8%'],\n })\n\n const hLine = horizontalLine()\n\n return [groupHeaderTable, hLine, groupTable]\n })\n })\n})\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../../src/pdf/helpers/build-audit-content/index.js"],"names":["flatten","isEmpty","round","Promise","fetchImage","fourColumnTable","horizontalLine","imageTables","table","text","LIGHT_BLUE","WHITE","buildAuditContent","method","items","settings","map","group","item","index","assets","assetUrl","link","Signature","Policy","KeyPairId","then","base64String","alignment","fit","image","rowImages","rows","fillColor","hasImages","hasComments","comments","label","id","questionId","push","scoreLabel","weight","scoreWeight","imageRow","colSpan","stack","commentsRow","margin","style","groupTableRows","actual","groupActualScore","max","groupMaximumScore","resultText","groupPercentageResultScore","skipped","groupScoreText","bold","headerText","title","groupHeaderTable","body","layout","widths","groupTableHeader","groupTable","headerRows","hLine"],"mappings":"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","sourcesContent":["import { flatten, isEmpty, round } from 'lodash'\nimport Promise from 'bluebird'\n\nimport { fetchImage } from '../../../helpers'\nimport { fourColumnTable, horizontalLine, imageTables, table, text } from '../'\nimport { LIGHT_BLUE, WHITE } from '../table'\n\nexport const buildAuditContent = Promise.method((items, settings = {}) => {\n return Promise.map(items, group => {\n return Promise.map(group.items, (item, index) => {\n return Promise.map(item.assets, ({ assetUrl, link }) => {\n return fetchImage(assetUrl, {\n Signature: settings.Signature,\n Policy: settings.Policy,\n KeyPairId: settings.KeyPairId,\n }).then(base64String => ({\n alignment: 'center',\n fit: [210, 210],\n image: base64String,\n link,\n }))\n }).then(rowImages => {\n const rows = []\n\n const fillColor = index % 2 === 0 ? WHITE : LIGHT_BLUE\n const hasImages = !isEmpty(rowImages)\n const hasComments = !isEmpty(item.comments)\n\n // Some audits use questionId to link a follow-up issue and its question\n const label = { text: item.label, fillColor, id: item.questionId }\n\n rows.push([\n label,\n { text: item.scoreLabel, fillColor },\n { alignment: 'center', text: item.weight, fillColor },\n { alignment: 'right', text: item.scoreWeight, fillColor },\n ])\n\n if (hasImages) {\n const imageRow = [\n {\n colSpan: 4,\n fillColor,\n stack: imageTables(rowImages),\n },\n ]\n\n rows.push(imageRow)\n }\n\n if (hasComments) {\n const commentsRow = [\n {\n colSpan: 4,\n fillColor,\n margin: [0, -10, 0, 0],\n stack: [\n { text: 'Comments:', style: 'commentsHeader' },\n { text: item.comments },\n ],\n },\n ]\n\n rows.push(commentsRow)\n }\n\n return rows\n })\n }).then(groupTableRows => {\n const actual = round(group.groupActualScore, 2)\n const max = round(group.groupMaximumScore, 2)\n const resultText = `${group.groupPercentageResultScore}%`\n\n const { skipped } = group\n\n const groupScoreText = skipped\n ? null\n : text(`${actual} / ${max} (${resultText})`, {\n alignment: 'right',\n bold: true,\n })\n const headerText = text(group.title)\n\n const groupHeaderTable = table({\n body: [[headerText, groupScoreText]],\n layout: 'noBorders',\n style: 'groupHeaderTable',\n widths: ['*', '*'],\n })\n\n const groupTableHeader = [\n text('Question', { bold: true }),\n text('Answer', { bold: true }),\n text('Weight', { alignment: 'center', bold: true }),\n text('Score', { alignment: 'right', bold: true }),\n ]\n\n const groupTable = fourColumnTable({\n headerRows: 0,\n // NOTE: must flatten here as we have arrays of rows\n body: [groupTableHeader, ...flatten(groupTableRows)],\n widths: ['60%', '24%', '8%', '8%'],\n })\n\n const hLine = horizontalLine()\n\n return [groupHeaderTable, hLine, groupTable]\n })\n })\n})\n"],"file":"index.js"}
@@ -1,7 +1,7 @@
1
1
  import { fetchImage, getTimezoneDatetime } from '../../../helpers';
2
2
  export function defaultFooter(_ref) {
3
3
  var Signature = _ref.Signature,
4
- Expires = _ref.Expires,
4
+ Policy = _ref.Policy,
5
5
  KeyPairId = _ref.KeyPairId,
6
6
  logoUrl = _ref.logoUrl,
7
7
  timestamp = _ref.timestamp,
@@ -18,7 +18,7 @@ export function defaultFooter(_ref) {
18
18
 
19
19
  return fetchImage(logoUrl, {
20
20
  Signature: Signature,
21
- Expires: Expires,
21
+ Policy: Policy,
22
22
  KeyPairId: KeyPairId,
23
23
  isHeader: true
24
24
  }).then(function (image) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/pdf/helpers/default-footer/index.js"],"names":["fetchImage","getTimezoneDatetime","defaultFooter","Signature","Expires","KeyPairId","logoUrl","timestamp","timezone","type","sequenceId","datetime","format","showTzAbbr","footerText","isHeader","then","image","_page","columns","fit","margin","alignment","font","text","style"],"mappings":"AAAA,SAASA,UAAT,EAAqBC,mBAArB,QAAgD,kBAAhD;AAEA,OAAO,SAASC,aAAT,OASJ;AAAA,MARDC,SAQC,QARDA,SAQC;AAAA,MAPDC,OAOC,QAPDA,OAOC;AAAA,MANDC,SAMC,QANDA,SAMC;AAAA,MALDC,OAKC,QALDA,OAKC;AAAA,MAJDC,SAIC,QAJDA,SAIC;AAAA,MAHDC,QAGC,QAHDA,QAGC;AAAA,MAFDC,IAEC,QAFDA,IAEC;AAAA,MADDC,UACC,QADDA,UACC;AACD,MAAMC,QAAQ,GAAGV,mBAAmB,CAAC;AACnCW,IAAAA,MAAM,EAAE,aAD2B;AAEnCC,IAAAA,UAAU,EAAE,KAFuB;AAGnCN,IAAAA,SAAS,EAATA,SAHmC;AAInCC,IAAAA,QAAQ,EAARA;AAJmC,GAAD,CAApC;AAOA,MAAMM,UAAU,GAAGJ,UAAU,aAAMD,IAAN,cAAcC,UAAd,cAAgCD,IAAhC,CAA7B,CARC,CAUD;;AACA,SAAOT,UAAU,CAACM,OAAD,EAAU;AACzBH,IAAAA,SAAS,EAATA,SADyB;AAEzBC,IAAAA,OAAO,EAAPA,OAFyB;AAGzBC,IAAAA,SAAS,EAATA,SAHyB;AAIzBU,IAAAA,QAAQ,EAAE;AAJe,GAAV,CAAV,CAKJC,IALI,CAKC,UAAAC,KAAK;AAAA,WAAI,UAAAC,KAAK;AAAA,aAAK;AACzBC,QAAAA,OAAO,EAAE,CACP;AACEC,UAAAA,GAAG,EAAE,CAAC,EAAD,EAAK,EAAL,CADP;AAEEH,UAAAA,KAAK,EAALA,KAFF;AAGEI,UAAAA,MAAM,EAAE,CAAC,EAAD,EAAK,EAAL,EAAS,CAAT,EAAY,CAAZ;AAHV,SADO,EAMP;AACEC,UAAAA,SAAS,EAAE,OADb;AAEEC,UAAAA,IAAI,EAAE,QAFR;AAGEC,UAAAA,IAAI,YAAKV,UAAL,gBAAqBH,QAArB,CAHN;AAIEc,UAAAA,KAAK,EAAE,OAJT;AAKEJ,UAAAA,MAAM,EAAE,CAAC,CAAD,EAAI,EAAJ,EAAQ,EAAR,EAAY,CAAZ;AALV,SANO;AADgB,OAAL;AAAA,KAAT;AAAA,GALN,CAAP;AAqBD","sourcesContent":["import { fetchImage, getTimezoneDatetime } from '../../../helpers'\n\nexport function defaultFooter({\n Signature,\n Expires,\n KeyPairId,\n logoUrl,\n timestamp,\n timezone,\n type,\n sequenceId,\n}) {\n const datetime = getTimezoneDatetime({\n format: 'Do MMM YYYY',\n showTzAbbr: false,\n timestamp,\n timezone,\n })\n\n const footerText = sequenceId ? `${type} ${sequenceId}` : `${type}`\n\n // eslint-disable-next-line no-unused-vars\n return fetchImage(logoUrl, {\n Signature,\n Expires,\n KeyPairId,\n isHeader: true,\n }).then(image => _page => ({\n columns: [\n {\n fit: [80, 30],\n image,\n margin: [60, 20, 0, 0],\n },\n {\n alignment: 'right',\n font: 'Gotham',\n text: `${footerText} | ${datetime}`,\n style: 'small',\n margin: [0, 25, 60, 0],\n },\n ],\n }))\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../../src/pdf/helpers/default-footer/index.js"],"names":["fetchImage","getTimezoneDatetime","defaultFooter","Signature","Policy","KeyPairId","logoUrl","timestamp","timezone","type","sequenceId","datetime","format","showTzAbbr","footerText","isHeader","then","image","_page","columns","fit","margin","alignment","font","text","style"],"mappings":"AAAA,SAASA,UAAT,EAAqBC,mBAArB,QAAgD,kBAAhD;AAEA,OAAO,SAASC,aAAT,OASJ;AAAA,MARDC,SAQC,QARDA,SAQC;AAAA,MAPDC,MAOC,QAPDA,MAOC;AAAA,MANDC,SAMC,QANDA,SAMC;AAAA,MALDC,OAKC,QALDA,OAKC;AAAA,MAJDC,SAIC,QAJDA,SAIC;AAAA,MAHDC,QAGC,QAHDA,QAGC;AAAA,MAFDC,IAEC,QAFDA,IAEC;AAAA,MADDC,UACC,QADDA,UACC;AACD,MAAMC,QAAQ,GAAGV,mBAAmB,CAAC;AACnCW,IAAAA,MAAM,EAAE,aAD2B;AAEnCC,IAAAA,UAAU,EAAE,KAFuB;AAGnCN,IAAAA,SAAS,EAATA,SAHmC;AAInCC,IAAAA,QAAQ,EAARA;AAJmC,GAAD,CAApC;AAOA,MAAMM,UAAU,GAAGJ,UAAU,aAAMD,IAAN,cAAcC,UAAd,cAAgCD,IAAhC,CAA7B,CARC,CAUD;;AACA,SAAOT,UAAU,CAACM,OAAD,EAAU;AACzBH,IAAAA,SAAS,EAATA,SADyB;AAEzBC,IAAAA,MAAM,EAANA,MAFyB;AAGzBC,IAAAA,SAAS,EAATA,SAHyB;AAIzBU,IAAAA,QAAQ,EAAE;AAJe,GAAV,CAAV,CAKJC,IALI,CAKC,UAAAC,KAAK;AAAA,WAAI,UAAAC,KAAK;AAAA,aAAK;AACzBC,QAAAA,OAAO,EAAE,CACP;AACEC,UAAAA,GAAG,EAAE,CAAC,EAAD,EAAK,EAAL,CADP;AAEEH,UAAAA,KAAK,EAALA,KAFF;AAGEI,UAAAA,MAAM,EAAE,CAAC,EAAD,EAAK,EAAL,EAAS,CAAT,EAAY,CAAZ;AAHV,SADO,EAMP;AACEC,UAAAA,SAAS,EAAE,OADb;AAEEC,UAAAA,IAAI,EAAE,QAFR;AAGEC,UAAAA,IAAI,YAAKV,UAAL,gBAAqBH,QAArB,CAHN;AAIEc,UAAAA,KAAK,EAAE,OAJT;AAKEJ,UAAAA,MAAM,EAAE,CAAC,CAAD,EAAI,EAAJ,EAAQ,EAAR,EAAY,CAAZ;AALV,SANO;AADgB,OAAL;AAAA,KAAT;AAAA,GALN,CAAP;AAqBD","sourcesContent":["import { fetchImage, getTimezoneDatetime } from '../../../helpers'\n\nexport function defaultFooter({\n Signature,\n Policy,\n KeyPairId,\n logoUrl,\n timestamp,\n timezone,\n type,\n sequenceId,\n}) {\n const datetime = getTimezoneDatetime({\n format: 'Do MMM YYYY',\n showTzAbbr: false,\n timestamp,\n timezone,\n })\n\n const footerText = sequenceId ? `${type} ${sequenceId}` : `${type}`\n\n // eslint-disable-next-line no-unused-vars\n return fetchImage(logoUrl, {\n Signature,\n Policy,\n KeyPairId,\n isHeader: true,\n }).then(image => _page => ({\n columns: [\n {\n fit: [80, 30],\n image,\n margin: [60, 20, 0, 0],\n },\n {\n alignment: 'right',\n font: 'Gotham',\n text: `${footerText} | ${datetime}`,\n style: 'small',\n margin: [0, 25, 60, 0],\n },\n ],\n }))\n}\n"],"file":"index.js"}
@@ -1,7 +1,7 @@
1
1
  import { fetchImage, getTimezoneDatetime } from '../../../helpers';
2
2
  export function defaultHeader(_ref) {
3
3
  var Signature = _ref.Signature,
4
- Expires = _ref.Expires,
4
+ Policy = _ref.Policy,
5
5
  KeyPairId = _ref.KeyPairId,
6
6
  logoUrl = _ref.logoUrl,
7
7
  timestamp = _ref.timestamp,
@@ -14,7 +14,7 @@ export function defaultHeader(_ref) {
14
14
  });
15
15
  return fetchImage(logoUrl, {
16
16
  Signature: Signature,
17
- Expires: Expires,
17
+ Policy: Policy,
18
18
  KeyPairId: KeyPairId,
19
19
  isHeader: true
20
20
  }).then(function (image) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/pdf/helpers/default-header/index.js"],"names":["fetchImage","getTimezoneDatetime","defaultHeader","Signature","Expires","KeyPairId","logoUrl","timestamp","timezone","datetime","format","showTzAbbr","isHeader","then","image","columns","fit","margin","alignment","color","font","fontSize","text"],"mappings":"AAAA,SAASA,UAAT,EAAqBC,mBAArB,QAAgD,kBAAhD;AAEA,OAAO,SAASC,aAAT,OAOJ;AAAA,MANDC,SAMC,QANDA,SAMC;AAAA,MALDC,OAKC,QALDA,OAKC;AAAA,MAJDC,SAIC,QAJDA,SAIC;AAAA,MAHDC,OAGC,QAHDA,OAGC;AAAA,MAFDC,SAEC,QAFDA,SAEC;AAAA,MADDC,QACC,QADDA,QACC;AACD,MAAMC,QAAQ,GAAGR,mBAAmB,CAAC;AACnCS,IAAAA,MAAM,EAAE,kBAD2B;AAEnCC,IAAAA,UAAU,EAAE,KAFuB;AAGnCJ,IAAAA,SAAS,EAATA,SAHmC;AAInCC,IAAAA,QAAQ,EAARA;AAJmC,GAAD,CAApC;AAOA,SAAOR,UAAU,CAACM,OAAD,EAAU;AACzBH,IAAAA,SAAS,EAATA,SADyB;AAEzBC,IAAAA,OAAO,EAAPA,OAFyB;AAGzBC,IAAAA,SAAS,EAATA,SAHyB;AAIzBO,IAAAA,QAAQ,EAAE;AAJe,GAAV,CAAV,CAKJC,IALI,CAKC,UAAAC,KAAK;AAAA,WAAK;AAChBC,MAAAA,OAAO,EAAE,CACP;AACEC,QAAAA,GAAG,EAAE,CAAC,GAAD,EAAM,EAAN,CADP;AAEEF,QAAAA,KAAK,EAALA,KAFF;AAGEG,QAAAA,MAAM,EAAE,CAAC,EAAD,EAAK,EAAL,EAAS,EAAT,EAAa,CAAb;AAHV,OADO,EAMP;AACEC,QAAAA,SAAS,EAAE,OADb;AAEEC,QAAAA,KAAK,EAAE,MAFT;AAGEC,QAAAA,IAAI,EAAE,QAHR;AAIEC,QAAAA,QAAQ,EAAE,EAJZ;AAKEC,QAAAA,IAAI,EAAEb,QALR;AAMEQ,QAAAA,MAAM,EAAE,CAAC,EAAD,EAAK,EAAL,EAAS,EAAT,EAAa,CAAb;AANV,OANO;AADO,KAAL;AAAA,GALN,CAAP;AAsBD","sourcesContent":["import { fetchImage, getTimezoneDatetime } from '../../../helpers'\n\nexport function defaultHeader({\n Signature,\n Expires,\n KeyPairId,\n logoUrl,\n timestamp,\n timezone,\n}) {\n const datetime = getTimezoneDatetime({\n format: 'ddd, Do MMM YYYY',\n showTzAbbr: false,\n timestamp,\n timezone,\n })\n\n return fetchImage(logoUrl, {\n Signature,\n Expires,\n KeyPairId,\n isHeader: true,\n }).then(image => ({\n columns: [\n {\n fit: [130, 30],\n image,\n margin: [60, 60, 60, 0],\n },\n {\n alignment: 'right',\n color: '#999',\n font: 'Gotham',\n fontSize: 11,\n text: datetime,\n margin: [60, 70, 60, 0],\n },\n ],\n }))\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../../src/pdf/helpers/default-header/index.js"],"names":["fetchImage","getTimezoneDatetime","defaultHeader","Signature","Policy","KeyPairId","logoUrl","timestamp","timezone","datetime","format","showTzAbbr","isHeader","then","image","columns","fit","margin","alignment","color","font","fontSize","text"],"mappings":"AAAA,SAASA,UAAT,EAAqBC,mBAArB,QAAgD,kBAAhD;AAEA,OAAO,SAASC,aAAT,OAOJ;AAAA,MANDC,SAMC,QANDA,SAMC;AAAA,MALDC,MAKC,QALDA,MAKC;AAAA,MAJDC,SAIC,QAJDA,SAIC;AAAA,MAHDC,OAGC,QAHDA,OAGC;AAAA,MAFDC,SAEC,QAFDA,SAEC;AAAA,MADDC,QACC,QADDA,QACC;AACD,MAAMC,QAAQ,GAAGR,mBAAmB,CAAC;AACnCS,IAAAA,MAAM,EAAE,kBAD2B;AAEnCC,IAAAA,UAAU,EAAE,KAFuB;AAGnCJ,IAAAA,SAAS,EAATA,SAHmC;AAInCC,IAAAA,QAAQ,EAARA;AAJmC,GAAD,CAApC;AAOA,SAAOR,UAAU,CAACM,OAAD,EAAU;AACzBH,IAAAA,SAAS,EAATA,SADyB;AAEzBC,IAAAA,MAAM,EAANA,MAFyB;AAGzBC,IAAAA,SAAS,EAATA,SAHyB;AAIzBO,IAAAA,QAAQ,EAAE;AAJe,GAAV,CAAV,CAKJC,IALI,CAKC,UAAAC,KAAK;AAAA,WAAK;AAChBC,MAAAA,OAAO,EAAE,CACP;AACEC,QAAAA,GAAG,EAAE,CAAC,GAAD,EAAM,EAAN,CADP;AAEEF,QAAAA,KAAK,EAALA,KAFF;AAGEG,QAAAA,MAAM,EAAE,CAAC,EAAD,EAAK,EAAL,EAAS,EAAT,EAAa,CAAb;AAHV,OADO,EAMP;AACEC,QAAAA,SAAS,EAAE,OADb;AAEEC,QAAAA,KAAK,EAAE,MAFT;AAGEC,QAAAA,IAAI,EAAE,QAHR;AAIEC,QAAAA,QAAQ,EAAE,EAJZ;AAKEC,QAAAA,IAAI,EAAEb,QALR;AAMEQ,QAAAA,MAAM,EAAE,CAAC,EAAD,EAAK,EAAL,EAAS,EAAT,EAAa,CAAb;AANV,OANO;AADO,KAAL;AAAA,GALN,CAAP;AAsBD","sourcesContent":["import { fetchImage, getTimezoneDatetime } from '../../../helpers'\n\nexport function defaultHeader({\n Signature,\n Policy,\n KeyPairId,\n logoUrl,\n timestamp,\n timezone,\n}) {\n const datetime = getTimezoneDatetime({\n format: 'ddd, Do MMM YYYY',\n showTzAbbr: false,\n timestamp,\n timezone,\n })\n\n return fetchImage(logoUrl, {\n Signature,\n Policy,\n KeyPairId,\n isHeader: true,\n }).then(image => ({\n columns: [\n {\n fit: [130, 30],\n image,\n margin: [60, 60, 60, 0],\n },\n {\n alignment: 'right',\n color: '#999',\n font: 'Gotham',\n fontSize: 11,\n text: datetime,\n margin: [60, 70, 60, 0],\n },\n ],\n }))\n}\n"],"file":"index.js"}
@@ -34,7 +34,7 @@ function buildImage(options) {
34
34
  cloudinaryBaseUrl = _ref2.cloudinaryBaseUrl,
35
35
  cloudfrontBaseUrl = _ref2.cloudfrontBaseUrl,
36
36
  Signature = _ref2.Signature,
37
- Expires = _ref2.Expires,
37
+ Policy = _ref2.Policy,
38
38
  KeyPairId = _ref2.KeyPairId;
39
39
 
40
40
  var isVideoType = new RegExp('.mp4$').test(filepath);
@@ -60,7 +60,7 @@ function buildImage(options) {
60
60
  });
61
61
  return fetchImage(url, {
62
62
  Signature: Signature,
63
- Expires: Expires,
63
+ Policy: Policy,
64
64
  KeyPairId: KeyPairId
65
65
  }).then(function (base64String) {
66
66
  return {
@@ -253,7 +253,7 @@ export function buildTemplateFieldRow(_ref4) {
253
253
  if (!value) return [labelText, ''];
254
254
  return fetchImage(value, {
255
255
  Signature: settings.Signature,
256
- Expires: settings.Expires,
256
+ Policy: settings.Policy,
257
257
  KeyPairId: settings.KeyPairId
258
258
  }).then(function (base64String) {
259
259
  var values = {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/pdf/helpers/fields/index.js"],"names":["isArray","isEmpty","join","first","map","startsWith","Promise","moment","buildFetchUrl","fetchImage","videoIcon","imageTables","parseValue","text","toPdf","buildFile","file","settings","extension","name","path","awsS3BaseUrl","link","margin","buildImage","options","alignment","filepath","height","width","cloudinaryBaseUrl","cloudfrontBaseUrl","Signature","Expires","KeyPairId","isVideoType","RegExp","test","fit","image","url","quality","then","base64String","buildSummaryField","field","timezone","fieldtype","value","isDayFirstDateField","format","isMonthFirstDateField","isFileField","isHtmlField","type","isNumberField","isPhotoField","isReferenceField","isSelectField","isSignatureField","isStarField","isSwitchField","isTextField","is12HourTimeField","is24HourTimeField","isDataImage","fileList","ol","parsedValue","displayValue","fontSize","filter","val","label","tz","buildTemplateFieldRow","skipped","showOnRead","isDisplayImageField","labelText","parsed","replace","values","fieldImages","tables","imagesRow","colSpan","layout","hLineWidth","paddingLeft","paddingRight","paddingTop","paddingBottom","vLineWidth","table","body","widths","string"],"mappings":"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","sourcesContent":["import { isArray, isEmpty, join, first, map, startsWith } from 'lodash'\nimport Promise from 'bluebird'\nimport moment from 'moment-timezone'\n\nimport { buildFetchUrl, fetchImage } from '../../../helpers'\nimport { videoIcon } from '../../../images'\nimport { imageTables, parseValue, text, toPdf } from '../'\n\nexport function buildFile({ file, settings }) {\n const { extension, name, path } = file\n const { awsS3BaseUrl } = settings\n\n const link = `${awsS3BaseUrl}/${path}`\n return text(`${name}.${extension}`, { link, margin: [0, 0, 0, 10] })\n}\n\nfunction buildImage(options) {\n const {\n alignment = 'center',\n filepath,\n height = 210,\n settings,\n width = 210,\n } = options\n const {\n awsS3BaseUrl,\n cloudinaryBaseUrl,\n cloudfrontBaseUrl,\n Signature,\n Expires,\n KeyPairId,\n } = settings || {}\n\n const isVideoType = new RegExp('.mp4$').test(filepath)\n const link = `${awsS3BaseUrl}/${filepath}`\n\n if (isVideoType) {\n return {\n alignment,\n fit: [width, height],\n image: videoIcon,\n link,\n }\n }\n\n const url = buildFetchUrl(filepath, {\n awsS3BaseUrl,\n cloudfrontBaseUrl,\n cloudinaryBaseUrl,\n fit: true,\n height: 400,\n width: 600,\n quality: 50,\n })\n\n return fetchImage(url, {\n Signature,\n Expires,\n KeyPairId,\n }).then(base64String => ({\n alignment,\n fit: [width, height],\n image: base64String,\n link,\n }))\n}\n\nexport function buildSummaryField({ field, settings, timezone }) {\n const { fieldtype, options = {}, value } = field\n\n const isDayFirstDateField =\n fieldtype === 'date' && options.format === 'DD/MM/YY'\n const isMonthFirstDateField =\n fieldtype === 'date' && options.format === 'MM/DD/YY'\n const isFileField = fieldtype === 'file'\n const isHtmlField = fieldtype === 'text' && options.type === 'html'\n const isNumberField = fieldtype === 'number'\n const isPhotoField = fieldtype === 'list' && options.type === 'media'\n const isReferenceField = fieldtype === 'reference'\n const isSelectField = fieldtype === 'select' && options.type !== 'stars'\n const isSignatureField = fieldtype === 'text' && options.type === 'signature'\n const isStarField = fieldtype === 'select' && options.type === 'stars'\n const isSwitchField = fieldtype === 'switch'\n const isTextField = fieldtype === 'text'\n const is12HourTimeField = fieldtype === 'time' && options.format === 'h:mm a'\n const is24HourTimeField = fieldtype === 'time' && options.format === 'HH:mm'\n\n // NOTE: html field is not supported for the summary fields but adding\n // logic to catch this and return empty text for completeness\n if (isHtmlField) {\n return { text: '' }\n }\n\n if (isSignatureField) {\n if (!value) return ''\n\n if (isDataImage(value)) {\n return { alignment: 'left', image: value, width: 140 }\n }\n\n return fetchImage(value).then(base64String => {\n return {\n alignment: 'left',\n image: base64String,\n width: 140,\n }\n })\n }\n\n if (isPhotoField) {\n const filepath = first(value)\n\n // NOTE: if no filepath return empty text as user has not uploaded an image\n // for this field\n if (!filepath) {\n return { text: '' }\n }\n\n const image = buildImage({\n alignment: 'left',\n filepath,\n height: 140,\n width: 140,\n settings,\n })\n\n return image\n }\n\n if (isFileField) {\n const fileList = map(value, file => buildFile({ file, settings }))\n return { ol: fileList }\n }\n\n if (isNumberField || isSelectField || isSwitchField || isTextField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? { text: join(parsedValue, ', '), fontSize: 7 }\n : { text: parsedValue, fontSize: 7 }\n\n return displayValue\n }\n\n if (isReferenceField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? {\n text: parsedValue\n .filter(val => val && val.label)\n .map(val => val.label)\n .join(', '),\n fontSize: 7,\n }\n : { text: parsedValue.label, fontSize: 7 }\n\n return displayValue\n }\n\n if (isStarField) {\n if (!value) return ''\n const displayValue = value === '1' ? `${value} star` : `${value} stars`\n return displayValue\n }\n\n if (\n isDayFirstDateField ||\n isMonthFirstDateField ||\n is12HourTimeField ||\n is24HourTimeField\n ) {\n const format = options.format\n const displayValue = moment(value)\n .tz(timezone)\n .format(format)\n\n return displayValue\n }\n\n // NOTE: return empty text fallback value when no match\n return { text: '' }\n}\n\nexport function buildTemplateFieldRow({ field, settings, timezone, skipped }) {\n const { fieldtype, label, options = {}, value } = field\n const { showOnRead = true } = options\n\n const isDayFirstDateField =\n fieldtype === 'date' && options.format === 'DD/MM/YY'\n const isMonthFirstDateField =\n fieldtype === 'date' && options.format === 'MM/DD/YY'\n const isFileField = fieldtype === 'file'\n const isHtmlField = fieldtype === 'text' && options.type === 'html'\n const isNumberField = fieldtype === 'number'\n const isPhotoField = fieldtype === 'list' && options.type === 'media'\n const isSelectField = fieldtype === 'select' && options.type !== 'stars'\n const isSignatureField = fieldtype === 'text' && options.type === 'signature'\n const isStarField = fieldtype === 'select' && options.type === 'stars'\n const isSwitchField = fieldtype === 'switch'\n const isTextField = fieldtype === 'text'\n const is12HourTimeField = fieldtype === 'time' && options.format === 'h:mm a'\n const is24HourTimeField = fieldtype === 'time' && options.format === 'HH:mm'\n const isDisplayImageField = fieldtype === 'image-display' && showOnRead\n const isReferenceField = fieldtype === 'reference'\n\n // NOTE: only show field when show on read is true\n if (!showOnRead) return null\n\n const labelText = [{ text: label }]\n\n if (skipped) {\n return [labelText, [{ text: '-' }]]\n }\n\n if (isHtmlField) {\n const parsed = value.replace(/<p><\\/p>/g, '')\n return [labelText, toPdf(parsed)]\n }\n\n if (isSignatureField) {\n if (!value) return [labelText, '']\n\n return fetchImage(value, {\n Signature: settings.Signature,\n Expires: settings.Expires,\n KeyPairId: settings.KeyPairId,\n }).then(base64String => {\n const values = {\n alignment: 'left',\n image: base64String,\n width: 140,\n }\n return [labelText, values]\n })\n }\n\n if (isDisplayImageField) {\n return Promise.map([value], filepath =>\n buildImage({ filepath, settings })\n ).then(fieldImages => [fieldImages, {}])\n }\n\n if (isPhotoField) {\n return Promise.map(value, filepath =>\n buildImage({ filepath, settings })\n ).then(fieldImages => {\n const tables = !isEmpty(fieldImages) ? imageTables(fieldImages) : []\n\n const imagesRow = {\n colSpan: 2,\n layout: {\n hLineWidth: () => 0,\n paddingLeft: () => 0,\n paddingRight: () => 0,\n paddingTop: () => 0,\n paddingBottom: () => 0,\n vLineWidth: () => 0,\n },\n table: {\n body: [labelText, ...tables],\n widths: ['*'],\n },\n }\n\n // NOTE: pass empty value here as otherwise\n // we can accidentally hide content below\n // this row. Please see the following issue:\n // https://github.com/bpampuch/pdfmake/issues/1598\n return [imagesRow, {}]\n })\n }\n\n if (isFileField) {\n const fileList = map(value, file => buildFile({ file, settings }))\n return [labelText, { ol: fileList }]\n }\n\n if (isNumberField || isSelectField || isSwitchField || isTextField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? { text: join(parsedValue, ', ') }\n : { text: parsedValue }\n\n return [labelText, displayValue]\n }\n\n if (isReferenceField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? {\n text: parsedValue\n .filter(val => val && val.label)\n .map(val => val.label)\n .join(', '),\n fontSize: 7,\n }\n : { text: parsedValue.label, fontSize: 7 }\n\n return [labelText, displayValue]\n }\n\n if (isStarField) {\n if (!value) return [labelText, '']\n const displayValue = value === '1' ? `${value} star` : `${value} stars`\n return [labelText, displayValue]\n }\n\n if (\n isDayFirstDateField ||\n isMonthFirstDateField ||\n is12HourTimeField ||\n is24HourTimeField\n ) {\n const format = options.format\n const displayValue = value\n ? moment(value)\n .tz(timezone)\n .format(format)\n : ''\n\n return [labelText, displayValue]\n }\n\n // NOTE: if no match above null values will be stripped within calling fn\n return null\n}\n\nfunction isDataImage(string) {\n return startsWith(string, 'data:image/png;')\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../../src/pdf/helpers/fields/index.js"],"names":["isArray","isEmpty","join","first","map","startsWith","Promise","moment","buildFetchUrl","fetchImage","videoIcon","imageTables","parseValue","text","toPdf","buildFile","file","settings","extension","name","path","awsS3BaseUrl","link","margin","buildImage","options","alignment","filepath","height","width","cloudinaryBaseUrl","cloudfrontBaseUrl","Signature","Policy","KeyPairId","isVideoType","RegExp","test","fit","image","url","quality","then","base64String","buildSummaryField","field","timezone","fieldtype","value","isDayFirstDateField","format","isMonthFirstDateField","isFileField","isHtmlField","type","isNumberField","isPhotoField","isReferenceField","isSelectField","isSignatureField","isStarField","isSwitchField","isTextField","is12HourTimeField","is24HourTimeField","isDataImage","fileList","ol","parsedValue","displayValue","fontSize","filter","val","label","tz","buildTemplateFieldRow","skipped","showOnRead","isDisplayImageField","labelText","parsed","replace","values","fieldImages","tables","imagesRow","colSpan","layout","hLineWidth","paddingLeft","paddingRight","paddingTop","paddingBottom","vLineWidth","table","body","widths","string"],"mappings":"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","sourcesContent":["import { isArray, isEmpty, join, first, map, startsWith } from 'lodash'\nimport Promise from 'bluebird'\nimport moment from 'moment-timezone'\n\nimport { buildFetchUrl, fetchImage } from '../../../helpers'\nimport { videoIcon } from '../../../images'\nimport { imageTables, parseValue, text, toPdf } from '../'\n\nexport function buildFile({ file, settings }) {\n const { extension, name, path } = file\n const { awsS3BaseUrl } = settings\n\n const link = `${awsS3BaseUrl}/${path}`\n return text(`${name}.${extension}`, { link, margin: [0, 0, 0, 10] })\n}\n\nfunction buildImage(options) {\n const {\n alignment = 'center',\n filepath,\n height = 210,\n settings,\n width = 210,\n } = options\n const {\n awsS3BaseUrl,\n cloudinaryBaseUrl,\n cloudfrontBaseUrl,\n Signature,\n Policy,\n KeyPairId,\n } = settings || {}\n\n const isVideoType = new RegExp('.mp4$').test(filepath)\n const link = `${awsS3BaseUrl}/${filepath}`\n\n if (isVideoType) {\n return {\n alignment,\n fit: [width, height],\n image: videoIcon,\n link,\n }\n }\n\n const url = buildFetchUrl(filepath, {\n awsS3BaseUrl,\n cloudfrontBaseUrl,\n cloudinaryBaseUrl,\n fit: true,\n height: 400,\n width: 600,\n quality: 50,\n })\n\n return fetchImage(url, {\n Signature,\n Policy,\n KeyPairId,\n }).then(base64String => ({\n alignment,\n fit: [width, height],\n image: base64String,\n link,\n }))\n}\n\nexport function buildSummaryField({ field, settings, timezone }) {\n const { fieldtype, options = {}, value } = field\n\n const isDayFirstDateField =\n fieldtype === 'date' && options.format === 'DD/MM/YY'\n const isMonthFirstDateField =\n fieldtype === 'date' && options.format === 'MM/DD/YY'\n const isFileField = fieldtype === 'file'\n const isHtmlField = fieldtype === 'text' && options.type === 'html'\n const isNumberField = fieldtype === 'number'\n const isPhotoField = fieldtype === 'list' && options.type === 'media'\n const isReferenceField = fieldtype === 'reference'\n const isSelectField = fieldtype === 'select' && options.type !== 'stars'\n const isSignatureField = fieldtype === 'text' && options.type === 'signature'\n const isStarField = fieldtype === 'select' && options.type === 'stars'\n const isSwitchField = fieldtype === 'switch'\n const isTextField = fieldtype === 'text'\n const is12HourTimeField = fieldtype === 'time' && options.format === 'h:mm a'\n const is24HourTimeField = fieldtype === 'time' && options.format === 'HH:mm'\n\n // NOTE: html field is not supported for the summary fields but adding\n // logic to catch this and return empty text for completeness\n if (isHtmlField) {\n return { text: '' }\n }\n\n if (isSignatureField) {\n if (!value) return ''\n\n if (isDataImage(value)) {\n return { alignment: 'left', image: value, width: 140 }\n }\n\n return fetchImage(value).then(base64String => {\n return {\n alignment: 'left',\n image: base64String,\n width: 140,\n }\n })\n }\n\n if (isPhotoField) {\n const filepath = first(value)\n\n // NOTE: if no filepath return empty text as user has not uploaded an image\n // for this field\n if (!filepath) {\n return { text: '' }\n }\n\n const image = buildImage({\n alignment: 'left',\n filepath,\n height: 140,\n width: 140,\n settings,\n })\n\n return image\n }\n\n if (isFileField) {\n const fileList = map(value, file => buildFile({ file, settings }))\n return { ol: fileList }\n }\n\n if (isNumberField || isSelectField || isSwitchField || isTextField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? { text: join(parsedValue, ', '), fontSize: 7 }\n : { text: parsedValue, fontSize: 7 }\n\n return displayValue\n }\n\n if (isReferenceField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? {\n text: parsedValue\n .filter(val => val && val.label)\n .map(val => val.label)\n .join(', '),\n fontSize: 7,\n }\n : { text: parsedValue.label, fontSize: 7 }\n\n return displayValue\n }\n\n if (isStarField) {\n if (!value) return ''\n const displayValue = value === '1' ? `${value} star` : `${value} stars`\n return displayValue\n }\n\n if (\n isDayFirstDateField ||\n isMonthFirstDateField ||\n is12HourTimeField ||\n is24HourTimeField\n ) {\n const format = options.format\n const displayValue = moment(value)\n .tz(timezone)\n .format(format)\n\n return displayValue\n }\n\n // NOTE: return empty text fallback value when no match\n return { text: '' }\n}\n\nexport function buildTemplateFieldRow({ field, settings, timezone, skipped }) {\n const { fieldtype, label, options = {}, value } = field\n const { showOnRead = true } = options\n\n const isDayFirstDateField =\n fieldtype === 'date' && options.format === 'DD/MM/YY'\n const isMonthFirstDateField =\n fieldtype === 'date' && options.format === 'MM/DD/YY'\n const isFileField = fieldtype === 'file'\n const isHtmlField = fieldtype === 'text' && options.type === 'html'\n const isNumberField = fieldtype === 'number'\n const isPhotoField = fieldtype === 'list' && options.type === 'media'\n const isSelectField = fieldtype === 'select' && options.type !== 'stars'\n const isSignatureField = fieldtype === 'text' && options.type === 'signature'\n const isStarField = fieldtype === 'select' && options.type === 'stars'\n const isSwitchField = fieldtype === 'switch'\n const isTextField = fieldtype === 'text'\n const is12HourTimeField = fieldtype === 'time' && options.format === 'h:mm a'\n const is24HourTimeField = fieldtype === 'time' && options.format === 'HH:mm'\n const isDisplayImageField = fieldtype === 'image-display' && showOnRead\n const isReferenceField = fieldtype === 'reference'\n\n // NOTE: only show field when show on read is true\n if (!showOnRead) return null\n\n const labelText = [{ text: label }]\n\n if (skipped) {\n return [labelText, [{ text: '-' }]]\n }\n\n if (isHtmlField) {\n const parsed = value.replace(/<p><\\/p>/g, '')\n return [labelText, toPdf(parsed)]\n }\n\n if (isSignatureField) {\n if (!value) return [labelText, '']\n\n return fetchImage(value, {\n Signature: settings.Signature,\n Policy: settings.Policy,\n KeyPairId: settings.KeyPairId,\n }).then(base64String => {\n const values = {\n alignment: 'left',\n image: base64String,\n width: 140,\n }\n return [labelText, values]\n })\n }\n\n if (isDisplayImageField) {\n return Promise.map([value], filepath =>\n buildImage({ filepath, settings })\n ).then(fieldImages => [fieldImages, {}])\n }\n\n if (isPhotoField) {\n return Promise.map(value, filepath =>\n buildImage({ filepath, settings })\n ).then(fieldImages => {\n const tables = !isEmpty(fieldImages) ? imageTables(fieldImages) : []\n\n const imagesRow = {\n colSpan: 2,\n layout: {\n hLineWidth: () => 0,\n paddingLeft: () => 0,\n paddingRight: () => 0,\n paddingTop: () => 0,\n paddingBottom: () => 0,\n vLineWidth: () => 0,\n },\n table: {\n body: [labelText, ...tables],\n widths: ['*'],\n },\n }\n\n // NOTE: pass empty value here as otherwise\n // we can accidentally hide content below\n // this row. Please see the following issue:\n // https://github.com/bpampuch/pdfmake/issues/1598\n return [imagesRow, {}]\n })\n }\n\n if (isFileField) {\n const fileList = map(value, file => buildFile({ file, settings }))\n return [labelText, { ol: fileList }]\n }\n\n if (isNumberField || isSelectField || isSwitchField || isTextField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? { text: join(parsedValue, ', ') }\n : { text: parsedValue }\n\n return [labelText, displayValue]\n }\n\n if (isReferenceField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? {\n text: parsedValue\n .filter(val => val && val.label)\n .map(val => val.label)\n .join(', '),\n fontSize: 7,\n }\n : { text: parsedValue.label, fontSize: 7 }\n\n return [labelText, displayValue]\n }\n\n if (isStarField) {\n if (!value) return [labelText, '']\n const displayValue = value === '1' ? `${value} star` : `${value} stars`\n return [labelText, displayValue]\n }\n\n if (\n isDayFirstDateField ||\n isMonthFirstDateField ||\n is12HourTimeField ||\n is24HourTimeField\n ) {\n const format = options.format\n const displayValue = value\n ? moment(value)\n .tz(timezone)\n .format(format)\n : ''\n\n return [labelText, displayValue]\n }\n\n // NOTE: if no match above null values will be stripped within calling fn\n return null\n}\n\nfunction isDataImage(string) {\n return startsWith(string, 'data:image/png;')\n}\n"],"file":"index.js"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lighthouse/common",
3
- "version": "4.38.0-canary-3",
3
+ "version": "4.38.0-canary-5",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "lib/index.js",