123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- import {Component} from 'react';
- import {browserHistory, RouteComponentProps} from 'react-router';
- import styled from '@emotion/styled';
- import {Client} from 'sentry/api';
- import EventSearchBar from 'sentry/components/events/searchBar';
- import * as Layout from 'sentry/components/layouts/thirds';
- import {space} from 'sentry/styles/space';
- import {Group, Organization} from 'sentry/types';
- import {handleRouteLeave} from 'sentry/utils/useCleanQueryParamsOnRouteLeave';
- import withApi from 'sentry/utils/withApi';
- import {normalizeUrl} from 'sentry/utils/withDomainRequired';
- import withOrganization from 'sentry/utils/withOrganization';
- import AllEventsTable from './allEventsTable';
- type Props = {
- api: Client;
- group: Group;
- organization: Organization;
- } & RouteComponentProps<{groupId: string}, {}>;
- interface State {
- query: string;
- }
- const excludedTags = [
- 'environment',
- 'issue',
- 'issue.id',
- 'performance.issue_ids',
- 'transaction.op',
- 'transaction.status',
- ];
- class GroupEvents extends Component<Props, State> {
- constructor(props: Props) {
- super(props);
- const queryParams = this.props.location.query;
- this.state = {
- query: queryParams.query || '',
- };
- }
- componentDidMount() {
- this._unsubscribeHandleRouteLeave = browserHistory.listen(newLocation =>
- handleRouteLeave({
- fieldsToClean: ['cursor'],
- newLocation,
- oldPathname: this.props.location.pathname,
- })
- );
- }
- UNSAFE_componentWillReceiveProps(nextProps: Props) {
- if (this.props.location.search !== nextProps.location.search) {
- const queryParams = nextProps.location.query;
- this.setState({
- query: queryParams.query,
- });
- }
- }
- componentWillUnmount() {
- this._unsubscribeHandleRouteLeave?.();
- }
- _unsubscribeHandleRouteLeave: undefined | ReturnType<typeof browserHistory.listen>;
- handleSearch = (query: string) => {
- const targetQueryParams = {...this.props.location.query};
- targetQueryParams.query = query;
- const {organization} = this.props;
- const {groupId} = this.props.params;
- browserHistory.push(
- normalizeUrl({
- pathname: `/organizations/${organization.slug}/issues/${groupId}/events/`,
- query: targetQueryParams,
- })
- );
- };
- render() {
- return (
- <Layout.Body>
- <Layout.Main fullWidth>
- <AllEventsFilters>
- <EventSearchBar
- organization={this.props.organization}
- defaultQuery=""
- onSearch={this.handleSearch}
- excludedTags={excludedTags}
- query={this.state.query}
- hasRecentSearches={false}
- />
- </AllEventsFilters>
- <AllEventsTable
- issueId={this.props.group.id}
- location={this.props.location}
- organization={this.props.organization}
- group={this.props.group}
- excludedTags={excludedTags}
- />
- </Layout.Main>
- </Layout.Body>
- );
- }
- }
- const AllEventsFilters = styled('div')`
- margin-bottom: ${space(2)};
- `;
- export {GroupEvents};
- export default withOrganization(withApi(GroupEvents));
|