UNPKG

9.98 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
8
9var _react = require('react');
10
11var _react2 = _interopRequireDefault(_react);
12
13var _propTypes = require('prop-types');
14
15var _propTypes2 = _interopRequireDefault(_propTypes);
16
17var _classnames = require('classnames');
18
19var _classnames2 = _interopRequireDefault(_classnames);
20
21function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
22
23function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }
24
25function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
26
27function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
28
29function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
30
31function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
32
33function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : _defaults(subClass, superClass); } /**
34 * This source code is quoted from rc-steps.
35 * homepage: https://github.com/react-component/steps
36 */
37
38
39function isString(str) {
40 return typeof str === 'string';
41}
42
43var Step = function (_React$Component) {
44 _inherits(Step, _React$Component);
45
46 function Step() {
47 _classCallCheck(this, Step);
48
49 return _possibleConstructorReturn(this, _React$Component.apply(this, arguments));
50 }
51
52 Step.prototype.renderIconNode = function renderIconNode() {
53 var _classNames;
54
55 var _props = this.props,
56 prefixCls = _props.prefixCls,
57 progressDot = _props.progressDot,
58 stepNumber = _props.stepNumber,
59 status = _props.status,
60 title = _props.title,
61 description = _props.description,
62 icon = _props.icon,
63 iconPrefix = _props.iconPrefix,
64 icons = _props.icons;
65
66 var iconNode = void 0;
67 var iconClassName = (0, _classnames2["default"])(prefixCls + '-icon', iconPrefix + 'icon', (_classNames = {}, _defineProperty(_classNames, iconPrefix + 'icon-' + icon, icon && isString(icon)), _defineProperty(_classNames, iconPrefix + 'icon-check', !icon && status === 'finish' && icons && !icons.finish), _defineProperty(_classNames, iconPrefix + 'icon-close', !icon && status === 'error' && icons && !icons.error), _classNames));
68 var iconDot = _react2["default"].createElement('span', { className: prefixCls + '-icon-dot' });
69 // `progressDot` enjoy the highest priority
70 if (progressDot) {
71 if (typeof progressDot === 'function') {
72 iconNode = _react2["default"].createElement(
73 'span',
74 { className: prefixCls + '-icon' },
75 progressDot(iconDot, { index: stepNumber - 1, status: status, title: title, description: description })
76 );
77 } else {
78 iconNode = _react2["default"].createElement(
79 'span',
80 { className: prefixCls + '-icon' },
81 iconDot
82 );
83 }
84 } else if (icon && !isString(icon)) {
85 iconNode = _react2["default"].createElement(
86 'span',
87 { className: prefixCls + '-icon' },
88 icon
89 );
90 } else if (icons && icons.finish && status === 'finish') {
91 iconNode = _react2["default"].createElement(
92 'span',
93 { className: prefixCls + '-icon' },
94 icons.finish
95 );
96 } else if (icons && icons.error && status === 'error') {
97 iconNode = _react2["default"].createElement(
98 'span',
99 { className: prefixCls + '-icon' },
100 icons.error
101 );
102 } else if (icon || status === 'finish' || status === 'error') {
103 iconNode = _react2["default"].createElement('span', { className: iconClassName });
104 } else {
105 iconNode = _react2["default"].createElement(
106 'span',
107 { className: prefixCls + '-icon' },
108 stepNumber
109 );
110 }
111
112 return iconNode;
113 };
114
115 Step.prototype.render = function render() {
116 var _props2 = this.props,
117 className = _props2.className,
118 prefixCls = _props2.prefixCls,
119 style = _props2.style,
120 itemWidth = _props2.itemWidth,
121 _props2$status = _props2.status,
122 status = _props2$status === undefined ? 'wait' : _props2$status,
123 iconPrefix = _props2.iconPrefix,
124 icon = _props2.icon,
125 wrapperStyle = _props2.wrapperStyle,
126 adjustMarginRight = _props2.adjustMarginRight,
127 stepNumber = _props2.stepNumber,
128 description = _props2.description,
129 title = _props2.title,
130 progressDot = _props2.progressDot,
131 tailContent = _props2.tailContent,
132 icons = _props2.icons,
133 restProps = _objectWithoutProperties(_props2, ['className', 'prefixCls', 'style', 'itemWidth', 'status', 'iconPrefix', 'icon', 'wrapperStyle', 'adjustMarginRight', 'stepNumber', 'description', 'title', 'progressDot', 'tailContent', 'icons']);
134
135 var classString = (0, _classnames2["default"])(prefixCls + '-item', prefixCls + '-item-' + status, className, _defineProperty({}, prefixCls + '-item-custom', icon));
136 var stepItemStyle = _extends({}, style);
137 if (itemWidth) {
138 stepItemStyle.width = itemWidth;
139 }
140 if (adjustMarginRight) {
141 stepItemStyle.marginRight = adjustMarginRight;
142 }
143 return _react2["default"].createElement(
144 'div',
145 _extends({}, restProps, {
146 className: classString,
147 style: stepItemStyle
148 }),
149 _react2["default"].createElement(
150 'div',
151 { className: prefixCls + '-item-tail' },
152 tailContent
153 ),
154 _react2["default"].createElement(
155 'div',
156 { className: prefixCls + '-item-icon' },
157 this.renderIconNode()
158 ),
159 _react2["default"].createElement(
160 'div',
161 { className: prefixCls + '-item-content' },
162 _react2["default"].createElement(
163 'div',
164 { className: prefixCls + '-item-title' },
165 title
166 ),
167 description && _react2["default"].createElement(
168 'div',
169 { className: prefixCls + '-item-description' },
170 description
171 )
172 )
173 );
174 };
175
176 return Step;
177}(_react2["default"].Component);
178
179Step.propTypes = {
180 className: _propTypes2["default"].string,
181 prefixCls: _propTypes2["default"].string,
182 style: _propTypes2["default"].object,
183 wrapperStyle: _propTypes2["default"].object,
184 itemWidth: _propTypes2["default"].oneOfType([_propTypes2["default"].number, _propTypes2["default"].string]),
185 status: _propTypes2["default"].string,
186 iconPrefix: _propTypes2["default"].string,
187 icon: _propTypes2["default"].node,
188 adjustMarginRight: _propTypes2["default"].oneOfType([_propTypes2["default"].number, _propTypes2["default"].string]),
189 stepNumber: _propTypes2["default"].string,
190 description: _propTypes2["default"].any,
191 title: _propTypes2["default"].any,
192 progressDot: _propTypes2["default"].oneOfType([_propTypes2["default"].bool, _propTypes2["default"].func]),
193 tailContent: _propTypes2["default"].any,
194 icons: _propTypes2["default"].shape({
195 finish: _propTypes2["default"].node,
196 error: _propTypes2["default"].node
197 })
198};
199
200exports["default"] = Step;
201module.exports = exports['default'];
\No newline at end of file