import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props' import { globalProps } from '../utilities/globalProps' type LayoutPropTypes = { aria?: {[key: string]: string}, children?: React.ReactChild[] | React.ReactChild, className?: string, collapse?: "xs" | "sm" | "md" | "lg" | "xl", dark?: boolean, data?: object, full?: boolean, htmlOptions?: {[key: string]: string | number | boolean | Function}, position?: "left" | "right", responsive?: boolean, size?: "xs" | "sm" | "md" | "base" | "lg" | "xl", variant?: "light" | "dark" | "gradient", transparent?: boolean, layout?: "sidebar" | "collection" | "kanban" | "content" | "masonry", } type LayoutSideProps = { children: React.ReactNode[] | React.ReactNode, className?: string, } type LayoutBodyProps = { children: React.ReactNode[] | React.ReactNode, className?: string, } type LayoutItemProps = { children: React.ReactNode[] | React.ReactNode, className?: string, size?: "sm" | "md" | "lg" } type LayoutHeaderProps = { children: React.ReactNode[] | React.ReactNode, className?: string, } type LayoutFooterProps = { children: React.ReactNode[] | React.ReactNode, className?: string, } // Side component const Side = (props: LayoutSideProps) => { const { children, className } = props return (
{children}
) } // Body component const Body = (props: LayoutBodyProps) => { const { children, className } = props return (
{children}
) } // Item component const Item = (props: LayoutItemProps) => { const { children, className, size = 'sm' } = props const sizeClass = `size_${size}` return (
{children}
) } // Header component const Header = (props: LayoutHeaderProps) => { const { children, className } = props return (
{children}
) } // Footer component const Footer = (props: LayoutFooterProps) => { const { children, className } = props return (
{children}
) } const Layout = (props: LayoutPropTypes) => { const { aria = {}, children, className, collapse = 'md', dark = false, data = {}, full = false, htmlOptions = {}, position = 'left', responsive = false, size = 'md', layout = 'sidebar', variant = 'light', transparent = false, } = props const responsiveClass = responsive ? '_responsive' : '' const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) const layoutCss = layout == 'collection' ? `pb_layout_kit_${layout}` : layout == 'kanban' ? `pb_layout_kit_${layout}${responsiveClass}` : buildCss(`pb_layout_kit_${layout}`, `size_${size}`, position, variant, { dark: dark, transparent: transparent, full: full, }) const layoutCollapseCss = layout == 'collection' ? '' : layout == 'kanban' ? '' : buildCss('layout', position, 'collapse', collapse) const layoutChildren = React.Children.toArray(children) const subComponentTags = (tagName: string) => { return layoutChildren .filter((c: React.ReactElement & {type: {displayName: string}}) => { return c.type?.displayName === tagName }) .map((child, i) => { return React.cloneElement(child as React.ReactElement, { key: `${tagName.toLowerCase()}-${i}`, }) }) } const nonSideChildren = layoutChildren.filter( (child: React.ReactElement & {type: {displayName: string}}) => child.type?.displayName !== 'Side' ) const filteredProps = {...props} delete filteredProps?.position return (
{subComponentTags('Side')} {nonSideChildren}
) } Layout.Side = Side Layout.Body = Body Layout.Item = Item Layout.Header = Header Layout.Footer = Footer export default Layout