import * as React from 'react'; import styles from '@patternfly/react-styles/css/components/List/list'; import { css } from '@patternfly/react-styles'; export enum OrderType { number = '1', lowercaseLetter = 'a', uppercaseLetter = 'A', lowercaseRomanNumber = 'i', uppercaseRomanNumber = 'I' } export enum ListVariant { inline = 'inline' } export enum ListComponent { ol = 'ol', ul = 'ul' } export interface ListProps extends Omit, 'type'> { /** Anything that can be rendered inside of the list */ children?: React.ReactNode; /** Additional classes added to the list */ className?: string; /** Adds list variant styles */ variant?: ListVariant.inline; /** Modifies the list to add borders between items */ isBordered?: boolean; /** Modifies the list to include plain styling */ isPlain?: boolean; /** Modifies the size of the icons in the list */ iconSize?: 'default' | 'large'; /** Sets the way items are numbered if component is set to "ol". */ type?: OrderType; /** Sets the type of the list component. */ component?: 'ol' | 'ul'; /** Adds an accessible label to the list. */ 'aria-label'?: string; } export const List: React.FunctionComponent = ({ className = '', children = null, variant = null, isBordered = false, isPlain = false, iconSize = 'default', type = OrderType.number, ref = null, component = ListComponent.ul, ...props }: ListProps) => component === ListComponent.ol ? (
    } type={type} {...(isPlain && { role: 'list' })} {...props} className={css( styles.list, variant && styles.modifiers[variant], isBordered && styles.modifiers.bordered, isPlain && styles.modifiers.plain, iconSize && iconSize === 'large' && styles.modifiers.iconLg, className )} > {children}
) : ( ); List.displayName = 'List';