23 lines
660 B
Plaintext
23 lines
660 B
Plaintext
/**
|
|
* Copyright 2015-present Facebook. All Rights Reserved.
|
|
*
|
|
* @providesModule partitionObjectByKey
|
|
* @typechecks
|
|
* @flow
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
var partitionObject = require('./partitionObject');
|
|
|
|
/**
|
|
* Partitions the enumerable properties of an object into two objects, given a
|
|
* whitelist `Set` for the first object. This is comparable to
|
|
* `whitelistObjectKeys`, but eventually keeping all the keys. Returns a tuple
|
|
* of objects `[first, second]`.
|
|
*/
|
|
function partitionObjectByKey(source: Object, whitelist: Set<string>): [Object, Object] {
|
|
return partitionObject(source, (_, key) => whitelist.has(key));
|
|
}
|
|
|
|
module.exports = partitionObjectByKey; |