Roughing out the demo app
This commit is contained in:
146
node_modules/lodash-id/README.md
generated
vendored
Normal file
146
node_modules/lodash-id/README.md
generated
vendored
Normal file
@@ -0,0 +1,146 @@
|
||||
# lodash-id [](https://travis-ci.org/typicode/lodash-id) [](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)
|
||||
Reference in New Issue
Block a user