import * as React from 'react';
import gql from 'graphql-tag';
import { inject } from 'mobx-react';

import { IMeQueryProps, MeQuery } from './types';

import { usagepackFragment } from '../fragments/usagepack';
import { userFragment } from '../fragments/user';
import { rateplanFragment } from '../fragments/rateplan';

export const RATEPLAN = gql`
  query rateplan($subscriptionId: ID, $accountInput: AccountInput) {
    me(input: $accountInput) {
      ...UserFragment
      profiles (subscriptionId: $subscriptionId) {
        subscriptionId
        ...RateplanFragment
        packs {
            ...UsagepackFragment
        }
      }
    }
  }
	${userFragment}
  ${usagepackFragment}
  ${rateplanFragment}
`;

@inject('authentication')
export default class Query extends React.Component<IMeQueryProps> {
  render() {
    const { authentication: { accountInput }, variables, children, ...rest } = this.props;

    return (
      <MeQuery query={RATEPLAN} variables={{ accountInput, ...variables }} {...rest}>
        {result => children(result)}
      </MeQuery>
    );
  }
}
