import {Component, Fragment} 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'; import ToolbarHeader from 'sentry/components/toolbarHeader'; import {t} from 'sentry/locale'; import GroupingStore from 'sentry/stores/groupingStore'; import space from 'sentry/styles/space'; import {callIfFunction} from 'sentry/utils/callIfFunction'; type Props = { onMerge: () => void; v2: boolean; }; const initialState = { mergeCount: 0, }; type State = typeof initialState; class SimilarToolbar extends Component { state: State = initialState; componentWillUnmount() { callIfFunction(this.listener); } onGroupChange = ({mergeList}) => { if (!mergeList?.length) { return; } if (mergeList.length !== this.state.mergeCount) { this.setState({mergeCount: mergeList.length}); } }; listener = GroupingStore.listen(this.onGroupChange, undefined); render() { const {onMerge, v2} = this.props; const {mergeCount} = this.state; return ( {t('Events')} {v2 ? ( {t('Score')} ) : ( {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; `;