From 99c1d9af689e5325f3cf535c4007b3aeb8325229 Mon Sep 17 00:00:00 2001 From: Minteck Date: Tue, 10 Jan 2023 14:54:04 +0100 Subject: Update - This is an automated commit --- .../graphql/jsutils/promiseForObject.js | 26 ++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 school/node_modules/graphql/jsutils/promiseForObject.js (limited to 'school/node_modules/graphql/jsutils/promiseForObject.js') diff --git a/school/node_modules/graphql/jsutils/promiseForObject.js b/school/node_modules/graphql/jsutils/promiseForObject.js new file mode 100644 index 0000000..f291f9b --- /dev/null +++ b/school/node_modules/graphql/jsutils/promiseForObject.js @@ -0,0 +1,26 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = promiseForObject; + +/** + * This function transforms a JS object `ObjMap>` into + * a `Promise>` + * + * This is akin to bluebird's `Promise.props`, but implemented only using + * `Promise.all` so it will work with any implementation of ES6 promises. + */ +function promiseForObject(object) { + var keys = Object.keys(object); + var valuesAndPromises = keys.map(function (name) { + return object[name]; + }); + return Promise.all(valuesAndPromises).then(function (values) { + return values.reduce(function (resolvedObject, value, i) { + resolvedObject[keys[i]] = value; + return resolvedObject; + }, Object.create(null)); + }); +} -- cgit