import {Component} from 'react'; import styled from '@emotion/styled'; import {Button} from 'sentry/components/button'; import Confirm from 'sentry/components/confirm'; import PanelHeader from 'sentry/components/panels/panelHeader'; import ToolbarHeader from 'sentry/components/toolbarHeader'; import {t} from 'sentry/locale'; import GroupingStore from 'sentry/stores/groupingStore'; import {space} from 'sentry/styles/space'; type Props = { onMerge: () => void; }; const initialState = { mergeCount: 0, }; type State = typeof initialState; class SimilarToolbar extends Component { state: State = initialState; componentWillUnmount() { this.listener?.(); } onGroupChange = ({mergeList}) => { if (!mergeList?.length) { this.setState({mergeCount: 0}); return; } if (mergeList.length !== this.state.mergeCount) { this.setState({mergeCount: mergeList.length}); } }; listener = GroupingStore.listen(this.onGroupChange, undefined); render() { const {onMerge} = this.props; const {mergeCount} = this.state; return ( {t('Events')} {t('Exception')} {t('Message')} ); } } export default SimilarToolbar; const Columns = styled('div')` display: flex; align-items: center; flex-shrink: 0; min-width: 300px; width: 300px; `; const StyledToolbarHeader = styled(ToolbarHeader)` flex: 1; flex-shrink: 0; display: flex; justify-content: center; padding: ${space(0.5)} 0; `;