UNPKG

react-lines-ellipsis

Version:

Simple multiline ellipsis component for React.JS

60 lines (56 loc) 1.7 kB
import React from 'react'; function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; } const _excluded = ["component", "text", "lineHeight", "maxLine", "style", "overflowFallback"]; function LinesEllipsisLoose(props) { const { component: Component, text, lineHeight, maxLine, style, overflowFallback } = props, rest = _objectWithoutPropertiesLoose(props, _excluded); const maxLineNumber = +maxLine || 1; let usedStyle = _extends({}, style, { display: '-webkit-box', WebkitBoxOrient: 'vertical', WebkitLineClamp: maxLineNumber }); if (overflowFallback && lineHeight) { const lineHeightNumber = parseFloat(lineHeight); const unit = typeof lineHeight === 'string' && lineHeight.trim().endsWith('em') ? 'em' : 'px'; usedStyle = _extends({}, usedStyle, { lineHeight: `${lineHeightNumber}${unit}`, maxHeight: `${maxLineNumber * lineHeightNumber}${unit}`, overflow: 'hidden' }); } return /*#__PURE__*/React.createElement(Component, _extends({}, rest, { style: usedStyle }), text); } LinesEllipsisLoose.defaultProps = { component: 'div', maxLine: 1, style: {}, overflowFallback: true }; export default LinesEllipsisLoose;