@ultraviolet/ui 1.52.0 → 1.53.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/README.md +5 -2
- package/dist/components/NumberInputV2/index.cjs +14 -9
- package/dist/components/NumberInputV2/index.js +14 -9
- package/dist/components/TagInput/index.cjs +10 -8
- package/dist/components/TagInput/index.js +10 -8
- package/dist/components/TextInputV2/index.cjs +12 -10
- package/dist/components/TextInputV2/index.js +12 -10
- package/dist/components/Toggle/index.cjs +18 -6
- package/dist/components/Toggle/index.d.ts +1 -0
- package/dist/components/Toggle/index.js +18 -6
- package/dist/components/ToggleGroup/index.cjs +4 -3
- package/dist/components/ToggleGroup/index.d.ts +2 -2
- package/dist/components/ToggleGroup/index.js +4 -3
- package/package.json +1 -1
|
@@ -66,7 +66,17 @@ const StyledToggle = /* @__PURE__ */ _styled__default.default("div", process.env
|
|
|
66
66
|
theme
|
|
67
67
|
}) => theme.colors.neutral.backgroundStrongDisabled, ";&[data-checked='true']{background:", ({
|
|
68
68
|
theme
|
|
69
|
-
}) => theme.colors.primary.backgroundStrongDisabled, ";}}
|
|
69
|
+
}) => theme.colors.primary.backgroundStrongDisabled, ";}}&[data-error='true']{background-color:", ({
|
|
70
|
+
theme
|
|
71
|
+
}) => theme.colors.danger.background, ";&:focus-within,&:focus{box-shadow:", ({
|
|
72
|
+
theme
|
|
73
|
+
}) => theme.shadows.focusDanger, ";}&[data-checked='true']{background-color:", ({
|
|
74
|
+
theme
|
|
75
|
+
}) => theme.colors.danger.backgroundStrong, ";}&[data-disabled='true']{background-color:", ({
|
|
76
|
+
theme
|
|
77
|
+
}) => theme.colors.danger.backgroundDisabled, ";&[data-checked='true']{background-color:", ({
|
|
78
|
+
theme
|
|
79
|
+
}) => theme.colors.danger.backgroundStrongDisabled, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AAiCE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error='true'] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked='true'] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled='true'] {\n      background-color: ${({ theme }) =>\n        theme.colors.danger.backgroundDisabled};\n\n      &[data-checked='true'] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
70
80
|
const StyledCheckbox = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
|
|
71
81
|
target: "e1wstm611"
|
|
72
82
|
} : {
|
|
@@ -78,7 +88,7 @@ const StyledCheckbox = /* @__PURE__ */ _styled__default.default("input", process
|
|
|
78
88
|
} : {
|
|
79
89
|
name: "p9zju0",
|
|
80
90
|
styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}",
|
|
81
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AAsGmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {helper ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
|
|
91
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AA8HmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error='true'] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked='true'] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled='true'] {\n      background-color: ${({ theme }) =>\n        theme.colors.danger.backgroundDisabled};\n\n      &[data-checked='true'] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
|
|
82
92
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
83
93
|
});
|
|
84
94
|
const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.env.NODE_ENV === "production" ? {
|
|
@@ -94,7 +104,7 @@ const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.en
|
|
|
94
104
|
size
|
|
95
105
|
}) => SIZES[size].ball * 1.3775, "px;}&[aria-disabled='true']{cursor:not-allowed;color:", ({
|
|
96
106
|
theme
|
|
97
|
-
}) => theme.colors.neutral.textDisabled, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AAuHE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {helper ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
107
|
+
}) => theme.colors.neutral.textDisabled, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AA+IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error='true'] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked='true'] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled='true'] {\n      background-color: ${({ theme }) =>\n        theme.colors.danger.backgroundDisabled};\n\n      &[data-checked='true'] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
98
108
|
const RequiredIcon = () => /* @__PURE__ */ jsxRuntime.jsx("sup", { children: /* @__PURE__ */ jsxRuntime.jsx(icons.Icon, { name: "asterisk", size: 10, color: "danger" }) });
|
|
99
109
|
const Toggle = React.forwardRef(({
|
|
100
110
|
checked = false,
|
|
@@ -110,7 +120,8 @@ const Toggle = React.forwardRef(({
|
|
|
110
120
|
required,
|
|
111
121
|
className,
|
|
112
122
|
"data-testid": dataTestId,
|
|
113
|
-
value
|
|
123
|
+
value,
|
|
124
|
+
error
|
|
114
125
|
}, ref) => {
|
|
115
126
|
const [state, setState] = React.useState(checked);
|
|
116
127
|
const uniqueId = React.useId();
|
|
@@ -129,9 +140,10 @@ const Toggle = React.forwardRef(({
|
|
|
129
140
|
label,
|
|
130
141
|
required ? /* @__PURE__ */ jsxRuntime.jsx(RequiredIcon, {}) : null
|
|
131
142
|
] }) : null,
|
|
132
|
-
|
|
143
|
+
typeof error === "string" ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "p", variant: "bodySmall", prominence: "default", sentiment: "danger", disabled, children: error }) : null,
|
|
144
|
+
helper && !error ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "p", variant: "bodySmall", prominence: "weak", children: helper }) : null
|
|
133
145
|
] }),
|
|
134
|
-
/* @__PURE__ */ jsxRuntime.jsx(StyledToggle, { size, "data-checked": state, "data-disabled": disabled, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { id: id || uniqueId, checked: state, "aria-checked": state, disabled, name, onChange: onLocalChange, type: "checkbox", ref, value }) })
|
|
146
|
+
/* @__PURE__ */ jsxRuntime.jsx(StyledToggle, { size, "data-checked": state, "data-disabled": disabled, "data-error": !!error, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { id: id || uniqueId, checked: state, "aria-checked": state, disabled, name, onChange: onLocalChange, type: "checkbox", ref, value }) })
|
|
135
147
|
] }) });
|
|
136
148
|
});
|
|
137
149
|
exports.SIZES = SIZES;
|
|
@@ -30,5 +30,6 @@ export declare const Toggle: import("react").ForwardRefExoticComponent<{
|
|
|
30
30
|
disabled?: boolean | undefined;
|
|
31
31
|
className?: string | undefined;
|
|
32
32
|
required?: boolean | undefined;
|
|
33
|
+
error?: string | boolean | undefined;
|
|
33
34
|
'data-testid'?: string | undefined;
|
|
34
35
|
} & Pick<InputHTMLAttributes<HTMLInputElement>, "value"> & import("react").RefAttributes<HTMLInputElement>>;
|
|
@@ -62,7 +62,17 @@ const StyledToggle = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "pr
|
|
|
62
62
|
theme
|
|
63
63
|
}) => theme.colors.neutral.backgroundStrongDisabled, ";&[data-checked='true']{background:", ({
|
|
64
64
|
theme
|
|
65
|
-
}) => theme.colors.primary.backgroundStrongDisabled, ";}}
|
|
65
|
+
}) => theme.colors.primary.backgroundStrongDisabled, ";}}&[data-error='true']{background-color:", ({
|
|
66
|
+
theme
|
|
67
|
+
}) => theme.colors.danger.background, ";&:focus-within,&:focus{box-shadow:", ({
|
|
68
|
+
theme
|
|
69
|
+
}) => theme.shadows.focusDanger, ";}&[data-checked='true']{background-color:", ({
|
|
70
|
+
theme
|
|
71
|
+
}) => theme.colors.danger.backgroundStrong, ";}&[data-disabled='true']{background-color:", ({
|
|
72
|
+
theme
|
|
73
|
+
}) => theme.colors.danger.backgroundDisabled, ";&[data-checked='true']{background-color:", ({
|
|
74
|
+
theme
|
|
75
|
+
}) => theme.colors.danger.backgroundStrongDisabled, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AAiCE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error='true'] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked='true'] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled='true'] {\n      background-color: ${({ theme }) =>\n        theme.colors.danger.backgroundDisabled};\n\n      &[data-checked='true'] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
66
76
|
const StyledCheckbox = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
|
|
67
77
|
target: "e1wstm611"
|
|
68
78
|
} : {
|
|
@@ -74,7 +84,7 @@ const StyledCheckbox = /* @__PURE__ */ _styled("input", process.env.NODE_ENV ===
|
|
|
74
84
|
} : {
|
|
75
85
|
name: "p9zju0",
|
|
76
86
|
styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}",
|
|
77
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AAsGmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {helper ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
|
|
87
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AA8HmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error='true'] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked='true'] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled='true'] {\n      background-color: ${({ theme }) =>\n        theme.colors.danger.backgroundDisabled};\n\n      &[data-checked='true'] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
|
|
78
88
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
79
89
|
});
|
|
80
90
|
const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "production" ? {
|
|
@@ -90,7 +100,7 @@ const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "p
|
|
|
90
100
|
size
|
|
91
101
|
}) => SIZES[size].ball * 1.3775, "px;}&[aria-disabled='true']{cursor:not-allowed;color:", ({
|
|
92
102
|
theme
|
|
93
|
-
}) => theme.colors.neutral.textDisabled, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AAuHE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {helper ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
103
|
+
}) => theme.colors.neutral.textDisabled, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AA+IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: '';\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled='false']:active:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[data-checked='true'] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked='true'] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error='true'] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked='true'] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled='true'] {\n      background-color: ${({ theme }) =>\n        theme.colors.danger.backgroundDisabled};\n\n      &[data-checked='true'] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n    width: ${({ size }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\n)\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
94
104
|
const RequiredIcon = () => /* @__PURE__ */ jsx("sup", { children: /* @__PURE__ */ jsx(Icon, { name: "asterisk", size: 10, color: "danger" }) });
|
|
95
105
|
const Toggle = forwardRef(({
|
|
96
106
|
checked = false,
|
|
@@ -106,7 +116,8 @@ const Toggle = forwardRef(({
|
|
|
106
116
|
required,
|
|
107
117
|
className,
|
|
108
118
|
"data-testid": dataTestId,
|
|
109
|
-
value
|
|
119
|
+
value,
|
|
120
|
+
error
|
|
110
121
|
}, ref) => {
|
|
111
122
|
const [state, setState] = useState(checked);
|
|
112
123
|
const uniqueId = useId();
|
|
@@ -125,9 +136,10 @@ const Toggle = forwardRef(({
|
|
|
125
136
|
label,
|
|
126
137
|
required ? /* @__PURE__ */ jsx(RequiredIcon, {}) : null
|
|
127
138
|
] }) : null,
|
|
128
|
-
|
|
139
|
+
typeof error === "string" ? /* @__PURE__ */ jsx(Text, { as: "p", variant: "bodySmall", prominence: "default", sentiment: "danger", disabled, children: error }) : null,
|
|
140
|
+
helper && !error ? /* @__PURE__ */ jsx(Text, { as: "p", variant: "bodySmall", prominence: "weak", children: helper }) : null
|
|
129
141
|
] }),
|
|
130
|
-
/* @__PURE__ */ jsx(StyledToggle, { size, "data-checked": state, "data-disabled": disabled, children: /* @__PURE__ */ jsx(StyledCheckbox, { id: id || uniqueId, checked: state, "aria-checked": state, disabled, name, onChange: onLocalChange, type: "checkbox", ref, value }) })
|
|
142
|
+
/* @__PURE__ */ jsx(StyledToggle, { size, "data-checked": state, "data-disabled": disabled, "data-error": !!error, children: /* @__PURE__ */ jsx(StyledCheckbox, { id: id || uniqueId, checked: state, "aria-checked": state, disabled, name, onChange: onLocalChange, type: "checkbox", ref, value }) })
|
|
131
143
|
] }) });
|
|
132
144
|
});
|
|
133
145
|
export {
|
|
@@ -19,6 +19,7 @@ const ToggleGroupToggle = ({
|
|
|
19
19
|
value,
|
|
20
20
|
label,
|
|
21
21
|
helper,
|
|
22
|
+
error,
|
|
22
23
|
className,
|
|
23
24
|
"data-testid": dataTestId
|
|
24
25
|
}) => {
|
|
@@ -33,7 +34,7 @@ const ToggleGroupToggle = ({
|
|
|
33
34
|
} = context;
|
|
34
35
|
const ToggleName = `${groupName}.${name}`;
|
|
35
36
|
const ToggleValue = `${value}`;
|
|
36
|
-
return /* @__PURE__ */ jsxRuntime.jsx(index$2.Toggle, { onChange, checked: groupValues?.includes(ToggleValue), disabled, name: ToggleName, value: ToggleValue, helper, className, "data-testid": dataTestId, label });
|
|
37
|
+
return /* @__PURE__ */ jsxRuntime.jsx(index$2.Toggle, { onChange, checked: groupValues?.includes(ToggleValue), disabled, name: ToggleName, value: ToggleValue, helper, className, "data-testid": dataTestId, label, error });
|
|
37
38
|
};
|
|
38
39
|
const FieldSet = /* @__PURE__ */ _styled__default.default("fieldset", process.env.NODE_ENV === "production" ? {
|
|
39
40
|
target: "e1qvneex1"
|
|
@@ -46,7 +47,7 @@ const FieldSet = /* @__PURE__ */ _styled__default.default("fieldset", process.en
|
|
|
46
47
|
} : {
|
|
47
48
|
name: "7o2an9",
|
|
48
49
|
styles: "border:none;padding:0;margin:0",
|
|
49
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
50
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RWdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7XG4gIHR5cGUgQ29tcG9uZW50UHJvcHMsXG4gIHR5cGUgSW5wdXRIVE1MQXR0cmlidXRlcyxcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGNyZWF0ZUNvbnRleHQsXG4gIHVzZUNvbnRleHQsXG4gIHVzZU1lbW8sXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9nZ2xlIH0gZnJvbSAnLi4vVG9nZ2xlJ1xuXG50eXBlIFRvZ2dsZUdyb3VwQ29udGV4dFR5cGUgPSB7XG4gIGdyb3VwTmFtZTogc3RyaW5nXG4gIGdyb3VwVmFsdWVzOiBzdHJpbmdbXVxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBUb2dnbGVHcm91cENvbnRleHQgPSBjcmVhdGVDb250ZXh0PFRvZ2dsZUdyb3VwQ29udGV4dFR5cGUgfCB1bmRlZmluZWQ+KFxuICB1bmRlZmluZWQsXG4pXG5cbnR5cGUgVG9nZ2xlR3JvdXBUb2dnbGVQcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBUb2dnbGU+LFxuICAnb25DaGFuZ2UnIHwgJ2NoZWNrZWQnIHwgJ3JlcXVpcmVkJ1xuPiAmIHtcbiAgdmFsdWU6IHN0cmluZ1xufVxuXG4vKipcbiAqIFRvZ2dsZUdyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHlvdSB0byBncm91cCBhIHNldCBvZiBUb2dnbGUgY29tcG9uZW50cyB0b2dldGhlciB1bmRlciB0aGUgc2FtZSBsZWdlbmQuXG4gKi9cbmV4cG9ydCBjb25zdCBUb2dnbGVHcm91cFRvZ2dsZSA9ICh7XG4gIGRpc2FibGVkLFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFRvZ2dsZUdyb3VwVG9nZ2xlUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZUNvbnRleHQoVG9nZ2xlR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignVG9nZ2xlR3JvdXAuVG9nZ2xlIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgVG9nZ2xlR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlcyB9ID0gY29udGV4dFxuXG4gIGNvbnN0IFRvZ2dsZU5hbWUgPSBgJHtncm91cE5hbWV9LiR7bmFtZX1gXG4gIGNvbnN0IFRvZ2dsZVZhbHVlID0gYCR7dmFsdWV9YFxuXG4gIHJldHVybiAoXG4gICAgPFRvZ2dsZVxuICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgY2hlY2tlZD17Z3JvdXBWYWx1ZXM/LmluY2x1ZGVzKFRvZ2dsZVZhbHVlKX1cbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIG5hbWU9e1RvZ2dsZU5hbWV9XG4gICAgICB2YWx1ZT17VG9nZ2xlVmFsdWV9XG4gICAgICBoZWxwZXI9e2hlbHBlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBsYWJlbD17bGFiZWx9XG4gICAgICBlcnJvcj17ZXJyb3J9XG4gICAgLz5cbiAgKVxufVxuXG5jb25zdCBGaWVsZFNldCA9IHN0eWxlZC5maWVsZHNldGBcbiAgYm9yZGVyOiBub25lO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW46IDA7XG5gXG5cbmNvbnN0IFN0eWxlZFJlcXVpcmVkSWNvbiA9IHN0eWxlZChJY29uKWBcbiAgdmVydGljYWwtYWxpZ246IHN1cGVyO1xuYFxuXG50eXBlIFRvZ2dsZUdyb3VwUHJvcHMgPSB7XG4gIGxlZ2VuZDogc3RyaW5nXG4gIHZhbHVlPzogc3RyaW5nW11cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgcmVxdWlyZWQ/OiBib29sZWFuXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnIHwgJ25hbWUnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmV4cG9ydCBjb25zdCBUb2dnbGVHcm91cCA9ICh7XG4gIGxlZ2VuZCxcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gIGNoaWxkcmVuLFxuICBvbkNoYW5nZSxcbiAgbmFtZSxcbiAgcmVxdWlyZWQgPSBmYWxzZSxcbn06IFRvZ2dsZUdyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dFZhbHVlID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgZ3JvdXBOYW1lOiBuYW1lLFxuICAgICAgZ3JvdXBWYWx1ZXM6IHZhbHVlID8/IFtdLFxuICAgICAgb25DaGFuZ2UsXG4gICAgfSksXG4gICAgW25hbWUsIHZhbHVlLCBvbkNoYW5nZV0sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxUb2dnbGVHcm91cENvbnRleHQuUHJvdmlkZXIgdmFsdWU9e2NvbnRleHRWYWx1ZX0+XG4gICAgICA8U3RhY2sgZ2FwPXsxfT5cbiAgICAgICAgPEZpZWxkU2V0IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgICAgICA8U3RhY2sgZ2FwPXsxLjV9PlxuICAgICAgICAgICAgPFRleHQgYXM9XCJsZWdlbmRcIiB2YXJpYW50PVwiYm9keVN0cm9uZ1wiPlxuICAgICAgICAgICAgICB7bGVnZW5kfSZuYnNwO1xuICAgICAgICAgICAgICB7cmVxdWlyZWQgPyAoXG4gICAgICAgICAgICAgICAgPFN0eWxlZFJlcXVpcmVkSWNvbiBuYW1lPVwiYXN0ZXJpc2tcIiBjb2xvcj1cImRhbmdlclwiIHNpemU9ezh9IC8+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgPFN0YWNrIGdhcD17Mn0gZGlyZWN0aW9uPXtkaXJlY3Rpb259PlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgIDwvRmllbGRTZXQ+XG4gICAgICAgIHtoZWxwZXIgPyAoXG4gICAgICAgICAgPFRleHQgYXM9XCJwXCIgdmFyaWFudD1cImJvZHlTbWFsbFwiIHByb21pbmVuY2U9XCJ3ZWFrXCI+XG4gICAgICAgICAgICB7aGVscGVyfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtlcnJvciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInBcIiB2YXJpYW50PVwiYm9keVNtYWxsXCIgc2VudGltZW50PVwiZGFuZ2VyXCIgcHJvbWluZW5jZT1cIndlYWtcIj5cbiAgICAgICAgICAgIHtlcnJvcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L1RvZ2dsZUdyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5Ub2dnbGVHcm91cC5Ub2dnbGUgPSBUb2dnbGVHcm91cFRvZ2dsZVxuIl19 */",
|
|
50
51
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
51
52
|
});
|
|
52
53
|
const StyledRequiredIcon = /* @__PURE__ */ _styled__default.default(icons.Icon, process.env.NODE_ENV === "production" ? {
|
|
@@ -60,7 +61,7 @@ const StyledRequiredIcon = /* @__PURE__ */ _styled__default.default(icons.Icon,
|
|
|
60
61
|
} : {
|
|
61
62
|
name: "1nglpc5",
|
|
62
63
|
styles: "vertical-align:super",
|
|
63
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
64
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RXVDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7XG4gIHR5cGUgQ29tcG9uZW50UHJvcHMsXG4gIHR5cGUgSW5wdXRIVE1MQXR0cmlidXRlcyxcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGNyZWF0ZUNvbnRleHQsXG4gIHVzZUNvbnRleHQsXG4gIHVzZU1lbW8sXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9nZ2xlIH0gZnJvbSAnLi4vVG9nZ2xlJ1xuXG50eXBlIFRvZ2dsZUdyb3VwQ29udGV4dFR5cGUgPSB7XG4gIGdyb3VwTmFtZTogc3RyaW5nXG4gIGdyb3VwVmFsdWVzOiBzdHJpbmdbXVxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBUb2dnbGVHcm91cENvbnRleHQgPSBjcmVhdGVDb250ZXh0PFRvZ2dsZUdyb3VwQ29udGV4dFR5cGUgfCB1bmRlZmluZWQ+KFxuICB1bmRlZmluZWQsXG4pXG5cbnR5cGUgVG9nZ2xlR3JvdXBUb2dnbGVQcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBUb2dnbGU+LFxuICAnb25DaGFuZ2UnIHwgJ2NoZWNrZWQnIHwgJ3JlcXVpcmVkJ1xuPiAmIHtcbiAgdmFsdWU6IHN0cmluZ1xufVxuXG4vKipcbiAqIFRvZ2dsZUdyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHlvdSB0byBncm91cCBhIHNldCBvZiBUb2dnbGUgY29tcG9uZW50cyB0b2dldGhlciB1bmRlciB0aGUgc2FtZSBsZWdlbmQuXG4gKi9cbmV4cG9ydCBjb25zdCBUb2dnbGVHcm91cFRvZ2dsZSA9ICh7XG4gIGRpc2FibGVkLFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFRvZ2dsZUdyb3VwVG9nZ2xlUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZUNvbnRleHQoVG9nZ2xlR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignVG9nZ2xlR3JvdXAuVG9nZ2xlIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgVG9nZ2xlR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlcyB9ID0gY29udGV4dFxuXG4gIGNvbnN0IFRvZ2dsZU5hbWUgPSBgJHtncm91cE5hbWV9LiR7bmFtZX1gXG4gIGNvbnN0IFRvZ2dsZVZhbHVlID0gYCR7dmFsdWV9YFxuXG4gIHJldHVybiAoXG4gICAgPFRvZ2dsZVxuICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgY2hlY2tlZD17Z3JvdXBWYWx1ZXM/LmluY2x1ZGVzKFRvZ2dsZVZhbHVlKX1cbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIG5hbWU9e1RvZ2dsZU5hbWV9XG4gICAgICB2YWx1ZT17VG9nZ2xlVmFsdWV9XG4gICAgICBoZWxwZXI9e2hlbHBlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBsYWJlbD17bGFiZWx9XG4gICAgICBlcnJvcj17ZXJyb3J9XG4gICAgLz5cbiAgKVxufVxuXG5jb25zdCBGaWVsZFNldCA9IHN0eWxlZC5maWVsZHNldGBcbiAgYm9yZGVyOiBub25lO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW46IDA7XG5gXG5cbmNvbnN0IFN0eWxlZFJlcXVpcmVkSWNvbiA9IHN0eWxlZChJY29uKWBcbiAgdmVydGljYWwtYWxpZ246IHN1cGVyO1xuYFxuXG50eXBlIFRvZ2dsZUdyb3VwUHJvcHMgPSB7XG4gIGxlZ2VuZDogc3RyaW5nXG4gIHZhbHVlPzogc3RyaW5nW11cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgcmVxdWlyZWQ/OiBib29sZWFuXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnIHwgJ25hbWUnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmV4cG9ydCBjb25zdCBUb2dnbGVHcm91cCA9ICh7XG4gIGxlZ2VuZCxcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gIGNoaWxkcmVuLFxuICBvbkNoYW5nZSxcbiAgbmFtZSxcbiAgcmVxdWlyZWQgPSBmYWxzZSxcbn06IFRvZ2dsZUdyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dFZhbHVlID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgZ3JvdXBOYW1lOiBuYW1lLFxuICAgICAgZ3JvdXBWYWx1ZXM6IHZhbHVlID8/IFtdLFxuICAgICAgb25DaGFuZ2UsXG4gICAgfSksXG4gICAgW25hbWUsIHZhbHVlLCBvbkNoYW5nZV0sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxUb2dnbGVHcm91cENvbnRleHQuUHJvdmlkZXIgdmFsdWU9e2NvbnRleHRWYWx1ZX0+XG4gICAgICA8U3RhY2sgZ2FwPXsxfT5cbiAgICAgICAgPEZpZWxkU2V0IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgICAgICA8U3RhY2sgZ2FwPXsxLjV9PlxuICAgICAgICAgICAgPFRleHQgYXM9XCJsZWdlbmRcIiB2YXJpYW50PVwiYm9keVN0cm9uZ1wiPlxuICAgICAgICAgICAgICB7bGVnZW5kfSZuYnNwO1xuICAgICAgICAgICAgICB7cmVxdWlyZWQgPyAoXG4gICAgICAgICAgICAgICAgPFN0eWxlZFJlcXVpcmVkSWNvbiBuYW1lPVwiYXN0ZXJpc2tcIiBjb2xvcj1cImRhbmdlclwiIHNpemU9ezh9IC8+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgPFN0YWNrIGdhcD17Mn0gZGlyZWN0aW9uPXtkaXJlY3Rpb259PlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgIDwvRmllbGRTZXQ+XG4gICAgICAgIHtoZWxwZXIgPyAoXG4gICAgICAgICAgPFRleHQgYXM9XCJwXCIgdmFyaWFudD1cImJvZHlTbWFsbFwiIHByb21pbmVuY2U9XCJ3ZWFrXCI+XG4gICAgICAgICAgICB7aGVscGVyfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtlcnJvciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInBcIiB2YXJpYW50PVwiYm9keVNtYWxsXCIgc2VudGltZW50PVwiZGFuZ2VyXCIgcHJvbWluZW5jZT1cIndlYWtcIj5cbiAgICAgICAgICAgIHtlcnJvcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L1RvZ2dsZUdyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5Ub2dnbGVHcm91cC5Ub2dnbGUgPSBUb2dnbGVHcm91cFRvZ2dsZVxuIl19 */",
|
|
64
65
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
65
66
|
});
|
|
66
67
|
const ToggleGroup = ({
|
|
@@ -6,7 +6,7 @@ type ToggleGroupToggleProps = Omit<ComponentProps<typeof Toggle>, 'onChange' | '
|
|
|
6
6
|
/**
|
|
7
7
|
* ToggleGroup is a component that allows you to group a set of Toggle components together under the same legend.
|
|
8
8
|
*/
|
|
9
|
-
export declare const ToggleGroupToggle: ({ disabled, name, value, label, helper, className, "data-testid": dataTestId, }: ToggleGroupToggleProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
9
|
+
export declare const ToggleGroupToggle: ({ disabled, name, value, label, helper, error, className, "data-testid": dataTestId, }: ToggleGroupToggleProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
10
10
|
type ToggleGroupProps = {
|
|
11
11
|
legend: string;
|
|
12
12
|
value?: string[];
|
|
@@ -19,6 +19,6 @@ type ToggleGroupProps = {
|
|
|
19
19
|
} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'name'>> & Pick<InputHTMLAttributes<HTMLInputElement>, 'required'>;
|
|
20
20
|
export declare const ToggleGroup: {
|
|
21
21
|
({ legend, value, className, helper, error, direction, children, onChange, name, required, }: ToggleGroupProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
22
|
-
Toggle: ({ disabled, name, value, label, helper, className, "data-testid": dataTestId, }: ToggleGroupToggleProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
22
|
+
Toggle: ({ disabled, name, value, label, helper, error, className, "data-testid": dataTestId, }: ToggleGroupToggleProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
23
23
|
};
|
|
24
24
|
export {};
|
|
@@ -15,6 +15,7 @@ const ToggleGroupToggle = ({
|
|
|
15
15
|
value,
|
|
16
16
|
label,
|
|
17
17
|
helper,
|
|
18
|
+
error,
|
|
18
19
|
className,
|
|
19
20
|
"data-testid": dataTestId
|
|
20
21
|
}) => {
|
|
@@ -29,7 +30,7 @@ const ToggleGroupToggle = ({
|
|
|
29
30
|
} = context;
|
|
30
31
|
const ToggleName = `${groupName}.${name}`;
|
|
31
32
|
const ToggleValue = `${value}`;
|
|
32
|
-
return /* @__PURE__ */ jsx(Toggle, { onChange, checked: groupValues?.includes(ToggleValue), disabled, name: ToggleName, value: ToggleValue, helper, className, "data-testid": dataTestId, label });
|
|
33
|
+
return /* @__PURE__ */ jsx(Toggle, { onChange, checked: groupValues?.includes(ToggleValue), disabled, name: ToggleName, value: ToggleValue, helper, className, "data-testid": dataTestId, label, error });
|
|
33
34
|
};
|
|
34
35
|
const FieldSet = /* @__PURE__ */ _styled("fieldset", process.env.NODE_ENV === "production" ? {
|
|
35
36
|
target: "e1qvneex1"
|
|
@@ -42,7 +43,7 @@ const FieldSet = /* @__PURE__ */ _styled("fieldset", process.env.NODE_ENV === "p
|
|
|
42
43
|
} : {
|
|
43
44
|
name: "7o2an9",
|
|
44
45
|
styles: "border:none;padding:0;margin:0",
|
|
45
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
46
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RWdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7XG4gIHR5cGUgQ29tcG9uZW50UHJvcHMsXG4gIHR5cGUgSW5wdXRIVE1MQXR0cmlidXRlcyxcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGNyZWF0ZUNvbnRleHQsXG4gIHVzZUNvbnRleHQsXG4gIHVzZU1lbW8sXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9nZ2xlIH0gZnJvbSAnLi4vVG9nZ2xlJ1xuXG50eXBlIFRvZ2dsZUdyb3VwQ29udGV4dFR5cGUgPSB7XG4gIGdyb3VwTmFtZTogc3RyaW5nXG4gIGdyb3VwVmFsdWVzOiBzdHJpbmdbXVxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBUb2dnbGVHcm91cENvbnRleHQgPSBjcmVhdGVDb250ZXh0PFRvZ2dsZUdyb3VwQ29udGV4dFR5cGUgfCB1bmRlZmluZWQ+KFxuICB1bmRlZmluZWQsXG4pXG5cbnR5cGUgVG9nZ2xlR3JvdXBUb2dnbGVQcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBUb2dnbGU+LFxuICAnb25DaGFuZ2UnIHwgJ2NoZWNrZWQnIHwgJ3JlcXVpcmVkJ1xuPiAmIHtcbiAgdmFsdWU6IHN0cmluZ1xufVxuXG4vKipcbiAqIFRvZ2dsZUdyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHlvdSB0byBncm91cCBhIHNldCBvZiBUb2dnbGUgY29tcG9uZW50cyB0b2dldGhlciB1bmRlciB0aGUgc2FtZSBsZWdlbmQuXG4gKi9cbmV4cG9ydCBjb25zdCBUb2dnbGVHcm91cFRvZ2dsZSA9ICh7XG4gIGRpc2FibGVkLFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFRvZ2dsZUdyb3VwVG9nZ2xlUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZUNvbnRleHQoVG9nZ2xlR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignVG9nZ2xlR3JvdXAuVG9nZ2xlIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgVG9nZ2xlR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlcyB9ID0gY29udGV4dFxuXG4gIGNvbnN0IFRvZ2dsZU5hbWUgPSBgJHtncm91cE5hbWV9LiR7bmFtZX1gXG4gIGNvbnN0IFRvZ2dsZVZhbHVlID0gYCR7dmFsdWV9YFxuXG4gIHJldHVybiAoXG4gICAgPFRvZ2dsZVxuICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgY2hlY2tlZD17Z3JvdXBWYWx1ZXM/LmluY2x1ZGVzKFRvZ2dsZVZhbHVlKX1cbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIG5hbWU9e1RvZ2dsZU5hbWV9XG4gICAgICB2YWx1ZT17VG9nZ2xlVmFsdWV9XG4gICAgICBoZWxwZXI9e2hlbHBlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBsYWJlbD17bGFiZWx9XG4gICAgICBlcnJvcj17ZXJyb3J9XG4gICAgLz5cbiAgKVxufVxuXG5jb25zdCBGaWVsZFNldCA9IHN0eWxlZC5maWVsZHNldGBcbiAgYm9yZGVyOiBub25lO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW46IDA7XG5gXG5cbmNvbnN0IFN0eWxlZFJlcXVpcmVkSWNvbiA9IHN0eWxlZChJY29uKWBcbiAgdmVydGljYWwtYWxpZ246IHN1cGVyO1xuYFxuXG50eXBlIFRvZ2dsZUdyb3VwUHJvcHMgPSB7XG4gIGxlZ2VuZDogc3RyaW5nXG4gIHZhbHVlPzogc3RyaW5nW11cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgcmVxdWlyZWQ/OiBib29sZWFuXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnIHwgJ25hbWUnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmV4cG9ydCBjb25zdCBUb2dnbGVHcm91cCA9ICh7XG4gIGxlZ2VuZCxcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gIGNoaWxkcmVuLFxuICBvbkNoYW5nZSxcbiAgbmFtZSxcbiAgcmVxdWlyZWQgPSBmYWxzZSxcbn06IFRvZ2dsZUdyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dFZhbHVlID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgZ3JvdXBOYW1lOiBuYW1lLFxuICAgICAgZ3JvdXBWYWx1ZXM6IHZhbHVlID8/IFtdLFxuICAgICAgb25DaGFuZ2UsXG4gICAgfSksXG4gICAgW25hbWUsIHZhbHVlLCBvbkNoYW5nZV0sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxUb2dnbGVHcm91cENvbnRleHQuUHJvdmlkZXIgdmFsdWU9e2NvbnRleHRWYWx1ZX0+XG4gICAgICA8U3RhY2sgZ2FwPXsxfT5cbiAgICAgICAgPEZpZWxkU2V0IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgICAgICA8U3RhY2sgZ2FwPXsxLjV9PlxuICAgICAgICAgICAgPFRleHQgYXM9XCJsZWdlbmRcIiB2YXJpYW50PVwiYm9keVN0cm9uZ1wiPlxuICAgICAgICAgICAgICB7bGVnZW5kfSZuYnNwO1xuICAgICAgICAgICAgICB7cmVxdWlyZWQgPyAoXG4gICAgICAgICAgICAgICAgPFN0eWxlZFJlcXVpcmVkSWNvbiBuYW1lPVwiYXN0ZXJpc2tcIiBjb2xvcj1cImRhbmdlclwiIHNpemU9ezh9IC8+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgPFN0YWNrIGdhcD17Mn0gZGlyZWN0aW9uPXtkaXJlY3Rpb259PlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgIDwvRmllbGRTZXQ+XG4gICAgICAgIHtoZWxwZXIgPyAoXG4gICAgICAgICAgPFRleHQgYXM9XCJwXCIgdmFyaWFudD1cImJvZHlTbWFsbFwiIHByb21pbmVuY2U9XCJ3ZWFrXCI+XG4gICAgICAgICAgICB7aGVscGVyfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtlcnJvciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInBcIiB2YXJpYW50PVwiYm9keVNtYWxsXCIgc2VudGltZW50PVwiZGFuZ2VyXCIgcHJvbWluZW5jZT1cIndlYWtcIj5cbiAgICAgICAgICAgIHtlcnJvcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L1RvZ2dsZUdyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5Ub2dnbGVHcm91cC5Ub2dnbGUgPSBUb2dnbGVHcm91cFRvZ2dsZVxuIl19 */",
|
|
46
47
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
47
48
|
});
|
|
48
49
|
const StyledRequiredIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV === "production" ? {
|
|
@@ -56,7 +57,7 @@ const StyledRequiredIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV ==
|
|
|
56
57
|
} : {
|
|
57
58
|
name: "1nglpc5",
|
|
58
59
|
styles: "vertical-align:super",
|
|
59
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
60
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RXVDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7XG4gIHR5cGUgQ29tcG9uZW50UHJvcHMsXG4gIHR5cGUgSW5wdXRIVE1MQXR0cmlidXRlcyxcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGNyZWF0ZUNvbnRleHQsXG4gIHVzZUNvbnRleHQsXG4gIHVzZU1lbW8sXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9nZ2xlIH0gZnJvbSAnLi4vVG9nZ2xlJ1xuXG50eXBlIFRvZ2dsZUdyb3VwQ29udGV4dFR5cGUgPSB7XG4gIGdyb3VwTmFtZTogc3RyaW5nXG4gIGdyb3VwVmFsdWVzOiBzdHJpbmdbXVxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBUb2dnbGVHcm91cENvbnRleHQgPSBjcmVhdGVDb250ZXh0PFRvZ2dsZUdyb3VwQ29udGV4dFR5cGUgfCB1bmRlZmluZWQ+KFxuICB1bmRlZmluZWQsXG4pXG5cbnR5cGUgVG9nZ2xlR3JvdXBUb2dnbGVQcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBUb2dnbGU+LFxuICAnb25DaGFuZ2UnIHwgJ2NoZWNrZWQnIHwgJ3JlcXVpcmVkJ1xuPiAmIHtcbiAgdmFsdWU6IHN0cmluZ1xufVxuXG4vKipcbiAqIFRvZ2dsZUdyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHlvdSB0byBncm91cCBhIHNldCBvZiBUb2dnbGUgY29tcG9uZW50cyB0b2dldGhlciB1bmRlciB0aGUgc2FtZSBsZWdlbmQuXG4gKi9cbmV4cG9ydCBjb25zdCBUb2dnbGVHcm91cFRvZ2dsZSA9ICh7XG4gIGRpc2FibGVkLFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFRvZ2dsZUdyb3VwVG9nZ2xlUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZUNvbnRleHQoVG9nZ2xlR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignVG9nZ2xlR3JvdXAuVG9nZ2xlIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgVG9nZ2xlR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlcyB9ID0gY29udGV4dFxuXG4gIGNvbnN0IFRvZ2dsZU5hbWUgPSBgJHtncm91cE5hbWV9LiR7bmFtZX1gXG4gIGNvbnN0IFRvZ2dsZVZhbHVlID0gYCR7dmFsdWV9YFxuXG4gIHJldHVybiAoXG4gICAgPFRvZ2dsZVxuICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgY2hlY2tlZD17Z3JvdXBWYWx1ZXM/LmluY2x1ZGVzKFRvZ2dsZVZhbHVlKX1cbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIG5hbWU9e1RvZ2dsZU5hbWV9XG4gICAgICB2YWx1ZT17VG9nZ2xlVmFsdWV9XG4gICAgICBoZWxwZXI9e2hlbHBlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBsYWJlbD17bGFiZWx9XG4gICAgICBlcnJvcj17ZXJyb3J9XG4gICAgLz5cbiAgKVxufVxuXG5jb25zdCBGaWVsZFNldCA9IHN0eWxlZC5maWVsZHNldGBcbiAgYm9yZGVyOiBub25lO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW46IDA7XG5gXG5cbmNvbnN0IFN0eWxlZFJlcXVpcmVkSWNvbiA9IHN0eWxlZChJY29uKWBcbiAgdmVydGljYWwtYWxpZ246IHN1cGVyO1xuYFxuXG50eXBlIFRvZ2dsZUdyb3VwUHJvcHMgPSB7XG4gIGxlZ2VuZDogc3RyaW5nXG4gIHZhbHVlPzogc3RyaW5nW11cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgcmVxdWlyZWQ/OiBib29sZWFuXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnIHwgJ25hbWUnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmV4cG9ydCBjb25zdCBUb2dnbGVHcm91cCA9ICh7XG4gIGxlZ2VuZCxcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gIGNoaWxkcmVuLFxuICBvbkNoYW5nZSxcbiAgbmFtZSxcbiAgcmVxdWlyZWQgPSBmYWxzZSxcbn06IFRvZ2dsZUdyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dFZhbHVlID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgZ3JvdXBOYW1lOiBuYW1lLFxuICAgICAgZ3JvdXBWYWx1ZXM6IHZhbHVlID8/IFtdLFxuICAgICAgb25DaGFuZ2UsXG4gICAgfSksXG4gICAgW25hbWUsIHZhbHVlLCBvbkNoYW5nZV0sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxUb2dnbGVHcm91cENvbnRleHQuUHJvdmlkZXIgdmFsdWU9e2NvbnRleHRWYWx1ZX0+XG4gICAgICA8U3RhY2sgZ2FwPXsxfT5cbiAgICAgICAgPEZpZWxkU2V0IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgICAgICA8U3RhY2sgZ2FwPXsxLjV9PlxuICAgICAgICAgICAgPFRleHQgYXM9XCJsZWdlbmRcIiB2YXJpYW50PVwiYm9keVN0cm9uZ1wiPlxuICAgICAgICAgICAgICB7bGVnZW5kfSZuYnNwO1xuICAgICAgICAgICAgICB7cmVxdWlyZWQgPyAoXG4gICAgICAgICAgICAgICAgPFN0eWxlZFJlcXVpcmVkSWNvbiBuYW1lPVwiYXN0ZXJpc2tcIiBjb2xvcj1cImRhbmdlclwiIHNpemU9ezh9IC8+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgPFN0YWNrIGdhcD17Mn0gZGlyZWN0aW9uPXtkaXJlY3Rpb259PlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgIDwvRmllbGRTZXQ+XG4gICAgICAgIHtoZWxwZXIgPyAoXG4gICAgICAgICAgPFRleHQgYXM9XCJwXCIgdmFyaWFudD1cImJvZHlTbWFsbFwiIHByb21pbmVuY2U9XCJ3ZWFrXCI+XG4gICAgICAgICAgICB7aGVscGVyfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtlcnJvciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInBcIiB2YXJpYW50PVwiYm9keVNtYWxsXCIgc2VudGltZW50PVwiZGFuZ2VyXCIgcHJvbWluZW5jZT1cIndlYWtcIj5cbiAgICAgICAgICAgIHtlcnJvcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L1RvZ2dsZUdyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5Ub2dnbGVHcm91cC5Ub2dnbGUgPSBUb2dnbGVHcm91cFRvZ2dsZVxuIl19 */",
|
|
60
61
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
61
62
|
});
|
|
62
63
|
const ToggleGroup = ({
|