import React, { Component } from 'react'; import PropTypes from 'prop-types'; import { compose, graphql } from 'react-apollo'; import ServicesDeleteMutation from '@graphql/ServicesDeleteMutation.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 Component { 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).then(() => handleCloseClick()); }; return ( ); } } ServiceDelete.propTypes = { service: PropTypes.object, history: PropTypes.object, deleteServices: PropTypes.func.isRequired }; const DeleteServicesGql = graphql(ServicesDeleteMutation, { props: ({ mutate }) => ({ deleteServices: serviceId => mutate({ variables: { ids: [serviceId] }, updateQueries: { Services: (prev, { mutationResult }) => { const deletedService = mutationResult.data.deleteServices[0]; const prevServices = prev.deploymentGroup.services; const services = prevServices.filter( service => service.id !== deletedService.id && service.parent !== deletedService.id ); return { deploymentGroup: { ...prev.deploymentGroup, services } }; } } }) }) }); const ServiceDeleteWithData = compose(DeleteServicesGql, ServiceGql)( ServiceDelete ); export default ServiceDeleteWithData;