UNPKG

choerodon-ui

Version:

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

332 lines (298 loc) 10.3 kB
import _objectSpread from "@babel/runtime/helpers/objectSpread2"; import _defineProperty from "@babel/runtime/helpers/defineProperty"; import _slicedToArray from "@babel/runtime/helpers/slicedToArray"; import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray"; import { Children, isValidElement } from 'react'; import { isFragment } from 'react-is'; import isNil from 'lodash/isNil'; import { TabsPosition } from './enum'; import { isTabGroup } from './TabGroup'; export function toGroups(children) { var c = []; Children.forEach(children, function (child) { if (child) { if (isFragment(child)) { c.push.apply(c, _toConsumableArray(toGroups(child.props.children))); } else if (isTabGroup(child)) { c.push(child); } } }); return c; } export function toArray(children) { var c = []; Children.forEach(children, function (child) { if (child) { if (isFragment(child)) { c.push.apply(c, _toConsumableArray(toArray(child.props.children))); } else if (isValidElement(child)) { c.push(child); } } }); return c; } export function getDefaultActiveKeyInGroup(panelMap) { var _iteratorNormalCompletion = true; var _didIteratorError = false; var _iteratorError = undefined; try { for (var _iterator = panelMap[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { var _step$value = _slicedToArray(_step.value, 2), key = _step$value[0], panel = _step$value[1]; if (!panel.disabled) { return key; } } } catch (err) { _didIteratorError = true; _iteratorError = err; } finally { try { if (!_iteratorNormalCompletion && _iterator["return"] != null) { _iterator["return"](); } } finally { if (_didIteratorError) { throw _iteratorError; } } } } export function getDefaultActiveKey(totalPanelsMap, groupedPanelsMap, option) { var activeKey = option.activeKey, defaultActiveKey = option.defaultActiveKey; if (activeKey !== undefined) { return activeKey; } if (defaultActiveKey !== undefined) { return defaultActiveKey; } var _groupedPanelsMap$val = groupedPanelsMap.values().next(), value = _groupedPanelsMap$val.value; if (value) { var groupDefaultActiveKey = value.group.defaultActiveKey; if (groupDefaultActiveKey !== undefined) { return groupDefaultActiveKey; } } return getDefaultActiveKeyInGroup(totalPanelsMap); } export function getDefaultGroupKey(groupedPanelsMap) { var _iteratorNormalCompletion2 = true; var _didIteratorError2 = false; var _iteratorError2 = undefined; try { for (var _iterator2 = groupedPanelsMap[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) { var _step2$value = _slicedToArray(_step2.value, 2), key = _step2$value[0], panelsMap = _step2$value[1].panelsMap; var _iteratorNormalCompletion3 = true; var _didIteratorError3 = false; var _iteratorError3 = undefined; try { for (var _iterator3 = panelsMap[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) { var _step3$value = _slicedToArray(_step3.value, 2), panel = _step3$value[1]; if (!panel.disabled) { return key; } } } catch (err) { _didIteratorError3 = true; _iteratorError3 = err; } finally { try { if (!_iteratorNormalCompletion3 && _iterator3["return"] != null) { _iterator3["return"](); } } finally { if (_didIteratorError3) { throw _iteratorError3; } } } } } catch (err) { _didIteratorError2 = true; _iteratorError2 = err; } finally { try { if (!_iteratorNormalCompletion2 && _iterator2["return"] != null) { _iterator2["return"](); } } finally { if (_didIteratorError2) { throw _iteratorError2; } } } } export function getActiveKeyByGroupKey(groupedPanelsMap, key) { var map = groupedPanelsMap.get(key); if (map) { var group = map.group, panelsMap = map.panelsMap, lastActiveKey = map.lastActiveKey; if (lastActiveKey) { return lastActiveKey; } if ('defaultActiveKey' in group) { return group.defaultActiveKey; } return getDefaultActiveKeyInGroup(panelsMap); } } export function generateKey(key, index) { return String(isNil(key) ? index : key); } export function getActiveIndex(map, activeKey) { return activeKey === undefined ? -1 : _toConsumableArray(map.keys()).findIndex(function (key) { return key === activeKey; }); } export function setTransform(style) { var v = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; style.transform = v; style.webkitTransform = v; } export function isTransformSupported(style) { return 'transform' in style || 'webkitTransform' in style; } export function setTransition(style) { var v = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; style.transition = v; style.webkitTransition = v; } export function getTransformPropValue(v) { return { transform: v, WebkitTransform: v }; } export function isVertical(tabBarPosition) { return tabBarPosition === TabsPosition.left || tabBarPosition === TabsPosition.right; } export function getTransformByIndex(index, tabBarPosition) { var translate = isVertical(tabBarPosition) ? 'translateY' : 'translateX'; return "".concat(translate, "(").concat(-index * 100, "%) translateZ(0)"); } export function getMarginStyle(index, tabBarPosition) { var marginDirection = isVertical(tabBarPosition) ? 'marginTop' : 'marginLeft'; return _defineProperty({}, marginDirection, "".concat(-index * 100, "%")); } export function getStyle(el, property) { return +getComputedStyle(el).getPropertyValue(property).replace('px', ''); } export function setPxStyle(el, value, vertical) { value = vertical ? "0px, ".concat(value, "px, 0px") : "".concat(value, "px, 0px, 0px"); setTransform(el.style, "translate3d(".concat(value, ")")); } export function getDataAttr(props) { return Object.keys(props).reduce(function (prev, key) { if (key === 'role' || key.startsWith('aria-') || key.startsWith('data-')) { prev[key] = props[key]; } return prev; }, {}); } function toNum(style, property) { return +style.getPropertyValue(property).replace('px', ''); } function getTypeValue(start, current, end, tabNode, wrapperNode) { var total = getStyle(wrapperNode, "padding-".concat(start)); var parentNode = tabNode.parentNode; if (parentNode) { _toConsumableArray(parentNode.childNodes).some(function (node) { if (node !== tabNode) { // 此处对代码进行了修改 取自rc-tabs@9.4.2 这版本进行了计算方式的调整,避免了在类似modal等有动画的内容中使用的时候,计算出现错误的问题,因为在动画过程中的计算,会有一次Height width为0的情况 // 在 9.4.2版本中 因为前几个版本的修改 refactor: rm mixin and react-create-class // 对dom结构进行了调整 bar不与item在一个父元素中,因此有如下代码,在c7n中暂时不进行dom结构调整 if (node.className.includes('ink-bar')) { return false; } var style = getComputedStyle(node); total += toNum(style, "margin-".concat(start)); total += toNum(style, "margin-".concat(end)); total += toNum(style, current); if (style.boxSizing === 'content-box') { total += toNum(style, "border-".concat(start, "-width")) + toNum(style, "padding-".concat(start)) + toNum(style, "border-".concat(end, "-width")) + toNum(style, "padding-".concat(end)); } return false; } return true; }); } return total; } export function getLeft(tabNode, wrapperNode) { return getTypeValue('left', 'width', 'right', tabNode, wrapperNode); } export function getTop(tabNode, wrapperNode) { return getTypeValue('top', 'height', 'bottom', tabNode, wrapperNode); } export function getHeader(props) { var tab = props.tab, title = props.title; if (typeof tab === 'function') { return tab(title); } if (title !== undefined) { return title; } if (tab !== undefined) { return tab; } } export function normalizePanes(children, customized) { var groups = toGroups(children); var groupedPanels = new Map(); var panelList = []; var panes = customized && customized.panes; var getCustomizedPane = function getCustomizedPane(key) { if (panes) { return panes[key]; } }; var sorter = function sorter(item1, item2) { var _item1$1$sort = item1[1].sort, sort = _item1$1$sort === void 0 ? 0 : _item1$1$sort; var _item2$1$sort = item2[1].sort, sort2 = _item2$1$sort === void 0 ? 0 : _item2$1$sort; return sort - sort2; }; if (groups.length) { var index = 0; groups.forEach(function (group, i) { var groupPanelList = []; toArray(group.props.children).forEach(function (child, j) { var panelKey = generateKey(child.key, index); index += 1; groupPanelList.push([panelKey, _objectSpread({ type: child.type, sort: j }, child.props, {}, getCustomizedPane(panelKey))]); }); groupPanelList.sort(sorter); panelList.push.apply(panelList, groupPanelList); var groupKey = generateKey(group.key, i); groupedPanels.set(groupKey, { group: _objectSpread({}, group.props), panelsMap: new Map(groupPanelList) }); }); } else { toArray(children).sort().forEach(function (child, index) { var key = generateKey(child.key, index); panelList.push([key, _objectSpread({ type: child.type, sort: index }, child.props, {}, getCustomizedPane(key))]); }); panelList.sort(sorter); } return [new Map(panelList), groupedPanels]; } //# sourceMappingURL=utils.js.map