Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | 23x 23x 23x 23x 23x 23x 23x 23x 53x 53x 53x 53x 23x 53x 23x 21x 1x 20x 20x 2x 20x 2x 23x | import * as React from 'react'; import ApolloClient from 'apollo-client'; import { DefaultOptions } from 'apollo-client/ApolloClient'; import { InMemoryCache as Cache } from 'apollo-cache-inmemory'; import { ApolloProvider } from './index'; import { MockedResponse, MockLink } from './test-links'; export * from './test-links'; export interface MockedProviderProps { mocks?: MockedResponse[]; addTypename?: boolean; defaultOptions?: DefaultOptions; } export interface MockedProviderState { client: ApolloClient<any>; } export class MockedProvider extends React.Component<MockedProviderProps, MockedProviderState> { public static defaultProps: MockedProviderProps = { addTypename: true, }; constructor(props: MockedProviderProps) { super(props); const { mocks, addTypename, defaultOptions } = this.props; const client = new ApolloClient({ cache: new Cache({ addTypename }), defaultOptions, link: new MockLink(mocks || [], addTypename), }); this.state = { client }; } public render() { return <ApolloProvider client={this.state.client}>{this.props.children}</ApolloProvider>; } public componentWillUnmount() { if (!this.state.client.queryManager) { return; } const scheduler = this.state.client.queryManager.scheduler; Object.keys(scheduler.registeredQueries).forEach(queryId => { scheduler.stopPollingQuery(queryId); }); Object.keys(scheduler.intervalQueries).forEach((interval: any) => { scheduler.fetchQueriesOnInterval(interval); }); } } |