UNPKG

@nutui/nutui-react-taro

Version:

京东风格的轻量级移动端 React 组件库,支持一套代码生成 H5 和小程序

360 lines (359 loc) 17.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "Ellipsis", { enumerable: true, get: function() { return Ellipsis; } }); var _interop_require_default = require("@swc/helpers/_/_interop_require_default"); var _interop_require_wildcard = require("@swc/helpers/_/_interop_require_wildcard"); var _async_to_generator = require("@swc/helpers/_/_async_to_generator"); var _define_property = require("@swc/helpers/_/_define_property"); var _object_spread = require("@swc/helpers/_/_object_spread"); var _object_spread_props = require("@swc/helpers/_/_object_spread_props"); var _object_without_properties = require("@swc/helpers/_/_object_without_properties"); var _sliced_to_array = require("@swc/helpers/_/_sliced_to_array"); var _ts_generator = require("@swc/helpers/_/_ts_generator"); var _react = /*#__PURE__*/ _interop_require_wildcard._(require("react")); var _taro = require("@tarojs/taro"); var _classnames = /*#__PURE__*/ _interop_require_default._(require("classnames")); var _components = require("@tarojs/components"); var _getrect = require("../../utils/taro/get-rect"); var _typings = require("../../utils/typings"); var _index = require("../configprovider/index"); var defaultProps = (0, _object_spread_props._)((0, _object_spread._)({}, _typings.ComponentDefaults), { content: '', direction: 'end', rows: 1, expandText: '', collapseText: '', symbol: '...', lineHeight: '20', width: 'auto' }); var classPrefix = "nut-ellipsis"; var Ellipsis = function Ellipsis(props) { var _ellipsis_current, _ellipsis_current1, _ellipsis_current2, _ellipsis_current3; var _ref = (0, _object_spread._)({}, defaultProps, props), children = _ref.children, content = _ref.content, direction = _ref.direction, rows = _ref.rows, className = _ref.className, expandText = _ref.expandText, collapseText = _ref.collapseText, symbol = _ref.symbol, lineHeight = _ref.lineHeight, width = _ref.width, onClick = _ref.onClick, onChange = _ref.onChange, rest = (0, _object_without_properties._)(_ref, [ "children", "content", "direction", "rows", "className", "expandText", "collapseText", "symbol", "lineHeight", "width", "onClick", "onChange" ]); var maxHeight = (0, _react.useRef)(0); var _useState = (0, _sliced_to_array._)((0, _react.useState)(false), 2), exceeded = _useState[0], setExceeded = _useState[1]; var _useState1 = (0, _sliced_to_array._)((0, _react.useState)(false), 2), expanded = _useState1[0], setExpanded = _useState1[1]; var _useState2 = (0, _sliced_to_array._)((0, _react.useState)(false), 2), cacled = _useState2[0], setCacled = _useState2[1]; var ellipsis = (0, _react.useRef)({ leading: '', tailing: '' }); var root = (0, _react.useRef)(null); var rootContain = (0, _react.useRef)(null); var symbolContain = (0, _react.useRef)(null); var _useState3 = (0, _sliced_to_array._)((0, _react.useState)(content), 2), contentCopy = _useState3[0], setContentCopy = _useState3[1]; var lineH = (0, _react.useRef)(0) // 当行的最大高度 ; var originHeight = (0, _react.useRef)(0) // 原始高度 ; var refRandomId = (0, _react.useRef)(Math.random().toString(36).slice(-8)); var widthRef = (0, _react.useRef)('auto'); var widthBase = (0, _react.useRef)([ 14, 10, 7, 8.4, 10 ]) // 中、英(大)、英(小)、数字、其他字符的基础宽度 ; var symbolTextWidth = (0, _react.useRef)(widthBase.current[0] * 0.7921); var chineseReg = /^[\u4e00-\u9fa5]+$/ // 汉字 ; var digitReg = /^[0-9]+$/ // 数字 ; var letterUpperReg = /^[A-Z]+$/ // 字母 ; var letterLowerReg = /^[a-z]+$/ // 字母 ; var rtl = (0, _index.useRtl)(); var rtlClasses = (0, _classnames.default)((0, _define_property._)({}, "".concat(classPrefix, "-rtl"), rtl)); var classes = (0, _classnames.default)(classPrefix, width ? "".concat(classPrefix, "-width") : '', rtlClasses, className); (0, _react.useEffect)(function() { setContentCopy(content); (0, _taro.nextTick)(function() { getSymbolInfo(); getReference(); }); return function() { setCacled(false); }; }, [ content ]); // 获取省略号宽度 var getSymbolInfo = function getSymbolInfo() { return (0, _async_to_generator._)(function() { var refe; return (0, _ts_generator._)(this, function(_state) { switch(_state.label){ case 0: return [ 4, (0, _getrect.getRectInMultiPlatform)(symbolContain === null || symbolContain === void 0 ? void 0 : symbolContain.current) ]; case 1: refe = _state.sent(); symbolTextWidth.current = refe.width ? Math.ceil(refe.width) : Math.ceil(widthBase.current[0] * 0.7921); return [ 2 ]; } }); })(); }; var symbolText = function symbolText() { if (direction === 'end' || direction === 'middle') { return "".concat(symbol).concat(expandText); } return "".concat(symbol).concat(expandText).concat(symbol); }; var getReference = function getReference() { return (0, _async_to_generator._)(function() { var query; return (0, _ts_generator._)(this, function(_state) { query = (0, _taro.createSelectorQuery)(); query.select("#root".concat(refRandomId.current)) && query.select("#root".concat(refRandomId.current)).fields({ computedStyle: [ 'width', 'height', 'lineHeight', 'paddingTop', 'paddingBottom', 'fontSize' ] }, function(res) { if (!res) return; lineH.current = pxToNumber(res.lineHeight === 'normal' ? lineHeight : res.lineHeight); maxHeight.current = Math.floor(lineH.current * (Number(rows) + 0.5) + pxToNumber(res.paddingTop) + pxToNumber(res.paddingBottom)); originHeight.current = pxToNumber(res.height); widthRef.current = res.width; // 设置基础字符 var bsize = pxToNumber(res.fontSize); widthBase.current = [ bsize, bsize * 0.72, bsize * 0.53, bsize * 0.4, bsize * 0.75 ]; if (rootContain.current && rootContain.current.style) { rootContain.current.style.fontSize = "".concat(bsize, "px"); } calcEllipse(); }).exec(); return [ 2 ]; }); })(); }; // 计算省略号的位置 var calcEllipse = function calcEllipse() { return (0, _async_to_generator._)(function() { var refe, rowNum, end, end1, start; return (0, _ts_generator._)(this, function(_state) { switch(_state.label){ case 0: return [ 4, (0, _getrect.getRectInMultiPlatform)(rootContain.current) ]; case 1: refe = _state.sent(); if (refe.height <= maxHeight.current) { setExceeded(false); setCacled(true); } else { rowNum = Math.floor(content.length / (originHeight.current / lineH.current - 1)); // 每行的字数 if (direction === 'middle') { end = content.length; ellipsis.current.leading = tailorContent(0, rowNum * (Number(rows) + 0.5), 'end'); ellipsis.current.tailing = tailorContent(content.length - rowNum * (Number(rows) + 0.5), end, 'start'); } else if (direction === 'end') { end1 = rowNum * (Number(rows) + 0.5); ellipsis.current.leading = tailorContent(0, end1); } else { start = content.length - rowNum * (Number(rows) + 0.5) - 5; ellipsis.current.tailing = tailorContent(start, content.length); } // 进行兜底判断,是否符合要求 assignContent(); setTimeout(function() { verifyEllipsis(); }, 100); } return [ 2 ]; } }); })(); }; // 验证省略号 var verifyEllipsis = function verifyEllipsis1() { return (0, _async_to_generator._)(function() { var refe, _ellipsis_current_leading, _ellipsis_current, _ellipsis_current_leading1, _ellipsis_current1, _ellipsis_current2, _ellipsis_current_tailing, _ellipsis_current3; return (0, _ts_generator._)(this, function(_state) { switch(_state.label){ case 0: return [ 4, (0, _getrect.getRectInMultiPlatformWithoutCache)(rootContain.current) ]; case 1: refe = _state.sent(); if (refe && refe.height && refe.height > maxHeight.current) { if (direction === 'end') { ; ellipsis.current.leading = (_ellipsis_current1 = ellipsis.current) === null || _ellipsis_current1 === void 0 ? void 0 : (_ellipsis_current_leading1 = _ellipsis_current1.leading) === null || _ellipsis_current_leading1 === void 0 ? void 0 : _ellipsis_current_leading1.slice(0, (((_ellipsis_current = ellipsis.current) === null || _ellipsis_current === void 0 ? void 0 : (_ellipsis_current_leading = _ellipsis_current.leading) === null || _ellipsis_current_leading === void 0 ? void 0 : _ellipsis_current_leading.length) || 0) - 1); } else { ; ellipsis.current.tailing = (_ellipsis_current3 = ellipsis.current) === null || _ellipsis_current3 === void 0 ? void 0 : (_ellipsis_current_tailing = _ellipsis_current3.tailing) === null || _ellipsis_current_tailing === void 0 ? void 0 : _ellipsis_current_tailing.slice(1, (_ellipsis_current2 = ellipsis.current) === null || _ellipsis_current2 === void 0 ? void 0 : _ellipsis_current2.tailing.length); } assignContent(); setTimeout(function() { verifyEllipsis(); }, 100); } return [ 2 ]; } }); })(); }; var assignContent = function assignContent() { var _ellipsis_current, _ellipsis_current1, _ellipsis_current2, _ellipsis_current3; var newContent = "".concat(((_ellipsis_current = ellipsis.current) === null || _ellipsis_current === void 0 ? void 0 : _ellipsis_current.leading) || '').concat(((_ellipsis_current1 = ellipsis.current) === null || _ellipsis_current1 === void 0 ? void 0 : _ellipsis_current1.leading) ? symbol : '').concat(expandText || '').concat(((_ellipsis_current2 = ellipsis.current) === null || _ellipsis_current2 === void 0 ? void 0 : _ellipsis_current2.tailing) ? symbol : '').concat(((_ellipsis_current3 = ellipsis.current) === null || _ellipsis_current3 === void 0 ? void 0 : _ellipsis_current3.tailing) || ''); setContentCopy(newContent); }; // 计算省略号 var tailorContent = function tailorContent(left, right) { var type = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : ''; var threeDotWidth = symbolTextWidth.current; var direc = direction === 'middle' && type ? type : direction; setExceeded(true); var widthPart = -1; var start = left; var end = right; var cutoff = 0; var marking = 0; if (direc === 'end') { marking = start; cutoff = end; } else { marking = end; cutoff = start; } var contentWidth = pxToNumber(widthRef.current) * Number(rows) - threeDotWidth; var contentPartWidth = direction === 'middle' ? contentWidth / 2 : contentWidth; while(widthPart < contentPartWidth){ var zi = content[marking]; if (chineseReg.test(zi)) { widthPart = Number(widthPart + widthBase.current[0]); } else if (letterUpperReg.test(zi)) { widthPart = Number(widthPart + widthBase.current[1]); } else if (letterLowerReg.test(zi)) { widthPart = Number(widthPart + widthBase.current[2]); } else if (digitReg.test(zi)) { widthPart = Number(widthPart + widthBase.current[3]); } else { widthPart = Number(widthPart + widthBase.current[4]); } cutoff = marking; direc === 'end' ? marking++ : marking--; } if (direc === 'end') { return content.slice(0, cutoff); } return content.slice(cutoff, end); }; var pxToNumber = function pxToNumber(value) { if (!value) return 0; var match = value.match(/^\d*(\.\d*)?/); return match ? Number(match[0]) : 0; }; var clickHandle = function clickHandle(type) { if (type === 1) { setExpanded(true); onChange && onChange('expand'); } else { setExpanded(false); onChange && onChange('collapse'); } }; var handleClick = function handleClick() { onClick && onClick(); }; return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement("div", (0, _object_spread._)({ className: classes, onClick: handleClick, ref: root, id: "root".concat(refRandomId.current) }, rest), /*#__PURE__*/ _react.default.createElement(_components.View, null, !exceeded ? /*#__PURE__*/ _react.default.createElement(_components.View, { className: "nut-ellipsis-wordbreak", style: { width: "".concat(!Number.isNaN(Number(width)) ? "".concat(width, "px") : 'auto'), minHeight: '20px', height: cacled ? 'auto' : '20px', overflow: 'hidden' } }, content) : null, exceeded && !expanded ? /*#__PURE__*/ _react.default.createElement(_components.View, { className: "nut-ellipsis-wordbreak", style: { width: "".concat(!Number.isNaN(Number(width)) ? "".concat(width, "px") : 'auto') } }, (_ellipsis_current = ellipsis.current) === null || _ellipsis_current === void 0 ? void 0 : _ellipsis_current.leading, ((_ellipsis_current1 = ellipsis.current) === null || _ellipsis_current1 === void 0 ? void 0 : _ellipsis_current1.leading) && symbol, expandText ? /*#__PURE__*/ _react.default.createElement("span", { className: "nut-ellipsis-text", onClick: function onClick(e) { e.stopPropagation(); clickHandle(1); } }, expandText) : null, ((_ellipsis_current2 = ellipsis.current) === null || _ellipsis_current2 === void 0 ? void 0 : _ellipsis_current2.tailing) && symbol, (_ellipsis_current3 = ellipsis.current) === null || _ellipsis_current3 === void 0 ? void 0 : _ellipsis_current3.tailing) : null, exceeded && expanded ? /*#__PURE__*/ _react.default.createElement(_components.View, { style: { width: "".concat(!Number.isNaN(Number(width)) ? "".concat(width, "px") : 'auto') } }, content, expandText ? /*#__PURE__*/ _react.default.createElement("span", { className: "nut-ellipsis-text", onClick: function onClick(e) { e.stopPropagation(); clickHandle(2); } }, collapseText) : null) : null)), /*#__PURE__*/ _react.default.createElement(_components.View, { className: "nut-ellipsis-copy", ref: rootContain, id: "rootContain".concat(refRandomId.current), style: { width: "".concat(widthRef.current) } }, /*#__PURE__*/ _react.default.createElement(_components.View, null, contentCopy)), /*#__PURE__*/ _react.default.createElement(_components.View, { className: "nut-ellipsis-copy", ref: symbolContain, id: "symbolContain".concat(refRandomId.current), style: { display: 'inline' } }, symbolText())); }; Ellipsis.displayName = 'NutEllipsis';