import React, { Component } from 'react'; import { graphql } from 'react-apollo'; import gql from 'graphql-tag'; import hoistStatics from 'hoist-non-react-statics' import Telescope from 'meteor/nova:lib'; import withRemove from './withRemove.jsx' export default function withEdit(WrappedComponent, options) { class WithEdit extends Component { constructor(...args) { super(...args); } render() { // if the NovaForm mutation isn't about editing an existing document (it doesn't have one), do nothing if (!this.props.document) { return } else { const { mutationName, fragment, resultQuery, collection } = this.props; const collectionName = collection._name; const ComponentWithEdit = graphql(gql` mutation ${mutationName}($documentId: String, $set: ${collectionName}Input, $unset: ${collectionName}Unset) { ${mutationName}(documentId: $documentId, set: $set, unset: $unset) { ${fragment ? `...${fragment[0].name.value}` : resultQuery} } } `, { options: (props) => props.fragment ? {fragments: props.fragment} : {}, props: ({ownProps, mutate}) => ({ mutation: ({documentId, set, unset}) => { return mutate({ variables: {documentId: documentId, set, unset} }) } }), })(WrappedComponent); // add the remove mutation by default unless it's explicitly specified not to do it const ComponentToRender = this.props.noRemoveMutation ? ComponentWithEdit : withRemove(ComponentWithEdit); return } } }; WithEdit.displayName = `withEdit(${Telescope.utils.getComponentDisplayName(WrappedComponent)}`; WithEdit.WrappedComponent = WrappedComponent; return hoistStatics(WithEdit, WrappedComponent); };