UNPKG

@shopify/polaris

Version:

Shopify’s admin product component library

45 lines (40 loc) 1.22 kB
import React from 'react'; import { classNames } from '../../utilities/css.js'; import styles from './ActionMenu.scss.js'; import { RollupActions } from './components/RollupActions/RollupActions.js'; import { Actions } from './components/Actions/Actions.js'; function ActionMenu({ actions = [], groups = [], rollup, rollupActionsLabel }) { if (actions.length === 0 && groups.length === 0) { return null; } const actionMenuClassNames = classNames(styles.ActionMenu, rollup && styles.rollup); const rollupSections = groups.map(group => convertGroupToSection(group)); return /*#__PURE__*/React.createElement("div", { className: actionMenuClassNames }, rollup ? /*#__PURE__*/React.createElement(RollupActions, { accessibilityLabel: rollupActionsLabel, items: actions, sections: rollupSections }) : /*#__PURE__*/React.createElement(Actions, { actions: actions, groups: groups })); } function hasGroupsWithActions(groups = []) { return groups.length === 0 ? false : groups.some(group => group.actions.length > 0); } function convertGroupToSection({ title, actions }) { return { title, items: actions }; } export { ActionMenu, hasGroupsWithActions };