mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-13 06:34:39 -04:00
35 lines
1.1 KiB
TypeScript
35 lines
1.1 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: 2022 The HedgeDoc developers (see AUTHORS file)
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
import { ShowIf } from '../../common/show-if/show-if'
|
|
import styles from '../application-loader.module.scss'
|
|
import { LoadingAnimation } from './loading-animation'
|
|
import type { ReactElement } from 'react'
|
|
import React from 'react'
|
|
import { Alert } from 'react-bootstrap'
|
|
|
|
export interface LoadingScreenProps {
|
|
errorMessage?: string | ReactElement
|
|
}
|
|
|
|
/**
|
|
* Renders a loading animation.
|
|
*
|
|
* @param failedTaskName Should be set if a task failed to load. The name will be shown on screen.
|
|
*/
|
|
export const LoadingScreen: React.FC<LoadingScreenProps> = ({ errorMessage }) => {
|
|
return (
|
|
<div className={`${styles.loader} ${styles.middle} text-light overflow-hidden`}>
|
|
<div className='mb-3 text-light'>
|
|
<span className={`d-block`}>
|
|
<LoadingAnimation error={!!errorMessage} />
|
|
</span>
|
|
</div>
|
|
<ShowIf condition={!!errorMessage}>
|
|
<Alert variant={'danger'}>{errorMessage}</Alert>
|
|
</ShowIf>
|
|
</div>
|
|
)
|
|
}
|