All files / components/Quarters SingleQuarterDropdown.js

100% Statements 13/13
100% Branches 6/6
100% Functions 3/3
100% Lines 13/13

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                                  460x   460x         460x 29x 29x 29x 29x 29x 1x       460x   460x                 9000x 9000x                                
import React, { useState } from 'react'
import { Form } from 'react-bootstrap';
 
// controlId is used to remember the value for localStorage,
// and for the testId, so it should be unique to at least any
// given page where the component is used.
 
// quarter and setQuarter should be values returned
// by a parent component's setState 
 
// quarters is an array of objects in this format
// [{ yyyyq :"20214", qyy: "F21"},
//  { yyyyq :"20221", qyy: "W22"}, 
//  { yyyyq :"20222", qyy: "S22"}] 
 
function SingleQuarterDropdown({ quarters, setQuarter, controlId, onChange = null, label = "Quarter" }) {
 
    const localSearchQuarter = localStorage.getItem(controlId);
 
    const [quarterState, setQuarterState] = useState(
    // Stryker disable next-line all : not sure how to test/mock local storage
    localSearchQuarter || quarters[0].yyyyq
    );
 
    const handleQuarterOnChange = (event) => {
        const selectedQuarter = event.target.value;
        localStorage.setItem(controlId, selectedQuarter);
        setQuarterState(selectedQuarter);
        setQuarter(selectedQuarter);
        if (onChange != null) {
            onChange(event);
        }
    };
 
    setQuarter(quarterState); // set the parent state to the initial value
 
    return (
        <Form.Group controlId={controlId}>
            <Form.Label>{label}</Form.Label>
            <Form.Control
                as="select"
                value={quarterState}
                onChange={handleQuarterOnChange}
            >
                {quarters.map(function (object) {
                    const key=`${controlId}-option-${object.yyyyq}`;
                    return (
                        <option
                            key={key}
                            data-testid={key}
                            value={object.yyyyq}
                        >
                            {object.qyy}
                        </option>
                    );
                })}
            </Form.Control>
        </Form.Group>
    );
};
 
export default SingleQuarterDropdown;