UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

36 lines (35 loc) 1.13 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = useItems; var React = _interopRequireWildcard(require("react")); var _util = require("@rc-component/util"); var _responsiveObserver = require("../../_util/responsiveObserver"); // Convert children into items const transChildren2Items = childNodes => (0, _util.toArray)(childNodes).map(node => ({ ...node?.props, key: node.key })); function useItems(screens, items, children) { const mergedItems = React.useMemo(() => // Take `items` first or convert `children` into items items || transChildren2Items(children), [items, children]); const responsiveItems = React.useMemo(() => mergedItems.map(({ span, ...restItem }) => { if (span === 'filled') { return { ...restItem, filled: true }; } return { ...restItem, span: typeof span === 'number' ? span : (0, _responsiveObserver.matchScreen)(screens, span) }; }), [mergedItems, screens]); return responsiveItems; }