summaryrefslogtreecommitdiffstats
path: root/src/utils/hooks/use-add-classname.tsx
Commit message (Expand)AuthorAgeFilesLines
* refactor: rewrite Prism hooks and providersArmand Philippot2022-05-191-0/+34
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
import Field, { type FieldProps } from '@components/atoms/forms/field';
import Label from '@components/atoms/forms/label';
import { FC } from 'react';
import styles from './labelled-field.module.scss';

export type LabelledFieldProps = FieldProps & {
  /**
   * Visually hide the field label. Default: false.
   */
  hideLabel?: boolean;
  /**
   * The field label.
   */
  label: string;
  /**
   * The label position. Default: top.
   */
  labelPosition?: 'left' | 'top';
};

/**
 * LabelledField component
 *
 * Render a field tied to a label.
 */
const LabelledField: FC<LabelledFieldProps> = ({
  hideLabel = false,
  id,
  label,
  labelPosition = 'top',
  required,
  ...props
}) => {
  const positionModifier = `label--${labelPosition}`;
  const visibilityClass = hideLabel ? 'screen-reader-text' : '';

  return (
    <>
      <Label
        htmlFor={id}
        required={required}
        className={`${visibilityClass} ${styles[positionModifier]}`}
      >
        {label}
      </Label>
      <Field id={id} required={required} {...props} />
    </>
  );
};

export default LabelledField;