@salesforce/design-system-react
Version:
Salesforce Lightning Design System for React
54 lines (47 loc) • 1.95 kB
JavaScript
/* Copyright (c) 2015-present, salesforce.com, inc. All rights reserved */
/* Licensed under BSD 3-Clause - see LICENSE.txt or git.io/sfdc-license */
// # Tabs Component
// Implements the [Tabs design pattern](https://www.lightningdesignsystem.com/components/tabs/) in React.
// ## Dependencies
// ### React
import React from 'react';
import PropTypes from 'prop-types'; // ### classNames
import classNames from 'classnames';
import { TABS_LIST } from '../../../utilities/constants';
var TabsList = function TabsList(_ref) {
var id = _ref.id,
className = _ref.className,
children = _ref.children,
variant = _ref.variant;
return /*#__PURE__*/React.createElement("ul", {
id: "".concat(id, "-slds-tabs__nav"),
className: classNames(className, {
'slds-tabs_default__nav': variant === 'default',
'slds-tabs_scoped__nav': variant === 'scoped',
'slds-vertical-tabs__nav': variant === 'vertical'
}),
role: "tablist",
"aria-orientation": variant === 'vertical' ? 'vertical' : undefined
}, children);
};
TabsList.displayName = TABS_LIST;
TabsList.propTypes = {
/**
* Inherits the `id` from the parent `<Tabs />` component and appends `-tabs__nav`. Becomes the HTML `id` attribute of UL element that has the class `.slds-tabs_default__nav` on it.
*/
id: PropTypes.string,
/**
* Class names to be added to the tabs list element.
*/
className: PropTypes.oneOfType([PropTypes.array, PropTypes.object, PropTypes.string]),
/**
* The `children` are the actual tabs to be rendered as `li` elements. They get created by [tabs/index.jsx](./index.jsx) in the `renderTabsList` function.
*/
children: PropTypes.oneOfType([PropTypes.object, PropTypes.array]),
/**
* If the Tabs should be scoped, vertical, or default (default value)
*/
variant: PropTypes.oneOf(['default', 'scoped', 'vertical'])
};
export default TabsList;
//# sourceMappingURL=tabs-list.js.map