forked from canada-ca/tracker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathAdminPanel.js
More file actions
62 lines (57 loc) · 1.53 KB
/
AdminPanel.js
File metadata and controls
62 lines (57 loc) · 1.53 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
import React from 'react'
import {
Stack,
Tab,
TabList,
TabPanel,
TabPanels,
Tabs,
} from '@chakra-ui/react'
import { Trans } from '@lingui/macro'
import { string } from 'prop-types'
import { ErrorBoundary } from 'react-error-boundary'
import { AdminDomains } from './AdminDomains'
import { UserList } from './UserList'
import { ErrorFallbackMessage } from '../components/ErrorFallbackMessage'
export function AdminPanel({ orgSlug, permission, orgId }) {
return (
<Stack spacing={10}>
<Tabs isFitted variant="enclosed-colored">
<TabList mb="2">
<Tab borderTopWidth="4px">
<Trans>Domains</Trans>
</Tab>
<Tab borderTopWidth="4px">
<Trans>Users</Trans>
</Tab>
</TabList>
<TabPanels>
<TabPanel>
<ErrorBoundary FallbackComponent={ErrorFallbackMessage}>
<AdminDomains
orgSlug={orgSlug}
domainsPerPage={10}
orgId={orgId}
/>
</ErrorBoundary>
</TabPanel>
<TabPanel>
<ErrorBoundary FallbackComponent={ErrorFallbackMessage}>
<UserList
permission={permission}
orgSlug={orgSlug}
usersPerPage={10}
orgId={orgId}
/>
</ErrorBoundary>
</TabPanel>
</TabPanels>
</Tabs>
</Stack>
)
}
AdminPanel.propTypes = {
orgSlug: string.isRequired,
permission: string.isRequired,
orgId: string,
}