All files / src/components/forms TextWaitTimeSelect.tsx

0% Statements 0/35
0% Branches 0/4
0% Functions 0/10
0% Lines 0/34

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 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107                                                                                                                                                                                                                     
import { UnitSelectLabelButton } from "components/forms/UnitsSelectLabelButton";
import React, { useEffect, useRef } from "react";
import { useCallback } from "react";
import { TimeUnitType } from "shared/lib/entities/entitiesTypes";
import l10n from "shared/lib/lang/l10n";
import { ensureNumber } from "shared/types";
import styled from "styled-components";
import { FormField, FormRow } from "ui/form/layout/FormLayout";
import { NumberInput } from "ui/form/NumberInput";
 
interface TextWaitTimeSelectProps {
  value: number;
  units: "frames" | "time";
  onChange: (newValue: number) => void;
  onChangeUnits: (newUnits: "frames" | "time") => void;
  onBlur: () => void;
}
 
const Form = styled.form`
  min-width: 200px;
  padding-top: 5px;
`;
 
export const TextWaitTimeSelect = ({
  value,
  units,
  onChange,
  onChangeUnits,
  onBlur,
}: TextWaitTimeSelectProps) => {
  const timerRef = useRef<ReturnType<typeof setTimeout>>();
 
  const debouncedLeave = useCallback(() => {
    Iif (timerRef.current) {
      clearTimeout(timerRef.current);
    }
    timerRef.current = setTimeout(() => {
      onBlur();
    }, 250);
  }, [onBlur]);
 
  useEffect(() => {
    return () => {
      // Cleanup timer
      Iif (timerRef.current) {
        clearTimeout(timerRef.current);
      }
    };
  }, []);
 
  const onFocus = useCallback(() => {
    Iif (timerRef.current) {
      clearTimeout(timerRef.current);
    }
  }, []);
 
  const onFocusOut = useCallback(
    (event: React.FocusEvent<HTMLFormElement, Element>) => {
      Iif (event.currentTarget.contains(event.relatedTarget)) {
        return;
      }
      debouncedLeave();
    },
    [debouncedLeave]
  );
 
  const blockSubmit = useCallback((e: React.FormEvent<HTMLFormElement>) => {
    e.preventDefault();
    e.stopPropagation();
  }, []);
 
  return (
    <Form onFocus={onFocus} onBlur={onFocusOut} onSubmit={blockSubmit}>
      <FormRow>
        <FormField
          name="replaceWaitTime"
          label={
            <>
              {l10n("EVENT_WAIT")}
              <UnitSelectLabelButton
                value={units}
                allowedValues={["time", "frames"]}
                onChange={(value) => {
                  onChangeUnits(value as TimeUnitType);
                }}
              />
            </>
          }
        >
          <NumberInput
            id="replaceWaitTime"
            value={value}
            onChange={(e) => {
              const value = Math.max(
                0,
                ensureNumber(parseFloat(e.currentTarget.value), 0)
              );
              onChange(value);
            }}
            autoFocus
          />
        </FormField>
      </FormRow>
    </Form>
  );
};