@nfq/react-grid
Version:
An fork of react-awesome-styled-grid with more screen classes and some features.
88 lines (85 loc) • 14.6 kB
JavaScript
import { extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
import _styled from '@emotion/styled/base';
import React, { forwardRef } from 'react';
import { mergeMediaQueries } from '../../utils/styling.js';
import { useDebug } from '../hooks/useDebug.js';
import { calcAlignment } from '../util/calcAlignment.js';
import { calcDirection } from '../util/calcDirection.js';
import { debugCss } from '../util/debugCss.js';
import { calcOffset, calcSizes, calcPadding } from './utils.js';
const Col = forwardRef(({
align,
as,
children,
className,
direction = 'column',
isReverse,
justify,
offset,
onClick,
onContextMenu,
onDoubleClick,
onDrag,
onDragEnd,
onDragEnter,
onDragLeave,
onDragOver,
onDrop,
onMouseDown,
onMouseEnter,
onMouseLeave,
onMouseMove,
onMouseOut,
onMouseOver,
onMouseUp,
onScroll,
order,
padding,
paddingLeft,
paddingRight,
testId,
...sizes
}, ref) => {
const classNames = [className, useDebug()];
const handler = {
onClick,
onContextMenu,
onDoubleClick,
onDrag,
onDragEnd,
onDragEnter,
onDragLeave,
onDragOver,
onDrop,
onMouseDown,
onMouseEnter,
onMouseLeave,
onMouseMove,
onMouseOut,
onMouseOver,
onMouseUp,
onScroll
};
return React.createElement(ColElement, _extends({
ref: ref,
$align: align,
$direction: direction,
$isReverse: isReverse,
$justify: justify,
$offset: offset,
$order: order,
$padding: padding,
$paddingLeft: paddingLeft,
$paddingRight: paddingRight,
$sizes: sizes,
as: as,
className: classNames.join(' '),
"data-cy": testId
}, handler), children);
});
Col.displayName = 'Col';
const ColElement = _styled("div", {
target: "e1fw5zo50"
})("box-sizing:border-box;display:flex;flex:1 0 auto;flex-direction:column;max-width:100%;", mergeMediaQueries(calcPadding, calcSizes, calcOffset, calcAlignment('$order'), calcDirection('column'), calcAlignment('$align'), calcAlignment('$justify')), " ", debugCss('col'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Col.tsx"],"names":[],"mappings":"AA6M8C","file":"Col.tsx","sourcesContent":["/* eslint-disable no-undefined */\nimport type {ElementType} from 'react';\nimport React, {forwardRef} from 'react';\n\nimport styled from '@emotion/styled';\n\nimport {mergeMediaQueries} from '../../utils/styling';\nimport {useDebug} from '../hooks/useDebug';\nimport {calcAlignment} from '../util/calcAlignment';\nimport {calcDirection} from '../util/calcDirection';\nimport {debugCss} from '../util/debugCss';\n\nimport {calcOffset, calcPadding, calcSizes} from './utils';\n\nimport type {Breakpoints} from '../../sharedTypes/breakpointTypes';\nimport type {\n    AlignObject,\n    DirectionObject,\n    FlexAlign,\n    FlexDirection,\n    FlexJustify,\n    JustifyObject,\n    MouseEventHandler,\n    OffsetObject,\n    OrderObject,\n    Padding,\n    PaddingObject,\n    SizesObject,\n    StringSizes,\n    WithChildren\n} from '../../sharedTypes/componentTypes';\n\n// eslint-disable-next-line @typescript-eslint/consistent-indexed-object-style\ntype BreakpointProps = {\n    [key in Breakpoints]?: StringSizes | number;\n};\n\ninterface ComponentProps extends BreakpointProps {\n    /** Defines the content alignment of the column. It takes a `AlignObject` or a `FlexAlign` type value. Its direction is dependent on the `direction` prop. */\n    align?: AlignObject | FlexAlign;\n    /** Sets the html element type of the column. If you overwrite its styles with styled() it has to be forwardedAs. */\n    as?: ElementType;\n    /** Classname property to overwrite styles with styled(). */\n    className?: string;\n    /** Sets the direction the column children should render ('row' or 'column'). It takes a `DirectionObject` or a `FlexDirection` type value. */\n    direction?: DirectionObject | FlexDirection;\n    /** Reverses the direction of the column. It takes an array of `Breakpoints` or a `boolean` value. */\n    isReverse?: Breakpoints[] | boolean;\n    /** Defines the content justification of the column. It takes a `FlexJustify` or a `JustifyObject` type value. Its direction is dependent on the `direction` prop. */\n    justify?: FlexJustify | JustifyObject;\n    /** Sets the number of columns this column should offset to the left. It takes an `OffsetObject` or a `number` value. */\n    offset?: OffsetObject | number;\n    /** Sets the order this column should be in. It takes an `OrderObject` or a `number` value. */\n    order?: OrderObject | number;\n     /** Sets the padding added to both sides of the column. It takes a `Padding` or a `PaddingObject` type value. */\n    padding?: Padding | PaddingObject;\n    /** Sets the padding added to the left side of the column (Gets overwritten by padding). It takes a `Padding` or a `PaddingObject` type value. */\n    paddingLeft?: Padding | PaddingObject;\n    /** Sets the padding added to the right side of the column (Gets overwritten by padding). It takes a `Padding` or a `PaddingObject` type value. */\n    paddingRight?: Padding | PaddingObject;\n    /** TestId for cypress testing. */\n    testId?: string;\n}\n\n/**\n * Col component that creates a grid column.\n *\n * The Col component is used to create a grid column. It provides a wide range of properties to control column\n * behavior and layout. The Col component uses Flexbox properties to achieve column layouts. It is important to note\n * that the Col component is designed to be used within a Row component to create a grid system.\n *\n * @param props              The props for the Col component.\n * @param props.align        Defines the content alignment of the column. It takes a `AlignObject` or a `FlexAlign` type value. Its direction is dependent on the `direction` prop.\n * @param props.as           Sets the html element type of the column. If you overwrite its styles with styled() it has to be forwardedAs.\n * @param props.children     The child elements to be rendered within the column.\n * @param props.className    Classname property to overwrite styles with styled().\n * @param props.direction    Sets the direction the column children should render ('row' or 'column'). It takes a `DirectionObject` or a `FlexDirection` type value.\n * @param props.isReverse    Reverses the direction of the column. It takes an array of `Breakpoints` or a `boolean` value.\n * @param props.justify      Defines the content justification of the column. It takes a `FlexJustify` or a `JustifyObject` type value. Its direction is dependent on the `direction` prop.\n * @param props.lg           Sets the number of columns the col takes in width on screens lg. (Can also be auto, max-content, min-content).\n * @param props.md           Sets the number of columns the col takes in width on screens md. (Can also be auto, max-content, min-content).\n * @param props.offset       Sets the number of columns this column should offset to the left. It takes an `OffsetObject` or a `number` value.\n * @param props.order        Sets the order this column should be in. It takes an `OrderObject` or a `number` value.\n * @param props.padding      Sets the padding added to both sides of the column. It takes a `Padding` or a `PaddingObject` type value.\n * @param props.paddingLeft  Sets the padding added to the left side of the column (Gets overwritten by padding.). It takes a `Padding` or a `PaddingObject` type value.\n * @param props.paddingRight Sets the padding added to the right side of the column (Gets overwritten by padding.). It takes a `Padding` or a `PaddingObject` type value.\n * @param props.sm           Sets the number of columns the col takes in width on screens sm. (Can also be auto, max-content, min-content).\n * @param props.testId       TestId for cypress testing.\n * @param props.xl           Sets the number of columns the col takes in width on screens xl. (Can also be auto, max-content, min-content).\n * @param props.xs           Sets the number of columns the col takes in width on screens xs. (Can also be auto, max-content, min-content).\n * @param props.xxl          Sets the number of columns the col takes in width on screens xxl. (Can also be auto, max-content, min-content).\n *\n * @returns The Col component.\n * @example\n * ```tsx\n * import {Col, Row} from '@nfq/react-grid';\n *\n * const App = () => (\n *     <Row>\n *         <Col xs={12} sm={6} md={4} lg={3} xl={2} xxl={1}>\n *             <div>Column 1</div>\n *         </Col>\n *         <Col xs={12} sm={6} md={4} lg={3} xl={2} xxl={1}>\n *             <div>Column 2</div>\n *         </Col>\n *     </Row>\n * );\n * ```\n */\nconst Col = forwardRef<HTMLDivElement, WithChildren<ComponentProps & MouseEventHandler>>(({\n    align,\n    as,\n    children,\n    className,\n    direction = 'column',\n    isReverse,\n    justify,\n    offset,\n    onClick,\n    onContextMenu,\n    onDoubleClick,\n    onDrag,\n    onDragEnd,\n    onDragEnter,\n    onDragLeave,\n    onDragOver,\n    onDrop,\n    onMouseDown,\n    onMouseEnter,\n    onMouseLeave,\n    onMouseMove,\n    onMouseOut,\n    onMouseOver,\n    onMouseUp,\n    onScroll,\n    order,\n    padding,\n    paddingLeft,\n    paddingRight,\n    testId,\n    ...sizes\n}, ref) => {\n    const classNames = [className, useDebug()];\n    const handler = {\n        onClick,\n        onContextMenu,\n        onDoubleClick,\n        onDrag,\n        onDragEnd,\n        onDragEnter,\n        onDragLeave,\n        onDragOver,\n        onDrop,\n        onMouseDown,\n        onMouseEnter,\n        onMouseLeave,\n        onMouseMove,\n        onMouseOut,\n        onMouseOver,\n        onMouseUp,\n        onScroll\n    };\n\n    return (\n        <ColElement\n            ref={ref}\n            $align={align}\n            $direction={direction}\n            $isReverse={isReverse}\n            $justify={justify}\n            $offset={offset}\n            $order={order}\n            $padding={padding}\n            $paddingLeft={paddingLeft}\n            $paddingRight={paddingRight}\n            $sizes={sizes}\n            as={as}\n            className={classNames.join(' ')}\n            data-cy={testId}\n            // eslint-disable-next-line react/jsx-props-no-spreading\n            {...handler}\n        >\n            {children}\n        </ColElement>\n    );\n});\n\nCol.displayName = 'Col';\n\nexport {Col};\n\ninterface ColElementProps {\n    $align?: AlignObject | FlexAlign;\n    $direction?: DirectionObject | FlexDirection;\n    $isReverse?: Breakpoints[] | boolean;\n    $justify?: FlexJustify | JustifyObject;\n    $offset?: OffsetObject | number;\n    $order?: OrderObject | number;\n    $padding?: Padding | PaddingObject;\n    $paddingLeft?: Padding | PaddingObject;\n    $paddingRight?: Padding | PaddingObject;\n    $sizes: SizesObject;\n}\n\n/* eslint-disable indent */\nconst ColElement = styled.div<ColElementProps>`\n    box-sizing: border-box;\n    display: flex;\n    flex: 1 0 auto;\n    flex-direction: column;\n    max-width: 100%;\n\n    ${mergeMediaQueries<ColElementProps>(\n        calcPadding,\n        calcSizes,\n        calcOffset,\n        calcAlignment('$order'),\n        calcDirection('column'),\n        calcAlignment('$align'),\n        calcAlignment('$justify')\n    )}\n    ${debugCss('col')}\n`;\n/* eslint-enable indent */"]} */"));
export { Col };
//# sourceMappingURL=Col.js.map