123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- 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';
- type Props = {
- onMerge: () => void;
- v2: boolean;
- };
- const initialState = {
- mergeCount: 0,
- };
- type State = typeof initialState;
- class SimilarToolbar extends Component<Props, State> {
- state: State = initialState;
- componentWillUnmount() {
- 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 (
- <PanelHeader hasButtons>
- <Confirm
- disabled={mergeCount === 0}
- message={t('Are you sure you want to merge these issues?')}
- onConfirm={onMerge}
- >
- <Button size="sm" title={t('Merging %s issues', mergeCount)}>
- {t('Merge %s', `(${mergeCount || 0})`)}
- </Button>
- </Confirm>
- <Columns>
- <StyledToolbarHeader>{t('Events')}</StyledToolbarHeader>
- {v2 ? (
- <StyledToolbarHeader>{t('Score')}</StyledToolbarHeader>
- ) : (
- <Fragment>
- <StyledToolbarHeader>{t('Exception')}</StyledToolbarHeader>
- <StyledToolbarHeader>{t('Message')}</StyledToolbarHeader>
- </Fragment>
- )}
- </Columns>
- </PanelHeader>
- );
- }
- }
- 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;
- `;
|