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);
};