forked from canada-ca/tracker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDmarcGuidancePage.js
More file actions
103 lines (95 loc) · 2.98 KB
/
DmarcGuidancePage.js
File metadata and controls
103 lines (95 loc) · 2.98 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
import React from 'react'
import { useQuery } from '@apollo/client'
import {
Heading,
Link,
Box,
Stack,
Tab,
TabList,
TabPanel,
TabPanels,
Tabs,
} from '@chakra-ui/react'
import { LinkIcon } from '@chakra-ui/icons'
import { Link as RouteLink, useParams } from 'react-router-dom'
import { Trans } from '@lingui/macro'
import { ErrorBoundary } from 'react-error-boundary'
import { ScanCard } from './ScanCard'
import { ErrorFallbackMessage } from '../components/ErrorFallbackMessage'
import { LoadingMessage } from '../components/LoadingMessage'
import { useDocumentTitle } from '../utilities/useDocumentTitle'
import { GET_GUIDANCE_TAGS_OF_DOMAIN } from '../graphql/queries'
export default function DmarcGuidancePage() {
const { domainSlug } = useParams()
useDocumentTitle(`${domainSlug}`)
const { loading, error, data } = useQuery(GET_GUIDANCE_TAGS_OF_DOMAIN, {
variables: {
domain: domainSlug,
},
onComplete: (stuff) => console.log(`completed! recieved: ${stuff}`),
onError: (e) => console.log(`error! recieved: ${e}`),
})
if (loading)
return (
<LoadingMessage>
<Trans>Guidance Tags</Trans>
</LoadingMessage>
)
if (error) return <ErrorFallbackMessage error={error} />
const domainName = data.findDomainByDomain.domain
const webScan = data.findDomainByDomain.web
const emailScan = data.findDomainByDomain.email
const webStatus = data.findDomainByDomain.status
const dmarcPhase = data.findDomainByDomain.dmarcPhase
return (
<Stack spacing="25px" mb="6" px="4" mx="auto" minW="100%">
<Box d={{ md: 'flex' }}>
<Heading textAlign={{ base: 'center', md: 'left' }}>
{domainName.toUpperCase()}
</Heading>
{data.findDomainByDomain.hasDMARCReport && (
<Link
color="teal.600"
whiteSpace="noWrap"
my="auto"
ml="auto"
to={`/domains/${domainSlug}/dmarc-report/LAST30DAYS/${new Date().getFullYear()}`}
as={RouteLink}
d="block"
textAlign={{ base: 'center', md: 'right' }}
>
<Trans>DMARC Report</Trans>
<LinkIcon ml="4px" aria-hidden="true" />
</Link>
)}
</Box>
<Tabs isFitted>
<TabList mb="4">
<Tab>
<Trans>Web Guidance</Trans>
</Tab>
<Tab>
<Trans>Email Guidance</Trans>
</Tab>
</TabList>
<TabPanels>
<TabPanel>
<ErrorBoundary FallbackComponent={ErrorFallbackMessage}>
<ScanCard scanType="web" scanData={webScan} status={webStatus} />
</ErrorBoundary>
</TabPanel>
<TabPanel>
<ErrorBoundary FallbackComponent={ErrorFallbackMessage}>
<ScanCard
scanType="email"
scanData={emailScan}
status={dmarcPhase}
/>
</ErrorBoundary>
</TabPanel>
</TabPanels>
</Tabs>
</Stack>
)
}