UNPKG

4.06 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
5var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
7Object.defineProperty(exports, "__esModule", {
8 value: true
9});
10exports.default = exports.styles = void 0;
11
12var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
14var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
15
16var React = _interopRequireWildcard(require("react"));
17
18var _propTypes = _interopRequireDefault(require("prop-types"));
19
20var _clsx = _interopRequireDefault(require("clsx"));
21
22var _utils = require("@material-ui/core/utils");
23
24var _styles = require("@material-ui/core/styles");
25
26var _TimelineContext = _interopRequireDefault(require("../Timeline/TimelineContext"));
27
28var _TimelineItemContext = _interopRequireDefault(require("./TimelineItemContext"));
29
30var styles = function styles() {
31 return {
32 /* Styles applied to the root element. */
33 root: {
34 listStyle: 'none',
35 display: 'flex',
36 position: 'relative',
37 minHeight: 70
38 },
39
40 /* Styles applied to the root element if `align="left"`. */
41 alignLeft: {},
42
43 /* Styles applied to the root element if `align="right"`. */
44 alignRight: {
45 flexDirection: 'row-reverse'
46 },
47
48 /* Styles applied to the root element if `align="alternate"`. */
49 alignAlternate: {
50 '&:nth-child(even)': {
51 flexDirection: 'row-reverse',
52 '& $content': {
53 textAlign: 'right'
54 },
55 '& $oppositeContent': {
56 textAlign: 'left'
57 }
58 }
59 },
60
61 /* Styles applied to the root element if no there isn't TimelineOppositeContent provided. */
62 missingOppositeContent: {
63 '&:before': {
64 content: '""',
65 flex: 1,
66 padding: '6px 16px'
67 }
68 },
69
70 /* Styles applied to the timeline content node. */
71 content: {},
72
73 /* Styles applied to the timeline opposite content node. */
74 oppositeContent: {}
75 };
76};
77
78exports.styles = styles;
79var TimelineItem = /*#__PURE__*/React.forwardRef(function TimelineItem(props, ref) {
80 var classes = props.classes,
81 className = props.className,
82 other = (0, _objectWithoutProperties2.default)(props, ["classes", "className"]);
83
84 var _React$useContext = React.useContext(_TimelineContext.default),
85 _React$useContext$ali = _React$useContext.align,
86 align = _React$useContext$ali === void 0 ? 'left' : _React$useContext$ali;
87
88 var hasOppositeContent = false;
89 React.Children.forEach(props.children, function (child) {
90 if ((0, _utils.isMuiElement)(child, ['TimelineOppositeContent'])) {
91 hasOppositeContent = true;
92 }
93 });
94 return /*#__PURE__*/React.createElement(_TimelineItemContext.default.Provider, {
95 value: {
96 classes: {
97 content: classes.content,
98 oppositeContent: classes.oppositeContent
99 }
100 }
101 }, /*#__PURE__*/React.createElement("li", (0, _extends2.default)({
102 className: (0, _clsx.default)(classes.root, classes["align".concat((0, _utils.capitalize)(align))], className, !hasOppositeContent && classes.missingOppositeContent),
103 ref: ref
104 }, other)));
105});
106process.env.NODE_ENV !== "production" ? TimelineItem.propTypes = {
107 // ----------------------------- Warning --------------------------------
108 // | These PropTypes are generated from the TypeScript type definitions |
109 // | To update them edit the d.ts file and run "yarn proptypes" |
110 // ----------------------------------------------------------------------
111
112 /**
113 * The content of the component.
114 */
115 children: _propTypes.default.node,
116
117 /**
118 * Override or extend the styles applied to the component.
119 * See [CSS API](#css) below for more details.
120 */
121 classes: _propTypes.default.object,
122
123 /**
124 * @ignore
125 */
126 className: _propTypes.default.string
127} : void 0;
128
129var _default = (0, _styles.withStyles)(styles, {
130 name: 'MuiTimelineItem'
131})(TimelineItem);
132
133exports.default = _default;
\No newline at end of file