/* * SonarQube * Copyright (C) 2009-2019 SonarSource SA * mailto:info AT sonarsource DOT com * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 3 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ import * as React from 'react'; import AlertErrorIcon from 'sonar-ui-common/components/icons/AlertErrorIcon'; import AlertSuccessIcon from 'sonar-ui-common/components/icons/AlertSuccessIcon'; import BoxedGroupAccordion from 'sonar-ui-common/components/controls/BoxedGroupAccordion'; import DeliveryItem from './DeliveryItem'; import DateTimeFormatter from '../../../components/intl/DateTimeFormatter'; import { getDelivery } from '../../../api/webhooks'; interface Props { delivery: T.WebhookDelivery; } interface State { loading: boolean; open: boolean; payload?: string; } export default class DeliveryAccordion extends React.PureComponent { mounted = false; state: State = { loading: false, open: false }; componentDidMount() { this.mounted = true; } componentWillUnmount() { this.mounted = false; } fetchPayload = ({ delivery } = this.props) => { this.setState({ loading: true }); return getDelivery({ deliveryId: delivery.id }).then( ({ delivery }) => { if (this.mounted) { this.setState({ payload: delivery.payload, loading: false }); } }, () => { if (this.mounted) { this.setState({ loading: false }); } } ); }; formatPayload = (payload: string) => { try { return JSON.stringify(JSON.parse(payload), undefined, 2); } catch (error) { return payload; } }; handleClick = () => { if (!this.state.payload) { this.fetchPayload(); } this.setState(({ open }) => ({ open: !open })); }; render() { const { delivery } = this.props; const { loading, open, payload } = this.state; return ( delivery.success ? ( ) : ( ) } title={}> ); } }