From b603cbed282430e2f9be0c00bd074fe4441301c0 Mon Sep 17 00:00:00 2001 From: Matt Webster Date: Wed, 17 Mar 2021 12:34:32 -0700 Subject: [PATCH 1/5] Add Contentful as headless CMS Fixes #1025 - Implementing useContentful hook - Temp FAQ, Privacy, Blog --- client/Routes.jsx | 6 + client/components/Header.jsx | 16 +- client/components/main/Blog.jsx | 84 ++++++++ client/components/main/Faqs.jsx | 75 +++++++ client/components/main/Privacy.jsx | 57 +++++ client/hooks/useContentful.js | 29 +++ client/package-lock.json | 327 +++++++++++++++++++++++++++++ client/package.json | 1 + 8 files changed, 590 insertions(+), 5 deletions(-) create mode 100644 client/components/main/Blog.jsx create mode 100644 client/components/main/Faqs.jsx create mode 100644 client/components/main/Privacy.jsx create mode 100644 client/hooks/useContentful.js diff --git a/client/Routes.jsx b/client/Routes.jsx index 523aedf5c..f7bed0a92 100644 --- a/client/Routes.jsx +++ b/client/Routes.jsx @@ -2,12 +2,18 @@ import React from 'react'; import { Switch, Route, Redirect } from 'react-router-dom'; import Desktop from '@components/main/Desktop'; import Reports from '@components/main/Reports'; +import Privacy from '@components/main/Privacy'; +import Faqs from '@components/main/Faqs'; +import Blog from '@components/main/Blog'; export default function Routes() { return ( + + + diff --git a/client/components/Header.jsx b/client/components/Header.jsx index 124737b80..30b51daeb 100644 --- a/client/components/Header.jsx +++ b/client/components/Header.jsx @@ -54,6 +54,9 @@ const Header = () => { 311DATA + + + + + + + + - - - + + + ); diff --git a/client/components/main/Blog.jsx b/client/components/main/Blog.jsx new file mode 100644 index 000000000..64cfa9ce6 --- /dev/null +++ b/client/components/main/Blog.jsx @@ -0,0 +1,84 @@ +import React from 'react' +import ReactMarkdown from 'react-markdown' +import useContentful from '../../hooks/useContentful' +import { + makeStyles, + Container, + Box, + Typography, + Grid, + List, + ListItem +} from '@material-ui/core'; + +const query = ` + query { + blogPostCollection(order: publishDate_DESC) { + items { + sys { id } + slug + title + body + publishDate + } + } + } +` + +const useStyles = makeStyles({ + root: { + color: 'black', + backgroundColor: 'white', + padding: '2em', + '& h1': { + fontSize: '2.5em' + }, + '& img': { + maxWidth: '100%', + height: 'auto', + }, + } +}); + +const Blog = () => { + let { data, errors } = useContentful(query) + const classes = useStyles(); + + React.useEffect(() => { + if (errors) + console.log(errors) + }, [errors]) + + return ( + <> + { data && + + + + { data.blogPostCollection.items.map(item => { + return ( + +

{item.title}

+
Posted {new Date(item.publishDate).toLocaleDateString()}
+ {item.body} +
+ ) + })} +
+ + + { data.blogPostCollection.items.map(item => { + return ( + {item.title} + ) + })} + + +
+
+ } + + ) +} + +export default Blog; \ No newline at end of file diff --git a/client/components/main/Faqs.jsx b/client/components/main/Faqs.jsx new file mode 100644 index 000000000..6ed5a438a --- /dev/null +++ b/client/components/main/Faqs.jsx @@ -0,0 +1,75 @@ +import React from 'react' +import ReactMarkdown from 'react-markdown' +import useContentful from '../../hooks/useContentful' +import { + makeStyles, + Container, + Box, + Typography, + List, + ListItem +} from '@material-ui/core'; + +const query = ` + query { + faqCollection(order: priority_ASC) { + items { + sys { id } + question + answer + } + } + } +` + +const useStyles = makeStyles({ + root: { + color: 'black', + backgroundColor: 'white', + padding: '2em', + '& h1': { + fontSize: '2.5em' + }, + '& img': { + maxWidth: '100%', + height: 'auto', + }, + } +}); + +const Faqs = () => { + let { data, errors } = useContentful(query) + const classes = useStyles(); + + React.useEffect(() => { + if (errors) + console.log(errors) + }, [errors]) + + return ( + <> + { data && + +

Frequently Asked Questions

+ + { data.faqCollection.items.map(item => { + return ( + {item.question} + ) + })} + + { data.faqCollection.items.map(item => { + return ( + +

{item.question}

+ {item.answer} +
+ ) + })} +
+ } + + ) +} + +export default Faqs; \ No newline at end of file diff --git a/client/components/main/Privacy.jsx b/client/components/main/Privacy.jsx new file mode 100644 index 000000000..0f176b410 --- /dev/null +++ b/client/components/main/Privacy.jsx @@ -0,0 +1,57 @@ +import React from 'react' +import ReactMarkdown from 'react-markdown' +import useContentful from '../../hooks/useContentful' +import { + makeStyles, + Container, + Typography +} from '@material-ui/core'; + +const query = ` + query { + simplePageCollection(where: {slug: "privacy"}) { + items { + title + body + } + } + } +` + +const useStyles = makeStyles({ + root: { + color: 'black', + backgroundColor: 'white', + padding: '2em', + '& h1': { + fontSize: '2.5em' + }, + '& img': { + maxWidth: '100%', + height: 'auto', + }, + } +}); + +const Privacy = () => { + let { data, errors } = useContentful(query) + const classes = useStyles(); + + React.useEffect(() => { + if (errors) + console.log(errors) + }, [errors]) + + return ( + <> + { data && + +

{data.simplePageCollection.items[0].title}

+ {data.simplePageCollection.items[0].body} +
+ } + + ) +} + +export default Privacy; \ No newline at end of file diff --git a/client/hooks/useContentful.js b/client/hooks/useContentful.js new file mode 100644 index 000000000..db284b1df --- /dev/null +++ b/client/hooks/useContentful.js @@ -0,0 +1,29 @@ +import React from 'react' + +const url = `https://graphql.contentful.com/content/v1/spaces/${process.env.CONTENTFUL_SPACE}` + +const useContentful = (query) => { + let [data, setData] = React.useState(null) + let [errors, setErrors] = React.useState(null) + + React.useEffect(() => { + fetch(url, { + method: "POST", + headers: { + "Content-Type": "application/json", + Authorization: `Bearer ${process.env.CONTENTFUL_TOKEN}` + }, + body: JSON.stringify({ query }) + }) + .then((response) => response.json()) + .then(({data, errors}) => { + if (errors) setErrors(errors) + if (data) setData(data) + }) + .catch((error) => setErrors([error])) + }, [query]); + + return { data, errors }; +} + +export default useContentful; \ No newline at end of file diff --git a/client/package-lock.json b/client/package-lock.json index 2762a3f1d..51ad9604c 100644 --- a/client/package-lock.json +++ b/client/package-lock.json @@ -3392,6 +3392,14 @@ "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", "dev": true }, + "@types/mdast": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@types/mdast/-/mdast-3.0.3.tgz", + "integrity": "sha512-SXPBMnFVQg1s00dlMCc/jCdvPqdE4mXaMMCeRlxLDmTAEoegHT53xKtkDnzDTOcmMHUfcjyf36/YYZ6SxRdnsw==", + "requires": { + "@types/unist": "*" + } + }, "@types/minimatch": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", @@ -3460,6 +3468,11 @@ "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-1.0.1.tgz", "integrity": "sha512-l42BggppR6zLmpfU6fq9HEa2oGPEI8yrSPL3GITjfRInppYFahObbIQOQK3UGxEnyQpltZLaPe75046NOZQikw==" }, + "@types/unist": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@types/unist/-/unist-2.0.3.tgz", + "integrity": "sha512-FvUupuM3rlRsRtCN+fDudtmytGO6iHJuuRKS1Ss0pG5z8oX0diNEw94UEL7hgDbpN94rgaK5R7sWm6RrSkZuAQ==" + }, "@types/yargs": { "version": "13.0.10", "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-13.0.10.tgz", @@ -4443,6 +4456,11 @@ } } }, + "bail": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/bail/-/bail-1.0.5.tgz", + "integrity": "sha512-xFbRxM1tahm08yHBP16MMjVUAvDaBMD38zsM9EMAUN61omwLmKlOpB/Zku5QkjZ8TZ4vn53pj+t518cH0S03RQ==" + }, "balanced-match": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", @@ -5058,6 +5076,21 @@ "supports-color": "^5.3.0" } }, + "character-entities": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/character-entities/-/character-entities-1.2.4.tgz", + "integrity": "sha512-iBMyeEHxfVnIakwOuDXpVkc54HijNgCyQB2w0VfGQThle6NXn50zU6V/u+LDhxHcDUPojn6Kpga3PTAD8W1bQw==" + }, + "character-entities-legacy": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/character-entities-legacy/-/character-entities-legacy-1.1.4.tgz", + "integrity": "sha512-3Xnr+7ZFS1uxeiUDvV02wQ+QDbc55o97tIV5zHScSPJpcLm/r0DFPcoY3tYRp+VZukxuMeKgXYmsXQHO05zQeA==" + }, + "character-reference-invalid": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/character-reference-invalid/-/character-reference-invalid-1.1.4.tgz", + "integrity": "sha512-mKKUkUbhPpQlCOfIuZkvSEgktjPFIsZKRRbC6KWVEMvlzblj3i3asQv5ODsrwt0N3pHAEvjP8KTQPHkp0+6jOg==" + }, "chardet": { "version": "0.7.0", "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", @@ -8764,6 +8797,88 @@ } } }, + "html-to-react": { + "version": "1.4.5", + "resolved": "https://registry.npmjs.org/html-to-react/-/html-to-react-1.4.5.tgz", + "integrity": "sha512-KONZUDFPg5OodWaQu2ymfkDmU0JA7zB1iPfvyHehTmMUZnk0DS7/TyCMTzsLH6b4BvxX15g88qZCXFhJWktsmA==", + "requires": { + "domhandler": "^3.3.0", + "htmlparser2": "^5.0", + "lodash.camelcase": "^4.3.0", + "ramda": "^0.27.1" + }, + "dependencies": { + "dom-serializer": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.2.0.tgz", + "integrity": "sha512-n6kZFH/KlCrqs/1GHMOd5i2fd/beQHuehKdWvNNffbGHTr/almdhuVvTVFb3V7fglz+nC50fFusu3lY33h12pA==", + "requires": { + "domelementtype": "^2.0.1", + "domhandler": "^4.0.0", + "entities": "^2.0.0" + }, + "dependencies": { + "domhandler": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.0.0.tgz", + "integrity": "sha512-KPTbnGQ1JeEMQyO1iYXoagsI6so/C96HZiFyByU3T6iAzpXn8EGEvct6unm1ZGoed8ByO2oirxgwxBmqKF9haA==", + "requires": { + "domelementtype": "^2.1.0" + } + } + } + }, + "domelementtype": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.1.0.tgz", + "integrity": "sha512-LsTgx/L5VpD+Q8lmsXSHW2WpA+eBlZ9HPf3erD1IoPF00/3JKHZ3BknUVA2QGDNu69ZNmyFmCWBSO45XjYKC5w==" + }, + "domhandler": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-3.3.0.tgz", + "integrity": "sha512-J1C5rIANUbuYK+FuFL98650rihynUOEzRLxW+90bKZRWB6A1X1Tf82GxR1qAWLyfNPRvjqfip3Q5tdYlmAa9lA==", + "requires": { + "domelementtype": "^2.0.1" + } + }, + "domutils": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.5.0.tgz", + "integrity": "sha512-Ho16rzNMOFk2fPwChGh3D2D9OEHAfG19HgmRR2l+WLSsIstNsAYBzePH412bL0y5T44ejABIVfTHQ8nqi/tBCg==", + "requires": { + "dom-serializer": "^1.0.1", + "domelementtype": "^2.0.1", + "domhandler": "^4.0.0" + }, + "dependencies": { + "domhandler": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.0.0.tgz", + "integrity": "sha512-KPTbnGQ1JeEMQyO1iYXoagsI6so/C96HZiFyByU3T6iAzpXn8EGEvct6unm1ZGoed8ByO2oirxgwxBmqKF9haA==", + "requires": { + "domelementtype": "^2.1.0" + } + } + } + }, + "htmlparser2": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-5.0.1.tgz", + "integrity": "sha512-vKZZra6CSe9qsJzh0BjBGXo8dvzNsq/oGvsjfRdOrrryfeD9UOBEEQdeoqCRmKZchF5h2zOBMQ6YuQ0uRUmdbQ==", + "requires": { + "domelementtype": "^2.0.1", + "domhandler": "^3.3.0", + "domutils": "^2.4.2", + "entities": "^2.0.0" + } + }, + "ramda": { + "version": "0.27.1", + "resolved": "https://registry.npmjs.org/ramda/-/ramda-0.27.1.tgz", + "integrity": "sha512-PgIdVpn5y5Yns8vqb8FzBUEYn98V3xcPgawAkkgj0YJ0qDsnHCiNmZYfOGMgOvoB0eWFLpYbhxUR3mxfDIMvpw==" + } + } + }, "html-webpack-plugin": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-3.2.0.tgz", @@ -9344,6 +9459,20 @@ } } }, + "is-alphabetical": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-alphabetical/-/is-alphabetical-1.0.4.tgz", + "integrity": "sha512-DwzsA04LQ10FHTZuL0/grVDk4rFoVH1pjAToYwBrHSxcrBIGQuXrQMtD5U1b0U2XVgKZCTLLP8u2Qxqhy3l2Vg==" + }, + "is-alphanumerical": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-alphanumerical/-/is-alphanumerical-1.0.4.tgz", + "integrity": "sha512-UzoZUr+XfVz3t3v4KyGEniVL9BDRoQtY7tOyrRybkVNjDFWyo1yhXNGrrBTQxp3ib9BLAWs7k2YKBQsFRkZG9A==", + "requires": { + "is-alphabetical": "^1.0.0", + "is-decimal": "^1.0.0" + } + }, "is-arguments": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.0.4.tgz", @@ -9426,6 +9555,11 @@ "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==" }, + "is-decimal": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-decimal/-/is-decimal-1.0.4.tgz", + "integrity": "sha512-RGdriMmQQvZ2aqaQq3awNA6dCGtKpiDFcOzrTWrDAT2MiWrKQVPmxLGHl7Y2nNu6led0kEyoX0enY0qXYsv9zw==" + }, "is-descriptor": { "version": "0.1.6", "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", @@ -9479,6 +9613,11 @@ "is-extglob": "^2.1.1" } }, + "is-hexadecimal": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-hexadecimal/-/is-hexadecimal-1.0.4.tgz", + "integrity": "sha512-gyPJuv83bHMpocVYoqof5VDiZveEoGoFL8m3BXNb2VW8Xs+rz9kqO8LOQ5DH6EsuvilT1ApazU0pyl+ytbPtlw==" + }, "is-in-browser": { "version": "1.1.3", "resolved": "https://registry.npmjs.org/is-in-browser/-/is-in-browser-1.1.3.tgz", @@ -10532,6 +10671,11 @@ "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz", "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA==" }, + "lodash.camelcase": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", + "integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=" + }, "lodash.clonedeep": { "version": "4.5.0", "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", @@ -10704,6 +10848,31 @@ "safe-buffer": "^5.1.2" } }, + "mdast-add-list-metadata": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mdast-add-list-metadata/-/mdast-add-list-metadata-1.0.1.tgz", + "integrity": "sha512-fB/VP4MJ0LaRsog7hGPxgOrSL3gE/2uEdZyDuSEnKCv/8IkYHiDkIQSbChiJoHyxZZXZ9bzckyRk+vNxFzh8rA==", + "requires": { + "unist-util-visit-parents": "1.1.2" + } + }, + "mdast-util-from-markdown": { + "version": "0.8.5", + "resolved": "https://registry.npmjs.org/mdast-util-from-markdown/-/mdast-util-from-markdown-0.8.5.tgz", + "integrity": "sha512-2hkTXtYYnr+NubD/g6KGBS/0mFmBcifAsI0yIWRiRo0PjVs6SSOSOdtzbp6kSGnShDN6G5aWZpKQ2lWRy27mWQ==", + "requires": { + "@types/mdast": "^3.0.0", + "mdast-util-to-string": "^2.0.0", + "micromark": "~2.11.0", + "parse-entities": "^2.0.0", + "unist-util-stringify-position": "^2.0.0" + } + }, + "mdast-util-to-string": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-string/-/mdast-util-to-string-2.0.0.tgz", + "integrity": "sha512-AW4DRS3QbBayY/jJmD8437V1Gombjf8RSOUCMFBuo5iHi58AGEgVCKQ+ezHkZZDpAQS75hcBMpLqjpJTjtUL7w==" + }, "mdn-data": { "version": "2.0.4", "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.4.tgz", @@ -10852,6 +11021,30 @@ "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", "dev": true }, + "micromark": { + "version": "2.11.4", + "resolved": "https://registry.npmjs.org/micromark/-/micromark-2.11.4.tgz", + "integrity": "sha512-+WoovN/ppKolQOFIAajxi7Lu9kInbPxFuTBVEavFcL8eAfVstoc5MocPmqBeAdBOJV00uaVjegzH4+MA0DN/uA==", + "requires": { + "debug": "^4.0.0", + "parse-entities": "^2.0.0" + }, + "dependencies": { + "debug": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", + "requires": { + "ms": "2.1.2" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" + } + } + }, "micromatch": { "version": "3.1.10", "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", @@ -11888,6 +12081,19 @@ "safe-buffer": "^5.1.1" } }, + "parse-entities": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/parse-entities/-/parse-entities-2.0.0.tgz", + "integrity": "sha512-kkywGpCcRYhqQIchaWqZ875wzpS/bMKhz5HnN3p7wveJTkTtyAB/AlnS0f8DFSqYW1T82t6yEAkEcB+A1I3MbQ==", + "requires": { + "character-entities": "^1.0.0", + "character-entities-legacy": "^1.0.0", + "character-reference-invalid": "^1.0.0", + "is-alphanumerical": "^1.0.0", + "is-decimal": "^1.0.0", + "is-hexadecimal": "^1.0.0" + } + }, "parse-json": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", @@ -12555,6 +12761,23 @@ "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==" }, + "react-markdown": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/react-markdown/-/react-markdown-5.0.3.tgz", + "integrity": "sha512-jDWOc1AvWn0WahpjW6NK64mtx6cwjM4iSsLHJPNBqoAgGOVoIdJMqaKX4++plhOtdd4JksdqzlDibgPx6B/M2w==", + "requires": { + "@types/mdast": "^3.0.3", + "@types/unist": "^2.0.3", + "html-to-react": "^1.3.4", + "mdast-add-list-metadata": "1.0.1", + "prop-types": "^15.7.2", + "react-is": "^16.8.6", + "remark-parse": "^9.0.0", + "unified": "^9.0.0", + "unist-util-visit": "^2.0.0", + "xtend": "^4.0.1" + } + }, "react-motion": { "version": "0.5.2", "resolved": "https://registry.npmjs.org/react-motion/-/react-motion-0.5.2.tgz", @@ -12936,6 +13159,14 @@ "resolved": "https://registry.npmjs.org/relateurl/-/relateurl-0.2.7.tgz", "integrity": "sha1-VNvzd+UUQKypCkzSdGANP/LYiKk=" }, + "remark-parse": { + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/remark-parse/-/remark-parse-9.0.0.tgz", + "integrity": "sha512-geKatMwSzEXKHuzBNU1z676sGcDcFoChMK38TgdHJNAYfFtsfHDQG7MoJAjs6sgYMqyLduCYWDIWZIxiPeafEw==", + "requires": { + "mdast-util-from-markdown": "^0.8.0" + } + }, "remove-trailing-separator": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", @@ -14812,6 +15043,11 @@ "integrity": "sha1-WIeWa7WCpFA6QetST301ARgVphM=", "dev": true }, + "trough": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/trough/-/trough-1.0.5.tgz", + "integrity": "sha512-rvuRbTarPXmMb79SmzEp8aqXNKcK+y0XaB298IXueQ8I2PsrATcPBCSPyK/dDNa2iWOhKlfNnOjdAOTBU/nkFA==" + }, "true-case-path": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/true-case-path/-/true-case-path-1.0.3.tgz", @@ -14993,6 +15229,31 @@ "tiny-inflate": "^1.0.0" } }, + "unified": { + "version": "9.2.1", + "resolved": "https://registry.npmjs.org/unified/-/unified-9.2.1.tgz", + "integrity": "sha512-juWjuI8Z4xFg8pJbnEZ41b5xjGUWGHqXALmBZ3FC3WX0PIx1CZBIIJ6mXbYMcf6Yw4Fi0rFUTA1cdz/BglbOhA==", + "requires": { + "bail": "^1.0.0", + "extend": "^3.0.0", + "is-buffer": "^2.0.0", + "is-plain-obj": "^2.0.0", + "trough": "^1.0.0", + "vfile": "^4.0.0" + }, + "dependencies": { + "is-buffer": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.5.tgz", + "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==" + }, + "is-plain-obj": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", + "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==" + } + } + }, "union-value": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz", @@ -15028,6 +15289,45 @@ "imurmurhash": "^0.1.4" } }, + "unist-util-is": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/unist-util-is/-/unist-util-is-4.1.0.tgz", + "integrity": "sha512-ZOQSsnce92GrxSqlnEEseX0gi7GH9zTJZ0p9dtu87WRb/37mMPO2Ilx1s/t9vBHrFhbgweUwb+t7cIn5dxPhZg==" + }, + "unist-util-stringify-position": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/unist-util-stringify-position/-/unist-util-stringify-position-2.0.3.tgz", + "integrity": "sha512-3faScn5I+hy9VleOq/qNbAd6pAx7iH5jYBMS9I1HgQVijz/4mv5Bvw5iw1sC/90CODiKo81G/ps8AJrISn687g==", + "requires": { + "@types/unist": "^2.0.2" + } + }, + "unist-util-visit": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/unist-util-visit/-/unist-util-visit-2.0.3.tgz", + "integrity": "sha512-iJ4/RczbJMkD0712mGktuGpm/U4By4FfDonL7N/9tATGIF4imikjOuagyMY53tnZq3NP6BcmlrHhEKAfGWjh7Q==", + "requires": { + "@types/unist": "^2.0.0", + "unist-util-is": "^4.0.0", + "unist-util-visit-parents": "^3.0.0" + }, + "dependencies": { + "unist-util-visit-parents": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/unist-util-visit-parents/-/unist-util-visit-parents-3.1.1.tgz", + "integrity": "sha512-1KROIZWo6bcMrZEwiH2UrXDyalAa0uqzWCxCJj6lPOvTve2WkfgCytoDTPaMnodXh1WrXOq0haVYHj99ynJlsg==", + "requires": { + "@types/unist": "^2.0.0", + "unist-util-is": "^4.0.0" + } + } + } + }, + "unist-util-visit-parents": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/unist-util-visit-parents/-/unist-util-visit-parents-1.1.2.tgz", + "integrity": "sha512-yvo+MMLjEwdc3RhhPYSximset7rwjMrdt9E41Smmvg25UQIenzrN83cRnF1JMzoMi9zZOQeYXHSDf7p+IQkW3Q==" + }, "unpipe": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", @@ -15238,6 +15538,33 @@ "extsprintf": "^1.2.0" } }, + "vfile": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/vfile/-/vfile-4.2.1.tgz", + "integrity": "sha512-O6AE4OskCG5S1emQ/4gl8zK586RqA3srz3nfK/Viy0UPToBc5Trp9BVFb1u0CjsKrAWwnpr4ifM/KBXPWwJbCA==", + "requires": { + "@types/unist": "^2.0.0", + "is-buffer": "^2.0.0", + "unist-util-stringify-position": "^2.0.0", + "vfile-message": "^2.0.0" + }, + "dependencies": { + "is-buffer": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.5.tgz", + "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==" + } + } + }, + "vfile-message": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/vfile-message/-/vfile-message-2.0.4.tgz", + "integrity": "sha512-DjssxRGkMvifUOJre00juHoP9DPWuzjxKuMDrhNbk2TdaYYBNMStsNhEOt3idrtI12VQYM/1+iM0KOzXi4pxwQ==", + "requires": { + "@types/unist": "^2.0.0", + "unist-util-stringify-position": "^2.0.0" + } + }, "vm-browserify": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-1.1.2.tgz", diff --git a/client/package.json b/client/package.json index bc2ef2a33..0cedb0a53 100644 --- a/client/package.json +++ b/client/package.json @@ -35,6 +35,7 @@ "react": "^16.8.6", "react-day-picker": "^7.4.8", "react-dom": "^16.8.6", + "react-markdown": "^5.0.3", "react-redux": "^7.1.3", "react-router": "^5.1.2", "react-router-dom": "^5.1.2", From b24099dc9066a555bd26397b0ace66eb67e3bfc4 Mon Sep 17 00:00:00 2001 From: Matt Webster Date: Wed, 17 Mar 2021 12:35:13 -0700 Subject: [PATCH 2/5] linting --- client/components/Header.jsx | 2 +- client/components/main/Blog.jsx | 78 +++++++++++++++--------------- client/components/main/Faqs.jsx | 65 ++++++++++++------------- client/components/main/Privacy.jsx | 45 +++++++++-------- client/hooks/useContentful.js | 32 ++++++------ 5 files changed, 107 insertions(+), 115 deletions(-) diff --git a/client/components/Header.jsx b/client/components/Header.jsx index 30b51daeb..ff1fee324 100644 --- a/client/components/Header.jsx +++ b/client/components/Header.jsx @@ -105,7 +105,7 @@ const Header = () => { - + ); diff --git a/client/components/main/Blog.jsx b/client/components/main/Blog.jsx index 64cfa9ce6..edca66a17 100644 --- a/client/components/main/Blog.jsx +++ b/client/components/main/Blog.jsx @@ -1,15 +1,14 @@ -import React from 'react' -import ReactMarkdown from 'react-markdown' -import useContentful from '../../hooks/useContentful' -import { +import React from 'react'; +import ReactMarkdown from 'react-markdown'; +import { makeStyles, Container, Box, - Typography, Grid, List, - ListItem + ListItem, } from '@material-ui/core'; +import useContentful from '../../hooks/useContentful'; const query = ` query { @@ -23,62 +22,61 @@ const query = ` } } } -` +`; const useStyles = makeStyles({ root: { - color: 'black', - backgroundColor: 'white', + color: 'black', + backgroundColor: 'white', padding: '2em', '& h1': { - fontSize: '2.5em' + fontSize: '2.5em', }, '& img': { maxWidth: '100%', height: 'auto', }, - } + }, }); const Blog = () => { - let { data, errors } = useContentful(query) + const { data, errors } = useContentful(query); const classes = useStyles(); React.useEffect(() => { - if (errors) - console.log(errors) - }, [errors]) + if (errors) console.log(errors); + }, [errors]); return ( <> - { data && - - - - { data.blogPostCollection.items.map(item => { - return ( - + { data + && ( + + + + { data.blogPostCollection.items.map(item => ( +

{item.title}

-
Posted {new Date(item.publishDate).toLocaleDateString()}
+
+ Posted + {new Date(item.publishDate).toLocaleDateString()} +
{item.body}
- ) - })} -
- - - { data.blogPostCollection.items.map(item => { - return ( - {item.title} - ) - })} - + ))} + + + + { data.blogPostCollection.items.map(item => ( + {item.title} + ))} + +
-
-
- } + + )} - ) -} + ); +}; -export default Blog; \ No newline at end of file +export default Blog; diff --git a/client/components/main/Faqs.jsx b/client/components/main/Faqs.jsx index 6ed5a438a..966b34f24 100644 --- a/client/components/main/Faqs.jsx +++ b/client/components/main/Faqs.jsx @@ -1,14 +1,13 @@ -import React from 'react' -import ReactMarkdown from 'react-markdown' -import useContentful from '../../hooks/useContentful' -import { +import React from 'react'; +import ReactMarkdown from 'react-markdown'; +import { makeStyles, Container, Box, - Typography, List, - ListItem + ListItem, } from '@material-ui/core'; +import useContentful from '../../hooks/useContentful'; const query = ` query { @@ -20,56 +19,52 @@ const query = ` } } } -` +`; const useStyles = makeStyles({ root: { - color: 'black', - backgroundColor: 'white', + color: 'black', + backgroundColor: 'white', padding: '2em', '& h1': { - fontSize: '2.5em' + fontSize: '2.5em', }, '& img': { maxWidth: '100%', height: 'auto', }, - } + }, }); const Faqs = () => { - let { data, errors } = useContentful(query) + const { data, errors } = useContentful(query); const classes = useStyles(); React.useEffect(() => { - if (errors) - console.log(errors) - }, [errors]) + if (errors) console.log(errors); + }, [errors]); return ( <> - { data && - -

Frequently Asked Questions

- - { data.faqCollection.items.map(item => { - return ( - {item.question} - ) - })} - - { data.faqCollection.items.map(item => { - return ( - + { data + && ( + +

Frequently Asked Questions

+ + { data.faqCollection.items.map(item => ( + {item.question} + ))} + + { data.faqCollection.items.map(item => ( +

{item.question}

{item.answer}
- ) - })} -
- } + ))} +
+ )} - ) -} + ); +}; -export default Faqs; \ No newline at end of file +export default Faqs; diff --git a/client/components/main/Privacy.jsx b/client/components/main/Privacy.jsx index 0f176b410..e960b0cf2 100644 --- a/client/components/main/Privacy.jsx +++ b/client/components/main/Privacy.jsx @@ -1,11 +1,10 @@ -import React from 'react' -import ReactMarkdown from 'react-markdown' -import useContentful from '../../hooks/useContentful' -import { +import React from 'react'; +import ReactMarkdown from 'react-markdown'; +import { makeStyles, Container, - Typography } from '@material-ui/core'; +import useContentful from '../../hooks/useContentful'; const query = ` query { @@ -16,42 +15,42 @@ const query = ` } } } -` +`; const useStyles = makeStyles({ root: { - color: 'black', - backgroundColor: 'white', + color: 'black', + backgroundColor: 'white', padding: '2em', '& h1': { - fontSize: '2.5em' + fontSize: '2.5em', }, '& img': { maxWidth: '100%', height: 'auto', }, - } + }, }); const Privacy = () => { - let { data, errors } = useContentful(query) + const { data, errors } = useContentful(query); const classes = useStyles(); React.useEffect(() => { - if (errors) - console.log(errors) - }, [errors]) + if (errors) console.log(errors); + }, [errors]); return ( <> - { data && - -

{data.simplePageCollection.items[0].title}

- {data.simplePageCollection.items[0].body} -
- } + { data + && ( + +

{data.simplePageCollection.items[0].title}

+ {data.simplePageCollection.items[0].body} +
+ )} - ) -} + ); +}; -export default Privacy; \ No newline at end of file +export default Privacy; diff --git a/client/hooks/useContentful.js b/client/hooks/useContentful.js index db284b1df..d96f9dc95 100644 --- a/client/hooks/useContentful.js +++ b/client/hooks/useContentful.js @@ -1,29 +1,29 @@ -import React from 'react' +import React from 'react'; -const url = `https://graphql.contentful.com/content/v1/spaces/${process.env.CONTENTFUL_SPACE}` +const url = `https://graphql.contentful.com/content/v1/spaces/${process.env.CONTENTFUL_SPACE}`; -const useContentful = (query) => { - let [data, setData] = React.useState(null) - let [errors, setErrors] = React.useState(null) +const useContentful = query => { + const [data, setData] = React.useState(null); + const [errors, setErrors] = React.useState(null); React.useEffect(() => { fetch(url, { - method: "POST", + method: 'POST', headers: { - "Content-Type": "application/json", - Authorization: `Bearer ${process.env.CONTENTFUL_TOKEN}` + 'Content-Type': 'application/json', + Authorization: `Bearer ${process.env.CONTENTFUL_TOKEN}`, }, - body: JSON.stringify({ query }) + body: JSON.stringify({ query }), }) - .then((response) => response.json()) - .then(({data, errors}) => { - if (errors) setErrors(errors) - if (data) setData(data) + .then(response => response.json()) + .then(({ resData, resErrors }) => { + if (resErrors) setErrors(resErrors); + if (resData) setData(resData); }) - .catch((error) => setErrors([error])) + .catch(error => setErrors([error])); }, [query]); return { data, errors }; -} +}; -export default useContentful; \ No newline at end of file +export default useContentful; From 16542a376da2e07404cabffb5ebcf010fa980caa Mon Sep 17 00:00:00 2001 From: Matt Webster Date: Wed, 17 Mar 2021 16:52:06 -0700 Subject: [PATCH 3/5] Damn linting Fixes #1025 --- client/hooks/useContentful.js | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/client/hooks/useContentful.js b/client/hooks/useContentful.js index d96f9dc95..7b04dacfd 100644 --- a/client/hooks/useContentful.js +++ b/client/hooks/useContentful.js @@ -1,3 +1,4 @@ +/* eslint no-shadow: ["error", { "allow": ["data", "errors"] }] */ import React from 'react'; const url = `https://graphql.contentful.com/content/v1/spaces/${process.env.CONTENTFUL_SPACE}`; @@ -16,9 +17,9 @@ const useContentful = query => { body: JSON.stringify({ query }), }) .then(response => response.json()) - .then(({ resData, resErrors }) => { - if (resErrors) setErrors(resErrors); - if (resData) setData(resData); + .then(({ data, errors }) => { + if (errors) setErrors(errors); + if (data) setData(data); }) .catch(error => setErrors([error])); }, [query]); From 9e171ae12e0585bc2aa8e3fff4639a4108be3dd7 Mon Sep 17 00:00:00 2001 From: Matt Webster Date: Wed, 17 Mar 2021 17:21:26 -0700 Subject: [PATCH 4/5] some more cleanup --- client/components/main/Blog.jsx | 11 ++++++----- client/components/main/Faqs.jsx | 29 +++++++++++++++++------------ client/components/main/Privacy.jsx | 9 +++++++-- 3 files changed, 30 insertions(+), 19 deletions(-) diff --git a/client/components/main/Blog.jsx b/client/components/main/Blog.jsx index edca66a17..49b0958bd 100644 --- a/client/components/main/Blog.jsx +++ b/client/components/main/Blog.jsx @@ -56,11 +56,10 @@ const Blog = () => { { data.blogPostCollection.items.map(item => ( -

{item.title}

-
- Posted +

{item.title}

+

{new Date(item.publishDate).toLocaleDateString()} -

+ {item.body}
))} @@ -68,7 +67,9 @@ const Blog = () => { { data.blogPostCollection.items.map(item => ( - {item.title} + + {item.title} + ))} diff --git a/client/components/main/Faqs.jsx b/client/components/main/Faqs.jsx index 966b34f24..c2f4804ae 100644 --- a/client/components/main/Faqs.jsx +++ b/client/components/main/Faqs.jsx @@ -6,6 +6,7 @@ import { Box, List, ListItem, + Grid, } from '@material-ui/core'; import useContentful from '../../hooks/useContentful'; @@ -49,18 +50,22 @@ const Faqs = () => { { data && ( -

Frequently Asked Questions

- - { data.faqCollection.items.map(item => ( - {item.question} - ))} - - { data.faqCollection.items.map(item => ( - -

{item.question}

- {item.answer} -
- ))} + + +

Frequently Asked Questions

+ + { data.faqCollection.items.map(item => ( + {item.question} + ))} + + { data.faqCollection.items.map(item => ( + +

{item.question}

+ {item.answer} +
+ ))} +
+
)} diff --git a/client/components/main/Privacy.jsx b/client/components/main/Privacy.jsx index e960b0cf2..904d9fc30 100644 --- a/client/components/main/Privacy.jsx +++ b/client/components/main/Privacy.jsx @@ -3,6 +3,7 @@ import ReactMarkdown from 'react-markdown'; import { makeStyles, Container, + Grid, } from '@material-ui/core'; import useContentful from '../../hooks/useContentful'; @@ -45,8 +46,12 @@ const Privacy = () => { { data && ( -

{data.simplePageCollection.items[0].title}

- {data.simplePageCollection.items[0].body} + + +

{data.simplePageCollection.items[0].title}

+ {data.simplePageCollection.items[0].body} +
+
)} From 15af9714529690c03e824381a71e3ea79a9f8e42 Mon Sep 17 00:00:00 2001 From: Matt Webster Date: Thu, 18 Mar 2021 00:34:25 -0700 Subject: [PATCH 5/5] Fixed footer problems --- client/components/Footer.jsx | 2 -- client/components/main/Blog.jsx | 3 +++ client/components/main/Faqs.jsx | 5 ++++- client/components/main/Privacy.jsx | 3 +++ client/components/main/Reports.jsx | 2 +- server/terraform/templates/prefect.json | 1 + 6 files changed, 12 insertions(+), 4 deletions(-) diff --git a/client/components/Footer.jsx b/client/components/Footer.jsx index f8d5594e5..3292ab49c 100644 --- a/client/components/Footer.jsx +++ b/client/components/Footer.jsx @@ -10,8 +10,6 @@ import moment from 'moment'; const useStyles = makeStyles(theme => ({ footer: { - position: 'absolute', - bottom: 0, height: theme.footer.height, width: '100%', backgroundColor: theme.palette.primary.dark, diff --git a/client/components/main/Blog.jsx b/client/components/main/Blog.jsx index 49b0958bd..fcdd32d49 100644 --- a/client/components/main/Blog.jsx +++ b/client/components/main/Blog.jsx @@ -35,6 +35,9 @@ const useStyles = makeStyles({ '& img': { maxWidth: '100%', height: 'auto', + display: 'block', + marginLeft: 'auto', + marginRight: 'auto', }, }, }); diff --git a/client/components/main/Faqs.jsx b/client/components/main/Faqs.jsx index c2f4804ae..1cfc50967 100644 --- a/client/components/main/Faqs.jsx +++ b/client/components/main/Faqs.jsx @@ -33,6 +33,9 @@ const useStyles = makeStyles({ '& img': { maxWidth: '100%', height: 'auto', + display: 'block', + marginLeft: 'auto', + marginRight: 'auto', }, }, }); @@ -59,7 +62,7 @@ const Faqs = () => { ))} { data.faqCollection.items.map(item => ( - +

{item.question}

{item.answer}
diff --git a/client/components/main/Privacy.jsx b/client/components/main/Privacy.jsx index 904d9fc30..7120e85b9 100644 --- a/client/components/main/Privacy.jsx +++ b/client/components/main/Privacy.jsx @@ -29,6 +29,9 @@ const useStyles = makeStyles({ '& img': { maxWidth: '100%', height: 'auto', + display: 'block', + marginLeft: 'auto', + marginRight: 'auto', }, }, }); diff --git a/client/components/main/Reports.jsx b/client/components/main/Reports.jsx index 43f33a1f1..4b4d20ed3 100644 --- a/client/components/main/Reports.jsx +++ b/client/components/main/Reports.jsx @@ -57,7 +57,7 @@ const Reports = () => { src={url + reportPath} frameBorder="0" allowFullScreen - style={{ width: '100%', height: '100%', minHeight: '55em' }} + style={{ width: '100%', height: '100%' }} /> ); diff --git a/server/terraform/templates/prefect.json b/server/terraform/templates/prefect.json index 5398f6653..422672212 100644 --- a/server/terraform/templates/prefect.json +++ b/server/terraform/templates/prefect.json @@ -14,6 +14,7 @@ "secrets": [ { "name": "PREFECT__CONTEXT__SECRETS__DSN", "valueFrom": "/${stage}/${region}/DB_DSN" }, { "name": "PREFECT__CONTEXT__SECRETS__SLACK_HOOK", "valueFrom": "/${stage}/${region}/SLACK_HOOK" }, + { "name": "PREFECT__REPORT_SERVER_URL", "valueFrom": "/${stage}/${region}/REPORT_SERVER_URL" }, { "name": "PREFECT__API_URL", "valueFrom": "/${stage}/${region}/API_URL" }, { "name": "PREFECT__STAGE", "valueFrom": "/${stage}/${region}/STAGE" } ],