From 1d8e40bd2750d164f10ccd10e171da3bbad4cf7d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Burzy=C5=84ski?= Date: Wed, 29 Jul 2020 16:25:51 +0200 Subject: [PATCH 1/6] Introduce useCheckboxGroup, useCheckboxGroupState & useGroupedCheckbox hooks --- packages/@react-aria/checkbox/package.json | 2 + packages/@react-aria/checkbox/src/index.ts | 2 + .../checkbox/src/useCheckboxGroup.ts | 62 ++++++ .../checkbox/src/useGroupedCheckbox.ts | 40 ++++ .../checkbox/test/useCheckboxGroup.test.tsx | 71 ++++++ packages/@react-stately/toggle/src/index.ts | 1 + .../toggle/src/useCheckboxGroupState.ts | 86 ++++++++ .../test/useCheckboxGroupState.test.tsx | 208 ++++++++++++++++++ packages/@react-types/checkbox/src/index.d.ts | 22 +- 9 files changed, 493 insertions(+), 1 deletion(-) create mode 100644 packages/@react-aria/checkbox/src/useCheckboxGroup.ts create mode 100644 packages/@react-aria/checkbox/src/useGroupedCheckbox.ts create mode 100644 packages/@react-aria/checkbox/test/useCheckboxGroup.test.tsx create mode 100644 packages/@react-stately/toggle/src/useCheckboxGroupState.ts create mode 100644 packages/@react-stately/toggle/test/useCheckboxGroupState.test.tsx diff --git a/packages/@react-aria/checkbox/package.json b/packages/@react-aria/checkbox/package.json index 7f31bff075a..e23f6b576a3 100644 --- a/packages/@react-aria/checkbox/package.json +++ b/packages/@react-aria/checkbox/package.json @@ -18,7 +18,9 @@ }, "dependencies": { "@babel/runtime": "^7.6.2", + "@react-aria/label": "^3.1.0", "@react-aria/toggle": "^3.1.0", + "@react-aria/utils": "^3.1.0", "@react-stately/toggle": "^3.1.0", "@react-types/checkbox": "^3.1.0" }, diff --git a/packages/@react-aria/checkbox/src/index.ts b/packages/@react-aria/checkbox/src/index.ts index 38cda41ccc4..e8d445dafad 100644 --- a/packages/@react-aria/checkbox/src/index.ts +++ b/packages/@react-aria/checkbox/src/index.ts @@ -11,3 +11,5 @@ */ export * from './useCheckbox'; +export * from './useCheckboxGroup'; +export * from './useGroupedCheckbox'; diff --git a/packages/@react-aria/checkbox/src/useCheckboxGroup.ts b/packages/@react-aria/checkbox/src/useCheckboxGroup.ts new file mode 100644 index 00000000000..a38ef919a10 --- /dev/null +++ b/packages/@react-aria/checkbox/src/useCheckboxGroup.ts @@ -0,0 +1,62 @@ +/* + * Copyright 2020 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + */ + +import {AriaCheckboxGroupProps} from '@react-types/checkbox'; +import {filterDOMProps, mergeProps} from '@react-aria/utils'; +import {HTMLAttributes} from 'react'; +import {useLabel} from '@react-aria/label'; + +interface CheckboxGroupAria { + /** Props for the checkbox group wrapper element. */ + checkboxGroupProps: HTMLAttributes, + /** Props for the checkbox group's visible label (if any). */ + labelProps: HTMLAttributes +} + +/** + * Provides the behavior and accessibility implementation for a checkbox group component. + * Checkbox groups allow users to select multiple items from a list of options. + * @param props - Props for the checkbox group. + * @param state - State for the checkbox group, as returned by `useCheckboxGroupState`. + */ +export function useCheckboxGroup(props: AriaCheckboxGroupProps): CheckboxGroupAria { + let { + validationState, + isReadOnly, + isRequired, + isDisabled, + orientation = 'vertical' + } = props; + + let {labelProps, fieldProps} = useLabel({ + ...props, + // Checkbox group is not an HTML input element so it + // shouldn't be labeled by a