70 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import React, { useState } from 'react';
 | |
| import Modal from '@/components/elements/Modal';
 | |
| import deleteSchedule from '@/api/server/schedules/deleteSchedule';
 | |
| import { ServerContext } from '@/state/server';
 | |
| import { Actions, useStoreActions } from 'easy-peasy';
 | |
| import { ApplicationStore } from '@/state';
 | |
| import { httpErrorToHuman } from '@/api/http';
 | |
| 
 | |
| interface Props {
 | |
|     scheduleId: number;
 | |
|     onDeleted: () => void;
 | |
| }
 | |
| 
 | |
| export default ({ scheduleId, onDeleted }: Props) => {
 | |
|     const [ visible, setVisible ] = useState(false);
 | |
|     const [ isLoading, setIsLoading ] = useState(false);
 | |
|     const uuid = ServerContext.useStoreState(state => state.server.data!.uuid);
 | |
|     const { addError, clearFlashes } = useStoreActions((actions: Actions<ApplicationStore>) => actions.flashes);
 | |
| 
 | |
|     const onDelete = () => {
 | |
|         setIsLoading(true);
 | |
|         clearFlashes('schedules');
 | |
|         deleteSchedule(uuid, scheduleId)
 | |
|             .then(() => {
 | |
|                 setIsLoading(false);
 | |
|                 onDeleted();
 | |
|             })
 | |
|             .catch(error => {
 | |
|                 console.error(error);
 | |
| 
 | |
|                 addError({ key: 'schedules', message: httpErrorToHuman(error) });
 | |
|                 setIsLoading(false);
 | |
|                 setVisible(false);
 | |
|             });
 | |
|     };
 | |
| 
 | |
|     return (
 | |
|         <>
 | |
|             <Modal
 | |
|                 visible={visible}
 | |
|                 onDismissed={() => setVisible(false)}
 | |
|                 showSpinnerOverlay={isLoading}
 | |
|             >
 | |
|                 <h3 className={'mb-6'}>Delete schedule</h3>
 | |
|                 <p className={'text-sm'}>
 | |
|                     Are you sure you want to delete this schedule? All tasks will be removed and any running processes
 | |
|                     will be terminated.
 | |
|                 </p>
 | |
|                 <div className={'mt-6 flex justify-end'}>
 | |
|                     <button
 | |
|                         className={'btn btn-secondary btn-sm mr-4'}
 | |
|                         onClick={() => setVisible(false)}
 | |
|                     >
 | |
|                         Cancel
 | |
|                     </button>
 | |
|                     <button
 | |
|                         className={'btn btn-red btn-sm'}
 | |
|                         onClick={() => onDelete()}
 | |
|                     >
 | |
|                         Yes, delete schedule
 | |
|                     </button>
 | |
|                 </div>
 | |
|             </Modal>
 | |
|             <button className={'btn btn-red btn-secondary btn-sm mr-4'} onClick={() => setVisible(true)}>
 | |
|                 Delete
 | |
|             </button>
 | |
|         </>
 | |
|     );
 | |
| };
 | 
