drone/web/src/pages/Home/Home.tsx

64 lines
2.2 KiB
TypeScript

import React from 'react'
import { ButtonVariation, Container, Layout, PageBody, Text } from '@harnessio/uicore'
import { FontVariation } from '@harnessio/design-system'
import { noop } from 'lodash-es'
import { useHistory } from 'react-router-dom'
import { useStrings } from 'framework/strings'
import { LoadingSpinner } from 'components/LoadingSpinner/LoadingSpinner'
import { useAppContext } from 'AppContext'
import { useGetRepositoryMetadata } from 'hooks/useGetRepositoryMetadata'
import { NewSpaceModalButton } from 'components/NewSpaceModalButton/NewSpaceModalButton'
import css from './Home.module.scss'
export default function Home() {
const { getString } = useStrings()
const history = useHistory()
const { routes } = useAppContext()
const { currentUser } = useAppContext()
const { space } = useGetRepositoryMetadata()
const spaces = []
const NewSpaceButton = (
<NewSpaceModalButton
space={space}
modalTitle={getString('createASpace')}
text={getString('newSpace')}
variation={ButtonVariation.PRIMARY}
icon="plus"
width={173}
height={48}
onRefetch={noop}
handleNavigation={spaceName => {
history.push(routes.toCODERepositories({ space: spaceName }))
}}
/>
)
return (
<Container className={css.main}>
<PageBody
error={false}
// retryOnError={voidFn(refetch)}
>
<LoadingSpinner visible={false} />
{spaces.length == 0 ? (
<Container className={css.container} flex={{ justifyContent: 'center', align: 'center-center' }}>
<Layout.Vertical className={css.spaceContainer} spacing="small">
<Text font={{ variation: FontVariation.H2 }}>
{getString('homepage.welcomeText', {
currentUser: currentUser?.display_name
})}
</Text>
<Text font={{ variation: FontVariation.BODY1 }}>{getString('homepage.firstStep')} </Text>
<Container padding={{ top: 'large' }} flex={{ justifyContent: 'center' }}>
{NewSpaceButton}
</Container>
</Layout.Vertical>
</Container>
) : null}
</PageBody>
</Container>
)
}