-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathng-pouchdb-collection.js
123 lines (107 loc) · 3.59 KB
/
ng-pouchdb-collection.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
angular.module('pouchdb')
.factory('pouchCollection', ['$timeout', 'pouchdb', function($timeout, pouchDB) {
/**
* @class item in the collection
* @param item
* @param {int} index position of the item in the collection
*
* @property {String} _id unique identifier for this item within the collection
* @property {int} $index position of the item in the collection
*/
function PouchDbItem(item, index) {
this.$index = index;
angular.extend(this, item);
}
/**
* create a pouchCollection
* @param {String} collectionUrl The pouchdb url where the collection lives
* @return {Array} An array that will hold the items in the collection
*/
return function(collectionUrl) {
var collection = [];
var indexes = {};
var db = collection.$db = pouchDB.create(collectionUrl);
function getIndex(prevId) {
return prevId ? indexes[prevId] + 1 : 0;
}
function addChild(index, item) {
indexes[item._id] = index;
collection.splice(index, 0, item);
console.log('added: ', index, item);
}
function removeChild(id) {
var index = indexes[id];
// Remove the item from the collection
collection.splice(index, 1);
indexes[id] = undefined;
console.log('removed: ', id);
}
function updateChild(index, item) {
collection[index] = item;
console.log('changed: ', index, item);
}
function moveChild(from, to, item) {
collection.splice(from, 1);
collection.splice(to, 0, item);
updateIndexes(from, to);
console.log('moved: ', from, ' -> ', to, item);
}
function updateIndexes(from, to) {
var length = collection.length;
to = to || length;
if (to > length) {
to = length;
}
for (index = from; index < to; index++) {
var item = collection[index];
item.$index = indexes[item._id] = index;
}
}
db.changes({
live: true, onChange: function(change) {
if (!change.deleted) {
db.get(change.id).then(function(data) {
if (indexes[change.id] == undefined) { // CREATE / READ
addChild(collection.length, new PouchDbItem(data, collection.length)); // Add to end
updateIndexes(0);
} else { // UPDATE
var index = indexes[change.id];
var item = new PouchDbItem(data, index);
updateChild(index, item);
}
});
} else if (collection.length && indexes[change.id]) { //DELETE
removeChild(change.id);
updateIndexes(indexes[change.id]);
}
}
});
collection.$add = function(item) {
db.post(angular.copy(item)).then(
function(res) {
item._rev = res.rev;
item._id = res.id;
}
);
};
collection.$remove = function(itemOrId) {
var item = angular.isString(itemOrId) ? collection[itemOrId] : itemOrId;
db.remove(item)
};
collection.$update = function(itemOrId) {
var item = angular.isString(itemOrId) ? collection[itemOrId] : itemOrId;
var copy = {};
angular.forEach(item, function(value, key) {
if (key.indexOf('$') !== 0) {
copy[key] = value;
}
});
db.get(item._id).then(
function(res) {
db.put(copy, res._rev);
}
);
};
return collection;
};
}]);