@codecademy/gamut 67.6.5-alpha.e8ee42.0 → 67.6.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/dist/ConnectedForm/ConnectedFormGroup.d.ts +2 -8
  2. package/dist/ConnectedForm/ConnectedFormGroup.js +1 -1
  3. package/dist/ConnectedForm/ConnectedInputs/ConnectedCheckbox.js +0 -2
  4. package/dist/Form/elements/FormGroupLabel.d.ts +2 -2
  5. package/dist/Form/elements/FormGroupLabel.js +3 -10
  6. package/dist/Form/inputs/Checkbox.d.ts +0 -7
  7. package/dist/Form/inputs/Checkbox.js +11 -27
  8. package/dist/Form/inputs/Radio.d.ts +5 -9
  9. package/dist/Form/inputs/Radio.js +10 -13
  10. package/dist/Form/styles/Radio-styles.d.ts +3 -0
  11. package/dist/Form/styles/Radio-styles.js +6 -0
  12. package/dist/Form/styles/shared-system-props.d.ts +0 -7
  13. package/dist/Form/styles/shared-system-props.js +0 -11
  14. package/dist/GridForm/GridFormInputGroup/GridFormRadioGroupInput/index.js +0 -2
  15. package/dist/GridForm/GridFormInputGroup/__fixtures__/renderers.d.ts +0 -4
  16. package/dist/GridForm/types.d.ts +2 -7
  17. package/dist/Tip/InfoTip/InfoTipButton.js +2 -5
  18. package/dist/Tip/InfoTip/elements.d.ts +12 -0
  19. package/dist/Tip/InfoTip/elements.js +9 -0
  20. package/dist/Tip/InfoTip/index.d.ts +2 -39
  21. package/dist/Tip/InfoTip/index.js +67 -50
  22. package/dist/Tip/__tests__/helpers.d.ts +26 -5
  23. package/dist/Tip/shared/FloatingTip.js +3 -3
  24. package/dist/Tip/shared/InlineTip.js +1 -4
  25. package/dist/Tip/shared/types.d.ts +1 -1
  26. package/dist/Tip/shared/utils.d.ts +0 -19
  27. package/dist/Tip/shared/utils.js +0 -104
  28. package/package.json +8 -8
  29. package/dist/Form/__tests__/testUtils.d.ts +0 -22
  30. package/dist/Tip/InfoTip/type-utils.d.ts +0 -35
  31. package/dist/Tip/InfoTip/type-utils.js +0 -72
@@ -3,19 +3,16 @@ function _extends() { return _extends = Object.assign ? Object.assign.bind() : f
3
3
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
4
4
  import { noSelect, screenReaderOnly, styledOptions, timing } from '@codecademy/gamut-styles';
5
5
  import { forwardRef, useEffect, useRef } from 'react';
6
- import { FlexBox } from '../../Box';
7
- import { InfoTip } from '../../Tip/InfoTip';
8
- import { useInfotipProps } from '../../Tip/InfoTip/type-utils';
9
- import { checkboxElement, checkboxElementStates, checkboxInput, checkboxLabel, checkboxLabelStates, checkboxPadding, checkboxTextStates, InputWrapper, polyline } from '../styles';
6
+ import { checkboxElement, checkboxElementStates, checkboxInput, checkboxLabel, checkboxLabelStates, checkboxPadding, checkboxTextStates, polyline } from '../styles';
10
7
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
11
8
  const CheckboxLabel = /*#__PURE__*/_styled("label", {
12
9
  target: "e1ni3uy16",
13
10
  label: "CheckboxLabel"
14
- })(noSelect, checkboxLabel, checkboxPadding, checkboxLabelStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AAwFsB","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport { FlexBox } from '../../Box';\nimport { InfoTip } from '../../Tip/InfoTip';\nimport {\n  InfoTipSubComponentProps,\n  useInfotipProps,\n} from '../../Tip/InfoTip/type-utils';\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  InputWrapper,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * Infotip props to render to the right of your checkbox label.\n     * The InfoTip button is automatically labelled by the checkbox label.\n     * To override this behavior, provide `ariaLabel` or `ariaLabelledby`.\n     */\n    infotip?: InfoTipSubComponentProps;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      infotip,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n    const { infotipProps, labelId, shouldLabelInfoTip } =\n      useInfotipProps(infotip);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n    const textId = shouldLabelInfoTip ? labelId : `text-${id || htmlFor}`;\n\n    return (\n      <InputWrapper className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={textId}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={textId}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n        {infotipProps && (\n          <FlexBox center pl={8}>\n            <InfoTip {...infotipProps} />\n          </FlexBox>\n        )}\n      </InputWrapper>\n    );\n  }\n);\n"]} */");
11
+ })(noSelect, checkboxLabel, checkboxPadding, checkboxLabelStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AA2EsB","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n\n    return (\n      <div className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={`text-${id || htmlFor}`}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={`text-${id || htmlFor}`}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n      </div>\n    );\n  }\n);\n"]} */");
15
12
  const CheckboxElement = /*#__PURE__*/_styled('div', _extends({}, {
16
13
  target: "e1ni3uy15",
17
14
  label: "CheckboxElement"
18
- }, styledOptions))(checkboxElement, checkboxElementStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AAiGwB","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport { FlexBox } from '../../Box';\nimport { InfoTip } from '../../Tip/InfoTip';\nimport {\n  InfoTipSubComponentProps,\n  useInfotipProps,\n} from '../../Tip/InfoTip/type-utils';\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  InputWrapper,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * Infotip props to render to the right of your checkbox label.\n     * The InfoTip button is automatically labelled by the checkbox label.\n     * To override this behavior, provide `ariaLabel` or `ariaLabelledby`.\n     */\n    infotip?: InfoTipSubComponentProps;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      infotip,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n    const { infotipProps, labelId, shouldLabelInfoTip } =\n      useInfotipProps(infotip);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n    const textId = shouldLabelInfoTip ? labelId : `text-${id || htmlFor}`;\n\n    return (\n      <InputWrapper className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={textId}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={textId}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n        {infotipProps && (\n          <FlexBox center pl={8}>\n            <InfoTip {...infotipProps} />\n          </FlexBox>\n        )}\n      </InputWrapper>\n    );\n  }\n);\n"]} */");
15
+ }, styledOptions))(checkboxElement, checkboxElementStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AAoFwB","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n\n    return (\n      <div className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={`text-${id || htmlFor}`}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={`text-${id || htmlFor}`}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n      </div>\n    );\n  }\n);\n"]} */");
19
16
  const CheckboxVector = /*#__PURE__*/_styled("svg", {
20
17
  target: "e1ni3uy14",
21
18
  label: "CheckboxVector"
@@ -25,7 +22,7 @@ const CheckboxVector = /*#__PURE__*/_styled("svg", {
25
22
  } : {
26
23
  name: "13idn5w",
27
24
  styles: "position:absolute;top:-1px;left:-1px",
28
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AAsGiC","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport { FlexBox } from '../../Box';\nimport { InfoTip } from '../../Tip/InfoTip';\nimport {\n  InfoTipSubComponentProps,\n  useInfotipProps,\n} from '../../Tip/InfoTip/type-utils';\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  InputWrapper,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * Infotip props to render to the right of your checkbox label.\n     * The InfoTip button is automatically labelled by the checkbox label.\n     * To override this behavior, provide `ariaLabel` or `ariaLabelledby`.\n     */\n    infotip?: InfoTipSubComponentProps;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      infotip,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n    const { infotipProps, labelId, shouldLabelInfoTip } =\n      useInfotipProps(infotip);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n    const textId = shouldLabelInfoTip ? labelId : `text-${id || htmlFor}`;\n\n    return (\n      <InputWrapper className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={textId}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={textId}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n        {infotipProps && (\n          <FlexBox center pl={8}>\n            <InfoTip {...infotipProps} />\n          </FlexBox>\n        )}\n      </InputWrapper>\n    );\n  }\n);\n"]} */",
25
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AAyFiC","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n\n    return (\n      <div className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={`text-${id || htmlFor}`}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={`text-${id || htmlFor}`}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n      </div>\n    );\n  }\n);\n"]} */",
29
26
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
30
27
  });
31
28
  const Checkmark = /*#__PURE__*/_styled("polyline", {
@@ -33,21 +30,21 @@ const Checkmark = /*#__PURE__*/_styled("polyline", {
33
30
  label: "Checkmark"
34
31
  })(polyline, " fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:18px;stroke-dashoffset:", ({
35
32
  checked
36
- }) => checked ? 0 : `18px`, ";transition:stroke-dashoffset ", timing.fast, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AA4GiE","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport { FlexBox } from '../../Box';\nimport { InfoTip } from '../../Tip/InfoTip';\nimport {\n  InfoTipSubComponentProps,\n  useInfotipProps,\n} from '../../Tip/InfoTip/type-utils';\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  InputWrapper,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * Infotip props to render to the right of your checkbox label.\n     * The InfoTip button is automatically labelled by the checkbox label.\n     * To override this behavior, provide `ariaLabel` or `ariaLabelledby`.\n     */\n    infotip?: InfoTipSubComponentProps;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      infotip,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n    const { infotipProps, labelId, shouldLabelInfoTip } =\n      useInfotipProps(infotip);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n    const textId = shouldLabelInfoTip ? labelId : `text-${id || htmlFor}`;\n\n    return (\n      <InputWrapper className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={textId}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={textId}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n        {infotipProps && (\n          <FlexBox center pl={8}>\n            <InfoTip {...infotipProps} />\n          </FlexBox>\n        )}\n      </InputWrapper>\n    );\n  }\n);\n"]} */"));
33
+ }) => checked ? 0 : `18px`, ";transition:stroke-dashoffset ", timing.fast, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AA+FiE","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n\n    return (\n      <div className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={`text-${id || htmlFor}`}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={`text-${id || htmlFor}`}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n      </div>\n    );\n  }\n);\n"]} */"));
37
34
  const Line = /*#__PURE__*/_styled("line", {
38
35
  target: "e1ni3uy12",
39
36
  label: "Line"
40
37
  })(polyline, " fill:none;stroke:currentColor;stroke-width:2;stroke-dasharray:18px;stroke-dashoffset:", ({
41
38
  indeterminate
42
- }) => indeterminate ? 0 : `18px`, ";transition:stroke-dashoffset ", timing.fast, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AAwH8D","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport { FlexBox } from '../../Box';\nimport { InfoTip } from '../../Tip/InfoTip';\nimport {\n  InfoTipSubComponentProps,\n  useInfotipProps,\n} from '../../Tip/InfoTip/type-utils';\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  InputWrapper,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * Infotip props to render to the right of your checkbox label.\n     * The InfoTip button is automatically labelled by the checkbox label.\n     * To override this behavior, provide `ariaLabel` or `ariaLabelledby`.\n     */\n    infotip?: InfoTipSubComponentProps;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      infotip,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n    const { infotipProps, labelId, shouldLabelInfoTip } =\n      useInfotipProps(infotip);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n    const textId = shouldLabelInfoTip ? labelId : `text-${id || htmlFor}`;\n\n    return (\n      <InputWrapper className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={textId}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={textId}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n        {infotipProps && (\n          <FlexBox center pl={8}>\n            <InfoTip {...infotipProps} />\n          </FlexBox>\n        )}\n      </InputWrapper>\n    );\n  }\n);\n"]} */"));
39
+ }) => indeterminate ? 0 : `18px`, ";transition:stroke-dashoffset ", timing.fast, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AA2G8D","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n\n    return (\n      <div className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={`text-${id || htmlFor}`}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={`text-${id || htmlFor}`}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n      </div>\n    );\n  }\n);\n"]} */"));
43
40
  const Input = /*#__PURE__*/_styled("input", {
44
41
  target: "e1ni3uy11",
45
42
  label: "Input"
46
- })(screenReaderOnly, " ", checkboxInput, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AAkI0B","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport { FlexBox } from '../../Box';\nimport { InfoTip } from '../../Tip/InfoTip';\nimport {\n  InfoTipSubComponentProps,\n  useInfotipProps,\n} from '../../Tip/InfoTip/type-utils';\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  InputWrapper,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * Infotip props to render to the right of your checkbox label.\n     * The InfoTip button is automatically labelled by the checkbox label.\n     * To override this behavior, provide `ariaLabel` or `ariaLabelledby`.\n     */\n    infotip?: InfoTipSubComponentProps;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      infotip,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n    const { infotipProps, labelId, shouldLabelInfoTip } =\n      useInfotipProps(infotip);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n    const textId = shouldLabelInfoTip ? labelId : `text-${id || htmlFor}`;\n\n    return (\n      <InputWrapper className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={textId}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={textId}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n        {infotipProps && (\n          <FlexBox center pl={8}>\n            <InfoTip {...infotipProps} />\n          </FlexBox>\n        )}\n      </InputWrapper>\n    );\n  }\n);\n"]} */"));
43
+ })(screenReaderOnly, " ", checkboxInput, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AAqH0B","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n\n    return (\n      <div className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={`text-${id || htmlFor}`}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={`text-${id || htmlFor}`}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n      </div>\n    );\n  }\n);\n"]} */"));
47
44
  const CheckboxText = /*#__PURE__*/_styled("span", {
48
45
  target: "e1ni3uy10",
49
46
  label: "CheckboxText"
50
- })(checkboxTextStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AAuIqB","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport { FlexBox } from '../../Box';\nimport { InfoTip } from '../../Tip/InfoTip';\nimport {\n  InfoTipSubComponentProps,\n  useInfotipProps,\n} from '../../Tip/InfoTip/type-utils';\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  InputWrapper,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * Infotip props to render to the right of your checkbox label.\n     * The InfoTip button is automatically labelled by the checkbox label.\n     * To override this behavior, provide `ariaLabel` or `ariaLabelledby`.\n     */\n    infotip?: InfoTipSubComponentProps;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      infotip,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n    const { infotipProps, labelId, shouldLabelInfoTip } =\n      useInfotipProps(infotip);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n    const textId = shouldLabelInfoTip ? labelId : `text-${id || htmlFor}`;\n\n    return (\n      <InputWrapper className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={textId}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={textId}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n        {infotipProps && (\n          <FlexBox center pl={8}>\n            <InfoTip {...infotipProps} />\n          </FlexBox>\n        )}\n      </InputWrapper>\n    );\n  }\n);\n"]} */");
47
+ })(checkboxTextStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Form/inputs/Checkbox.tsx"],"names":[],"mappings":"AA0HqB","file":"../../../src/Form/inputs/Checkbox.tsx","sourcesContent":["import {\n  noSelect,\n  screenReaderOnly,\n  styledOptions,\n  timing,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { forwardRef, InputHTMLAttributes, useEffect, useRef } from 'react';\n\nimport {\n  checkboxElement,\n  checkboxElementStates,\n  checkboxInput,\n  checkboxLabel,\n  checkboxLabelStates,\n  checkboxPadding,\n  checkboxTextStates,\n  polyline,\n} from '../styles';\nimport { BaseInputProps } from '../types';\nimport { CheckboxCheckedUnion, CheckboxLabelUnion } from './types';\n\nexport type CheckboxTextProps = StyleProps<typeof checkboxTextStates>;\nexport type CheckboxPaddingProps = StyleProps<typeof checkboxPadding>;\n\nexport type CheckboxProps = Omit<\n  InputHTMLAttributes<HTMLInputElement>,\n  'checked' | 'value' | 'label' | 'aria-label'\n> &\n  CheckboxLabelUnion &\n  CheckboxCheckedUnion &\n  CheckboxPaddingProps &\n  Pick<BaseInputProps, 'name' | 'required'> & {\n    multiline?: boolean;\n    className?: string;\n    /**\n     * [The for/id string of a label or labelable form-related element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLLabelElement/htmlFor). The outer FormGroup or FormLabel should have an identical string as the inner FormElement for accessibility purposes.\n     */\n    htmlFor: string;\n    /**\n     * @remarks\n     * The `value` prop here gets passed to the underlying `input` component\n     * and functions exactly like the HTML spec for checkboxes defines\n     * (which may not be as you expect):\n     * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value=\n     *\n     * Of note is that `value` ends up being the string that your field name key\n     * is set to when the checkbox is checked. So a `value` of the boolean `true` and\n     * a `name` of \"isPro\" will result in `{\n     *  isPro: \"true\"\n     * }` being submitted to your (non-`Connected`) form when the checkbox is checked.\n     * However, if due to how your HOC is organized, the Checkbox recieves a value\n     * of the boolean `false` when it is unchecked, NOTHING will be submitted. You\n     * _will not_ get `{ isPro: \"false\" }` on submit. However, the `value` of your input\n     * will be \"false\"\n     *\n     * As the MDN documentation above states:\n     * \"If a checkbox is unchecked when its form is submitted, there is no value submitted to the server to represent its unchecked state (e.g. value=unchecked); the value is not submitted to the server at all\"\n     *\n     * This behavior may not matter to you if you're handling your own form values\n     * externally (i.e. not relying on default lower-case-`form`/`input` submit behavior)\n     * or you're using `register` from Gamut's `useField` hook,\n     * which uses `react-hook-form`'s logic to sidestep this behavior by not passing\n     * a value to the underlying checkbox at all.\n     */\n    value?: string | boolean;\n    id?: string;\n    /**\n     * Use if you want both the aria-label and text label to be read by voiceover - this component assumes that the aria-label and visual text label are identical.\n     * If you have a link in the Checkbox options, you should set this as true.\n     */\n    dontAriaHideLabel?: boolean;\n  };\n\nconst CheckboxLabel = styled.label<Pick<CheckboxProps, 'disabled' | 'spacing'>>(\n  noSelect,\n  checkboxLabel,\n  checkboxPadding,\n  checkboxLabelStates\n);\n\ntype CheckboxElementProps = StyleProps<typeof checkboxElementStates>;\n\nconst CheckboxElement = styled('div', styledOptions)<CheckboxElementProps>(\n  checkboxElement,\n  checkboxElementStates\n);\n\nconst CheckboxVector = styled.svg`\n  position: absolute;\n  top: -1px;\n  left: -1px;\n`;\n\nconst Checkmark = styled.polyline<Pick<CheckboxProps, 'checked'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-linecap: round;\n  stroke-linejoin: round;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ checked }) => (checked ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Line = styled.line<Pick<CheckboxProps, 'indeterminate'>>`\n  ${polyline}\n  fill: none;\n  stroke: currentColor;\n  stroke-width: 2;\n  stroke-dasharray: 18px;\n  stroke-dashoffset: ${({ indeterminate }) => (indeterminate ? 0 : `18px`)};\n  transition: stroke-dashoffset ${timing.fast};\n`;\n\nconst Input = styled.input`\n  ${screenReaderOnly}\n  ${checkboxInput}\n`;\n\nconst CheckboxText = styled.span<CheckboxTextProps>(checkboxTextStates);\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      'aria-label': ariaLabel,\n      checked,\n      indeterminate,\n      className,\n      disabled,\n      dontAriaHideLabel,\n      htmlFor,\n      id,\n      label,\n      multiline,\n      spacing,\n      value,\n      ...rest\n    },\n    ref\n  ) => {\n    const intRef = useRef<HTMLInputElement | null>(null);\n\n    function syncedRefs(element: HTMLInputElement | null) {\n      intRef.current = element;\n      if (ref) {\n        if (typeof ref === 'object') {\n          ref.current = element;\n        } else {\n          ref(element);\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (intRef.current && indeterminate !== undefined && !checked) {\n        intRef.current.indeterminate = indeterminate;\n      }\n    }, [checked, indeterminate]);\n\n    const active = checked || indeterminate;\n\n    return (\n      <div className={className}>\n        <Input\n          aria-label={\n            ariaLabel === undefined\n              ? typeof label === 'string'\n                ? label\n                : 'checkbox'\n              : ariaLabel\n          }\n          checked={checked}\n          disabled={disabled}\n          id={id || htmlFor}\n          labelled-by={`text-${id || htmlFor}`}\n          type=\"checkbox\"\n          value={`${value}`}\n          {...rest}\n          ref={syncedRefs}\n        />\n        <CheckboxLabel\n          disabled={disabled}\n          htmlFor={id || htmlFor}\n          spacing={spacing}\n        >\n          <CheckboxElement\n            active={active}\n            disabled={disabled}\n            hasBg={checked || indeterminate}\n            hideBorder={disabled && (checked || indeterminate)}\n            multiline={multiline}\n          >\n            <CheckboxVector\n              aria-hidden\n              color={active ? 'currentColor' : 'transparent'}\n              height=\"19px\"\n              viewBox=\"0 0 19 19\"\n              width=\"19px\"\n            >\n              <Checkmark\n                // This should never happen if the types are working, but is a good back-up.\n                checked={checked && !indeterminate}\n                points=\"4 11 8 15 16 6\"\n              />\n              <Line\n                indeterminate={indeterminate}\n                x1=\"4\"\n                x2=\"16\"\n                y1=\"10\"\n                y2=\"10\"\n              />\n            </CheckboxVector>\n          </CheckboxElement>\n          <CheckboxText\n            aria-hidden={dontAriaHideLabel ? 'false' : 'true'}\n            disabled={disabled}\n            id={`text-${id || htmlFor}`}\n            multiline={multiline}\n          >\n            {label}\n          </CheckboxText>\n        </CheckboxLabel>\n      </div>\n    );\n  }\n);\n"]} */");
51
48
  export const Checkbox = /*#__PURE__*/forwardRef(({
52
49
  'aria-label': ariaLabel,
53
50
  checked,
@@ -57,7 +54,6 @@ export const Checkbox = /*#__PURE__*/forwardRef(({
57
54
  dontAriaHideLabel,
58
55
  htmlFor,
59
56
  id,
60
- infotip,
61
57
  label,
62
58
  multiline,
63
59
  spacing,
@@ -65,11 +61,6 @@ export const Checkbox = /*#__PURE__*/forwardRef(({
65
61
  ...rest
66
62
  }, ref) => {
67
63
  const intRef = useRef(null);
68
- const {
69
- infotipProps,
70
- labelId,
71
- shouldLabelInfoTip
72
- } = useInfotipProps(infotip);
73
64
  function syncedRefs(element) {
74
65
  intRef.current = element;
75
66
  if (ref) {
@@ -86,15 +77,14 @@ export const Checkbox = /*#__PURE__*/forwardRef(({
86
77
  }
87
78
  }, [checked, indeterminate]);
88
79
  const active = checked || indeterminate;
89
- const textId = shouldLabelInfoTip ? labelId : `text-${id || htmlFor}`;
90
- return /*#__PURE__*/_jsxs(InputWrapper, {
80
+ return /*#__PURE__*/_jsxs("div", {
91
81
  className: className,
92
82
  children: [/*#__PURE__*/_jsx(Input, {
93
83
  "aria-label": ariaLabel === undefined ? typeof label === 'string' ? label : 'checkbox' : ariaLabel,
94
84
  checked: checked,
95
85
  disabled: disabled,
96
86
  id: id || htmlFor,
97
- "labelled-by": textId,
87
+ "labelled-by": `text-${id || htmlFor}`,
98
88
  type: "checkbox",
99
89
  value: `${value}`,
100
90
  ...rest,
@@ -131,16 +121,10 @@ export const Checkbox = /*#__PURE__*/forwardRef(({
131
121
  }), /*#__PURE__*/_jsx(CheckboxText, {
132
122
  "aria-hidden": dontAriaHideLabel ? 'false' : 'true',
133
123
  disabled: disabled,
134
- id: textId,
124
+ id: `text-${id || htmlFor}`,
135
125
  multiline: multiline,
136
126
  children: label
137
127
  })]
138
- }), infotipProps && /*#__PURE__*/_jsx(FlexBox, {
139
- center: true,
140
- pl: 8,
141
- children: /*#__PURE__*/_jsx(InfoTip, {
142
- ...infotipProps
143
- })
144
128
  })]
145
129
  });
146
130
  });
@@ -1,7 +1,7 @@
1
1
  import { StyleProps } from '@codecademy/variance';
2
2
  import { InputHTMLAttributes, ReactNode } from 'react';
3
3
  import * as React from 'react';
4
- import { InfoTipSubComponentProps } from '../../Tip/InfoTip/type-utils';
4
+ import { InfoTipProps } from '../../Tip/InfoTip';
5
5
  import { conditionalRadioInputStyles } from '../styles';
6
6
  import { BaseInputProps } from '../types';
7
7
  export type RadioProps = InputHTMLAttributes<HTMLInputElement> & Omit<BaseInputProps, 'label'> & {
@@ -9,11 +9,9 @@ export type RadioProps = InputHTMLAttributes<HTMLInputElement> & Omit<BaseInputP
9
9
  disabled?: boolean;
10
10
  id?: string;
11
11
  /**
12
- * Infotip props to render to the right of your radio label.
13
- * The InfoTip button is automatically labelled by the radio label.
14
- * To override this behavior, provide `ariaLabel` or `ariaLabelledby`.
12
+ * Infotip props to render to the right of your radio label
15
13
  */
16
- infotip?: InfoTipSubComponentProps;
14
+ infotip?: InfoTipProps;
17
15
  /**
18
16
  * A label for your Radio input - should not include infotips or other interactive elements
19
17
  */
@@ -33,11 +31,9 @@ export declare const Radio: React.ForwardRefExoticComponent<InputHTMLAttributes<
33
31
  disabled?: boolean | undefined;
34
32
  id?: string | undefined;
35
33
  /**
36
- * Infotip props to render to the right of your radio label.
37
- * The InfoTip button is automatically labelled by the radio label.
38
- * To override this behavior, provide `ariaLabel` or `ariaLabelledby`.
34
+ * Infotip props to render to the right of your radio label
39
35
  */
40
- infotip?: InfoTipSubComponentProps | undefined;
36
+ infotip?: InfoTipProps | undefined;
41
37
  /**
42
38
  * A label for your Radio input - should not include infotips or other interactive elements
43
39
  */
@@ -4,17 +4,20 @@ import { forwardRef } from 'react';
4
4
  import * as React from 'react';
5
5
  import { FlexBox } from '../../Box';
6
6
  import { InfoTip } from '../../Tip/InfoTip';
7
- import { useInfotipProps } from '../../Tip/InfoTip/type-utils';
8
- import { conditionalRadioInputStyles, conditionalRadioLabelStyles, InputWrapper, radioInput, radioLabel } from '../styles';
7
+ import { conditionalRadioInputStyles, conditionalRadioLabelStyles, radioInput, radioLabel, radioWrapper } from '../styles';
9
8
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
9
+ const RadioWrapper = /*#__PURE__*/_styled("div", {
10
+ target: "etm5hqp2",
11
+ label: "RadioWrapper"
12
+ })(radioWrapper, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9Gb3JtL2lucHV0cy9SYWRpby50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMENxQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvRm9ybS9pbnB1dHMvUmFkaW8udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2NyZWVuUmVhZGVyT25seSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgeyBTdHlsZVByb3BzIH0gZnJvbSAnQGNvZGVjYWRlbXkvdmFyaWFuY2UnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgSW5wdXRIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBGbGV4Qm94IH0gZnJvbSAnLi4vLi4vQm94JztcbmltcG9ydCB7IEluZm9UaXAsIEluZm9UaXBQcm9wcyB9IGZyb20gJy4uLy4uL1RpcC9JbmZvVGlwJztcbmltcG9ydCB7XG4gIGNvbmRpdGlvbmFsUmFkaW9JbnB1dFN0eWxlcyxcbiAgY29uZGl0aW9uYWxSYWRpb0xhYmVsU3R5bGVzLFxuICByYWRpb0lucHV0LFxuICByYWRpb0xhYmVsLFxuICByYWRpb1dyYXBwZXIsXG59IGZyb20gJy4uL3N0eWxlcyc7XG5pbXBvcnQgeyBCYXNlSW5wdXRQcm9wcyB9IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgUmFkaW9Qcm9wcyA9IElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4gJlxuICBPbWl0PEJhc2VJbnB1dFByb3BzLCAnbGFiZWwnPiAmIHtcbiAgICBjaGVja2VkPzogYm9vbGVhbjtcbiAgICBkaXNhYmxlZD86IGJvb2xlYW47XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogSW5mb3RpcCBwcm9wcyB0byByZW5kZXIgdG8gdGhlIHJpZ2h0IG9mIHlvdXIgcmFkaW8gbGFiZWxcbiAgICAgKi9cbiAgICBpbmZvdGlwPzogSW5mb1RpcFByb3BzO1xuICAgIC8qKlxuICAgICAqIEEgbGFiZWwgZm9yIHlvdXIgUmFkaW8gaW5wdXQgLSBzaG91bGQgbm90IGluY2x1ZGUgaW5mb3RpcHMgb3Igb3RoZXIgaW50ZXJhY3RpdmUgZWxlbWVudHNcbiAgICAgKi9cbiAgICBsYWJlbD86IFJlYWN0Tm9kZTtcbiAgICBvbkNoYW5nZT86IChldmVudDogUmVhY3QuQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHZvaWQ7XG4gICAgLyoqXG4gICAgICogU3BlY2lmaWVzIHRoZSB0YWIgb3JkZXIgb2YgdGhlIFJhZGlvIGlucHV0XG4gICAgICovXG4gICAgdGFiSW5kZXg/OiBudW1iZXI7XG4gICAgdmFsdWU/OiBzdHJpbmc7XG4gICAgcmVhZE9ubHk/OiBib29sZWFuO1xuICB9O1xuZXhwb3J0IGludGVyZmFjZSBSYWRpb0VsZW1lbnRQcm9wc1xuICBleHRlbmRzIFJhZGlvUHJvcHMsXG4gICAgU3R5bGVQcm9wczx0eXBlb2YgY29uZGl0aW9uYWxSYWRpb0lucHV0U3R5bGVzPiB7fVxuXG5jb25zdCBSYWRpb1dyYXBwZXIgPSBzdHlsZWQuZGl2KHJhZGlvV3JhcHBlcik7XG5jb25zdCBSYWRpb0xhYmVsID0gc3R5bGVkLmxhYmVsPFJhZGlvRWxlbWVudFByb3BzPihcbiAgcmFkaW9MYWJlbCxcbiAgY29uZGl0aW9uYWxSYWRpb0xhYmVsU3R5bGVzXG4pO1xuY29uc3QgUmFkaW9JbnB1dCA9IHN0eWxlZC5pbnB1dDxSYWRpb0VsZW1lbnRQcm9wcz4oXG4gIHNjcmVlblJlYWRlck9ubHksXG4gIHJhZGlvSW5wdXQsXG4gIGNvbmRpdGlvbmFsUmFkaW9JbnB1dFN0eWxlc1xuKTtcblxuY29uc3QgY29uZGl0aW9uYWxTdHlsZVN0YXRlID0gKGVycm9yPzogYm9vbGVhbiwgZGlzYWJsZWQ/OiBib29sZWFuKSA9PiB7XG4gIHJldHVybiBlcnJvciA/ICdlcnJvcicgOiBkaXNhYmxlZCA/ICdkaXNhYmxlZCcgOiB1bmRlZmluZWQ7XG59O1xuXG5leHBvcnQgY29uc3QgUmFkaW8gPSBmb3J3YXJkUmVmPEhUTUxJbnB1dEVsZW1lbnQsIFJhZGlvUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgY2hlY2tlZCxcbiAgICAgIGNsYXNzTmFtZSxcbiAgICAgIGRpc2FibGVkLFxuICAgICAgZXJyb3IsXG4gICAgICBodG1sRm9yLFxuICAgICAgaWQsXG4gICAgICBpbmZvdGlwLFxuICAgICAgbGFiZWwsXG4gICAgICBuYW1lLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICByZXF1aXJlZCxcbiAgICAgIHZhbHVlLFxuICAgICAgLi4ucmVzdFxuICAgIH0sXG4gICAgcmVmXG4gICkgPT4ge1xuICAgIGNvbnN0IGlucHV0SWQgPSBpZCA/IGAke2h0bWxGb3J9LSR7aWR9YCA6IGh0bWxGb3I7XG4gICAgY29uc3Qgc3R5bGVTdGF0ZSA9IGNvbmRpdGlvbmFsU3R5bGVTdGF0ZShlcnJvciwgZGlzYWJsZWQpO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxSYWRpb1dyYXBwZXIgY2xhc3NOYW1lPXtjbGFzc05hbWV9PlxuICAgICAgICA8UmFkaW9JbnB1dFxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIGlkPXtpbnB1dElkfVxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgcmVxdWlyZWQ9e3JlcXVpcmVkfVxuICAgICAgICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIHZhcmlhbnQ9e3N0eWxlU3RhdGV9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIHsuLi5yZXN0fVxuICAgICAgICAvPlxuICAgICAgICA8UmFkaW9MYWJlbCBkaXNhYmxlZD17ZGlzYWJsZWR9IGh0bWxGb3I9e2h0bWxGb3J9IHZhcmlhbnQ9e3N0eWxlU3RhdGV9PlxuICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgPC9SYWRpb0xhYmVsPlxuICAgICAgICB7aW5mb3RpcCAmJiAoXG4gICAgICAgICAgPEZsZXhCb3ggY2VudGVyIHBsPXs4fT5cbiAgICAgICAgICAgIDxJbmZvVGlwIHsuLi5pbmZvdGlwfSAvPlxuICAgICAgICAgIDwvRmxleEJveD5cbiAgICAgICAgKX1cbiAgICAgIDwvUmFkaW9XcmFwcGVyPlxuICAgICk7XG4gIH1cbik7XG4iXX0= */");
10
13
  const RadioLabel = /*#__PURE__*/_styled("label", {
11
14
  target: "etm5hqp1",
12
15
  label: "RadioLabel"
13
- })(radioLabel, conditionalRadioLabelStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9Gb3JtL2lucHV0cy9SYWRpby50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0RtQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvRm9ybS9pbnB1dHMvUmFkaW8udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2NyZWVuUmVhZGVyT25seSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgeyBTdHlsZVByb3BzIH0gZnJvbSAnQGNvZGVjYWRlbXkvdmFyaWFuY2UnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgSW5wdXRIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBGbGV4Qm94IH0gZnJvbSAnLi4vLi4vQm94JztcbmltcG9ydCB7IEluZm9UaXAgfSBmcm9tICcuLi8uLi9UaXAvSW5mb1RpcCc7XG5pbXBvcnQge1xuICBJbmZvVGlwU3ViQ29tcG9uZW50UHJvcHMsXG4gIHVzZUluZm90aXBQcm9wcyxcbn0gZnJvbSAnLi4vLi4vVGlwL0luZm9UaXAvdHlwZS11dGlscyc7XG5pbXBvcnQge1xuICBjb25kaXRpb25hbFJhZGlvSW5wdXRTdHlsZXMsXG4gIGNvbmRpdGlvbmFsUmFkaW9MYWJlbFN0eWxlcyxcbiAgSW5wdXRXcmFwcGVyLFxuICByYWRpb0lucHV0LFxuICByYWRpb0xhYmVsLFxufSBmcm9tICcuLi9zdHlsZXMnO1xuaW1wb3J0IHsgQmFzZUlucHV0UHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCB0eXBlIFJhZGlvUHJvcHMgPSBJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+ICZcbiAgT21pdDxCYXNlSW5wdXRQcm9wcywgJ2xhYmVsJz4gJiB7XG4gICAgY2hlY2tlZD86IGJvb2xlYW47XG4gICAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICAgIGlkPzogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIEluZm90aXAgcHJvcHMgdG8gcmVuZGVyIHRvIHRoZSByaWdodCBvZiB5b3VyIHJhZGlvIGxhYmVsLlxuICAgICAqIFRoZSBJbmZvVGlwIGJ1dHRvbiBpcyBhdXRvbWF0aWNhbGx5IGxhYmVsbGVkIGJ5IHRoZSByYWRpbyBsYWJlbC5cbiAgICAgKiBUbyBvdmVycmlkZSB0aGlzIGJlaGF2aW9yLCBwcm92aWRlIGBhcmlhTGFiZWxgIG9yIGBhcmlhTGFiZWxsZWRieWAuXG4gICAgICovXG4gICAgaW5mb3RpcD86IEluZm9UaXBTdWJDb21wb25lbnRQcm9wcztcbiAgICAvKipcbiAgICAgKiBBIGxhYmVsIGZvciB5b3VyIFJhZGlvIGlucHV0IC0gc2hvdWxkIG5vdCBpbmNsdWRlIGluZm90aXBzIG9yIG90aGVyIGludGVyYWN0aXZlIGVsZW1lbnRzXG4gICAgICovXG4gICAgbGFiZWw/OiBSZWFjdE5vZGU7XG4gICAgb25DaGFuZ2U/OiAoZXZlbnQ6IFJlYWN0LkNoYW5nZUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICAgIC8qKlxuICAgICAqIFNwZWNpZmllcyB0aGUgdGFiIG9yZGVyIG9mIHRoZSBSYWRpbyBpbnB1dFxuICAgICAqL1xuICAgIHRhYkluZGV4PzogbnVtYmVyO1xuICAgIHZhbHVlPzogc3RyaW5nO1xuICAgIHJlYWRPbmx5PzogYm9vbGVhbjtcbiAgfTtcbmV4cG9ydCBpbnRlcmZhY2UgUmFkaW9FbGVtZW50UHJvcHNcbiAgZXh0ZW5kcyBSYWRpb1Byb3BzLFxuICAgIFN0eWxlUHJvcHM8dHlwZW9mIGNvbmRpdGlvbmFsUmFkaW9JbnB1dFN0eWxlcz4ge31cblxuY29uc3QgUmFkaW9MYWJlbCA9IHN0eWxlZC5sYWJlbDxSYWRpb0VsZW1lbnRQcm9wcz4oXG4gIHJhZGlvTGFiZWwsXG4gIGNvbmRpdGlvbmFsUmFkaW9MYWJlbFN0eWxlc1xuKTtcbmNvbnN0IFJhZGlvSW5wdXQgPSBzdHlsZWQuaW5wdXQ8UmFkaW9FbGVtZW50UHJvcHM+KFxuICBzY3JlZW5SZWFkZXJPbmx5LFxuICByYWRpb0lucHV0LFxuICBjb25kaXRpb25hbFJhZGlvSW5wdXRTdHlsZXNcbik7XG5cbmNvbnN0IGNvbmRpdGlvbmFsU3R5bGVTdGF0ZSA9IChlcnJvcj86IGJvb2xlYW4sIGRpc2FibGVkPzogYm9vbGVhbikgPT4ge1xuICByZXR1cm4gZXJyb3IgPyAnZXJyb3InIDogZGlzYWJsZWQgPyAnZGlzYWJsZWQnIDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IFJhZGlvID0gZm9yd2FyZFJlZjxIVE1MSW5wdXRFbGVtZW50LCBSYWRpb1Byb3BzPihcbiAgKFxuICAgIHtcbiAgICAgIGNoZWNrZWQsXG4gICAgICBjbGFzc05hbWUsXG4gICAgICBkaXNhYmxlZCxcbiAgICAgIGVycm9yLFxuICAgICAgaHRtbEZvcixcbiAgICAgIGlkLFxuICAgICAgaW5mb3RpcCxcbiAgICAgIGxhYmVsLFxuICAgICAgbmFtZSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgICAgcmVxdWlyZWQsXG4gICAgICB2YWx1ZSxcbiAgICAgIC4uLnJlc3RcbiAgICB9LFxuICAgIHJlZlxuICApID0+IHtcbiAgICBjb25zdCBpbnB1dElkID0gaWQgPyBgJHtodG1sRm9yfS0ke2lkfWAgOiBodG1sRm9yO1xuICAgIGNvbnN0IHN0eWxlU3RhdGUgPSBjb25kaXRpb25hbFN0eWxlU3RhdGUoZXJyb3IsIGRpc2FibGVkKTtcbiAgICBjb25zdCB7IGluZm90aXBQcm9wcywgbGFiZWxJZCwgc2hvdWxkTGFiZWxJbmZvVGlwIH0gPVxuICAgICAgdXNlSW5mb3RpcFByb3BzKGluZm90aXApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxJbnB1dFdyYXBwZXIgY2xhc3NOYW1lPXtjbGFzc05hbWV9PlxuICAgICAgICA8UmFkaW9JbnB1dFxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIGlkPXtpbnB1dElkfVxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgcmVxdWlyZWQ9e3JlcXVpcmVkfVxuICAgICAgICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIHZhcmlhbnQ9e3N0eWxlU3RhdGV9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIHsuLi5yZXN0fVxuICAgICAgICAvPlxuICAgICAgICA8UmFkaW9MYWJlbFxuICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICBodG1sRm9yPXtodG1sRm9yfVxuICAgICAgICAgIGlkPXtpbmZvdGlwICYmIHNob3VsZExhYmVsSW5mb1RpcCA/IGxhYmVsSWQgOiB1bmRlZmluZWR9XG4gICAgICAgICAgdmFyaWFudD17c3R5bGVTdGF0ZX1cbiAgICAgICAgPlxuICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgPC9SYWRpb0xhYmVsPlxuICAgICAgICB7aW5mb3RpcFByb3BzICYmIChcbiAgICAgICAgICA8RmxleEJveCBjZW50ZXIgcGw9ezh9PlxuICAgICAgICAgICAgPEluZm9UaXAgey4uLmluZm90aXBQcm9wc30gLz5cbiAgICAgICAgICA8L0ZsZXhCb3g+XG4gICAgICAgICl9XG4gICAgICA8L0lucHV0V3JhcHBlcj5cbiAgICApO1xuICB9XG4pO1xuIl19 */");
16
+ })(radioLabel, conditionalRadioLabelStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9Gb3JtL2lucHV0cy9SYWRpby50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkNtQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvRm9ybS9pbnB1dHMvUmFkaW8udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2NyZWVuUmVhZGVyT25seSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgeyBTdHlsZVByb3BzIH0gZnJvbSAnQGNvZGVjYWRlbXkvdmFyaWFuY2UnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgSW5wdXRIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBGbGV4Qm94IH0gZnJvbSAnLi4vLi4vQm94JztcbmltcG9ydCB7IEluZm9UaXAsIEluZm9UaXBQcm9wcyB9IGZyb20gJy4uLy4uL1RpcC9JbmZvVGlwJztcbmltcG9ydCB7XG4gIGNvbmRpdGlvbmFsUmFkaW9JbnB1dFN0eWxlcyxcbiAgY29uZGl0aW9uYWxSYWRpb0xhYmVsU3R5bGVzLFxuICByYWRpb0lucHV0LFxuICByYWRpb0xhYmVsLFxuICByYWRpb1dyYXBwZXIsXG59IGZyb20gJy4uL3N0eWxlcyc7XG5pbXBvcnQgeyBCYXNlSW5wdXRQcm9wcyB9IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgUmFkaW9Qcm9wcyA9IElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4gJlxuICBPbWl0PEJhc2VJbnB1dFByb3BzLCAnbGFiZWwnPiAmIHtcbiAgICBjaGVja2VkPzogYm9vbGVhbjtcbiAgICBkaXNhYmxlZD86IGJvb2xlYW47XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogSW5mb3RpcCBwcm9wcyB0byByZW5kZXIgdG8gdGhlIHJpZ2h0IG9mIHlvdXIgcmFkaW8gbGFiZWxcbiAgICAgKi9cbiAgICBpbmZvdGlwPzogSW5mb1RpcFByb3BzO1xuICAgIC8qKlxuICAgICAqIEEgbGFiZWwgZm9yIHlvdXIgUmFkaW8gaW5wdXQgLSBzaG91bGQgbm90IGluY2x1ZGUgaW5mb3RpcHMgb3Igb3RoZXIgaW50ZXJhY3RpdmUgZWxlbWVudHNcbiAgICAgKi9cbiAgICBsYWJlbD86IFJlYWN0Tm9kZTtcbiAgICBvbkNoYW5nZT86IChldmVudDogUmVhY3QuQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHZvaWQ7XG4gICAgLyoqXG4gICAgICogU3BlY2lmaWVzIHRoZSB0YWIgb3JkZXIgb2YgdGhlIFJhZGlvIGlucHV0XG4gICAgICovXG4gICAgdGFiSW5kZXg/OiBudW1iZXI7XG4gICAgdmFsdWU/OiBzdHJpbmc7XG4gICAgcmVhZE9ubHk/OiBib29sZWFuO1xuICB9O1xuZXhwb3J0IGludGVyZmFjZSBSYWRpb0VsZW1lbnRQcm9wc1xuICBleHRlbmRzIFJhZGlvUHJvcHMsXG4gICAgU3R5bGVQcm9wczx0eXBlb2YgY29uZGl0aW9uYWxSYWRpb0lucHV0U3R5bGVzPiB7fVxuXG5jb25zdCBSYWRpb1dyYXBwZXIgPSBzdHlsZWQuZGl2KHJhZGlvV3JhcHBlcik7XG5jb25zdCBSYWRpb0xhYmVsID0gc3R5bGVkLmxhYmVsPFJhZGlvRWxlbWVudFByb3BzPihcbiAgcmFkaW9MYWJlbCxcbiAgY29uZGl0aW9uYWxSYWRpb0xhYmVsU3R5bGVzXG4pO1xuY29uc3QgUmFkaW9JbnB1dCA9IHN0eWxlZC5pbnB1dDxSYWRpb0VsZW1lbnRQcm9wcz4oXG4gIHNjcmVlblJlYWRlck9ubHksXG4gIHJhZGlvSW5wdXQsXG4gIGNvbmRpdGlvbmFsUmFkaW9JbnB1dFN0eWxlc1xuKTtcblxuY29uc3QgY29uZGl0aW9uYWxTdHlsZVN0YXRlID0gKGVycm9yPzogYm9vbGVhbiwgZGlzYWJsZWQ/OiBib29sZWFuKSA9PiB7XG4gIHJldHVybiBlcnJvciA/ICdlcnJvcicgOiBkaXNhYmxlZCA/ICdkaXNhYmxlZCcgOiB1bmRlZmluZWQ7XG59O1xuXG5leHBvcnQgY29uc3QgUmFkaW8gPSBmb3J3YXJkUmVmPEhUTUxJbnB1dEVsZW1lbnQsIFJhZGlvUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgY2hlY2tlZCxcbiAgICAgIGNsYXNzTmFtZSxcbiAgICAgIGRpc2FibGVkLFxuICAgICAgZXJyb3IsXG4gICAgICBodG1sRm9yLFxuICAgICAgaWQsXG4gICAgICBpbmZvdGlwLFxuICAgICAgbGFiZWwsXG4gICAgICBuYW1lLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICByZXF1aXJlZCxcbiAgICAgIHZhbHVlLFxuICAgICAgLi4ucmVzdFxuICAgIH0sXG4gICAgcmVmXG4gICkgPT4ge1xuICAgIGNvbnN0IGlucHV0SWQgPSBpZCA/IGAke2h0bWxGb3J9LSR7aWR9YCA6IGh0bWxGb3I7XG4gICAgY29uc3Qgc3R5bGVTdGF0ZSA9IGNvbmRpdGlvbmFsU3R5bGVTdGF0ZShlcnJvciwgZGlzYWJsZWQpO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxSYWRpb1dyYXBwZXIgY2xhc3NOYW1lPXtjbGFzc05hbWV9PlxuICAgICAgICA8UmFkaW9JbnB1dFxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIGlkPXtpbnB1dElkfVxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgcmVxdWlyZWQ9e3JlcXVpcmVkfVxuICAgICAgICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIHZhcmlhbnQ9e3N0eWxlU3RhdGV9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIHsuLi5yZXN0fVxuICAgICAgICAvPlxuICAgICAgICA8UmFkaW9MYWJlbCBkaXNhYmxlZD17ZGlzYWJsZWR9IGh0bWxGb3I9e2h0bWxGb3J9IHZhcmlhbnQ9e3N0eWxlU3RhdGV9PlxuICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgPC9SYWRpb0xhYmVsPlxuICAgICAgICB7aW5mb3RpcCAmJiAoXG4gICAgICAgICAgPEZsZXhCb3ggY2VudGVyIHBsPXs4fT5cbiAgICAgICAgICAgIDxJbmZvVGlwIHsuLi5pbmZvdGlwfSAvPlxuICAgICAgICAgIDwvRmxleEJveD5cbiAgICAgICAgKX1cbiAgICAgIDwvUmFkaW9XcmFwcGVyPlxuICAgICk7XG4gIH1cbik7XG4iXX0= */");
14
17
  const RadioInput = /*#__PURE__*/_styled("input", {
15
18
  target: "etm5hqp0",
16
19
  label: "RadioInput"
17
- })(screenReaderOnly, radioInput, conditionalRadioInputStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9Gb3JtL2lucHV0cy9SYWRpby50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0RtQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvRm9ybS9pbnB1dHMvUmFkaW8udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2NyZWVuUmVhZGVyT25seSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgeyBTdHlsZVByb3BzIH0gZnJvbSAnQGNvZGVjYWRlbXkvdmFyaWFuY2UnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgSW5wdXRIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBGbGV4Qm94IH0gZnJvbSAnLi4vLi4vQm94JztcbmltcG9ydCB7IEluZm9UaXAgfSBmcm9tICcuLi8uLi9UaXAvSW5mb1RpcCc7XG5pbXBvcnQge1xuICBJbmZvVGlwU3ViQ29tcG9uZW50UHJvcHMsXG4gIHVzZUluZm90aXBQcm9wcyxcbn0gZnJvbSAnLi4vLi4vVGlwL0luZm9UaXAvdHlwZS11dGlscyc7XG5pbXBvcnQge1xuICBjb25kaXRpb25hbFJhZGlvSW5wdXRTdHlsZXMsXG4gIGNvbmRpdGlvbmFsUmFkaW9MYWJlbFN0eWxlcyxcbiAgSW5wdXRXcmFwcGVyLFxuICByYWRpb0lucHV0LFxuICByYWRpb0xhYmVsLFxufSBmcm9tICcuLi9zdHlsZXMnO1xuaW1wb3J0IHsgQmFzZUlucHV0UHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCB0eXBlIFJhZGlvUHJvcHMgPSBJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+ICZcbiAgT21pdDxCYXNlSW5wdXRQcm9wcywgJ2xhYmVsJz4gJiB7XG4gICAgY2hlY2tlZD86IGJvb2xlYW47XG4gICAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICAgIGlkPzogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIEluZm90aXAgcHJvcHMgdG8gcmVuZGVyIHRvIHRoZSByaWdodCBvZiB5b3VyIHJhZGlvIGxhYmVsLlxuICAgICAqIFRoZSBJbmZvVGlwIGJ1dHRvbiBpcyBhdXRvbWF0aWNhbGx5IGxhYmVsbGVkIGJ5IHRoZSByYWRpbyBsYWJlbC5cbiAgICAgKiBUbyBvdmVycmlkZSB0aGlzIGJlaGF2aW9yLCBwcm92aWRlIGBhcmlhTGFiZWxgIG9yIGBhcmlhTGFiZWxsZWRieWAuXG4gICAgICovXG4gICAgaW5mb3RpcD86IEluZm9UaXBTdWJDb21wb25lbnRQcm9wcztcbiAgICAvKipcbiAgICAgKiBBIGxhYmVsIGZvciB5b3VyIFJhZGlvIGlucHV0IC0gc2hvdWxkIG5vdCBpbmNsdWRlIGluZm90aXBzIG9yIG90aGVyIGludGVyYWN0aXZlIGVsZW1lbnRzXG4gICAgICovXG4gICAgbGFiZWw/OiBSZWFjdE5vZGU7XG4gICAgb25DaGFuZ2U/OiAoZXZlbnQ6IFJlYWN0LkNoYW5nZUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICAgIC8qKlxuICAgICAqIFNwZWNpZmllcyB0aGUgdGFiIG9yZGVyIG9mIHRoZSBSYWRpbyBpbnB1dFxuICAgICAqL1xuICAgIHRhYkluZGV4PzogbnVtYmVyO1xuICAgIHZhbHVlPzogc3RyaW5nO1xuICAgIHJlYWRPbmx5PzogYm9vbGVhbjtcbiAgfTtcbmV4cG9ydCBpbnRlcmZhY2UgUmFkaW9FbGVtZW50UHJvcHNcbiAgZXh0ZW5kcyBSYWRpb1Byb3BzLFxuICAgIFN0eWxlUHJvcHM8dHlwZW9mIGNvbmRpdGlvbmFsUmFkaW9JbnB1dFN0eWxlcz4ge31cblxuY29uc3QgUmFkaW9MYWJlbCA9IHN0eWxlZC5sYWJlbDxSYWRpb0VsZW1lbnRQcm9wcz4oXG4gIHJhZGlvTGFiZWwsXG4gIGNvbmRpdGlvbmFsUmFkaW9MYWJlbFN0eWxlc1xuKTtcbmNvbnN0IFJhZGlvSW5wdXQgPSBzdHlsZWQuaW5wdXQ8UmFkaW9FbGVtZW50UHJvcHM+KFxuICBzY3JlZW5SZWFkZXJPbmx5LFxuICByYWRpb0lucHV0LFxuICBjb25kaXRpb25hbFJhZGlvSW5wdXRTdHlsZXNcbik7XG5cbmNvbnN0IGNvbmRpdGlvbmFsU3R5bGVTdGF0ZSA9IChlcnJvcj86IGJvb2xlYW4sIGRpc2FibGVkPzogYm9vbGVhbikgPT4ge1xuICByZXR1cm4gZXJyb3IgPyAnZXJyb3InIDogZGlzYWJsZWQgPyAnZGlzYWJsZWQnIDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IFJhZGlvID0gZm9yd2FyZFJlZjxIVE1MSW5wdXRFbGVtZW50LCBSYWRpb1Byb3BzPihcbiAgKFxuICAgIHtcbiAgICAgIGNoZWNrZWQsXG4gICAgICBjbGFzc05hbWUsXG4gICAgICBkaXNhYmxlZCxcbiAgICAgIGVycm9yLFxuICAgICAgaHRtbEZvcixcbiAgICAgIGlkLFxuICAgICAgaW5mb3RpcCxcbiAgICAgIGxhYmVsLFxuICAgICAgbmFtZSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgICAgcmVxdWlyZWQsXG4gICAgICB2YWx1ZSxcbiAgICAgIC4uLnJlc3RcbiAgICB9LFxuICAgIHJlZlxuICApID0+IHtcbiAgICBjb25zdCBpbnB1dElkID0gaWQgPyBgJHtodG1sRm9yfS0ke2lkfWAgOiBodG1sRm9yO1xuICAgIGNvbnN0IHN0eWxlU3RhdGUgPSBjb25kaXRpb25hbFN0eWxlU3RhdGUoZXJyb3IsIGRpc2FibGVkKTtcbiAgICBjb25zdCB7IGluZm90aXBQcm9wcywgbGFiZWxJZCwgc2hvdWxkTGFiZWxJbmZvVGlwIH0gPVxuICAgICAgdXNlSW5mb3RpcFByb3BzKGluZm90aXApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxJbnB1dFdyYXBwZXIgY2xhc3NOYW1lPXtjbGFzc05hbWV9PlxuICAgICAgICA8UmFkaW9JbnB1dFxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIGlkPXtpbnB1dElkfVxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgcmVxdWlyZWQ9e3JlcXVpcmVkfVxuICAgICAgICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIHZhcmlhbnQ9e3N0eWxlU3RhdGV9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIHsuLi5yZXN0fVxuICAgICAgICAvPlxuICAgICAgICA8UmFkaW9MYWJlbFxuICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICBodG1sRm9yPXtodG1sRm9yfVxuICAgICAgICAgIGlkPXtpbmZvdGlwICYmIHNob3VsZExhYmVsSW5mb1RpcCA/IGxhYmVsSWQgOiB1bmRlZmluZWR9XG4gICAgICAgICAgdmFyaWFudD17c3R5bGVTdGF0ZX1cbiAgICAgICAgPlxuICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgPC9SYWRpb0xhYmVsPlxuICAgICAgICB7aW5mb3RpcFByb3BzICYmIChcbiAgICAgICAgICA8RmxleEJveCBjZW50ZXIgcGw9ezh9PlxuICAgICAgICAgICAgPEluZm9UaXAgey4uLmluZm90aXBQcm9wc30gLz5cbiAgICAgICAgICA8L0ZsZXhCb3g+XG4gICAgICAgICl9XG4gICAgICA8L0lucHV0V3JhcHBlcj5cbiAgICApO1xuICB9XG4pO1xuIl19 */");
20
+ })(screenReaderOnly, radioInput, conditionalRadioInputStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9Gb3JtL2lucHV0cy9SYWRpby50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0NtQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvRm9ybS9pbnB1dHMvUmFkaW8udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2NyZWVuUmVhZGVyT25seSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgeyBTdHlsZVByb3BzIH0gZnJvbSAnQGNvZGVjYWRlbXkvdmFyaWFuY2UnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgSW5wdXRIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBGbGV4Qm94IH0gZnJvbSAnLi4vLi4vQm94JztcbmltcG9ydCB7IEluZm9UaXAsIEluZm9UaXBQcm9wcyB9IGZyb20gJy4uLy4uL1RpcC9JbmZvVGlwJztcbmltcG9ydCB7XG4gIGNvbmRpdGlvbmFsUmFkaW9JbnB1dFN0eWxlcyxcbiAgY29uZGl0aW9uYWxSYWRpb0xhYmVsU3R5bGVzLFxuICByYWRpb0lucHV0LFxuICByYWRpb0xhYmVsLFxuICByYWRpb1dyYXBwZXIsXG59IGZyb20gJy4uL3N0eWxlcyc7XG5pbXBvcnQgeyBCYXNlSW5wdXRQcm9wcyB9IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgUmFkaW9Qcm9wcyA9IElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4gJlxuICBPbWl0PEJhc2VJbnB1dFByb3BzLCAnbGFiZWwnPiAmIHtcbiAgICBjaGVja2VkPzogYm9vbGVhbjtcbiAgICBkaXNhYmxlZD86IGJvb2xlYW47XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogSW5mb3RpcCBwcm9wcyB0byByZW5kZXIgdG8gdGhlIHJpZ2h0IG9mIHlvdXIgcmFkaW8gbGFiZWxcbiAgICAgKi9cbiAgICBpbmZvdGlwPzogSW5mb1RpcFByb3BzO1xuICAgIC8qKlxuICAgICAqIEEgbGFiZWwgZm9yIHlvdXIgUmFkaW8gaW5wdXQgLSBzaG91bGQgbm90IGluY2x1ZGUgaW5mb3RpcHMgb3Igb3RoZXIgaW50ZXJhY3RpdmUgZWxlbWVudHNcbiAgICAgKi9cbiAgICBsYWJlbD86IFJlYWN0Tm9kZTtcbiAgICBvbkNoYW5nZT86IChldmVudDogUmVhY3QuQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHZvaWQ7XG4gICAgLyoqXG4gICAgICogU3BlY2lmaWVzIHRoZSB0YWIgb3JkZXIgb2YgdGhlIFJhZGlvIGlucHV0XG4gICAgICovXG4gICAgdGFiSW5kZXg/OiBudW1iZXI7XG4gICAgdmFsdWU/OiBzdHJpbmc7XG4gICAgcmVhZE9ubHk/OiBib29sZWFuO1xuICB9O1xuZXhwb3J0IGludGVyZmFjZSBSYWRpb0VsZW1lbnRQcm9wc1xuICBleHRlbmRzIFJhZGlvUHJvcHMsXG4gICAgU3R5bGVQcm9wczx0eXBlb2YgY29uZGl0aW9uYWxSYWRpb0lucHV0U3R5bGVzPiB7fVxuXG5jb25zdCBSYWRpb1dyYXBwZXIgPSBzdHlsZWQuZGl2KHJhZGlvV3JhcHBlcik7XG5jb25zdCBSYWRpb0xhYmVsID0gc3R5bGVkLmxhYmVsPFJhZGlvRWxlbWVudFByb3BzPihcbiAgcmFkaW9MYWJlbCxcbiAgY29uZGl0aW9uYWxSYWRpb0xhYmVsU3R5bGVzXG4pO1xuY29uc3QgUmFkaW9JbnB1dCA9IHN0eWxlZC5pbnB1dDxSYWRpb0VsZW1lbnRQcm9wcz4oXG4gIHNjcmVlblJlYWRlck9ubHksXG4gIHJhZGlvSW5wdXQsXG4gIGNvbmRpdGlvbmFsUmFkaW9JbnB1dFN0eWxlc1xuKTtcblxuY29uc3QgY29uZGl0aW9uYWxTdHlsZVN0YXRlID0gKGVycm9yPzogYm9vbGVhbiwgZGlzYWJsZWQ/OiBib29sZWFuKSA9PiB7XG4gIHJldHVybiBlcnJvciA/ICdlcnJvcicgOiBkaXNhYmxlZCA/ICdkaXNhYmxlZCcgOiB1bmRlZmluZWQ7XG59O1xuXG5leHBvcnQgY29uc3QgUmFkaW8gPSBmb3J3YXJkUmVmPEhUTUxJbnB1dEVsZW1lbnQsIFJhZGlvUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgY2hlY2tlZCxcbiAgICAgIGNsYXNzTmFtZSxcbiAgICAgIGRpc2FibGVkLFxuICAgICAgZXJyb3IsXG4gICAgICBodG1sRm9yLFxuICAgICAgaWQsXG4gICAgICBpbmZvdGlwLFxuICAgICAgbGFiZWwsXG4gICAgICBuYW1lLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICByZXF1aXJlZCxcbiAgICAgIHZhbHVlLFxuICAgICAgLi4ucmVzdFxuICAgIH0sXG4gICAgcmVmXG4gICkgPT4ge1xuICAgIGNvbnN0IGlucHV0SWQgPSBpZCA/IGAke2h0bWxGb3J9LSR7aWR9YCA6IGh0bWxGb3I7XG4gICAgY29uc3Qgc3R5bGVTdGF0ZSA9IGNvbmRpdGlvbmFsU3R5bGVTdGF0ZShlcnJvciwgZGlzYWJsZWQpO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxSYWRpb1dyYXBwZXIgY2xhc3NOYW1lPXtjbGFzc05hbWV9PlxuICAgICAgICA8UmFkaW9JbnB1dFxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIGlkPXtpbnB1dElkfVxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgcmVxdWlyZWQ9e3JlcXVpcmVkfVxuICAgICAgICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIHZhcmlhbnQ9e3N0eWxlU3RhdGV9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIHsuLi5yZXN0fVxuICAgICAgICAvPlxuICAgICAgICA8UmFkaW9MYWJlbCBkaXNhYmxlZD17ZGlzYWJsZWR9IGh0bWxGb3I9e2h0bWxGb3J9IHZhcmlhbnQ9e3N0eWxlU3RhdGV9PlxuICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgPC9SYWRpb0xhYmVsPlxuICAgICAgICB7aW5mb3RpcCAmJiAoXG4gICAgICAgICAgPEZsZXhCb3ggY2VudGVyIHBsPXs4fT5cbiAgICAgICAgICAgIDxJbmZvVGlwIHsuLi5pbmZvdGlwfSAvPlxuICAgICAgICAgIDwvRmxleEJveD5cbiAgICAgICAgKX1cbiAgICAgIDwvUmFkaW9XcmFwcGVyPlxuICAgICk7XG4gIH1cbik7XG4iXX0= */");
18
21
  const conditionalStyleState = (error, disabled) => {
19
22
  return error ? 'error' : disabled ? 'disabled' : undefined;
20
23
  };
@@ -35,12 +38,7 @@ export const Radio = /*#__PURE__*/forwardRef(({
35
38
  }, ref) => {
36
39
  const inputId = id ? `${htmlFor}-${id}` : htmlFor;
37
40
  const styleState = conditionalStyleState(error, disabled);
38
- const {
39
- infotipProps,
40
- labelId,
41
- shouldLabelInfoTip
42
- } = useInfotipProps(infotip);
43
- return /*#__PURE__*/_jsxs(InputWrapper, {
41
+ return /*#__PURE__*/_jsxs(RadioWrapper, {
44
42
  className: className,
45
43
  children: [/*#__PURE__*/_jsx(RadioInput, {
46
44
  checked: checked,
@@ -57,14 +55,13 @@ export const Radio = /*#__PURE__*/forwardRef(({
57
55
  }), /*#__PURE__*/_jsx(RadioLabel, {
58
56
  disabled: disabled,
59
57
  htmlFor: htmlFor,
60
- id: infotip && shouldLabelInfoTip ? labelId : undefined,
61
58
  variant: styleState,
62
59
  children: label
63
- }), infotipProps && /*#__PURE__*/_jsx(FlexBox, {
60
+ }), infotip && /*#__PURE__*/_jsx(FlexBox, {
64
61
  center: true,
65
62
  pl: 8,
66
63
  children: /*#__PURE__*/_jsx(InfoTip, {
67
- ...infotipProps
64
+ ...infotip
68
65
  })
69
66
  })]
70
67
  });
@@ -1,3 +1,6 @@
1
+ export declare const radioWrapper: (props: {
2
+ theme?: import("@emotion/react").Theme | undefined;
3
+ }) => import("@codecademy/variance").CSSObject;
1
4
  export declare const radioLabel: (props: {
2
5
  theme?: import("@emotion/react").Theme | undefined;
3
6
  }) => import("@codecademy/variance").CSSObject;