From 459ab785c1db3f225ec0d6f8d40da4c5febe3fd8 Mon Sep 17 00:00:00 2001 From: Jason Quense Date: Wed, 7 Jul 2021 15:56:38 -0400 Subject: [PATCH] feat: add low level List.renderList() --- packages/react-widgets/src/List.tsx | 36 +++++++++---------- .../react-widgets/src/scss/number-picker.scss | 3 +- 2 files changed, 19 insertions(+), 20 deletions(-) diff --git a/packages/react-widgets/src/List.tsx b/packages/react-widgets/src/List.tsx index 08fda1913..382fba055 100644 --- a/packages/react-widgets/src/List.tsx +++ b/packages/react-widgets/src/List.tsx @@ -208,6 +208,7 @@ const List: List = React.forwardRef(function List( groupBy, elementRef, optionComponent: Option = ListOption, + renderList, // onKeyDown, ...props }: ListProps, @@ -263,7 +264,7 @@ const List: List = React.forwardRef(function List( ) } - const children = groupedData + const items = groupedData ? groupedData.map(([group, items], idx) => (
@@ -274,23 +275,22 @@ const List: List = React.forwardRef(function List( )) : data.map(renderOption) - return ( -
- {React.Children.count(children) ? ( - children - ) : ( -
{emptyList()}
- )} -
- ) + const rootProps = { + id, + tabIndex: 0, + ref: divRef, + ...elementProps, + 'aria-multiselectable': !!multiple, + className: cn(className, 'rw-list'), + role: elementProps.role ?? 'listbox', + children: React.Children.count(items) ? ( + items + ) : ( +
{emptyList()}
+ ), + } + + return renderList ? renderList(rootProps) :
}) List.displayName = 'List' diff --git a/packages/react-widgets/src/scss/number-picker.scss b/packages/react-widgets/src/scss/number-picker.scss index 802e4e103..d50879c3c 100644 --- a/packages/react-widgets/src/scss/number-picker.scss +++ b/packages/react-widgets/src/scss/number-picker.scss @@ -1,9 +1,8 @@ -@use 'sass:math'; @use './variables.scss' as *; @mixin NumberPicker() { .rw-number-picker { - $half-width: math.div($input-height, 2); + $half-width: $input-height * 0.5; } .rw-number-picker-spinners {