@ultraviolet/ui 2.0.0-beta.13 → 2.0.0-beta.14
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/Card/index.cjs +4 -5
- package/dist/components/Card/index.d.ts +0 -4
- package/dist/components/Card/index.js +4 -5
- package/dist/components/Checkbox/index.cjs +35 -53
- package/dist/components/Checkbox/index.d.ts +0 -8
- package/dist/components/Checkbox/index.js +27 -45
- package/dist/components/CopyButton/index.cjs +1 -2
- package/dist/components/CopyButton/index.d.ts +1 -5
- package/dist/components/CopyButton/index.js +1 -2
- package/dist/components/Link/index.cjs +6 -5
- package/dist/components/Link/index.d.ts +1 -0
- package/dist/components/Link/index.js +6 -5
- package/dist/components/SelectInput/SelectInputProvider.cjs +8 -8
- package/dist/components/SelectInput/SelectInputProvider.d.ts +2 -1
- package/dist/components/SelectInput/SelectInputProvider.js +8 -8
- package/dist/components/SelectInput/index.cjs +5 -4
- package/dist/components/SelectInput/index.d.ts +6 -1
- package/dist/components/SelectInput/index.js +5 -4
- package/dist/components/Skeleton/Slider.cjs +3 -3
- package/dist/components/Skeleton/Slider.js +3 -3
- package/dist/components/SwitchButton/Option.cjs +25 -4
- package/dist/components/SwitchButton/Option.d.ts +4 -2
- package/dist/components/SwitchButton/Option.js +25 -4
- package/dist/components/SwitchButton/index.cjs +1 -1
- package/dist/components/SwitchButton/index.d.ts +3 -1
- package/dist/components/SwitchButton/index.js +1 -1
- package/package.json +1 -1
|
@@ -21,7 +21,7 @@ const SelectInputContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV
|
|
|
21
21
|
styles: "width:100%"
|
|
22
22
|
} : {
|
|
23
23
|
name: "1d3w5wq",
|
|
24
|
-
styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx"],"names":[],"mappings":"AAuIuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */",
|
|
24
|
+
styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx"],"names":[],"mappings":"AA4IuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n  /**\n   * Allow to specify a callback called when option dropdown is open\n   * Please wrap that definition in useCallback\n   */\n  onOpen?: () => void\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n  onOpen,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n      onOpen={onOpen}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */",
|
|
25
25
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
26
26
|
});
|
|
27
27
|
const HelperText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
@@ -31,7 +31,7 @@ const HelperText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "produ
|
|
|
31
31
|
label: "HelperText"
|
|
32
32
|
})("padding-top:", ({
|
|
33
33
|
theme
|
|
34
|
-
}) => theme.space["0.5"], ";" + (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/SelectInput/index.tsx"],"names":[],"mappings":"AA0I+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */"));
|
|
34
|
+
}) => theme.space["0.5"], ";" + (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/SelectInput/index.tsx"],"names":[],"mappings":"AA+I+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n  /**\n   * Allow to specify a callback called when option dropdown is open\n   * Please wrap that definition in useCallback\n   */\n  onOpen?: () => void\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n  onOpen,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n      onOpen={onOpen}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */"));
|
|
35
35
|
const SelectInput = ({
|
|
36
36
|
name,
|
|
37
37
|
id,
|
|
@@ -68,14 +68,15 @@ const SelectInput = ({
|
|
|
68
68
|
selectAll,
|
|
69
69
|
selectAllGroup = false,
|
|
70
70
|
dropdownAlign,
|
|
71
|
-
portalTarget
|
|
71
|
+
portalTarget,
|
|
72
|
+
onOpen
|
|
72
73
|
}) => {
|
|
73
74
|
const localId = useId();
|
|
74
75
|
const finalId = id ?? localId;
|
|
75
76
|
const ref = useRef(null);
|
|
76
77
|
const numberOfOptions = Array.isArray(options) ? options.length : Object.values(options).reduce((acc, current) => acc + current.filter((option) => !option.disabled).length, 0);
|
|
77
78
|
const finalDataTestId = dataTestId ?? `select-input-${name ?? "name"}`;
|
|
78
|
-
return /* @__PURE__ */ jsx(SelectInputProvider, { options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, onChange, refSelect: ref, children: /* @__PURE__ */ jsxs(SelectInputContainer, { onBlur, onFocus, className, "aria-label": name, children: [
|
|
79
|
+
return /* @__PURE__ */ jsx(SelectInputProvider, { options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, onChange, refSelect: ref, onOpen, children: /* @__PURE__ */ jsxs(SelectInputContainer, { onBlur, onFocus, className, "aria-label": name, children: [
|
|
79
80
|
/* @__PURE__ */ jsx(Dropdown, { emptyState, descriptionDirection, searchable, placeholder: placeholderSearch, footer, refSelect: ref, loadMore, optionalInfoPlacement, isLoading, size, dropdownAlign, portalTarget, children: /* @__PURE__ */ jsxs(Stack, { gap: 0.5, "aria-label": ariaLabel, children: [
|
|
80
81
|
label || labelDescription ? /* @__PURE__ */ jsx(Label, { htmlFor: finalId, labelDescription, required, size, children: label }) : null,
|
|
81
82
|
/* @__PURE__ */ jsx(SelectBar, { size, "data-testid": finalDataTestId, clearable, readOnly, disabled, placeholder, success, error, autoFocus: autofocus, innerRef: ref, id: finalId, label, tooltip })
|
|
@@ -14,7 +14,7 @@ const StyledContainer = /* @__PURE__ */ _styled__default.default("div", process.
|
|
|
14
14
|
length
|
|
15
15
|
}) => length, ", 1fr);gap:", ({
|
|
16
16
|
theme
|
|
17
|
-
}) => theme.space["2"], ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSXNEIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBsZW5ndGg6IG51bWJlciB9PmBcbiAgaGVpZ2h0OiAxNy4zNzVyZW07XG4gIGRpc3BsYXk6IGdyaWQ7XG4gIGdyaWQtdGVtcGxhdGUtY29sdW1uczogcmVwZWF0KCR7KHsgbGVuZ3RoIH0pID0+IGxlbmd0aH0sIDFmcik7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gXG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQuZGl2YFxuICBib3JkZXI6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWt9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+
|
|
17
|
+
}) => theme.space["2"], ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSXNEIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBsZW5ndGg6IG51bWJlciB9PmBcbiAgaGVpZ2h0OiAxNy4zNzVyZW07XG4gIGRpc3BsYXk6IGdyaWQ7XG4gIGdyaWQtdGVtcGxhdGUtY29sdW1uczogcmVwZWF0KCR7KHsgbGVuZ3RoIH0pID0+IGxlbmd0aH0sIDFmcik7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gXG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQuZGl2YFxuICBib3JkZXI6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWt9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICB3aWR0aDogMTQuODc1cmVtO1xuICBoZWlnaHQ6IDE2LjM3NXJlbjtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmBcblxuY29uc3QgU3R5bGVkQmFubmVyID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMzMlO1xuYFxuXG5leHBvcnQgY29uc3QgU2xpZGVyID0gKHsgbGVuZ3RoID0gNCB9OiB7IGxlbmd0aD86IG51bWJlciB9KSA9PiAoXG4gIDxTdHlsZWRDb250YWluZXIgbGVuZ3RoPXtsZW5ndGh9PlxuICAgIHtBcnJheS5mcm9tKHsgbGVuZ3RoIH0sIChfLCBpKSA9PiAoXG4gICAgICA8U3R5bGVkQ2FyZCBrZXk9e2Bza2VsZXRvbi1zbGlkZXItY2FyZC0ke2l9YH0+XG4gICAgICAgIDxTdHlsZWRCYW5uZXIgLz5cbiAgICAgIDwvU3R5bGVkQ2FyZD5cbiAgICApKX1cbiAgPC9TdHlsZWRDb250YWluZXI+XG4pXG4iXX0= */"));
|
|
18
18
|
const StyledCard = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
19
19
|
target: "e1yrvvrg1"
|
|
20
20
|
} : {
|
|
@@ -24,7 +24,7 @@ const StyledCard = /* @__PURE__ */ _styled__default.default("div", process.env.N
|
|
|
24
24
|
theme
|
|
25
25
|
}) => theme.colors.neutral.borderWeak, ";border-radius:", ({
|
|
26
26
|
theme
|
|
27
|
-
}) => theme.radii.default, ";width:14.875rem
|
|
27
|
+
}) => theme.radii.default, ";width:14.875rem;height:16.375ren;overflow:hidden;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWTZCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBsZW5ndGg6IG51bWJlciB9PmBcbiAgaGVpZ2h0OiAxNy4zNzVyZW07XG4gIGRpc3BsYXk6IGdyaWQ7XG4gIGdyaWQtdGVtcGxhdGUtY29sdW1uczogcmVwZWF0KCR7KHsgbGVuZ3RoIH0pID0+IGxlbmd0aH0sIDFmcik7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gXG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQuZGl2YFxuICBib3JkZXI6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWt9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICB3aWR0aDogMTQuODc1cmVtO1xuICBoZWlnaHQ6IDE2LjM3NXJlbjtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmBcblxuY29uc3QgU3R5bGVkQmFubmVyID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMzMlO1xuYFxuXG5leHBvcnQgY29uc3QgU2xpZGVyID0gKHsgbGVuZ3RoID0gNCB9OiB7IGxlbmd0aD86IG51bWJlciB9KSA9PiAoXG4gIDxTdHlsZWRDb250YWluZXIgbGVuZ3RoPXtsZW5ndGh9PlxuICAgIHtBcnJheS5mcm9tKHsgbGVuZ3RoIH0sIChfLCBpKSA9PiAoXG4gICAgICA8U3R5bGVkQ2FyZCBrZXk9e2Bza2VsZXRvbi1zbGlkZXItY2FyZC0ke2l9YH0+XG4gICAgICAgIDxTdHlsZWRCYW5uZXIgLz5cbiAgICAgIDwvU3R5bGVkQ2FyZD5cbiAgICApKX1cbiAgPC9TdHlsZWRDb250YWluZXI+XG4pXG4iXX0= */"));
|
|
28
28
|
const StyledBanner = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
29
29
|
target: "e1yrvvrg0"
|
|
30
30
|
} : {
|
|
@@ -34,7 +34,7 @@ const StyledBanner = /* @__PURE__ */ _styled__default.default("div", process.env
|
|
|
34
34
|
theme
|
|
35
35
|
}) => theme.colors.neutral.borderWeak, ";background-color:", ({
|
|
36
36
|
theme
|
|
37
|
-
}) => theme.colors.neutral.borderWeak, ";width:100%;height:33%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
37
|
+
}) => theme.colors.neutral.borderWeak, ";width:100%;height:33%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0IrQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Ta2VsZXRvbi9TbGlkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PHsgbGVuZ3RoOiBudW1iZXIgfT5gXG4gIGhlaWdodDogMTcuMzc1cmVtO1xuICBkaXNwbGF5OiBncmlkO1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IHJlcGVhdCgkeyh7IGxlbmd0aCB9KSA9PiBsZW5ndGh9LCAxZnIpO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gIG92ZXJmbG93OiBhdXRvO1xuYFxuXG5jb25zdCBTdHlsZWRDYXJkID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgd2lkdGg6IDE0Ljg3NXJlbTtcbiAgaGVpZ2h0OiAxNi4zNzVyZW47XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gXG5cbmNvbnN0IFN0eWxlZEJhbm5lciA9IHN0eWxlZC5kaXZgXG4gIGJvcmRlcjogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2Vha307XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2Vha307XG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDMzJTtcbmBcblxuZXhwb3J0IGNvbnN0IFNsaWRlciA9ICh7IGxlbmd0aCA9IDQgfTogeyBsZW5ndGg/OiBudW1iZXIgfSkgPT4gKFxuICA8U3R5bGVkQ29udGFpbmVyIGxlbmd0aD17bGVuZ3RofT5cbiAgICB7QXJyYXkuZnJvbSh7IGxlbmd0aCB9LCAoXywgaSkgPT4gKFxuICAgICAgPFN0eWxlZENhcmQga2V5PXtgc2tlbGV0b24tc2xpZGVyLWNhcmQtJHtpfWB9PlxuICAgICAgICA8U3R5bGVkQmFubmVyIC8+XG4gICAgICA8L1N0eWxlZENhcmQ+XG4gICAgKSl9XG4gIDwvU3R5bGVkQ29udGFpbmVyPlxuKVxuIl19 */"));
|
|
38
38
|
const Slider = ({
|
|
39
39
|
length = 4
|
|
40
40
|
}) => /* @__PURE__ */ jsxRuntime.jsx(StyledContainer, { length, children: Array.from({
|
|
@@ -10,7 +10,7 @@ const StyledContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
|
|
|
10
10
|
length
|
|
11
11
|
}) => length, ", 1fr);gap:", ({
|
|
12
12
|
theme
|
|
13
|
-
}) => theme.space["2"], ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSXNEIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBsZW5ndGg6IG51bWJlciB9PmBcbiAgaGVpZ2h0OiAxNy4zNzVyZW07XG4gIGRpc3BsYXk6IGdyaWQ7XG4gIGdyaWQtdGVtcGxhdGUtY29sdW1uczogcmVwZWF0KCR7KHsgbGVuZ3RoIH0pID0+IGxlbmd0aH0sIDFmcik7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gXG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQuZGl2YFxuICBib3JkZXI6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWt9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+
|
|
13
|
+
}) => theme.space["2"], ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSXNEIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBsZW5ndGg6IG51bWJlciB9PmBcbiAgaGVpZ2h0OiAxNy4zNzVyZW07XG4gIGRpc3BsYXk6IGdyaWQ7XG4gIGdyaWQtdGVtcGxhdGUtY29sdW1uczogcmVwZWF0KCR7KHsgbGVuZ3RoIH0pID0+IGxlbmd0aH0sIDFmcik7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gXG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQuZGl2YFxuICBib3JkZXI6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWt9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICB3aWR0aDogMTQuODc1cmVtO1xuICBoZWlnaHQ6IDE2LjM3NXJlbjtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmBcblxuY29uc3QgU3R5bGVkQmFubmVyID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMzMlO1xuYFxuXG5leHBvcnQgY29uc3QgU2xpZGVyID0gKHsgbGVuZ3RoID0gNCB9OiB7IGxlbmd0aD86IG51bWJlciB9KSA9PiAoXG4gIDxTdHlsZWRDb250YWluZXIgbGVuZ3RoPXtsZW5ndGh9PlxuICAgIHtBcnJheS5mcm9tKHsgbGVuZ3RoIH0sIChfLCBpKSA9PiAoXG4gICAgICA8U3R5bGVkQ2FyZCBrZXk9e2Bza2VsZXRvbi1zbGlkZXItY2FyZC0ke2l9YH0+XG4gICAgICAgIDxTdHlsZWRCYW5uZXIgLz5cbiAgICAgIDwvU3R5bGVkQ2FyZD5cbiAgICApKX1cbiAgPC9TdHlsZWRDb250YWluZXI+XG4pXG4iXX0= */"));
|
|
14
14
|
const StyledCard = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
15
15
|
target: "e1yrvvrg1"
|
|
16
16
|
} : {
|
|
@@ -20,7 +20,7 @@ const StyledCard = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "prod
|
|
|
20
20
|
theme
|
|
21
21
|
}) => theme.colors.neutral.borderWeak, ";border-radius:", ({
|
|
22
22
|
theme
|
|
23
|
-
}) => theme.radii.default, ";width:14.875rem
|
|
23
|
+
}) => theme.radii.default, ";width:14.875rem;height:16.375ren;overflow:hidden;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWTZCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBsZW5ndGg6IG51bWJlciB9PmBcbiAgaGVpZ2h0OiAxNy4zNzVyZW07XG4gIGRpc3BsYXk6IGdyaWQ7XG4gIGdyaWQtdGVtcGxhdGUtY29sdW1uczogcmVwZWF0KCR7KHsgbGVuZ3RoIH0pID0+IGxlbmd0aH0sIDFmcik7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gXG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQuZGl2YFxuICBib3JkZXI6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWt9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICB3aWR0aDogMTQuODc1cmVtO1xuICBoZWlnaHQ6IDE2LjM3NXJlbjtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmBcblxuY29uc3QgU3R5bGVkQmFubmVyID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMzMlO1xuYFxuXG5leHBvcnQgY29uc3QgU2xpZGVyID0gKHsgbGVuZ3RoID0gNCB9OiB7IGxlbmd0aD86IG51bWJlciB9KSA9PiAoXG4gIDxTdHlsZWRDb250YWluZXIgbGVuZ3RoPXtsZW5ndGh9PlxuICAgIHtBcnJheS5mcm9tKHsgbGVuZ3RoIH0sIChfLCBpKSA9PiAoXG4gICAgICA8U3R5bGVkQ2FyZCBrZXk9e2Bza2VsZXRvbi1zbGlkZXItY2FyZC0ke2l9YH0+XG4gICAgICAgIDxTdHlsZWRCYW5uZXIgLz5cbiAgICAgIDwvU3R5bGVkQ2FyZD5cbiAgICApKX1cbiAgPC9TdHlsZWRDb250YWluZXI+XG4pXG4iXX0= */"));
|
|
24
24
|
const StyledBanner = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
25
25
|
target: "e1yrvvrg0"
|
|
26
26
|
} : {
|
|
@@ -30,7 +30,7 @@ const StyledBanner = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "pr
|
|
|
30
30
|
theme
|
|
31
31
|
}) => theme.colors.neutral.borderWeak, ";background-color:", ({
|
|
32
32
|
theme
|
|
33
|
-
}) => theme.colors.neutral.borderWeak, ";width:100%;height:33%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
33
|
+
}) => theme.colors.neutral.borderWeak, ";width:100%;height:33%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NrZWxldG9uL1NsaWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0IrQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Ta2VsZXRvbi9TbGlkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PHsgbGVuZ3RoOiBudW1iZXIgfT5gXG4gIGhlaWdodDogMTcuMzc1cmVtO1xuICBkaXNwbGF5OiBncmlkO1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IHJlcGVhdCgkeyh7IGxlbmd0aCB9KSA9PiBsZW5ndGh9LCAxZnIpO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gIG92ZXJmbG93OiBhdXRvO1xuYFxuXG5jb25zdCBTdHlsZWRDYXJkID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgd2lkdGg6IDE0Ljg3NXJlbTtcbiAgaGVpZ2h0OiAxNi4zNzVyZW47XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gXG5cbmNvbnN0IFN0eWxlZEJhbm5lciA9IHN0eWxlZC5kaXZgXG4gIGJvcmRlcjogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2Vha307XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2Vha307XG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDMzJTtcbmBcblxuZXhwb3J0IGNvbnN0IFNsaWRlciA9ICh7IGxlbmd0aCA9IDQgfTogeyBsZW5ndGg/OiBudW1iZXIgfSkgPT4gKFxuICA8U3R5bGVkQ29udGFpbmVyIGxlbmd0aD17bGVuZ3RofT5cbiAgICB7QXJyYXkuZnJvbSh7IGxlbmd0aCB9LCAoXywgaSkgPT4gKFxuICAgICAgPFN0eWxlZENhcmQga2V5PXtgc2tlbGV0b24tc2xpZGVyLWNhcmQtJHtpfWB9PlxuICAgICAgICA8U3R5bGVkQmFubmVyIC8+XG4gICAgICA8L1N0eWxlZENhcmQ+XG4gICAgKSl9XG4gIDwvU3R5bGVkQ29udGFpbmVyPlxuKVxuIl19 */"));
|
|
34
34
|
const Slider = ({
|
|
35
35
|
length = 4
|
|
36
36
|
}) => /* @__PURE__ */ jsx(StyledContainer, { length, children: Array.from({
|
|
@@ -21,7 +21,7 @@ const StyledSelectableCard = /* @__PURE__ */ _styled__default.default(index.Sele
|
|
|
21
21
|
theme
|
|
22
22
|
}) => theme.space["2"], ";font-weight:", ({
|
|
23
23
|
theme
|
|
24
|
-
}) => theme.typography.bodyStrong.weight, ";justify-content:center;align-items:center;transition:all 200ms ease-in-out;white-space:nowrap;background:transparent;height:100
|
|
24
|
+
}) => theme.typography.bodyStrong.weight, ";justify-content:center;align-items:center;transition:all 200ms ease-in-out;white-space:nowrap;background:transparent;height:100%;user-select:none;&:hover,&:active{box-shadow:none;border:none;&:not([data-error='true'][data-disabled='true']){border:none;}}&[data-checked='true']{border:none;}& label{transition:color 300ms;color:", ({
|
|
25
25
|
theme
|
|
26
26
|
}) => theme.colors.neutral.textStrong, ";}&[data-checked='true'] label{color:", ({
|
|
27
27
|
theme,
|
|
@@ -29,11 +29,32 @@ const StyledSelectableCard = /* @__PURE__ */ _styled__default.default(index.Sele
|
|
|
29
29
|
}) => sentiment === "neutral" ? theme.colors.neutral.textStrong : theme.colors.primary.textStrong, ";}&:not([data-checked='true']) label{&:hover{color:", ({
|
|
30
30
|
theme,
|
|
31
31
|
sentiment
|
|
32
|
-
}) => sentiment === "neutral" ? theme.colors.neutral.textHover : theme.colors.primary.text, ";}}"
|
|
32
|
+
}) => sentiment === "neutral" ? theme.colors.neutral.textHover : theme.colors.primary.text, ";}}", ({
|
|
33
|
+
disabled,
|
|
34
|
+
theme
|
|
35
|
+
}) => disabled ? `
|
|
36
|
+
&[data-disabled='true'] {
|
|
37
|
+
background: transparent;
|
|
38
|
+
border: none;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
label {
|
|
42
|
+
color: ${theme.colors.neutral.textDisabled};
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
&:not([data-checked='true']) label {
|
|
46
|
+
&:hover {
|
|
47
|
+
background: transparent;
|
|
48
|
+
color: ${theme.colors.neutral.textDisabled};
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
` : "", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1N3aXRjaEJ1dHRvbi9PcHRpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVU0RCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Td2l0Y2hCdXR0b24vT3B0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgU2VsZWN0YWJsZUNhcmQgfSBmcm9tICcuLi9TZWxlY3RhYmxlQ2FyZCdcbmltcG9ydCB7IHVzZVN3aXRjaEJ1dHRvbiB9IGZyb20gJy4vU3dpdGNoQnV0dG9uQ29udGV4dCdcblxuY29uc3QgU3R5bGVkU2VsZWN0YWJsZUNhcmQgPSBzdHlsZWQoU2VsZWN0YWJsZUNhcmQsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnc2VudGltZW50J10uaW5jbHVkZXMocHJvcCksXG59KTx7IHNlbnRpbWVudDogJ25ldXRyYWwnIHwgJ3ByaW1hcnknOyBkaXNhYmxlZD86IGJvb2xlYW4gfT5gXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfSAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICBmb250LXdlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmJvZHlTdHJvbmcud2VpZ2h0fTtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHRyYW5zaXRpb246IGFsbCAyMDBtcyBlYXNlLWluLW91dDtcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGhlaWdodDogMTAwJTtcbiAgdXNlci1zZWxlY3Q6IG5vbmU7XG5cbiAgJjpob3ZlcixcbiAgJjphY3RpdmUge1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYm9yZGVyOiBub25lO1xuICAgICY6bm90KFtkYXRhLWVycm9yPSd0cnVlJ11bZGF0YS1kaXNhYmxlZD0ndHJ1ZSddKSB7XG4gICAgICBib3JkZXI6IG5vbmU7XG4gICAgfVxuICB9XG5cbiAgJltkYXRhLWNoZWNrZWQ9J3RydWUnXSB7XG4gICAgYm9yZGVyOiBub25lO1xuICB9XG5cbiAgJiBsYWJlbCB7XG4gICAgdHJhbnNpdGlvbjogY29sb3IgMzAwbXM7XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFN0cm9uZ307XG4gIH1cblxuICAmW2RhdGEtY2hlY2tlZD0ndHJ1ZSddIGxhYmVsIHtcbiAgICBjb2xvcjogJHsoeyB0aGVtZSwgc2VudGltZW50IH0pID0+XG4gICAgICBzZW50aW1lbnQgPT09ICduZXV0cmFsJ1xuICAgICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmdcbiAgICAgICAgOiB0aGVtZS5jb2xvcnMucHJpbWFyeS50ZXh0U3Ryb25nfTtcbiAgfVxuXG4gICY6bm90KFtkYXRhLWNoZWNrZWQ9J3RydWUnXSkgbGFiZWwge1xuICAgICY6aG92ZXIge1xuICAgICAgY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PlxuICAgICAgICBzZW50aW1lbnQgPT09ICduZXV0cmFsJ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dEhvdmVyXG4gICAgICAgICAgOiB0aGVtZS5jb2xvcnMucHJpbWFyeS50ZXh0fTtcbiAgICB9XG59XG5cbiAgJHsoeyBkaXNhYmxlZCwgdGhlbWUgfSkgPT5cbiAgICBkaXNhYmxlZFxuICAgICAgPyBgXG4gICAgICAmW2RhdGEtZGlzYWJsZWQ9J3RydWUnXSB7XG4gICAgICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgICAgICBib3JkZXI6IG5vbmU7XG4gICAgICB9XG5cbiAgICAgIGxhYmVsIHtcbiAgICAgICAgY29sb3I6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dERpc2FibGVkfTtcbiAgICAgIH1cblxuICAgICAgJjpub3QoW2RhdGEtY2hlY2tlZD0ndHJ1ZSddKSBsYWJlbCB7XG4gICAgICAgICY6aG92ZXIge1xuICAgICAgICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgICAgICAgIGNvbG9yOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHREaXNhYmxlZH07XG4gICAgICAgIH1cbiAgICAgIH1cbiAgYFxuICAgICAgOiAnJ31cblxuYFxuXG50eXBlIE9wdGlvblByb3BzID0ge1xuICB2YWx1ZTogc3RyaW5nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBkaXNhYmxlZD86IGJvb2xlYW5cbiAgdG9vbHRpcD86IHN0cmluZ1xufVxuZXhwb3J0IGNvbnN0IE9wdGlvbiA9ICh7XG4gIHZhbHVlLFxuICBjaGlsZHJlbixcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgZGlzYWJsZWQsXG4gIHRvb2x0aXAsXG59OiBPcHRpb25Qcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlU3dpdGNoQnV0dG9uKClcbiAgY29uc3QgcmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpXG5cbiAgY29uc3Qge1xuICAgIGxvY2FsVmFsdWUsXG4gICAgbmFtZSxcbiAgICBvbkJsdXIsXG4gICAgb25Gb2N1cyxcbiAgICBoYW5kbGVPbkNoYW5nZSxcbiAgICByZWZPcHRpb25zLFxuICAgIHNldFJlZk9wdGlvbnMsXG4gICAgc2VudGltZW50LFxuICB9ID0gY29udGV4dFxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChcbiAgICAgIHJlZj8uY3VycmVudCAmJlxuICAgICAgcmVmT3B0aW9ucy5maWx0ZXIob3B0aW9uID0+IG9wdGlvbi52YWx1ZSA9PT0gdmFsdWUpLmxlbmd0aCA9PT0gMFxuICAgICkge1xuICAgICAgY29uc3Qgb3B0aW9uID0ge1xuICAgICAgICB2YWx1ZSxcbiAgICAgICAgY3VycmVudDogcmVmLmN1cnJlbnQsXG4gICAgICB9XG4gICAgICBzZXRSZWZPcHRpb25zKFsuLi5yZWZPcHRpb25zLCBvcHRpb25dKVxuICAgIH1cbiAgfSwgW3JlZk9wdGlvbnMsIHNldFJlZk9wdGlvbnMsIHZhbHVlXSlcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRTZWxlY3RhYmxlQ2FyZFxuICAgICAgbmFtZT17bmFtZX1cbiAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgIGNoZWNrZWQ9e2xvY2FsVmFsdWUgPT09IHZhbHVlfVxuICAgICAgb25DaGFuZ2U9e2hhbmRsZU9uQ2hhbmdlfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgZGF0YS1jaGVja2VkPXtsb2NhbFZhbHVlID09PSB2YWx1ZX1cbiAgICAgIGxhYmVsPXtjaGlsZHJlbn1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkID8/IGBzd2l0Y2gtYnV0dG9uLSR7dmFsdWV9YH1cbiAgICAgIHJlZj17cmVmfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICB0b29sdGlwPXt0b29sdGlwfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgIC8+XG4gIClcbn1cbiJdfQ== */"));
|
|
33
52
|
const Option = ({
|
|
34
53
|
value,
|
|
35
54
|
children,
|
|
36
|
-
"data-testid": dataTestId
|
|
55
|
+
"data-testid": dataTestId,
|
|
56
|
+
disabled,
|
|
57
|
+
tooltip
|
|
37
58
|
}) => {
|
|
38
59
|
const context = SwitchButtonContext.useSwitchButton();
|
|
39
60
|
const ref = react.useRef(null);
|
|
@@ -56,6 +77,6 @@ const Option = ({
|
|
|
56
77
|
setRefOptions([...refOptions, option]);
|
|
57
78
|
}
|
|
58
79
|
}, [refOptions, setRefOptions, value]);
|
|
59
|
-
return /* @__PURE__ */ jsxRuntime.jsx(StyledSelectableCard, { name, value, checked: localValue === value, onChange: handleOnChange, onBlur, onFocus, "data-checked": localValue === value, label: children, "data-testid": dataTestId ?? `switch-button-${value}`, ref, sentiment });
|
|
80
|
+
return /* @__PURE__ */ jsxRuntime.jsx(StyledSelectableCard, { name, value, checked: localValue === value, onChange: handleOnChange, onBlur, onFocus, "data-checked": localValue === value, label: children, "data-testid": dataTestId ?? `switch-button-${value}`, ref, sentiment, tooltip, disabled });
|
|
60
81
|
};
|
|
61
82
|
exports.Option = Option;
|
|
@@ -1,8 +1,10 @@
|
|
|
1
|
-
import { ReactNode } from 'react';
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
2
|
type OptionProps = {
|
|
3
3
|
value: string;
|
|
4
4
|
children: ReactNode;
|
|
5
5
|
'data-testid'?: string;
|
|
6
|
+
disabled?: boolean;
|
|
7
|
+
tooltip?: string;
|
|
6
8
|
};
|
|
7
|
-
export declare const Option: ({ value, children, "data-testid": dataTestId, }: OptionProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
9
|
+
export declare const Option: ({ value, children, "data-testid": dataTestId, disabled, tooltip, }: OptionProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
8
10
|
export {};
|
|
@@ -17,7 +17,7 @@ const StyledSelectableCard = /* @__PURE__ */ _styled(SelectableCard, process.env
|
|
|
17
17
|
theme
|
|
18
18
|
}) => theme.space["2"], ";font-weight:", ({
|
|
19
19
|
theme
|
|
20
|
-
}) => theme.typography.bodyStrong.weight, ";justify-content:center;align-items:center;transition:all 200ms ease-in-out;white-space:nowrap;background:transparent;height:100
|
|
20
|
+
}) => theme.typography.bodyStrong.weight, ";justify-content:center;align-items:center;transition:all 200ms ease-in-out;white-space:nowrap;background:transparent;height:100%;user-select:none;&:hover,&:active{box-shadow:none;border:none;&:not([data-error='true'][data-disabled='true']){border:none;}}&[data-checked='true']{border:none;}& label{transition:color 300ms;color:", ({
|
|
21
21
|
theme
|
|
22
22
|
}) => theme.colors.neutral.textStrong, ";}&[data-checked='true'] label{color:", ({
|
|
23
23
|
theme,
|
|
@@ -25,11 +25,32 @@ const StyledSelectableCard = /* @__PURE__ */ _styled(SelectableCard, process.env
|
|
|
25
25
|
}) => sentiment === "neutral" ? theme.colors.neutral.textStrong : theme.colors.primary.textStrong, ";}&:not([data-checked='true']) label{&:hover{color:", ({
|
|
26
26
|
theme,
|
|
27
27
|
sentiment
|
|
28
|
-
}) => sentiment === "neutral" ? theme.colors.neutral.textHover : theme.colors.primary.text, ";}}"
|
|
28
|
+
}) => sentiment === "neutral" ? theme.colors.neutral.textHover : theme.colors.primary.text, ";}}", ({
|
|
29
|
+
disabled,
|
|
30
|
+
theme
|
|
31
|
+
}) => disabled ? `
|
|
32
|
+
&[data-disabled='true'] {
|
|
33
|
+
background: transparent;
|
|
34
|
+
border: none;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
label {
|
|
38
|
+
color: ${theme.colors.neutral.textDisabled};
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
&:not([data-checked='true']) label {
|
|
42
|
+
&:hover {
|
|
43
|
+
background: transparent;
|
|
44
|
+
color: ${theme.colors.neutral.textDisabled};
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
` : "", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1N3aXRjaEJ1dHRvbi9PcHRpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVU0RCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Td2l0Y2hCdXR0b24vT3B0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgU2VsZWN0YWJsZUNhcmQgfSBmcm9tICcuLi9TZWxlY3RhYmxlQ2FyZCdcbmltcG9ydCB7IHVzZVN3aXRjaEJ1dHRvbiB9IGZyb20gJy4vU3dpdGNoQnV0dG9uQ29udGV4dCdcblxuY29uc3QgU3R5bGVkU2VsZWN0YWJsZUNhcmQgPSBzdHlsZWQoU2VsZWN0YWJsZUNhcmQsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnc2VudGltZW50J10uaW5jbHVkZXMocHJvcCksXG59KTx7IHNlbnRpbWVudDogJ25ldXRyYWwnIHwgJ3ByaW1hcnknOyBkaXNhYmxlZD86IGJvb2xlYW4gfT5gXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfSAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICBmb250LXdlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmJvZHlTdHJvbmcud2VpZ2h0fTtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHRyYW5zaXRpb246IGFsbCAyMDBtcyBlYXNlLWluLW91dDtcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGhlaWdodDogMTAwJTtcbiAgdXNlci1zZWxlY3Q6IG5vbmU7XG5cbiAgJjpob3ZlcixcbiAgJjphY3RpdmUge1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYm9yZGVyOiBub25lO1xuICAgICY6bm90KFtkYXRhLWVycm9yPSd0cnVlJ11bZGF0YS1kaXNhYmxlZD0ndHJ1ZSddKSB7XG4gICAgICBib3JkZXI6IG5vbmU7XG4gICAgfVxuICB9XG5cbiAgJltkYXRhLWNoZWNrZWQ9J3RydWUnXSB7XG4gICAgYm9yZGVyOiBub25lO1xuICB9XG5cbiAgJiBsYWJlbCB7XG4gICAgdHJhbnNpdGlvbjogY29sb3IgMzAwbXM7XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFN0cm9uZ307XG4gIH1cblxuICAmW2RhdGEtY2hlY2tlZD0ndHJ1ZSddIGxhYmVsIHtcbiAgICBjb2xvcjogJHsoeyB0aGVtZSwgc2VudGltZW50IH0pID0+XG4gICAgICBzZW50aW1lbnQgPT09ICduZXV0cmFsJ1xuICAgICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmdcbiAgICAgICAgOiB0aGVtZS5jb2xvcnMucHJpbWFyeS50ZXh0U3Ryb25nfTtcbiAgfVxuXG4gICY6bm90KFtkYXRhLWNoZWNrZWQ9J3RydWUnXSkgbGFiZWwge1xuICAgICY6aG92ZXIge1xuICAgICAgY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PlxuICAgICAgICBzZW50aW1lbnQgPT09ICduZXV0cmFsJ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dEhvdmVyXG4gICAgICAgICAgOiB0aGVtZS5jb2xvcnMucHJpbWFyeS50ZXh0fTtcbiAgICB9XG59XG5cbiAgJHsoeyBkaXNhYmxlZCwgdGhlbWUgfSkgPT5cbiAgICBkaXNhYmxlZFxuICAgICAgPyBgXG4gICAgICAmW2RhdGEtZGlzYWJsZWQ9J3RydWUnXSB7XG4gICAgICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgICAgICBib3JkZXI6IG5vbmU7XG4gICAgICB9XG5cbiAgICAgIGxhYmVsIHtcbiAgICAgICAgY29sb3I6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dERpc2FibGVkfTtcbiAgICAgIH1cblxuICAgICAgJjpub3QoW2RhdGEtY2hlY2tlZD0ndHJ1ZSddKSBsYWJlbCB7XG4gICAgICAgICY6aG92ZXIge1xuICAgICAgICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgICAgICAgIGNvbG9yOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHREaXNhYmxlZH07XG4gICAgICAgIH1cbiAgICAgIH1cbiAgYFxuICAgICAgOiAnJ31cblxuYFxuXG50eXBlIE9wdGlvblByb3BzID0ge1xuICB2YWx1ZTogc3RyaW5nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBkaXNhYmxlZD86IGJvb2xlYW5cbiAgdG9vbHRpcD86IHN0cmluZ1xufVxuZXhwb3J0IGNvbnN0IE9wdGlvbiA9ICh7XG4gIHZhbHVlLFxuICBjaGlsZHJlbixcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgZGlzYWJsZWQsXG4gIHRvb2x0aXAsXG59OiBPcHRpb25Qcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlU3dpdGNoQnV0dG9uKClcbiAgY29uc3QgcmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpXG5cbiAgY29uc3Qge1xuICAgIGxvY2FsVmFsdWUsXG4gICAgbmFtZSxcbiAgICBvbkJsdXIsXG4gICAgb25Gb2N1cyxcbiAgICBoYW5kbGVPbkNoYW5nZSxcbiAgICByZWZPcHRpb25zLFxuICAgIHNldFJlZk9wdGlvbnMsXG4gICAgc2VudGltZW50LFxuICB9ID0gY29udGV4dFxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChcbiAgICAgIHJlZj8uY3VycmVudCAmJlxuICAgICAgcmVmT3B0aW9ucy5maWx0ZXIob3B0aW9uID0+IG9wdGlvbi52YWx1ZSA9PT0gdmFsdWUpLmxlbmd0aCA9PT0gMFxuICAgICkge1xuICAgICAgY29uc3Qgb3B0aW9uID0ge1xuICAgICAgICB2YWx1ZSxcbiAgICAgICAgY3VycmVudDogcmVmLmN1cnJlbnQsXG4gICAgICB9XG4gICAgICBzZXRSZWZPcHRpb25zKFsuLi5yZWZPcHRpb25zLCBvcHRpb25dKVxuICAgIH1cbiAgfSwgW3JlZk9wdGlvbnMsIHNldFJlZk9wdGlvbnMsIHZhbHVlXSlcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRTZWxlY3RhYmxlQ2FyZFxuICAgICAgbmFtZT17bmFtZX1cbiAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgIGNoZWNrZWQ9e2xvY2FsVmFsdWUgPT09IHZhbHVlfVxuICAgICAgb25DaGFuZ2U9e2hhbmRsZU9uQ2hhbmdlfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgZGF0YS1jaGVja2VkPXtsb2NhbFZhbHVlID09PSB2YWx1ZX1cbiAgICAgIGxhYmVsPXtjaGlsZHJlbn1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkID8/IGBzd2l0Y2gtYnV0dG9uLSR7dmFsdWV9YH1cbiAgICAgIHJlZj17cmVmfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICB0b29sdGlwPXt0b29sdGlwfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgIC8+XG4gIClcbn1cbiJdfQ== */"));
|
|
29
48
|
const Option = ({
|
|
30
49
|
value,
|
|
31
50
|
children,
|
|
32
|
-
"data-testid": dataTestId
|
|
51
|
+
"data-testid": dataTestId,
|
|
52
|
+
disabled,
|
|
53
|
+
tooltip
|
|
33
54
|
}) => {
|
|
34
55
|
const context = useSwitchButton();
|
|
35
56
|
const ref = useRef(null);
|
|
@@ -52,7 +73,7 @@ const Option = ({
|
|
|
52
73
|
setRefOptions([...refOptions, option]);
|
|
53
74
|
}
|
|
54
75
|
}, [refOptions, setRefOptions, value]);
|
|
55
|
-
return /* @__PURE__ */ jsx(StyledSelectableCard, { name, value, checked: localValue === value, onChange: handleOnChange, onBlur, onFocus, "data-checked": localValue === value, label: children, "data-testid": dataTestId ?? `switch-button-${value}`, ref, sentiment });
|
|
76
|
+
return /* @__PURE__ */ jsx(StyledSelectableCard, { name, value, checked: localValue === value, onChange: handleOnChange, onBlur, onFocus, "data-checked": localValue === value, label: children, "data-testid": dataTestId ?? `switch-button-${value}`, ref, sentiment, tooltip, disabled });
|
|
56
77
|
};
|
|
57
78
|
export {
|
|
58
79
|
Option
|
|
@@ -34,7 +34,7 @@ const StyledBorderedBox = /* @__PURE__ */ _styled__default.default("div", proces
|
|
|
34
34
|
theme
|
|
35
35
|
}) => theme.sizing[SIZES.small], ";}&[data-size='medium']{height:", ({
|
|
36
36
|
theme
|
|
37
|
-
}) => theme.sizing[SIZES.medium], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
37
|
+
}) => theme.sizing[SIZES.medium], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1N3aXRjaEJ1dHRvbi9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUJ5RSIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Td2l0Y2hCdXR0b24vaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUge1xuICBDaGFuZ2VFdmVudCxcbiAgQ2hhbmdlRXZlbnRIYW5kbGVyLFxuICBGb2N1c0V2ZW50SGFuZGxlcixcbiAgUmVhY3ROb2RlLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCdcbmltcG9ydCB7IEZvY3VzT3ZlcmxheSB9IGZyb20gJy4vRm9jdXNPdmVybGF5J1xuaW1wb3J0IHsgT3B0aW9uIH0gZnJvbSAnLi9PcHRpb24nXG5pbXBvcnQgdHlwZSB7IFJlZk9wdGlvblR5cGUgfSBmcm9tICcuL1N3aXRjaEJ1dHRvbkNvbnRleHQnXG5pbXBvcnQgeyBTd2l0Y2hCdXR0b25Db250ZXh0IH0gZnJvbSAnLi9Td2l0Y2hCdXR0b25Db250ZXh0J1xuaW1wb3J0IHsgRk9DVVNfT1ZFUkxBWV9TQ0FMRV9SQVRJTyB9IGZyb20gJy4vY29uc3RhbnQnXG5cbmNvbnN0IFNJWkVTID0ge1xuICBzbWFsbDogJzUwMCcsIC8vIHNpemluZyB0b2tlbiBmcm9tIHRoZW1lXG4gIG1lZGl1bTogJzYwMCcsXG59IGFzIGNvbnN0XG5cbmNvbnN0IFN0eWxlZEJvcmRlcmVkQm94ID0gc3R5bGVkLmRpdjx7ICdkYXRhLXNpemUnOiAnc21hbGwnIHwgJ21lZGl1bScgfT5gXG4gIGJvcmRlcjogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMC41J119O1xuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuICAmW2RhdGEtc2l6ZT0nc21hbGwnXSB7XG4gICAgICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc2l6aW5nW1NJWkVTLnNtYWxsXX07XG4gIH1cblxuICAmW2RhdGEtc2l6ZT0nbWVkaXVtJ10ge1xuICAgICAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1tTSVpFUy5tZWRpdW1dfTtcbiAgfVxuYFxudHlwZSBTd2l0Y2hCdXR0b25Qcm9wcyA9IHtcbiAgbmFtZT86IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIG9uQmx1cj86IEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxJbnB1dEVsZW1lbnQ+XG4gIG9uQ2hhbmdlOiBDaGFuZ2VFdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD5cbiAgb25Gb2N1cz86IEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxJbnB1dEVsZW1lbnQ+XG4gIHRvb2x0aXA/OiBzdHJpbmdcbiAgdmFsdWU6IHN0cmluZ1xuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBzaXplPzogJ3NtYWxsJyB8ICdtZWRpdW0nXG4gIHNlbnRpbWVudD86ICdwcmltYXJ5JyB8ICduZXV0cmFsJ1xufVxuXG4vKipcbiAqIFN3aXRjaEJ1dHRvbiBpcyBhIGNvbXBvbmVudCB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBzZWxlY3QgYmV0d2VlbiB0d28gb3B0aW9ucy5cbiAqL1xuZXhwb3J0IGNvbnN0IFN3aXRjaEJ1dHRvbiA9ICh7XG4gIHZhbHVlLFxuICBvbkNoYW5nZSxcbiAgb25Gb2N1cyxcbiAgb25CbHVyLFxuICBuYW1lLFxuICBzaXplID0gJ3NtYWxsJyxcbiAgc2VudGltZW50ID0gJ3ByaW1hcnknLFxuICB0b29sdGlwLFxuICBjbGFzc05hbWUsXG4gIGNoaWxkcmVuLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogU3dpdGNoQnV0dG9uUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGFpbmVyUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuXG4gIGNvbnN0IFtsb2NhbFZhbHVlLCBzZXRMb2NhbFZhbHVlXSA9IHVzZVN0YXRlPHN0cmluZz4odmFsdWUpXG4gIGNvbnN0IFtyZWZPcHRpb25zLCBzZXRSZWZPcHRpb25zXSA9IHVzZVN0YXRlPFJlZk9wdGlvblR5cGVbXT4oW10pXG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGUoMClcbiAgY29uc3QgW3dpZHRoLCBzZXRXaWR0aF0gPSB1c2VTdGF0ZSgwKVxuICBjb25zdCBbbW91c2VEb3duU2lkZSwgc2V0TW91c2VEb3duU2lkZV0gPSB1c2VTdGF0ZTwnbGVmdCcgfCAncmlnaHQnIHwgbnVsbD4oXG4gICAgbnVsbCxcbiAgKVxuXG4gIGNvbnN0IGdldEVsZW1lbnQgPSB1c2VDYWxsYmFjayhcbiAgICAocmVmZXJlbmNlVmFsdWU6IHN0cmluZykgPT5cbiAgICAgIHJlZk9wdGlvbnMuZmluZChcbiAgICAgICAgZWxlbWVudCA9PiBlbGVtZW50LmN1cnJlbnQgJiYgZWxlbWVudC52YWx1ZSA9PT0gcmVmZXJlbmNlVmFsdWUsXG4gICAgICApPy5jdXJyZW50LFxuICAgIFtyZWZPcHRpb25zXSxcbiAgKVxuXG4gIGNvbnN0IGdldFBvc2l0aW9uID0gKGN1cmVudEVsZW1lbnQ/OiBIVE1MSW5wdXRFbGVtZW50KSA9PiB7XG4gICAgaWYgKCFjdXJlbnRFbGVtZW50KSByZXR1cm4gMFxuICAgIGNvbnN0IGN1cnJlbnRQb3NpdGlvbiA9IGN1cmVudEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCkubGVmdFxuICAgIGNvbnN0IGNvbnRhaW5lclBvc2l0aW9uID1cbiAgICAgIGNvbnRhaW5lclJlZi5jdXJyZW50Py5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKS5sZWZ0ID8/IDBcblxuICAgIHJldHVybiBjdXJyZW50UG9zaXRpb24gLSBjb250YWluZXJQb3NpdGlvblxuICB9XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBzZXRMb2NhbFZhbHVlKHZhbHVlKVxuICAgIHNldFdpZHRoKGdldEVsZW1lbnQodmFsdWUpPy5vZmZzZXRXaWR0aCA/PyAwKVxuICAgIHNldFBvc2l0aW9uKGdldFBvc2l0aW9uKGdldEVsZW1lbnQodmFsdWUpKSlcbiAgfSwgW2dldEVsZW1lbnQsIHJlZk9wdGlvbnMsIHZhbHVlXSlcblxuICBjb25zdCBoYW5kbGVPbkNoYW5nZSA9IHVzZUNhbGxiYWNrKFxuICAgIChldmVudDogQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHtcbiAgICAgIG9uQ2hhbmdlPy4oZXZlbnQpXG4gICAgICBzZXRMb2NhbFZhbHVlKGV2ZW50LnRhcmdldC52YWx1ZSlcblxuICAgICAgY29uc3QgY3VycmVudEVsZW1lbnQgPSBnZXRFbGVtZW50KGV2ZW50LnRhcmdldC52YWx1ZSlcblxuICAgICAgaWYgKGN1cnJlbnRFbGVtZW50ICYmIGNvbnRhaW5lclJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGN1cnJlbnRXaWR0aCA9IGN1cnJlbnRFbGVtZW50Lm9mZnNldFdpZHRoID8/IDBcbiAgICAgICAgc2V0V2lkdGgoY3VycmVudFdpZHRoKVxuICAgICAgICBzZXRQb3NpdGlvbihnZXRQb3NpdGlvbihjdXJyZW50RWxlbWVudCkpXG4gICAgICB9XG4gICAgfSxcbiAgICBbZ2V0RWxlbWVudCwgb25DaGFuZ2VdLFxuICApXG5cbiAgY29uc3QgdmFsdWVDb250ZXh0ID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgbG9jYWxWYWx1ZSxcbiAgICAgIG5hbWUsXG4gICAgICBvbkJsdXIsXG4gICAgICBvbkZvY3VzLFxuICAgICAgc2l6ZSxcbiAgICAgIGhhbmRsZU9uQ2hhbmdlLFxuICAgICAgcmVmT3B0aW9ucyxcbiAgICAgIHNldFJlZk9wdGlvbnMsXG4gICAgICBzZW50aW1lbnQsXG4gICAgfSksXG4gICAgW1xuICAgICAgaGFuZGxlT25DaGFuZ2UsXG4gICAgICBsb2NhbFZhbHVlLFxuICAgICAgbmFtZSxcbiAgICAgIG9uQmx1cixcbiAgICAgIG9uRm9jdXMsXG4gICAgICByZWZPcHRpb25zLFxuICAgICAgc2l6ZSxcbiAgICAgIHNlbnRpbWVudCxcbiAgICBdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8U3dpdGNoQnV0dG9uQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17dmFsdWVDb250ZXh0fT5cbiAgICAgIDxUb29sdGlwIHRleHQ9e3Rvb2x0aXB9PlxuICAgICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgY2xhc3NOYW1lPXtjbGFzc05hbWV9IGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfT5cbiAgICAgICAgICA8U3R5bGVkQm9yZGVyZWRCb3hcbiAgICAgICAgICAgIG9uTW91c2VEb3duPXtldmVudCA9PiB7XG4gICAgICAgICAgICAgIGNvbnN0IHJlY3QgPSBldmVudC5jdXJyZW50VGFyZ2V0LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpXG4gICAgICAgICAgICAgIGNvbnN0IGNsaWNrWCA9IGV2ZW50LmNsaWVudFggLSByZWN0LmxlZnRcbiAgICAgICAgICAgICAgY29uc3QgY2xpY2tJbkN1cnJlbnRFbGVtZW50ID1cbiAgICAgICAgICAgICAgICBjbGlja1ggPiBwb3NpdGlvbiAmJiBjbGlja1ggPCBwb3NpdGlvbiArIHdpZHRoXG4gICAgICAgICAgICAgIGlmICghY2xpY2tJbkN1cnJlbnRFbGVtZW50KSB7XG4gICAgICAgICAgICAgICAgc2V0TW91c2VEb3duU2lkZShcbiAgICAgICAgICAgICAgICAgIGNsaWNrWCA8IGdldFBvc2l0aW9uKGdldEVsZW1lbnQobG9jYWxWYWx1ZSkpXG4gICAgICAgICAgICAgICAgICAgID8gJ2xlZnQnXG4gICAgICAgICAgICAgICAgICAgIDogJ3JpZ2h0JyxcbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgc2V0V2lkdGgod2lkdGggKyBGT0NVU19PVkVSTEFZX1NDQUxFX1JBVElPKVxuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNldE1vdXNlRG93blNpZGUobnVsbClcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIG9uTW91c2VVcD17KCkgPT4ge1xuICAgICAgICAgICAgICBzZXRNb3VzZURvd25TaWRlKG51bGwpXG4gICAgICAgICAgICAgIGlmIChtb3VzZURvd25TaWRlKSBzZXRXaWR0aCh3aWR0aCAtIEZPQ1VTX09WRVJMQVlfU0NBTEVfUkFUSU8pXG4gICAgICAgICAgICB9fVxuICAgICAgICAgICAgb25Nb3VzZUxlYXZlPXsoKSA9PiB7XG4gICAgICAgICAgICAgIHNldE1vdXNlRG93blNpZGUobnVsbClcbiAgICAgICAgICAgICAgaWYgKG1vdXNlRG93blNpZGUpIHNldFdpZHRoKHdpZHRoIC0gRk9DVVNfT1ZFUkxBWV9TQ0FMRV9SQVRJTylcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBkYXRhLXNpemU9e3NpemV9XG4gICAgICAgICAgICByZWY9e2NvbnRhaW5lclJlZn1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7d2lkdGggPyAoXG4gICAgICAgICAgICAgIDxGb2N1c092ZXJsYXlcbiAgICAgICAgICAgICAgICBjYXJkV2lkdGg9e3dpZHRofVxuICAgICAgICAgICAgICAgIHBvc2l0aW9uPXtwb3NpdGlvbn1cbiAgICAgICAgICAgICAgICBtb3VzZURvd25TaWRlPXttb3VzZURvd25TaWRlfVxuICAgICAgICAgICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgPC9TdHlsZWRCb3JkZXJlZEJveD5cbiAgICAgICAgPC9TdGFjaz5cbiAgICAgIDwvVG9vbHRpcD5cbiAgICA8L1N3aXRjaEJ1dHRvbkNvbnRleHQuUHJvdmlkZXI+XG4gIClcbn1cblxuU3dpdGNoQnV0dG9uLk9wdGlvbiA9IE9wdGlvblxuIl19 */"));
|
|
38
38
|
const SwitchButton = ({
|
|
39
39
|
value,
|
|
40
40
|
onChange,
|
|
@@ -17,10 +17,12 @@ type SwitchButtonProps = {
|
|
|
17
17
|
*/
|
|
18
18
|
export declare const SwitchButton: {
|
|
19
19
|
({ value, onChange, onFocus, onBlur, name, size, sentiment, tooltip, className, children, "data-testid": dataTestId, }: SwitchButtonProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
20
|
-
Option: ({ value, children, "data-testid": dataTestId, }: {
|
|
20
|
+
Option: ({ value, children, "data-testid": dataTestId, disabled, tooltip, }: {
|
|
21
21
|
value: string;
|
|
22
22
|
children: ReactNode;
|
|
23
23
|
'data-testid'?: string;
|
|
24
|
+
disabled?: boolean;
|
|
25
|
+
tooltip?: string;
|
|
24
26
|
}) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
25
27
|
};
|
|
26
28
|
export {};
|
|
@@ -30,7 +30,7 @@ const StyledBorderedBox = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ==
|
|
|
30
30
|
theme
|
|
31
31
|
}) => theme.sizing[SIZES.small], ";}&[data-size='medium']{height:", ({
|
|
32
32
|
theme
|
|
33
|
-
}) => theme.sizing[SIZES.medium], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
33
|
+
}) => theme.sizing[SIZES.medium], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1N3aXRjaEJ1dHRvbi9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUJ5RSIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Td2l0Y2hCdXR0b24vaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUge1xuICBDaGFuZ2VFdmVudCxcbiAgQ2hhbmdlRXZlbnRIYW5kbGVyLFxuICBGb2N1c0V2ZW50SGFuZGxlcixcbiAgUmVhY3ROb2RlLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCdcbmltcG9ydCB7IEZvY3VzT3ZlcmxheSB9IGZyb20gJy4vRm9jdXNPdmVybGF5J1xuaW1wb3J0IHsgT3B0aW9uIH0gZnJvbSAnLi9PcHRpb24nXG5pbXBvcnQgdHlwZSB7IFJlZk9wdGlvblR5cGUgfSBmcm9tICcuL1N3aXRjaEJ1dHRvbkNvbnRleHQnXG5pbXBvcnQgeyBTd2l0Y2hCdXR0b25Db250ZXh0IH0gZnJvbSAnLi9Td2l0Y2hCdXR0b25Db250ZXh0J1xuaW1wb3J0IHsgRk9DVVNfT1ZFUkxBWV9TQ0FMRV9SQVRJTyB9IGZyb20gJy4vY29uc3RhbnQnXG5cbmNvbnN0IFNJWkVTID0ge1xuICBzbWFsbDogJzUwMCcsIC8vIHNpemluZyB0b2tlbiBmcm9tIHRoZW1lXG4gIG1lZGl1bTogJzYwMCcsXG59IGFzIGNvbnN0XG5cbmNvbnN0IFN0eWxlZEJvcmRlcmVkQm94ID0gc3R5bGVkLmRpdjx7ICdkYXRhLXNpemUnOiAnc21hbGwnIHwgJ21lZGl1bScgfT5gXG4gIGJvcmRlcjogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMC41J119O1xuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuICAmW2RhdGEtc2l6ZT0nc21hbGwnXSB7XG4gICAgICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc2l6aW5nW1NJWkVTLnNtYWxsXX07XG4gIH1cblxuICAmW2RhdGEtc2l6ZT0nbWVkaXVtJ10ge1xuICAgICAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1tTSVpFUy5tZWRpdW1dfTtcbiAgfVxuYFxudHlwZSBTd2l0Y2hCdXR0b25Qcm9wcyA9IHtcbiAgbmFtZT86IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIG9uQmx1cj86IEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxJbnB1dEVsZW1lbnQ+XG4gIG9uQ2hhbmdlOiBDaGFuZ2VFdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD5cbiAgb25Gb2N1cz86IEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxJbnB1dEVsZW1lbnQ+XG4gIHRvb2x0aXA/OiBzdHJpbmdcbiAgdmFsdWU6IHN0cmluZ1xuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBzaXplPzogJ3NtYWxsJyB8ICdtZWRpdW0nXG4gIHNlbnRpbWVudD86ICdwcmltYXJ5JyB8ICduZXV0cmFsJ1xufVxuXG4vKipcbiAqIFN3aXRjaEJ1dHRvbiBpcyBhIGNvbXBvbmVudCB0aGF0IGFsbG93cyB0aGUgdXNlciB0byBzZWxlY3QgYmV0d2VlbiB0d28gb3B0aW9ucy5cbiAqL1xuZXhwb3J0IGNvbnN0IFN3aXRjaEJ1dHRvbiA9ICh7XG4gIHZhbHVlLFxuICBvbkNoYW5nZSxcbiAgb25Gb2N1cyxcbiAgb25CbHVyLFxuICBuYW1lLFxuICBzaXplID0gJ3NtYWxsJyxcbiAgc2VudGltZW50ID0gJ3ByaW1hcnknLFxuICB0b29sdGlwLFxuICBjbGFzc05hbWUsXG4gIGNoaWxkcmVuLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogU3dpdGNoQnV0dG9uUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGFpbmVyUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuXG4gIGNvbnN0IFtsb2NhbFZhbHVlLCBzZXRMb2NhbFZhbHVlXSA9IHVzZVN0YXRlPHN0cmluZz4odmFsdWUpXG4gIGNvbnN0IFtyZWZPcHRpb25zLCBzZXRSZWZPcHRpb25zXSA9IHVzZVN0YXRlPFJlZk9wdGlvblR5cGVbXT4oW10pXG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGUoMClcbiAgY29uc3QgW3dpZHRoLCBzZXRXaWR0aF0gPSB1c2VTdGF0ZSgwKVxuICBjb25zdCBbbW91c2VEb3duU2lkZSwgc2V0TW91c2VEb3duU2lkZV0gPSB1c2VTdGF0ZTwnbGVmdCcgfCAncmlnaHQnIHwgbnVsbD4oXG4gICAgbnVsbCxcbiAgKVxuXG4gIGNvbnN0IGdldEVsZW1lbnQgPSB1c2VDYWxsYmFjayhcbiAgICAocmVmZXJlbmNlVmFsdWU6IHN0cmluZykgPT5cbiAgICAgIHJlZk9wdGlvbnMuZmluZChcbiAgICAgICAgZWxlbWVudCA9PiBlbGVtZW50LmN1cnJlbnQgJiYgZWxlbWVudC52YWx1ZSA9PT0gcmVmZXJlbmNlVmFsdWUsXG4gICAgICApPy5jdXJyZW50LFxuICAgIFtyZWZPcHRpb25zXSxcbiAgKVxuXG4gIGNvbnN0IGdldFBvc2l0aW9uID0gKGN1cmVudEVsZW1lbnQ/OiBIVE1MSW5wdXRFbGVtZW50KSA9PiB7XG4gICAgaWYgKCFjdXJlbnRFbGVtZW50KSByZXR1cm4gMFxuICAgIGNvbnN0IGN1cnJlbnRQb3NpdGlvbiA9IGN1cmVudEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCkubGVmdFxuICAgIGNvbnN0IGNvbnRhaW5lclBvc2l0aW9uID1cbiAgICAgIGNvbnRhaW5lclJlZi5jdXJyZW50Py5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKS5sZWZ0ID8/IDBcblxuICAgIHJldHVybiBjdXJyZW50UG9zaXRpb24gLSBjb250YWluZXJQb3NpdGlvblxuICB9XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBzZXRMb2NhbFZhbHVlKHZhbHVlKVxuICAgIHNldFdpZHRoKGdldEVsZW1lbnQodmFsdWUpPy5vZmZzZXRXaWR0aCA/PyAwKVxuICAgIHNldFBvc2l0aW9uKGdldFBvc2l0aW9uKGdldEVsZW1lbnQodmFsdWUpKSlcbiAgfSwgW2dldEVsZW1lbnQsIHJlZk9wdGlvbnMsIHZhbHVlXSlcblxuICBjb25zdCBoYW5kbGVPbkNoYW5nZSA9IHVzZUNhbGxiYWNrKFxuICAgIChldmVudDogQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHtcbiAgICAgIG9uQ2hhbmdlPy4oZXZlbnQpXG4gICAgICBzZXRMb2NhbFZhbHVlKGV2ZW50LnRhcmdldC52YWx1ZSlcblxuICAgICAgY29uc3QgY3VycmVudEVsZW1lbnQgPSBnZXRFbGVtZW50KGV2ZW50LnRhcmdldC52YWx1ZSlcblxuICAgICAgaWYgKGN1cnJlbnRFbGVtZW50ICYmIGNvbnRhaW5lclJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGN1cnJlbnRXaWR0aCA9IGN1cnJlbnRFbGVtZW50Lm9mZnNldFdpZHRoID8/IDBcbiAgICAgICAgc2V0V2lkdGgoY3VycmVudFdpZHRoKVxuICAgICAgICBzZXRQb3NpdGlvbihnZXRQb3NpdGlvbihjdXJyZW50RWxlbWVudCkpXG4gICAgICB9XG4gICAgfSxcbiAgICBbZ2V0RWxlbWVudCwgb25DaGFuZ2VdLFxuICApXG5cbiAgY29uc3QgdmFsdWVDb250ZXh0ID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgbG9jYWxWYWx1ZSxcbiAgICAgIG5hbWUsXG4gICAgICBvbkJsdXIsXG4gICAgICBvbkZvY3VzLFxuICAgICAgc2l6ZSxcbiAgICAgIGhhbmRsZU9uQ2hhbmdlLFxuICAgICAgcmVmT3B0aW9ucyxcbiAgICAgIHNldFJlZk9wdGlvbnMsXG4gICAgICBzZW50aW1lbnQsXG4gICAgfSksXG4gICAgW1xuICAgICAgaGFuZGxlT25DaGFuZ2UsXG4gICAgICBsb2NhbFZhbHVlLFxuICAgICAgbmFtZSxcbiAgICAgIG9uQmx1cixcbiAgICAgIG9uRm9jdXMsXG4gICAgICByZWZPcHRpb25zLFxuICAgICAgc2l6ZSxcbiAgICAgIHNlbnRpbWVudCxcbiAgICBdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8U3dpdGNoQnV0dG9uQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17dmFsdWVDb250ZXh0fT5cbiAgICAgIDxUb29sdGlwIHRleHQ9e3Rvb2x0aXB9PlxuICAgICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgY2xhc3NOYW1lPXtjbGFzc05hbWV9IGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfT5cbiAgICAgICAgICA8U3R5bGVkQm9yZGVyZWRCb3hcbiAgICAgICAgICAgIG9uTW91c2VEb3duPXtldmVudCA9PiB7XG4gICAgICAgICAgICAgIGNvbnN0IHJlY3QgPSBldmVudC5jdXJyZW50VGFyZ2V0LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpXG4gICAgICAgICAgICAgIGNvbnN0IGNsaWNrWCA9IGV2ZW50LmNsaWVudFggLSByZWN0LmxlZnRcbiAgICAgICAgICAgICAgY29uc3QgY2xpY2tJbkN1cnJlbnRFbGVtZW50ID1cbiAgICAgICAgICAgICAgICBjbGlja1ggPiBwb3NpdGlvbiAmJiBjbGlja1ggPCBwb3NpdGlvbiArIHdpZHRoXG4gICAgICAgICAgICAgIGlmICghY2xpY2tJbkN1cnJlbnRFbGVtZW50KSB7XG4gICAgICAgICAgICAgICAgc2V0TW91c2VEb3duU2lkZShcbiAgICAgICAgICAgICAgICAgIGNsaWNrWCA8IGdldFBvc2l0aW9uKGdldEVsZW1lbnQobG9jYWxWYWx1ZSkpXG4gICAgICAgICAgICAgICAgICAgID8gJ2xlZnQnXG4gICAgICAgICAgICAgICAgICAgIDogJ3JpZ2h0JyxcbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgc2V0V2lkdGgod2lkdGggKyBGT0NVU19PVkVSTEFZX1NDQUxFX1JBVElPKVxuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNldE1vdXNlRG93blNpZGUobnVsbClcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIG9uTW91c2VVcD17KCkgPT4ge1xuICAgICAgICAgICAgICBzZXRNb3VzZURvd25TaWRlKG51bGwpXG4gICAgICAgICAgICAgIGlmIChtb3VzZURvd25TaWRlKSBzZXRXaWR0aCh3aWR0aCAtIEZPQ1VTX09WRVJMQVlfU0NBTEVfUkFUSU8pXG4gICAgICAgICAgICB9fVxuICAgICAgICAgICAgb25Nb3VzZUxlYXZlPXsoKSA9PiB7XG4gICAgICAgICAgICAgIHNldE1vdXNlRG93blNpZGUobnVsbClcbiAgICAgICAgICAgICAgaWYgKG1vdXNlRG93blNpZGUpIHNldFdpZHRoKHdpZHRoIC0gRk9DVVNfT1ZFUkxBWV9TQ0FMRV9SQVRJTylcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBkYXRhLXNpemU9e3NpemV9XG4gICAgICAgICAgICByZWY9e2NvbnRhaW5lclJlZn1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7d2lkdGggPyAoXG4gICAgICAgICAgICAgIDxGb2N1c092ZXJsYXlcbiAgICAgICAgICAgICAgICBjYXJkV2lkdGg9e3dpZHRofVxuICAgICAgICAgICAgICAgIHBvc2l0aW9uPXtwb3NpdGlvbn1cbiAgICAgICAgICAgICAgICBtb3VzZURvd25TaWRlPXttb3VzZURvd25TaWRlfVxuICAgICAgICAgICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgPC9TdHlsZWRCb3JkZXJlZEJveD5cbiAgICAgICAgPC9TdGFjaz5cbiAgICAgIDwvVG9vbHRpcD5cbiAgICA8L1N3aXRjaEJ1dHRvbkNvbnRleHQuUHJvdmlkZXI+XG4gIClcbn1cblxuU3dpdGNoQnV0dG9uLk9wdGlvbiA9IE9wdGlvblxuIl19 */"));
|
|
34
34
|
const SwitchButton = ({
|
|
35
35
|
value,
|
|
36
36
|
onChange,
|