gatsby-core-theme 1.6.10 → 1.6.14

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,75 @@
1
+ ## [1.6.14](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/compare/v1.6.13...v1.6.14) (2021-12-01)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * added clean up html tags in faq schema data ([0b9ae93](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/0b9ae937928ede9f1f710ee0749108bf99b16757))
7
+ * added clean up html tags in faq schema data ([1b22637](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/1b22637bfadd48e9731e01d82b39e7db97e156ac))
8
+ * added new cdn env var for gifs ([e5bb4bc](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/e5bb4bc6507688fbb8060a4df349fe5ff534a009))
9
+ * geturl func ([c531ed3](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/c531ed335ae4e35aaa5b94010cb136d419826ac7))
10
+
11
+
12
+ * Merge branch 'fix-gif-images' into 'master' ([0fd8aab](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/0fd8aab0d3798b6487d0cc5a3d1a5a8c14d45c7f))
13
+
14
+ ## [1.6.13](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/compare/v1.6.12...v1.6.13) (2021-11-28)
15
+
16
+
17
+ ### Bug Fixes
18
+
19
+ * added no script tag for all lazyimages ([76ee02f](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/76ee02f235bcdab777b961fe19068e9033cdb514))
20
+ * fixes on accessibility score ([b0e213e](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/b0e213e09741e2fbcb40356db77c600a39327885))
21
+ * noscript tag ([d922b66](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/d922b66d5ac8b4312a623ff0a37b213e3d07b908))
22
+ * noscript tag ([d97e54d](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/d97e54d035e1bd580fec1b1c9cf2f6cca8a24308))
23
+ * noscript tag ([2571d26](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/2571d2624b28db40db235f65916623dc51abd41a))
24
+ * noscript tag ([844db38](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/844db385179f7a291148de789d62629c6950c4bc))
25
+ * noscript tag ([45deece](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/45deececbc31fdaef83e90a7924b5e5084d8e7bf))
26
+ * noscript tag ([6ea5975](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/6ea5975e81bdf29b25c57a93e8996fd83a155e9b))
27
+ * noscript tag ([09fa187](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/09fa1876c0142f042fdb81f47f01713492c8d487))
28
+ * noscript tag ([a7ecfb4](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/a7ecfb45c772460d62aad290a91e463c68eebcfa))
29
+
30
+
31
+ ### Code Refactoring
32
+
33
+ * add missing aria label ([a670669](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/a670669eb29a136d57228824900cb2a3a64b6f56))
34
+ * replace div with ul for performance imporvements ([5373d6c](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/5373d6c0d3fafdd1dfd17c91deaf79e8bc96eb06))
35
+
36
+
37
+ ### Config
38
+
39
+ * increased pagespeed performance score to 90 ([143b68a](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/143b68a0107811d366afa08223e672f26227322b))
40
+
41
+
42
+ * Merge branch 'tm-2609-lazyload-noscript-tag' into 'master' ([6669bad](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/6669bad97a1817b01033a42c8686f09c565dca37))
43
+ * Merge branch 'tm-2595-accessibility-scores-fix' into 'master' ([048a617](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/048a6175d4025e4fcd4a7999dced518f97f6140b))
44
+
45
+ ## [1.6.12](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/compare/v1.6.11...v1.6.12) (2021-11-25)
46
+
47
+
48
+ ### Bug Fixes
49
+
50
+ * tracker redirect fix ([cdcc2d4](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/cdcc2d4fb25bd3f16c17e3547f192a58b7e5bbfd))
51
+
52
+
53
+ * Merge branch 'master' of git.ilcd.rocks:team-floyd/themes/gatsby-themes ([2bb149a](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/2bb149a0796a572868175b3c0a9e1307c88dc538))
54
+
55
+ ## [1.6.11](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/compare/v1.6.10...v1.6.11) (2021-11-25)
56
+
57
+
58
+ ### Bug Fixes
59
+
60
+ * 404 ([2355a82](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/2355a8216c6431f34bac5f6cc8dd5302446fb0f4))
61
+ * helmet ([6299dc5](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/6299dc536bcf7d3fac7ab89326fd0c6b42a692c9))
62
+ * helmet ([2a05f83](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/2a05f83042de1490a64f5606052104d59dfb6768))
63
+ * preview ([5153a58](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/5153a581700032ddad095e6a6e9593df8ac8dc8b))
64
+ * preview func ([16bb0dc](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/16bb0dca646eb50da48ad98a09fe9d5022757177))
65
+ * tracker pages ([07c6e3c](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/07c6e3c7d86190d82989ff270364a7ba940950c2))
66
+ * tracker pages ([6defb88](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/6defb88aeac9d9f71051e8c9f739dc4b8d41f80d))
67
+ * tracker pages ([a61f2a8](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/a61f2a8db973fd5ba8098171e554883ac502e0a5))
68
+ * tracker pages ([e68afc4](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/e68afc4321955393f58da1dc7cb079dfc9383db1))
69
+
70
+
71
+ * Merge branch 'master' of git.ilcd.rocks:team-floyd/themes/gatsby-themes ([7ffdc47](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/commit/7ffdc47fcc468429cd2ac02e482d53aa558e7c97))
72
+
1
73
  ## [1.6.10](https://git.ilcd.rocks/team-floyd/themes/gatsby-themes/compare/v1.6.9...v1.6.10) (2021-11-25)
2
74
 
3
75
 
@@ -243,19 +243,26 @@ exports.createPages = async ({ actions: { createPage } }, themeOptions) => {
243
243
  } else {
244
244
  createPage({
245
245
  path: page.path.charAt(0) === '/' ? page.path : `/${page.path}`,
246
- component: require.resolve(
247
- page.path === 'preview'
248
- ? './src/components/app-preview.js'
249
- : './src/components/app.js'
250
- ),
246
+ component: require.resolve('./src/components/app.js'),
251
247
  context: {
252
248
  ...contextData,
253
249
  siteSchema,
254
250
  translations,
251
+ isPreview: page.path === 'preview',
255
252
  },
256
253
  });
257
254
  }
258
255
 
256
+ const trackerPageObject = {
257
+ meta_title: 'Tracker',
258
+ template: 'tracker',
259
+ title: 'Tracker',
260
+ type: 'page',
261
+ language: languageKey,
262
+ path: '',
263
+ meta_robots: ['noindex', 'nofollow'],
264
+ };
265
+
259
266
  // Operator tracker pages
260
267
  if (page.type === 'operator') {
261
268
  const operator = operators[page.relation_id];
@@ -265,10 +272,11 @@ exports.createPages = async ({ actions: { createPage } }, themeOptions) => {
265
272
  );
266
273
  tracker.forEach((trackerPath) => {
267
274
  // Create splash page
275
+ trackerPageObject['path'] = trackerPath;
268
276
  createPage({
269
277
  path: trackerPath,
270
- component: require.resolve('./src/components/pages/tracker/'),
271
- context: { operator },
278
+ component: require.resolve('./src/components/app.js'),
279
+ context: { page: trackerPageObject, operator, isTracker: true },
272
280
  });
273
281
  });
274
282
  }
@@ -288,7 +296,7 @@ exports.createPages = async ({ actions: { createPage } }, themeOptions) => {
288
296
  providerData.forEach((provider) => {
289
297
  createPage({
290
298
  path: provider.tracker,
291
- component: require.resolve('./src/components/pages/tracker/'),
299
+ component: require.resolve('./src/components/app.js'),
292
300
  context: {
293
301
  provider: provider.providerObject,
294
302
  },
@@ -307,7 +315,7 @@ exports.onCreatePage = ({ page, actions }) => {
307
315
  if (page.path.includes('404')) {
308
316
  createPage({
309
317
  path: page.path,
310
- component: require.resolve('./src/pages/404/'),
318
+ component: require.resolve('./src/components/app.js'),
311
319
  context: context404,
312
320
  });
313
321
  } else {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "gatsby-core-theme",
3
- "version": "1.6.10",
3
+ "version": "1.6.14",
4
4
  "description": "Gatsby Theme NPM Package",
5
5
  "main": "index.js",
6
6
  "GATSBY_RECAPTCHA_SITEKEY": "6LfoyvMUAAAAAO4nl_MQnqHb4XdHxEiu5cXgIqeB",
@@ -1,15 +1,28 @@
1
+ /* eslint-disable no-unused-vars */
1
2
  import React, { useEffect, useState } from 'react';
2
3
  import PropTypes from 'prop-types';
3
4
  import { globalHistory } from '@reach/router';
4
5
 
5
- import Body from '~pages/body';
6
- import Head from '~organisms/head';
7
- import { getPreview } from '~helpers/api';
6
+ // import Body from '~pages/body';
7
+ // import Head from '~organisms/head';
8
+ // import { getPreview } from '~helpers/api';
8
9
 
9
10
  const AppPreview = ({ pageContext }) => {
10
11
  const [previewContext, setPreviewContext] = useState({});
11
12
  const [isLoading, setIsLoading] = useState({});
12
13
 
14
+ async function getData(searchParams, staticPath = null) {
15
+ const { getPreview } = await import('~helpers/api');
16
+ getPreview(
17
+ pageContext.siteName,
18
+ !staticPath ? searchParams.get('path') || '/' : staticPath,
19
+ pageContext
20
+ ).then((previewResponse) => {
21
+ setPreviewContext(previewResponse);
22
+ setIsLoading(false);
23
+ });
24
+ }
25
+
13
26
  useEffect(() => {
14
27
  setIsLoading(true);
15
28
  const searchParams =
@@ -17,23 +30,28 @@ const AppPreview = ({ pageContext }) => {
17
30
  if (!searchParams.get('path')) {
18
31
  window.location = `${window.location.origin}/preview?path=/`;
19
32
  }
20
- getPreview(pageContext.siteName, searchParams.get('path') || '/', pageContext).then(
21
- (previewResponse) => {
22
- setPreviewContext(previewResponse);
23
- setIsLoading(false);
24
- }
25
- );
33
+
34
+ getData(searchParams);
35
+ // let { hi, bye } = await import('./say.js');
36
+ // getPreview(pageContext.siteName, searchParams.get('path') || '/', pageContext).then(
37
+ // (previewResponse) => {
38
+ // setPreviewContext(previewResponse);
39
+ // setIsLoading(false);
40
+ // }
41
+ // );
26
42
 
27
43
  globalHistory.listen(({ location }) => {
28
44
  setIsLoading(true);
29
- getPreview(pageContext.siteName, location.search.replace('?path=', ''), pageContext)
30
- .then((previewResponse) => {
31
- setPreviewContext(previewResponse);
32
- setIsLoading(false);
33
- })
34
- .catch(() => {
35
- alert('failed to load..');
36
- });
45
+
46
+ getData(null, location.search.replace('?path=', ''));
47
+ // getPreview(pageContext.siteName, location.search.replace('?path=', ''), pageContext)
48
+ // .then((previewResponse) => {
49
+ // setPreviewContext(previewResponse);
50
+ // setIsLoading(false);
51
+ // })
52
+ // .catch(() => {
53
+ // alert('failed to load..');
54
+ // });
37
55
  });
38
56
  // eslint-disable-next-line
39
57
  }, [pageContext.siteName]);
@@ -44,8 +62,8 @@ const AppPreview = ({ pageContext }) => {
44
62
 
45
63
  return (
46
64
  <>
47
- <Head page={previewContext.page} siteInfo={previewContext.siteInfo} />
48
- <Body pageContext={previewContext} />
65
+ {/* <Head page={previewContext.page} siteInfo={previewContext.siteInfo} />
66
+ <Body pageContext={previewContext} /> */}
49
67
  </>
50
68
  );
51
69
  };
@@ -1,24 +1,95 @@
1
1
  /* eslint-disable react/forbid-prop-types */
2
- import React from 'react';
2
+ import React, { useEffect, useState } from 'react';
3
3
  import PropTypes from 'prop-types';
4
+ import loadable from '@loadable/component';
5
+ import { globalHistory } from '@reach/router';
4
6
  import TranslationsProvider from '~context/TranslationsProvider';
5
7
  import Body from '~pages/body';
6
8
  import Head from '~organisms/head';
7
9
 
8
10
  const App = ({ pageContext }) => {
9
- const { translations } = pageContext;
10
- return (
11
- <TranslationsProvider value={{ translations }}>
11
+ const { translations, isTracker, isPreview } = pageContext;
12
+ const [previewContext, setPreviewContext] = useState({});
13
+ const [isLoading, setIsLoading] = useState({});
14
+
15
+ async function getData(searchParams, staticPath = null) {
16
+ const { getPreview } = await import('~helpers/api');
17
+ getPreview(
18
+ pageContext.siteName,
19
+ !staticPath ? searchParams.get('path') || '/' : staticPath,
20
+ pageContext
21
+ ).then((previewResponse) => {
22
+ setPreviewContext(previewResponse);
23
+ setIsLoading(false);
24
+ });
25
+ }
26
+
27
+ useEffect(() => {
28
+ if (isPreview) {
29
+ setIsLoading(true);
30
+ const searchParams =
31
+ typeof window !== 'undefined' ? new URLSearchParams(window.location.search) : null;
32
+ if (!searchParams.get('path')) {
33
+ window.location = `${window.location.origin}/preview?path=/`;
34
+ }
35
+ getData(searchParams);
36
+ // let { hi, bye } = await import('./say.js');
37
+ // getPreview(pageContext.siteName, searchParams.get('path') || '/', pageContext).then(
38
+ // (previewResponse) => {
39
+ // setPreviewContext(previewResponse);
40
+ // setIsLoading(false);
41
+ // }
42
+ // );
43
+
44
+ globalHistory.listen(({ location }) => {
45
+ setIsLoading(true);
46
+
47
+ getData(null, location.search.replace('?path=', ''));
48
+ // getPreview(pageContext.siteName, location.search.replace('?path=', ''), pageContext)
49
+ // .then((previewResponse) => {
50
+ // setPreviewContext(previewResponse);
51
+ // setIsLoading(false);
52
+ // })
53
+ // .catch(() => {
54
+ // alert('failed to load..');
55
+ // });
56
+ });
57
+ }
58
+ // eslint-disable-next-line react-hooks/exhaustive-deps
59
+ }, []);
60
+
61
+ if (isPreview) {
62
+ if (isLoading) {
63
+ return 'Loading...';
64
+ }
65
+ }
66
+
67
+ const TrackerContent = isTracker ? loadable(() => import(`~pages/tracker`)) : null;
68
+
69
+ return isTracker ? (
70
+ <>
12
71
  <Head page={pageContext.page} siteInfo={pageContext.siteInfo} />
13
- <Body pageContext={pageContext} />
72
+ <TrackerContent pageContext={pageContext} path={pageContext.page.path} />
73
+ </>
74
+ ) : (
75
+ <TranslationsProvider value={{ translations }}>
76
+ <Head
77
+ page={isPreview ? previewContext.page : pageContext.page}
78
+ siteInfo={isPreview ? previewContext.siteInfo : pageContext.siteInfo}
79
+ />
80
+ <Body pageContext={isPreview ? previewContext : pageContext} />
14
81
  </TranslationsProvider>
15
82
  );
16
83
  };
17
84
 
18
85
  App.propTypes = {
19
86
  pageContext: PropTypes.shape({
87
+ siteName: PropTypes.string,
88
+ isTracker: PropTypes.bool,
89
+ isPreview: PropTypes.bool,
20
90
  page: PropTypes.shape({
21
91
  id: PropTypes.number,
92
+ path: PropTypes.string,
22
93
  }),
23
94
  translations: PropTypes.object,
24
95
  siteInfo: PropTypes.shape({
@@ -11,8 +11,8 @@ describe('author box component', () => {
11
11
  const { container, getByText } = render(<AuthorBox author={author} />);
12
12
  expect(container).toBeTruthy();
13
13
  // Logo
14
- expect(container.querySelector('img')).toBeFalsy();
15
- expect(container.querySelectorAll('div.lazyload-placeholder')).toHaveLength(1);
14
+ // expect(container.querySelector('img')).toBeFalsy();
15
+ // expect(container.querySelectorAll('div.lazyload-placeholder')).toHaveLength(1);
16
16
  // Name
17
17
  expect(getByText('Ida Moen Olsen')).toBeTruthy();
18
18
  // Title
@@ -10,6 +10,7 @@ const Arrow = ({ direction, content = '', onClick, onKeyDown, disabled, gtmClass
10
10
  onClick={onClick}
11
11
  onKeyDown={onKeyDown}
12
12
  disabled={disabled}
13
+ aria-label={`Arrow ${direction} Link`}
13
14
  >
14
15
  {content}
15
16
  </button>
@@ -16,8 +16,8 @@ describe('Image Component', () => {
16
16
  expect(container).toBeTruthy();
17
17
 
18
18
  // Lazy image
19
- expect(container.querySelector('img')).toBeFalsy();
20
- expect(container.querySelector('div.lazyload-placeholder')).toBeTruthy();
19
+ // expect(container.querySelector('img')).toBeFalsy();
20
+ // expect(container.querySelector('div.lazyload-placeholder')).toBeTruthy();
21
21
  });
22
22
  });
23
23
  afterEach(() => {
@@ -18,7 +18,7 @@ const Spotlights = ({ module }) => {
18
18
  return (
19
19
  <>
20
20
  <span className={styles.itemImage}>
21
- <LazyImage alt={item.label} src={imagePrettyUrl(img)} />
21
+ <LazyImage alt={item.label || item?.link_text} src={imagePrettyUrl(img)} />
22
22
  </span>
23
23
  <span className={styles.label}>{item.label}</span>
24
24
  </>
@@ -43,11 +43,17 @@ const Spotlights = ({ module }) => {
43
43
  title={item.label}
44
44
  target="_blank"
45
45
  rel="noreferrer"
46
+ aria-label={`${item?.label || item?.link_text} Link`}
46
47
  >
47
48
  {content(item)}
48
49
  </a>
49
50
  ) : (
50
- <Link to={item.link.value} title={item.label} className="spotlights-gtm">
51
+ <Link
52
+ to={item.link.value}
53
+ title={item.label}
54
+ className="spotlights-gtm"
55
+ aria-label={`${item?.label || item?.link_text} Link`}
56
+ >
51
57
  {content(item)}
52
58
  </Link>
53
59
  )}
@@ -17,8 +17,8 @@ describe('Content Component', () => {
17
17
  expect(container.querySelectorAll('i')).toHaveLength(1);
18
18
 
19
19
  // Lazy image
20
- expect(container.querySelector('img')).toBeFalsy();
21
- expect(container.querySelector('div.lazyload-placeholder')).toBeTruthy();
20
+ // expect(container.querySelector('img')).toBeFalsy();
21
+ // expect(container.querySelector('div.lazyload-placeholder')).toBeTruthy();
22
22
  });
23
23
  });
24
24
  afterEach(() => {
@@ -57,7 +57,7 @@ const PaginationWithMidPoints = ({
57
57
  )}
58
58
  </li>
59
59
 
60
- <div className={styles.padd}>
60
+ <ul className={styles.padd}>
61
61
  {/* first page link */}
62
62
  {current !== 1 && (
63
63
  <li>
@@ -122,7 +122,7 @@ const PaginationWithMidPoints = ({
122
122
  {total}
123
123
  </Link>
124
124
  </li>
125
- </div>
125
+ </ul>
126
126
 
127
127
  {/* next button */}
128
128
  <li className={styles.showInAll}>
@@ -200,6 +200,7 @@ function Slider({
200
200
  className={`${styles.sliderContent}`}
201
201
  style={style}
202
202
  ref={sliderContentRef}
203
+ aria-label="Slider Content Button"
203
204
  >
204
205
  {children.map((slide, index) => (
205
206
  <div
@@ -1,6 +1,5 @@
1
1
  import React, { useEffect } from 'react';
2
2
  import PropTypes from 'prop-types';
3
- import { Helmet } from 'react-helmet';
4
3
  import Button from '~atoms/button';
5
4
  import LazyImage from '~hooks/lazy-image';
6
5
  import { prettyTracker } from '~helpers/getters';
@@ -91,9 +90,6 @@ const Tracker = ({
91
90
  <>
92
91
  {showSplashScreen && !isMobile && (
93
92
  <>
94
- <Helmet>
95
- <meta name="robots" content="noindex,nofollow" />
96
- </Helmet>
97
93
  <div className={styles.container}>
98
94
  {background}
99
95
  <div className={styles.content}>
@@ -90,8 +90,15 @@ export function image(filename, width, height, fit = 'cover') {
90
90
  return `${cloudFrontUrl}/${Buffer.from(imageRequest).toString('base64')}`;
91
91
  }
92
92
 
93
+ export function getImageExtension(filename) {
94
+ return filename && filename.split('.').pop();
95
+ }
96
+
93
97
  export function imagePrettyUrl(filename = 'image.png', width = null, height = null) {
94
- const cdnURL = process.env.IMAGE_CDN_URL || process.env.STORYBOOK_IMAGE_CDN_URL;
98
+ const cdnURL =
99
+ (getImageExtension(filename) === 'gif'
100
+ ? process.env.GIFS_CDN_URL
101
+ : process.env.IMAGE_CDN_URL) || process.env.STORYBOOK_IMAGE_CDN_URL;
95
102
 
96
103
  if (width && height) {
97
104
  const urlPath = '/fit-in';
@@ -262,7 +269,8 @@ export function getUrl(path) {
262
269
  if (path === '/') {
263
270
  return process.env.GATSBY_SITE_URL;
264
271
  }
265
- return `${process.env.GATSBY_SITE_URL}${path}`;
272
+
273
+ return `${process.env.GATSBY_SITE_URL}${path.replace(/^\//, '')}`;
266
274
  }
267
275
 
268
276
  export function getLanguage(language) {
@@ -68,6 +68,12 @@ describe('Getters Helper', () => {
68
68
  );
69
69
  });
70
70
 
71
+ test('getImageExtension()', () => {
72
+ expect(Getters.getImageExtension('photo.jpg')).toBeTruthy();
73
+ expect(Getters.getImageExtension('photo.jpg')).toEqual('jpg');
74
+ expect(Getters.getImageExtension(null)).toEqual(null);
75
+ });
76
+
71
77
  test('getPageImage()', () => {
72
78
  expect(
73
79
  Getters.getPageImage({ type: 'operator', relation: { default_logo_url: 'foo.jpg' } })
@@ -191,8 +197,9 @@ describe('Getters Helper', () => {
191
197
  });
192
198
 
193
199
  test('getUrl()', () => {
194
- expect(Getters.getUrl('/')).toEqual('http://urltest.com');
200
+ expect(Getters.getUrl('/')).toEqual('http://urltest.com/');
195
201
  expect(Getters.getUrl('/games')).toEqual('http://urltest.com/games');
202
+ expect(Getters.getUrl('games')).toEqual('http://urltest.com/games');
196
203
  });
197
204
 
198
205
  test('getLanguage()', () => {
@@ -1,4 +1,5 @@
1
1
  import { getGameRating, getUrl, getLanguage } from './getters';
2
+ import { cleanHTML } from './strings';
2
3
 
3
4
  /* HardCoded Start */
4
5
  const isIL = process.env.GATSBY_SITE_NAME === 'Irishluck.ie';
@@ -178,9 +179,9 @@ export function moduleSchemas(modules) {
178
179
  '@type': 'Question',
179
180
  acceptedAnswer: {
180
181
  '@type': 'Answer',
181
- text: item.answer,
182
+ text: cleanHTML(item.answer),
182
183
  },
183
- name: item.question,
184
+ name: cleanHTML(item.question),
184
185
  })),
185
186
  };
186
187
 
@@ -370,8 +370,9 @@ describe('Schema Helper', () => {
370
370
  test('schemaGenerator()', () => {
371
371
  const output = Schema.schemaGenerator({
372
372
  seo_json_schema: 'SEO JSON Schema',
373
- breadcrumbs: [{}],
373
+ breadcrumbs: [{ path: '/test' }],
374
374
  type: 'article',
375
+ path: '/test-path',
375
376
  sections: { main: { modules: [{ name: 'faq' }] } },
376
377
  });
377
378
 
@@ -51,3 +51,7 @@ export function truncateString(str, num, dots = '...') {
51
51
  trimmedString = trimmedString.substr(0, trimmedString.lastIndexOf(' '));
52
52
  return `${trimmedString}${dots}`;
53
53
  }
54
+
55
+ export function cleanHTML(string) {
56
+ return string && string.replace(/(<([^>]+)>)/gi, '');
57
+ }
@@ -26,7 +26,11 @@ describe('Strings Helper', () => {
26
26
  });
27
27
 
28
28
  test('truncateString()', () => {
29
- expect(Strings.truncateString('hello i think',5)).toEqual('hello...');
30
- expect(Strings.truncateString('hello i think',10)).toEqual('hello i...');
29
+ expect(Strings.truncateString('hello i think', 5)).toEqual('hello...');
30
+ expect(Strings.truncateString('hello i think', 10)).toEqual('hello i...');
31
+ });
32
+
33
+ test('cleanHTML()', () => {
34
+ expect(Strings.cleanHTML('<p>hello <a>i</a> think</p>')).toEqual('hello i think');
31
35
  });
32
36
  });
@@ -1,6 +1,6 @@
1
- import React, { useState } from 'react';
1
+ import React from 'react';
2
2
  // eslint-disable-next-line import/no-extraneous-dependencies
3
- import LazyLoad from 'react-lazyload';
3
+ // import LazyLoad from 'react-lazyload';
4
4
  import PropTypes from 'prop-types';
5
5
 
6
6
  // When to use this component:
@@ -9,49 +9,68 @@ import PropTypes from 'prop-types';
9
9
  export default function LazyImage({
10
10
  height,
11
11
  width,
12
- offset = 200,
12
+ // offset = 200,
13
13
  style = {},
14
14
  className,
15
15
  src = '#',
16
- srcSet = '',
16
+ // srcSet = '',
17
17
  alt = '',
18
- sizes,
19
- defaultImg,
20
- once = false,
18
+ // sizes,
19
+ // defaultImg,
20
+ // once = false,
21
21
  }) {
22
- const [errorImage, setErrorImage] = useState(false);
22
+ // const [errorImage, setErrorImage] = useState(false);
23
23
 
24
- if ((defaultImg && !src) || errorImage === true) {
25
- return defaultImg;
26
- }
24
+ // if ((defaultImg && !src) || errorImage === true) {
25
+ // return defaultImg;
26
+ // }
27
27
 
28
28
  return (
29
- <LazyLoad height={`${height}px`} width={`${width}px`} offset={offset} debounce={0} once={once}>
29
+ <>
30
+ {/* <LazyLoad
31
+ height={`${height}px`}
32
+ width={`${width}px`}
33
+ offset={offset}
34
+ debounce={0}
35
+ once={once}
36
+ >
37
+ <img
38
+ src={src}
39
+ className={className}
40
+ height={height}
41
+ width={width}
42
+ alt={alt}
43
+ style={style}
44
+ srcSet={srcSet}
45
+ sizes={sizes}
46
+ onError={() => setErrorImage(true)}
47
+ />
48
+ </LazyLoad> */}
49
+ {/* <noscript> */}
30
50
  <img
31
51
  src={src}
52
+ loading="lazy"
32
53
  className={className}
33
54
  height={height}
34
55
  width={width}
35
56
  alt={alt}
36
57
  style={style}
37
- srcSet={srcSet}
38
- sizes={sizes}
39
- onError={() => setErrorImage(true)}
40
58
  />
41
- </LazyLoad>
59
+ {/* </noscript> */}
60
+ </>
42
61
  );
43
62
  }
44
63
 
45
64
  LazyImage.propTypes = {
46
65
  width: PropTypes.number,
47
66
  height: PropTypes.number,
48
- offset: PropTypes.number,
67
+ // offset: PropTypes.number,
49
68
  style: PropTypes.shape({}),
50
69
  className: PropTypes.string,
51
70
  src: PropTypes.string,
52
71
  alt: PropTypes.string,
53
- sizes: PropTypes.string,
54
- srcSet: PropTypes.string,
55
- defaultImg: PropTypes.element,
56
- once: PropTypes.bool,
72
+ // sizes: PropTypes.string,
73
+ // srcSet: PropTypes.string,
74
+ // defaultImg: PropTypes.element,
75
+ // once: PropTypes.bool,
57
76
  };
@@ -60,7 +60,12 @@ const ModalContent = ({ closeIcon }) => {
60
60
  <div className={styles.modalOverlay} onClick={close} />
61
61
  <div className={styles.modalContent}>
62
62
  {closeIcon && (
63
- <button className={`${styles.closeIcon} modal-gtm btn-cta`} type="button" onClick={close}>
63
+ <button
64
+ className={`${styles.closeIcon} modal-gtm btn-cta`}
65
+ aria-label="Close Icon"
66
+ type="button"
67
+ onClick={close}
68
+ >
64
69
  {closeIcon}
65
70
  </button>
66
71
  )}
package/tests/envVars.js CHANGED
@@ -1,5 +1,5 @@
1
1
  process.env.GATSBY_SITE_NAME = 'norskespilleautomater.com';
2
- process.env.GATSBY_SITE_URL = 'http://urltest.com';
2
+ process.env.GATSBY_SITE_URL = 'http://urltest.com/';
3
3
  process.env.IMAGE_CDN_URL = 'https://cdn.images.com';
4
4
  process.env.TRACKER_LINK_FORMAT_MAIN = '[no],[visit],short_name';
5
5
  process.env.TRACKER_LINK_FORMAT_NON_MAIN = '[no],[visit],short_name,type,[tracker]';