@lighthouse/common 4.37.0-canary-19 → 4.37.0

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.
Files changed (40) hide show
  1. package/dist/helpers/build-fetch-url/index.js +0 -14
  2. package/dist/helpers/fetch-image/index.js +1 -70
  3. package/dist/helpers/get-audit-entry-details/index.js +2 -0
  4. package/dist/helpers/get-audit-items-data/index.js +1 -4
  5. package/dist/helpers/get-issue-details/index.js +2 -0
  6. package/dist/helpers/get-task-entry-details/index.js +3 -1
  7. package/dist/pdf/audit/index.js +1 -0
  8. package/dist/pdf/helpers/build-audit-content/index.js +2 -4
  9. package/dist/pdf/helpers/default-footer/index.js +0 -2
  10. package/dist/pdf/helpers/default-header/index.js +0 -2
  11. package/dist/pdf/helpers/fields/index.js +3 -10
  12. package/lib/helpers/build-fetch-url/index.js +0 -19
  13. package/lib/helpers/build-fetch-url/index.js.map +1 -1
  14. package/lib/helpers/fetch-image/index.js +5 -106
  15. package/lib/helpers/fetch-image/index.js.map +1 -1
  16. package/lib/helpers/get-audit-entry-details/index.js +2 -0
  17. package/lib/helpers/get-audit-entry-details/index.js.map +1 -1
  18. package/lib/helpers/get-audit-items-data/index.js +0 -3
  19. package/lib/helpers/get-audit-items-data/index.js.map +1 -1
  20. package/lib/helpers/get-issue-details/index.js +2 -0
  21. package/lib/helpers/get-issue-details/index.js.map +1 -1
  22. package/lib/helpers/get-task-entry-details/index.js +3 -1
  23. package/lib/helpers/get-task-entry-details/index.js.map +1 -1
  24. package/lib/pdf/audit/index.js +1 -0
  25. package/lib/pdf/audit/index.js.map +1 -1
  26. package/lib/pdf/helpers/build-audit-content/index.js +1 -4
  27. package/lib/pdf/helpers/build-audit-content/index.js.map +1 -1
  28. package/lib/pdf/helpers/default-footer/index.js +1 -3
  29. package/lib/pdf/helpers/default-footer/index.js.map +1 -1
  30. package/lib/pdf/helpers/default-header/index.js +1 -3
  31. package/lib/pdf/helpers/default-header/index.js.map +1 -1
  32. package/lib/pdf/helpers/fields/index.js +3 -10
  33. package/lib/pdf/helpers/fields/index.js.map +1 -1
  34. package/package.json +1 -2
  35. package/.vscode/tasks.json +0 -15
  36. package/dist/helpers/fetch-jwt/index.js +0 -43
  37. package/lib/helpers/fetch-jwt/index.js +0 -64
  38. package/lib/helpers/fetch-jwt/index.js.map +0 -1
  39. package/mise.toml +0 -2
  40. package/yarn-error.log +0 -13549
@@ -8,26 +8,12 @@ exports.buildFetchUrl = buildFetchUrl;
8
8
  function buildFetchUrl(url, options) {
9
9
  const {
10
10
  awsS3BaseUrl,
11
- cloudfrontBaseUrl = '',
12
11
  cloudinaryBaseUrl,
13
12
  fit,
14
13
  height,
15
14
  width,
16
15
  quality
17
16
  } = options;
18
- const shouldUseCloudfront = cloudfrontBaseUrl && cloudfrontBaseUrl.includes('.cloudfront.net');
19
-
20
- if (shouldUseCloudfront) {
21
- const transformations = [];
22
- if (width) transformations.push(`width=${width.toString()}`);
23
- if (height) transformations.push(`height=${height.toString()}`);
24
- if (quality) transformations.push(`quality=${quality.toString()}`);
25
- transformations.push(`fit=contain`);
26
- const transformationsString = transformations.join(',');
27
- const fetchUrl = `${cloudfrontBaseUrl}/${url}?${transformationsString}`;
28
- return fetchUrl;
29
- }
30
-
31
17
  const transformations = [];
32
18
  let transformationsString = '';
33
19
  if (width) transformations.push(`w_${width.toString()}`);
@@ -20,8 +20,6 @@ var _constants = require("../../constants");
20
20
 
21
21
  var _images = require("../../images");
22
22
 
23
- var _fetchJwt = require("../fetch-jwt");
24
-
25
23
  // NOTE use the native fetch if it's available in the browser, because the
26
24
  // ponyfill (which actually uses the github polyfill) does not support all the
27
25
  // same options as native fetch
@@ -46,78 +44,11 @@ const defaultOptions = {
46
44
  function fetchImage(url, options = {}) {
47
45
  const encodedUrl = encodeURI(url);
48
46
  const fetchOptions = { ...defaultOptions,
49
- ...options,
50
- headers: { ...(options.headers || {})
51
- }
47
+ ...options
52
48
  };
53
- const urlMatch = url && url.match(/([a-f0-9]{24})\//);
54
- const applicationId = urlMatch && urlMatch[1];
55
- const shouldUseCloudfront = url && url.includes('.cloudfront.net');
56
49
  const {
57
50
  isHeader = false
58
51
  } = options;
59
-
60
- if (shouldUseCloudfront) {
61
- console.info('Fetching image via CloudFront');
62
- return (async () => {
63
- const isWebContext = typeof window === 'object';
64
- const token = isWebContext ? options.imageAuthToken : await (0, _fetchJwt.fetchJWTFromGenerator)(applicationId)?.token;
65
- const webFetchOptions = {
66
- headers: {
67
- Authorization: `Bearer ${token}`
68
- }
69
- };
70
- const serverlessFetchOptions = { ...defaultOptions,
71
- ...options,
72
- headers: { ...(options.headers || {})
73
- }
74
- };
75
- const fetchOptions = isWebContext ? webFetchOptions : serverlessFetchOptions;
76
- return fetch(encodedUrl, fetchOptions).then(response => {
77
- const contentHeader = response.headers.get('content-length');
78
- const contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
79
- // image meaning pdfmake will error. Raise error here and return early.
80
-
81
- if (contentHeader === '0') {
82
- return _bluebird.default.reject(new Error(`Failed to fetch image as no content length: ${encodedUrl}`));
83
- }
84
-
85
- if (!response.ok) {
86
- return _bluebird.default.reject(new Error(`Failed to fetch image: ${encodedUrl}`));
87
- }
88
-
89
- const imageType = contentTypes[contentType];
90
- return response.arrayBuffer().then(buffer => ({
91
- buffer,
92
- imageType
93
- }));
94
- }).then(({
95
- buffer,
96
- imageType
97
- }) => {
98
- const base64Flag = `data:image/${imageType};base64,`;
99
- const imageStr = arrayBufferToBase64(buffer);
100
- const base64 = `${base64Flag}${imageStr}`;
101
- const isValid = validateBase64Image(base64);
102
-
103
- if (!isValid) {
104
- return _bluebird.default.reject(new Error('InvalidImageError'));
105
- }
106
-
107
- return base64;
108
- }).catch(error => {
109
- if (isHeader) {
110
- // NOTE: Replace failed headers with LH logo
111
- console.error('FetchImageHeaderError', error);
112
- return fetchImage(_constants.LIGHTHOUSE_LOGO_URL, defaultOptions);
113
- }
114
-
115
- console.error(error);
116
- return _images.imageNotFound;
117
- });
118
- })();
119
- }
120
-
121
52
  return fetch(encodedUrl, fetchOptions).then(response => {
122
53
  const contentHeader = response.headers.get('content-length');
123
54
  const contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
@@ -18,6 +18,7 @@ function getAuditEntryDetails(data) {
18
18
  createdAt,
19
19
  gps,
20
20
  items,
21
+ templateRevision,
21
22
  sequenceId,
22
23
  score,
23
24
  target,
@@ -43,6 +44,7 @@ function getAuditEntryDetails(data) {
43
44
  locationText,
44
45
  referenceLabel: referenceDetails.label,
45
46
  referenceValue: referenceDetails.value,
47
+ templateRevision,
46
48
  scoreText,
47
49
  sequenceId,
48
50
  target,
@@ -13,8 +13,7 @@ function getAuditItemsData(items, data) {
13
13
  const {
14
14
  settings: {
15
15
  awsS3BaseUrl,
16
- cloudinaryBaseUrl,
17
- cloudfrontBaseUrl
16
+ cloudinaryBaseUrl
18
17
  } = {},
19
18
  entity: {
20
19
  groupScores
@@ -57,7 +56,6 @@ function getAuditItemsData(items, data) {
57
56
  const assets = rawAssets.map((asset, assetIndex) => {
58
57
  const assetUrl = (0, _.buildFetchUrl)(asset, {
59
58
  awsS3BaseUrl,
60
- cloudfrontBaseUrl,
61
59
  cloudinaryBaseUrl,
62
60
  fit: true,
63
61
  height: 400,
@@ -67,7 +65,6 @@ function getAuditItemsData(items, data) {
67
65
  const link = `${awsS3BaseUrl}/${asset}`;
68
66
  const thumbnailUrl = (0, _.buildFetchUrl)(asset, {
69
67
  awsS3BaseUrl,
70
- cloudfrontBaseUrl,
71
68
  cloudinaryBaseUrl,
72
69
  width: 100,
73
70
  quality: 50
@@ -24,6 +24,7 @@ function getIssueDetails(data) {
24
24
  createdAt,
25
25
  duration,
26
26
  gps,
27
+ templateRevision,
27
28
  sequenceId,
28
29
  status,
29
30
  user
@@ -52,6 +53,7 @@ function getIssueDetails(data) {
52
53
  fullName,
53
54
  isClosedStatus,
54
55
  locationText,
56
+ templateRevision,
55
57
  sequenceId,
56
58
  statusStyle,
57
59
  statusColor,
@@ -17,7 +17,8 @@ function getTaskEntryDetails(data) {
17
17
  const {
18
18
  createdAt,
19
19
  gps,
20
- sequenceId
20
+ sequenceId,
21
+ templateRevision
21
22
  } = entity;
22
23
  const gpsText = (0, _lodash.get)(gps, 'reverseGeocoded.label', 'Unknown Location');
23
24
  const locationText = (0, _.getLocationReference)(data);
@@ -37,6 +38,7 @@ function getTaskEntryDetails(data) {
37
38
  referenceLabel: referenceDetails.label,
38
39
  referenceValue: referenceDetails.value,
39
40
  sequenceId,
41
+ templateRevision,
40
42
  timezoneHourTime,
41
43
  timezoneDatetime
42
44
  };
@@ -49,6 +49,7 @@ function buildAuditPdf(pdfOptions, data) {
49
49
  const {
50
50
  flags = {}
51
51
  } = pdfOptions;
52
+ console.info('buildAuditPdf');
52
53
  const sequenceId = entity.sequenceId;
53
54
  const timestamp = entity.createdAt;
54
55
  const title = entity.title || 'Unknown';
@@ -17,16 +17,14 @@ var _ = require("../");
17
17
 
18
18
  var _table = require("../table");
19
19
 
20
- const buildAuditContent = _bluebird.default.method((items, settings = {}) => {
20
+ const buildAuditContent = _bluebird.default.method(items => {
21
21
  return _bluebird.default.map(items, group => {
22
22
  return _bluebird.default.map(group.items, (item, index) => {
23
23
  return _bluebird.default.map(item.assets, ({
24
24
  assetUrl,
25
25
  link
26
26
  }) => {
27
- return (0, _helpers.fetchImage)(assetUrl, {
28
- imageAuthToken: settings.imageAuthToken
29
- }).then(base64String => ({
27
+ return (0, _helpers.fetchImage)(assetUrl).then(base64String => ({
30
28
  alignment: 'center',
31
29
  fit: [210, 210],
32
30
  image: base64String,
@@ -8,7 +8,6 @@ exports.defaultFooter = defaultFooter;
8
8
  var _helpers = require("../../../helpers");
9
9
 
10
10
  function defaultFooter({
11
- imageAuthToken,
12
11
  logoUrl,
13
12
  timestamp,
14
13
  timezone,
@@ -24,7 +23,6 @@ function defaultFooter({
24
23
  const footerText = sequenceId ? `${type} ${sequenceId}` : `${type}`; // eslint-disable-next-line no-unused-vars
25
24
 
26
25
  return (0, _helpers.fetchImage)(logoUrl, {
27
- imageAuthToken,
28
26
  isHeader: true
29
27
  }).then(image => _page => ({
30
28
  columns: [{
@@ -8,7 +8,6 @@ exports.defaultHeader = defaultHeader;
8
8
  var _helpers = require("../../../helpers");
9
9
 
10
10
  function defaultHeader({
11
- imageAuthToken,
12
11
  logoUrl,
13
12
  timestamp,
14
13
  timezone
@@ -20,7 +19,6 @@ function defaultHeader({
20
19
  timezone
21
20
  });
22
21
  return (0, _helpers.fetchImage)(logoUrl, {
23
- imageAuthToken,
24
22
  isHeader: true
25
23
  }).then(image => ({
26
24
  columns: [{
@@ -50,9 +50,7 @@ function buildImage(options) {
50
50
  } = options;
51
51
  const {
52
52
  awsS3BaseUrl,
53
- cloudinaryBaseUrl,
54
- cloudfrontBaseUrl,
55
- imageAuthToken
53
+ cloudinaryBaseUrl
56
54
  } = settings;
57
55
  const isVideoType = new RegExp('.mp4$').test(filepath);
58
56
  const link = `${awsS3BaseUrl}/${filepath}`;
@@ -68,16 +66,13 @@ function buildImage(options) {
68
66
 
69
67
  const url = (0, _helpers.buildFetchUrl)(filepath, {
70
68
  awsS3BaseUrl,
71
- cloudfrontBaseUrl,
72
69
  cloudinaryBaseUrl,
73
70
  fit: true,
74
71
  height: 400,
75
72
  width: 600,
76
73
  quality: 50
77
74
  });
78
- return (0, _helpers.fetchImage)(url, {
79
- imageAuthToken
80
- }).then(base64String => ({
75
+ return (0, _helpers.fetchImage)(url).then(base64String => ({
81
76
  alignment,
82
77
  fit: [width, height],
83
78
  image: base64String,
@@ -258,9 +253,7 @@ function buildTemplateFieldRow({
258
253
 
259
254
  if (isSignatureField) {
260
255
  if (!value) return [labelText, ''];
261
- return (0, _helpers.fetchImage)(value, {
262
- imageAuthToken: settings.imageAuthToken
263
- }).then(base64String => {
256
+ return (0, _helpers.fetchImage)(value).then(base64String => {
264
257
  const values = {
265
258
  alignment: 'left',
266
259
  image: base64String,
@@ -1,29 +1,10 @@
1
1
  export function buildFetchUrl(url, options) {
2
2
  var awsS3BaseUrl = options.awsS3BaseUrl,
3
- _options$cloudfrontBa = options.cloudfrontBaseUrl,
4
- cloudfrontBaseUrl = _options$cloudfrontBa === void 0 ? '' : _options$cloudfrontBa,
5
3
  cloudinaryBaseUrl = options.cloudinaryBaseUrl,
6
4
  fit = options.fit,
7
5
  height = options.height,
8
6
  width = options.width,
9
7
  quality = options.quality;
10
- var shouldUseCloudfront = cloudfrontBaseUrl && cloudfrontBaseUrl.includes('.cloudfront.net');
11
-
12
- if (shouldUseCloudfront) {
13
- var _transformations = [];
14
- if (width) _transformations.push("width=".concat(width.toString()));
15
- if (height) _transformations.push("height=".concat(height.toString()));
16
- if (quality) _transformations.push("quality=".concat(quality.toString()));
17
-
18
- _transformations.push("fit=contain");
19
-
20
- var _transformationsString = _transformations.join(',');
21
-
22
- var _fetchUrl = "".concat(cloudfrontBaseUrl, "/").concat(url, "?").concat(_transformationsString);
23
-
24
- return _fetchUrl;
25
- }
26
-
27
8
  var transformations = [];
28
9
  var transformationsString = '';
29
10
  if (width) transformations.push("w_".concat(width.toString()));
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/build-fetch-url/index.js"],"names":["buildFetchUrl","url","options","awsS3BaseUrl","cloudfrontBaseUrl","cloudinaryBaseUrl","fit","height","width","quality","shouldUseCloudfront","includes","transformations","push","toString","transformationsString","join","fetchUrl"],"mappings":"AAAA,OAAO,SAASA,aAAT,CAAuBC,GAAvB,EAA4BC,OAA5B,EAAqC;AAAA,MAExCC,YAFwC,GAStCD,OATsC,CAExCC,YAFwC;AAAA,8BAStCD,OATsC,CAGxCE,iBAHwC;AAAA,MAGxCA,iBAHwC,sCAGpB,EAHoB;AAAA,MAIxCC,iBAJwC,GAStCH,OATsC,CAIxCG,iBAJwC;AAAA,MAKxCC,GALwC,GAStCJ,OATsC,CAKxCI,GALwC;AAAA,MAMxCC,MANwC,GAStCL,OATsC,CAMxCK,MANwC;AAAA,MAOxCC,KAPwC,GAStCN,OATsC,CAOxCM,KAPwC;AAAA,MAQxCC,OARwC,GAStCP,OATsC,CAQxCO,OARwC;AAW1C,MAAMC,mBAAmB,GACvBN,iBAAiB,IAAIA,iBAAiB,CAACO,QAAlB,CAA2B,iBAA3B,CADvB;;AAGA,MAAID,mBAAJ,EAAyB;AACvB,QAAME,gBAAe,GAAG,EAAxB;AAEA,QAAIJ,KAAJ,EAAWI,gBAAe,CAACC,IAAhB,iBAA8BL,KAAK,CAACM,QAAN,EAA9B;AACX,QAAIP,MAAJ,EAAYK,gBAAe,CAACC,IAAhB,kBAA+BN,MAAM,CAACO,QAAP,EAA/B;AACZ,QAAIL,OAAJ,EAAaG,gBAAe,CAACC,IAAhB,mBAAgCJ,OAAO,CAACK,QAAR,EAAhC;;AACbF,IAAAA,gBAAe,CAACC,IAAhB;;AAEA,QAAME,sBAAqB,GAAGH,gBAAe,CAACI,IAAhB,CAAqB,GAArB,CAA9B;;AAEA,QAAMC,SAAQ,aAAMb,iBAAN,cAA2BH,GAA3B,cAAkCc,sBAAlC,CAAd;;AACA,WAAOE,SAAP;AACD;;AAED,MAAML,eAAe,GAAG,EAAxB;AACA,MAAIG,qBAAqB,GAAG,EAA5B;AAEA,MAAIP,KAAJ,EAAWI,eAAe,CAACC,IAAhB,aAA0BL,KAAK,CAACM,QAAN,EAA1B;AACX,MAAIP,MAAJ,EAAYK,eAAe,CAACC,IAAhB,aAA0BN,MAAM,CAACO,QAAP,EAA1B;AACZ,MAAIL,OAAJ,EAAaG,eAAe,CAACC,IAAhB,aAA0BJ,OAAO,CAACK,QAAR,EAA1B;AACb,MAAIR,GAAJ,EAASM,eAAe,CAACC,IAAhB,CAAqB,OAArB;AAETE,EAAAA,qBAAqB,aAAMH,eAAe,CAACI,IAAhB,CAAqB,GAArB,CAAN,MAArB;AAEA,MAAMC,QAAQ,aAAMZ,iBAAN,cAA2BU,qBAA3B,SAAmDZ,YAAnD,cAAmEF,GAAnE,CAAd;AAEA,SAAOgB,QAAP;AACD","sourcesContent":["export function buildFetchUrl(url, options) {\n const {\n awsS3BaseUrl,\n cloudfrontBaseUrl = '',\n cloudinaryBaseUrl,\n fit,\n height,\n width,\n quality,\n } = options\n\n const shouldUseCloudfront =\n cloudfrontBaseUrl && cloudfrontBaseUrl.includes('.cloudfront.net')\n\n if (shouldUseCloudfront) {\n const transformations = []\n\n if (width) transformations.push(`width=${width.toString()}`)\n if (height) transformations.push(`height=${height.toString()}`)\n if (quality) transformations.push(`quality=${quality.toString()}`)\n transformations.push(`fit=contain`)\n\n const transformationsString = transformations.join(',')\n\n const fetchUrl = `${cloudfrontBaseUrl}/${url}?${transformationsString}`\n return fetchUrl\n }\n\n const transformations = []\n let transformationsString = ''\n\n if (width) transformations.push(`w_${width.toString()}`)\n if (height) transformations.push(`h_${height.toString()}`)\n if (quality) transformations.push(`q_${quality.toString()}`)\n if (fit) transformations.push('c_fit')\n\n transformationsString = `${transformations.join(',')}/`\n\n const fetchUrl = `${cloudinaryBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`\n\n return fetchUrl\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/helpers/build-fetch-url/index.js"],"names":["buildFetchUrl","url","options","awsS3BaseUrl","cloudinaryBaseUrl","fit","height","width","quality","transformations","transformationsString","push","toString","join","fetchUrl"],"mappings":"AAAA,OAAO,SAASA,aAAT,CAAuBC,GAAvB,EAA4BC,OAA5B,EAAqC;AAAA,MAExCC,YAFwC,GAQtCD,OARsC,CAExCC,YAFwC;AAAA,MAGxCC,iBAHwC,GAQtCF,OARsC,CAGxCE,iBAHwC;AAAA,MAIxCC,GAJwC,GAQtCH,OARsC,CAIxCG,GAJwC;AAAA,MAKxCC,MALwC,GAQtCJ,OARsC,CAKxCI,MALwC;AAAA,MAMxCC,KANwC,GAQtCL,OARsC,CAMxCK,KANwC;AAAA,MAOxCC,OAPwC,GAQtCN,OARsC,CAOxCM,OAPwC;AAU1C,MAAMC,eAAe,GAAG,EAAxB;AACA,MAAIC,qBAAqB,GAAG,EAA5B;AAEA,MAAIH,KAAJ,EAAWE,eAAe,CAACE,IAAhB,aAA0BJ,KAAK,CAACK,QAAN,EAA1B;AACX,MAAIN,MAAJ,EAAYG,eAAe,CAACE,IAAhB,aAA0BL,MAAM,CAACM,QAAP,EAA1B;AACZ,MAAIJ,OAAJ,EAAaC,eAAe,CAACE,IAAhB,aAA0BH,OAAO,CAACI,QAAR,EAA1B;AACb,MAAIP,GAAJ,EAASI,eAAe,CAACE,IAAhB,CAAqB,OAArB;AAETD,EAAAA,qBAAqB,aAAMD,eAAe,CAACI,IAAhB,CAAqB,GAArB,CAAN,MAArB;AAEA,MAAMC,QAAQ,aAAMV,iBAAN,cAA2BM,qBAA3B,SAAmDP,YAAnD,cAAmEF,GAAnE,CAAd;AAEA,SAAOa,QAAP;AACD","sourcesContent":["export function buildFetchUrl(url, options) {\n const {\n awsS3BaseUrl,\n cloudinaryBaseUrl,\n fit,\n height,\n width,\n quality,\n } = options\n\n const transformations = []\n let transformationsString = ''\n\n if (width) transformations.push(`w_${width.toString()}`)\n if (height) transformations.push(`h_${height.toString()}`)\n if (quality) transformations.push(`q_${quality.toString()}`)\n if (fit) transformations.push('c_fit')\n\n transformationsString = `${transformations.join(',')}/`\n\n const fetchUrl = `${cloudinaryBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`\n\n return fetchUrl\n}\n"],"file":"index.js"}
@@ -1,5 +1,3 @@
1
- import _regeneratorRuntime from "@babel/runtime/regenerator";
2
- import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
3
1
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
4
2
  import _typeof from "@babel/runtime/helpers/typeof";
5
3
 
@@ -11,8 +9,7 @@ import { atob, btoa } from '@lighthouse/abab';
11
9
  import fetchPonyfill from 'fetch-ponyfill';
12
10
  import Promise from 'bluebird';
13
11
  import { LIGHTHOUSE_LOGO_URL } from '../../constants';
14
- import { imageNotFound } from '../../images';
15
- import { fetchJWTFromGenerator } from '../fetch-jwt'; // NOTE use the native fetch if it's available in the browser, because the
12
+ import { imageNotFound } from '../../images'; // NOTE use the native fetch if it's available in the browser, because the
16
13
  // ponyfill (which actually uses the github polyfill) does not support all the
17
14
  // same options as native fetch
18
15
 
@@ -37,108 +34,10 @@ export function fetchImage(url) {
37
34
  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
38
35
  var encodedUrl = encodeURI(url);
39
36
 
40
- var fetchOptions = _objectSpread(_objectSpread(_objectSpread({}, defaultOptions), options), {}, {
41
- headers: _objectSpread({}, options.headers || {})
42
- });
37
+ var fetchOptions = _objectSpread(_objectSpread({}, defaultOptions), options);
43
38
 
44
- var urlMatch = url && url.match(/([a-f0-9]{24})\//);
45
- var applicationId = urlMatch && urlMatch[1];
46
- var shouldUseCloudfront = url && url.includes('.cloudfront.net');
47
39
  var _options$isHeader = options.isHeader,
48
40
  isHeader = _options$isHeader === void 0 ? false : _options$isHeader;
49
-
50
- if (shouldUseCloudfront) {
51
- console.info('Fetching image via CloudFront');
52
- return _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
53
- var _fetchJWTFromGenerato;
54
-
55
- var isWebContext, token, webFetchOptions, serverlessFetchOptions, fetchOptions;
56
- return _regeneratorRuntime.wrap(function _callee$(_context) {
57
- while (1) {
58
- switch (_context.prev = _context.next) {
59
- case 0:
60
- isWebContext = (typeof window === "undefined" ? "undefined" : _typeof(window)) === 'object';
61
-
62
- if (!isWebContext) {
63
- _context.next = 5;
64
- break;
65
- }
66
-
67
- _context.t0 = options.imageAuthToken;
68
- _context.next = 8;
69
- break;
70
-
71
- case 5:
72
- _context.next = 7;
73
- return (_fetchJWTFromGenerato = fetchJWTFromGenerator(applicationId)) === null || _fetchJWTFromGenerato === void 0 ? void 0 : _fetchJWTFromGenerato.token;
74
-
75
- case 7:
76
- _context.t0 = _context.sent;
77
-
78
- case 8:
79
- token = _context.t0;
80
- webFetchOptions = {
81
- headers: {
82
- Authorization: "Bearer ".concat(token)
83
- }
84
- };
85
- serverlessFetchOptions = _objectSpread(_objectSpread(_objectSpread({}, defaultOptions), options), {}, {
86
- headers: _objectSpread({}, options.headers || {})
87
- });
88
- fetchOptions = isWebContext ? webFetchOptions : serverlessFetchOptions;
89
- return _context.abrupt("return", fetch(encodedUrl, fetchOptions).then(function (response) {
90
- var contentHeader = response.headers.get('content-length');
91
- var contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
92
- // image meaning pdfmake will error. Raise error here and return early.
93
-
94
- if (contentHeader === '0') {
95
- return Promise.reject(new Error("Failed to fetch image as no content length: ".concat(encodedUrl)));
96
- }
97
-
98
- if (!response.ok) {
99
- return Promise.reject(new Error("Failed to fetch image: ".concat(encodedUrl)));
100
- }
101
-
102
- var imageType = contentTypes[contentType];
103
- return response.arrayBuffer().then(function (buffer) {
104
- return {
105
- buffer: buffer,
106
- imageType: imageType
107
- };
108
- });
109
- }).then(function (_ref2) {
110
- var buffer = _ref2.buffer,
111
- imageType = _ref2.imageType;
112
- var base64Flag = "data:image/".concat(imageType, ";base64,");
113
- var imageStr = arrayBufferToBase64(buffer);
114
- var base64 = "".concat(base64Flag).concat(imageStr);
115
- var isValid = validateBase64Image(base64);
116
-
117
- if (!isValid) {
118
- return Promise.reject(new Error('InvalidImageError'));
119
- }
120
-
121
- return base64;
122
- }).catch(function (error) {
123
- if (isHeader) {
124
- // NOTE: Replace failed headers with LH logo
125
- console.error('FetchImageHeaderError', error);
126
- return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions);
127
- }
128
-
129
- console.error(error);
130
- return imageNotFound;
131
- }));
132
-
133
- case 13:
134
- case "end":
135
- return _context.stop();
136
- }
137
- }
138
- }, _callee);
139
- }))();
140
- }
141
-
142
41
  return fetch(encodedUrl, fetchOptions).then(function (response) {
143
42
  var contentHeader = response.headers.get('content-length');
144
43
  var contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
@@ -159,9 +58,9 @@ export function fetchImage(url) {
159
58
  imageType: imageType
160
59
  };
161
60
  });
162
- }).then(function (_ref3) {
163
- var buffer = _ref3.buffer,
164
- imageType = _ref3.imageType;
61
+ }).then(function (_ref) {
62
+ var buffer = _ref.buffer,
63
+ imageType = _ref.imageType;
165
64
  var base64Flag = "data:image/".concat(imageType, ";base64,");
166
65
  var imageStr = arrayBufferToBase64(buffer);
167
66
  var base64 = "".concat(base64Flag).concat(imageStr);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/fetch-image/index.js"],"names":["atob","btoa","fetchPonyfill","Promise","LIGHTHOUSE_LOGO_URL","imageNotFound","fetchJWTFromGenerator","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","encodedUrl","encodeURI","fetchOptions","headers","urlMatch","match","applicationId","shouldUseCloudfront","includes","isHeader","console","info","isWebContext","window","imageAuthToken","token","webFetchOptions","Authorization","serverlessFetchOptions","then","response","contentHeader","get","contentType","reject","Error","ok","imageType","arrayBuffer","buffer","base64Flag","imageStr","arrayBufferToBase64","base64","isValid","validateBase64Image","catch","error","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 { fetchJWTFromGenerator } from '../fetch-jwt'\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 encodedUrl = encodeURI(url)\n const fetchOptions = {\n ...defaultOptions,\n ...options,\n headers: {\n ...(options.headers || {}),\n },\n }\n\n const urlMatch = url && url.match(/([a-f0-9]{24})\\//)\n const applicationId = urlMatch && urlMatch[1]\n\n const shouldUseCloudfront = url && url.includes('.cloudfront.net')\n\n const { isHeader = false } = options\n\n if (shouldUseCloudfront) {\n console.info('Fetching image via CloudFront')\n\n return (async () => {\n const isWebContext = typeof window === 'object'\n\n const token = isWebContext\n ? options.imageAuthToken\n : await fetchJWTFromGenerator(applicationId)?.token\n\n const webFetchOptions = {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n }\n\n const serverlessFetchOptions = {\n ...defaultOptions,\n ...options,\n headers: {\n ...(options.headers || {}),\n },\n }\n\n const fetchOptions = isWebContext\n ? webFetchOptions\n : serverlessFetchOptions\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(\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 })()\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","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","encodedUrl","encodeURI","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'\nimport { imageNotFound } from '../../images'\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 encodedUrl = encodeURI(url)\n const fetchOptions = {\n ...defaultOptions,\n ...options,\n }\n const { isHeader = false } = options\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"}
@@ -6,6 +6,7 @@ export function getAuditEntryDetails(data) {
6
6
  var createdAt = entity.createdAt,
7
7
  gps = entity.gps,
8
8
  items = entity.items,
9
+ templateRevision = entity.templateRevision,
9
10
  sequenceId = entity.sequenceId,
10
11
  score = entity.score,
11
12
  target = entity.target,
@@ -30,6 +31,7 @@ export function getAuditEntryDetails(data) {
30
31
  locationText: locationText,
31
32
  referenceLabel: referenceDetails.label,
32
33
  referenceValue: referenceDetails.value,
34
+ templateRevision: templateRevision,
33
35
  scoreText: scoreText,
34
36
  sequenceId: sequenceId,
35
37
  target: target,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/get-audit-entry-details/index.js"],"names":["get","getAuditItemsData","getLocationReference","getReferenceDetails","getTimezoneDatetime","getAuditEntryDetails","data","entity","timezone","createdAt","gps","items","sequenceId","score","target","targetServiceLevel","locationText","gpsText","groupedData","referenceDetails","scoreText","percentageResult","undefined","timezoneHourTime","format","timestamp","timezoneDatetime","referenceLabel","label","referenceValue","value"],"mappings":"AAAA,SAASA,GAAT,QAAoB,QAApB;AAEA,SACEC,iBADF,EAEEC,oBAFF,EAGEC,mBAHF,EAIEC,mBAJF,QAKO,KALP;AAOA,OAAO,SAASC,oBAAT,CAA8BC,IAA9B,EAAoC;AAAA,MACjCC,MADiC,GACZD,IADY,CACjCC,MADiC;AAAA,MACzBC,QADyB,GACZF,IADY,CACzBE,QADyB;AAAA,MAIvCC,SAJuC,GAWrCF,MAXqC,CAIvCE,SAJuC;AAAA,MAKvCC,GALuC,GAWrCH,MAXqC,CAKvCG,GALuC;AAAA,MAMvCC,KANuC,GAWrCJ,MAXqC,CAMvCI,KANuC;AAAA,MAOvCC,UAPuC,GAWrCL,MAXqC,CAOvCK,UAPuC;AAAA,MAQvCC,KARuC,GAWrCN,MAXqC,CAQvCM,KARuC;AAAA,MASvCC,MATuC,GAWrCP,MAXqC,CASvCO,MATuC;AAAA,MAUvCC,kBAVuC,GAWrCR,MAXqC,CAUvCQ,kBAVuC;AAazC,MAAMC,YAAY,GAAGd,oBAAoB,CAACI,IAAD,CAAzC;AACA,MAAMW,OAAO,GAAGjB,GAAG,CAACU,GAAD,EAAM,uBAAN,EAA+B,kBAA/B,CAAnB;AACA,MAAMQ,WAAW,GAAGjB,iBAAiB,CAACU,KAAD,EAAQL,IAAR,CAArC;AACA,MAAMa,gBAAgB,GAAGhB,mBAAmB,CAACG,IAAD,CAA5C;AACA,MAAMc,SAAS,GACbP,KAAK,IAAIA,KAAK,CAACQ,gBAAN,KAA2BC,SAApC,aACOT,KAAK,CAACQ,gBADb,SAEI,EAHN;AAIA,MAAME,gBAAgB,GAAGnB,mBAAmB,CAAC;AAC3CoB,IAAAA,MAAM,EAAE,QADmC;AAE3CC,IAAAA,SAAS,EAAEhB,SAFgC;AAG3CD,IAAAA,QAAQ,EAARA;AAH2C,GAAD,CAA5C;AAKA,MAAMkB,gBAAgB,GAAGtB,mBAAmB,CAAC;AAC3CqB,IAAAA,SAAS,EAAEhB,SADgC;AAE3CD,IAAAA,QAAQ,EAARA;AAF2C,GAAD,CAA5C;AAKA,SAAO;AACLS,IAAAA,OAAO,EAAPA,OADK;AAELC,IAAAA,WAAW,EAAXA,WAFK;AAGLF,IAAAA,YAAY,EAAZA,YAHK;AAILW,IAAAA,cAAc,EAAER,gBAAgB,CAACS,KAJ5B;AAKLC,IAAAA,cAAc,EAAEV,gBAAgB,CAACW,KAL5B;AAMLV,IAAAA,SAAS,EAATA,SANK;AAOLR,IAAAA,UAAU,EAAVA,UAPK;AAQLE,IAAAA,MAAM,EAANA,MARK;AASLC,IAAAA,kBAAkB,EAAlBA,kBATK;AAULW,IAAAA,gBAAgB,EAAhBA,gBAVK;AAWLH,IAAAA,gBAAgB,EAAhBA;AAXK,GAAP;AAaD","sourcesContent":["import { get } from 'lodash'\n\nimport {\n getAuditItemsData,\n getLocationReference,\n getReferenceDetails,\n getTimezoneDatetime,\n} from '../'\n\nexport function getAuditEntryDetails(data) {\n const { entity, timezone } = data\n\n const {\n createdAt,\n gps,\n items,\n sequenceId,\n score,\n target,\n targetServiceLevel,\n } = entity\n\n const locationText = getLocationReference(data)\n const gpsText = get(gps, 'reverseGeocoded.label', 'Unknown Location')\n const groupedData = getAuditItemsData(items, data)\n const referenceDetails = getReferenceDetails(data)\n const scoreText =\n score && score.percentageResult !== undefined\n ? `${score.percentageResult}%`\n : ''\n const timezoneHourTime = getTimezoneDatetime({\n format: 'h:mm a',\n timestamp: createdAt,\n timezone,\n })\n const timezoneDatetime = getTimezoneDatetime({\n timestamp: createdAt,\n timezone,\n })\n\n return {\n gpsText,\n groupedData,\n locationText,\n referenceLabel: referenceDetails.label,\n referenceValue: referenceDetails.value,\n scoreText,\n sequenceId,\n target,\n targetServiceLevel,\n timezoneDatetime,\n timezoneHourTime,\n }\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/helpers/get-audit-entry-details/index.js"],"names":["get","getAuditItemsData","getLocationReference","getReferenceDetails","getTimezoneDatetime","getAuditEntryDetails","data","entity","timezone","createdAt","gps","items","templateRevision","sequenceId","score","target","targetServiceLevel","locationText","gpsText","groupedData","referenceDetails","scoreText","percentageResult","undefined","timezoneHourTime","format","timestamp","timezoneDatetime","referenceLabel","label","referenceValue","value"],"mappings":"AAAA,SAASA,GAAT,QAAoB,QAApB;AAEA,SACEC,iBADF,EAEEC,oBAFF,EAGEC,mBAHF,EAIEC,mBAJF,QAKO,KALP;AAOA,OAAO,SAASC,oBAAT,CAA8BC,IAA9B,EAAoC;AAAA,MACjCC,MADiC,GACZD,IADY,CACjCC,MADiC;AAAA,MACzBC,QADyB,GACZF,IADY,CACzBE,QADyB;AAAA,MAIvCC,SAJuC,GAYrCF,MAZqC,CAIvCE,SAJuC;AAAA,MAKvCC,GALuC,GAYrCH,MAZqC,CAKvCG,GALuC;AAAA,MAMvCC,KANuC,GAYrCJ,MAZqC,CAMvCI,KANuC;AAAA,MAOvCC,gBAPuC,GAYrCL,MAZqC,CAOvCK,gBAPuC;AAAA,MAQvCC,UARuC,GAYrCN,MAZqC,CAQvCM,UARuC;AAAA,MASvCC,KATuC,GAYrCP,MAZqC,CASvCO,KATuC;AAAA,MAUvCC,MAVuC,GAYrCR,MAZqC,CAUvCQ,MAVuC;AAAA,MAWvCC,kBAXuC,GAYrCT,MAZqC,CAWvCS,kBAXuC;AAczC,MAAMC,YAAY,GAAGf,oBAAoB,CAACI,IAAD,CAAzC;AACA,MAAMY,OAAO,GAAGlB,GAAG,CAACU,GAAD,EAAM,uBAAN,EAA+B,kBAA/B,CAAnB;AACA,MAAMS,WAAW,GAAGlB,iBAAiB,CAACU,KAAD,EAAQL,IAAR,CAArC;AACA,MAAMc,gBAAgB,GAAGjB,mBAAmB,CAACG,IAAD,CAA5C;AACA,MAAMe,SAAS,GACbP,KAAK,IAAIA,KAAK,CAACQ,gBAAN,KAA2BC,SAApC,aACOT,KAAK,CAACQ,gBADb,SAEI,EAHN;AAIA,MAAME,gBAAgB,GAAGpB,mBAAmB,CAAC;AAC3CqB,IAAAA,MAAM,EAAE,QADmC;AAE3CC,IAAAA,SAAS,EAAEjB,SAFgC;AAG3CD,IAAAA,QAAQ,EAARA;AAH2C,GAAD,CAA5C;AAKA,MAAMmB,gBAAgB,GAAGvB,mBAAmB,CAAC;AAC3CsB,IAAAA,SAAS,EAAEjB,SADgC;AAE3CD,IAAAA,QAAQ,EAARA;AAF2C,GAAD,CAA5C;AAKA,SAAO;AACLU,IAAAA,OAAO,EAAPA,OADK;AAELC,IAAAA,WAAW,EAAXA,WAFK;AAGLF,IAAAA,YAAY,EAAZA,YAHK;AAILW,IAAAA,cAAc,EAAER,gBAAgB,CAACS,KAJ5B;AAKLC,IAAAA,cAAc,EAAEV,gBAAgB,CAACW,KAL5B;AAMLnB,IAAAA,gBAAgB,EAAhBA,gBANK;AAOLS,IAAAA,SAAS,EAATA,SAPK;AAQLR,IAAAA,UAAU,EAAVA,UARK;AASLE,IAAAA,MAAM,EAANA,MATK;AAULC,IAAAA,kBAAkB,EAAlBA,kBAVK;AAWLW,IAAAA,gBAAgB,EAAhBA,gBAXK;AAYLH,IAAAA,gBAAgB,EAAhBA;AAZK,GAAP;AAcD","sourcesContent":["import { get } from 'lodash'\n\nimport {\n getAuditItemsData,\n getLocationReference,\n getReferenceDetails,\n getTimezoneDatetime,\n} from '../'\n\nexport function getAuditEntryDetails(data) {\n const { entity, timezone } = data\n\n const {\n createdAt,\n gps,\n items,\n templateRevision,\n sequenceId,\n score,\n target,\n targetServiceLevel,\n } = entity\n\n const locationText = getLocationReference(data)\n const gpsText = get(gps, 'reverseGeocoded.label', 'Unknown Location')\n const groupedData = getAuditItemsData(items, data)\n const referenceDetails = getReferenceDetails(data)\n const scoreText =\n score && score.percentageResult !== undefined\n ? `${score.percentageResult}%`\n : ''\n const timezoneHourTime = getTimezoneDatetime({\n format: 'h:mm a',\n timestamp: createdAt,\n timezone,\n })\n const timezoneDatetime = getTimezoneDatetime({\n timestamp: createdAt,\n timezone,\n })\n\n return {\n gpsText,\n groupedData,\n locationText,\n referenceLabel: referenceDetails.label,\n referenceValue: referenceDetails.value,\n templateRevision,\n scoreText,\n sequenceId,\n target,\n targetServiceLevel,\n timezoneDatetime,\n timezoneHourTime,\n }\n}\n"],"file":"index.js"}
@@ -5,7 +5,6 @@ export function getAuditItemsData(items, data) {
5
5
  _data$settings = _data$settings === void 0 ? {} : _data$settings;
6
6
  var awsS3BaseUrl = _data$settings.awsS3BaseUrl,
7
7
  cloudinaryBaseUrl = _data$settings.cloudinaryBaseUrl,
8
- cloudfrontBaseUrl = _data$settings.cloudfrontBaseUrl,
9
8
  _data$entity = data.entity;
10
9
  _data$entity = _data$entity === void 0 ? {} : _data$entity;
11
10
  var groupScores = _data$entity.groupScores;
@@ -46,7 +45,6 @@ export function getAuditItemsData(items, data) {
46
45
  var assets = rawAssets.map(function (asset, assetIndex) {
47
46
  var assetUrl = buildFetchUrl(asset, {
48
47
  awsS3BaseUrl: awsS3BaseUrl,
49
- cloudfrontBaseUrl: cloudfrontBaseUrl,
50
48
  cloudinaryBaseUrl: cloudinaryBaseUrl,
51
49
  fit: true,
52
50
  height: 400,
@@ -56,7 +54,6 @@ export function getAuditItemsData(items, data) {
56
54
  var link = "".concat(awsS3BaseUrl, "/").concat(asset);
57
55
  var thumbnailUrl = buildFetchUrl(asset, {
58
56
  awsS3BaseUrl: awsS3BaseUrl,
59
- cloudfrontBaseUrl: cloudfrontBaseUrl,
60
57
  cloudinaryBaseUrl: cloudinaryBaseUrl,
61
58
  width: 100,
62
59
  quality: 50
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/get-audit-items-data/index.js"],"names":["find","groupBy","map","get","round","buildFetchUrl","getAuditItemsData","items","data","settings","awsS3BaseUrl","cloudinaryBaseUrl","cloudfrontBaseUrl","entity","groupScores","groupedItems","auditData","overallActualScore","overallMaximumScore","groupIndex","key","skipped","group","title","label","groupData","groupMaximumScore","groupActualScore","groupResultScore","groupPercentageResultScore","currentGroupScores","max","actual","result","percentageResult","item","itemIndex","hasScore","score","rawAssets","assets","assetCount","length","asset","assetIndex","assetUrl","fit","height","width","quality","link","thumbnailUrl","comments","matchingScore","scores","value","scoreLabel","scoreWeight","weight","questionId","_id"],"mappings":"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","sourcesContent":["import { find, groupBy, map, get, round } from 'lodash'\n\nimport { buildFetchUrl } from '../'\n\nexport function getAuditItemsData(items, data) {\n const {\n settings: { awsS3BaseUrl, cloudinaryBaseUrl, cloudfrontBaseUrl } = {},\n entity: { groupScores } = {},\n } = data\n\n const groupedItems = groupBy(items, 'group.id')\n\n const auditData = {\n overallActualScore: 0,\n overallMaximumScore: 0,\n }\n\n auditData.items = map(groupedItems, (items, groupIndex) => {\n const key = groupIndex\n const skipped = !!items[0].group.skipped\n const title = items[0].group.label\n\n const groupData = {\n key,\n groupMaximumScore: 0,\n groupActualScore: 0,\n groupResultScore: 0,\n groupPercentageResultScore: 0,\n skipped,\n title,\n }\n\n const currentGroupScores = get(groupScores, key)\n\n if (currentGroupScores) {\n groupData.groupMaximumScore = round(currentGroupScores.max, 2)\n groupData.groupActualScore = round(currentGroupScores.actual, 2)\n groupData.groupResultScore = currentGroupScores.result\n groupData.groupPercentageResultScore = currentGroupScores.percentageResult\n }\n\n groupData.items = items.map((item, itemIndex) => {\n // NOTE: we handle scores of -1, 0 and 1\n // -1 scores are skipped from group max and actual score\n // 0 and 1 must be included in the final scores\n const hasScore = item.score !== null && item.score !== -1\n const rawAssets = item.assets || []\n const assetCount = rawAssets.length\n\n const assets = rawAssets.map((asset, assetIndex) => {\n const assetUrl = buildFetchUrl(asset, {\n awsS3BaseUrl,\n cloudfrontBaseUrl,\n cloudinaryBaseUrl,\n fit: true,\n height: 400,\n width: 600,\n quality: 50,\n })\n\n const link = `${awsS3BaseUrl}/${asset}`\n\n const thumbnailUrl = buildFetchUrl(asset, {\n awsS3BaseUrl,\n cloudfrontBaseUrl,\n cloudinaryBaseUrl,\n width: 100,\n quality: 50,\n })\n\n const key = `${groupIndex}-item-asset-${assetIndex}`\n\n return {\n assetUrl,\n key,\n link,\n thumbnailUrl,\n }\n })\n\n const comments = item.comments\n const label = item.label\n const score = item.score\n const key = `${groupIndex}-item-${itemIndex}`\n const matchingScore = find(item.scores, { value: score })\n\n // NOTE: ensure we have a score otherwise fallback to - value\n const scoreLabel =\n hasScore && matchingScore && !skipped ? matchingScore.label : '-'\n const scoreWeight = hasScore && !skipped ? item.scoreWeight : '-'\n const weight = hasScore ? item.weight : '-'\n\n return {\n assetCount,\n assets,\n comments,\n key,\n label,\n questionId: item._id,\n score,\n scoreLabel,\n scoreWeight,\n weight,\n }\n })\n\n return groupData\n })\n\n return auditData\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/helpers/get-audit-items-data/index.js"],"names":["find","groupBy","map","get","round","buildFetchUrl","getAuditItemsData","items","data","settings","awsS3BaseUrl","cloudinaryBaseUrl","entity","groupScores","groupedItems","auditData","overallActualScore","overallMaximumScore","groupIndex","key","skipped","group","title","label","groupData","groupMaximumScore","groupActualScore","groupResultScore","groupPercentageResultScore","currentGroupScores","max","actual","result","percentageResult","item","itemIndex","hasScore","score","rawAssets","assets","assetCount","length","asset","assetIndex","assetUrl","fit","height","width","quality","link","thumbnailUrl","comments","matchingScore","scores","value","scoreLabel","scoreWeight","weight","questionId","_id"],"mappings":"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","sourcesContent":["import { find, groupBy, map, get, round } from 'lodash'\n\nimport { buildFetchUrl } from '../'\n\nexport function getAuditItemsData(items, data) {\n const {\n settings: { awsS3BaseUrl, cloudinaryBaseUrl } = {},\n entity: { groupScores } = {},\n } = data\n\n const groupedItems = groupBy(items, 'group.id')\n\n const auditData = {\n overallActualScore: 0,\n overallMaximumScore: 0,\n }\n\n auditData.items = map(groupedItems, (items, groupIndex) => {\n const key = groupIndex\n const skipped = !!items[0].group.skipped\n const title = items[0].group.label\n\n const groupData = {\n key,\n groupMaximumScore: 0,\n groupActualScore: 0,\n groupResultScore: 0,\n groupPercentageResultScore: 0,\n skipped,\n title,\n }\n\n const currentGroupScores = get(groupScores, key)\n\n if (currentGroupScores) {\n groupData.groupMaximumScore = round(currentGroupScores.max, 2)\n groupData.groupActualScore = round(currentGroupScores.actual, 2)\n groupData.groupResultScore = currentGroupScores.result\n groupData.groupPercentageResultScore = currentGroupScores.percentageResult\n }\n\n groupData.items = items.map((item, itemIndex) => {\n // NOTE: we handle scores of -1, 0 and 1\n // -1 scores are skipped from group max and actual score\n // 0 and 1 must be included in the final scores\n const hasScore = item.score !== null && item.score !== -1\n const rawAssets = item.assets || []\n const assetCount = rawAssets.length\n\n const assets = rawAssets.map((asset, assetIndex) => {\n const assetUrl = buildFetchUrl(asset, {\n awsS3BaseUrl,\n cloudinaryBaseUrl,\n fit: true,\n height: 400,\n width: 600,\n quality: 50,\n })\n\n const link = `${awsS3BaseUrl}/${asset}`\n\n const thumbnailUrl = buildFetchUrl(asset, {\n awsS3BaseUrl,\n cloudinaryBaseUrl,\n width: 100,\n quality: 50,\n })\n\n const key = `${groupIndex}-item-asset-${assetIndex}`\n\n return {\n assetUrl,\n key,\n link,\n thumbnailUrl,\n }\n })\n\n const comments = item.comments\n const label = item.label\n const score = item.score\n const key = `${groupIndex}-item-${itemIndex}`\n const matchingScore = find(item.scores, { value: score })\n\n // NOTE: ensure we have a score otherwise fallback to - value\n const scoreLabel =\n hasScore && matchingScore && !skipped ? matchingScore.label : '-'\n const scoreWeight = hasScore && !skipped ? item.scoreWeight : '-'\n const weight = hasScore ? item.weight : '-'\n\n return {\n assetCount,\n assets,\n comments,\n key,\n label,\n questionId: item._id,\n score,\n scoreLabel,\n scoreWeight,\n weight,\n }\n })\n\n return groupData\n })\n\n return auditData\n}\n"],"file":"index.js"}