UNPKG

@wonderflow/react-components

Version:

UI components from Wonderflow's Wanda design system

29 lines (28 loc) 1.49 kB
import { jsx as _jsx } from "react/jsx-runtime"; /* * Copyright 2022-2023 Wonderflow Design Team * * Licensed 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 CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import clsx from 'clsx'; import { Children, cloneElement, forwardRef, isValidElement, useMemo, } from 'react'; import * as styles from './list.module.css'; import { ListItem } from './list-item'; export const List = forwardRef(({ as: Wrapper = 'ul', children, dimension = 'regular', className, hideMarker = false, ...otherProps }, forwardedRef) => { const isUnordered = useMemo(() => Wrapper === 'ul', [Wrapper]); return (_jsx(Wrapper, { ref: forwardedRef, className: clsx(styles.List, className), "data-list-size": dimension, "data-list-ordered": !isUnordered, "data-list-no-marker": hideMarker, ...otherProps, children: Children.map(children, child => isValidElement(child) && cloneElement(child, { hideMarker: !isUnordered && !hideMarker, dimension, })) })); }); List.Li = ListItem;