lodash.filter
Advanced tools
Comparing version 2.4.1 to 3.0.0
92
index.js
/** | ||
* Lo-Dash 2.4.1 (Custom Build) <http://lodash.com/> | ||
* Build: `lodash modularize modern exports="npm" -o ./npm/` | ||
* Copyright 2012-2013 The Dojo Foundation <http://dojofoundation.org/> | ||
* Based on Underscore.js 1.5.2 <http://underscorejs.org/LICENSE> | ||
* Copyright 2009-2013 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | ||
* Available under MIT license <http://lodash.com/license> | ||
* lodash 3.0.0 (Custom Build) <https://lodash.com/> | ||
* Build: `lodash modern modularize exports="npm" -o ./` | ||
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | ||
* Based on Underscore.js 1.7.0 <http://underscorejs.org/LICENSE> | ||
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | ||
* Available under MIT license <https://lodash.com/license> | ||
*/ | ||
var createCallback = require('lodash.createcallback'), | ||
forOwn = require('lodash.forown'); | ||
var arrayFilter = require('lodash._arrayfilter'), | ||
baseCallback = require('lodash._basecallback'), | ||
baseFilter = require('lodash._basefilter'), | ||
isArray = require('lodash.isarray'); | ||
/** | ||
* Iterates over elements of a collection, returning an array of all elements | ||
* the callback returns truey for. The callback is bound to `thisArg` and | ||
* Iterates over elements of `collection`, returning an array of all elements | ||
* `predicate` returns truthy for. The predicate is bound to `thisArg` and | ||
* invoked with three arguments; (value, index|key, collection). | ||
* | ||
* If a property name is provided for `callback` the created "_.pluck" style | ||
* callback will return the property value of the given element. | ||
* If a property name is provided for `predicate` the created "_.property" | ||
* style callback returns the property value of the given element. | ||
* | ||
* If an object is provided for `callback` the created "_.where" style callback | ||
* will return `true` for elements that have the properties of the given object, | ||
* else `false`. | ||
* If an object is provided for `predicate` the created "_.matches" style | ||
* callback returns `true` for elements that have the properties of the given | ||
* object, else `false`. | ||
* | ||
@@ -27,51 +29,33 @@ * @static | ||
* @alias select | ||
* @category Collections | ||
* @category Collection | ||
* @param {Array|Object|string} collection The collection to iterate over. | ||
* @param {Function|Object|string} [callback=identity] The function called | ||
* per iteration. If a property name or object is provided it will be used | ||
* to create a "_.pluck" or "_.where" style callback, respectively. | ||
* @param {*} [thisArg] The `this` binding of `callback`. | ||
* @returns {Array} Returns a new array of elements that passed the callback check. | ||
* @param {Function|Object|string} [predicate=_.identity] The function invoked | ||
* per iteration. If a property name or object is provided it is used to | ||
* create a "_.property" or "_.matches" style callback respectively. | ||
* @param {*} [thisArg] The `this` binding of `predicate`. | ||
* @returns {Array} Returns the new filtered array. | ||
* @example | ||
* | ||
* var evens = _.filter([1, 2, 3, 4, 5, 6], function(num) { return num % 2 == 0; }); | ||
* // => [2, 4, 6] | ||
* var evens = _.filter([1, 2, 3, 4], function(n) { return n % 2 == 0; }); | ||
* // => [2, 4] | ||
* | ||
* var characters = [ | ||
* { 'name': 'barney', 'age': 36, 'blocked': false }, | ||
* { 'name': 'fred', 'age': 40, 'blocked': true } | ||
* var users = [ | ||
* { 'user': 'barney', 'age': 36, 'active': false }, | ||
* { 'user': 'fred', 'age': 40, 'active': true } | ||
* ]; | ||
* | ||
* // using "_.pluck" callback shorthand | ||
* _.filter(characters, 'blocked'); | ||
* // => [{ 'name': 'fred', 'age': 40, 'blocked': true }] | ||
* // using the "_.property" callback shorthand | ||
* _.pluck(_.filter(users, 'active'), 'user'); | ||
* // => ['fred'] | ||
* | ||
* // using "_.where" callback shorthand | ||
* _.filter(characters, { 'age': 36 }); | ||
* // => [{ 'name': 'barney', 'age': 36, 'blocked': false }] | ||
* // using the "_.matches" callback shorthand | ||
* _.pluck(_.filter(users, { 'age': 36 }), 'user'); | ||
* // => ['barney'] | ||
*/ | ||
function filter(collection, callback, thisArg) { | ||
var result = []; | ||
callback = createCallback(callback, thisArg, 3); | ||
var index = -1, | ||
length = collection ? collection.length : 0; | ||
if (typeof length == 'number') { | ||
while (++index < length) { | ||
var value = collection[index]; | ||
if (callback(value, index, collection)) { | ||
result.push(value); | ||
} | ||
} | ||
} else { | ||
forOwn(collection, function(value, index, collection) { | ||
if (callback(value, index, collection)) { | ||
result.push(value); | ||
} | ||
}); | ||
} | ||
return result; | ||
function filter(collection, predicate, thisArg) { | ||
var func = isArray(collection) ? arrayFilter : baseFilter; | ||
predicate = baseCallback(predicate, thisArg, 3); | ||
return func(collection, predicate); | ||
} | ||
module.exports = filter; |
@@ -1,3 +0,3 @@ | ||
Copyright 2012-2013 The Dojo Foundation <http://dojofoundation.org/> | ||
Based on Underscore.js 1.5.2, copyright 2009-2013 Jeremy Ashkenas, | ||
Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | ||
Based on Underscore.js 1.7.0, copyright 2009-2015 Jeremy Ashkenas, | ||
DocumentCloud and Investigative Reporters & Editors <http://underscorejs.org/> | ||
@@ -22,2 +22,2 @@ | ||
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
{ | ||
"name": "lodash.filter", | ||
"version": "2.4.1", | ||
"description": "The Lo-Dash function `_.filter` as a Node.js module generated by lodash-cli.", | ||
"homepage": "http://lodash.com/custom-builds", | ||
"version": "3.0.0", | ||
"description": "The modern build of lodash’s `_.filter` as a module.", | ||
"homepage": "https://lodash.com/", | ||
"icon": "https://lodash.com/icon.svg", | ||
"license": "MIT", | ||
"keywords": ["functional", "lodash", "lodash-modularized", "server", "util"], | ||
"keywords": "lodash, lodash-modularized, stdlib, util", | ||
"author": "John-David Dalton <john.david.dalton@gmail.com> (http://allyoucanleet.com/)", | ||
"contributors": [ | ||
"John-David Dalton <john.david.dalton@gmail.com> (http://allyoucanleet.com/)", | ||
"Benjamin Tan <demoneaux@gmail.com> (https://d10.github.io/)", | ||
"Blaine Bublitz <blaine@iceddev.com> (http://www.iceddev.com/)", | ||
"Kit Cambridge <github@kitcambridge.be> (http://kitcambridge.be/)", | ||
"Mathias Bynens <mathias@qiwi.be> (http://mathiasbynens.be/)" | ||
"Mathias Bynens <mathias@qiwi.be> (https://mathiasbynens.be/)" | ||
], | ||
"bugs": "https://github.com/lodash/lodash-cli/issues", | ||
"repository": { "type": "git", "url": "https://github.com/lodash/lodash-cli.git" }, | ||
"repository": "lodash/lodash", | ||
"scripts": { "test": "echo \"See https://travis-ci.org/lodash/lodash-cli for testing details.\"" }, | ||
"dependencies": { | ||
"lodash.createcallback": "~2.4.1", | ||
"lodash.forown": "~2.4.1" | ||
"lodash._arrayfilter": "^3.0.0", | ||
"lodash._basecallback": "^3.0.0", | ||
"lodash._basefilter": "^3.0.0", | ||
"lodash.isarray": "^3.0.0" | ||
} | ||
} |
@@ -1,15 +0,20 @@ | ||
# lodash.filter v2.4.1 | ||
# lodash.filter v3.0.0 | ||
The [Lo-Dash](http://lodash.com/) function [`_.filter`](http://lodash.com/docs#filter) as a [Node.js](http://nodejs.org/) module generated by [lodash-cli](https://npmjs.org/package/lodash-cli). | ||
The [modern build](https://github.com/lodash/lodash/wiki/Build-Differences) of [lodash’s](https://lodash.com/) `_.filter` exported as a [Node.js](http://nodejs.org/)/[io.js](https://iojs.org/) module. | ||
## Author | ||
## Installation | ||
| [![twitter/jdalton](http://gravatar.com/avatar/299a3d891ff1920b69c364d061007043?s=70)](https://twitter.com/jdalton "Follow @jdalton on Twitter") | | ||
|---| | ||
| [John-David Dalton](http://allyoucanleet.com/) | | ||
Using npm: | ||
## Contributors | ||
```bash | ||
$ {sudo -H} npm i -g npm | ||
$ npm i --save lodash.filter | ||
``` | ||
| [![twitter/blainebublitz](http://gravatar.com/avatar/ac1c67fd906c9fecd823ce302283b4c1?s=70)](https://twitter.com/blainebublitz "Follow @BlaineBublitz on Twitter") | [![twitter/kitcambridge](http://gravatar.com/avatar/6662a1d02f351b5ef2f8b4d815804661?s=70)](https://twitter.com/kitcambridge "Follow @kitcambridge on Twitter") | [![twitter/mathias](http://gravatar.com/avatar/24e08a9ea84deb17ae121074d0f17125?s=70)](https://twitter.com/mathias "Follow @mathias on Twitter") | | ||
|---|---|---| | ||
| [Blaine Bublitz](http://www.iceddev.com/) | [Kit Cambridge](http://kitcambridge.be/) | [Mathias Bynens](http://mathiasbynens.be/) | | ||
In Node.js/io.js: | ||
```js | ||
var filter = require('lodash.filter'); | ||
``` | ||
See the [documentation](https://lodash.com/docs#filter) or [package source](https://github.com/lodash/lodash/blob/3.0.0-npm-packages/lodash.filter) for more details. |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
No bug tracker
MaintenancePackage does not have a linked bug tracker in package.json.
Found 1 instance in 1 package
No repository
Supply chain riskPackage does not have a linked source code repository. Without this field, a package will have no reference to the location of the source code use to generate the package.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
21
5193
4
58
1
+ Addedlodash._arrayfilter@^3.0.0
+ Addedlodash._basecallback@^3.0.0
+ Addedlodash._basefilter@^3.0.0
+ Addedlodash.isarray@^3.0.0
+ Addedlodash._arrayfilter@3.0.0(transitive)
+ Addedlodash._basecallback@3.3.1(transitive)
+ Addedlodash._baseeach@3.0.4(transitive)
+ Addedlodash._basefilter@3.0.0(transitive)
+ Addedlodash._baseisequal@3.0.7(transitive)
+ Addedlodash._bindcallback@3.0.1(transitive)
+ Addedlodash._getnative@3.9.1(transitive)
+ Addedlodash.isarguments@3.1.0(transitive)
+ Addedlodash.isarray@3.0.4(transitive)
+ Addedlodash.istypedarray@3.0.6(transitive)
+ Addedlodash.keys@3.1.2(transitive)
+ Addedlodash.pairs@3.0.1(transitive)
- Removedlodash.createcallback@~2.4.1
- Removedlodash.forown@~2.4.1
- Removedlodash._arraypool@2.4.1(transitive)
- Removedlodash._basebind@2.4.1(transitive)
- Removedlodash._basecreate@2.4.1(transitive)
- Removedlodash._basecreatecallback@2.4.1(transitive)
- Removedlodash._basecreatewrapper@2.4.1(transitive)
- Removedlodash._baseisequal@2.4.1(transitive)
- Removedlodash._createwrapper@2.4.1(transitive)
- Removedlodash._getarray@2.4.1(transitive)
- Removedlodash._isnative@2.4.1(transitive)
- Removedlodash._maxpoolsize@2.4.1(transitive)
- Removedlodash._objecttypes@2.4.1(transitive)
- Removedlodash._releasearray@2.4.1(transitive)
- Removedlodash._setbinddata@2.4.1(transitive)
- Removedlodash._shimkeys@2.4.1(transitive)
- Removedlodash._slice@2.4.1(transitive)
- Removedlodash.bind@2.4.1(transitive)
- Removedlodash.createcallback@2.4.4(transitive)
- Removedlodash.forin@2.4.1(transitive)
- Removedlodash.forown@2.4.1(transitive)
- Removedlodash.identity@2.4.1(transitive)
- Removedlodash.isfunction@2.4.1(transitive)
- Removedlodash.isobject@2.4.1(transitive)
- Removedlodash.keys@2.4.1(transitive)
- Removedlodash.noop@2.4.1(transitive)
- Removedlodash.property@2.4.1(transitive)
- Removedlodash.support@2.4.1(transitive)