@codecademy/gamut 67.6.4 → 67.6.5-alpha.9b8a7f.0
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.
- package/dist/ConnectedForm/ConnectedFormGroup.d.ts +8 -2
- package/dist/ConnectedForm/ConnectedFormGroup.js +1 -1
- package/dist/ConnectedForm/ConnectedInputs/ConnectedCheckbox.js +2 -0
- package/dist/Form/__tests__/testUtils.d.ts +22 -0
- package/dist/Form/elements/FormGroupLabel.d.ts +2 -2
- package/dist/Form/elements/FormGroupLabel.js +10 -3
- package/dist/Form/inputs/Checkbox.d.ts +7 -0
- package/dist/Form/inputs/Checkbox.js +27 -11
- package/dist/Form/inputs/Radio.d.ts +9 -5
- package/dist/Form/inputs/Radio.js +13 -10
- package/dist/Form/styles/Radio-styles.d.ts +0 -3
- package/dist/Form/styles/Radio-styles.js +0 -6
- package/dist/Form/styles/shared-system-props.d.ts +7 -0
- package/dist/Form/styles/shared-system-props.js +11 -0
- package/dist/GridForm/GridFormInputGroup/GridFormRadioGroupInput/index.js +2 -0
- package/dist/GridForm/GridFormInputGroup/__fixtures__/renderers.d.ts +4 -0
- package/dist/GridForm/types.d.ts +7 -2
- package/dist/Tip/InfoTip/InfoTipButton.js +5 -2
- package/dist/Tip/InfoTip/index.d.ts +27 -2
- package/dist/Tip/InfoTip/index.js +50 -67
- package/dist/Tip/InfoTip/type-utils.d.ts +35 -0
- package/dist/Tip/InfoTip/type-utils.js +72 -0
- package/dist/Tip/__tests__/helpers.d.ts +5 -26
- package/dist/Tip/shared/FloatingTip.js +3 -3
- package/dist/Tip/shared/InlineTip.js +4 -1
- package/dist/Tip/shared/types.d.ts +1 -1
- package/dist/Tip/shared/utils.d.ts +19 -0
- package/dist/Tip/shared/utils.js +104 -0
- package/package.json +2 -2
- package/dist/Tip/InfoTip/elements.d.ts +0 -12
- package/dist/Tip/InfoTip/elements.js +0 -9
|
@@ -3,16 +3,19 @@ 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 {
|
|
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';
|
|
7
10
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
8
11
|
const CheckboxLabel = /*#__PURE__*/_styled("label", {
|
|
9
12
|
target: "e1ni3uy16",
|
|
10
13
|
label: "CheckboxLabel"
|
|
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"]} */");
|
|
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"]} */");
|
|
12
15
|
const CheckboxElement = /*#__PURE__*/_styled('div', _extends({}, {
|
|
13
16
|
target: "e1ni3uy15",
|
|
14
17
|
label: "CheckboxElement"
|
|
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"]} */");
|
|
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"]} */");
|
|
16
19
|
const CheckboxVector = /*#__PURE__*/_styled("svg", {
|
|
17
20
|
target: "e1ni3uy14",
|
|
18
21
|
label: "CheckboxVector"
|
|
@@ -22,7 +25,7 @@ const CheckboxVector = /*#__PURE__*/_styled("svg", {
|
|
|
22
25
|
} : {
|
|
23
26
|
name: "13idn5w",
|
|
24
27
|
styles: "position:absolute;top:-1px;left:-1px",
|
|
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"]} */",
|
|
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"]} */",
|
|
26
29
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
27
30
|
});
|
|
28
31
|
const Checkmark = /*#__PURE__*/_styled("polyline", {
|
|
@@ -30,21 +33,21 @@ const Checkmark = /*#__PURE__*/_styled("polyline", {
|
|
|
30
33
|
label: "Checkmark"
|
|
31
34
|
})(polyline, " fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:18px;stroke-dashoffset:", ({
|
|
32
35
|
checked
|
|
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"]} */"));
|
|
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"]} */"));
|
|
34
37
|
const Line = /*#__PURE__*/_styled("line", {
|
|
35
38
|
target: "e1ni3uy12",
|
|
36
39
|
label: "Line"
|
|
37
40
|
})(polyline, " fill:none;stroke:currentColor;stroke-width:2;stroke-dasharray:18px;stroke-dashoffset:", ({
|
|
38
41
|
indeterminate
|
|
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"]} */"));
|
|
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"]} */"));
|
|
40
43
|
const Input = /*#__PURE__*/_styled("input", {
|
|
41
44
|
target: "e1ni3uy11",
|
|
42
45
|
label: "Input"
|
|
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"]} */"));
|
|
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"]} */"));
|
|
44
47
|
const CheckboxText = /*#__PURE__*/_styled("span", {
|
|
45
48
|
target: "e1ni3uy10",
|
|
46
49
|
label: "CheckboxText"
|
|
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"]} */");
|
|
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"]} */");
|
|
48
51
|
export const Checkbox = /*#__PURE__*/forwardRef(({
|
|
49
52
|
'aria-label': ariaLabel,
|
|
50
53
|
checked,
|
|
@@ -54,6 +57,7 @@ export const Checkbox = /*#__PURE__*/forwardRef(({
|
|
|
54
57
|
dontAriaHideLabel,
|
|
55
58
|
htmlFor,
|
|
56
59
|
id,
|
|
60
|
+
infotip,
|
|
57
61
|
label,
|
|
58
62
|
multiline,
|
|
59
63
|
spacing,
|
|
@@ -61,6 +65,11 @@ export const Checkbox = /*#__PURE__*/forwardRef(({
|
|
|
61
65
|
...rest
|
|
62
66
|
}, ref) => {
|
|
63
67
|
const intRef = useRef(null);
|
|
68
|
+
const {
|
|
69
|
+
infotipProps,
|
|
70
|
+
labelId,
|
|
71
|
+
shouldLabelInfoTip
|
|
72
|
+
} = useInfotipProps(infotip);
|
|
64
73
|
function syncedRefs(element) {
|
|
65
74
|
intRef.current = element;
|
|
66
75
|
if (ref) {
|
|
@@ -77,14 +86,15 @@ export const Checkbox = /*#__PURE__*/forwardRef(({
|
|
|
77
86
|
}
|
|
78
87
|
}, [checked, indeterminate]);
|
|
79
88
|
const active = checked || indeterminate;
|
|
80
|
-
|
|
89
|
+
const textId = shouldLabelInfoTip ? labelId : `text-${id || htmlFor}`;
|
|
90
|
+
return /*#__PURE__*/_jsxs(InputWrapper, {
|
|
81
91
|
className: className,
|
|
82
92
|
children: [/*#__PURE__*/_jsx(Input, {
|
|
83
93
|
"aria-label": ariaLabel === undefined ? typeof label === 'string' ? label : 'checkbox' : ariaLabel,
|
|
84
94
|
checked: checked,
|
|
85
95
|
disabled: disabled,
|
|
86
96
|
id: id || htmlFor,
|
|
87
|
-
"labelled-by":
|
|
97
|
+
"labelled-by": textId,
|
|
88
98
|
type: "checkbox",
|
|
89
99
|
value: `${value}`,
|
|
90
100
|
...rest,
|
|
@@ -121,10 +131,16 @@ export const Checkbox = /*#__PURE__*/forwardRef(({
|
|
|
121
131
|
}), /*#__PURE__*/_jsx(CheckboxText, {
|
|
122
132
|
"aria-hidden": dontAriaHideLabel ? 'false' : 'true',
|
|
123
133
|
disabled: disabled,
|
|
124
|
-
id:
|
|
134
|
+
id: textId,
|
|
125
135
|
multiline: multiline,
|
|
126
136
|
children: label
|
|
127
137
|
})]
|
|
138
|
+
}), infotipProps && /*#__PURE__*/_jsx(FlexBox, {
|
|
139
|
+
center: true,
|
|
140
|
+
pl: 8,
|
|
141
|
+
children: /*#__PURE__*/_jsx(InfoTip, {
|
|
142
|
+
...infotipProps
|
|
143
|
+
})
|
|
128
144
|
})]
|
|
129
145
|
});
|
|
130
146
|
});
|
|
@@ -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 {
|
|
4
|
+
import { InfoTipSubComponentProps } from '../../Tip/InfoTip/type-utils';
|
|
5
5
|
import { conditionalRadioInputStyles } from '../styles';
|
|
6
6
|
import { BaseInputProps } from '../types';
|
|
7
7
|
export type RadioProps = InputHTMLAttributes<HTMLInputElement> & Omit<BaseInputProps, 'label'> & {
|
|
@@ -9,9 +9,11 @@ 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
|
|
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`.
|
|
13
15
|
*/
|
|
14
|
-
infotip?:
|
|
16
|
+
infotip?: InfoTipSubComponentProps;
|
|
15
17
|
/**
|
|
16
18
|
* A label for your Radio input - should not include infotips or other interactive elements
|
|
17
19
|
*/
|
|
@@ -31,9 +33,11 @@ export declare const Radio: React.ForwardRefExoticComponent<InputHTMLAttributes<
|
|
|
31
33
|
disabled?: boolean | undefined;
|
|
32
34
|
id?: string | undefined;
|
|
33
35
|
/**
|
|
34
|
-
* Infotip props to render to the right of your radio label
|
|
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`.
|
|
35
39
|
*/
|
|
36
|
-
infotip?:
|
|
40
|
+
infotip?: InfoTipSubComponentProps | undefined;
|
|
37
41
|
/**
|
|
38
42
|
* A label for your Radio input - should not include infotips or other interactive elements
|
|
39
43
|
*/
|
|
@@ -4,20 +4,17 @@ 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 {
|
|
7
|
+
import { useInfotipProps } from '../../Tip/InfoTip/type-utils';
|
|
8
|
+
import { conditionalRadioInputStyles, conditionalRadioLabelStyles, InputWrapper, radioInput, radioLabel } from '../styles';
|
|
8
9
|
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= */");
|
|
13
10
|
const RadioLabel = /*#__PURE__*/_styled("label", {
|
|
14
11
|
target: "etm5hqp1",
|
|
15
12
|
label: "RadioLabel"
|
|
16
|
-
})(radioLabel, conditionalRadioLabelStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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 */");
|
|
17
14
|
const RadioInput = /*#__PURE__*/_styled("input", {
|
|
18
15
|
target: "etm5hqp0",
|
|
19
16
|
label: "RadioInput"
|
|
20
|
-
})(screenReaderOnly, radioInput, conditionalRadioInputStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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 */");
|
|
21
18
|
const conditionalStyleState = (error, disabled) => {
|
|
22
19
|
return error ? 'error' : disabled ? 'disabled' : undefined;
|
|
23
20
|
};
|
|
@@ -38,7 +35,12 @@ export const Radio = /*#__PURE__*/forwardRef(({
|
|
|
38
35
|
}, ref) => {
|
|
39
36
|
const inputId = id ? `${htmlFor}-${id}` : htmlFor;
|
|
40
37
|
const styleState = conditionalStyleState(error, disabled);
|
|
41
|
-
|
|
38
|
+
const {
|
|
39
|
+
infotipProps,
|
|
40
|
+
labelId,
|
|
41
|
+
shouldLabelInfoTip
|
|
42
|
+
} = useInfotipProps(infotip);
|
|
43
|
+
return /*#__PURE__*/_jsxs(InputWrapper, {
|
|
42
44
|
className: className,
|
|
43
45
|
children: [/*#__PURE__*/_jsx(RadioInput, {
|
|
44
46
|
checked: checked,
|
|
@@ -55,13 +57,14 @@ export const Radio = /*#__PURE__*/forwardRef(({
|
|
|
55
57
|
}), /*#__PURE__*/_jsx(RadioLabel, {
|
|
56
58
|
disabled: disabled,
|
|
57
59
|
htmlFor: htmlFor,
|
|
60
|
+
id: infotip && shouldLabelInfoTip ? labelId : undefined,
|
|
58
61
|
variant: styleState,
|
|
59
62
|
children: label
|
|
60
|
-
}),
|
|
63
|
+
}), infotipProps && /*#__PURE__*/_jsx(FlexBox, {
|
|
61
64
|
center: true,
|
|
62
65
|
pl: 8,
|
|
63
66
|
children: /*#__PURE__*/_jsx(InfoTip, {
|
|
64
|
-
...
|
|
67
|
+
...infotipProps
|
|
65
68
|
})
|
|
66
69
|
})]
|
|
67
70
|
});
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
export declare const radioWrapper: (props: {
|
|
2
|
-
theme?: import("@emotion/react").Theme | undefined;
|
|
3
|
-
}) => import("@codecademy/variance").CSSObject;
|
|
4
1
|
export declare const radioLabel: (props: {
|
|
5
2
|
theme?: import("@emotion/react").Theme | undefined;
|
|
6
3
|
}) => import("@codecademy/variance").CSSObject;
|