From 2c4ae43e688a9873e86211ea0e7aeb9ba770dd77 Mon Sep 17 00:00:00 2001 From: Minteck Date: Tue, 18 Oct 2022 08:59:09 +0200 Subject: Update --- .../graphql/jsutils/promiseForObject.js | 26 ++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 alarm/node_modules/graphql/jsutils/promiseForObject.js (limited to 'alarm/node_modules/graphql/jsutils/promiseForObject.js') diff --git a/alarm/node_modules/graphql/jsutils/promiseForObject.js b/alarm/node_modules/graphql/jsutils/promiseForObject.js new file mode 100644 index 0000000..f291f9b --- /dev/null +++ b/alarm/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