mirror of
https://github.com/FranP-code/countries.git
synced 2025-10-13 00:02:15 +00:00
Update deps and rewrite resolvers to not compute everything and put it in context
This commit is contained in:
16
index.js
16
index.js
@@ -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
845
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@@ -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",
|
||||
|
||||
74
resolvers.js
74
resolvers.js
@@ -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
|
||||
}));
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user