choerodon-ui
Version:
An enterprise-class UI design language and React-based implementation
320 lines (280 loc) • 9.49 kB
JavaScript
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