@carbon/react
Version:
React components for the Carbon Design System
58 lines (54 loc) • 1.75 kB
JavaScript
/**
* Copyright IBM Corp. 2016, 2023
*
* This source code is licensed under the Apache-2.0 license found in the
* LICENSE file in the root directory of this source tree.
*/
import { extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
import { Settings } from '@carbon/icons-react';
import cx from 'classnames';
import PropTypes from 'prop-types';
import React from 'react';
import { usePrefix } from '../../internal/usePrefix.js';
import OverflowMenu from '../OverflowMenu/index.js';
const defaultIconDescription = 'Settings';
const TableToolbarMenu = ({
className,
renderIcon = Settings,
iconDescription = defaultIconDescription,
children,
menuOptionsClass,
...rest
}) => {
const prefix = usePrefix();
const toolbarActionClasses = cx(className, `${prefix}--toolbar-action ${prefix}--overflow-menu`);
const menuOptionsClasses = cx(menuOptionsClass, `${prefix}--toolbar-action__menu`);
return /*#__PURE__*/React.createElement(OverflowMenu, _extends({
renderIcon: renderIcon,
className: toolbarActionClasses,
title: iconDescription,
iconDescription: iconDescription,
menuOptionsClass: menuOptionsClasses,
flipped: true
}, rest), children);
};
TableToolbarMenu.propTypes = {
children: PropTypes.node.isRequired,
/**
* Provide an optional class name for the toolbar menu
*/
className: PropTypes.string,
/**
* The description of the menu icon.
*/
iconDescription: PropTypes.string,
/**
* Provide an optional class name for the toolbar menu
*/
menuOptionsClass: PropTypes.string,
/**
* A component used to render an icon.
*/
renderIcon: PropTypes.oneOfType([PropTypes.func, PropTypes.object])
};
export { TableToolbarMenu as default };