Improved view example.
This commit is contained in:
parent
51f4578a41
commit
1f30a19566
@ -1,32 +1,48 @@
|
|||||||
|
import forEach from 'lodash.foreach'
|
||||||
|
|
||||||
import Collection from './collection'
|
import Collection from './collection'
|
||||||
import View from './view'
|
import View from './view'
|
||||||
|
|
||||||
|
// ===================================================================
|
||||||
|
|
||||||
|
// Create the collection.
|
||||||
const users = new Collection()
|
const users = new Collection()
|
||||||
users.getId = (user) => user.name
|
users.getId = (user) => user.name
|
||||||
|
|
||||||
const activeUsers = new View(users, 'active')
|
// Inserts some data.
|
||||||
activeUsers.on('add', console.log)
|
|
||||||
activeUsers.on('update', console.log)
|
|
||||||
activeUsers.on('remove', console.log)
|
|
||||||
|
|
||||||
users.add({
|
users.add({
|
||||||
name: 'bob'
|
name: 'bob'
|
||||||
})
|
})
|
||||||
|
|
||||||
users.add({
|
users.add({
|
||||||
name: 'clara',
|
name: 'clara',
|
||||||
active: true
|
active: true
|
||||||
})
|
})
|
||||||
|
|
||||||
users.add({
|
users.add({
|
||||||
name: 'ophelia'
|
name: 'ophelia'
|
||||||
})
|
})
|
||||||
|
|
||||||
users.add({
|
users.add({
|
||||||
name: 'Steve',
|
name: 'Steve',
|
||||||
active: true
|
active: true
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// -------------------------------------------------------------------
|
||||||
|
|
||||||
|
// Create the view.
|
||||||
|
const activeUsers = new View(users, 'active')
|
||||||
|
|
||||||
|
// Register some event listeners to see the changes.
|
||||||
|
activeUsers.on('add', users => {
|
||||||
|
forEach(users, (_, id) => {
|
||||||
|
console.log('+ active user:', id)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
activeUsers.on('remove', users => {
|
||||||
|
forEach(users, (_, id) => {
|
||||||
|
console.log('- active user:', id)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
// Make some changes in the future.
|
||||||
setTimeout(function () {
|
setTimeout(function () {
|
||||||
console.log('-----')
|
console.log('-----')
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user