@ultraviolet/ui 1.72.1 → 1.72.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Checkbox/index.cjs +36 -22
- package/dist/components/Checkbox/index.js +37 -23
- package/dist/components/List/Row.cjs +10 -6
- package/dist/components/List/Row.d.ts +5 -1
- package/dist/components/List/Row.js +10 -6
- package/dist/components/List/index.d.ts +1 -0
- package/dist/components/Modal/ModalProvider.cjs +3 -3
- package/dist/components/Modal/ModalProvider.d.ts +8 -4
- package/dist/components/Modal/ModalProvider.js +3 -3
- package/dist/components/Modal/components/Dialog.cjs +27 -11
- package/dist/components/Modal/components/Dialog.d.ts +1 -0
- package/dist/components/Modal/components/Dialog.js +28 -12
- package/dist/components/Radio/index.cjs +40 -30
- package/dist/components/Radio/index.js +41 -31
- package/dist/components/Row/index.cjs +9 -6
- package/dist/components/Row/index.d.ts +3 -2
- package/dist/components/Row/index.js +9 -6
- package/dist/components/SelectInputV2/Dropdown.cjs +50 -29
- package/dist/components/SelectInputV2/Dropdown.d.ts +2 -1
- package/dist/components/SelectInputV2/Dropdown.js +51 -30
- package/dist/components/SelectInputV2/index.cjs +3 -3
- package/dist/components/SelectInputV2/index.js +3 -3
- package/dist/components/SelectableCard/index.cjs +12 -12
- package/dist/components/SelectableCard/index.js +12 -12
- package/dist/components/Toggle/index.cjs +4 -4
- package/dist/components/Toggle/index.js +4 -4
- package/package.json +3 -3
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { jsx, jsxs } from "@emotion/react/jsx-runtime";
|
|
1
|
+
import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
|
|
2
2
|
import _styled from "@emotion/styled/base";
|
|
3
3
|
import { forwardRef, useId } from "react";
|
|
4
4
|
import { Stack } from "../Stack/index.js";
|
|
@@ -9,32 +9,32 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
|
9
9
|
}
|
|
10
10
|
const SIZE = 24;
|
|
11
11
|
const InnerCircleRing = /* @__PURE__ */ _styled("circle", process.env.NODE_ENV === "production" ? {
|
|
12
|
-
target: "
|
|
12
|
+
target: "ehkrmld8"
|
|
13
13
|
} : {
|
|
14
|
-
target: "
|
|
14
|
+
target: "ehkrmld8",
|
|
15
15
|
label: "InnerCircleRing"
|
|
16
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTcUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW8vaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEZvcndhcmRlZFJlZiwgSW5wdXRIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmLCB1c2VJZCB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFNJWkUgPSAyNFxuXG5jb25zdCBJbm5lckNpcmNsZVJpbmcgPSBzdHlsZWQuY2lyY2xlYGBcbmNvbnN0IFJhZGlvTWFyayA9IHN0eWxlZC5jaXJjbGVgYFxuXG5leHBvcnQgY29uc3QgUmFkaW9TdGFjayA9IHN0eWxlZChTdGFjaylgYFxuXG5jb25zdCBSYWRpb01hcmtlZEljb24gPSAoKSA9PiAoXG4gIDxnPlxuICAgIDxjaXJjbGUgY3g9XCIxMlwiIGN5PVwiMTJcIiByPVwiMTBcIiBzdHJva2VXaWR0aD1cIjJcIiAvPlxuICAgIDxJbm5lckNpcmNsZVJpbmcgY3g9XCIxMlwiIGN5PVwiMTJcIiByPVwiOFwiIC8+XG4gICAgPFJhZGlvTWFyayBjeD1cIjEyXCIgY3k9XCIxMlwiIHI9XCI1XCIgLz5cbiAgPC9nPlxuKVxuXG5jb25zdCBSaW5nID0gc3R5bGVkLnN2Z2BcbiAgaGVpZ2h0OiAke1NJWkV9cHg7XG4gIHdpZHRoOiAke1NJWkV9cHg7XG4gIG1pbi13aWR0aDogJHtTSVpFfXB4O1xuICBtaW4taGVpZ2h0OiAke1NJWkV9cHg7XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuY2lyY2xlfTtcbiAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICAke0lubmVyQ2lyY2xlUmluZ30ge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH07XG4gIH1cbmBcblxuY29uc3QgUmFkaW9JbnB1dCA9IHN0eWxlZC5pbnB1dGBcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIGhlaWdodDogJHtTSVpFfXB4O1xuICB3aWR0aDogJHtTSVpFfXB4O1xuICBvcGFjaXR5OiAwO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBib3JkZXItd2lkdGg6IDA7XG4gICYgKyAke1Jpbmd9IHtcbiAgICAke1JhZGlvTWFya30ge1xuICAgICAgdHJhbnNmb3JtLW9yaWdpbjogY2VudGVyO1xuICAgICAgdHJhbnNpdGlvbjogMjAwbXMgdHJhbnNmb3JtIGVhc2UtaW4tb3V0O1xuICAgICAgdHJhbnNmb3JtOiBzY2FsZSgwKTtcbiAgICB9XG4gIH1cblxuICAmOmNoZWNrZWQgKyBzdmcge1xuICAgICR7UmFkaW9NYXJrfSB7XG4gICAgICB0cmFuc2Zvcm06IHNjYWxlKDEpO1xuICAgIH1cbiAgfVxuXG4gICY6Y2hlY2tlZFthcmlhLWRpc2FibGVkPSdmYWxzZSddW2FyaWEtaW52YWxpZD0nZmFsc2UnXSArICR7UmluZ30ge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ307XG4gIH1cblxuICAmOmNoZWNrZWRbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddW2FyaWEtaW52YWxpZD0nZmFsc2UnXSArICR7UmluZ30ge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYm9yZGVyRGlzYWJsZWR9O1xuICB9XG5cbiAgJlthcmlhLWludmFsaWQ9J3RydWUnXTpub3QoW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSkgKyAke1Jpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5kYW5nZXIuYmFja2dyb3VuZFN0cm9uZ307XG4gIH1cblxuICAmW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ106YWN0aXZlICsgJHtSaW5nfSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogIzVlMTI3ZTQwO1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZH07XG4gICAgfVxuICB9XG5cbiAgJlthcmlhLWRpc2FibGVkPSdmYWxzZSddOmZvY3VzLXZpc2libGUgKyAke1Jpbmd9IHtcbiAgICBvdXRsaW5lOiAtd2Via2l0LWZvY3VzLXJpbmctY29sb3IgYXV0byAxcHg7XG4gIH1cblxuICAmW2FyaWEtaW52YWxpZD0ndHJ1ZSddOmZvY3VzICsgJHtSaW5nfSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogI2Y5MWI2YzQwO1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgICAke0lubmVyQ2lyY2xlUmluZ30ge1xuICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMuZGFuZ2VyLmJhY2tncm91bmR9O1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBSYWRpb0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcblxuICAmW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ10sXG4gICZbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXSA+IGxhYmVsIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gIH1cblxuICA6aG92ZXJbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXSB7XG4gICAgJHtSYWRpb0lucHV0fSArICR7UmluZ30ge1xuICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeS5ib3JkZXJ9O1xuICAgICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeS5iYWNrZ3JvdW5kSG92ZXJ9O1xuICAgICAgfVxuICAgIH1cblxuICAgICR7UmFkaW9JbnB1dH1bYXJpYS1pbnZhbGlkPSd0cnVlJ10gKyAke1Jpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5ib3JkZXJ9O1xuICAgICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMuZGFuZ2VyLmJhY2tncm91bmRIb3Zlcn07XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgJlthcmlhLWRpc2FibGVkPSd0cnVlJ10ge1xuICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dERpc2FibGVkfTtcblxuICAgICYgPiBsYWJlbCxcbiAgICAke1JhZGlvSW5wdXR9IHtcbiAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgfVxuXG4gICAgJHtSaW5nfSB7XG4gICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+
|
|
16
|
+
})(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/Radio/index.tsx"],"names":[],"mappings":"AASqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
|
|
17
17
|
const RadioMark = /* @__PURE__ */ _styled("circle", process.env.NODE_ENV === "production" ? {
|
|
18
|
-
target: "
|
|
18
|
+
target: "ehkrmld7"
|
|
19
19
|
} : {
|
|
20
|
-
target: "
|
|
20
|
+
target: "ehkrmld7",
|
|
21
21
|
label: "RadioMark"
|
|
22
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW8vaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEZvcndhcmRlZFJlZiwgSW5wdXRIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmLCB1c2VJZCB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFNJWkUgPSAyNFxuXG5jb25zdCBJbm5lckNpcmNsZVJpbmcgPSBzdHlsZWQuY2lyY2xlYGBcbmNvbnN0IFJhZGlvTWFyayA9IHN0eWxlZC5jaXJjbGVgYFxuXG5leHBvcnQgY29uc3QgUmFkaW9TdGFjayA9IHN0eWxlZChTdGFjaylgYFxuXG5jb25zdCBSYWRpb01hcmtlZEljb24gPSAoKSA9PiAoXG4gIDxnPlxuICAgIDxjaXJjbGUgY3g9XCIxMlwiIGN5PVwiMTJcIiByPVwiMTBcIiBzdHJva2VXaWR0aD1cIjJcIiAvPlxuICAgIDxJbm5lckNpcmNsZVJpbmcgY3g9XCIxMlwiIGN5PVwiMTJcIiByPVwiOFwiIC8+XG4gICAgPFJhZGlvTWFyayBjeD1cIjEyXCIgY3k9XCIxMlwiIHI9XCI1XCIgLz5cbiAgPC9nPlxuKVxuXG5jb25zdCBSaW5nID0gc3R5bGVkLnN2Z2BcbiAgaGVpZ2h0OiAke1NJWkV9cHg7XG4gIHdpZHRoOiAke1NJWkV9cHg7XG4gIG1pbi13aWR0aDogJHtTSVpFfXB4O1xuICBtaW4taGVpZ2h0OiAke1NJWkV9cHg7XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuY2lyY2xlfTtcbiAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICAke0lubmVyQ2lyY2xlUmluZ30ge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH07XG4gIH1cbmBcblxuY29uc3QgUmFkaW9JbnB1dCA9IHN0eWxlZC5pbnB1dGBcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIGhlaWdodDogJHtTSVpFfXB4O1xuICB3aWR0aDogJHtTSVpFfXB4O1xuICBvcGFjaXR5OiAwO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBib3JkZXItd2lkdGg6IDA7XG4gICYgKyAke1Jpbmd9IHtcbiAgICAke1JhZGlvTWFya30ge1xuICAgICAgdHJhbnNmb3JtLW9yaWdpbjogY2VudGVyO1xuICAgICAgdHJhbnNpdGlvbjogMjAwbXMgdHJhbnNmb3JtIGVhc2UtaW4tb3V0O1xuICAgICAgdHJhbnNmb3JtOiBzY2FsZSgwKTtcbiAgICB9XG4gIH1cblxuICAmOmNoZWNrZWQgKyBzdmcge1xuICAgICR7UmFkaW9NYXJrfSB7XG4gICAgICB0cmFuc2Zvcm06IHNjYWxlKDEpO1xuICAgIH1cbiAgfVxuXG4gICY6Y2hlY2tlZFthcmlhLWRpc2FibGVkPSdmYWxzZSddW2FyaWEtaW52YWxpZD0nZmFsc2UnXSArICR7UmluZ30ge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ307XG4gIH1cblxuICAmOmNoZWNrZWRbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddW2FyaWEtaW52YWxpZD0nZmFsc2UnXSArICR7UmluZ30ge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYm9yZGVyRGlzYWJsZWR9O1xuICB9XG5cbiAgJlthcmlhLWludmFsaWQ9J3RydWUnXTpub3QoW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSkgKyAke1Jpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5kYW5nZXIuYmFja2dyb3VuZFN0cm9uZ307XG4gIH1cblxuICAmW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ106YWN0aXZlICsgJHtSaW5nfSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogIzVlMTI3ZTQwO1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZH07XG4gICAgfVxuICB9XG5cbiAgJlthcmlhLWRpc2FibGVkPSdmYWxzZSddOmZvY3VzLXZpc2libGUgKyAke1Jpbmd9IHtcbiAgICBvdXRsaW5lOiAtd2Via2l0LWZvY3VzLXJpbmctY29sb3IgYXV0byAxcHg7XG4gIH1cblxuICAmW2FyaWEtaW52YWxpZD0ndHJ1ZSddOmZvY3VzICsgJHtSaW5nfSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogI2Y5MWI2YzQwO1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgICAke0lubmVyQ2lyY2xlUmluZ30ge1xuICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMuZGFuZ2VyLmJhY2tncm91bmR9O1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBSYWRpb0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcblxuICAmW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ10sXG4gICZbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXSA+IGxhYmVsIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gIH1cblxuICA6aG92ZXJbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXSB7XG4gICAgJHtSYWRpb0lucHV0fSArICR7UmluZ30ge1xuICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeS5ib3JkZXJ9O1xuICAgICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeS5iYWNrZ3JvdW5kSG92ZXJ9O1xuICAgICAgfVxuICAgIH1cblxuICAgICR7UmFkaW9JbnB1dH1bYXJpYS1pbnZhbGlkPSd0cnVlJ10gKyAke1Jpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5ib3JkZXJ9O1xuICAgICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMuZGFuZ2VyLmJhY2tncm91bmRIb3Zlcn07XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgJlthcmlhLWRpc2FibGVkPSd0cnVlJ10ge1xuICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dERpc2FibGVkfTtcblxuICAgICYgPiBsYWJlbCxcbiAgICAke1JhZGlvSW5wdXR9IHtcbiAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgfVxuXG4gICAgJHtSaW5nfSB7XG4gICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+
|
|
22
|
+
})(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/Radio/index.tsx"],"names":[],"mappings":"AAU+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
|
|
23
23
|
const RadioStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
24
|
-
target: "
|
|
24
|
+
target: "ehkrmld6"
|
|
25
25
|
} : {
|
|
26
|
-
target: "
|
|
26
|
+
target: "ehkrmld6",
|
|
27
27
|
label: "RadioStack"
|
|
28
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZdUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW8vaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEZvcndhcmRlZFJlZiwgSW5wdXRIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmLCB1c2VJZCB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFNJWkUgPSAyNFxuXG5jb25zdCBJbm5lckNpcmNsZVJpbmcgPSBzdHlsZWQuY2lyY2xlYGBcbmNvbnN0IFJhZGlvTWFyayA9IHN0eWxlZC5jaXJjbGVgYFxuXG5leHBvcnQgY29uc3QgUmFkaW9TdGFjayA9IHN0eWxlZChTdGFjaylgYFxuXG5jb25zdCBSYWRpb01hcmtlZEljb24gPSAoKSA9PiAoXG4gIDxnPlxuICAgIDxjaXJjbGUgY3g9XCIxMlwiIGN5PVwiMTJcIiByPVwiMTBcIiBzdHJva2VXaWR0aD1cIjJcIiAvPlxuICAgIDxJbm5lckNpcmNsZVJpbmcgY3g9XCIxMlwiIGN5PVwiMTJcIiByPVwiOFwiIC8+XG4gICAgPFJhZGlvTWFyayBjeD1cIjEyXCIgY3k9XCIxMlwiIHI9XCI1XCIgLz5cbiAgPC9nPlxuKVxuXG5jb25zdCBSaW5nID0gc3R5bGVkLnN2Z2BcbiAgaGVpZ2h0OiAke1NJWkV9cHg7XG4gIHdpZHRoOiAke1NJWkV9cHg7XG4gIG1pbi13aWR0aDogJHtTSVpFfXB4O1xuICBtaW4taGVpZ2h0OiAke1NJWkV9cHg7XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuY2lyY2xlfTtcbiAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICAke0lubmVyQ2lyY2xlUmluZ30ge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH07XG4gIH1cbmBcblxuY29uc3QgUmFkaW9JbnB1dCA9IHN0eWxlZC5pbnB1dGBcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIGhlaWdodDogJHtTSVpFfXB4O1xuICB3aWR0aDogJHtTSVpFfXB4O1xuICBvcGFjaXR5OiAwO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBib3JkZXItd2lkdGg6IDA7XG4gICYgKyAke1Jpbmd9IHtcbiAgICAke1JhZGlvTWFya30ge1xuICAgICAgdHJhbnNmb3JtLW9yaWdpbjogY2VudGVyO1xuICAgICAgdHJhbnNpdGlvbjogMjAwbXMgdHJhbnNmb3JtIGVhc2UtaW4tb3V0O1xuICAgICAgdHJhbnNmb3JtOiBzY2FsZSgwKTtcbiAgICB9XG4gIH1cblxuICAmOmNoZWNrZWQgKyBzdmcge1xuICAgICR7UmFkaW9NYXJrfSB7XG4gICAgICB0cmFuc2Zvcm06IHNjYWxlKDEpO1xuICAgIH1cbiAgfVxuXG4gICY6Y2hlY2tlZFthcmlhLWRpc2FibGVkPSdmYWxzZSddW2FyaWEtaW52YWxpZD0nZmFsc2UnXSArICR7UmluZ30ge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ307XG4gIH1cblxuICAmOmNoZWNrZWRbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddW2FyaWEtaW52YWxpZD0nZmFsc2UnXSArICR7UmluZ30ge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYm9yZGVyRGlzYWJsZWR9O1xuICB9XG5cbiAgJlthcmlhLWludmFsaWQ9J3RydWUnXTpub3QoW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSkgKyAke1Jpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5kYW5nZXIuYmFja2dyb3VuZFN0cm9uZ307XG4gIH1cblxuICAmW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ106YWN0aXZlICsgJHtSaW5nfSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogIzVlMTI3ZTQwO1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZH07XG4gICAgfVxuICB9XG5cbiAgJlthcmlhLWRpc2FibGVkPSdmYWxzZSddOmZvY3VzLXZpc2libGUgKyAke1Jpbmd9IHtcbiAgICBvdXRsaW5lOiAtd2Via2l0LWZvY3VzLXJpbmctY29sb3IgYXV0byAxcHg7XG4gIH1cblxuICAmW2FyaWEtaW52YWxpZD0ndHJ1ZSddOmZvY3VzICsgJHtSaW5nfSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogI2Y5MWI2YzQwO1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgICAke0lubmVyQ2lyY2xlUmluZ30ge1xuICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMuZGFuZ2VyLmJhY2tncm91bmR9O1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBSYWRpb0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcblxuICAmW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ10sXG4gICZbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXSA+IGxhYmVsIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gIH1cblxuICA6aG92ZXJbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXSB7XG4gICAgJHtSYWRpb0lucHV0fSArICR7UmluZ30ge1xuICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeS5ib3JkZXJ9O1xuICAgICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeS5iYWNrZ3JvdW5kSG92ZXJ9O1xuICAgICAgfVxuICAgIH1cblxuICAgICR7UmFkaW9JbnB1dH1bYXJpYS1pbnZhbGlkPSd0cnVlJ10gKyAke1Jpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5ib3JkZXJ9O1xuICAgICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMuZGFuZ2VyLmJhY2tncm91bmRIb3Zlcn07XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgJlthcmlhLWRpc2FibGVkPSd0cnVlJ10ge1xuICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dERpc2FibGVkfTtcblxuICAgICYgPiBsYWJlbCxcbiAgICAke1JhZGlvSW5wdXR9IHtcbiAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgfVxuXG4gICAgJHtSaW5nfSB7XG4gICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+
|
|
28
|
+
})(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/Radio/index.tsx"],"names":[],"mappings":"AAYuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
|
|
29
29
|
const RadioMarkedIcon = () => /* @__PURE__ */ jsxs("g", { children: [
|
|
30
30
|
/* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "10", strokeWidth: "2" }),
|
|
31
31
|
/* @__PURE__ */ jsx(InnerCircleRing, { cx: "12", cy: "12", r: "8" }),
|
|
32
32
|
/* @__PURE__ */ jsx(RadioMark, { cx: "12", cy: "12", r: "5" })
|
|
33
33
|
] });
|
|
34
34
|
const Ring = /* @__PURE__ */ _styled("svg", process.env.NODE_ENV === "production" ? {
|
|
35
|
-
target: "
|
|
35
|
+
target: "ehkrmld5"
|
|
36
36
|
} : {
|
|
37
|
-
target: "
|
|
37
|
+
target: "ehkrmld5",
|
|
38
38
|
label: "Ring"
|
|
39
39
|
})("height:", SIZE, "px;width:", SIZE, "px;min-width:", SIZE, "px;min-height:", SIZE, "px;border-radius:", ({
|
|
40
40
|
theme
|
|
@@ -42,11 +42,11 @@ const Ring = /* @__PURE__ */ _styled("svg", process.env.NODE_ENV === "production
|
|
|
42
42
|
theme
|
|
43
43
|
}) => theme.colors.neutral.border, ";", InnerCircleRing, "{fill:", ({
|
|
44
44
|
theme
|
|
45
|
-
}) => theme.colors.neutral.background, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQnVCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBGb3J3YXJkZWRSZWYsIElucHV0SFRNTEF0dHJpYnV0ZXMsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgdXNlSWQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCB7IFRvb2x0aXAgfSBmcm9tICcuLi9Ub29sdGlwJ1xuXG5jb25zdCBTSVpFID0gMjRcblxuY29uc3QgSW5uZXJDaXJjbGVSaW5nID0gc3R5bGVkLmNpcmNsZWBgXG5jb25zdCBSYWRpb01hcmsgPSBzdHlsZWQuY2lyY2xlYGBcblxuZXhwb3J0IGNvbnN0IFJhZGlvU3RhY2sgPSBzdHlsZWQoU3RhY2spYGBcblxuY29uc3QgUmFkaW9NYXJrZWRJY29uID0gKCkgPT4gKFxuICA8Zz5cbiAgICA8Y2lyY2xlIGN4PVwiMTJcIiBjeT1cIjEyXCIgcj1cIjEwXCIgc3Ryb2tlV2lkdGg9XCIyXCIgLz5cbiAgICA8SW5uZXJDaXJjbGVSaW5nIGN4PVwiMTJcIiBjeT1cIjEyXCIgcj1cIjhcIiAvPlxuICAgIDxSYWRpb01hcmsgY3g9XCIxMlwiIGN5PVwiMTJcIiByPVwiNVwiIC8+XG4gIDwvZz5cbilcblxuY29uc3QgUmluZyA9IHN0eWxlZC5zdmdgXG4gIGhlaWdodDogJHtTSVpFfXB4O1xuICB3aWR0aDogJHtTSVpFfXB4O1xuICBtaW4td2lkdGg6ICR7U0laRX1weDtcbiAgbWluLWhlaWdodDogJHtTSVpFfXB4O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmNpcmNsZX07XG4gIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcbiAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICB9XG5gXG5cbmNvbnN0IFJhZGlvSW5wdXQgPSBzdHlsZWQuaW5wdXRgXG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBoZWlnaHQ6ICR7U0laRX1weDtcbiAgd2lkdGg6ICR7U0laRX1weDtcbiAgb3BhY2l0eTogMDtcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgYm9yZGVyLXdpZHRoOiAwO1xuICAmICsgJHtSaW5nfSB7XG4gICAgJHtSYWRpb01hcmt9IHtcbiAgICAgIHRyYW5zZm9ybS1vcmlnaW46IGNlbnRlcjtcbiAgICAgIHRyYW5zaXRpb246IDIwMG1zIHRyYW5zZm9ybSBlYXNlLWluLW91dDtcbiAgICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gICAgfVxuICB9XG5cbiAgJjpjaGVja2VkICsgc3ZnIHtcbiAgICAke1JhZGlvTWFya30ge1xuICAgICAgdHJhbnNmb3JtOiBzY2FsZSgxKTtcbiAgICB9XG4gIH1cblxuICAmOmNoZWNrZWRbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXVthcmlhLWludmFsaWQ9J2ZhbHNlJ10gKyAke1Jpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9O1xuICB9XG5cbiAgJjpjaGVja2VkW2FyaWEtZGlzYWJsZWQ9J3RydWUnXVthcmlhLWludmFsaWQ9J2ZhbHNlJ10gKyAke1Jpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJvcmRlckRpc2FibGVkfTtcbiAgfVxuXG4gICZbYXJpYS1pbnZhbGlkPSd0cnVlJ106bm90KFthcmlhLWRpc2FibGVkPSd0cnVlJ10pICsgJHtSaW5nfSB7XG4gICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMuZGFuZ2VyLmJhY2tncm91bmRTdHJvbmd9O1xuICB9XG5cbiAgJlthcmlhLWRpc2FibGVkPSdmYWxzZSddOmFjdGl2ZSArICR7UmluZ30ge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICM1ZTEyN2U0MDtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9O1xuICAgICR7SW5uZXJDaXJjbGVSaW5nfSB7XG4gICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgIH1cbiAgfVxuXG4gICZbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXTpmb2N1cy12aXNpYmxlICsgJHtSaW5nfSB7XG4gICAgb3V0bGluZTogLXdlYmtpdC1mb2N1cy1yaW5nLWNvbG9yIGF1dG8gMXB4O1xuICB9XG5cbiAgJlthcmlhLWludmFsaWQ9J3RydWUnXTpmb2N1cyArICR7UmluZ30ge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICNmOTFiNmM0MDtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5kYW5nZXIuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5iYWNrZ3JvdW5kfTtcbiAgICB9XG4gIH1cbmBcblxuY29uc3QgUmFkaW9Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGFsaWduLWl0ZW1zOiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5cbiAgJlthcmlhLWRpc2FibGVkPSdmYWxzZSddLFxuICAmW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ10gPiBsYWJlbCB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICB9XG5cbiAgOmhvdmVyW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ10ge1xuICAgICR7UmFkaW9JbnB1dH0gKyAke1Jpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYm9yZGVyfTtcbiAgICAgICR7SW5uZXJDaXJjbGVSaW5nfSB7XG4gICAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZEhvdmVyfTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICAke1JhZGlvSW5wdXR9W2FyaWEtaW52YWxpZD0ndHJ1ZSddICsgJHtSaW5nfSB7XG4gICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5kYW5nZXIuYm9yZGVyfTtcbiAgICAgICR7SW5uZXJDaXJjbGVSaW5nfSB7XG4gICAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5iYWNrZ3JvdW5kSG92ZXJ9O1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gICZbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddIHtcbiAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHREaXNhYmxlZH07XG5cbiAgICAmID4gbGFiZWwsXG4gICAgJHtSYWRpb0lucHV0fSB7XG4gICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgIH1cblxuICAgICR7UmluZ30ge1xuICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJEaXNhYmxlZH07XG4gICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuXG4gICAgICAke0lubmVyQ2lyY2xlUmluZ30ge1xuICAgICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+
|
|
45
|
+
}) => theme.colors.neutral.background, ";}" + (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/Radio/index.tsx"],"names":[],"mappings":"AAsBuB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
46
46
|
const RadioInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
|
|
47
|
-
target: "
|
|
47
|
+
target: "ehkrmld4"
|
|
48
48
|
} : {
|
|
49
|
-
target: "
|
|
49
|
+
target: "ehkrmld4",
|
|
50
50
|
label: "RadioInput"
|
|
51
51
|
})("cursor:pointer;position:absolute;height:", SIZE, "px;width:", SIZE, "px;opacity:0;white-space:nowrap;border-width:0;&+", Ring, "{", RadioMark, "{transform-origin:center;transition:200ms transform ease-in-out;transform:scale(0);}}&:checked+svg{", RadioMark, "{transform:scale(1);}}&:checked[aria-disabled='false'][aria-invalid='false']+", Ring, "{fill:", ({
|
|
52
52
|
theme
|
|
@@ -62,11 +62,11 @@ const RadioInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "pr
|
|
|
62
62
|
theme
|
|
63
63
|
}) => theme.colors.danger.backgroundStrong, ";", InnerCircleRing, "{fill:", ({
|
|
64
64
|
theme
|
|
65
|
-
}) => theme.colors.danger.background, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQytCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBGb3J3YXJkZWRSZWYsIElucHV0SFRNTEF0dHJpYnV0ZXMsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgdXNlSWQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCB7IFRvb2x0aXAgfSBmcm9tICcuLi9Ub29sdGlwJ1xuXG5jb25zdCBTSVpFID0gMjRcblxuY29uc3QgSW5uZXJDaXJjbGVSaW5nID0gc3R5bGVkLmNpcmNsZWBgXG5jb25zdCBSYWRpb01hcmsgPSBzdHlsZWQuY2lyY2xlYGBcblxuZXhwb3J0IGNvbnN0IFJhZGlvU3RhY2sgPSBzdHlsZWQoU3RhY2spYGBcblxuY29uc3QgUmFkaW9NYXJrZWRJY29uID0gKCkgPT4gKFxuICA8Zz5cbiAgICA8Y2lyY2xlIGN4PVwiMTJcIiBjeT1cIjEyXCIgcj1cIjEwXCIgc3Ryb2tlV2lkdGg9XCIyXCIgLz5cbiAgICA8SW5uZXJDaXJjbGVSaW5nIGN4PVwiMTJcIiBjeT1cIjEyXCIgcj1cIjhcIiAvPlxuICAgIDxSYWRpb01hcmsgY3g9XCIxMlwiIGN5PVwiMTJcIiByPVwiNVwiIC8+XG4gIDwvZz5cbilcblxuY29uc3QgUmluZyA9IHN0eWxlZC5zdmdgXG4gIGhlaWdodDogJHtTSVpFfXB4O1xuICB3aWR0aDogJHtTSVpFfXB4O1xuICBtaW4td2lkdGg6ICR7U0laRX1weDtcbiAgbWluLWhlaWdodDogJHtTSVpFfXB4O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmNpcmNsZX07XG4gIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcbiAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICB9XG5gXG5cbmNvbnN0IFJhZGlvSW5wdXQgPSBzdHlsZWQuaW5wdXRgXG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBoZWlnaHQ6ICR7U0laRX1weDtcbiAgd2lkdGg6ICR7U0laRX1weDtcbiAgb3BhY2l0eTogMDtcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgYm9yZGVyLXdpZHRoOiAwO1xuICAmICsgJHtSaW5nfSB7XG4gICAgJHtSYWRpb01hcmt9IHtcbiAgICAgIHRyYW5zZm9ybS1vcmlnaW46IGNlbnRlcjtcbiAgICAgIHRyYW5zaXRpb246IDIwMG1zIHRyYW5zZm9ybSBlYXNlLWluLW91dDtcbiAgICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gICAgfVxuICB9XG5cbiAgJjpjaGVja2VkICsgc3ZnIHtcbiAgICAke1JhZGlvTWFya30ge1xuICAgICAgdHJhbnNmb3JtOiBzY2FsZSgxKTtcbiAgICB9XG4gIH1cblxuICAmOmNoZWNrZWRbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXVthcmlhLWludmFsaWQ9J2ZhbHNlJ10gKyAke1Jpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9O1xuICB9XG5cbiAgJjpjaGVja2VkW2FyaWEtZGlzYWJsZWQ9J3RydWUnXVthcmlhLWludmFsaWQ9J2ZhbHNlJ10gKyAke1Jpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJvcmRlckRpc2FibGVkfTtcbiAgfVxuXG4gICZbYXJpYS1pbnZhbGlkPSd0cnVlJ106bm90KFthcmlhLWRpc2FibGVkPSd0cnVlJ10pICsgJHtSaW5nfSB7XG4gICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMuZGFuZ2VyLmJhY2tncm91bmRTdHJvbmd9O1xuICB9XG5cbiAgJlthcmlhLWRpc2FibGVkPSdmYWxzZSddOmFjdGl2ZSArICR7UmluZ30ge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICM1ZTEyN2U0MDtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9O1xuICAgICR7SW5uZXJDaXJjbGVSaW5nfSB7XG4gICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgIH1cbiAgfVxuXG4gICZbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXTpmb2N1cy12aXNpYmxlICsgJHtSaW5nfSB7XG4gICAgb3V0bGluZTogLXdlYmtpdC1mb2N1cy1yaW5nLWNvbG9yIGF1dG8gMXB4O1xuICB9XG5cbiAgJlthcmlhLWludmFsaWQ9J3RydWUnXTpmb2N1cyArICR7UmluZ30ge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICNmOTFiNmM0MDtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5kYW5nZXIuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5iYWNrZ3JvdW5kfTtcbiAgICB9XG4gIH1cbmBcblxuY29uc3QgUmFkaW9Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGFsaWduLWl0ZW1zOiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5cbiAgJlthcmlhLWRpc2FibGVkPSdmYWxzZSddLFxuICAmW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ10gPiBsYWJlbCB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICB9XG5cbiAgOmhvdmVyW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ10ge1xuICAgICR7UmFkaW9JbnB1dH0gKyAke1Jpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYm9yZGVyfTtcbiAgICAgICR7SW5uZXJDaXJjbGVSaW5nfSB7XG4gICAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZEhvdmVyfTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICAke1JhZGlvSW5wdXR9W2FyaWEtaW52YWxpZD0ndHJ1ZSddICsgJHtSaW5nfSB7XG4gICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5kYW5nZXIuYm9yZGVyfTtcbiAgICAgICR7SW5uZXJDaXJjbGVSaW5nfSB7XG4gICAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5iYWNrZ3JvdW5kSG92ZXJ9O1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gICZbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddIHtcbiAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHREaXNhYmxlZH07XG5cbiAgICAmID4gbGFiZWwsXG4gICAgJHtSYWRpb0lucHV0fSB7XG4gICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgIH1cblxuICAgICR7UmluZ30ge1xuICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJEaXNhYmxlZH07XG4gICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuXG4gICAgICAke0lubmVyQ2lyY2xlUmluZ30ge1xuICAgICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+
|
|
65
|
+
}) => theme.colors.danger.background, ";}}" + (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/Radio/index.tsx"],"names":[],"mappings":"AAkC+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
66
66
|
const RadioContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
67
|
-
target: "
|
|
67
|
+
target: "ehkrmld3"
|
|
68
68
|
} : {
|
|
69
|
-
target: "
|
|
69
|
+
target: "ehkrmld3",
|
|
70
70
|
label: "RadioContainer"
|
|
71
71
|
})("position:relative;display:flex;flex:1;align-items:flex-start;gap:", ({
|
|
72
72
|
theme
|
|
@@ -84,19 +84,33 @@ const RadioContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "
|
|
|
84
84
|
theme
|
|
85
85
|
}) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;", InnerCircleRing, "{fill:", ({
|
|
86
86
|
theme
|
|
87
|
-
}) => theme.colors.neutral.backgroundDisabled, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5RmlDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBGb3J3YXJkZWRSZWYsIElucHV0SFRNTEF0dHJpYnV0ZXMsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgdXNlSWQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCB7IFRvb2x0aXAgfSBmcm9tICcuLi9Ub29sdGlwJ1xuXG5jb25zdCBTSVpFID0gMjRcblxuY29uc3QgSW5uZXJDaXJjbGVSaW5nID0gc3R5bGVkLmNpcmNsZWBgXG5jb25zdCBSYWRpb01hcmsgPSBzdHlsZWQuY2lyY2xlYGBcblxuZXhwb3J0IGNvbnN0IFJhZGlvU3RhY2sgPSBzdHlsZWQoU3RhY2spYGBcblxuY29uc3QgUmFkaW9NYXJrZWRJY29uID0gKCkgPT4gKFxuICA8Zz5cbiAgICA8Y2lyY2xlIGN4PVwiMTJcIiBjeT1cIjEyXCIgcj1cIjEwXCIgc3Ryb2tlV2lkdGg9XCIyXCIgLz5cbiAgICA8SW5uZXJDaXJjbGVSaW5nIGN4PVwiMTJcIiBjeT1cIjEyXCIgcj1cIjhcIiAvPlxuICAgIDxSYWRpb01hcmsgY3g9XCIxMlwiIGN5PVwiMTJcIiByPVwiNVwiIC8+XG4gIDwvZz5cbilcblxuY29uc3QgUmluZyA9IHN0eWxlZC5zdmdgXG4gIGhlaWdodDogJHtTSVpFfXB4O1xuICB3aWR0aDogJHtTSVpFfXB4O1xuICBtaW4td2lkdGg6ICR7U0laRX1weDtcbiAgbWluLWhlaWdodDogJHtTSVpFfXB4O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmNpcmNsZX07XG4gIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcbiAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICB9XG5gXG5cbmNvbnN0IFJhZGlvSW5wdXQgPSBzdHlsZWQuaW5wdXRgXG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBoZWlnaHQ6ICR7U0laRX1weDtcbiAgd2lkdGg6ICR7U0laRX1weDtcbiAgb3BhY2l0eTogMDtcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgYm9yZGVyLXdpZHRoOiAwO1xuICAmICsgJHtSaW5nfSB7XG4gICAgJHtSYWRpb01hcmt9IHtcbiAgICAgIHRyYW5zZm9ybS1vcmlnaW46IGNlbnRlcjtcbiAgICAgIHRyYW5zaXRpb246IDIwMG1zIHRyYW5zZm9ybSBlYXNlLWluLW91dDtcbiAgICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gICAgfVxuICB9XG5cbiAgJjpjaGVja2VkICsgc3ZnIHtcbiAgICAke1JhZGlvTWFya30ge1xuICAgICAgdHJhbnNmb3JtOiBzY2FsZSgxKTtcbiAgICB9XG4gIH1cblxuICAmOmNoZWNrZWRbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXVthcmlhLWludmFsaWQ9J2ZhbHNlJ10gKyAke1Jpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9O1xuICB9XG5cbiAgJjpjaGVja2VkW2FyaWEtZGlzYWJsZWQ9J3RydWUnXVthcmlhLWludmFsaWQ9J2ZhbHNlJ10gKyAke1Jpbmd9IHtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJvcmRlckRpc2FibGVkfTtcbiAgfVxuXG4gICZbYXJpYS1pbnZhbGlkPSd0cnVlJ106bm90KFthcmlhLWRpc2FibGVkPSd0cnVlJ10pICsgJHtSaW5nfSB7XG4gICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMuZGFuZ2VyLmJhY2tncm91bmRTdHJvbmd9O1xuICB9XG5cbiAgJlthcmlhLWRpc2FibGVkPSdmYWxzZSddOmFjdGl2ZSArICR7UmluZ30ge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICM1ZTEyN2U0MDtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9O1xuICAgICR7SW5uZXJDaXJjbGVSaW5nfSB7XG4gICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgIH1cbiAgfVxuXG4gICZbYXJpYS1kaXNhYmxlZD0nZmFsc2UnXTpmb2N1cy12aXNpYmxlICsgJHtSaW5nfSB7XG4gICAgb3V0bGluZTogLXdlYmtpdC1mb2N1cy1yaW5nLWNvbG9yIGF1dG8gMXB4O1xuICB9XG5cbiAgJlthcmlhLWludmFsaWQ9J3RydWUnXTpmb2N1cyArICR7UmluZ30ge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICNmOTFiNmM0MDtcbiAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5kYW5nZXIuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgJHtJbm5lckNpcmNsZVJpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5iYWNrZ3JvdW5kfTtcbiAgICB9XG4gIH1cbmBcblxuY29uc3QgUmFkaW9Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGFsaWduLWl0ZW1zOiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5cbiAgJlthcmlhLWRpc2FibGVkPSdmYWxzZSddLFxuICAmW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ10gPiBsYWJlbCB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICB9XG5cbiAgOmhvdmVyW2FyaWEtZGlzYWJsZWQ9J2ZhbHNlJ10ge1xuICAgICR7UmFkaW9JbnB1dH0gKyAke1Jpbmd9IHtcbiAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYm9yZGVyfTtcbiAgICAgICR7SW5uZXJDaXJjbGVSaW5nfSB7XG4gICAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZEhvdmVyfTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICAke1JhZGlvSW5wdXR9W2FyaWEtaW52YWxpZD0ndHJ1ZSddICsgJHtSaW5nfSB7XG4gICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5kYW5nZXIuYm9yZGVyfTtcbiAgICAgICR7SW5uZXJDaXJjbGVSaW5nfSB7XG4gICAgICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLmRhbmdlci5iYWNrZ3JvdW5kSG92ZXJ9O1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gICZbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddIHtcbiAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHREaXNhYmxlZH07XG5cbiAgICAmID4gbGFiZWwsXG4gICAgJHtSYWRpb0lucHV0fSB7XG4gICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgIH1cblxuICAgICR7UmluZ30ge1xuICAgICAgZmlsbDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJEaXNhYmxlZH07XG4gICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuXG4gICAgICAke0lubmVyQ2lyY2xlUmluZ30ge1xuICAgICAgICBmaWxsOiAkeyh7IHRoZW1lIH0pID0+
|
|
87
|
+
}) => theme.colors.neutral.backgroundDisabled, ";}}}" + (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/Radio/index.tsx"],"names":[],"mappings":"AAyFiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
88
88
|
const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "production" ? {
|
|
89
|
+
target: "ehkrmld2"
|
|
90
|
+
} : {
|
|
91
|
+
target: "ehkrmld2",
|
|
92
|
+
label: "StyledLabel"
|
|
93
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
94
|
+
name: "1co5109",
|
|
95
|
+
styles: "flex:1;cursor:pointer"
|
|
96
|
+
} : {
|
|
97
|
+
name: "1co5109",
|
|
98
|
+
styles: "flex:1;cursor:pointer",
|
|
99
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAyIgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
|
|
100
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
101
|
+
});
|
|
102
|
+
const StyledTextLabel = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
89
103
|
target: "ehkrmld1"
|
|
90
104
|
} : {
|
|
91
105
|
target: "ehkrmld1",
|
|
92
|
-
label: "
|
|
106
|
+
label: "StyledTextLabel"
|
|
93
107
|
})(process.env.NODE_ENV === "production" ? {
|
|
94
|
-
name: "
|
|
95
|
-
styles: "flex:1"
|
|
108
|
+
name: "1co5109",
|
|
109
|
+
styles: "flex:1;cursor:pointer"
|
|
96
110
|
} : {
|
|
97
|
-
name: "
|
|
98
|
-
styles: "flex:1",
|
|
99
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
111
|
+
name: "1co5109",
|
|
112
|
+
styles: "flex:1;cursor:pointer",
|
|
113
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AA8IoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
|
|
100
114
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
101
115
|
});
|
|
102
116
|
const MargedText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
@@ -106,7 +120,7 @@ const MargedText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "produ
|
|
|
106
120
|
label: "MargedText"
|
|
107
121
|
})("margin-left:", ({
|
|
108
122
|
theme
|
|
109
|
-
}) => theme.space["4"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
123
|
+
}) => theme.space["4"], ";" + (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/Radio/index.tsx"],"names":[],"mappings":"AAmJ+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
|
|
110
124
|
const Radio = forwardRef(({
|
|
111
125
|
checked = false,
|
|
112
126
|
onChange,
|
|
@@ -132,11 +146,7 @@ const Radio = forwardRef(({
|
|
|
132
146
|
/* @__PURE__ */ jsxs(RadioContainer, { "aria-disabled": disabled, className, "data-checked": checked, "data-error": error, "data-testid": dataTestId, children: [
|
|
133
147
|
/* @__PURE__ */ jsx(RadioInput, { type: "radio", "aria-invalid": !!error, "aria-disabled": disabled, "aria-label": ariaLabel, checked, id: `${computedName}-${value}`, onChange, onFocus, onKeyDown, onBlur, value, disabled, name: computedName, autoFocus, ref, tabIndex }),
|
|
134
148
|
/* @__PURE__ */ jsx(Ring, { viewBox: "0 0 24 24", children: /* @__PURE__ */ jsx(RadioMarkedIcon, {}) }),
|
|
135
|
-
label ? /* @__PURE__ */ jsx(
|
|
136
|
-
" ",
|
|
137
|
-
label,
|
|
138
|
-
" "
|
|
139
|
-
] }) : label }) : null
|
|
149
|
+
label ? /* @__PURE__ */ jsx(Fragment, { children: typeof label === "string" ? /* @__PURE__ */ jsx(StyledTextLabel, { as: "label", variant: "body", prominence: "default", htmlFor: `${computedName}-${value}`, children: label }) : /* @__PURE__ */ jsx(StyledLabel, { htmlFor: `${computedName}-${value}`, children: label }) }) : null
|
|
140
150
|
] }),
|
|
141
151
|
helper ? /* @__PURE__ */ jsx(MargedText, { as: "span", variant: "caption", prominence: "weak", sentiment: "neutral", children: helper }) : null
|
|
142
152
|
] }) });
|
|
@@ -5,10 +5,10 @@ const _styled = require("@emotion/styled/base");
|
|
|
5
5
|
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
6
6
|
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
7
7
|
const StyledRow = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
8
|
-
shouldForwardProp: (prop) => !["templateColumns", "gap", "alignItems", "justifyContent"].includes(prop),
|
|
8
|
+
shouldForwardProp: (prop) => !["templateColumns", "gap", "alignItems", "justifyContent", "padding"].includes(prop),
|
|
9
9
|
target: "e3f5lzv0"
|
|
10
10
|
} : {
|
|
11
|
-
shouldForwardProp: (prop) => !["templateColumns", "gap", "alignItems", "justifyContent"].includes(prop),
|
|
11
|
+
shouldForwardProp: (prop) => !["templateColumns", "gap", "alignItems", "justifyContent", "padding"].includes(prop),
|
|
12
12
|
target: "e3f5lzv0",
|
|
13
13
|
label: "StyledRow"
|
|
14
14
|
})("display:grid;", ({
|
|
@@ -16,13 +16,15 @@ const StyledRow = /* @__PURE__ */ _styled__default.default("div", process.env.NO
|
|
|
16
16
|
gap,
|
|
17
17
|
alignItems = "normal",
|
|
18
18
|
templateColumns,
|
|
19
|
-
justifyContent = "normal"
|
|
19
|
+
justifyContent = "normal",
|
|
20
|
+
padding
|
|
20
21
|
}) => `
|
|
21
22
|
grid-template-columns: ${templateColumns};
|
|
22
23
|
${gap ? `gap: ${theme.space[gap]};` : ""}
|
|
23
24
|
align-items: ${alignItems};
|
|
24
25
|
justify-content: ${justifyContent};
|
|
25
|
-
|
|
26
|
+
${padding ? `padding: ${padding};` : ""}
|
|
27
|
+
`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1Jvdy9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0JrQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Sb3cvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENTU1Byb3BlcnRpZXMsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBVbHRyYXZpb2xldFVJVGhlbWUgfSBmcm9tICcuLi8uLi90aGVtZSdcblxudHlwZSBTdHlsZWRSb3dQcm9wcyA9IFBpY2s8XG4gIFJvd1Byb3BzLFxuICAnZ2FwJyB8ICd0ZW1wbGF0ZUNvbHVtbnMnIHwgJ2FsaWduSXRlbXMnIHwgJ2p1c3RpZnlDb250ZW50JyB8ICdwYWRkaW5nJ1xuPlxuXG5leHBvcnQgY29uc3QgU3R5bGVkUm93ID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVtcbiAgICAgICd0ZW1wbGF0ZUNvbHVtbnMnLFxuICAgICAgJ2dhcCcsXG4gICAgICAnYWxpZ25JdGVtcycsXG4gICAgICAnanVzdGlmeUNvbnRlbnQnLFxuICAgICAgJ3BhZGRpbmcnLFxuICAgIF0uaW5jbHVkZXMocHJvcCksXG59KTxTdHlsZWRSb3dQcm9wcz5gXG4gIGRpc3BsYXk6IGdyaWQ7XG4gICR7KHtcbiAgICB0aGVtZSxcbiAgICBnYXAsXG4gICAgYWxpZ25JdGVtcyA9ICdub3JtYWwnLFxuICAgIHRlbXBsYXRlQ29sdW1ucyxcbiAgICBqdXN0aWZ5Q29udGVudCA9ICdub3JtYWwnLFxuICAgIHBhZGRpbmcsXG4gIH0pID0+IGBcbiAgICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6ICR7dGVtcGxhdGVDb2x1bW5zfTtcbiAgICAke1xuICAgICAgZ2FwXG4gICAgICAgID8gYGdhcDogJHt0aGVtZS5zcGFjZVtnYXAgYXMga2V5b2YgVWx0cmF2aW9sZXRVSVRoZW1lWydzcGFjZSddXX07YFxuICAgICAgICA6ICcnXG4gICAgfVxuICAgIGFsaWduLWl0ZW1zOiAke2FsaWduSXRlbXN9O1xuICAgIGp1c3RpZnktY29udGVudDogJHtqdXN0aWZ5Q29udGVudH07XG4gICAgJHtwYWRkaW5nID8gYHBhZGRpbmc6ICR7cGFkZGluZ307YCA6ICcnfVxuICBgfVxuYFxuXG50eXBlIFJvd1Byb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHRlbXBsYXRlQ29sdW1uczogc3RyaW5nXG4gIGdhcD86IGtleW9mIFVsdHJhdmlvbGV0VUlUaGVtZVsnc3BhY2UnXSB8IG51bWJlclxuICBhbGlnbkl0ZW1zPzogQ1NTUHJvcGVydGllc1snYWxpZ25JdGVtcyddXG4gIGp1c3RpZnlDb250ZW50PzogQ1NTUHJvcGVydGllc1snanVzdGlmeUNvbnRlbnQnXVxuICBwYWRkaW5nPzogQ1NTUHJvcGVydGllc1sncGFkZGluZyddXG59XG5cbi8qKlxuICogUm93IGNvbXBvbmVudCBpcyBhIHdyYXBwZXIgZm9yIGdyaWQgbGF5b3V0LlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIGNvbXBvbmVudCBpcyBleHBlcmltZW50YWwgYW5kIG1heSBiZSBzdWJqZWN0IHRvIGJyZWFraW5nIGNoYW5nZXMgaW4gdGhlIGZ1dHVyZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFJvdyA9ICh7XG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgY2hpbGRyZW4sXG4gIHRlbXBsYXRlQ29sdW1ucyxcbiAgYWxpZ25JdGVtcyxcbiAganVzdGlmeUNvbnRlbnQsXG4gIGdhcCxcbiAgcGFkZGluZyxcbn06IFJvd1Byb3BzKSA9PiAoXG4gIDxTdHlsZWRSb3dcbiAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICBnYXA9e2dhcH1cbiAgICB0ZW1wbGF0ZUNvbHVtbnM9e3RlbXBsYXRlQ29sdW1uc31cbiAgICBhbGlnbkl0ZW1zPXthbGlnbkl0ZW1zfVxuICAgIGp1c3RpZnlDb250ZW50PXtqdXN0aWZ5Q29udGVudH1cbiAgICBwYWRkaW5nPXtwYWRkaW5nfVxuICA+XG4gICAge2NoaWxkcmVufVxuICA8L1N0eWxlZFJvdz5cbilcbiJdfQ== */"));
|
|
26
28
|
const Row = ({
|
|
27
29
|
className,
|
|
28
30
|
"data-testid": dataTestId,
|
|
@@ -30,7 +32,8 @@ const Row = ({
|
|
|
30
32
|
templateColumns,
|
|
31
33
|
alignItems,
|
|
32
34
|
justifyContent,
|
|
33
|
-
gap
|
|
34
|
-
|
|
35
|
+
gap,
|
|
36
|
+
padding
|
|
37
|
+
}) => /* @__PURE__ */ jsxRuntime.jsx(StyledRow, { className, "data-testid": dataTestId, gap, templateColumns, alignItems, justifyContent, padding, children });
|
|
35
38
|
exports.Row = Row;
|
|
36
39
|
exports.StyledRow = StyledRow;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { CSSProperties, ReactNode } from 'react';
|
|
2
2
|
import type { UltravioletUITheme } from '../../theme';
|
|
3
|
-
type StyledRowProps = Pick<RowProps, 'gap' | 'templateColumns' | 'alignItems' | 'justifyContent'>;
|
|
3
|
+
type StyledRowProps = Pick<RowProps, 'gap' | 'templateColumns' | 'alignItems' | 'justifyContent' | 'padding'>;
|
|
4
4
|
export declare const StyledRow: import("@emotion/styled").StyledComponent<{
|
|
5
5
|
theme?: import("@emotion/react").Theme;
|
|
6
6
|
as?: React.ElementType;
|
|
@@ -13,10 +13,11 @@ type RowProps = {
|
|
|
13
13
|
gap?: keyof UltravioletUITheme['space'] | number;
|
|
14
14
|
alignItems?: CSSProperties['alignItems'];
|
|
15
15
|
justifyContent?: CSSProperties['justifyContent'];
|
|
16
|
+
padding?: CSSProperties['padding'];
|
|
16
17
|
};
|
|
17
18
|
/**
|
|
18
19
|
* Row component is a wrapper for grid layout.
|
|
19
20
|
* @experimental This component is experimental and may be subject to breaking changes in the future.
|
|
20
21
|
*/
|
|
21
|
-
export declare const Row: ({ className, "data-testid": dataTestId, children, templateColumns, alignItems, justifyContent, gap, }: RowProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
22
|
+
export declare const Row: ({ className, "data-testid": dataTestId, children, templateColumns, alignItems, justifyContent, gap, padding, }: RowProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
22
23
|
export {};
|