UNPKG

@carbon/react

Version:

React components for the Carbon Design System

62 lines (56 loc) 1.88 kB
/** * 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. */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _rollupPluginBabelHelpers = require('../../_virtual/_rollupPluginBabelHelpers.js'); var iconsReact = require('@carbon/icons-react'); var cx = require('classnames'); var PropTypes = require('prop-types'); var React = require('react'); var usePrefix = require('../../internal/usePrefix.js'); var index = require('../OverflowMenu/index.js'); const defaultIconDescription = 'Settings'; const TableToolbarMenu = ({ className, renderIcon = iconsReact.Settings, iconDescription = defaultIconDescription, children, menuOptionsClass, ...rest }) => { const prefix = usePrefix.usePrefix(); const toolbarActionClasses = cx(className, `${prefix}--toolbar-action ${prefix}--overflow-menu`); const menuOptionsClasses = cx(menuOptionsClass, `${prefix}--toolbar-action__menu`); return /*#__PURE__*/React.createElement(index.default, _rollupPluginBabelHelpers.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]) }; exports.default = TableToolbarMenu;