This package gives you possibility to create your own client database and work with it. All what yHERE.createCollection('some_collection_name');
npm i @pavanser/clientdb
// or
yarn add @pavanser/clientdb
You need add data to the collection so:
YOUR_DB_NAME_HERE.some_collection_name.add('object_here');
Return:
response = {
all_docs: ['docs_with_added_data'],
added_doc: { /** doc which you have add */ },
status: "success"
}
YOUR_DB_NAME_HERE.some_collection_name.bulkAdd('array_here');
Return:
response = {
all_docs: ['docs_with_added_data'],
status: 'success',
added_docs: [ /** Your added docs */ ]
}
In case if you use bulkAdd
and some of added data already exists at the store, will be added only uniq data, and you will get next response:
rsponse = {
added_docs: ['only docs which have been added'],
all_docs: ['docs_with_updated_data'],
status: 'added with warnings'
}
For updating use:
YOUR_DB_NAME_HERE.some_collection_name.update('object_here');
Response for update:
response = {
all_docs: [/** docs_with_updated_data */],
updated_doc: {/** Updated doc */},
old_doc: {/** Doc before update */},
status: 'success'
}
For updating two or more docs use bulk update:
YOUR_DB_NAME_HERE.some_collection_name.bulkUpdate('array_here');
Response for bulk updating:
response = {
all_docs: [/** docs_with_updated_data */],
updated_docs: [/** Updated docs */],
old_docs: [/** Docs before update */],
status: 'success'
}
In case if during updating some doc or docs will not be founded, they will be passed and you will get response:
response = {
all_docs: [/** docs_with_updated_data */],
updated_docs: [/** Only updated docs */],
old_docs: [/** Docs before update which was updated */],
passed_data: [ /** Docs whic were not founded */ ],
status: "Not existed docs were not updated"
}
Sometimes you need add some data and update existed data, but not remove else data. For this you can use:
YOUR_DB_NAME_HERE.some_collection_name.upsert('object_here');
Return:
response = {
all_docs: this.docs,
upserted_doc: { /** Added or updated doc */ },
status: 'success'
}
YOUR_DB_NAME_HERE.some_collection_name.bulkUpsert('array_here');
Both methods will return:
response = {
all_docs: ['docs_with_updated_data'],
upserted_docs: [ /** Added or updated docs */],
status: 'success'
}
If you need just get all docs from collection, you can do it by next way:
YOUR_DB_NAME_HERE.some_collection_name.docs;
But some times you need not only get all docs but sort or limit them. So you can use
YOUR_DB_NAME_HERE.some_collection_name.getAll();
Also you may want take some filtered data, you can use where
method got this.
As argument you coud set an object or filter function which should return true
or false
.
YOUR_DB_NAME_HERE.some_collection_name.where('filter options here, object with required fields or filter function');
In some cases you need to get first element of collection, for this you could use
YOUR_DB_NAME_HERE.some_collection_name.getFirst();
In some cases you want to get one doc by id or by some fields:
YOUR_DB_NAME_HERE.some_collection_name.getById(/** doc id */);
if you nedd fine some doc by specific params you can use
YOUR_DB_NAME_HERE.some_collection_name.getOne('filter options here, object with required fields or filter function');
These methods will return you first matches at your collection.
You can subscribe on changes at the collection by fields. If some field will be changed, listeners who listen this filed update will be triggered. for one listener could be set unlimited list of fields.
YOUR_DB_NAME_HERE
.some_collection_name
.subscribe({
next:({ all_docs: [], updated: [] }) => { /** doc id */ },
keys: ['title', 'desc'],
options: {}
});
When you subscribe, it will be triggered and return you arrays with docs.
Also subscription could get options clustered_changes
and clustered_all
, they are boolean
and false
by default.
-
clustered_changes
- iffalse
will just return array of updated items. If true then this items will be wrapped at the cluster, which you can sort offset or limit; Then you will need to execute it byexec()
; -
clustered_all
- same as withclustered_changes
but with all docs.
Cluster instance have next methods.
- sort - this method is sorting data by fields at the array. At the second argument ( this is optional ) you could describe direction of sorting
desc
orasc
for fields one by one; - limit - data will be chunked to tha pages with docs on each equal didgit at the method's argument.
- offset - remove number of docs from start.
- page - change current page.
- exec - return data property value. Could be used as end of chain.
YOUR_DB_NAME_HERE
.some_collection_name
.getAll()
.sort('name') // Will be sorted by name field
.limit(9); // Will be take 9 items from 0
responseWithoutExec = {
data: [/** Docs sorted limited etc. */],
current_page: 0 /** Index of the page at the pages array */,
pages: [/** Array of pages */]
/** ...List of methods */
}
YOUR_DB_NAME_HERE
.some_collection_name
.where({ /** filter options here */ })
.offset(9) // start index for limit is 8
.sort('name') // Will be sorted by name field
.limit(9) // Will be take 9 items from 8th
.exec()
/** ...Response will be value of the data property */