Download all records data for export together, to avoid request-toll issues

This commit is contained in:
Giulio Cesare Solaroli 2015-08-21 11:42:05 +02:00
parent 7eb82d391e
commit 337743964c
8 changed files with 56 additions and 107 deletions

View File

@ -461,10 +461,11 @@ div.overlay {
-o-animation-delay: -0.0833s; -o-animation-delay: -0.0833s;
animation-delay: -0.0833s; } animation-delay: -0.0833s; }
div.overlay .progressBar { div.overlay .progressBar {
width: 100%;
background-color: #222; background-color: #222;
height: 4px; height: 4px;
margin-top: 86px; margin-top: 86px;
margin-left: 10px;
margin-right: 10px;
-webkit-border-radius: 2px; -webkit-border-radius: 2px;
-moz-border-radius: 2px; -moz-border-radius: 2px;
border-radius: 2px; } border-radius: 2px; }

File diff suppressed because one or more lines are too long

View File

@ -164,10 +164,19 @@ Clipperz.PM.DataModel.EncryptedRemoteObject.prototype = MochiKit.Base.update(nul
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
'hasLoadedRemoteData': function () { 'hasLoadedRemoteData': function () {
//console.log("EncryptedRemoteObject.hasLoadedRemoteData", this._remoteData);
return (this._remoteData != null); return (this._remoteData != null);
}, },
'setRemoteData': function (someData) {
return Clipperz.Async.callbacks("EncryptedRemoteObject.setRemoteData", [
MochiKit.Base.method(this, 'unpackRemoteData', someData),
MochiKit.Base.bind(function (unpackedData) {
this._remoteData = unpackedData;
return this._remoteData;
}, this)
], {trace:false});
},
'getRemoteData': function () { 'getRemoteData': function () {
var deferredResult; var deferredResult;
var deferredLock; var deferredLock;
@ -184,17 +193,12 @@ Clipperz.PM.DataModel.EncryptedRemoteObject.prototype = MochiKit.Base.update(nul
} else { } else {
innerDeferredResult = Clipperz.Async.callbacks("EncryptedRemoteObjects.getRemoteData <inner deferred>", [ innerDeferredResult = Clipperz.Async.callbacks("EncryptedRemoteObjects.getRemoteData <inner deferred>", [
MochiKit.Base.partial(this.retrieveRemoteDataFunction(), this.reference()), MochiKit.Base.partial(this.retrieveRemoteDataFunction(), this.reference()),
MochiKit.Base.method(this, 'unpackRemoteData'), MochiKit.Base.method(this, 'setRemoteData'),
MochiKit.Base.bind(function (someData) {
this._remoteData = someData;
return this._remoteData;
}, this)
], {trace:false}); ], {trace:false});
} }
return innerDeferredResult; return innerDeferredResult;
}, this)) }, this))
deferredResult.addCallbackPass(MochiKit.Signal.signal, Clipperz.Signal.NotificationCenter, 'advanceProgress');
deferredResult.releaseLock(deferredLock); deferredResult.releaseLock(deferredLock);
deferredResult.callback(); deferredResult.callback();
@ -259,7 +263,6 @@ Clipperz.PM.DataModel.EncryptedRemoteObject.prototype = MochiKit.Base.update(nul
innerDeferredResult = new Clipperz.Async.Deferred("EncryptedRemoteObject.getDecryptedData <inner deferred>", {trace:false}); innerDeferredResult = new Clipperz.Async.Deferred("EncryptedRemoteObject.getDecryptedData <inner deferred>", {trace:false});
innerDeferredResult.addMethod(this, 'getRemoteData'); innerDeferredResult.addMethod(this, 'getRemoteData');
innerDeferredResult.addCallbackPass(MochiKit.Signal.signal, Clipperz.Signal.NotificationCenter, 'advanceProgress');
innerDeferredResult.collectResults({ innerDeferredResult.collectResults({
'key': MochiKit.Base.method(this, 'getKey'), 'key': MochiKit.Base.method(this, 'getKey'),
'value': MochiKit.Base.itemgetter(this._encryptedDataKeypath), 'value': MochiKit.Base.itemgetter(this._encryptedDataKeypath),
@ -267,14 +270,12 @@ Clipperz.PM.DataModel.EncryptedRemoteObject.prototype = MochiKit.Base.update(nul
}); });
innerDeferredResult.addCallback(Clipperz.PM.Crypto.deferredDecrypt); innerDeferredResult.addCallback(Clipperz.PM.Crypto.deferredDecrypt);
innerDeferredResult.addCallbackPass(MochiKit.Signal.signal, Clipperz.Signal.NotificationCenter, 'advanceProgress');
innerDeferredResult.addMethod(this, 'unpackData'); innerDeferredResult.addMethod(this, 'unpackData');
innerDeferredResult.callback(); innerDeferredResult.callback();
return innerDeferredResult; return innerDeferredResult;
}, this))); }, this)));
deferredResult.releaseLock(deferredLock); deferredResult.releaseLock(deferredLock);
deferredResult.addCallbackPass(MochiKit.Signal.signal, Clipperz.Signal.NotificationCenter, 'advanceProgress');
deferredResult.callback(); deferredResult.callback();
return deferredResult; return deferredResult;
@ -534,10 +535,6 @@ Clipperz.PM.DataModel.EncryptedRemoteObject.prototype = MochiKit.Base.update(nul
}, },
MochiKit.Base.method(this, 'packRemoteData'), MochiKit.Base.method(this, 'packRemoteData'),
MochiKit.Base.method(this.transientState(), 'setValue', 'packedRemoteData'), MochiKit.Base.method(this.transientState(), 'setValue', 'packedRemoteData'),
function (someData) {
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'advanceProgress');
return someData;
}
], {trace:false}); ], {trace:false});
}, },

View File

@ -630,6 +630,19 @@ Clipperz.Base.extend(Clipperz.PM.DataModel.User, Object, {
//========================================================================= //=========================================================================
'recordWithData': function (recordData) {
//console.log("recordWithData", recordData)
return Clipperz.Async.callbacks("User.recordWithData", [
MochiKit.Base.method(this, 'getHeaderIndex', 'recordsIndex'),
MochiKit.Base.methodcaller('records'),
MochiKit.Base.itemgetter(recordData['reference']),
MochiKit.Base.methodcaller('setRemoteData', recordData),
], {trace:false});
},
//=========================================================================
'getRecords': function () { 'getRecords': function () {
return Clipperz.Async.callbacks("User.getRecords", [ return Clipperz.Async.callbacks("User.getRecords", [
MochiKit.Base.method(this, 'getHeaderIndex', 'recordsIndex'), MochiKit.Base.method(this, 'getHeaderIndex', 'recordsIndex'),
@ -638,49 +651,22 @@ Clipperz.Base.extend(Clipperz.PM.DataModel.User, Object, {
], {trace:false}); ], {trace:false});
}, },
'getRecordsInfo': function (someInfo /*, shouldIncludeArchivedCards */) { 'getRecordsLoadingAllData': function () {
return Clipperz.Async.callbacks("User.getRecordsLoadingAllData", [
MochiKit.Base.method(this.connection(), 'message', 'getAllRecordDetails'),
MochiKit.Base.values,
MochiKit.Base.partial(MochiKit.Base.map, MochiKit.Base.method(this, 'recordWithData')),
MochiKit.Base.method(this, 'getRecords'),
], {trace:false});
},
'getRecordsInfo': function (someInfo) {
return Clipperz.Async.callbacks("User.getRecordsInfo", [ return Clipperz.Async.callbacks("User.getRecordsInfo", [
MochiKit.Base.method(this, 'getRecords'), MochiKit.Base.method(this, 'getRecords'),
MochiKit.Base.partial(MochiKit.Base.map, Clipperz.Async.collectResults("collectResults", someInfo, {trace:false})), MochiKit.Base.partial(MochiKit.Base.map, Clipperz.Async.collectResults("collectResults", someInfo, {trace:false})),
Clipperz.Async.collectAll, Clipperz.Async.collectAll,
/*
function (aResult) {
var result;
if (shouldIncludeArchivedCards == false) {
result = MochiKit.Base.filter(function (aRecordInfo) { return !aRecordInfo['_isArchived']; }, aResult);
} else {
result = aResult;
}
return result;
}
*/
], {trace:false}); ], {trace:false});
}, },
/*
'filterRecordsInfo': function (someArgs) {
var info = (someArgs.info ? someArgs.info : Clipperz.PM.DataModel.Record.defaultCardInfo);
var searchField = (someArgs.searchField ? someArgs.searchField : Clipperz.PM.DataModel.Record.defaultSearchField);
var includeArchived = (someArgs.includeArchived ? someArgs.includeArchived : false);
var regExp = (someArgs.regExp ? someArgs.regExp : Clipperz.PM.DataModel.Record.regExpForSearch(''));
if (someArgs.regExp) {
regExp = regExp;
} else if (someArgs.search) {
regExp = Clipperz.PM.DataModel.Record.regExpForSearch(someArgs.search);
} else if (someArgs.tag) {
regExp = Clipperz.PM.DataModel.Record.regExpForTag(someArgs.tag);
} else {
regExp = Clipperz.PM.DataModel.Record.regExpForSearch('');
};
return Clipperz.Async.callbacks("User.filterRecordsInfo", [
MochiKit.Base.method(this, 'getRecordsInfo', info, includeArchived),
MochiKit.Base.partial(MochiKit.Base.filter, function (aCardInfo) { regExp.lastIndex = 0; return regExp.test(aCardInfo[searchField]);})
], {trace:false});
},
*/
'recordWithLabel': function (aLabel) { 'recordWithLabel': function (aLabel) {
return Clipperz.Async.callbacks("User.recordWithLabel", [ return Clipperz.Async.callbacks("User.recordWithLabel", [

View File

@ -482,37 +482,11 @@ Clipperz.Base.extend(Clipperz.PM.Proxy.Offline.DataStore, Object, {
//===================================================================== //=====================================================================
} else if (someParameters.message == 'getRecordDetail') { } else if (someParameters.message == 'getRecordDetail') {
/*
var recordData;
var currentVersionData;
recordData = this.userData()['records'][someParameters['parameters']['reference']];
result['reference'] = someParameters['parameters']['reference'];
result['data'] = recordData['data'];
result['version'] = recordData['version'];
result['creationData'] = recordData['creationDate'];
result['updateDate'] = recordData['updateDate'];
result['accessDate'] = recordData['accessDate'];
currentVersionData = recordData['versions'][recordData['currentVersion']];
result['currentVersion'] = {};
result['currentVersion']['reference'] = recordData['currentVersion'];
result['currentVersion']['version'] = currentVersionData['version'];
result['currentVersion']['header'] = currentVersionData['header'];
result['currentVersion']['data'] = currentVersionData['data'];
result['currentVersion']['creationData'] = currentVersionData['creationDate'];
result['currentVersion']['updateDate'] = currentVersionData['updateDate'];
result['currentVersion']['accessDate'] = currentVersionData['accessDate'];
if (typeof(currentVersionData['previousVersion']) != 'undefined') {
result['currentVersion']['previousVersionKey'] = currentVersionData['previousVersionKey'];
result['currentVersion']['previousVersion'] = currentVersionData['previousVersion'];
}
*/
MochiKit.Base.update(result, aConnection['userData']['records'][someParameters['parameters']['reference']]); MochiKit.Base.update(result, aConnection['userData']['records'][someParameters['parameters']['reference']]);
result['reference'] = someParameters['parameters']['reference']; result['reference'] = someParameters['parameters']['reference'];
} else if (someParameters.message == 'getAllRecordDetails') {
} else if (someParameters.message == 'getOneTimePasswordsDetails') { MochiKit.Base.update(result, aConnection['userData']['records']);
} else if (someParameters.message == 'getOneTimePasswordsDetails') {
var result = MochiKit.Iter.reduce(function(prev, cur){ var result = MochiKit.Iter.reduce(function(prev, cur){
prev[cur.reference] = { prev[cur.reference] = {
'status': cur.status, 'status': cur.status,

View File

@ -28,8 +28,8 @@ Clipperz.Base.module('Clipperz.PM.UI');
// https://github.com/eligrey/Blob.js // https://github.com/eligrey/Blob.js
Clipperz.PM.UI.ExportController = function(args) { Clipperz.PM.UI.ExportController = function(args) {
this._recordsInfo = args['recordsInfo'] || Clipperz.Base.exception.raise('MandatoryParameter');
this._processedRecords = 0; this._processedRecords = 0;
this._totalCardsToExport = 0;
this._style = this._style =
"body {" + "body {" +
@ -157,24 +157,13 @@ MochiKit.Base.update(Clipperz.PM.UI.ExportController.prototype, {
return "Clipperz.PM.UI.ExportController"; return "Clipperz.PM.UI.ExportController";
}, },
//-----------------------------------------------------------------------------
'recordsInfo': function () {
return this._recordsInfo;
},
//============================================================================= //=============================================================================
'reportRecordExport': function (aRecordData) { 'reportRecordExport': function (aRecordData) {
var percentage; var percentage;
var exportedCardsCount;
var totalCardsToExport;
this._processedRecords = this._processedRecords + 1; this._processedRecords = this._processedRecords + 1;
percentage = Math.round(100 * this._processedRecords / this._totalCardsToExport);
exportedCardsCount = this._processedRecords;
totalCardsToExport = this.recordsInfo().length;
percentage = Math.round(100 * exportedCardsCount / totalCardsToExport);
//console.log("PROCESSING " + exportedCardsCount + "/" + totalCardsToExport + " - " + percentage + "%"); //console.log("PROCESSING " + exportedCardsCount + "/" + totalCardsToExport + " - " + percentage + "%");
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'updateProgress', percentage); MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'updateProgress', percentage);
@ -285,16 +274,17 @@ MochiKit.Base.update(Clipperz.PM.UI.ExportController.prototype, {
//============================================================================= //=============================================================================
'run': function () { 'run': function (records) {
var deferredResult; var deferredResult;
var self = this; var self = this;
this._totalCardsToExport = records.length;
deferredResult = new Clipperz.Async.Deferred("ExportController.run", {trace:false}); deferredResult = new Clipperz.Async.Deferred("ExportController.run", {trace:false});
deferredResult.addCallback(MochiKit.Base.map, function(recordIn) { deferredResult.addCallback(MochiKit.Base.map, function(aRecord) {
var innerDeferredResult; var innerDeferredResult;
innerDeferredResult = new Clipperz.Async.Deferred("ExportController.run__exportRecord", {trace:false}); innerDeferredResult = new Clipperz.Async.Deferred("ExportController.run__exportRecord", {trace:false});
innerDeferredResult.addMethod(recordIn._rowObject, 'export'); innerDeferredResult.addMethod(aRecord, 'export');
innerDeferredResult.addMethod(self, 'reportRecordExport'); innerDeferredResult.addMethod(self, 'reportRecordExport');
innerDeferredResult.callback(); innerDeferredResult.callback();
@ -302,7 +292,7 @@ MochiKit.Base.update(Clipperz.PM.UI.ExportController.prototype, {
}); });
deferredResult.addCallback(Clipperz.Async.collectAll); deferredResult.addCallback(Clipperz.Async.collectAll);
deferredResult.addMethod(this, 'saveResult'); deferredResult.addMethod(this, 'saveResult');
deferredResult.callback(this.recordsInfo()); deferredResult.callback(records);
return deferredResult; return deferredResult;
}, },

View File

@ -99,6 +99,8 @@ Clipperz.PM.UI.MainController = function() {
Mousetrap.bind(['?'], MochiKit.Base.method(this, 'showHelp_handler')); Mousetrap.bind(['?'], MochiKit.Base.method(this, 'showHelp_handler'));
// Mousetrap.bind(['t e s t'], MochiKit.Base.method(this, 'downloadExport_handler'));
return this; return this;
} }
@ -1288,19 +1290,16 @@ console.log("THE BROWSER IS OFFLINE");
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
// export_handler: function(exportType) {
// return Clipperz.PM.UI.ExportController.exportJSON( this.recordsInfo(), exportType );
// },
downloadExport_handler: function () { downloadExport_handler: function () {
var exportController; var exportController;
var deferredResult; var deferredResult;
exportController = new Clipperz.PM.UI.ExportController({'recordsInfo': this.recordsInfo()}); exportController = new Clipperz.PM.UI.ExportController();
deferredResult = new Clipperz.Async.Deferred("MainController.downloadExport_handler", {trace: false}); deferredResult = new Clipperz.Async.Deferred("MainController.downloadExport_handler", {trace: false});
deferredResult.addMethod(this.overlay(), 'show', "exporting …", true, true); deferredResult.addMethod(this.overlay(), 'show', "loading …", true, true);
// deferredResult.addCallback(MochiKit.Signal.signal, Clipperz.Signal.NotificationCenter, 'toggleSettingsPanel'); deferredResult.addMethod(this.user(), 'getRecordsLoadingAllData');
deferredResult.addCallbackPass(MochiKit.Base.method(this.overlay(), 'show', "exporting …", true, true));
deferredResult.addMethod(exportController, 'run'); deferredResult.addMethod(exportController, 'run');
deferredResult.addMethod(this.overlay(), 'done', "", 1); deferredResult.addMethod(this.overlay(), 'done', "", 1);
deferredResult.callback(); deferredResult.callback();

View File

@ -129,10 +129,12 @@ div.overlay {
.progressBar { .progressBar {
// display: block; // display: block;
width: 100%; // width: 100%;
background-color: #222; background-color: #222;
height: 4px; height: 4px;
margin-top: 86px; margin-top: 86px;
margin-left: 10px;
margin-right: 10px;
@include border-radius(2px); @include border-radius(2px);
.progress { .progress {