import React from "react"; import classnames from "classnames"; import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from "../utilities/props"; import { globalProps } from "../utilities/globalProps"; import Draggable from "../pb_draggable/_draggable"; type ListProps = { aria?: { [key: string]: string }; borderless?: boolean; className?: string; children: React.ReactNode[] | React.ReactNode; dark?: boolean; draggable?: boolean; data?: Record; htmlOptions?: {[key: string]: string | number | boolean | (() => void)}, id?: string; layout?: "" | "left" | "right"; ordered?: boolean; role?: string; tabIndex?: number; text?: string; size?: string; variant?: string; xpadding?: boolean; }; const List = (props: ListProps) => { const { aria = {}, borderless = false, children, className, dark = false, data = {}, draggable = false, htmlOptions = {}, id, layout = "", ordered = false, role, size = "", tabIndex, xpadding = false, variant, text, } = props; const layoutClass: { [key: string]: string } = { left: "layout_left", right: "layout_right", default: "", }; const childrenWithProps = React.Children.map( children, (child: React.ReactElement) => { return React.cloneElement(child, { text, variant, draggable }); } ); const ariaProps = buildAriaProps(aria); const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions); const classes = classnames( buildCss("pb_list_kit", layoutClass[layout], size, { dark: dark, borderless: borderless, ordered: ordered, xpadding: xpadding, }), globalProps(props), className ); return ( <> { draggable ? (
{ordered ? (
    {childrenWithProps}
) : (
    {childrenWithProps}
)}
) : (
{ordered ? (
    {childrenWithProps}
) : ( )}
) } ); }; export default List;