Skip to content

Commit

Permalink
Feat: add LoadingTemplate delayed/failed updates
Browse files Browse the repository at this point in the history
  • Loading branch information
dit7ya committed Mar 14, 2022
1 parent 366e916 commit 4b113a2
Showing 4 changed files with 169 additions and 17 deletions.
55 changes: 55 additions & 0 deletions src/img/naked-mole-without-bg.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
17 changes: 17 additions & 0 deletions src/modules/pages/components/LoadingTemplate/LoadingTemplate.css
Original file line number Diff line number Diff line change
@@ -15,3 +15,20 @@
.loaderContainer {
composes: marginBottomLarge from '~styles/layout.css';
}

.loadingDelayedOrFailed {
margin: 0 auto;
height: 108px;
width: 380px;
font-size: var(--size-medium-l);
}

.loadingDelayedOrFailedDetail {
padding-top: 24px;
font-size: var(--size-normal);
}

.nakedMole {
margin: 0 auto;
padding-bottom: 12px;
}
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
export const main: string;
export const mainContent: string;
export const loaderContainer: string;
export const loadingDelayedOrFailed: string;
export const loadingDelayedOrFailedDetail: string;
export const nakedMole: string;
111 changes: 94 additions & 17 deletions src/modules/pages/components/LoadingTemplate/LoadingTemplate.tsx
Original file line number Diff line number Diff line change
@@ -1,29 +1,106 @@
import React, { ReactNode } from 'react';
import { MessageDescriptor } from 'react-intl';
import React, { ReactNode, useEffect, useState } from 'react';
import { MessageDescriptor, defineMessages, useIntl } from 'react-intl';

import { SpinnerLoader } from '~core/Preloaders';

import NakedMole from '../../../../img/naked-mole-without-bg.svg';
import styles from './LoadingTemplate.css';

interface Props {
children?: ReactNode;
loadingText?: string | MessageDescriptor;
}

const LoadingTemplate = ({ children, loadingText }: Props) => (
<div className={styles.main}>
<main className={styles.mainContent}>
<div>
<div className={styles.loaderContainer}>
<SpinnerLoader
loadingText={loadingText}
appearance={{ theme: 'primary', size: 'massive' }}
/>
</div>
{children}
</div>
</main>
</div>
);
const MSG = defineMessages({
loadingDelayed: {
id: 'pages.LoadingTemplate.loadingDelayed',
defaultMessage: `As you can see, it's taking a while to connect to the service.`,
},

loadingDelayedDescription: {
id: 'pages.LoadingTemplate.loadingDelayedDescription',
defaultMessage: `Please hold tight while we keep trying. Sorry, we know this is boring.`,
},

loadingFailed: {
id: 'pages.LoadingTemplate.loadingFailed',
defaultMessage: `Oh noes! We tried and tried but
couldn't get any response from the service.`,
},

loadingFailedDescription: {
id: 'pages.LoadingTemplate.loadingFailedDescription',
defaultMessage: `We're probably already trying to fix this, so please try again later.`,
},
});

const delayedLoadingDuration = 15 * 1000; // 15 seconds
const failedLoadingDuration = 30 * 1000; // 30 seconds

const LoadingTemplate = ({ children, loadingText }: Props) => {
type LoadingStateType = 'default' | 'delayed' | 'failed';
const [loadingState, setLoadingState] = useState<LoadingStateType>('default');

useEffect(() => {
const delayTimer = setTimeout(() => {
setLoadingState('delayed');
}, delayedLoadingDuration);
return () => clearTimeout(delayTimer);
}, []);

useEffect(() => {
const failedTimer = setTimeout(() => {
setLoadingState('failed');
}, failedLoadingDuration);
return () => clearTimeout(failedTimer);
}, []);

const { formatMessage } = useIntl();

return (
<div className={styles.main}>
<main className={styles.mainContent}>
{loadingState !== 'failed' && (
<div>
<div className={styles.loaderContainer}>
<SpinnerLoader
loadingText={loadingText}
appearance={{ theme: 'primary', size: 'massive' }}
/>
</div>
{children}
</div>
)}

{loadingState === 'failed' && (
<div className={styles.loaderContainer}>
<div className={styles.nakedMole}>
<NakedMole />
</div>
</div>
)}

{loadingState !== 'default' && (
<div>
<div className={styles.loadingDelayedOrFailed}>
<p>
{loadingState === 'delayed'
? formatMessage(MSG.loadingDelayed)
: formatMessage(MSG.loadingFailed)}
</p>
<div className={styles.loadingDelayedOrFailedDetail}>
<p>
{loadingState === 'delayed'
? formatMessage(MSG.loadingDelayedDescription)
: formatMessage(MSG.loadingFailedDescription)}
</p>
</div>
</div>
</div>
)}
</main>
</div>
);
};

export default LoadingTemplate;

0 comments on commit 4b113a2

Please sign in to comment.