1.0.18 • Published 5 years ago
rxcollection-subscriber v1.0.18
RxCollection Subscriber
A powerful tool built on top of RxCollection that allows you to efficiently display real-time data coming from a RxDB in any way you can imagine.
Renderless component that reacts on VM (criteria) changes for RxDB's collections (RxCollection).
Features
- Reacts on criteria change;
- State management;
- Selects / Deselects items;
- Lets you keep hold of IDs you're working with;
Usage
import Subscriber from 'rxcollection-subscriber'
const sub1 = new Subscriber(collection)
const sub2 = new Subscriber(collection, { criteria: { limit: 3 } })
console.log(sub1.criteria) // the view model.
sub1.criteria.index = 2
console.log(sub1.items) // render this -> main data holder
// select a document
sub1.select(sub1.ids[0])
// get the active RxDocument
console.log(sub1.selectedDoc)Options
| key | type | description | default | 
|---|---|---|---|
| criteria | Criteria | Initial criteria to subscribe with. also applies to lazy subscribers | { limit: 25, index: 0, sort: {}, filter: undefined } | 
| fields | all / string[] | Fields the .items holder should contain for items. Fields starting with _such as_idor_revare always contained. | 'all' | 
| multipleSelect | bool | Allows multiple ids & documents to be selected | false | 
| lazy | bool | does not subscribe on construct | false | 
| progressivePaging | bool | whenever the indexkey in criteria changes / increases, results will not be paginated but appended to previous | false | 
| autoSelectOnCRUD | bool | if a new document gets added / removed from the collection, it'll immediately get selected | false | 
API
| command | description | 
|---|---|
| select( ids : string | string[] ) | This works in 2 ways. With multipleSelectoption enabled it adds / removees the itemId from the .selectedIds list, otherwise it just selects / deselects that item. If the render function is used, this is cached in localStorage | 
| render( options ?: RenderOptions ) | Renders the data. Only works in browser, client-side. | 
Contribute
License
Footnotes
Compatibility
- Works in Node & Browser (IE 11+);
- Compatible with any framework;
1.0.18
5 years ago
1.0.17
5 years ago
1.0.16
5 years ago
1.0.15
5 years ago
1.0.14
5 years ago
1.0.1-3.1
5 years ago
1.0.13
5 years ago
1.0.12
5 years ago
1.0.11
5 years ago
1.0.10
5 years ago
1.0.9
5 years ago
1.0.8
5 years ago
1.0.7
7 years ago
1.0.6
7 years ago
1.0.5
7 years ago
1.0.4
7 years ago
1.0.3
7 years ago
1.0.2
7 years ago
1.0.1
7 years ago
1.0.0
7 years ago