1
0
mirror of http://git.whoc.org.uk/git/password-manager.git synced 2025-01-10 12:20:03 +01:00

Cached record index loading in order to improve rendering performances.

This commit is contained in:
Giulio Cesare Solaroli 2014-12-30 10:28:59 +01:00
parent 8b7a51b95c
commit 88f9bc2cdf

View File

@ -44,7 +44,7 @@ Clipperz.PM.UI.MainController = function() {
this._isDesktop = window.screenX != 0 && !this._isTouchDevice; this._isDesktop = window.screenX != 0 && !this._isTouchDevice;
this._hasKeyboard = this._isDesktop; this._hasKeyboard = this._isDesktop;
this._cardInfoList = []; this._recordsInfo = null;
this._selectedCardInfo = null; this._selectedCardInfo = null;
this._closeMaskAction = null; this._closeMaskAction = null;
@ -162,7 +162,7 @@ console.log("THE BROWSER IS OFFLINE");
var self = this; var self = this;
MochiKit.Iter.forEach(pages, function (aPageName) { MochiKit.Iter.forEach(pages, function (aPageName) {
//console.log("RENDERING", aPageName); //console.log("RENDERING", aPageName);
self._pages[aPageName] = React.renderComponent( self._pages[aPageName] = React.render(
Clipperz.PM.UI.Components.Pages[self.capitaliseFirstLetter(aPageName)](self.pageProperties(aPageName)), Clipperz.PM.UI.Components.Pages[self.capitaliseFirstLetter(aPageName)](self.pageProperties(aPageName)),
MochiKit.DOM.getElement(aPageName) MochiKit.DOM.getElement(aPageName)
); );
@ -512,10 +512,38 @@ console.log("SET USER", aUser);
return result; return result;
}, },
getRecordsInfo: function (cardInfo, shouldIncludeArchivedCards) { //----------------------------------------------------------------------------
return this.user().getRecordsInfo(Clipperz.PM.DataModel.Record.defaultCardInfo /*, shouldIncludeArchivedCards*/);
recordsInfo: function () {
return this._recordsInfo;
}, },
setRecordsInfo: function (someRecordsInfo) {
this._recordsInfo = someRecordsInfo;
return this._recordsInfo;
},
resetRecordsInfo: function () {
this._recordsInfo = null;
},
getRecordsInfo: function (cardInfo, shouldIncludeArchivedCards) {
var deferredResult;
if (this._recordsInfo == null) {
deferredResult = new Clipperz.Async.Deferred('MainController.getRecordsInfo', {trace:false});
deferredResult.addMethod(this.user(), 'getRecordsInfo', Clipperz.PM.DataModel.Record.defaultCardInfo /*, shouldIncludeArchivedCards*/);
deferredResult.addMethod(this, 'setRecordsInfo');
deferredResult.callback();
} else {
deferredResult = MochiKit.Async.succeed(this._recordsInfo);
}
return deferredResult;
},
//----------------------------------------------------------------------------
updateSelectedCards: function (shouldIncludeArchivedCards, aFilter) { updateSelectedCards: function (shouldIncludeArchivedCards, aFilter) {
var deferredResult; var deferredResult;
@ -1005,6 +1033,13 @@ console.log("SET USER", aUser);
// //
// }, // },
saveChanges: function () {
return Clipperz.Async.callbacks("MainController.saveChanges", [
MochiKit.Base.method(this.user(), 'saveChanges'),
MochiKit.Base.method(this, 'resetRecordsInfo'),
], {trace:false});
},
saveCardEdits_handler: function (aRecordReference) { saveCardEdits_handler: function (aRecordReference) {
var currentPage = this.pages()[this.currentPage()]; var currentPage = this.pages()[this.currentPage()];
var self = this; var self = this;
@ -1012,7 +1047,7 @@ console.log("SET USER", aUser);
return Clipperz.Async.callbacks("MainController.saveCardEdits_handler", [ return Clipperz.Async.callbacks("MainController.saveCardEdits_handler", [
MochiKit.Base.method(currentPage, 'setProps', {'showGlobalMask':true}), MochiKit.Base.method(currentPage, 'setProps', {'showGlobalMask':true}),
MochiKit.Base.method(this.overlay(), 'show', "saving …", true), MochiKit.Base.method(this.overlay(), 'show', "saving …", true),
MochiKit.Base.method(this.user(), 'saveChanges'), MochiKit.Base.method(this, 'saveChanges'),
MochiKit.Base.method(currentPage, 'setProps', {'mode':'view', 'showGlobalMask':false}), MochiKit.Base.method(currentPage, 'setProps', {'mode':'view', 'showGlobalMask':false}),
MochiKit.Base.method(this, 'refreshUI', aRecordReference), MochiKit.Base.method(this, 'refreshUI', aRecordReference),
MochiKit.Base.method(this.overlay(), 'done', "saved", 1), MochiKit.Base.method(this.overlay(), 'done', "saved", 1),
@ -1110,7 +1145,7 @@ console.log("SET USER", aUser);
}), }),
MochiKit.Base.method(this.user(), 'getRecord', anEvent['reference']), MochiKit.Base.method(this.user(), 'getRecord', anEvent['reference']),
MochiKit.Base.method(this.user(), 'deleteRecord'), MochiKit.Base.method(this.user(), 'deleteRecord'),
MochiKit.Base.method(this.user(), 'saveChanges'), MochiKit.Base.method(this, 'saveChanges'),
MochiKit.Base.method(this, 'refreshUI') MochiKit.Base.method(this, 'refreshUI')
], {trace:false}); ], {trace:false});
}, },
@ -1119,7 +1154,7 @@ console.log("SET USER", aUser);
return Clipperz.Async.callbacks("MainController.archiveCard_handler", [ return Clipperz.Async.callbacks("MainController.archiveCard_handler", [
MochiKit.Base.method(this.user(), 'getRecord', anEvent['reference']), MochiKit.Base.method(this.user(), 'getRecord', anEvent['reference']),
MochiKit.Base.methodcaller('toggleArchive'), MochiKit.Base.methodcaller('toggleArchive'),
MochiKit.Base.method(this.user(), 'saveChanges'), MochiKit.Base.method(this, 'saveChanges'),
MochiKit.Base.method(this, 'refreshUI', anEvent['reference']) MochiKit.Base.method(this, 'refreshUI', anEvent['reference'])
], {trace:false}); ], {trace:false});
}, },