UNPKG

lucid-ui

Version:

A UI component library from AppNexus.

143 lines (142 loc) 4.6 kB
import _ from 'lodash'; import React from 'react'; import PropTypes from 'react-peek/prop-types'; import { lucidClassNames } from '../../util/style-helpers'; import { findTypes, omitProps, } from '../../util/component-types'; const cx = lucidClassNames.bind('&-Grid'); const { string, bool, node } = PropTypes; // ----------------------------------------------------------------------------- // Cell child component // ----------------------------------------------------------------------------- const Cell = (_props) => null; Cell.displayName = 'Grid.Cell'; Cell.peek = { description: ` Renders an \`<article>\` as the grid cell `, }; Cell.propTypes = { isFull: bool ` fill all twelve columns of the primary grid axis `, isHalf: bool ` fill six columns of the primary grid axis `, isThird: bool ` fill four columns of the primary grid axis `, isQuarter: bool ` fill three columns of the primary grid axis `, is2: bool ` fill 2 columns of 12 `, is3: bool ` fill 3 columns of 12 `, is4: bool ` fill 4 columns of 12 `, is5: bool ` fill 5 columns of 12 `, is6: bool ` fill 6 columns of 12 `, is7: bool ` fill 7 columns of 12 `, is8: bool ` fill 8 columns of 12 `, is9: bool ` fill 9 columns of 12 `, is10: bool ` fill 10 columns of 12 `, is11: bool ` fill 11 columns of 12 `, isOffsetQuarter: bool ` offset a grid cell by three columns `, isOffsetThird: bool ` offset a grid cell by four columns `, isOffsetHalf: bool ` offset a grid cell by six columns `, }; Cell.peek = { description: ` Renders an \`<article>\` as the grid cell `, }; // ----------------------------------------------------------------------------- // Grid // ----------------------------------------------------------------------------- export const Grid = (props) => { const { className, children, isVertical, isHorizontal, isGutterless, isMultiline, ...passThroughs } = props; const cellChildProps = _.map(findTypes(props, Grid.Cell), 'props'); return (React.createElement("section", Object.assign({}, omitProps(passThroughs, undefined, _.keys(Grid.propTypes)), { className: cx('&', { '&-is-vertical': isVertical, '&-is-horizontal': isHorizontal, '&-is-gutterless': isGutterless, '&-is-multiline': isMultiline, }, className) }), _.map(cellChildProps, (cellChildProp, index) => { return (React.createElement("article", Object.assign({}, omitProps(cellChildProp, undefined, _.keys(Grid.Cell.propTypes)), { key: index, className: cx('&-Cell', { '&-Cell-is-full': cellChildProp.isFull, '&-Cell-is-half': cellChildProp.isHalf, '&-Cell-is-quarter': cellChildProp.isQuarter, '&-Cell-is-third': cellChildProp.isThird, '&-Cell-is-2': cellChildProp.is2, '&-Cell-is-3': cellChildProp.is3, '&-Cell-is-4': cellChildProp.is4, '&-Cell-is-5': cellChildProp.is5, '&-Cell-is-6': cellChildProp.is6, '&-Cell-is-7': cellChildProp.is7, '&-Cell-is-8': cellChildProp.is8, '&-Cell-is-9': cellChildProp.is9, '&-Cell-is-10': cellChildProp.is10, '&-Cell-is-11': cellChildProp.is11, '&-Cell-is-offset-quarter': cellChildProp.isOffsetQuarter, '&-Cell-is-offset-third': cellChildProp.isOffsetThird, '&-Cell-is-offset-half': cellChildProp.isOffsetHalf, }, cellChildProp.className) }), cellChildProp.children)); }), children)); }; Grid.Cell = Cell; Grid.displayName = 'Grid'; Grid.peek = { description: ` This component is designed to be used in Composites as a layout tool. You can use the Grid components themselves or create your own components using the Grid styles from Grid.less. Please see examples for more information. `, categories: ['layout'], }; Grid.propTypes = { className: string ` Appended to the component-specific class names set on the root element. `, isVertical: bool ` explicitly set the primary axis of the grid to Y `, isHorizontal: bool ` explicitly set the primary axis of the grid to X `, isGutterless: bool ` a grid without padding separating grid cells `, isMultiline: bool ` Allow Grids to wrap multiple lines `, children: node ` Any valid React component `, }; export default Grid;