diff options
author | Minteck <contact@minteck.org> | 2023-02-23 19:34:56 +0100 |
---|---|---|
committer | Minteck <contact@minteck.org> | 2023-02-23 19:34:56 +0100 |
commit | 3d1cd02f27518f1a04374c7c8320cd5d82ede6e9 (patch) | |
tree | 75be5fba4368472fb11c8015aee026b2b9a71888 /school/node_modules/graphql/jsutils/safeArrayFrom.js.flow | |
parent | 8cc1f13c17fa2fb5a4410542d39e650e02945634 (diff) | |
download | pluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.tar.gz pluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.tar.bz2 pluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.zip |
Updated 40 files, added 37 files, deleted 1103 files and renamed 3905 files (automated)
Diffstat (limited to 'school/node_modules/graphql/jsutils/safeArrayFrom.js.flow')
-rw-r--r-- | school/node_modules/graphql/jsutils/safeArrayFrom.js.flow | 59 |
1 files changed, 0 insertions, 59 deletions
diff --git a/school/node_modules/graphql/jsutils/safeArrayFrom.js.flow b/school/node_modules/graphql/jsutils/safeArrayFrom.js.flow deleted file mode 100644 index db2bdea..0000000 --- a/school/node_modules/graphql/jsutils/safeArrayFrom.js.flow +++ /dev/null @@ -1,59 +0,0 @@ -// @flow strict -import { SYMBOL_ITERATOR } from '../polyfills/symbols'; - -/** - * Safer version of `Array.from` that return `null` if value isn't convertible to array. - * Also protects against Array-like objects without items. - * - * @example - * - * safeArrayFrom([ 1, 2, 3 ]) // [1, 2, 3] - * safeArrayFrom('ABC') // null - * safeArrayFrom({ length: 1 }) // null - * safeArrayFrom({ length: 1, 0: 'Alpha' }) // ['Alpha'] - * safeArrayFrom({ key: 'value' }) // null - * safeArrayFrom(new Map()) // [] - * - */ -export default function safeArrayFrom<T>( - collection: mixed, - mapFn: (elem: mixed, index: number) => T = (item) => ((item: any): T), -): Array<T> | null { - if (collection == null || typeof collection !== 'object') { - return null; - } - - if (Array.isArray(collection)) { - return collection.map(mapFn); - } - - // Is Iterable? - const iteratorMethod = collection[SYMBOL_ITERATOR]; - if (typeof iteratorMethod === 'function') { - // $FlowFixMe[incompatible-use] - const iterator = iteratorMethod.call(collection); - const result = []; - let step; - - for (let i = 0; !(step = iterator.next()).done; ++i) { - result.push(mapFn(step.value, i)); - } - return result; - } - - // Is Array like? - const length = collection.length; - if (typeof length === 'number' && length >= 0 && length % 1 === 0) { - const result = []; - for (let i = 0; i < length; ++i) { - if (!Object.prototype.hasOwnProperty.call(collection, i)) { - return null; - } - result.push(mapFn(collection[String(i)], i)); - } - - return result; - } - - return null; -} |