45 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import React from 'react';
 | |
| import { ServerContext } from '@/state/server';
 | |
| import ScreenBlock from '@/components/elements/ScreenBlock';
 | |
| import ServerInstallSvg from '@/assets/images/server_installing.svg';
 | |
| import ServerErrorSvg from '@/assets/images/server_error.svg';
 | |
| import ServerRestoreSvg from '@/assets/images/server_restore.svg';
 | |
| 
 | |
| export default () => {
 | |
|     const status = ServerContext.useStoreState((state) => state.server.data?.status || null);
 | |
|     const isTransferring = ServerContext.useStoreState((state) => state.server.data?.isTransferring || false);
 | |
|     const isNodeUnderMaintenance = ServerContext.useStoreState(
 | |
|         (state) => state.server.data?.isNodeUnderMaintenance || false
 | |
|     );
 | |
| 
 | |
|     return status === 'installing' || status === 'install_failed' || status === 'reinstall_failed' ? (
 | |
|         <ScreenBlock
 | |
|             title={'Running Installer'}
 | |
|             image={ServerInstallSvg}
 | |
|             message={'Your server should be ready soon, please try again in a few minutes.'}
 | |
|         />
 | |
|     ) : status === 'suspended' ? (
 | |
|         <ScreenBlock
 | |
|             title={'Server Suspended'}
 | |
|             image={ServerErrorSvg}
 | |
|             message={'This server is suspended and cannot be accessed.'}
 | |
|         />
 | |
|     ) : isNodeUnderMaintenance ? (
 | |
|         <ScreenBlock
 | |
|             title={'Node under Maintenance'}
 | |
|             image={ServerErrorSvg}
 | |
|             message={'The node of this server is currently under maintenance.'}
 | |
|         />
 | |
|     ) : (
 | |
|         <ScreenBlock
 | |
|             title={isTransferring ? 'Transferring' : 'Restoring from Backup'}
 | |
|             image={ServerRestoreSvg}
 | |
|             message={
 | |
|                 isTransferring
 | |
|                     ? 'Your server is being transferred to a new node, please check back later.'
 | |
|                     : 'Your server is currently being restored from a backup, please check back in a few minutes.'
 | |
|             }
 | |
|         />
 | |
|     );
 | |
| };
 | 
