UNPKG

choerodon-ui

Version:

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

320 lines (280 loc) 9.49 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 isNil from 'lodash/isNil'; import omit from 'lodash/omit'; import isFragment from '../../pro/es/_util/isFragment'; import { iteratorFindIndex, iteratorSome } from '../../pro/es/_util/iteratorUtils'; 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 ( /*#__PURE__*/isValidElement(child)) { c.push(child); } } }); return c; } export function getDefaultActiveKeyInGroup(panelMap) { var activeKey; iteratorSome(panelMap.entries(), function (_ref) { var _ref2 = _slicedToArray(_ref, 2), key = _ref2[0], panel = _ref2[1]; if (!panel.disabled) { activeKey = key; return true; } return false; }); return activeKey; } 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 groupKey; iteratorSome(groupedPanelsMap.entries(), function (_ref3) { var _ref4 = _slicedToArray(_ref3, 2), key = _ref4[0], panelsMap = _ref4[1].panelsMap; return iteratorSome(panelsMap.values(), function (panel) { if (!panel.disabled) { groupKey = key; return true; } return false; }); }); return groupKey; } 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 : iteratorFindIndex(map.keys(), 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; } } 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; } export function normalizePanes(children, customized, options) { var groups = toGroups(children); var groupedPanels = new Map(); var panelList = []; var panes = customized && customized.panes; var omitKeys = []; if (options) { var tabDraggable = options.tabDraggable, tabTitleEditable = options.tabTitleEditable, tabCountHideable = options.tabCountHideable; if (!tabDraggable) { omitKeys.push('sort'); } if (!tabTitleEditable) { omitKeys.push('title'); } if (!tabCountHideable) { omitKeys.push('showCount'); } } var length = omitKeys.length; var getCustomizedPane = function getCustomizedPane(key) { if (panes) { var pane = panes[key]; if (pane && !pane.hidden) { if (length) { return omit(pane, omitKeys); } return pane; } } }; if (groups.length) { var index = 0; groups.forEach(function (group, i) { if (!group.props.hidden) { var groupPanelList = []; toArray(group.props.children).forEach(function (child, j) { if (!child.props.hidden) { var panelKey = generateKey(child.key, index); index += 1; groupPanelList.push([panelKey, _objectSpread(_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).forEach(function (child, index) { if (!child.props.hidden) { var key = generateKey(child.key, index); panelList.push([key, _objectSpread(_objectSpread({ type: child.type, sort: index }, child.props), getCustomizedPane(key))]); } }); panelList.sort(sorter); } return [new Map(panelList), groupedPanels]; } //# sourceMappingURL=utils.js.map