Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/typicode/lodash-id
Makes it easy to manipulate id-based resources with lodash or lowdb
https://github.com/typicode/lodash-id
database lodash lowdb query underscore
Last synced: 4 days ago
JSON representation
Makes it easy to manipulate id-based resources with lodash or lowdb
- Host: GitHub
- URL: https://github.com/typicode/lodash-id
- Owner: typicode
- License: mit
- Created: 2014-01-13T14:34:02.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2022-06-25T11:23:30.000Z (over 2 years ago)
- Last Synced: 2025-01-11T03:09:54.300Z (11 days ago)
- Topics: database, lodash, lowdb, query, underscore
- Language: JavaScript
- Homepage:
- Size: 105 KB
- Stars: 474
- Watchers: 14
- Forks: 26
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# lodash-id [![Build Status](https://travis-ci.org/typicode/lodash-id.svg)](https://travis-ci.org/typicode/lodash-id) [![NPM version](https://badge.fury.io/js/lodash-id.svg)](http://badge.fury.io/js/lodash-id)
> `lodash-id` makes it easy to manipulate id-based resources with [lodash](https://lodash.com/) or [lowdb](https://github.com/typicode/lowdb)
* `getById`
* `insert`
* `upsert`
* `updateById`
* `updateWhere`
* `replaceById`
* `removeById`
* `removeWhere`
* `createId`## Install
```bash
# with lodash
npm install lodash lodash-id --save# with lowdb
npm install lowdb lodash-id --save
```__Note__ `lodash-id` is also compatible with [underscore](http://underscorejs.org/)
## API
In the API examples, we're assuming `db` to be:
```js
const db = {
posts: [
{id: 1, body: 'one', published: false},
{id: 2, body: 'two', published: true}
],
comments: [
{id: 1, body: 'foo', postId: 1},
{id: 2, body: 'bar', postId: 2}
]
}
```__getById(collection, id)__
Finds and returns document by id or undefined.
```js
const post = _.getById(db.posts, 1)
```__insert(collection, document)__
Adds document to collection, sets an id and returns created document.
```js
const post = _.insert(db.posts, { body: 'New post' })
```If the document already has an id, and it is the same as an existing document in the collection, an error is thrown.
```js
_.insert(db.posts, { id: 1, body: 'New post' })
_.insert(db.posts, { id: 1, title: 'New title' }) // Throws an error
```__upsert(collection, document)__
Adds document to collection, sets an id and returns created document.
```js
const post = _.upsert(db.posts, { body: 'New post' })
```If the document already has an id, it will be used to insert or replace.
```js
_.upsert(db.posts, { id: 1, body: 'New post' })
_.upsert(db.posts, { id: 1, title: 'New title' })
_.getById(db.posts, 1) // { id: 1, title: 'New title' }
```__updateById(collection, id, attrs)__
Finds document by id, copies properties to it and returns updated document or undefined.
```js
const post = _.updateById(db.posts, 1, { body: 'Updated body' })
```__updateWhere(collection, whereAttrs, attrs)__
Finds documents using `_.where`, updates documents and returns updated documents or an empty array.
```js
// Publish all unpublished posts
const posts = _.updateWhere(db.posts, { published: false }, { published: true })
```__replaceById(collection, id, attrs)__
Finds document by id, replaces properties and returns document or undefined.
```js
const post = _.replaceById(db.posts, 1, { foo: 'bar' })
```__removeById(collection, id)__
Removes document from collection and returns it or undefined.
```js
const comment = _.removeById(db.comments, 1)
```__removeWhere(collection, whereAttrs)__
Removes documents from collection using `_.where` and returns removed documents or an empty array.
```js
const comments = _.removeWhere(db.comments, { postId: 1 })
```__id__
Overwrite it if you want to use another id property.
```js
_.id = '_id'
```__createId(collectionName, doc)__
Called by lodash-id when a document is inserted. Overwrite it if you want to change id generation algorithm.
```js
_.createId = (collectionName, item) => `${collectionName}-${item.prop}-${Date.now()}`
```## Changelog
See details changes for each version in the [release notes](https://github.com/typicode/lodash-id/releases).
## License
MIT - [Typicode :cactus:](https://github.com/typicode)