Update deps and rewrite resolvers to not compute everything and put it in context

This commit is contained in:
Trevor Blades
2019-07-22 01:16:09 -07:00
parent 77360d3649
commit 7e68c39351
4 changed files with 459 additions and 484 deletions

View File

@@ -1,14 +1,6 @@
import resolvers from './resolvers';
import typeDefs from './schema';
import {ApolloServer} from 'apollo-server';
import {continents, countries, languages} from 'countries-list';
function toArray(object) {
return Object.keys(object).map(code => ({
...object[code],
code
}));
}
const server = new ApolloServer({
typeDefs,
@@ -17,14 +9,6 @@ const server = new ApolloServer({
playground: true,
engine: {
apiKey: process.env.ENGINE_API_KEY
},
context: {
continents: Object.entries(continents).map(([code, name]) => ({
code,
name
})),
countries: toArray(countries),
languages: toArray(languages)
}
});

845
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -8,10 +8,10 @@
"start": "nodemon -r dotenv/config -r esm index.js"
},
"dependencies": {
"apollo-server": "^2.1.0",
"countries-list": "^2.3.2",
"esm": "^3.0.84",
"graphql": "^14.0.2"
"apollo-server": "^2.7.0",
"countries-list": "^2.4.3",
"esm": "^3.2.25",
"graphql": "^14.4.2"
},
"devDependencies": {
"@trevorblades/eslint-config": "^6.18.0",

View File

@@ -1,25 +1,67 @@
function byCode(code) {
return item => item.code === code;
}
import {continents, countries, languages} from 'countries-list';
export default {
Country: {
continent: (country, args, {continents}) =>
continents.find(continent => continent.code === country.continent),
languages: (country, args, {languages}) =>
languages.filter(language => country.languages.includes(language.code))
continent({continent}) {
return {
code: continent,
name: continents[continent]
};
},
languages(parent) {
return parent.languages.map(code => {
const language = languages[code];
return {
...language,
code
};
});
}
},
Continent: {
countries: (continent, args, {countries}) =>
countries.filter(country => country.continent === continent.code)
countries(parent) {
return Object.entries(countries)
.filter(entry => entry[1].continent === parent.code)
.map(([code, country]) => ({
...country,
code
}));
}
},
Query: {
continent: (parent, args, {continents}) =>
continents.find(byCode(args.code)),
continents: (parent, args, {continents}) => continents,
country: (parent, args, {countries}) => countries.find(byCode(args.code)),
countries: (parent, args, {countries}) => countries,
language: (parent, args, {languages}) => languages.find(byCode(args.code)),
languages: (parent, args, {languages}) => languages
continent(parent, {code}) {
return {
code,
name: continents[code]
};
},
continents() {
return Object.entries(continents).map(([code, name]) => ({
code,
name
}));
},
country(parent, {code}) {
return countries[code];
},
countries() {
return Object.entries(countries).map(([code, country]) => ({
...country,
code
}));
},
language(parent, {code}) {
const language = languages[code];
return {
...language,
code
};
},
languages() {
return Object.entries(languages).map(([code, language]) => ({
...language,
code
}));
}
}
};