UNPKG

choerodon-ui

Version:

An enterprise-class UI design language and React-based implementation

381 lines (300 loc) 14.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault")["default"]; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard")["default"]; Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _react = _interopRequireWildcard(require("react")); var _omit = _interopRequireDefault(require("lodash/omit")); var _classnames = _interopRequireDefault(require("classnames")); var _copyToClipboard = _interopRequireDefault(require("copy-to-clipboard")); var _ref2 = require("rc-util/lib/ref"); var _icon = _interopRequireDefault(require("../../../../lib/icon")); var _resizeObserver = _interopRequireDefault(require("../../../../lib/_util/resizeObserver")); var _ConfigContext = _interopRequireDefault(require("../../../../lib/config-provider/ConfigContext")); var _tooltip = _interopRequireDefault(require("../../tooltip")); var _TransButton = _interopRequireDefault(require("../../_util/TransButton")); var _EllipsisTooltip = _interopRequireDefault(require("./EllipsisTooltip")); var _Ellipsis = _interopRequireDefault(require("./Ellipsis")); var _useMergedConfig5 = _interopRequireDefault(require("../hooks/useMergedConfig")); var _Typography = _interopRequireDefault(require("../Typography")); var _localeContext = require("../../locale-context"); var _styleChecker = require("../../_util/styleChecker"); var _excluded = ["prefixCls", "className", "style", "type", "disabled", "children", "ellipsis", "copyable", "component", "title", "suffixCls"]; function wrapperDecorations(_ref, content) { var mark = _ref.mark, code = _ref.code, underline = _ref.underline, del = _ref["delete"], strong = _ref.strong, keyboard = _ref.keyboard, italic = _ref.italic; var currentContent = content; function wrap(needed, tag) { if (!needed) return; currentContent = /*#__PURE__*/_react["default"].createElement(tag, {}, currentContent); } wrap(strong, 'strong'); wrap(underline, 'u'); wrap(del, 'del'); wrap(code, 'code'); wrap(mark, 'mark'); wrap(keyboard, 'kbd'); wrap(italic, 'i'); return currentContent; } function getNode(dom, defaultNode, needDom) { if (dom === true || dom === undefined) { return defaultNode; } return dom || needDom && defaultNode; } function toList(val) { return Array.isArray(val) ? val : [val]; } var ELLIPSIS_STR = '...'; var Base = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) { var _classNames; var customizePrefixCls = props.prefixCls, className = props.className, style = props.style, type = props.type, disabled = props.disabled, children = props.children, ellipsis = props.ellipsis, copyable = props.copyable, component = props.component, title = props.title, suffixCls = props.suffixCls, restProps = (0, _objectWithoutProperties2["default"])(props, _excluded); var _useContext = (0, _react.useContext)(_ConfigContext["default"]), getProPrefixCls = _useContext.getProPrefixCls; var typographyRef = (0, _react.useRef)(null); // ============================ MISC ============================ var prefixCls = getProPrefixCls('typography', customizePrefixCls); var textProps = (0, _omit["default"])(restProps, ['mark', 'code', 'delete', 'underline', 'strong', 'keyboard', 'italic', 'dataSet', 'rowIndex', 'colIndex', 'suffixCls']); // ========================== Copyable ========================== var _useMergedConfig = (0, _useMergedConfig5["default"])(copyable), _useMergedConfig2 = (0, _slicedToArray2["default"])(_useMergedConfig, 2), enableCopy = _useMergedConfig2[0], copyConfig = _useMergedConfig2[1]; var _useState = (0, _react.useState)(false), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), copied = _useState2[0], setCopied = _useState2[1]; var copyIdRef = (0, _react.useRef)(); var cleanCopyId = function cleanCopyId() { clearTimeout(copyIdRef.current); }; var onCopyClick = function onCopyClick(e) { if (e) { e.preventDefault(); e.stopPropagation(); } (0, _copyToClipboard["default"])(copyConfig.text || String(children) || ''); setCopied(true); // Trigger tips update cleanCopyId(); copyIdRef.current = setTimeout(function () { setCopied(false); }, 3000); if (copyConfig.onCopy) { copyConfig.onCopy(); } }; (0, _react.useEffect)(function () { return cleanCopyId; }, []); // ========================== Ellipsis ========================== var _useState3 = (0, _react.useState)(false), _useState4 = (0, _slicedToArray2["default"])(_useState3, 2), isLineClampSupport = _useState4[0], setIsLineClampSupport = _useState4[1]; var _useState5 = (0, _react.useState)(false), _useState6 = (0, _slicedToArray2["default"])(_useState5, 2), isTextOverflowSupport = _useState6[0], setIsTextOverflowSupport = _useState6[1]; var _useState7 = (0, _react.useState)(false), _useState8 = (0, _slicedToArray2["default"])(_useState7, 2), expanded = _useState8[0], setExpanded = _useState8[1]; var _useState9 = (0, _react.useState)(false), _useState10 = (0, _slicedToArray2["default"])(_useState9, 2), isJsEllipsis = _useState10[0], setIsJsEllipsis = _useState10[1]; var _useState11 = (0, _react.useState)(false), _useState12 = (0, _slicedToArray2["default"])(_useState11, 2), isNativeEllipsis = _useState12[0], setIsNativeEllipsis = _useState12[1]; var _useMergedConfig3 = (0, _useMergedConfig5["default"])(ellipsis, { expandable: false }), _useMergedConfig4 = (0, _slicedToArray2["default"])(_useMergedConfig3, 2), enableEllipsis = _useMergedConfig4[0], ellipsisConfig = _useMergedConfig4[1]; var mergedEnableEllipsis = enableEllipsis && !expanded; var _ellipsisConfig$rows = ellipsisConfig.rows, rows = _ellipsisConfig$rows === void 0 ? 1 : _ellipsisConfig$rows; var needMeasureEllipsis = (0, _react.useMemo)(function () { return !mergedEnableEllipsis || ellipsisConfig.suffix !== undefined || ellipsisConfig.onEllipsis || ellipsisConfig.expandable || enableCopy; }, [mergedEnableEllipsis, ellipsisConfig, enableCopy]); (0, _react.useLayoutEffect)(function () { if (enableEllipsis && !needMeasureEllipsis) { setIsLineClampSupport((0, _styleChecker.isStyleSupport)('webkitLineClamp')); setIsTextOverflowSupport((0, _styleChecker.isStyleSupport)('textOverflow')); } }, [needMeasureEllipsis, enableEllipsis]); var cssEllipsis = (0, _react.useMemo)(function () { if (needMeasureEllipsis) { return false; } if (rows === 1) { return isTextOverflowSupport; } return isLineClampSupport; }, [needMeasureEllipsis, isTextOverflowSupport, isLineClampSupport]); var isMergedEllipsis = mergedEnableEllipsis && (cssEllipsis ? isNativeEllipsis : isJsEllipsis); var cssTextOverflow = mergedEnableEllipsis && rows === 1 && cssEllipsis; var cssLineClamp = mergedEnableEllipsis && rows > 1 && cssEllipsis; // >>>>> Expand var onExpandClick = function onExpandClick(e) { setExpanded(true); if (ellipsisConfig.onExpand) { ellipsisConfig.onExpand(e); } }; var _useState13 = (0, _react.useState)(0), _useState14 = (0, _slicedToArray2["default"])(_useState13, 2), ellipsisWidth = _useState14[0], setEllipsisWidth = _useState14[1]; var onResize = function onResize(width) { setEllipsisWidth(width); }; var onJsEllipsis = function onJsEllipsis(jsEllipsis) { setIsJsEllipsis(jsEllipsis); if (isJsEllipsis !== jsEllipsis && ellipsisConfig.onEllipsis) { ellipsisConfig.onEllipsis(jsEllipsis); } }; (0, _react.useEffect)(function () { var textEle = typographyRef.current; if (enableEllipsis && cssEllipsis && textEle) { var currentEllipsis = cssLineClamp ? textEle.offsetHeight < textEle.scrollHeight : textEle.offsetWidth < textEle.scrollWidth; if (isNativeEllipsis !== currentEllipsis) { setIsNativeEllipsis(currentEllipsis); } } }, [enableEllipsis, cssEllipsis, children, cssLineClamp]); // ========================== Tooltip =========================== var tooltipTitle = ellipsisConfig.tooltip === true ? children : ellipsisConfig.tooltip; var topAriaLabel = (0, _react.useMemo)(function () { var isValid = function isValid(val) { return ['string', 'number'].includes((0, _typeof2["default"])(val)); }; if (!enableEllipsis || cssEllipsis) { return undefined; } if (isValid(children)) { return children; } if (isValid(title)) { return title; } if (isValid(tooltipTitle)) { return tooltipTitle; } return undefined; }, [enableEllipsis, cssEllipsis, title, tooltipTitle, isMergedEllipsis]); // =========================== Render =========================== // >>>>>>>>>>> Typography // Expand var renderExpand = function renderExpand() { var expandable = ellipsisConfig.expandable, symbol = ellipsisConfig.symbol; if (!expandable) return null; var expandContent; if (symbol) { expandContent = symbol; } else { expandContent = (0, _localeContext.$l)('Typography', 'expand'); } return /*#__PURE__*/_react["default"].createElement("a", { key: "expand", className: "".concat(prefixCls, "-expand"), onClick: onExpandClick, "aria-label": (0, _localeContext.$l)('Typography', 'expand') }, expandContent); }; // Copy var renderCopy = function renderCopy() { if (!enableCopy) return; var tooltips = copyConfig.tooltips, icon = copyConfig.icon; var tooltipNodes = toList(tooltips); var iconNodes = toList(icon); var copyTitle = copied ? getNode(tooltipNodes[1], (0, _localeContext.$l)('Typography', 'copied')) : getNode(tooltipNodes[0], (0, _localeContext.$l)('Typography', 'copy')); var systemStr = copied ? (0, _localeContext.$l)('Typography', 'copied') : (0, _localeContext.$l)('Typography', 'copy'); var ariaLabel = typeof copyTitle === 'string' ? copyTitle : systemStr; return /*#__PURE__*/_react["default"].createElement(_tooltip["default"], { key: "copy", title: copyTitle }, /*#__PURE__*/_react["default"].createElement(_TransButton["default"], { className: (0, _classnames["default"])("".concat(prefixCls, "-copy"), copied && "".concat(prefixCls, "-copy-success")), onClick: onCopyClick, "aria-label": ariaLabel }, copied ? getNode(iconNodes[1], /*#__PURE__*/_react["default"].createElement(_icon["default"], { type: "check" }), true) : getNode(iconNodes[0], /*#__PURE__*/_react["default"].createElement(_icon["default"], { type: "content_copy" }), true))); }; var renderOperations = function renderOperations(renderExpanded) { return [renderExpanded && renderExpand(), renderCopy()]; }; var renderEllipsis = function renderEllipsis(needEllipsis) { return [needEllipsis && /*#__PURE__*/_react["default"].createElement("span", { "aria-hidden": true, key: "ellipsis" }, ELLIPSIS_STR), ellipsisConfig.suffix, renderOperations(needEllipsis)]; }; return /*#__PURE__*/_react["default"].createElement(_resizeObserver["default"], { onResize: onResize, disabled: !mergedEnableEllipsis || cssEllipsis }, /*#__PURE__*/_react["default"].createElement(_EllipsisTooltip["default"], { title: tooltipTitle, enabledEllipsis: mergedEnableEllipsis, isEllipsis: isMergedEllipsis }, /*#__PURE__*/_react["default"].createElement(_Typography["default"], (0, _extends2["default"])({ className: (0, _classnames["default"])((_classNames = {}, (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-").concat(type), type), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-").concat(suffixCls), suffixCls), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-disabled"), disabled), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-ellipsis"), enableEllipsis), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-single-line"), mergedEnableEllipsis && rows === 1), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-ellipsis-single-line"), cssTextOverflow), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-ellipsis-multiple-line"), cssLineClamp), _classNames), className), style: (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, style), {}, { WebkitLineClamp: cssLineClamp ? rows : undefined }), component: component, ref: (0, _ref2.composeRef)(typographyRef, ref), "aria-label": topAriaLabel, title: title }, textProps), /*#__PURE__*/_react["default"].createElement(_Ellipsis["default"], { enabledMeasure: mergedEnableEllipsis && !cssEllipsis, text: children, rows: rows, width: ellipsisWidth, onEllipsis: onJsEllipsis }, function (node, needEllipsis) { var renderNode = node; if (node.length && needEllipsis && topAriaLabel) { renderNode = /*#__PURE__*/_react["default"].createElement("span", { key: "show-content", "aria-hidden": true }, renderNode); } var wrappedContext = wrapperDecorations(props, /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, renderNode, renderEllipsis(needEllipsis))); return wrappedContext; })))); }); Base.displayName = 'Base'; Base._PRO_TYPOGRAPHY_BASE = true; Base.defaultProps = { component: 'div' }; var _default = Base; exports["default"] = _default; //# sourceMappingURL=index.js.map