84 lines
2.7 KiB
JavaScript
84 lines
2.7 KiB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
import React from 'react';
|
|
import requiredForA11y from 'prop-types-extra/lib/isRequiredForA11y';
|
|
import { useUncontrolled } from 'uncontrollable';
|
|
import Nav from './Nav';
|
|
import NavLink from './NavLink';
|
|
import NavItem from './NavItem';
|
|
import TabContainer from './TabContainer';
|
|
import TabContent from './TabContent';
|
|
import TabPane from './TabPane';
|
|
import { forEach, map } from './ElementChildren';
|
|
var defaultProps = {
|
|
variant: 'tabs',
|
|
mountOnEnter: false,
|
|
unmountOnExit: false
|
|
};
|
|
|
|
function getDefaultActiveKey(children) {
|
|
var defaultActiveKey;
|
|
forEach(children, function (child) {
|
|
if (defaultActiveKey == null) {
|
|
defaultActiveKey = child.props.eventKey;
|
|
}
|
|
});
|
|
return defaultActiveKey;
|
|
}
|
|
|
|
function renderTab(child) {
|
|
var _child$props = child.props,
|
|
title = _child$props.title,
|
|
eventKey = _child$props.eventKey,
|
|
disabled = _child$props.disabled,
|
|
tabClassName = _child$props.tabClassName;
|
|
|
|
if (title == null) {
|
|
return null;
|
|
}
|
|
|
|
return React.createElement(NavItem, {
|
|
as: NavLink,
|
|
eventKey: eventKey,
|
|
disabled: disabled,
|
|
className: tabClassName
|
|
}, title);
|
|
}
|
|
|
|
var Tabs = React.forwardRef(function (props, ref) {
|
|
var _useUncontrolled = useUncontrolled(props, {
|
|
activeKey: 'onSelect'
|
|
}),
|
|
id = _useUncontrolled.id,
|
|
onSelect = _useUncontrolled.onSelect,
|
|
transition = _useUncontrolled.transition,
|
|
mountOnEnter = _useUncontrolled.mountOnEnter,
|
|
unmountOnExit = _useUncontrolled.unmountOnExit,
|
|
children = _useUncontrolled.children,
|
|
_useUncontrolled$acti = _useUncontrolled.activeKey,
|
|
activeKey = _useUncontrolled$acti === void 0 ? getDefaultActiveKey(children) : _useUncontrolled$acti,
|
|
controlledProps = _objectWithoutPropertiesLoose(_useUncontrolled, ["id", "onSelect", "transition", "mountOnEnter", "unmountOnExit", "children", "activeKey"]);
|
|
|
|
return React.createElement(TabContainer, {
|
|
ref: ref,
|
|
id: id,
|
|
activeKey: activeKey,
|
|
onSelect: onSelect,
|
|
transition: transition,
|
|
mountOnEnter: mountOnEnter,
|
|
unmountOnExit: unmountOnExit
|
|
}, React.createElement(Nav, _extends({}, controlledProps, {
|
|
role: "tablist",
|
|
as: "nav"
|
|
}), map(children, renderTab)), React.createElement(TabContent, null, map(children, function (child) {
|
|
var childProps = _extends({}, child.props);
|
|
|
|
delete childProps.title;
|
|
delete childProps.disabled;
|
|
delete childProps.tabClassName;
|
|
return React.createElement(TabPane, childProps);
|
|
})));
|
|
});
|
|
Tabs.defaultProps = defaultProps;
|
|
Tabs.displayName = 'Tabs';
|
|
export default Tabs; |