UNPKG

linkmore-design

Version:

🌈 πŸš€lmη»„δ»ΆεΊ“γ€‚πŸš€

175 lines (170 loc) β€’ 5.49 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.DescriptionsContext = void 0; var _classnames = _interopRequireDefault(require("classnames")); var _toArray = _interopRequireDefault(require("rc-util/lib/Children/toArray")); var React = _interopRequireWildcard(require("react")); var _configProvider = require("../config-provider"); var _reactNode = require("../_util/reactNode"); var _responsiveObserve = _interopRequireWildcard(require("../_util/responsiveObserve")); var _warning = _interopRequireDefault(require("../_util/warning")); var _Item = _interopRequireDefault(require("./Item")); var _Row = _interopRequireDefault(require("./Row")); /* eslint-disable react/no-array-index-key */ const DescriptionsContext = /*#__PURE__*/React.createContext({}); exports.DescriptionsContext = DescriptionsContext; const DEFAULT_COLUMN_MAP = { xxl: 3, xl: 3, lg: 3, md: 3, sm: 2, xs: 1 }; function getColumn(column, screens) { if (typeof column === 'number') { return column; } if (typeof column === 'object') { for (let i = 0; i < _responsiveObserve.responsiveArray.length; i++) { const breakpoint = _responsiveObserve.responsiveArray[i]; if (screens[breakpoint] && column[breakpoint] !== undefined) { return column[breakpoint] || DEFAULT_COLUMN_MAP[breakpoint]; } } } return 3; } function getFilledItem(node, span, rowRestCol) { let clone = node; if (span === undefined || span > rowRestCol) { clone = (0, _reactNode.cloneElement)(node, { span: rowRestCol }); (0, _warning.default)(span === undefined, 'Descriptions', 'Sum of column `span` in a line not match `column` of Descriptions.'); } return clone; } function getRows(children, column, roleFiledKeys) { const childNodes = (0, _toArray.default)(children).filter(n => { if (n?.props?.roleKey && roleFiledKeys?.roleHideKeys?.includes(n?.props?.roleKey)) { return false; } return n; }); const rows = []; let tmpRow = []; let rowRestCol = column; childNodes.forEach((node, index) => { const span = node.props?.span; const mergedSpan = span || 1; // Additional handle last one if (index === childNodes.length - 1) { tmpRow.push(getFilledItem(node, span, rowRestCol)); rows.push(tmpRow); return; } if (mergedSpan < rowRestCol) { rowRestCol -= mergedSpan; tmpRow.push(node); } else { tmpRow.push(getFilledItem(node, mergedSpan, rowRestCol)); rows.push(tmpRow); rowRestCol = column; tmpRow = []; } }); return rows; } function Descriptions({ prefixCls: customizePrefixCls, title, extra, column = DEFAULT_COLUMN_MAP, colon = true, bordered, layout, children, className, style, size, labelStyle, contentStyle, roleFiledKeys = [] }) { const { getPrefixCls, direction } = React.useContext(_configProvider.ConfigContext); const prefixCls = getPrefixCls('descriptions', customizePrefixCls); const [screens, setScreens] = React.useState({}); const mergedColumn = getColumn(column, screens); // Responsive React.useEffect(() => { const token = _responsiveObserve.default.subscribe(newScreens => { if (typeof column !== 'object') { return; } setScreens(newScreens); }); return () => { _responsiveObserve.default.unsubscribe(token); }; }, []); const typeofRoleFiledKeys = React.useMemo(() => { let roleHideKeys = []; let roleReadOnlyKeys = []; roleFiledKeys.forEach(item => { if (item.type === 0) { roleHideKeys.push(item.key); } else if (item.type === 1) { roleReadOnlyKeys.push(item.key); } }); return { roleHideKeys, roleReadOnlyKeys }; }, [roleFiledKeys]); // Children const rows = getRows(children, mergedColumn, typeofRoleFiledKeys); // console.log(rows, 'rows') const contextValue = React.useMemo(() => ({ labelStyle, contentStyle, roleFiledKeys }), [labelStyle, contentStyle, roleFiledKeys]); return /*#__PURE__*/React.createElement(DescriptionsContext.Provider, { value: contextValue }, /*#__PURE__*/React.createElement("div", { className: (0, _classnames.default)(prefixCls, { [`${prefixCls}-${size}`]: size && size !== 'default', [`${prefixCls}-bordered`]: !!bordered, [`${prefixCls}-rtl`]: direction === 'rtl' }, className), style: style }, (title || extra) && /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-header` }, title && /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-title` }, title), extra && /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-extra` }, extra)), /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-view` }, /*#__PURE__*/React.createElement("table", null, /*#__PURE__*/React.createElement("tbody", null, rows.map((row, index) => /*#__PURE__*/React.createElement(_Row.default, { key: index, index: index, colon: colon, prefixCls: prefixCls, vertical: layout === 'vertical', bordered: bordered, row: row }))))))); } Descriptions.Item = _Item.default; var _default = Descriptions; exports.default = _default;