client/src/Components/Modals/UnsavedForceModal.tsx
import React from 'react'
import uniqid from 'uniqid'
import ModalWrapper from './ModalWrapper'
import { useDispatch, useSelector } from 'react-redux'
import ButtonList from '../local/molecules/button-list'
import { Props } from '../../Components/local/atoms/button/types/props'
import { modalAction } from '../../ActionsAndReducers/Modal/Modal_ActionCreators'
import {
setSelectedForce,
setTabSaved,
addNewForce,
saveForce,
refreshForce
} from '../../ActionsAndReducers/dbWargames/wargames_ActionCreators'
import { forceTemplate } from 'src/config'
import 'src/themes/App.scss'
import { RootState } from 'src/custom-types'
const UnsavedForceModal: React.FC = () => {
const dispatch = useDispatch()
const currentModal = useSelector((state: RootState) => state.currentModal)
const wargame = useSelector((state: RootState) => state.wargame)
const dontSave = () => {
if (currentModal.data as string === 'create-new') {
const id = 'force-' + uniqid.time()
dispatch(addNewForce({ name: id, uniqid: id }))
dispatch(setSelectedForce({ name: id, uniqid: id }))
const template = forceTemplate
template.name = id
template.uniqid = id
if (wargame.currentWargame) dispatch(saveForce(wargame.currentWargame, template))
} else {
if (wargame.currentWargame && currentModal.data) dispatch(refreshForce(wargame.currentWargame, currentModal.data as string))
}
dispatch(setTabSaved())
dispatch(modalAction.close())
}
const onHideModal = () => {
dispatch(modalAction.close())
}
if (!currentModal.open) return <></>
const buttons: Props[] = [{
name: 'cancel',
color: 'secondary',
onClick: onHideModal,
children: 'Cancel'
}, {
name: 'continue',
color: 'primary',
onClick: dontSave,
children: 'Don\'t save'
}]
// const actions = [{
// onClick: () => setView(`${MESSAGE_CREATOR_BASE_ROUTE}${EDIT_TEMPLATE_ROUTE}`),
// color: 'secondary',
// fullWidth: true,
// icon: 'edit',
// children: 'Edit'
// }, {
// onClick: duplicateTemplate,
// color: 'secondary',
// fullWidth: true,
// icon: 'copy',
// children: 'Duplicate'
// }, {
// onClick: deleteTemplate,
// color: 'secondary',
// fullWidth: true,
// icon: 'delete',
// children: 'Delete'
// }]
return (
<ModalWrapper>
<div className='display-text-wrapper'>
<h3>Are you sure?</h3>
<p>There are unsaved changes.</p>
<div className='buttons'>
<ButtonList buttons={buttons} />
</div>
</div>
</ModalWrapper>
)
}
export default UnsavedForceModal