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 | 5x 9x 9x 9x 9x 7x 6x 9x 2x 2x 2x 2x 2x 1x 9x 16x | import React, { useState, useEffect } from "react"; import { Form } from "react-bootstrap"; import { useBackend } from "main/utils/useBackend"; import { yyyyqToQyy } from "main/utils/quarterUtilities.js"; const PersonalScheduleSelector = ({ schedule, setSchedule, controlId, onChange = null, label = "Schedule", }) => { const localSearchSchedule = localStorage.getItem(controlId); const [scheduleState, setScheduleState] = useState( localSearchSchedule || schedule, ); // Stryker disable all const { data: schedules, error: _error, status: _status, } = useBackend( ["/api/personalschedules/all"], { method: "GET", url: "/api/personalschedules/all" }, [], ); // Stryker restore all useEffect(() => { if (schedules.length > 0) { setSchedule(schedules[0].id); } }, [schedules, setSchedule]); const handleScheduleOnChange = (event) => { const selectedSchedule = event.target.value; localStorage.setItem(controlId, selectedSchedule); setScheduleState(selectedSchedule); setSchedule(selectedSchedule); if (onChange != null) { onChange(event); } }; return ( <Form.Group controlId={controlId}> <Form.Label>{label}</Form.Label> <Form.Control as="select" value={scheduleState} onChange={handleScheduleOnChange} > {schedules && schedules.map((schedule) => ( <option key={schedule.id} value={schedule.id}> {yyyyqToQyy(schedule.quarter)} {schedule.name} </option> ))} </Form.Control> </Form.Group> ); }; export default PersonalScheduleSelector; |