import * as React from 'react'; import styles from '@patternfly/react-styles/css/components/Toolbar/toolbar'; import { css } from '@patternfly/react-styles'; import { canUseDOM } from '../../helpers/util'; import { RefObject } from 'react'; import { ToolbarItem } from './ToolbarItem'; import { Button } from '../Button'; import { ToolbarGroup } from './ToolbarGroup'; import { globalBreakpoints } from './ToolbarUtils'; import { PickOptional } from '../../helpers/typeUtils'; export interface ToolbarLabelGroupContentProps extends React.HTMLProps { /** Classes applied to root element of the data toolbar content row */ className?: string; /** Flag indicating if a data toolbar toggle group's expandable content is expanded */ isExpanded?: boolean; /** Label group content reference for passing to data toolbar children */ labelGroupContentRef?: RefObject; /** optional callback for clearing all filters in the toolbar */ clearAllFilters?: () => void; /** Flag indicating that the clear all filters button should be visible */ showClearFiltersButton: boolean; /** Text to display in the clear all filters button */ clearFiltersButtonText?: string; /** Total number of filters currently being applied across all ToolbarFilter components */ numberOfFilters: number; /** Text to display in the total number of applied filters ToolbarFilter */ numberOfFiltersText?: (numberOfFilters: number) => string; /** The breakpoint at which the listed filters in label groups are collapsed down to a summary */ collapseListedFiltersBreakpoint?: 'all' | 'md' | 'lg' | 'xl' | '2xl'; /** Custom additional content appended to the generated labels. To maintain spacing and styling, each node should be a ToolbarItem or ToolbarGroup. This property will remove the built in "Clear all filters" button. */ customLabelGroupContent?: React.ReactNode; } class ToolbarLabelGroupContent extends React.Component { static displayName = 'ToolbarLabelGroupContent'; static defaultProps: PickOptional = { clearFiltersButtonText: 'Clear all filters', collapseListedFiltersBreakpoint: 'lg', numberOfFiltersText: (numberOfFilters: number) => `${numberOfFilters} filters applied` }; render() { const { className, isExpanded, labelGroupContentRef, clearAllFilters, showClearFiltersButton, clearFiltersButtonText, collapseListedFiltersBreakpoint, numberOfFilters, numberOfFiltersText, customLabelGroupContent, ...props } = this.props; const clearLabelGroups = () => { clearAllFilters(); }; let collapseListedFilters = false; if (collapseListedFiltersBreakpoint === 'all') { collapseListedFilters = true; } else if (canUseDOM) { collapseListedFilters = (canUseDOM ? window.innerWidth : 1200) < globalBreakpoints[collapseListedFiltersBreakpoint]; } const isHidden = numberOfFilters === 0 || isExpanded; const showNumberOfFilters = collapseListedFilters && numberOfFilters > 0 && !isExpanded; const showDefaultClearFilter = showClearFiltersButton && !isExpanded && !customLabelGroupContent; return (
{(showNumberOfFilters || showDefaultClearFilter || customLabelGroupContent) && ( {showNumberOfFilters && {numberOfFiltersText(numberOfFilters)}} {showDefaultClearFilter && ( )} {customLabelGroupContent && customLabelGroupContent} )}
); } } export { ToolbarLabelGroupContent };