@alfalab/core-components-radio-group 5.1.0 → 5.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/components/base-radio-group/Component.d.ts +3 -3
  2. package/components/base-radio-group/Component.js +2 -2
  3. package/components/base-radio-group/Component.js.map +1 -1
  4. package/components/base-radio-group/index.css +17 -17
  5. package/components/base-radio-group/index.module.css.js +1 -1
  6. package/cssm/components/base-radio-group/Component.d.ts +3 -3
  7. package/cssm/components/base-radio-group/Component.js +2 -2
  8. package/cssm/components/base-radio-group/Component.js.map +1 -1
  9. package/cssm/components/base-radio-group/index.module.css +2 -2
  10. package/cssm/desktop/desktop.module.css +1 -1
  11. package/cssm/mobile/mobile.module.css +3 -3
  12. package/desktop/desktop.css +6 -6
  13. package/desktop/desktop.module.css.js +1 -1
  14. package/esm/components/base-radio-group/Component.d.ts +3 -3
  15. package/esm/components/base-radio-group/Component.js +3 -3
  16. package/esm/components/base-radio-group/Component.js.map +1 -1
  17. package/esm/components/base-radio-group/index.css +17 -17
  18. package/esm/components/base-radio-group/index.module.css.js +1 -1
  19. package/esm/desktop/desktop.css +6 -6
  20. package/esm/desktop/desktop.module.css.js +1 -1
  21. package/esm/mobile/mobile.css +10 -10
  22. package/esm/mobile/mobile.module.css.js +1 -1
  23. package/mobile/mobile.css +10 -10
  24. package/mobile/mobile.module.css.js +1 -1
  25. package/modern/components/base-radio-group/Component.d.ts +3 -3
  26. package/modern/components/base-radio-group/Component.js +2 -2
  27. package/modern/components/base-radio-group/Component.js.map +1 -1
  28. package/modern/components/base-radio-group/index.css +17 -17
  29. package/modern/components/base-radio-group/index.module.css.js +1 -1
  30. package/modern/desktop/desktop.css +6 -6
  31. package/modern/desktop/desktop.module.css.js +1 -1
  32. package/modern/mobile/mobile.css +10 -10
  33. package/modern/mobile/mobile.module.css.js +1 -1
  34. package/moderncssm/components/base-radio-group/Component.d.ts +3 -3
  35. package/moderncssm/components/base-radio-group/Component.js +2 -2
  36. package/moderncssm/components/base-radio-group/Component.js.map +1 -1
  37. package/moderncssm/components/base-radio-group/index.module.css +4 -2
  38. package/moderncssm/desktop/desktop.module.css +3 -1
  39. package/moderncssm/mobile/mobile.module.css +5 -3
  40. package/package.json +2 -2
  41. package/src/components/base-radio-group/Component.tsx +12 -3
  42. package/src/vars.css +1 -1
@@ -16,28 +16,28 @@
16
16
  --radio-group-mobile-label-color: var(--color-light-text-secondary);
17
17
  --radio-group-mobile-error-padding-left: var(--gap-0);
18
18
  --radio-group-mobile-error-border-left: none;
19
- } .radio-group__radioList_1estx {
19
+ } .radio-group__radioList_gxadg {
20
20
  padding-left: var(--radio-group-mobile-list-padding-left);
21
- } .radio-group__label_1estx {
21
+ } .radio-group__label_gxadg {
22
22
  font-size: 14px;
23
23
  line-height: 18px;
24
24
  font-weight: 400;
25
25
  color: var(--radio-group-mobile-label-color);
26
26
  padding-left: var(--radio-group-mobile-sub-padding-left);
27
- margin-bottom: var(--gap-12)
28
- } .radio-group__label_1estx.radio-group__tag_1estx {
27
+ margin-bottom: var(--gap-12);
28
+ } .radio-group__label_gxadg.radio-group__tag_gxadg {
29
29
  margin-bottom: var(--gap-8);
30
- } .radio-group__sub_1estx {
30
+ } .radio-group__sub_gxadg {
31
31
  font-size: 14px;
32
32
  line-height: 18px;
33
33
  font-weight: 400;
34
34
  margin-top: var(--gap-12);
35
- padding-left: var(--radio-group-mobile-sub-padding-left)
36
- } .radio-group__sub_1estx.radio-group__tag_1estx {
35
+ padding-left: var(--radio-group-mobile-sub-padding-left);
36
+ } .radio-group__sub_gxadg.radio-group__tag_gxadg {
37
37
  margin-top: var(--gap-8);
38
- } .radio-group__error_1estx {
38
+ } .radio-group__error_gxadg {
39
39
  padding-left: var(--radio-group-mobile-error-padding-left);
40
- border-left: var(--radio-group-mobile-error-border-left)
41
- } .radio-group__error_1estx.radio-group__tag_1estx {
40
+ border-left: var(--radio-group-mobile-error-border-left);
41
+ } .radio-group__error_gxadg.radio-group__tag_gxadg {
42
42
  padding-left: var(--gap-0);
43
43
  }
@@ -1,6 +1,6 @@
1
1
  import './mobile.css';
2
2
 
3
- var styles = {"radioList":"radio-group__radioList_1estx","label":"radio-group__label_1estx","tag":"radio-group__tag_1estx","sub":"radio-group__sub_1estx","error":"radio-group__error_1estx"};
3
+ var styles = {"radioList":"radio-group__radioList_gxadg","label":"radio-group__label_gxadg","tag":"radio-group__tag_gxadg","sub":"radio-group__sub_gxadg","error":"radio-group__error_gxadg"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=mobile.module.css.js.map
package/mobile/mobile.css CHANGED
@@ -16,28 +16,28 @@
16
16
  --radio-group-mobile-label-color: var(--color-light-text-secondary);
17
17
  --radio-group-mobile-error-padding-left: var(--gap-0);
18
18
  --radio-group-mobile-error-border-left: none;
19
- } .radio-group__radioList_1estx {
19
+ } .radio-group__radioList_gxadg {
20
20
  padding-left: var(--radio-group-mobile-list-padding-left);
21
- } .radio-group__label_1estx {
21
+ } .radio-group__label_gxadg {
22
22
  font-size: 14px;
23
23
  line-height: 18px;
24
24
  font-weight: 400;
25
25
  color: var(--radio-group-mobile-label-color);
26
26
  padding-left: var(--radio-group-mobile-sub-padding-left);
27
- margin-bottom: var(--gap-12)
28
- } .radio-group__label_1estx.radio-group__tag_1estx {
27
+ margin-bottom: var(--gap-12);
28
+ } .radio-group__label_gxadg.radio-group__tag_gxadg {
29
29
  margin-bottom: var(--gap-8);
30
- } .radio-group__sub_1estx {
30
+ } .radio-group__sub_gxadg {
31
31
  font-size: 14px;
32
32
  line-height: 18px;
33
33
  font-weight: 400;
34
34
  margin-top: var(--gap-12);
35
- padding-left: var(--radio-group-mobile-sub-padding-left)
36
- } .radio-group__sub_1estx.radio-group__tag_1estx {
35
+ padding-left: var(--radio-group-mobile-sub-padding-left);
36
+ } .radio-group__sub_gxadg.radio-group__tag_gxadg {
37
37
  margin-top: var(--gap-8);
38
- } .radio-group__error_1estx {
38
+ } .radio-group__error_gxadg {
39
39
  padding-left: var(--radio-group-mobile-error-padding-left);
40
- border-left: var(--radio-group-mobile-error-border-left)
41
- } .radio-group__error_1estx.radio-group__tag_1estx {
40
+ border-left: var(--radio-group-mobile-error-border-left);
41
+ } .radio-group__error_gxadg.radio-group__tag_gxadg {
42
42
  padding-left: var(--gap-0);
43
43
  }
@@ -2,7 +2,7 @@
2
2
 
3
3
  require('./mobile.css');
4
4
 
5
- var styles = {"radioList":"radio-group__radioList_1estx","label":"radio-group__label_1estx","tag":"radio-group__tag_1estx","sub":"radio-group__sub_1estx","error":"radio-group__error_1estx"};
5
+ var styles = {"radioList":"radio-group__radioList_gxadg","label":"radio-group__label_gxadg","tag":"radio-group__tag_gxadg","sub":"radio-group__sub_gxadg","error":"radio-group__error_gxadg"};
6
6
 
7
7
  module.exports = styles;
8
8
  //# sourceMappingURL=mobile.module.css.js.map
@@ -1,7 +1,7 @@
1
- import React, { ChangeEvent, FocusEvent, MouseEvent, ReactNode } from 'react';
1
+ import React, { AriaAttributes, ChangeEvent, FocusEvent, HTMLAttributes, MouseEvent, ReactNode } from 'react';
2
2
  export declare type Direction = 'horizontal' | 'vertical';
3
3
  export declare type RadioGroupType = 'radio' | 'tag';
4
- export declare type BaseRadioGroupProps = {
4
+ export interface BaseRadioGroupProps extends Omit<HTMLAttributes<HTMLDivElement>, 'onChange' | 'onBlur' | 'onFocus' | 'children' | 'className'>, AriaAttributes {
5
5
  /**
6
6
  * Заголовок группы
7
7
  */
@@ -71,5 +71,5 @@ export declare type BaseRadioGroupProps = {
71
71
  styles: {
72
72
  [key: string]: string;
73
73
  };
74
- };
74
+ }
75
75
  export declare const BaseRadioGroup: React.ForwardRefExoticComponent<BaseRadioGroupProps & React.RefAttributes<HTMLDivElement>>;
@@ -4,7 +4,7 @@ import { getDataTestId } from '@alfalab/core-components-shared/modern';
4
4
  import { useDidUpdateEffect } from '@alfalab/hooks';
5
5
  import commonStyles from './index.module.css.js';
6
6
 
7
- const BaseRadioGroup = forwardRef(({ children, className, radioListClassName, direction = 'vertical', label, error, hint, onChange, onBlur, onFocus, type = 'radio', dataTestId, disabled = false, name, value, styles, }, ref) => {
7
+ const BaseRadioGroup = forwardRef(({ children, className, radioListClassName, direction = 'vertical', label, error, hint, onChange, onBlur, onFocus, type = 'radio', dataTestId, disabled = false, name, value, styles, ...restProps }, ref) => {
8
8
  const [stateValue, setStateValue] = useState('');
9
9
  useDidUpdateEffect(() => {
10
10
  setStateValue(value);
@@ -43,7 +43,7 @@ const BaseRadioGroup = forwardRef(({ children, className, radioListClassName, di
43
43
  clone));
44
44
  };
45
45
  const errorMessage = typeof error === 'boolean' ? '' : error;
46
- return (React.createElement("div", { className: cn(commonStyles.component, commonStyles[type], { [styles.error]: error }, className), "data-test-id": dataTestId, ref: ref },
46
+ return (React.createElement("div", { className: cn(commonStyles.component, commonStyles[type], { [styles.error]: error }, className), ref: ref, "data-test-id": dataTestId, ...restProps },
47
47
  label ? (React.createElement("span", { className: cn(styles.label, {
48
48
  [styles.tag]: type === 'tag',
49
49
  }), "data-test-id": getDataTestId(dataTestId, 'label') }, label)) : null,
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/base-radio-group/Component.tsx"],"sourcesContent":["import React, {\n ChangeEvent,\n Children,\n cloneElement,\n FocusEvent,\n forwardRef,\n isValidElement,\n MouseEvent,\n ReactElement,\n ReactNode,\n useState,\n} from 'react';\nimport cn from 'classnames';\n\nimport { getDataTestId } from '@alfalab/core-components-shared';\nimport { useDidUpdateEffect } from '@alfalab/hooks';\n\nimport commonStyles from './index.module.css';\n\nexport type Direction = 'horizontal' | 'vertical';\nexport type RadioGroupType = 'radio' | 'tag';\n\nexport type BaseRadioGroupProps = {\n /**\n * Заголовок группы\n */\n label?: ReactNode;\n\n /**\n * Направление\n */\n direction?: Direction;\n\n /**\n * Тип компонента\n */\n type?: RadioGroupType;\n\n /**\n * Дополнительный класс\n */\n className?: string;\n\n /**\n * Дополнительный класс для списка радио элементов\n */\n radioListClassName?: string;\n\n /**\n * Отображение ошибки\n */\n error?: ReactNode | boolean;\n\n /**\n * Текст подсказки снизу\n */\n hint?: ReactNode;\n\n /**\n * Дочерние элементы. Ожидаются компоненты `Radio` или `Tag`\n */\n children: ReactNode;\n\n /**\n * Обработчик изменения значения 'checked' одного из дочерних компонентов\n */\n onChange?: (\n event: ChangeEvent | MouseEvent,\n payload: {\n value: string;\n name?: string;\n },\n ) => void;\n\n /**\n * Обработчик блюра.\n */\n onBlur?: (event: FocusEvent<HTMLInputElement>) => void;\n\n /**\n * Обработчик фокуса.\n */\n onFocus?: (event: FocusEvent<HTMLInputElement>) => void;\n\n /**\n * Управление возможностью изменения состояния 'checked' дочерних компонентов Radio | Tag\n */\n disabled?: boolean;\n\n /**\n * Идентификатор для систем автоматизированного тестирования\n */\n dataTestId?: string;\n\n /**\n * Атрибут name для всех дочерних компонентов\n */\n name?: string;\n\n /**\n * Value выбранного дочернего элемента\n */\n value?: string | null;\n\n /**\n * Основные стили компонента.\n */\n styles: { [key: string]: string };\n};\n\nexport const BaseRadioGroup = forwardRef<HTMLDivElement, BaseRadioGroupProps>(\n (\n {\n children,\n className,\n radioListClassName,\n direction = 'vertical',\n label,\n error,\n hint,\n onChange,\n onBlur,\n onFocus,\n type = 'radio',\n dataTestId,\n disabled = false,\n name,\n value,\n styles,\n },\n ref,\n ) => {\n const [stateValue, setStateValue] = useState<BaseRadioGroupProps['value']>('');\n\n useDidUpdateEffect(() => {\n setStateValue(value);\n }, [value]);\n\n const isChecked = (childValue: string) =>\n value !== null && (value || stateValue) === childValue;\n\n const handleChange = (event: ChangeEvent | MouseEvent, childValue: string) => {\n setStateValue(childValue);\n if (onChange) {\n onChange(event, { name, value: childValue });\n }\n };\n\n const renderRadio = (child: ReactElement) => {\n const { className: childClassName, value: childValue } = child.props;\n\n return cloneElement(child, {\n onChange: (event: ChangeEvent) => handleChange(event, childValue),\n disabled,\n ...child.props,\n checked: isChecked(childValue),\n name,\n className: cn(childClassName, commonStyles[`${direction}Radio`]),\n });\n };\n\n const renderTag = (child: ReactElement) => {\n const childValue = child.props.value;\n const checked = isChecked(childValue);\n const clone = cloneElement(child, {\n onClick: (event: MouseEvent) => handleChange(event, childValue),\n disabled,\n ...child.props,\n checked,\n name,\n tabIndex: -1,\n });\n\n return (\n <label\n className={cn(\n commonStyles[`${direction}Radio`],\n commonStyles[`${direction}TagLabel`],\n commonStyles.tagLabel,\n )}\n >\n <input\n type='radio'\n autoComplete='off'\n onChange={(event: ChangeEvent) => handleChange(event, childValue)}\n disabled={disabled || child.props.disabled}\n name={name}\n checked={checked}\n className={commonStyles.hiddenInput}\n value={child.props.value}\n />\n {clone}\n </label>\n );\n };\n\n const errorMessage = typeof error === 'boolean' ? '' : error;\n\n return (\n <div\n className={cn(\n commonStyles.component,\n commonStyles[type],\n { [styles.error]: error },\n className,\n )}\n data-test-id={dataTestId}\n ref={ref}\n >\n {label ? (\n <span\n className={cn(styles.label, {\n [styles.tag]: type === 'tag',\n })}\n data-test-id={getDataTestId(dataTestId, 'label')}\n >\n {label}\n </span>\n ) : null}\n\n {children ? (\n <div\n className={cn(\n commonStyles.radioList,\n commonStyles[`${direction}RadioList`],\n radioListClassName,\n { [styles.radioList]: type === 'radio' },\n )}\n onBlur={onBlur}\n onFocus={onFocus}\n >\n {Children.map(children, (child) => {\n if (isValidElement(child)) {\n return type === 'radio' ? renderRadio(child) : renderTag(child);\n }\n\n return null;\n })}\n </div>\n ) : null}\n\n {errorMessage && (\n <span\n className={cn(\n styles.sub,\n {\n [styles.tag]: type === 'tag',\n },\n commonStyles.errorMessage,\n )}\n role='alert'\n data-test-id={getDataTestId(dataTestId, 'error')}\n >\n {errorMessage}\n </span>\n )}\n\n {hint && !errorMessage && (\n <span\n className={cn(\n styles.sub,\n {\n [styles.tag]: type === 'tag',\n },\n commonStyles.hint,\n )}\n data-test-id={getDataTestId(dataTestId, 'hint')}\n >\n {hint}\n </span>\n )}\n </div>\n );\n },\n);\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/base-radio-group/Component.tsx"],"sourcesContent":["import React, {\n AriaAttributes,\n ChangeEvent,\n Children,\n cloneElement,\n FocusEvent,\n forwardRef,\n HTMLAttributes,\n isValidElement,\n MouseEvent,\n ReactElement,\n ReactNode,\n useState,\n} from 'react';\nimport cn from 'classnames';\n\nimport { getDataTestId } from '@alfalab/core-components-shared';\nimport { useDidUpdateEffect } from '@alfalab/hooks';\n\nimport commonStyles from './index.module.css';\n\nexport type Direction = 'horizontal' | 'vertical';\nexport type RadioGroupType = 'radio' | 'tag';\n\nexport interface BaseRadioGroupProps\n extends Omit<\n HTMLAttributes<HTMLDivElement>,\n 'onChange' | 'onBlur' | 'onFocus' | 'children' | 'className'\n >,\n AriaAttributes {\n /**\n * Заголовок группы\n */\n label?: ReactNode;\n\n /**\n * Направление\n */\n direction?: Direction;\n\n /**\n * Тип компонента\n */\n type?: RadioGroupType;\n\n /**\n * Дополнительный класс\n */\n className?: string;\n\n /**\n * Дополнительный класс для списка радио элементов\n */\n radioListClassName?: string;\n\n /**\n * Отображение ошибки\n */\n error?: ReactNode | boolean;\n\n /**\n * Текст подсказки снизу\n */\n hint?: ReactNode;\n\n /**\n * Дочерние элементы. Ожидаются компоненты `Radio` или `Tag`\n */\n children: ReactNode;\n\n /**\n * Обработчик изменения значения 'checked' одного из дочерних компонентов\n */\n onChange?: (\n event: ChangeEvent | MouseEvent,\n payload: {\n value: string;\n name?: string;\n },\n ) => void;\n\n /**\n * Обработчик блюра.\n */\n onBlur?: (event: FocusEvent<HTMLInputElement>) => void;\n\n /**\n * Обработчик фокуса.\n */\n onFocus?: (event: FocusEvent<HTMLInputElement>) => void;\n\n /**\n * Управление возможностью изменения состояния 'checked' дочерних компонентов Radio | Tag\n */\n disabled?: boolean;\n\n /**\n * Идентификатор для систем автоматизированного тестирования\n */\n dataTestId?: string;\n\n /**\n * Атрибут name для всех дочерних компонентов\n */\n name?: string;\n\n /**\n * Value выбранного дочернего элемента\n */\n value?: string | null;\n\n /**\n * Основные стили компонента.\n */\n styles: { [key: string]: string };\n}\n\nexport const BaseRadioGroup = forwardRef<HTMLDivElement, BaseRadioGroupProps>(\n (\n {\n children,\n className,\n radioListClassName,\n direction = 'vertical',\n label,\n error,\n hint,\n onChange,\n onBlur,\n onFocus,\n type = 'radio',\n dataTestId,\n disabled = false,\n name,\n value,\n styles,\n ...restProps\n },\n ref,\n ) => {\n const [stateValue, setStateValue] = useState<BaseRadioGroupProps['value']>('');\n\n useDidUpdateEffect(() => {\n setStateValue(value);\n }, [value]);\n\n const isChecked = (childValue: string) =>\n value !== null && (value || stateValue) === childValue;\n\n const handleChange = (event: ChangeEvent | MouseEvent, childValue: string) => {\n setStateValue(childValue);\n if (onChange) {\n onChange(event, { name, value: childValue });\n }\n };\n\n const renderRadio = (child: ReactElement) => {\n const { className: childClassName, value: childValue } = child.props;\n\n return cloneElement(child, {\n onChange: (event: ChangeEvent) => handleChange(event, childValue),\n disabled,\n ...child.props,\n checked: isChecked(childValue),\n name,\n className: cn(childClassName, commonStyles[`${direction}Radio`]),\n });\n };\n\n const renderTag = (child: ReactElement) => {\n const childValue = child.props.value;\n const checked = isChecked(childValue);\n const clone = cloneElement(child, {\n onClick: (event: MouseEvent) => handleChange(event, childValue),\n disabled,\n ...child.props,\n checked,\n name,\n tabIndex: -1,\n });\n\n return (\n <label\n className={cn(\n commonStyles[`${direction}Radio`],\n commonStyles[`${direction}TagLabel`],\n commonStyles.tagLabel,\n )}\n >\n <input\n type='radio'\n autoComplete='off'\n onChange={(event: ChangeEvent) => handleChange(event, childValue)}\n disabled={disabled || child.props.disabled}\n name={name}\n checked={checked}\n className={commonStyles.hiddenInput}\n value={child.props.value}\n />\n {clone}\n </label>\n );\n };\n\n const errorMessage = typeof error === 'boolean' ? '' : error;\n\n return (\n <div\n className={cn(\n commonStyles.component,\n commonStyles[type],\n { [styles.error]: error },\n className,\n )}\n ref={ref}\n data-test-id={dataTestId}\n {...restProps}\n >\n {label ? (\n <span\n className={cn(styles.label, {\n [styles.tag]: type === 'tag',\n })}\n data-test-id={getDataTestId(dataTestId, 'label')}\n >\n {label}\n </span>\n ) : null}\n\n {children ? (\n <div\n className={cn(\n commonStyles.radioList,\n commonStyles[`${direction}RadioList`],\n radioListClassName,\n { [styles.radioList]: type === 'radio' },\n )}\n onBlur={onBlur}\n onFocus={onFocus}\n >\n {Children.map(children, (child) => {\n if (isValidElement(child)) {\n return type === 'radio' ? renderRadio(child) : renderTag(child);\n }\n\n return null;\n })}\n </div>\n ) : null}\n\n {errorMessage && (\n <span\n className={cn(\n styles.sub,\n {\n [styles.tag]: type === 'tag',\n },\n commonStyles.errorMessage,\n )}\n role='alert'\n data-test-id={getDataTestId(dataTestId, 'error')}\n >\n {errorMessage}\n </span>\n )}\n\n {hint && !errorMessage && (\n <span\n className={cn(\n styles.sub,\n {\n [styles.tag]: type === 'tag',\n },\n commonStyles.hint,\n )}\n data-test-id={getDataTestId(dataTestId, 'hint')}\n >\n {hint}\n </span>\n )}\n </div>\n );\n },\n);\n"],"names":[],"mappings":"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"}
@@ -17,43 +17,43 @@
17
17
  } :root {
18
18
  --radio-group-hint-color: var(--color-light-text-secondary);
19
19
  --radio-group-error-color: var(--color-light-text-negative);
20
- } .radio-group__component_zyivd {
20
+ } .radio-group__component_j2nm5 {
21
21
  display: flex;
22
22
  flex-direction: column;
23
- } .radio-group__radioList_zyivd {
23
+ } .radio-group__radioList_j2nm5 {
24
24
  display: flex;
25
- } .radio-group__verticalRadioList_zyivd {
25
+ } .radio-group__verticalRadioList_j2nm5 {
26
26
  flex-direction: column;
27
27
  align-items: flex-start;
28
- } .radio-group__horizontalRadioList_zyivd {
28
+ } .radio-group__horizontalRadioList_j2nm5 {
29
29
  flex-wrap: wrap;
30
30
  margin-bottom: var(--gap-8-neg);
31
- } .radio-group__verticalRadio_zyivd {
32
- margin-bottom: var(--gap-12)
33
- } .radio-group__verticalRadio_zyivd:last-child {
31
+ } .radio-group__verticalRadio_j2nm5 {
32
+ margin-bottom: var(--gap-12);
33
+ } .radio-group__verticalRadio_j2nm5:last-child {
34
34
  margin-bottom: var(--gap-0);
35
- } .radio-group__horizontalRadio_zyivd {
35
+ } .radio-group__horizontalRadio_j2nm5 {
36
36
  margin-right: var(--gap-24);
37
37
  margin-bottom: var(--gap-8);
38
- } .radio-group__horizontalTagLabel_zyivd {
38
+ } .radio-group__horizontalTagLabel_j2nm5 {
39
39
  margin-right: var(--gap-8);
40
- } .radio-group__horizontalRadio_zyivd:last-child,
41
- .radio-group__horizontalTagLabel_zyivd:last-child {
40
+ } .radio-group__horizontalRadio_j2nm5:last-child,
41
+ .radio-group__horizontalTagLabel_j2nm5:last-child {
42
42
  margin-right: var(--gap-0);
43
- } .radio-group__errorMessage_zyivd {
43
+ } .radio-group__errorMessage_j2nm5 {
44
44
  color: var(--radio-group-error-color);
45
- } .radio-group__hint_zyivd {
45
+ } .radio-group__hint_j2nm5 {
46
46
  color: var(--radio-group-hint-color);
47
- } .radio-group__hiddenInput_zyivd {
47
+ } .radio-group__hiddenInput_j2nm5 {
48
48
  position: absolute;
49
49
  z-index: -1;
50
50
  top: var(--gap-0);
51
51
  left: var(--gap-0);
52
- opacity: 0
53
- } .radio-group__hiddenInput_zyivd:focus ~ button {
52
+ opacity: 0;
53
+ } .radio-group__hiddenInput_j2nm5:focus ~ button {
54
54
  outline: 2px solid var(--focus-color);
55
55
  outline-offset: 2px;
56
- } .radio-group__tagLabel_zyivd {
56
+ } .radio-group__tagLabel_j2nm5 {
57
57
  position: relative;
58
58
  max-width: 100%;
59
59
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- const commonStyles = {"component":"radio-group__component_zyivd","radioList":"radio-group__radioList_zyivd","verticalRadioList":"radio-group__verticalRadioList_zyivd","horizontalRadioList":"radio-group__horizontalRadioList_zyivd","verticalRadio":"radio-group__verticalRadio_zyivd","horizontalRadio":"radio-group__horizontalRadio_zyivd","horizontalTagLabel":"radio-group__horizontalTagLabel_zyivd","errorMessage":"radio-group__errorMessage_zyivd","hint":"radio-group__hint_zyivd","hiddenInput":"radio-group__hiddenInput_zyivd","tagLabel":"radio-group__tagLabel_zyivd"};
3
+ const commonStyles = {"component":"radio-group__component_j2nm5","radioList":"radio-group__radioList_j2nm5","verticalRadioList":"radio-group__verticalRadioList_j2nm5","horizontalRadioList":"radio-group__horizontalRadioList_j2nm5","verticalRadio":"radio-group__verticalRadio_j2nm5","horizontalRadio":"radio-group__horizontalRadio_j2nm5","horizontalTagLabel":"radio-group__horizontalTagLabel_j2nm5","errorMessage":"radio-group__errorMessage_j2nm5","hint":"radio-group__hint_j2nm5","hiddenInput":"radio-group__hiddenInput_j2nm5","tagLabel":"radio-group__tagLabel_j2nm5"};
4
4
 
5
5
  export { commonStyles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -13,24 +13,24 @@
13
13
  --radio-group-list-padding-left: var(--gap-0);
14
14
  --radio-group-error-padding-left: var(--gap-8);
15
15
  --radio-group-error-border-left: 1px solid var(--color-light-status-negative);
16
- } .radio-group__radioList_1a60s {
16
+ } .radio-group__radioList_1qcbs {
17
17
  padding-left: var(--radio-group-list-padding-left);
18
- } .radio-group__label_1a60s {
18
+ } .radio-group__label_1qcbs {
19
19
  font-size: 16px;
20
20
  line-height: 24px;
21
21
  font-weight: 400;
22
22
  color: var(--radio-group-label-color);
23
23
  margin-bottom: var(--gap-12);
24
24
  padding-left: var(--radio-group-sub-padding-left);
25
- } .radio-group__sub_1a60s {
25
+ } .radio-group__sub_1qcbs {
26
26
  font-size: 14px;
27
27
  line-height: 18px;
28
28
  font-weight: 400;
29
29
  margin-top: var(--gap-12);
30
30
  padding-left: var(--radio-group-sub-padding-left);
31
- } .radio-group__error_1a60s {
31
+ } .radio-group__error_1qcbs {
32
32
  padding-left: var(--radio-group-error-padding-left);
33
- border-left: var(--radio-group-error-border-left)
34
- } .radio-group__error_1a60s.radio-group__tag_1a60s {
33
+ border-left: var(--radio-group-error-border-left);
34
+ } .radio-group__error_1qcbs.radio-group__tag_1qcbs {
35
35
  padding-left: var(--gap-8);
36
36
  }
@@ -1,6 +1,6 @@
1
1
  import './desktop.css';
2
2
 
3
- const styles = {"radioList":"radio-group__radioList_1a60s","label":"radio-group__label_1a60s","sub":"radio-group__sub_1a60s","error":"radio-group__error_1a60s","tag":"radio-group__tag_1a60s"};
3
+ const styles = {"radioList":"radio-group__radioList_1qcbs","label":"radio-group__label_1qcbs","sub":"radio-group__sub_1qcbs","error":"radio-group__error_1qcbs","tag":"radio-group__tag_1qcbs"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=desktop.module.css.js.map
@@ -16,28 +16,28 @@
16
16
  --radio-group-mobile-label-color: var(--color-light-text-secondary);
17
17
  --radio-group-mobile-error-padding-left: var(--gap-0);
18
18
  --radio-group-mobile-error-border-left: none;
19
- } .radio-group__radioList_1estx {
19
+ } .radio-group__radioList_gxadg {
20
20
  padding-left: var(--radio-group-mobile-list-padding-left);
21
- } .radio-group__label_1estx {
21
+ } .radio-group__label_gxadg {
22
22
  font-size: 14px;
23
23
  line-height: 18px;
24
24
  font-weight: 400;
25
25
  color: var(--radio-group-mobile-label-color);
26
26
  padding-left: var(--radio-group-mobile-sub-padding-left);
27
- margin-bottom: var(--gap-12)
28
- } .radio-group__label_1estx.radio-group__tag_1estx {
27
+ margin-bottom: var(--gap-12);
28
+ } .radio-group__label_gxadg.radio-group__tag_gxadg {
29
29
  margin-bottom: var(--gap-8);
30
- } .radio-group__sub_1estx {
30
+ } .radio-group__sub_gxadg {
31
31
  font-size: 14px;
32
32
  line-height: 18px;
33
33
  font-weight: 400;
34
34
  margin-top: var(--gap-12);
35
- padding-left: var(--radio-group-mobile-sub-padding-left)
36
- } .radio-group__sub_1estx.radio-group__tag_1estx {
35
+ padding-left: var(--radio-group-mobile-sub-padding-left);
36
+ } .radio-group__sub_gxadg.radio-group__tag_gxadg {
37
37
  margin-top: var(--gap-8);
38
- } .radio-group__error_1estx {
38
+ } .radio-group__error_gxadg {
39
39
  padding-left: var(--radio-group-mobile-error-padding-left);
40
- border-left: var(--radio-group-mobile-error-border-left)
41
- } .radio-group__error_1estx.radio-group__tag_1estx {
40
+ border-left: var(--radio-group-mobile-error-border-left);
41
+ } .radio-group__error_gxadg.radio-group__tag_gxadg {
42
42
  padding-left: var(--gap-0);
43
43
  }
@@ -1,6 +1,6 @@
1
1
  import './mobile.css';
2
2
 
3
- const styles = {"radioList":"radio-group__radioList_1estx","label":"radio-group__label_1estx","tag":"radio-group__tag_1estx","sub":"radio-group__sub_1estx","error":"radio-group__error_1estx"};
3
+ const styles = {"radioList":"radio-group__radioList_gxadg","label":"radio-group__label_gxadg","tag":"radio-group__tag_gxadg","sub":"radio-group__sub_gxadg","error":"radio-group__error_gxadg"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=mobile.module.css.js.map
@@ -1,7 +1,7 @@
1
- import React, { ChangeEvent, FocusEvent, MouseEvent, ReactNode } from 'react';
1
+ import React, { AriaAttributes, ChangeEvent, FocusEvent, HTMLAttributes, MouseEvent, ReactNode } from 'react';
2
2
  export declare type Direction = 'horizontal' | 'vertical';
3
3
  export declare type RadioGroupType = 'radio' | 'tag';
4
- export declare type BaseRadioGroupProps = {
4
+ export interface BaseRadioGroupProps extends Omit<HTMLAttributes<HTMLDivElement>, 'onChange' | 'onBlur' | 'onFocus' | 'children' | 'className'>, AriaAttributes {
5
5
  /**
6
6
  * Заголовок группы
7
7
  */
@@ -71,5 +71,5 @@ export declare type BaseRadioGroupProps = {
71
71
  styles: {
72
72
  [key: string]: string;
73
73
  };
74
- };
74
+ }
75
75
  export declare const BaseRadioGroup: React.ForwardRefExoticComponent<BaseRadioGroupProps & React.RefAttributes<HTMLDivElement>>;
@@ -4,7 +4,7 @@ import { getDataTestId } from '@alfalab/core-components-shared/moderncssm';
4
4
  import { useDidUpdateEffect } from '@alfalab/hooks';
5
5
  import commonStyles from './index.module.css';
6
6
 
7
- const BaseRadioGroup = forwardRef(({ children, className, radioListClassName, direction = 'vertical', label, error, hint, onChange, onBlur, onFocus, type = 'radio', dataTestId, disabled = false, name, value, styles, }, ref) => {
7
+ const BaseRadioGroup = forwardRef(({ children, className, radioListClassName, direction = 'vertical', label, error, hint, onChange, onBlur, onFocus, type = 'radio', dataTestId, disabled = false, name, value, styles, ...restProps }, ref) => {
8
8
  const [stateValue, setStateValue] = useState('');
9
9
  useDidUpdateEffect(() => {
10
10
  setStateValue(value);
@@ -43,7 +43,7 @@ const BaseRadioGroup = forwardRef(({ children, className, radioListClassName, di
43
43
  clone));
44
44
  };
45
45
  const errorMessage = typeof error === 'boolean' ? '' : error;
46
- return (React.createElement("div", { className: cn(commonStyles.component, commonStyles[type], { [styles.error]: error }, className), "data-test-id": dataTestId, ref: ref },
46
+ return (React.createElement("div", { className: cn(commonStyles.component, commonStyles[type], { [styles.error]: error }, className), ref: ref, "data-test-id": dataTestId, ...restProps },
47
47
  label ? (React.createElement("span", { className: cn(styles.label, {
48
48
  [styles.tag]: type === 'tag',
49
49
  }), "data-test-id": getDataTestId(dataTestId, 'label') }, label)) : null,
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/base-radio-group/Component.tsx"],"sourcesContent":["import React, {\n ChangeEvent,\n Children,\n cloneElement,\n FocusEvent,\n forwardRef,\n isValidElement,\n MouseEvent,\n ReactElement,\n ReactNode,\n useState,\n} from 'react';\nimport cn from 'classnames';\n\nimport { getDataTestId } from '@alfalab/core-components-shared';\nimport { useDidUpdateEffect } from '@alfalab/hooks';\n\nimport commonStyles from './index.module.css';\n\nexport type Direction = 'horizontal' | 'vertical';\nexport type RadioGroupType = 'radio' | 'tag';\n\nexport type BaseRadioGroupProps = {\n /**\n * Заголовок группы\n */\n label?: ReactNode;\n\n /**\n * Направление\n */\n direction?: Direction;\n\n /**\n * Тип компонента\n */\n type?: RadioGroupType;\n\n /**\n * Дополнительный класс\n */\n className?: string;\n\n /**\n * Дополнительный класс для списка радио элементов\n */\n radioListClassName?: string;\n\n /**\n * Отображение ошибки\n */\n error?: ReactNode | boolean;\n\n /**\n * Текст подсказки снизу\n */\n hint?: ReactNode;\n\n /**\n * Дочерние элементы. Ожидаются компоненты `Radio` или `Tag`\n */\n children: ReactNode;\n\n /**\n * Обработчик изменения значения 'checked' одного из дочерних компонентов\n */\n onChange?: (\n event: ChangeEvent | MouseEvent,\n payload: {\n value: string;\n name?: string;\n },\n ) => void;\n\n /**\n * Обработчик блюра.\n */\n onBlur?: (event: FocusEvent<HTMLInputElement>) => void;\n\n /**\n * Обработчик фокуса.\n */\n onFocus?: (event: FocusEvent<HTMLInputElement>) => void;\n\n /**\n * Управление возможностью изменения состояния 'checked' дочерних компонентов Radio | Tag\n */\n disabled?: boolean;\n\n /**\n * Идентификатор для систем автоматизированного тестирования\n */\n dataTestId?: string;\n\n /**\n * Атрибут name для всех дочерних компонентов\n */\n name?: string;\n\n /**\n * Value выбранного дочернего элемента\n */\n value?: string | null;\n\n /**\n * Основные стили компонента.\n */\n styles: { [key: string]: string };\n};\n\nexport const BaseRadioGroup = forwardRef<HTMLDivElement, BaseRadioGroupProps>(\n (\n {\n children,\n className,\n radioListClassName,\n direction = 'vertical',\n label,\n error,\n hint,\n onChange,\n onBlur,\n onFocus,\n type = 'radio',\n dataTestId,\n disabled = false,\n name,\n value,\n styles,\n },\n ref,\n ) => {\n const [stateValue, setStateValue] = useState<BaseRadioGroupProps['value']>('');\n\n useDidUpdateEffect(() => {\n setStateValue(value);\n }, [value]);\n\n const isChecked = (childValue: string) =>\n value !== null && (value || stateValue) === childValue;\n\n const handleChange = (event: ChangeEvent | MouseEvent, childValue: string) => {\n setStateValue(childValue);\n if (onChange) {\n onChange(event, { name, value: childValue });\n }\n };\n\n const renderRadio = (child: ReactElement) => {\n const { className: childClassName, value: childValue } = child.props;\n\n return cloneElement(child, {\n onChange: (event: ChangeEvent) => handleChange(event, childValue),\n disabled,\n ...child.props,\n checked: isChecked(childValue),\n name,\n className: cn(childClassName, commonStyles[`${direction}Radio`]),\n });\n };\n\n const renderTag = (child: ReactElement) => {\n const childValue = child.props.value;\n const checked = isChecked(childValue);\n const clone = cloneElement(child, {\n onClick: (event: MouseEvent) => handleChange(event, childValue),\n disabled,\n ...child.props,\n checked,\n name,\n tabIndex: -1,\n });\n\n return (\n <label\n className={cn(\n commonStyles[`${direction}Radio`],\n commonStyles[`${direction}TagLabel`],\n commonStyles.tagLabel,\n )}\n >\n <input\n type='radio'\n autoComplete='off'\n onChange={(event: ChangeEvent) => handleChange(event, childValue)}\n disabled={disabled || child.props.disabled}\n name={name}\n checked={checked}\n className={commonStyles.hiddenInput}\n value={child.props.value}\n />\n {clone}\n </label>\n );\n };\n\n const errorMessage = typeof error === 'boolean' ? '' : error;\n\n return (\n <div\n className={cn(\n commonStyles.component,\n commonStyles[type],\n { [styles.error]: error },\n className,\n )}\n data-test-id={dataTestId}\n ref={ref}\n >\n {label ? (\n <span\n className={cn(styles.label, {\n [styles.tag]: type === 'tag',\n })}\n data-test-id={getDataTestId(dataTestId, 'label')}\n >\n {label}\n </span>\n ) : null}\n\n {children ? (\n <div\n className={cn(\n commonStyles.radioList,\n commonStyles[`${direction}RadioList`],\n radioListClassName,\n { [styles.radioList]: type === 'radio' },\n )}\n onBlur={onBlur}\n onFocus={onFocus}\n >\n {Children.map(children, (child) => {\n if (isValidElement(child)) {\n return type === 'radio' ? renderRadio(child) : renderTag(child);\n }\n\n return null;\n })}\n </div>\n ) : null}\n\n {errorMessage && (\n <span\n className={cn(\n styles.sub,\n {\n [styles.tag]: type === 'tag',\n },\n commonStyles.errorMessage,\n )}\n role='alert'\n data-test-id={getDataTestId(dataTestId, 'error')}\n >\n {errorMessage}\n </span>\n )}\n\n {hint && !errorMessage && (\n <span\n className={cn(\n styles.sub,\n {\n [styles.tag]: type === 'tag',\n },\n commonStyles.hint,\n )}\n data-test-id={getDataTestId(dataTestId, 'hint')}\n >\n {hint}\n </span>\n )}\n </div>\n );\n },\n);\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/base-radio-group/Component.tsx"],"sourcesContent":["import React, {\n AriaAttributes,\n ChangeEvent,\n Children,\n cloneElement,\n FocusEvent,\n forwardRef,\n HTMLAttributes,\n isValidElement,\n MouseEvent,\n ReactElement,\n ReactNode,\n useState,\n} from 'react';\nimport cn from 'classnames';\n\nimport { getDataTestId } from '@alfalab/core-components-shared';\nimport { useDidUpdateEffect } from '@alfalab/hooks';\n\nimport commonStyles from './index.module.css';\n\nexport type Direction = 'horizontal' | 'vertical';\nexport type RadioGroupType = 'radio' | 'tag';\n\nexport interface BaseRadioGroupProps\n extends Omit<\n HTMLAttributes<HTMLDivElement>,\n 'onChange' | 'onBlur' | 'onFocus' | 'children' | 'className'\n >,\n AriaAttributes {\n /**\n * Заголовок группы\n */\n label?: ReactNode;\n\n /**\n * Направление\n */\n direction?: Direction;\n\n /**\n * Тип компонента\n */\n type?: RadioGroupType;\n\n /**\n * Дополнительный класс\n */\n className?: string;\n\n /**\n * Дополнительный класс для списка радио элементов\n */\n radioListClassName?: string;\n\n /**\n * Отображение ошибки\n */\n error?: ReactNode | boolean;\n\n /**\n * Текст подсказки снизу\n */\n hint?: ReactNode;\n\n /**\n * Дочерние элементы. Ожидаются компоненты `Radio` или `Tag`\n */\n children: ReactNode;\n\n /**\n * Обработчик изменения значения 'checked' одного из дочерних компонентов\n */\n onChange?: (\n event: ChangeEvent | MouseEvent,\n payload: {\n value: string;\n name?: string;\n },\n ) => void;\n\n /**\n * Обработчик блюра.\n */\n onBlur?: (event: FocusEvent<HTMLInputElement>) => void;\n\n /**\n * Обработчик фокуса.\n */\n onFocus?: (event: FocusEvent<HTMLInputElement>) => void;\n\n /**\n * Управление возможностью изменения состояния 'checked' дочерних компонентов Radio | Tag\n */\n disabled?: boolean;\n\n /**\n * Идентификатор для систем автоматизированного тестирования\n */\n dataTestId?: string;\n\n /**\n * Атрибут name для всех дочерних компонентов\n */\n name?: string;\n\n /**\n * Value выбранного дочернего элемента\n */\n value?: string | null;\n\n /**\n * Основные стили компонента.\n */\n styles: { [key: string]: string };\n}\n\nexport const BaseRadioGroup = forwardRef<HTMLDivElement, BaseRadioGroupProps>(\n (\n {\n children,\n className,\n radioListClassName,\n direction = 'vertical',\n label,\n error,\n hint,\n onChange,\n onBlur,\n onFocus,\n type = 'radio',\n dataTestId,\n disabled = false,\n name,\n value,\n styles,\n ...restProps\n },\n ref,\n ) => {\n const [stateValue, setStateValue] = useState<BaseRadioGroupProps['value']>('');\n\n useDidUpdateEffect(() => {\n setStateValue(value);\n }, [value]);\n\n const isChecked = (childValue: string) =>\n value !== null && (value || stateValue) === childValue;\n\n const handleChange = (event: ChangeEvent | MouseEvent, childValue: string) => {\n setStateValue(childValue);\n if (onChange) {\n onChange(event, { name, value: childValue });\n }\n };\n\n const renderRadio = (child: ReactElement) => {\n const { className: childClassName, value: childValue } = child.props;\n\n return cloneElement(child, {\n onChange: (event: ChangeEvent) => handleChange(event, childValue),\n disabled,\n ...child.props,\n checked: isChecked(childValue),\n name,\n className: cn(childClassName, commonStyles[`${direction}Radio`]),\n });\n };\n\n const renderTag = (child: ReactElement) => {\n const childValue = child.props.value;\n const checked = isChecked(childValue);\n const clone = cloneElement(child, {\n onClick: (event: MouseEvent) => handleChange(event, childValue),\n disabled,\n ...child.props,\n checked,\n name,\n tabIndex: -1,\n });\n\n return (\n <label\n className={cn(\n commonStyles[`${direction}Radio`],\n commonStyles[`${direction}TagLabel`],\n commonStyles.tagLabel,\n )}\n >\n <input\n type='radio'\n autoComplete='off'\n onChange={(event: ChangeEvent) => handleChange(event, childValue)}\n disabled={disabled || child.props.disabled}\n name={name}\n checked={checked}\n className={commonStyles.hiddenInput}\n value={child.props.value}\n />\n {clone}\n </label>\n );\n };\n\n const errorMessage = typeof error === 'boolean' ? '' : error;\n\n return (\n <div\n className={cn(\n commonStyles.component,\n commonStyles[type],\n { [styles.error]: error },\n className,\n )}\n ref={ref}\n data-test-id={dataTestId}\n {...restProps}\n >\n {label ? (\n <span\n className={cn(styles.label, {\n [styles.tag]: type === 'tag',\n })}\n data-test-id={getDataTestId(dataTestId, 'label')}\n >\n {label}\n </span>\n ) : null}\n\n {children ? (\n <div\n className={cn(\n commonStyles.radioList,\n commonStyles[`${direction}RadioList`],\n radioListClassName,\n { [styles.radioList]: type === 'radio' },\n )}\n onBlur={onBlur}\n onFocus={onFocus}\n >\n {Children.map(children, (child) => {\n if (isValidElement(child)) {\n return type === 'radio' ? renderRadio(child) : renderTag(child);\n }\n\n return null;\n })}\n </div>\n ) : null}\n\n {errorMessage && (\n <span\n className={cn(\n styles.sub,\n {\n [styles.tag]: type === 'tag',\n },\n commonStyles.errorMessage,\n )}\n role='alert'\n data-test-id={getDataTestId(dataTestId, 'error')}\n >\n {errorMessage}\n </span>\n )}\n\n {hint && !errorMessage && (\n <span\n className={cn(\n styles.sub,\n {\n [styles.tag]: type === 'tag',\n },\n commonStyles.hint,\n )}\n data-test-id={getDataTestId(dataTestId, 'hint')}\n >\n {hint}\n </span>\n )}\n </div>\n );\n },\n);\n"],"names":[],"mappings":"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"}
@@ -1,3 +1,5 @@
1
+
2
+
1
3
  :root {
2
4
  --radio-group-hint-color: var(--color-light-text-secondary);
3
5
  --radio-group-error-color: var(--color-light-text-negative);
@@ -23,7 +25,7 @@
23
25
  }
24
26
 
25
27
  .verticalRadio {
26
- margin-bottom: var(--gap-12)
28
+ margin-bottom: var(--gap-12);
27
29
  }
28
30
 
29
31
  .verticalRadio:last-child {
@@ -57,7 +59,7 @@
57
59
  z-index: -1;
58
60
  top: var(--gap-0);
59
61
  left: var(--gap-0);
60
- opacity: 0
62
+ opacity: 0;
61
63
  }
62
64
 
63
65
  .hiddenInput:focus ~ button {
@@ -1,3 +1,5 @@
1
+
2
+
1
3
  :root {
2
4
  --radio-group-label-color: var(--color-light-text-primary);
3
5
  --radio-group-sub-padding-left: var(--gap-0);
@@ -29,7 +31,7 @@
29
31
 
30
32
  .error {
31
33
  padding-left: var(--radio-group-error-padding-left);
32
- border-left: var(--radio-group-error-border-left)
34
+ border-left: var(--radio-group-error-border-left);
33
35
  }
34
36
 
35
37
  .error.tag {
@@ -1,3 +1,5 @@
1
+
2
+
1
3
  :root {
2
4
  --radio-group-mobile-sub-padding-left: var(--gap-4);
3
5
  --radio-group-mobile-list-padding-left: var(--gap-2);
@@ -16,7 +18,7 @@
16
18
  font-weight: 400;
17
19
  color: var(--radio-group-mobile-label-color);
18
20
  padding-left: var(--radio-group-mobile-sub-padding-left);
19
- margin-bottom: var(--gap-12)
21
+ margin-bottom: var(--gap-12);
20
22
  }
21
23
 
22
24
  .label.tag {
@@ -28,7 +30,7 @@
28
30
  line-height: 18px;
29
31
  font-weight: 400;
30
32
  margin-top: var(--gap-12);
31
- padding-left: var(--radio-group-mobile-sub-padding-left)
33
+ padding-left: var(--radio-group-mobile-sub-padding-left);
32
34
  }
33
35
 
34
36
  .sub.tag {
@@ -37,7 +39,7 @@
37
39
 
38
40
  .error {
39
41
  padding-left: var(--radio-group-mobile-error-padding-left);
40
- border-left: var(--radio-group-mobile-error-border-left)
42
+ border-left: var(--radio-group-mobile-error-border-left);
41
43
  }
42
44
 
43
45
  .error.tag {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alfalab/core-components-radio-group",
3
- "version": "5.1.0",
3
+ "version": "5.2.0",
4
4
  "description": "Radio group",
5
5
  "keywords": [],
6
6
  "license": "MIT",
@@ -24,6 +24,6 @@
24
24
  "access": "public",
25
25
  "directory": "dist"
26
26
  },
27
- "themesVersion": "14.1.0",
27
+ "themesVersion": "14.1.2",
28
28
  "varsVersion": "10.1.0"
29
29
  }
@@ -1,9 +1,11 @@
1
1
  import React, {
2
+ AriaAttributes,
2
3
  ChangeEvent,
3
4
  Children,
4
5
  cloneElement,
5
6
  FocusEvent,
6
7
  forwardRef,
8
+ HTMLAttributes,
7
9
  isValidElement,
8
10
  MouseEvent,
9
11
  ReactElement,
@@ -20,7 +22,12 @@ import commonStyles from './index.module.css';
20
22
  export type Direction = 'horizontal' | 'vertical';
21
23
  export type RadioGroupType = 'radio' | 'tag';
22
24
 
23
- export type BaseRadioGroupProps = {
25
+ export interface BaseRadioGroupProps
26
+ extends Omit<
27
+ HTMLAttributes<HTMLDivElement>,
28
+ 'onChange' | 'onBlur' | 'onFocus' | 'children' | 'className'
29
+ >,
30
+ AriaAttributes {
24
31
  /**
25
32
  * Заголовок группы
26
33
  */
@@ -106,7 +113,7 @@ export type BaseRadioGroupProps = {
106
113
  * Основные стили компонента.
107
114
  */
108
115
  styles: { [key: string]: string };
109
- };
116
+ }
110
117
 
111
118
  export const BaseRadioGroup = forwardRef<HTMLDivElement, BaseRadioGroupProps>(
112
119
  (
@@ -127,6 +134,7 @@ export const BaseRadioGroup = forwardRef<HTMLDivElement, BaseRadioGroupProps>(
127
134
  name,
128
135
  value,
129
136
  styles,
137
+ ...restProps
130
138
  },
131
139
  ref,
132
140
  ) => {
@@ -204,8 +212,9 @@ export const BaseRadioGroup = forwardRef<HTMLDivElement, BaseRadioGroupProps>(
204
212
  { [styles.error]: error },
205
213
  className,
206
214
  )}
207
- data-test-id={dataTestId}
208
215
  ref={ref}
216
+ data-test-id={dataTestId}
217
+ {...restProps}
209
218
  >
210
219
  {label ? (
211
220
  <span
package/src/vars.css CHANGED
@@ -1,4 +1,4 @@
1
- @import '@alfalab/core-components-vars/src/index.css';
1
+ @import '@alfalab/core-components-vars/src/no-typography-index.css';
2
2
 
3
3
  :root {
4
4
  --radio-group-hint-color: var(--color-light-text-secondary);