UNPKG

rsuite

Version:

A suite of react components

57 lines 2.17 kB
'use client'; import _extends from "@babel/runtime/helpers/esm/extends"; import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose"; var _excluded = ["as", "children", "classPrefix", "last", "className", "dot", "time", "INTERNAL_active"]; import React from 'react'; import PropTypes from 'prop-types'; import { useClassNames } from "../internals/hooks/index.js"; /** * The `Timeline.Item` component is used to set the layout of the child element in the `Timeline` component. * * @see https://rsuitejs.com/compo◊nents/timeline */ var TimelineItem = /*#__PURE__*/React.forwardRef(function (props, ref) { var _props$as = props.as, Component = _props$as === void 0 ? 'li' : _props$as, children = props.children, _props$classPrefix = props.classPrefix, classPrefix = _props$classPrefix === void 0 ? 'timeline-item' : _props$classPrefix, DEPRECATED_last = props.last, className = props.className, dot = props.dot, time = props.time, INTERNAL_active = props.INTERNAL_active, rest = _objectWithoutPropertiesLoose(props, _excluded); var _useClassNames = useClassNames(classPrefix), merge = _useClassNames.merge, withClassPrefix = _useClassNames.withClassPrefix, prefix = _useClassNames.prefix; var classes = merge(className, withClassPrefix({ last: DEPRECATED_last, active: INTERNAL_active })); return /*#__PURE__*/React.createElement(Component, _extends({}, rest, { ref: ref, className: classes }), /*#__PURE__*/React.createElement("span", { className: prefix('tail') }), /*#__PURE__*/React.createElement("span", { className: prefix('dot', { 'custom-dot': dot }) }, dot), time && /*#__PURE__*/React.createElement("div", { className: prefix('time') }, time), /*#__PURE__*/React.createElement("div", { className: prefix('content') }, children)); }); TimelineItem.displayName = 'TimelineItem'; TimelineItem.propTypes = { last: PropTypes.bool, dot: PropTypes.node, className: PropTypes.string, children: PropTypes.node, classPrefix: PropTypes.string, as: PropTypes.elementType }; export default TimelineItem;