2012-09-16 14:59:19 +04:00
|
|
|
(function () {
|
|
|
|
var ns = $.namespace("pskl.service");
|
|
|
|
|
2013-09-22 23:02:43 +04:00
|
|
|
ns.LocalStorageService = function (piskelController) {
|
2012-09-16 14:59:19 +04:00
|
|
|
|
2013-09-22 23:02:43 +04:00
|
|
|
if(piskelController === undefined) {
|
|
|
|
throw "Bad LocalStorageService initialization: <undefined piskelController>";
|
2012-09-16 14:59:19 +04:00
|
|
|
}
|
2013-09-22 23:02:43 +04:00
|
|
|
this.piskelController = piskelController;
|
2012-09-16 14:59:19 +04:00
|
|
|
this.localStorageThrottler_ = null;
|
|
|
|
};
|
|
|
|
|
2013-08-04 20:27:32 +04:00
|
|
|
/**
|
|
|
|
* @public
|
|
|
|
*/
|
2013-09-22 23:02:43 +04:00
|
|
|
ns.LocalStorageService.prototype.init = function(piskelController) {
|
2013-08-04 20:27:32 +04:00
|
|
|
$.subscribe(Events.LOCALSTORAGE_REQUEST, $.proxy(this.persistToLocalStorageRequest_, this));
|
|
|
|
};
|
|
|
|
|
2012-09-16 14:59:19 +04:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
ns.LocalStorageService.prototype.persistToLocalStorageRequest_ = function () {
|
|
|
|
// Persist to localStorage when drawing. We throttle localStorage accesses
|
|
|
|
// for high frequency drawing (eg mousemove).
|
|
|
|
if(this.localStorageThrottler_ !== null) {
|
|
|
|
window.clearTimeout(this.localStorageThrottler_);
|
|
|
|
}
|
|
|
|
this.localStorageThrottler_ = window.setTimeout($.proxy(function() {
|
|
|
|
this.persistToLocalStorage_();
|
|
|
|
this.localStorageThrottler_ = null;
|
|
|
|
}, this), 1000);
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
ns.LocalStorageService.prototype.persistToLocalStorage_ = function() {
|
2013-11-02 02:30:33 +04:00
|
|
|
|
2013-06-13 22:07:12 +04:00
|
|
|
console.log('[LocalStorage service]: Snapshot stored');
|
2013-09-22 23:02:43 +04:00
|
|
|
window.localStorage.snapShot = this.piskelController.serialize();
|
2012-09-16 14:59:19 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
ns.LocalStorageService.prototype.restoreFromLocalStorage_ = function() {
|
2013-11-02 02:30:33 +04:00
|
|
|
var framesheet = JSON.parse(window.localStorage.snapShot);
|
|
|
|
var piskel = pskl.utils.Serializer.createPiskel(framesheet);
|
|
|
|
pskl.app.piskelController.setPiskel(piskel);
|
2012-09-16 14:59:19 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
ns.LocalStorageService.prototype.cleanLocalStorage_ = function() {
|
|
|
|
console.log('[LocalStorage service]: Snapshot removed');
|
|
|
|
delete window.localStorage.snapShot;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
ns.LocalStorageService.prototype.displayRestoreNotification = function() {
|
|
|
|
if(window.localStorage && window.localStorage.snapShot) {
|
2013-07-15 01:04:42 +04:00
|
|
|
var reloadLink = "<a href='#' class='localstorage-restore onclick='pskl.app.restoreFromLocalStorage()'>reload</a>";
|
|
|
|
var discardLink = "<a href='#' class='localstorage-discard' onclick='pskl.app.cleanLocalStorage()'>discard</a>";
|
2012-09-16 14:59:19 +04:00
|
|
|
var content = "Non saved version found. " + reloadLink + " or " + discardLink;
|
|
|
|
|
|
|
|
$.publish(Events.SHOW_NOTIFICATION, [{
|
|
|
|
"content": content,
|
|
|
|
"behavior": $.proxy(function(rootNode) {
|
|
|
|
rootNode = $(rootNode);
|
|
|
|
rootNode.click($.proxy(function(evt) {
|
|
|
|
var target = $(evt.target);
|
|
|
|
if(target.hasClass("localstorage-restore")) {
|
|
|
|
this.restoreFromLocalStorage_();
|
|
|
|
}
|
|
|
|
else if (target.hasClass("localstorage-discard")) {
|
|
|
|
this.cleanLocalStorage_();
|
|
|
|
}
|
|
|
|
$.publish(Events.HIDE_NOTIFICATION);
|
|
|
|
}, this));
|
|
|
|
}, this)
|
|
|
|
}]);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
})();
|