@elastic/eui
Version:
Elastic UI Component Library
57 lines (54 loc) • 3.15 kB
JavaScript
import _extends from "@babel/runtime/helpers/extends";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
var _excluded = ["className", "component", "gutterSize", "alignItems", "responsive", "justifyContent", "direction", "wrap"];
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
import React, { forwardRef } from 'react';
import classNames from 'classnames';
import { useEuiMemoizedStyles } from '../../services';
import { euiFlexGroupStyles } from './flex_group.styles';
import { jsx as ___EmotionJSX } from "@emotion/react";
export var GUTTER_SIZES = ['none', 'xs', 's', 'm', 'l', 'xl'];
export var ALIGN_ITEMS = ['stretch', 'flexStart', 'flexEnd', 'center', 'baseline'];
export var JUSTIFY_CONTENTS = ['flexStart', 'flexEnd', 'center', 'spaceBetween', 'spaceAround', 'spaceEvenly'];
export var DIRECTIONS = ['row', 'rowReverse', 'column', 'columnReverse'];
var EuiFlexGroupInternal = function EuiFlexGroupInternal(_ref, ref) {
var className = _ref.className,
_ref$component = _ref.component,
component = _ref$component === void 0 ? 'div' : _ref$component,
_ref$gutterSize = _ref.gutterSize,
gutterSize = _ref$gutterSize === void 0 ? 'm' : _ref$gutterSize,
_ref$alignItems = _ref.alignItems,
alignItems = _ref$alignItems === void 0 ? 'stretch' : _ref$alignItems,
_ref$responsive = _ref.responsive,
responsive = _ref$responsive === void 0 ? true : _ref$responsive,
_ref$justifyContent = _ref.justifyContent,
justifyContent = _ref$justifyContent === void 0 ? 'flexStart' : _ref$justifyContent,
_ref$direction = _ref.direction,
direction = _ref$direction === void 0 ? 'row' : _ref$direction,
_ref$wrap = _ref.wrap,
wrap = _ref$wrap === void 0 ? false : _ref$wrap,
rest = _objectWithoutProperties(_ref, _excluded);
var styles = useEuiMemoizedStyles(euiFlexGroupStyles);
var cssStyles = [styles.euiFlexGroup, responsive && !direction.includes('column') && styles.responsive, wrap && styles.wrap, styles.gutterSizes[gutterSize], styles.justifyContent[justifyContent], styles.alignItems[alignItems], styles.direction[direction]];
var classes = classNames('euiFlexGroup', className);
// Cast `component` to FunctionComponent to simplify its type.
// Note that FunctionComponent type is used here for purely typing
// convenience since we specify the return type above, and function
// components don't support `ref`s, but that doesn't matter in this case.
var Component = component;
return ___EmotionJSX(Component, _extends({}, rest, {
ref: ref,
className: classes,
css: cssStyles
}));
};
// Cast forwardRef return type to work with the generic TComponent type
// and not fallback to implicit any typing
export var EuiFlexGroup = /*#__PURE__*/forwardRef(EuiFlexGroupInternal);
EuiFlexGroup.displayName = 'EuiFlexGroup';