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.flow | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 school/node_modules/graphql/jsutils/promiseForObject.js.flow (limited to 'school/node_modules/graphql/jsutils/promiseForObject.js.flow') diff --git a/school/node_modules/graphql/jsutils/promiseForObject.js.flow b/school/node_modules/graphql/jsutils/promiseForObject.js.flow new file mode 100644 index 0000000..5c2c65b --- /dev/null +++ b/school/node_modules/graphql/jsutils/promiseForObject.js.flow @@ -0,0 +1,22 @@ +// @flow strict +import type { ObjMap } from './ObjMap'; + +/** + * 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. + */ +export default function promiseForObject( + object: ObjMap>, +): Promise> { + const keys = Object.keys(object); + const valuesAndPromises = keys.map((name) => object[name]); + return Promise.all(valuesAndPromises).then((values) => + values.reduce((resolvedObject, value, i) => { + resolvedObject[keys[i]] = value; + return resolvedObject; + }, Object.create(null)), + ); +} -- cgit