tdesign-react
Version:
TDesign Component for React
178 lines (170 loc) • 8.39 kB
JavaScript
/**
* tdesign v1.13.2
* (c) 2025 tdesign
* @license MIT
*/
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var defineProperty = require('../_chunks/dep-cc768e34.js');
var React = require('react');
var classNames = require('classnames');
var hooks_useConfig = require('../hooks/useConfig.js');
var timeline_TimelineContext = require('./TimelineContext.js');
var _util_parseTNode = require('../_util/parseTNode.js');
var timeline_useAlign = require('./useAlign.js');
var loading_index = require('../loading/index.js');
var omit = require('../_chunks/dep-ab823a9f.js');
require('../_chunks/dep-6d4d8660.js');
require('../config-provider/ConfigContext.js');
require('../_chunks/dep-3a869b87.js');
require('../_chunks/dep-ac58e1cc.js');
require('dayjs');
require('../_chunks/dep-7da96a57.js');
require('../_chunks/dep-07b911d8.js');
require('../_chunks/dep-4b02d669.js');
require('../_chunks/dep-f0379c5f.js');
require('../_chunks/dep-ddacd27a.js');
require('../_chunks/dep-028b759d.js');
require('../_chunks/dep-8a116183.js');
require('../_chunks/dep-4671b9bd.js');
require('../_chunks/dep-bed9d73e.js');
require('../_chunks/dep-780eda7b.js');
require('../_chunks/dep-47bdc05f.js');
require('../_chunks/dep-cab13149.js');
require('../_chunks/dep-a30819a4.js');
require('../_chunks/dep-6a7ba247.js');
require('../_chunks/dep-c87d9752.js');
require('../_chunks/dep-bd956a2d.js');
require('../_chunks/dep-0cdb3286.js');
require('../_chunks/dep-865c186c.js');
require('../_chunks/dep-f4e58639.js');
require('../_chunks/dep-781a2854.js');
require('../_chunks/dep-1ef213f8.js');
require('../_chunks/dep-e2c832a5.js');
require('../_chunks/dep-4bc3c0ab.js');
require('../loading/Loading.js');
require('../_chunks/dep-e17e2d31.js');
require('../_chunks/dep-b7d577ac.js');
require('../_chunks/dep-3f65dfe7.js');
require('../_chunks/dep-3e2d2665.js');
require('../common/Portal.js');
require('react-dom');
require('../hooks/useLayoutEffect.js');
require('../loading/gradient.js');
require('../_chunks/dep-58719304.js');
require('../_chunks/dep-b8d4cf07.js');
require('../_chunks/dep-64a1054a.js');
require('../_chunks/dep-422caf30.js');
require('../hooks/useDomRefCallback.js');
require('../loading/defaultProps.js');
require('../hooks/useDefaultProps.js');
require('../loading/plugin.js');
require('../_util/react-render.js');
require('../_chunks/dep-a93b6608.js');
require('../common/PluginContainer.js');
require('../config-provider/ConfigProvider.js');
require('../_chunks/dep-ed886f2a.js');
require('../_chunks/dep-aeef4e56.js');
require('../_chunks/dep-0c1ca63f.js');
require('../_chunks/dep-fd5d57c1.js');
require('../_chunks/dep-ac2874ce.js');
require('../_chunks/dep-6cfc06a0.js');
require('../_chunks/dep-5d9d080b.js');
require('../_chunks/dep-62193a48.js');
require('../_chunks/dep-f076775e.js');
require('../_chunks/dep-1843e637.js');
require('../_chunks/dep-4ba2ac6b.js');
require('../_chunks/dep-e6a14ce7.js');
require('../_chunks/dep-05b4c661.js');
require('../_chunks/dep-ef231277.js');
require('../_chunks/dep-ba1bf618.js');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
var classNames__default = /*#__PURE__*/_interopDefaultLegacy(classNames);
var DefaultTheme = ["default", "primary", "success", "warning", "error"];
var TimelineItem = function TimelineItem(props) {
var className = props.className,
_props$style = props.style,
style = _props$style === void 0 ? {} : _props$style,
dot = props.dot,
_props$dotColor = props.dotColor,
dotColor = _props$dotColor === void 0 ? "primary" : _props$dotColor,
labelAlign = props.labelAlign,
children = props.children,
index = props.index,
content = props.content,
label = props.label,
_props$loading = props.loading,
loading = _props$loading === void 0 ? false : _props$loading,
onClick = props.onClick;
var _useContext = React.useContext(timeline_TimelineContext["default"]),
theme = _useContext.theme,
reverse = _useContext.reverse,
itemsStatus = _useContext.itemsStatus,
layout = _useContext.layout,
globalAlign = _useContext.globalAlign,
mode = _useContext.mode;
var _useConfig = hooks_useConfig["default"](),
classPrefix = _useConfig.classPrefix;
var renderAlign = timeline_useAlign.useAlign(globalAlign, layout);
var getPositionClassName = function getPositionClassName(index2) {
var left = layout === "horizontal" ? "top" : "left";
var right = layout === "horizontal" ? "bottom" : "right";
if (renderAlign === "alternate") {
return labelAlign || index2 % 2 === 0 ? "".concat(classPrefix, "-timeline-item-").concat(left) : "".concat(classPrefix, "-timeline-item-").concat(right);
}
if (renderAlign === "left" || renderAlign === "top") {
return "".concat(classPrefix, "-timeline-item-").concat(left);
}
if (renderAlign === "right" || renderAlign === "bottom") {
return "".concat(classPrefix, "-timeline-item-").concat(right);
}
return "";
};
var dotElement = React.useMemo(function () {
var ele = _util_parseTNode["default"](dot);
if (/*#__PURE__*/React__default["default"].isValidElement(ele)) {
var _ele$props;
return /*#__PURE__*/React__default["default"].cloneElement(ele, {
className: classNames__default["default"](ele === null || ele === void 0 || (_ele$props = ele.props) === null || _ele$props === void 0 ? void 0 : _ele$props.className, "".concat(classPrefix, "-timeline-item__dot-content"))
});
}
return ele;
}, [dot, classPrefix]);
var handleClick = function handleClick(e) {
onClick === null || onClick === void 0 || onClick({
e: e,
item: omit.omit(props, ["children", "index", "onClick"])
});
};
var itemClassName = classNames__default["default"](defineProperty._defineProperty(defineProperty._defineProperty({}, "".concat(classPrefix, "-timeline-item"), true), "".concat(getPositionClassName(index)), true), className);
var tailClassName = classNames__default["default"](defineProperty._defineProperty(defineProperty._defineProperty(defineProperty._defineProperty({}, "".concat(classPrefix, "-timeline-item__tail"), true), "".concat(classPrefix, "-timeline-item__tail--theme-").concat(theme), true), "".concat(classPrefix, "-timeline-item__tail--status-").concat(itemsStatus[index]), reverse));
var dotClassName = classNames__default["default"](defineProperty._defineProperty(defineProperty._defineProperty(defineProperty._defineProperty({}, "".concat(classPrefix, "-timeline-item__dot"), true), "".concat(classPrefix, "-timeline-item__dot--custom"), !!dotElement || !dotElement && loading), "".concat(classPrefix, "-timeline-item__dot--").concat(dotColor), DefaultTheme.includes(dotColor)));
var labelClassName = classNames__default["default"]("".concat(classPrefix, "-timeline-item__label"), defineProperty._defineProperty({}, "".concat(classPrefix, "-timeline-item__label--").concat(mode), true));
return /* @__PURE__ */React__default["default"].createElement("li", {
className: itemClassName,
style: style,
onClick: handleClick
}, mode === "alternate" && label && /* @__PURE__ */React__default["default"].createElement("div", {
className: labelClassName
}, label), /* @__PURE__ */React__default["default"].createElement("div", {
className: "".concat(classPrefix, "-timeline-item__wrapper")
}, /* @__PURE__ */React__default["default"].createElement("div", {
className: dotClassName,
style: {
borderColor: !DefaultTheme.includes(dotColor) && dotColor
}
}, !dotElement && loading && /* @__PURE__ */React__default["default"].createElement(loading_index.Loading, {
size: "12px",
className: "".concat(classPrefix, "-timeline-item__dot-content")
}), dotElement), /* @__PURE__ */React__default["default"].createElement("div", {
className: tailClassName
})), /* @__PURE__ */React__default["default"].createElement("div", {
className: "".concat(classPrefix, "-timeline-item__content")
}, content || children, mode === "same" && label && /* @__PURE__ */React__default["default"].createElement("div", {
className: labelClassName
}, label)));
};
TimelineItem.displayName = "TimelineItem";
exports["default"] = TimelineItem;
//# sourceMappingURL=TimelineItem.js.map