import React, { PureComponent } from 'react'; import PropTypes from 'prop-types'; import { compose, graphql, gql } from 'react-apollo'; import ServiceScaleMutation from '@graphql/ServiceScale.gql'; import { Loader, ErrorMessage } from '@components/messaging'; import { ServiceDelete as ServiceDeleteComponent } from '@components/service'; import { Modal } from 'joyent-ui-toolkit'; import ServiceGql from './service-gql'; class ServiceDelete extends PureComponent { render() { if (this.props.loading) { return ; } if (this.props.error) { return ( ); } const { service, deleteServices, history, match } = this.props; const handleCloseClick = evt => { const closeUrl = match.url.split('/').slice(0, -2).join('/'); history.replace(closeUrl); }; const handleConfirmClick = evt => { deleteServices(service.id); }; return ( ); } } ServiceDelete.propTypes = { service: PropTypes.object, history: PropTypes.object, deleteServices: PropTypes.func.isRequired }; const DeleteGql = gql` mutation deleteServices($ids: [ID]!) { deleteServices(ids: $ids) { id slug } } `; const DeleteServicesGql = graphql(DeleteGql, { props: ({ mutate }) => ({ deleteServices: serviceId => mutate({ variables: { ids: [serviceId] } }) }) }); const ServiceDeleteWithData = compose(DeleteServicesGql, ServiceGql)( ServiceDelete ); export default ServiceDeleteWithData;