@lighthouse/common 4.24.3-canary.1425 → 4.24.3

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.
package/CHANGELOG.md CHANGED
@@ -1,3 +1,27 @@
1
+ # 4.24.3 (Sun Jan 29 2023)
2
+
3
+ #### 🐛 Bug Fix
4
+
5
+ - ❗️ Hotfix - Absolute URL error fix [#113](https://github.com/Lighthouse-io/common/pull/113) ([@ChrisHurt](https://github.com/ChrisHurt))
6
+
7
+ #### Authors: 1
8
+
9
+ - Chris Hurt ([@ChrisHurt](https://github.com/ChrisHurt))
10
+
11
+ ---
12
+
13
+ # 4.24.2 (Mon Jan 23 2023)
14
+
15
+ #### 🐛 Bug Fix
16
+
17
+ - Phrasing fix [#112](https://github.com/Lighthouse-io/common/pull/112) ([@ChrisHurt](https://github.com/ChrisHurt))
18
+
19
+ #### Authors: 1
20
+
21
+ - Chris Hurt ([@ChrisHurt](https://github.com/ChrisHurt))
22
+
23
+ ---
24
+
1
25
  # 4.23.1 (Mon Jan 23 2023)
2
26
 
3
27
  #### 🐛 Bug Fix
@@ -16,6 +16,8 @@ var _fetchPonyfill = _interopRequireDefault(require("fetch-ponyfill"));
16
16
 
17
17
  var _bluebird = _interopRequireDefault(require("bluebird"));
18
18
 
19
+ var _constants = require("../../constants");
20
+
19
21
  // NOTE use the native fetch if it's available in the browser, because the
20
22
  // ponyfill (which actually uses the github polyfill) does not support all the
21
23
  // same options as native fetch
@@ -41,6 +43,9 @@ function fetchImage(url, options = {}) {
41
43
  const fetchOptions = { ...defaultOptions,
42
44
  ...options
43
45
  };
46
+ const {
47
+ isHeader = false
48
+ } = options;
44
49
  return fetch(url, fetchOptions).then(response => {
45
50
  const contentHeader = response.headers.get('content-length');
46
51
  const contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
@@ -74,7 +79,13 @@ function fetchImage(url, options = {}) {
74
79
 
75
80
  return base64;
76
81
  }).catch(error => {
77
- // NOTE: catch all error to log and then rethrow
82
+ if (isHeader) {
83
+ // NOTE: Replace failed headers with LH logo
84
+ console.error('FetchImageHeaderError', error);
85
+ return fetchImage(_constants.LIGHTHOUSE_LOGO_URL, defaultOptions);
86
+ } // NOTE: catch all error to log and then rethrow
87
+
88
+
78
89
  console.error(error);
79
90
  throw error;
80
91
  });
@@ -22,7 +22,9 @@ function defaultFooter({
22
22
  });
23
23
  const footerText = sequenceId ? `${type} ${sequenceId}` : `${type}`; // eslint-disable-next-line no-unused-vars
24
24
 
25
- return (0, _helpers.fetchImage)(logoUrl).then(image => _page => ({
25
+ return (0, _helpers.fetchImage)(logoUrl, {
26
+ isHeader: true
27
+ }).then(image => _page => ({
26
28
  columns: [{
27
29
  fit: [80, 30],
28
30
  image,
@@ -7,24 +7,6 @@ exports.defaultHeader = defaultHeader;
7
7
 
8
8
  var _helpers = require("../../../helpers");
9
9
 
10
- const generateColumnsWithImage = ({
11
- datetime,
12
- image
13
- }) => ({
14
- columns: [{
15
- fit: [130, 30],
16
- image,
17
- margin: [60, 60, 60, 0]
18
- }, {
19
- alignment: 'right',
20
- color: '#999',
21
- font: 'Gotham',
22
- fontSize: 11,
23
- text: datetime,
24
- margin: [60, 70, 60, 0]
25
- }]
26
- });
27
-
28
10
  function defaultHeader({
29
11
  logoUrl,
30
12
  timestamp,
@@ -36,14 +18,20 @@ function defaultHeader({
36
18
  timestamp,
37
19
  timezone
38
20
  });
39
- return (0, _helpers.fetchImage)(logoUrl).then(image => generateColumnsWithImage({
40
- datetime,
41
- image
42
- })).catch(error => {
43
- console.error(`GenerateDefinitionError: Invalid Image URL: ${logoUrl}`, error);
44
- return (0, _helpers.fetchImage)().then(image => generateColumnsWithImage({
45
- datetime,
46
- image
47
- }));
48
- });
21
+ return (0, _helpers.fetchImage)(logoUrl, {
22
+ isHeader: true
23
+ }).then(image => ({
24
+ columns: [{
25
+ fit: [130, 30],
26
+ image,
27
+ margin: [60, 60, 60, 0]
28
+ }, {
29
+ alignment: 'right',
30
+ color: '#999',
31
+ font: 'Gotham',
32
+ fontSize: 11,
33
+ text: datetime,
34
+ margin: [60, 70, 60, 0]
35
+ }]
36
+ }));
49
37
  }
@@ -7,7 +7,8 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
7
7
 
8
8
  import { atob, btoa } from '@lighthouse/abab';
9
9
  import fetchPonyfill from 'fetch-ponyfill';
10
- import Promise from 'bluebird'; // NOTE use the native fetch if it's available in the browser, because the
10
+ import Promise from 'bluebird';
11
+ import { LIGHTHOUSE_LOGO_URL } from '../../constants'; // NOTE use the native fetch if it's available in the browser, because the
11
12
  // ponyfill (which actually uses the github polyfill) does not support all the
12
13
  // same options as native fetch
13
14
 
@@ -33,6 +34,8 @@ export function fetchImage(url) {
33
34
 
34
35
  var fetchOptions = _objectSpread(_objectSpread({}, defaultOptions), options);
35
36
 
37
+ var _options$isHeader = options.isHeader,
38
+ isHeader = _options$isHeader === void 0 ? false : _options$isHeader;
36
39
  return fetch(url, fetchOptions).then(function (response) {
37
40
  var contentHeader = response.headers.get('content-length');
38
41
  var contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
@@ -67,7 +70,13 @@ export function fetchImage(url) {
67
70
 
68
71
  return base64;
69
72
  }).catch(function (error) {
70
- // NOTE: catch all error to log and then rethrow
73
+ if (isHeader) {
74
+ // NOTE: Replace failed headers with LH logo
75
+ console.error('FetchImageHeaderError', error);
76
+ return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions);
77
+ } // NOTE: catch all error to log and then rethrow
78
+
79
+
71
80
  console.error(error);
72
81
  throw error;
73
82
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/fetch-image/index.js"],"names":["atob","btoa","fetchPonyfill","Promise","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","fetchOptions","then","response","contentHeader","headers","get","contentType","reject","Error","ok","imageType","arrayBuffer","buffer","base64Flag","imageStr","arrayBufferToBase64","base64","isValid","validateBase64Image","catch","error","console","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'\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 fetchOptions = {\n ...defaultOptions,\n ...options,\n }\n\n return fetch(url, 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: ${url}`)\n )\n }\n\n if (!response.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${url}`))\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 // NOTE: catch all error to log and then rethrow\n console.error(error)\n throw error\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","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","fetchOptions","isHeader","then","response","contentHeader","headers","get","contentType","reject","Error","ok","imageType","arrayBuffer","buffer","base64Flag","imageStr","arrayBufferToBase64","base64","isValid","validateBase64Image","catch","error","console","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'\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 fetchOptions = {\n ...defaultOptions,\n ...options,\n }\n\n const { isHeader = false } = options\n\n return fetch(url, 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: ${url}`)\n )\n }\n\n if (!response.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${url}`))\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 // NOTE: catch all error to log and then rethrow\n console.error(error)\n throw error\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"}
@@ -13,7 +13,9 @@ export function defaultFooter(_ref) {
13
13
  });
14
14
  var footerText = sequenceId ? "".concat(type, " ").concat(sequenceId) : "".concat(type); // eslint-disable-next-line no-unused-vars
15
15
 
16
- return fetchImage(logoUrl).then(function (image) {
16
+ return fetchImage(logoUrl, {
17
+ isHeader: true
18
+ }).then(function (image) {
17
19
  return function (_page) {
18
20
  return {
19
21
  columns: [{
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/pdf/helpers/default-footer/index.js"],"names":["fetchImage","getTimezoneDatetime","defaultFooter","logoUrl","timestamp","timezone","type","sequenceId","datetime","format","showTzAbbr","footerText","then","image","_page","columns","fit","margin","alignment","font","text","style"],"mappings":"AAAA,SAASA,UAAT,EAAqBC,mBAArB,QAAgD,kBAAhD;AAEA,OAAO,SAASC,aAAT,OAMJ;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,GAAGP,mBAAmB,CAAC;AACnCQ,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,SAAON,UAAU,CAACG,OAAD,CAAV,CAAoBS,IAApB,CAAyB,UAAAC,KAAK;AAAA,WAAI,UAAAC,KAAK;AAAA,aAAK;AACjDC,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,YAAKT,UAAL,gBAAqBH,QAArB,CAHN;AAIEa,UAAAA,KAAK,EAAE,OAJT;AAKEJ,UAAAA,MAAM,EAAE,CAAC,CAAD,EAAI,EAAJ,EAAQ,EAAR,EAAY,CAAZ;AALV,SANO;AADwC,OAAL;AAAA,KAAT;AAAA,GAA9B,CAAP;AAgBD","sourcesContent":["import { fetchImage, getTimezoneDatetime } from '../../../helpers'\n\nexport function defaultFooter({\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).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","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,OAMJ;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,GAAGP,mBAAmB,CAAC;AACnCQ,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,SAAON,UAAU,CAACG,OAAD,EAAU;AAAES,IAAAA,QAAQ,EAAE;AAAZ,GAAV,CAAV,CAAwCC,IAAxC,CAA6C,UAAAC,KAAK;AAAA,WAAI,UAAAC,KAAK;AAAA,aAAK;AACrEC,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;AAD4D,OAAL;AAAA,KAAT;AAAA,GAAlD,CAAP;AAgBD","sourcesContent":["import { fetchImage, getTimezoneDatetime } from '../../../helpers'\n\nexport function defaultFooter({\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, { isHeader: true }).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,47 +1,31 @@
1
1
  import { fetchImage, getTimezoneDatetime } from '../../../helpers';
2
-
3
- var generateColumnsWithImage = function generateColumnsWithImage(_ref) {
4
- var datetime = _ref.datetime,
5
- image = _ref.image;
6
- return {
7
- columns: [{
8
- fit: [130, 30],
9
- image: image,
10
- margin: [60, 60, 60, 0]
11
- }, {
12
- alignment: 'right',
13
- color: '#999',
14
- font: 'Gotham',
15
- fontSize: 11,
16
- text: datetime,
17
- margin: [60, 70, 60, 0]
18
- }]
19
- };
20
- };
21
-
22
- export function defaultHeader(_ref2) {
23
- var logoUrl = _ref2.logoUrl,
24
- timestamp = _ref2.timestamp,
25
- timezone = _ref2.timezone;
2
+ export function defaultHeader(_ref) {
3
+ var logoUrl = _ref.logoUrl,
4
+ timestamp = _ref.timestamp,
5
+ timezone = _ref.timezone;
26
6
  var datetime = getTimezoneDatetime({
27
7
  format: 'ddd, Do MMM YYYY',
28
8
  showTzAbbr: false,
29
9
  timestamp: timestamp,
30
10
  timezone: timezone
31
11
  });
32
- return fetchImage(logoUrl).then(function (image) {
33
- return generateColumnsWithImage({
34
- datetime: datetime,
35
- image: image
36
- });
37
- }).catch(function (error) {
38
- console.error("GenerateDefinitionError: Invalid Image URL: ".concat(logoUrl), error);
39
- return fetchImage().then(function (image) {
40
- return generateColumnsWithImage({
41
- datetime: datetime,
42
- image: image
43
- });
44
- });
12
+ return fetchImage(logoUrl, {
13
+ isHeader: true
14
+ }).then(function (image) {
15
+ return {
16
+ columns: [{
17
+ fit: [130, 30],
18
+ image: image,
19
+ margin: [60, 60, 60, 0]
20
+ }, {
21
+ alignment: 'right',
22
+ color: '#999',
23
+ font: 'Gotham',
24
+ fontSize: 11,
25
+ text: datetime,
26
+ margin: [60, 70, 60, 0]
27
+ }]
28
+ };
45
29
  });
46
30
  }
47
31
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/pdf/helpers/default-header/index.js"],"names":["fetchImage","getTimezoneDatetime","generateColumnsWithImage","datetime","image","columns","fit","margin","alignment","color","font","fontSize","text","defaultHeader","logoUrl","timestamp","timezone","format","showTzAbbr","then","catch","error","console"],"mappings":"AAAA,SAASA,UAAT,EAAqBC,mBAArB,QAAgD,kBAAhD;;AAEA,IAAMC,wBAAwB,GAAG,SAA3BA,wBAA2B;AAAA,MAAGC,QAAH,QAAGA,QAAH;AAAA,MAAaC,KAAb,QAAaA,KAAb;AAAA,SAA0B;AACzDC,IAAAA,OAAO,EAAE,CACP;AACEC,MAAAA,GAAG,EAAE,CAAC,GAAD,EAAM,EAAN,CADP;AAEEF,MAAAA,KAAK,EAALA,KAFF;AAGEG,MAAAA,MAAM,EAAE,CAAC,EAAD,EAAK,EAAL,EAAS,EAAT,EAAa,CAAb;AAHV,KADO,EAMP;AACEC,MAAAA,SAAS,EAAE,OADb;AAEEC,MAAAA,KAAK,EAAE,MAFT;AAGEC,MAAAA,IAAI,EAAE,QAHR;AAIEC,MAAAA,QAAQ,EAAE,EAJZ;AAKEC,MAAAA,IAAI,EAAET,QALR;AAMEI,MAAAA,MAAM,EAAE,CAAC,EAAD,EAAK,EAAL,EAAS,EAAT,EAAa,CAAb;AANV,KANO;AADgD,GAA1B;AAAA,CAAjC;;AAkBA,OAAO,SAASM,aAAT,QAAyD;AAAA,MAAhCC,OAAgC,SAAhCA,OAAgC;AAAA,MAAvBC,SAAuB,SAAvBA,SAAuB;AAAA,MAAZC,QAAY,SAAZA,QAAY;AAC9D,MAAMb,QAAQ,GAAGF,mBAAmB,CAAC;AACnCgB,IAAAA,MAAM,EAAE,kBAD2B;AAEnCC,IAAAA,UAAU,EAAE,KAFuB;AAGnCH,IAAAA,SAAS,EAATA,SAHmC;AAInCC,IAAAA,QAAQ,EAARA;AAJmC,GAAD,CAApC;AAOA,SAAOhB,UAAU,CAACc,OAAD,CAAV,CACJK,IADI,CACC,UAAAf,KAAK;AAAA,WAAIF,wBAAwB,CAAC;AAAEC,MAAAA,QAAQ,EAARA,QAAF;AAAYC,MAAAA,KAAK,EAALA;AAAZ,KAAD,CAA5B;AAAA,GADN,EAEJgB,KAFI,CAEE,UAAAC,KAAK,EAAI;AACdC,IAAAA,OAAO,CAACD,KAAR,uDACiDP,OADjD,GAEEO,KAFF;AAKA,WAAOrB,UAAU,GAAGmB,IAAb,CAAkB,UAAAf,KAAK;AAAA,aAC5BF,wBAAwB,CAAC;AAAEC,QAAAA,QAAQ,EAARA,QAAF;AAAYC,QAAAA,KAAK,EAALA;AAAZ,OAAD,CADI;AAAA,KAAvB,CAAP;AAGD,GAXI,CAAP;AAYD","sourcesContent":["import { fetchImage, getTimezoneDatetime } from '../../../helpers'\n\nconst generateColumnsWithImage = ({ datetime, 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\nexport function defaultHeader({ logoUrl, timestamp, timezone }) {\n const datetime = getTimezoneDatetime({\n format: 'ddd, Do MMM YYYY',\n showTzAbbr: false,\n timestamp,\n timezone,\n })\n\n return fetchImage(logoUrl)\n .then(image => generateColumnsWithImage({ datetime, image }))\n .catch(error => {\n console.error(\n `GenerateDefinitionError: Invalid Image URL: ${logoUrl}`,\n error\n )\n\n return fetchImage().then(image =>\n generateColumnsWithImage({ datetime, image })\n )\n })\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../../src/pdf/helpers/default-header/index.js"],"names":["fetchImage","getTimezoneDatetime","defaultHeader","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,OAAyD;AAAA,MAAhCC,OAAgC,QAAhCA,OAAgC;AAAA,MAAvBC,SAAuB,QAAvBA,SAAuB;AAAA,MAAZC,QAAY,QAAZA,QAAY;AAC9D,MAAMC,QAAQ,GAAGL,mBAAmB,CAAC;AACnCM,IAAAA,MAAM,EAAE,kBAD2B;AAEnCC,IAAAA,UAAU,EAAE,KAFuB;AAGnCJ,IAAAA,SAAS,EAATA,SAHmC;AAInCC,IAAAA,QAAQ,EAARA;AAJmC,GAAD,CAApC;AAOA,SAAOL,UAAU,CAACG,OAAD,EAAU;AAAEM,IAAAA,QAAQ,EAAE;AAAZ,GAAV,CAAV,CAAwCC,IAAxC,CAA6C,UAAAC,KAAK;AAAA,WAAK;AAC5DC,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;AADmD,KAAL;AAAA,GAAlD,CAAP;AAiBD","sourcesContent":["import { fetchImage, getTimezoneDatetime } from '../../../helpers'\n\nexport function defaultHeader({ logoUrl, timestamp, timezone }) {\n const datetime = getTimezoneDatetime({\n format: 'ddd, Do MMM YYYY',\n showTzAbbr: false,\n timestamp,\n timezone,\n })\n\n return fetchImage(logoUrl, { isHeader: true }).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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lighthouse/common",
3
- "version": "4.24.3-canary.1425",
3
+ "version": "4.24.3",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "lib/index.js",