2017-06-24 20:06:28 +02:00
|
|
|
import { BaseModel } from 'lib/base-model.js';
|
|
|
|
import { Log } from 'lib/log.js';
|
2017-05-18 21:58:01 +02:00
|
|
|
|
|
|
|
class Change extends BaseModel {
|
|
|
|
|
|
|
|
static tableName() {
|
|
|
|
return 'changes';
|
|
|
|
}
|
|
|
|
|
|
|
|
static newChange() {
|
|
|
|
return {
|
|
|
|
id: null,
|
|
|
|
type: null,
|
|
|
|
item_id: null,
|
|
|
|
item_type: null,
|
|
|
|
item_field: null,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-05-19 21:12:09 +02:00
|
|
|
static all() {
|
2017-06-11 23:11:14 +02:00
|
|
|
return this.db().selectAll('SELECT * FROM changes');
|
2017-05-19 21:12:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static deleteMultiple(ids) {
|
|
|
|
if (ids.length == 0) return Promise.resolve();
|
|
|
|
|
2017-06-11 23:11:14 +02:00
|
|
|
let queries = [];
|
|
|
|
for (let i = 0; i < ids.length; i++) {
|
|
|
|
queries.push(['DELETE FROM changes WHERE id = ?', [ids[i]]]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return this.db().transactionExecBatch(queries);
|
2017-05-19 21:12:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static mergeChanges(changes) {
|
|
|
|
let createdItems = [];
|
|
|
|
let deletedItems = [];
|
|
|
|
let itemChanges = {};
|
|
|
|
|
|
|
|
for (let i = 0; i < changes.length; i++) {
|
|
|
|
let change = changes[i];
|
2017-06-11 23:11:14 +02:00
|
|
|
let mergedChange = null;
|
2017-05-19 21:12:09 +02:00
|
|
|
|
|
|
|
if (itemChanges[change.item_id]) {
|
|
|
|
mergedChange = itemChanges[change.item_id];
|
|
|
|
} else {
|
|
|
|
mergedChange = {
|
|
|
|
item_id: change.item_id,
|
|
|
|
item_type: change.item_type,
|
|
|
|
fields: [],
|
|
|
|
ids: [],
|
|
|
|
type: change.type,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (change.type == this.TYPE_CREATE) {
|
|
|
|
createdItems.push(change.item_id);
|
|
|
|
} else if (change.type == this.TYPE_DELETE) {
|
|
|
|
deletedItems.push(change.item_id);
|
|
|
|
} else if (change.type == this.TYPE_UPDATE) {
|
|
|
|
if (mergedChange.fields.indexOf(change.item_field) < 0) {
|
|
|
|
mergedChange.fields.push(change.item_field);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
mergedChange.ids.push(change.id);
|
|
|
|
|
|
|
|
itemChanges[change.item_id] = mergedChange;
|
|
|
|
}
|
|
|
|
|
|
|
|
let output = [];
|
|
|
|
|
|
|
|
for (let itemId in itemChanges) {
|
|
|
|
if (!itemChanges.hasOwnProperty(itemId)) continue;
|
|
|
|
let change = itemChanges[itemId];
|
|
|
|
|
|
|
|
if (createdItems.indexOf(itemId) >= 0 && deletedItems.indexOf(itemId) >= 0) {
|
|
|
|
// Item both created then deleted - skip
|
|
|
|
change.type = this.TYPE_NOOP;
|
|
|
|
} else if (deletedItems.indexOf(itemId) >= 0) {
|
|
|
|
// Item was deleted at some point - just return one 'delete' event
|
|
|
|
change.type = this.TYPE_DELETE;
|
|
|
|
} else if (createdItems.indexOf(itemId) >= 0) {
|
|
|
|
// Item was created then updated - just return one 'create' event with the latest changes
|
|
|
|
change.type = this.TYPE_CREATE;
|
|
|
|
}
|
|
|
|
|
|
|
|
output.push(change);
|
|
|
|
}
|
|
|
|
|
|
|
|
return output;
|
|
|
|
}
|
2017-05-18 21:58:01 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-06-06 22:01:43 +02:00
|
|
|
Change.TYPE_NOOP = 0;
|
|
|
|
Change.TYPE_CREATE = 1;
|
|
|
|
Change.TYPE_UPDATE = 2;
|
|
|
|
Change.TYPE_DELETE = 3;
|
|
|
|
|
2017-05-18 21:58:01 +02:00
|
|
|
export { Change };
|