-
Notifications
You must be signed in to change notification settings - Fork 318
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Maps Update: Cards and Modals for Maps Components #1314
base: development
Are you sure you want to change the base?
Changes from 4 commits
6f3ee9f
17d26a0
823b161
09b333a
8ff0ebe
dc87b56
c799c95
0a941da
af01ec7
b55b672
2b3885d
a7e6ddf
6397225
0fb3b45
76ddde9
815f998
b427cbf
b687569
d57da8c
bc49a65
105395d
0d0a421
75c5609
8430932
6db61de
e775c62
4c5f66c
09e0738
811dc66
9641220
30d7bf7
1e0b61b
51a220f
d270242
18fa275
ca08606
9c4513d
8a276b4
21de916
45d0db6
17c851e
5c8dbc1
b7a3e56
ae28cda
67d578c
66ea48d
095def8
8a53505
b71527a
90db2c6
18b8b6e
a8237ba
04ba6a5
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
/* This Source Code Form is subject to the terms of the Mozilla Public | ||
* License, v. 2.0. If a copy of the MPL was not distributed with this | ||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */ | ||
|
||
import * as React from 'react'; | ||
import { useState } from 'react'; | ||
import { FormattedMessage } from 'react-intl'; | ||
import { Button, Modal, ModalHeader, ModalBody, ModalFooter, Form, FormGroup, Label, Input } from 'reactstrap'; | ||
import { Link } from 'react-router-dom'; | ||
|
||
interface CreateMapModalProps { | ||
show: boolean; | ||
handleClose: () => void; | ||
createNewMap: () => void; | ||
} | ||
|
||
/** | ||
* Defines the create map modal form | ||
* @returns Map create element | ||
*/ | ||
function CreateMapModalComponent({ show, handleClose, createNewMap }: CreateMapModalProps) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Other create modals do not pass props. Are these essential or does a change need to happen (maybe outside this PR)? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This will be future work, I have left a TODO note. |
||
const [nameInput, setNameInput] = useState(''); | ||
const [noteInput, setNoteInput] = useState(''); | ||
|
||
const handleCreate = () => { | ||
// TODO: Implement create functionality | ||
createNewMap(); | ||
handleClose(); | ||
}; | ||
|
||
return ( | ||
<Modal isOpen={show} toggle={handleClose}> | ||
<ModalHeader toggle={handleClose}> | ||
<FormattedMessage id="create.map" /> | ||
</ModalHeader> | ||
<ModalBody> | ||
<Form> | ||
<FormGroup> | ||
<Label for="mapName"><FormattedMessage id="map.name" /></Label> | ||
<Input | ||
id="mapName" | ||
value={nameInput} | ||
onChange={e => setNameInput(e.target.value)} | ||
/> | ||
</FormGroup> | ||
<FormGroup> | ||
<Label for="mapNote"><FormattedMessage id="note" /></Label> | ||
<Input | ||
id="mapNote" | ||
type="textarea" | ||
value={noteInput} | ||
onChange={e => setNoteInput(e.target.value)} | ||
/> | ||
</FormGroup> | ||
</Form> | ||
<div> | ||
<Link to='/calibration' onClick={() => createNewMap()}> | ||
<Button color='primary'> | ||
<FormattedMessage id='map.upload.file' /> | ||
</Button> | ||
</Link> | ||
</div> | ||
</ModalBody> | ||
<ModalFooter> | ||
<Button color="secondary" onClick={handleClose}> | ||
<FormattedMessage id="cancel" /> | ||
</Button> | ||
<Button color="primary" onClick={handleCreate}> | ||
<FormattedMessage id="create" /> | ||
</Button> | ||
</ModalFooter> | ||
</Modal> | ||
); | ||
} | ||
|
||
export default CreateMapModalComponent; |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,151 @@ | ||
/* This Source Code Form is subject to the terms of the Mozilla Public | ||
* License, v. 2.0. If a copy of the MPL was not distributed with this | ||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */ | ||
|
||
import * as React from 'react'; | ||
import { useState } from 'react'; | ||
import { FormattedMessage, useIntl } from 'react-intl'; | ||
import { Button, Modal, ModalHeader, ModalBody, ModalFooter, Form, FormGroup, Label, Input } from 'reactstrap'; | ||
import { Link } from 'react-router-dom'; | ||
import { CalibrationModeTypes, MapMetadata } from '../../types/redux/map'; | ||
import { showErrorNotification } from '../../utils/notifications'; | ||
|
||
interface EditMapModalProps { | ||
show: boolean; | ||
handleClose: () => void; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is probably a note for the future. The view passes the id but here is passed the map state object. At some point OED needs to standardize. |
||
map: MapMetadata; | ||
editMapDetails(map: MapMetadata): any; | ||
setCalibration(mode: CalibrationModeTypes, mapID: number): any; | ||
removeMap(id: number): any; | ||
} | ||
|
||
/** | ||
*Defines the edit maps modal form | ||
* @param props state variables needed to define the component | ||
* @returns Map edit element | ||
*/ | ||
function EditMapModalComponent(props: EditMapModalProps) { | ||
const [nameInput, setNameInput] = useState(props.map.name); | ||
const [noteInput, setNoteInput] = useState(props.map.note || ''); | ||
const [circleInput, setCircleInput] = useState(props.map.circleSize.toString()); | ||
const [displayable, setDisplayable] = useState(props.map.displayable); | ||
|
||
const intl = useIntl(); | ||
|
||
const handleSave = () => { | ||
const updatedMap = { | ||
...props.map, | ||
name: nameInput, | ||
note: noteInput, | ||
circleSize: parseFloat(circleInput), | ||
displayable: displayable | ||
}; | ||
props.editMapDetails(updatedMap); | ||
props.handleClose(); | ||
}; | ||
|
||
const handleDelete = () => { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is not being done as is the case, for example, with unit. It should be the same. |
||
const consent = window.confirm(intl.formatMessage({ id: 'map.confirm.remove' }, { name: props.map.name })); | ||
if (consent) { | ||
props.removeMap(props.map.id); | ||
props.handleClose(); | ||
} | ||
}; | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Maybe for future TODO and in issue. Most modals use centralized functions for changes and not one for each item. This means you don't dispatch changes until save. |
||
const handleCalibrationSetting = (mode: CalibrationModeTypes) => { | ||
props.setCalibration(mode, props.map.id); | ||
props.handleClose(); | ||
}; | ||
|
||
const toggleCircleEdit = () => { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This sort of check is now done with input checks on the form in other modals. |
||
const regtest = /^\d+(\.\d+)?$/; | ||
if (regtest.test(circleInput) && parseFloat(circleInput) <= 2.0) { | ||
setCircleInput(circleInput); | ||
} else { | ||
showErrorNotification(intl.formatMessage({ id: 'invalid.number' })); | ||
} | ||
}; | ||
|
||
return ( | ||
<Modal isOpen={props.show} toggle={props.handleClose}> | ||
<ModalHeader toggle={props.handleClose}> | ||
<FormattedMessage id="edit.map" /> | ||
</ModalHeader> | ||
<ModalBody> | ||
<Form> | ||
juanjoseguva marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<FormGroup> | ||
<Label for="mapName"><FormattedMessage id="map.name" /></Label> | ||
<Input | ||
id="mapName" | ||
value={nameInput} | ||
onChange={e => setNameInput(e.target.value)} | ||
/> | ||
</FormGroup> | ||
<FormGroup> | ||
<Label for="mapDisplayable"><FormattedMessage id="map.displayable" /></Label> | ||
<Input | ||
id="mapDisplayable" | ||
type="select" | ||
value={displayable.toString()} | ||
onChange={e => setDisplayable(e.target.value === 'true')} | ||
> | ||
<option value="true">{intl.formatMessage({ id: 'map.is.displayable' })}</option> | ||
juanjoseguva marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<option value="false">{intl.formatMessage({ id: 'map.is.not.displayable' })}</option> | ||
</Input> | ||
</FormGroup> | ||
<FormGroup> | ||
<Label for="mapCircleSize"><FormattedMessage id="map.circle.size" /></Label> | ||
<Input | ||
id="mapCircleSize" | ||
juanjoseguva marked this conversation as resolved.
Show resolved
Hide resolved
|
||
value={circleInput} | ||
onChange={e => setCircleInput(e.target.value)} | ||
onBlur={toggleCircleEdit} | ||
/> | ||
</FormGroup> | ||
<FormGroup> | ||
<Label for="mapNote"><FormattedMessage id="note" /></Label> | ||
<Input | ||
id="mapNote" | ||
type="textarea" | ||
value={noteInput} | ||
onChange={e => setNoteInput(e.target.value)} | ||
/> | ||
</FormGroup> | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The cards show the label/name on one line. I think that is clearer. However done it would be good to be consistent. When I click on new file nothing seems to happen but a message shows in the terminal/log for actions started. |
||
</Form> | ||
<div> | ||
<Label><FormattedMessage id="map.filename" /></Label> | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please see conversion edit for how uneditable items should look. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. From what I see this still does not look the way the mentioned page works. Am I missing something? |
||
<p>{props.map.filename}</p> | ||
<Link to='/calibration' onClick={() => handleCalibrationSetting(CalibrationModeTypes.initiate)}> | ||
<Button color='primary'> | ||
<FormattedMessage id='map.upload.new.file' /> | ||
juanjoseguva marked this conversation as resolved.
Show resolved
Hide resolved
|
||
</Button> | ||
</Link> | ||
</div> | ||
<div> | ||
<Label><FormattedMessage id="map.calibration" /></Label> | ||
<p> | ||
<FormattedMessage id={props.map.origin && props.map.opposite ? 'map.is.calibrated' : 'map.is.not.calibrated'} /> | ||
</p> | ||
<Link to='/calibration' onClick={() => handleCalibrationSetting(CalibrationModeTypes.calibrate)}> | ||
<Button color='primary'> | ||
<FormattedMessage id='map.calibrate' /> | ||
</Button> | ||
</Link> | ||
</div> | ||
</ModalBody> | ||
<ModalFooter> | ||
<Button color="danger" onClick={handleDelete}> | ||
<FormattedMessage id="delete.map" /> | ||
</Button> | ||
<Button color="secondary" onClick={props.handleClose}> | ||
<FormattedMessage id="cancel" /> | ||
</Button> | ||
<Button color="primary" onClick={handleSave}> | ||
<FormattedMessage id="done.editing" /> | ||
</Button> | ||
</ModalFooter> | ||
</Modal> | ||
); | ||
} | ||
|
||
export default EditMapModalComponent; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm unclear as what this file is used for. When I click create map it goes to the old page. I cannot find it used anywhere. Is it for the future, unneeded or am I missing something? If it is future then a clear TODO/comment is needed.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is work for the future, as there was not enough time to finish it given our time constraints. I have left TODOs throughout the necessary pieces of code.