import React, { Component } from 'react'; import PropTypes from 'prop-types'; import { graphql } from 'react-apollo'; import gql from 'graphql-tag'; import { getSetting, getFragment, getFragmentName, getCollection, singleClientTemplate, Utils } from 'meteor/vulcan:lib'; export default function withSingle(options) { const { collectionName, pollInterval = getSetting('pollInterval', 20000), enableCache = false, extraQueries, } = options; const collection = options.collection || getCollection(collectionName); const typeName = collection.options.typeName; const resolverName = Utils.camelCaseify(typeName); let fragment; if (options.fragment) { fragment = options.fragment; } else if (options.fragmentName) { fragment = getFragment(options.fragmentName); } else { fragment = getFragment(`${collection.options.collectionName}DefaultFragment`); } const fragmentName = getFragmentName(fragment); const query = gql`${singleClientTemplate({ typeName, fragmentName, extraQueries })}${fragment}`; return graphql(query, { alias: `with${typeName}`, options({ documentId, slug }) { const graphQLOptions = { variables: { input: { documentId: documentId, slug: slug, enableCache, } }, pollInterval, // note: pollInterval can be set to 0 to disable polling (20s by default) }; if (options.fetchPolicy) { graphQLOptions.fetchPolicy = options.fetchPolicy; } return graphQLOptions; }, props: returnedProps => { const { /* ownProps, */ data } = returnedProps; const propertyName = options.propertyName || 'document'; const props = { loading: data.loading, // document: Utils.convertDates(collection, data[singleResolverName]), [propertyName]: data[resolverName] && data[resolverName].result, fragmentName, fragment, data, }; if (data.error) { // get graphQL error (see https://github.com/thebigredgeek/apollo-errors/issues/12) props.error = data.error.graphQLErrors[0]; } return props; }, }); }