observ-node-array
Populate an observable array from node descriptors.
npm
Install via$ npm install observ-node-array
API
var ObservNodeArray =
var nodeArray = ObservNodeArray(options)
options:
- nodes: An object containing a lookup of observ-* constructors.
- nodeKey: (defaults to
'node'
) They key on the descriptor to use for finding constructor innodes
lookup.
nodeArray()
Gets an array of descriptors as set
or added using push
, insert
(recursive obs()
).
nodeArray(listener)
listener
is called every time the node array is updated.
nodeArray.set(arrayOfDescriptors)
Hydrate descriptors based on nodeKey
specified using the constructors in options.nodes
. If a node already exists at the same index, it will be updated to matched (using node.set
), otherwise replaced or deleted (calling node.destroy
).
nodeArray.push(descriptor)
nodeArray.insert(descriptor, targetIndex)
nodeArray.get(index)
nodeArray.getLength()
nodeArray.indexOf(node)
nodeArray.move(node, targetIndex)
nodeArray.remove(node)
nodeArray.onUpdate(listener)
Lookup / Map
var lookup = require('observ-node-array/lookup')
var map = require('observ-node-array/map')
var lookupValues = lookup(nodeArray, indexKeyOrFunction[, valueKeyOrFunction, rawKeyOrFunction])
lookupValues()
lookupValues(listener)
lookupValues.keys()
lookupValues.get()
lookupValues.flush()
var values = map(nodeArray, valueKeyOrFunction[, rawKeyOrFunction])
values()
values(listener)
values.get(index)
values.getLength()
values.indexOf(node)
values.forEach(iterator[, context])
values.map(iterator[, context])
values.flush()
Concat / Merge / First
var concat = require('observ-node-array/concat')
var merge = require('observ-node-array/merge')
var first = require('observ-node-array/first')
var values = concat(nodeArrays)
var lookupValues = merge(nodeArrayLookups)
var firstItem = first(nodeArray)
Single
var ObservNode = require('observ-node-array/single')
Varhash
var ObservVarhash = require('observ-node-array/varhash')
Watch
var watch = require('observ-node-array/watch')
watch(nodeArray, function(item){
return item(function onChange(){
})
})