Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 | 39x 39x 39x 39x 3x 39x 2x 2x 39x 39x 4x | import React, { useState } from "react"; import Modal from "react-bootstrap/Modal"; import Button from "react-bootstrap/Button"; import Form from "react-bootstrap/Form"; import PersonalScheduleSelector from "./PersonalScheduleSelector"; import { useBackend } from "main/utils/useBackend"; import { Link } from "react-router-dom"; import { yyyyqToQyy } from "main/utils/quarterUtilities.js"; import { filterSchedulesByQuarter } from "main/utils/PersonalScheduleUtils"; export default function AddToScheduleModal({ quarter, section, onAdd }) { const [showModal, setShowModal] = useState(false); const [selectedSchedule, setSelectedSchedule] = useState(""); // Stryker disable all const { data: schedules, error: _error, status: _status, } = useBackend( ["/api/personalschedules/all"], { method: "GET", url: "/api/personalschedules/all" }, [], ); // Stryker restore all const handleModalClose = () => { setShowModal(false); }; const handleModalSave = () => { onAdd(section, selectedSchedule); handleModalClose(); }; //filter schedules to match the current quarter const filteredSchedules = filterSchedulesByQuarter(schedules, quarter); // Stryker disable all : tested manually, complicated to test return ( <> <Button variant="success" onClick={() => setShowModal(true)}> Add </Button> <Modal show={showModal} onHide={handleModalClose}> <Modal.Header closeButton> <Modal.Title>Add to Schedule</Modal.Title> </Modal.Header> <Modal.Body> <Form> { /* istanbul ignore next */ filteredSchedules.length > 0 ? ( <Form.Group controlId="scheduleSelect"> <Form.Label>Select Schedule</Form.Label> <PersonalScheduleSelector filteredSchedules={filteredSchedules} schedule={selectedSchedule} setSchedule={setSelectedSchedule} controlId="scheduleSelect" /> </Form.Group> ) : ( <p> No personal schedules exist for quarter {yyyyqToQyy(quarter)}. <br /> <Link to="/personalschedules/create">[Create One]</Link> </p> ) } </Form> </Modal.Body> <Modal.Footer> <Button variant="secondary" onClick={handleModalClose}> Close </Button> <Button variant="primary" onClick={handleModalSave}> Save Changes </Button> </Modal.Footer> </Modal> </> ); // Stryker restore all } |