All files / src/components/Inputs/InputTypes Text.tsx

0% Statements 0/6
0% Branches 0/6
0% Functions 0/2
0% Lines 0/6

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                                                                                                 
import { Tooltip } from "@mui/material";
import React, { HTMLInputTypeAttribute } from "react";
 
type TextInputTypes = {
  label?: string;
  value: string;
  handleChange: (val: string) => void;
  error?: string;
  placeholder?: string;
  disabled?: boolean;
  className?: string;
  type?: HTMLInputTypeAttribute;
} & React.InputHTMLAttributes<HTMLInputElement>;
 
function Text({
  label,
  value,
  error,
  handleChange,
  placeholder,
  disabled,
  className,
  type,
  ...props
}: TextInputTypes) {
  const onChange = (e: React.ChangeEvent<HTMLInputElement>) => {
    const value = e.target.value;
    handleChange(value);
  };
 
  return (
    <Tooltip title={disabled ? value : ""}>
      <input
        className={`${className} ${
          error ? "border-red-500" : ""
        } border p-2 rounded text-xs outline-none font-normal text-ellipsis min-w-[100px] w-fit max-w-full h-auto`}
        onChange={onChange}
        placeholder={placeholder ?? `${label}`}
        value={value}
        disabled={disabled}
        type={type}
        {...props}
      />
    </Tooltip>
  );
}
 
export default Text;