@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.
- package/components/base-radio-group/Component.d.ts +3 -3
- package/components/base-radio-group/Component.js +2 -2
- package/components/base-radio-group/Component.js.map +1 -1
- package/components/base-radio-group/index.css +17 -17
- package/components/base-radio-group/index.module.css.js +1 -1
- package/cssm/components/base-radio-group/Component.d.ts +3 -3
- package/cssm/components/base-radio-group/Component.js +2 -2
- package/cssm/components/base-radio-group/Component.js.map +1 -1
- package/cssm/components/base-radio-group/index.module.css +2 -2
- package/cssm/desktop/desktop.module.css +1 -1
- package/cssm/mobile/mobile.module.css +3 -3
- package/desktop/desktop.css +6 -6
- package/desktop/desktop.module.css.js +1 -1
- package/esm/components/base-radio-group/Component.d.ts +3 -3
- package/esm/components/base-radio-group/Component.js +3 -3
- package/esm/components/base-radio-group/Component.js.map +1 -1
- package/esm/components/base-radio-group/index.css +17 -17
- package/esm/components/base-radio-group/index.module.css.js +1 -1
- package/esm/desktop/desktop.css +6 -6
- package/esm/desktop/desktop.module.css.js +1 -1
- package/esm/mobile/mobile.css +10 -10
- package/esm/mobile/mobile.module.css.js +1 -1
- package/mobile/mobile.css +10 -10
- package/mobile/mobile.module.css.js +1 -1
- package/modern/components/base-radio-group/Component.d.ts +3 -3
- package/modern/components/base-radio-group/Component.js +2 -2
- package/modern/components/base-radio-group/Component.js.map +1 -1
- package/modern/components/base-radio-group/index.css +17 -17
- package/modern/components/base-radio-group/index.module.css.js +1 -1
- package/modern/desktop/desktop.css +6 -6
- package/modern/desktop/desktop.module.css.js +1 -1
- package/modern/mobile/mobile.css +10 -10
- package/modern/mobile/mobile.module.css.js +1 -1
- package/moderncssm/components/base-radio-group/Component.d.ts +3 -3
- package/moderncssm/components/base-radio-group/Component.js +2 -2
- package/moderncssm/components/base-radio-group/Component.js.map +1 -1
- package/moderncssm/components/base-radio-group/index.module.css +4 -2
- package/moderncssm/desktop/desktop.module.css +3 -1
- package/moderncssm/mobile/mobile.module.css +5 -3
- package/package.json +2 -2
- package/src/components/base-radio-group/Component.tsx +12 -3
- package/src/vars.css +1 -1
package/esm/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-
|
|
19
|
+
} .radio-group__radioList_gxadg {
|
|
20
20
|
padding-left: var(--radio-group-mobile-list-padding-left);
|
|
21
|
-
} .radio-
|
|
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-
|
|
27
|
+
margin-bottom: var(--gap-12);
|
|
28
|
+
} .radio-group__label_gxadg.radio-group__tag_gxadg {
|
|
29
29
|
margin-bottom: var(--gap-8);
|
|
30
|
-
} .radio-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
19
|
+
} .radio-group__radioList_gxadg {
|
|
20
20
|
padding-left: var(--radio-group-mobile-list-padding-left);
|
|
21
|
-
} .radio-
|
|
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-
|
|
27
|
+
margin-bottom: var(--gap-12);
|
|
28
|
+
} .radio-group__label_gxadg.radio-group__tag_gxadg {
|
|
29
29
|
margin-bottom: var(--gap-8);
|
|
30
|
-
} .radio-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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
|
|
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,
|
|
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":";;;;;;MA8Ga,cAAc,GAAG,UAAU,CACpC,CACI,EACI,QAAQ,EACR,SAAS,EACT,kBAAkB,EAClB,SAAS,GAAG,UAAU,EACtB,KAAK,EACL,KAAK,EACL,IAAI,EACJ,QAAQ,EACR,MAAM,EACN,OAAO,EACP,IAAI,GAAG,OAAO,EACd,UAAU,EACV,QAAQ,GAAG,KAAK,EAChB,IAAI,EACJ,KAAK,EACL,MAAM,GACT,EACD,GAAG,KACH;IACA,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAA+B,EAAE,CAAC;IAE9E,kBAAkB,CAAC,MAAK;QACpB,aAAa,CAAC,KAAK,CAAC;AACxB,KAAC,EAAE,CAAC,KAAK,CAAC,CAAC;AAEX,IAAA,MAAM,SAAS,GAAG,CAAC,UAAkB,KACjC,KAAK,KAAK,IAAI,IAAI,CAAC,KAAK,IAAI,UAAU,MAAM,UAAU;AAE1D,IAAA,MAAM,YAAY,GAAG,CAAC,KAA+B,EAAE,UAAkB,KAAI;QACzE,aAAa,CAAC,UAAU,CAAC;AACzB,QAAA,IAAI,QAAQ,EAAE;YACV,QAAQ,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC;AAC/C;AACL,KAAC;AAED,IAAA,MAAM,WAAW,GAAG,CAAC,KAAmB,KAAI;AACxC,QAAA,MAAM,EAAE,SAAS,EAAE,cAAc,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,KAAK,CAAC,KAAK;QAEpE,OAAO,YAAY,CAAC,KAAK,EAAE;YACvB,QAAQ,EAAE,CAAC,KAAkB,KAAK,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC;YACjE,QAAQ;YACR,GAAG,KAAK,CAAC,KAAK;AACd,YAAA,OAAO,EAAE,SAAS,CAAC,UAAU,CAAC;YAC9B,IAAI;YACJ,SAAS,EAAE,EAAE,CAAC,cAAc,EAAE,YAAY,CAAC,CAAG,EAAA,SAAS,CAAO,KAAA,CAAA,CAAC,CAAC;AACnE,SAAA,CAAC;AACN,KAAC;AAED,IAAA,MAAM,SAAS,GAAG,CAAC,KAAmB,KAAI;AACtC,QAAA,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK;AACpC,QAAA,MAAM,OAAO,GAAG,SAAS,CAAC,UAAU,CAAC;AACrC,QAAA,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,EAAE;YAC9B,OAAO,EAAE,CAAC,KAAiB,KAAK,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC;YAC/D,QAAQ;YACR,GAAG,KAAK,CAAC,KAAK;YACd,OAAO;YACP,IAAI;YACJ,QAAQ,EAAE,EAAE;AACf,SAAA,CAAC;QAEF,QACI,+BACI,SAAS,EAAE,EAAE,CACT,YAAY,CAAC,CAAA,EAAG,SAAS,CAAA,KAAA,CAAO,CAAC,EACjC,YAAY,CAAC,CAAA,EAAG,SAAS,CAAA,QAAA,CAAU,CAAC,EACpC,YAAY,CAAC,QAAQ,CACxB,EAAA;YAED,KACI,CAAA,aAAA,CAAA,OAAA,EAAA,EAAA,IAAI,EAAC,OAAO,EACZ,YAAY,EAAC,KAAK,EAClB,QAAQ,EAAE,CAAC,KAAkB,KAAK,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC,EACjE,QAAQ,EAAE,QAAQ,IAAI,KAAK,CAAC,KAAK,CAAC,QAAQ,EAC1C,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,YAAY,CAAC,WAAW,EACnC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,KAAK,EAC1B,CAAA;YACD,KAAK,CACF;AAEhB,KAAC;AAED,IAAA,MAAM,YAAY,GAAG,OAAO,KAAK,KAAK,SAAS,GAAG,EAAE,GAAG,KAAK;AAE5D,IAAA,QACI,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CACT,YAAY,CAAC,SAAS,EACtB,YAAY,CAAC,IAAI,CAAC,EAClB,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,EAAE,EACzB,SAAS,CACZ,EACa,cAAA,EAAA,UAAU,EACxB,GAAG,EAAE,GAAG,EAAA;AAEP,QAAA,KAAK,IACF,KACI,CAAA,aAAA,CAAA,MAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE;AACxB,gBAAA,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,KAAK,KAAK;AAC/B,aAAA,CAAC,EACY,cAAA,EAAA,aAAa,CAAC,UAAU,EAAE,OAAO,CAAC,EAE/C,EAAA,KAAK,CACH,IACP,IAAI;QAEP,QAAQ,IACL,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CACT,YAAY,CAAC,SAAS,EACtB,YAAY,CAAC,CAAG,EAAA,SAAS,CAAW,SAAA,CAAA,CAAC,EACrC,kBAAkB,EAClB,EAAE,CAAC,MAAM,CAAC,SAAS,GAAG,IAAI,KAAK,OAAO,EAAE,CAC3C,EACD,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,OAAO,EAAA,EAEf,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,KAAK,KAAI;AAC9B,YAAA,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE;AACvB,gBAAA,OAAO,IAAI,KAAK,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC,KAAK,CAAC;AAClE;AAED,YAAA,OAAO,IAAI;AACf,SAAC,CAAC,CACA,IACN,IAAI;QAEP,YAAY,KACT,KAAA,CAAA,aAAA,CAAA,MAAA,EAAA,EACI,SAAS,EAAE,EAAE,CACT,MAAM,CAAC,GAAG,EACV;AACI,gBAAA,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,KAAK,KAAK;AAC/B,aAAA,EACD,YAAY,CAAC,YAAY,CAC5B,EACD,IAAI,EAAC,OAAO,EAAA,cAAA,EACE,aAAa,CAAC,UAAU,EAAE,OAAO,CAAC,EAE/C,EAAA,YAAY,CACV,CACV;AAEA,QAAA,IAAI,IAAI,CAAC,YAAY,KAClB,KAAA,CAAA,aAAA,CAAA,MAAA,EAAA,EACI,SAAS,EAAE,EAAE,CACT,MAAM,CAAC,GAAG,EACV;AACI,gBAAA,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,KAAK,KAAK;AAC/B,aAAA,EACD,YAAY,CAAC,IAAI,CACpB,EAAA,cAAA,EACa,aAAa,CAAC,UAAU,EAAE,MAAM,CAAC,EAE9C,EAAA,IAAI,CACF,CACV,CACC;AAEd,CAAC;;;;"}
|
|
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-
|
|
20
|
+
} .radio-group__component_j2nm5 {
|
|
21
21
|
display: flex;
|
|
22
22
|
flex-direction: column;
|
|
23
|
-
} .radio-
|
|
23
|
+
} .radio-group__radioList_j2nm5 {
|
|
24
24
|
display: flex;
|
|
25
|
-
} .radio-
|
|
25
|
+
} .radio-group__verticalRadioList_j2nm5 {
|
|
26
26
|
flex-direction: column;
|
|
27
27
|
align-items: flex-start;
|
|
28
|
-
} .radio-
|
|
28
|
+
} .radio-group__horizontalRadioList_j2nm5 {
|
|
29
29
|
flex-wrap: wrap;
|
|
30
30
|
margin-bottom: var(--gap-8-neg);
|
|
31
|
-
} .radio-
|
|
32
|
-
margin-bottom: var(--gap-12)
|
|
33
|
-
} .radio-
|
|
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-
|
|
35
|
+
} .radio-group__horizontalRadio_j2nm5 {
|
|
36
36
|
margin-right: var(--gap-24);
|
|
37
37
|
margin-bottom: var(--gap-8);
|
|
38
|
-
} .radio-
|
|
38
|
+
} .radio-group__horizontalTagLabel_j2nm5 {
|
|
39
39
|
margin-right: var(--gap-8);
|
|
40
|
-
} .radio-
|
|
41
|
-
.radio-
|
|
40
|
+
} .radio-group__horizontalRadio_j2nm5:last-child,
|
|
41
|
+
.radio-group__horizontalTagLabel_j2nm5:last-child {
|
|
42
42
|
margin-right: var(--gap-0);
|
|
43
|
-
} .radio-
|
|
43
|
+
} .radio-group__errorMessage_j2nm5 {
|
|
44
44
|
color: var(--radio-group-error-color);
|
|
45
|
-
} .radio-
|
|
45
|
+
} .radio-group__hint_j2nm5 {
|
|
46
46
|
color: var(--radio-group-hint-color);
|
|
47
|
-
} .radio-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
16
|
+
} .radio-group__radioList_1qcbs {
|
|
17
17
|
padding-left: var(--radio-group-list-padding-left);
|
|
18
|
-
} .radio-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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
|
package/modern/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-
|
|
19
|
+
} .radio-group__radioList_gxadg {
|
|
20
20
|
padding-left: var(--radio-group-mobile-list-padding-left);
|
|
21
|
-
} .radio-
|
|
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-
|
|
27
|
+
margin-bottom: var(--gap-12);
|
|
28
|
+
} .radio-group__label_gxadg.radio-group__tag_gxadg {
|
|
29
29
|
margin-bottom: var(--gap-8);
|
|
30
|
-
} .radio-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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
|
|
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,
|
|
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.
|
|
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.
|
|
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
|
|
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