UNPKG

@kiwicom/orbit-components

Version:

Orbit-components is a React component library which provides developers with the easiest possible way of building Kiwi.com’s products.

89 lines (72 loc) 3.12 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; exports.__esModule = true; exports.default = void 0; var React = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireWildcard(require("styled-components")); var _context = require("./context"); var _AirplaneDown = _interopRequireDefault(require("../../icons/AirplaneDown")); var _AlertCircle = _interopRequireDefault(require("../../icons/AlertCircle")); var _Circle = _interopRequireDefault(require("../../icons/Circle")); var _defaultTheme = _interopRequireDefault(require("../../defaultTheme")); const lineMixin = (0, _styledComponents.css)(["content:\"\";position:absolute;height:calc(50% + 9px);z-index:-1;"]); // TODO: Improve const IconStyled = _styledComponents.default.div.withConfig({ displayName: "ItineraryIcon__IconStyled", componentId: "sc-wz4151-0" })(["", ""], ({ theme, index, last, count, isPrevHidden, isHidden }) => (0, _styledComponents.css)(["display:flex;justify-content:center;z-index:1;svg{background:", ";overflow:hidden;}", " ", ";", ";"], last || index === 0 ? "transparent" : theme.orbit.paletteWhite, index > 0 && !last && (0, _styledComponents.css)(["padding:", " 0;background:radial-gradient( farthest-side,", ",", ",", ",transparent );"], theme.orbit.spaceXXSmall, theme.orbit.paletteWhite, theme.orbit.paletteWhite, theme.orbit.paletteWhite), index > 0 && count > 0 && (0, _styledComponents.css)(["&:before{top:", ";border:1px ", " ", ";", ";}"], last && isPrevHidden ? "-14px" : "-9px", isPrevHidden ? "dashed" : "solid", theme.orbit.paletteCloudNormalActive, lineMixin), !last && count > 0 && (0, _styledComponents.css)(["&:after{bottom:", ";border:1px ", " ", ";", ";}"], isHidden ? "4px" : "-9px", isHidden ? "dashed" : "solid", theme.orbit.paletteCloudNormalActive, lineMixin))); // $FlowFixMe: https://github.com/flow-typed/flow-typed/issues/3653#issuecomment-568539198 IconStyled.defaultProps = { theme: _defaultTheme.default }; const Icon = ({ type, isDetails, icon }) => { if (icon) return icon; if (type) return /*#__PURE__*/React.createElement(_AlertCircle.default, { size: "small", color: type === "neutral" ? "primary" : type }); if (isDetails) return /*#__PURE__*/React.createElement(_AirplaneDown.default, { size: "small" }); return /*#__PURE__*/React.createElement(_Circle.default, { size: "small", color: "secondary" }); }; const ItineraryIcon = ({ isDetails, type, children }) => { const { index, last, isPrevHidden, isHidden, count } = (0, _context.usePart)(); return /*#__PURE__*/React.createElement(IconStyled, { index: index, last: last, isDetails: isDetails, isPrevHidden: isPrevHidden, isHidden: isHidden, count: count }, /*#__PURE__*/React.createElement(Icon, { type: type, isDetails: isDetails, icon: children })); }; var _default = ItineraryIcon; exports.default = _default;