export default function TableData()

in source/console/src/components/Simulations/TableData.tsx [23:127]


export default function TableData(props: IProps): JSX.Element {
    const logger = new Logger("Simulation Table Data");
    const [showDevices, setShowDevices] = useState(-1);
    const [showDeleteModal, setShowDeleteModal] = useState(false);

    /**
     * deletes the given simulation from ddb and reloads the page
     * @param simId 
     */
    const handleDelete = async (simId: string, index: number) => {
        try {
            await API.del(API_NAME, `/simulation/${simId}`, {});
            props.simulations.splice(index, 1);
            props.setSimulations([...props.simulations]);
        } catch (err) {
            logger.error(I18n.get("simulation.delete.error"), err);
            throw err;
        }
    }

    return (
        <tbody>
            { props.simulations.map((sim, i) => (
                <tr key={i}>
                    <td>
                        <Form.Check
                            id="sim.id"
                            type="checkbox"
                            checked={sim.checked}
                            onChange={(event) => { props.handleCheckboxSelect(event, i) }}
                        >
                        </Form.Check>
                    </td>
                    <td>{sim.name}</td>
                    <td>{sim.stage}</td>
                    <td>

                        &nbsp;
                    <Button
                            className="button-theme button-rounded"
                            size="sm"
                            onClick={() => { setShowDevices(i) }}
                        >
                            <i className="bi bi-info-circle" /> {I18n.get("info")}
                        </Button>
                        <Modal show={showDevices === i} onHide={() => { setShowDevices(-1) }}>
                            <Modal.Header closeButton>
                                <Modal.Title>{sim.name}</Modal.Title>
                            </Modal.Header>
                            <Modal.Body>
                                <Table
                                    className="form-table table-header"
                                    borderless>
                                    <thead>
                                        <tr>
                                            <th>{I18n.get("device.types")}</th>
                                            <th>{I18n.get("amount")}</th>
                                        </tr>
                                    </thead>
                                    <tbody>
                                        {sim.devices.map((device, j) => (
                                            <tr key={j}>
                                                <td>{device.name}</td>
                                                <td>{device.amount}</td>
                                            </tr>
                                        ))}
                                    </tbody>
                                </Table>
                            </Modal.Body>
                        </Modal>
                    </td>
                    <td>{sim.runs}</td>
                    <td>{sim.lastRun ? sim.lastRun : ""}</td>
                    <td>
                        <Link
                            to={{
                                pathname: `/simulations/${sim.simId}`,
                                state: {
                                    simulatiom: sim.simId
                                }
                            }}
                        >
                            <Button size="sm" className="button-theme" type="submit">
                                <i className="bi bi-eye-fill" /> {I18n.get("view")}
                            </Button>
                        </Link>
                        <Button
                            size="sm"
                            className="button-theme-alt"
                            onClick={() => { setShowDeleteModal(true) }}
                        >
                            <i className="bi bi-trash-fill" /> {I18n.get("delete")}
                        </Button>
                        <DeleteConfirm
                            id={sim.simId}
                            name={sim.name}
                            delete={handleDelete}
                            showModal={setShowDeleteModal}
                            show={showDeleteModal}
                            index={i}
                        />
                    </td>
                </tr>
            ))
            }