1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/open-hand-choerodon-ui

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
Клонировать/Скачать
RadioContext.tsx 1.2 КБ
Копировать Редактировать Исходные данные Просмотреть построчно История
HughHzWu Отправлено 3 лет назад bad5b40
import React, { FunctionComponent, memo, ReactNode, useMemo } from 'react';
import { getContext, Symbols } from 'choerodon-ui/shared';
import { getPrefixCls } from '../configure/utils';
import { RadioChangeEvent } from './interface';
export interface RadioGroupContext {
radioGroup?: {
onChange: (e: RadioChangeEvent) => void;
value: any;
disabled?: boolean;
name?: string;
};
getPrefixCls(suffixCls: string, customizePrefixCls?: string): string;
}
export interface RadioContextProviderProps extends RadioGroupContext {
children?: ReactNode;
}
const RadioContext = getContext<RadioGroupContext>(Symbols.RadioContext, { getPrefixCls });
const BaseRadioContextProvider: FunctionComponent<RadioContextProviderProps> = function RadioContextProvider(props) {
const { children, radioGroup, getPrefixCls: getGlobalPrefixCls } = props;
const value = useMemo(() => ({
radioGroup,
getPrefixCls: getGlobalPrefixCls,
}), [getGlobalPrefixCls, radioGroup]);
return (
<RadioContext.Provider value={value}>
{children}
</RadioContext.Provider>
);
};
BaseRadioContextProvider.displayName = 'RadioContextProvider';
export const RadioContextProvider = memo(BaseRadioContextProvider);
export default RadioContext;

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://gitlife.ru/oschina-mirror/open-hand-choerodon-ui.git
git@gitlife.ru:oschina-mirror/open-hand-choerodon-ui.git
oschina-mirror
open-hand-choerodon-ui
open-hand-choerodon-ui
1.6.4