176 lines
5.0 KiB
JavaScript
176 lines
5.0 KiB
JavaScript
import { useMemo } from 'react';
|
|
import { ApolloClient } from 'apollo-client';
|
|
import { InMemoryCache } from 'apollo-cache-inmemory';
|
|
import { SchemaLink } from 'apollo-link-schema';
|
|
import { makeExecutableSchema } from 'graphql-tools';
|
|
|
|
let apolloClient;
|
|
|
|
const typeDefs = `
|
|
type Query {
|
|
search(query: SearchQuery!): Response!
|
|
}
|
|
|
|
type SearchQuery {
|
|
q: String!
|
|
fq: String!
|
|
sort: String!
|
|
rows: Int!
|
|
start: Int!
|
|
facet: String!
|
|
include_drafts: Boolean!
|
|
include_private: Boolean!
|
|
use_default_schema: Boolean!
|
|
}
|
|
|
|
type Response {
|
|
success: Boolean!
|
|
result: Result!
|
|
}
|
|
|
|
type Result {
|
|
count: Int!
|
|
sort: String!
|
|
facets: String!
|
|
search_facets: String!
|
|
results: [Package!]!
|
|
}
|
|
|
|
type Package {
|
|
name: String!
|
|
title: String!
|
|
notes: String!
|
|
resources: [Resource!]!
|
|
organization: Organization!
|
|
metadata_created: String!
|
|
metadata_modified: String!
|
|
}
|
|
|
|
type Resource {
|
|
name: String!
|
|
id: String!
|
|
title: String!
|
|
format: String!
|
|
created: String!
|
|
last_modified: String!
|
|
datastore_active: Boolean!
|
|
url: String!
|
|
}
|
|
|
|
type Organization {
|
|
name: String!
|
|
title: String!
|
|
description: String!
|
|
created: String!
|
|
image_url: String!
|
|
}
|
|
`;
|
|
|
|
const resolvers = {
|
|
Query: {
|
|
search: (parent, { query }) => ({
|
|
success: true,
|
|
result: {
|
|
count: 2,
|
|
sort: 'score desc, metadata_modified desc',
|
|
facets: {},
|
|
results: [
|
|
{
|
|
name: 'gdp',
|
|
title: 'Country, Regional and World GDP (Gross Domestic Product)',
|
|
notes:
|
|
'Country, regional and world GDP in current US Dollars ($). Regional means collections of countries e.g. Europe & Central Asia. Data is sourced from the World Bank and turned into a standard normalized CSV.',
|
|
resources: [
|
|
{
|
|
name: 'gdp',
|
|
id: 'gdp',
|
|
title: 'GDP data',
|
|
format: 'csv',
|
|
created: '2019-03-07T12:00:36.273495',
|
|
last_modified: '2020-05-07T12:00:36.273495',
|
|
datastore_active: false,
|
|
url: 'http://mock.filestore/gdp.csv',
|
|
},
|
|
],
|
|
organization: {
|
|
title: 'World Bank',
|
|
name: 'world-bank',
|
|
description:
|
|
'The World Bank is an international financial institution that provides loans and grants to the governments of poorer countries for the purpose of pursuing capital projects.',
|
|
created: '2019-03-07T11:51:13.758844',
|
|
image_url:
|
|
'https://github.com/datahq/frontend/raw/master/public/img/avatars/world-bank.jpg',
|
|
},
|
|
metadata_created: '2019-03-07T11:56:19.696257',
|
|
metadata_modified: '2019-03-07T12:03:58.817280',
|
|
},
|
|
{
|
|
name: 'population',
|
|
title: 'World population data',
|
|
notes:
|
|
'Population figures for countries, regions (e.g. Asia) and the world. Data comes originally from World Bank and has been converted into standard CSV.',
|
|
resources: [
|
|
{
|
|
name: 'population',
|
|
id: 'population',
|
|
title: 'Population data',
|
|
format: 'csv',
|
|
created: '2019-03-07T12:00:36.273495',
|
|
last_modified: '2020-05-07T12:00:36.273495',
|
|
datastore_active: true,
|
|
url: 'http://mock.filestore/population.csv',
|
|
},
|
|
],
|
|
organization: {
|
|
title: 'World Bank',
|
|
name: 'world-bank',
|
|
description:
|
|
'The World Bank is an international financial institution that provides loans and grants to the governments of poorer countries for the purpose of pursuing capital projects.',
|
|
created: '2019-03-07T11:51:13.758844',
|
|
image_url:
|
|
'https://github.com/datahq/frontend/raw/master/public/img/avatars/world-bank.jpg',
|
|
},
|
|
},
|
|
],
|
|
search_facets: {},
|
|
},
|
|
}),
|
|
},
|
|
};
|
|
|
|
const executableSchema = makeExecutableSchema({
|
|
typeDefs,
|
|
resolvers,
|
|
});
|
|
|
|
const link = new SchemaLink({ schema: executableSchema });
|
|
|
|
function createApolloClient() {
|
|
return new ApolloClient({
|
|
ssrMode: typeof window === 'undefined',
|
|
link,
|
|
cache: new InMemoryCache(),
|
|
});
|
|
}
|
|
|
|
export function initializeApollo(initialState = null) {
|
|
const _apolloClient = apolloClient ?? createApolloClient();
|
|
|
|
// If your page has Next.js data fetching methods that use Apollo Client, the initial state
|
|
// gets hydrated here
|
|
if (initialState) {
|
|
_apolloClient.cache.restore(initialState);
|
|
}
|
|
// For SSG and SSR always create a new Apollo Client
|
|
if (typeof window === 'undefined') return _apolloClient;
|
|
// Create the Apollo Client once in the client
|
|
if (!apolloClient) apolloClient = _apolloClient;
|
|
|
|
return _apolloClient;
|
|
}
|
|
|
|
export function useApollo(initialState) {
|
|
const store = useMemo(() => initializeApollo(initialState), [initialState]);
|
|
return store;
|
|
}
|