Bug 796584 - Don't use localStorage in pdf.js

This commit is contained in:
Tim Taubert 2012-10-03 01:16:42 +02:00
parent 338373a841
commit 5bab0c354a
2 changed files with 63 additions and 43 deletions

View File

@ -2,6 +2,7 @@
<link rel="resource" type="application/l10n" href="locale.properties"/> <link rel="resource" type="application/l10n" href="locale.properties"/>
<script type="text/javascript" src="l10n.js"></script> <script type="text/javascript" src="l10n.js"></script>
<script type="text/javascript" src="../build/pdf.js"></script> <script type="text/javascript" src="../build/pdf.js"></script>
<script type="text/javascript" src="/shared/js/async_storage.js"></script>
<script type="text/javascript"> <script type="text/javascript">
// This specifies the location of the pdf.js file. // This specifies the location of the pdf.js file.
PDFJS.workerSrc = "../build/pdf.js"; PDFJS.workerSrc = "../build/pdf.js";

View File

@ -135,6 +135,7 @@ var ProgressBar = (function ProgressBarClosure() {
// Settings Manager - This is a utility for saving settings // Settings Manager - This is a utility for saving settings
// First we see if localStorage is available // First we see if localStorage is available
// If not, we use FUEL in FF // If not, we use FUEL in FF
// Use asyncStorage for B2G
var Settings = (function SettingsClosure() { var Settings = (function SettingsClosure() {
var isLocalStorageEnabled = (function localStorageEnabledTest() { var isLocalStorageEnabled = (function localStorageEnabledTest() {
// Feature test as per http://diveintohtml5.info/storage.html // Feature test as per http://diveintohtml5.info/storage.html
@ -149,39 +150,52 @@ var Settings = (function SettingsClosure() {
})(); })();
function Settings(fingerprint) { function Settings(fingerprint) {
var database = null; this.fingerprint = fingerprint;
var index; this.initializedPromise = new PDFJS.Promise();
//#if !(FIREFOX || MOZCENTRAL)
if (isLocalStorageEnabled) var resolvePromise = (function settingsResolvePromise(db) {
database = localStorage.getItem('database') || '{}'; this.initialize(db || '{}');
else this.initializedPromise.resolve();
return; }).bind(this);
//#else
// database = FirefoxCom.requestSync('getDatabase', null) || '{}'; //#if B2G
// asyncStorage.getItem('database', resolvePromise);
//#endif //#endif
//#if FIREFOX || MOZCENTRAL
// resolvePromise(FirefoxCom.requestSync('getDatabase', null));
//#endif
//#if !(FIREFOX || MOZCENTRAL || B2G)
if (isLocalStorageEnabled)
resolvePromise(localStorage.getItem('database'));
//#endif
}
Settings.prototype = {
initialize: function settingsInitialize(database) {
database = JSON.parse(database); database = JSON.parse(database);
if (!('files' in database)) if (!('files' in database))
database.files = []; database.files = [];
if (database.files.length >= kSettingsMemory) if (database.files.length >= kSettingsMemory)
database.files.shift(); database.files.shift();
var index;
for (var i = 0, length = database.files.length; i < length; i++) { for (var i = 0, length = database.files.length; i < length; i++) {
var branch = database.files[i]; var branch = database.files[i];
if (branch.fingerprint == fingerprint) { if (branch.fingerprint == this.fingerprint) {
index = i; index = i;
break; break;
} }
} }
if (typeof index != 'number') if (typeof index != 'number')
index = database.files.push({fingerprint: fingerprint}) - 1; index = database.files.push({fingerprint: this.fingerprint}) - 1;
this.file = database.files[index]; this.file = database.files[index];
this.database = database; this.database = database;
} },
Settings.prototype = {
set: function settingsSet(name, val) { set: function settingsSet(name, val) {
if (!('file' in this)) if (!this.initializedPromise.isResolved)
return false; return;
var file = this.file; var file = this.file;
file[name] = val; file[name] = val;
@ -195,7 +209,7 @@ var Settings = (function SettingsClosure() {
}, },
get: function settingsGet(name, defaultValue) { get: function settingsGet(name, defaultValue) {
if (!('file' in this)) if (!this.initializedPromise.isResolved)
return defaultValue; return defaultValue;
return this.file[name] || defaultValue; return this.file[name] || defaultValue;
@ -697,20 +711,12 @@ var PDFView = {
var pagesCount = pdfDocument.numPages; var pagesCount = pdfDocument.numPages;
var id = pdfDocument.fingerprint; var id = pdfDocument.fingerprint;
var storedHash = null;
document.getElementById('numPages').textContent = document.getElementById('numPages').textContent =
mozL10n.get('page_of', {pageCount: pagesCount}, 'of {{pageCount}}'); mozL10n.get('page_of', {pageCount: pagesCount}, 'of {{pageCount}}');
document.getElementById('pageNumber').max = pagesCount; document.getElementById('pageNumber').max = pagesCount;
PDFView.documentFingerprint = id; PDFView.documentFingerprint = id;
var store = PDFView.store = new Settings(id); var store = PDFView.store = new Settings(id);
if (store.get('exists', false)) { var storePromise = store.initializedPromise;
var page = store.get('page', '1');
var zoom = store.get('zoom', PDFView.currentScale);
var left = store.get('scrollLeft', '0');
var top = store.get('scrollTop', '0');
storedHash = 'page=' + page + '&zoom=' + zoom + ',' + left + ',' + top;
}
this.pageRotation = 0; this.pageRotation = 0;
@ -747,11 +753,22 @@ var PDFView = {
}); });
// outline and initial view depends on destinations and pagesRefMap // outline and initial view depends on destinations and pagesRefMap
PDFJS.Promise.all([pagesPromise, destinationsPromise]).then(function() { var promises = [pagesPromise, destinationsPromise, storePromise];
PDFJS.Promise.all(promises).then(function() {
pdfDocument.getOutline().then(function(outline) { pdfDocument.getOutline().then(function(outline) {
self.outline = new DocumentOutlineView(outline); self.outline = new DocumentOutlineView(outline);
}); });
var storedHash = null;
if (store.get('exists', false)) {
var page = store.get('page', '1');
var zoom = store.get('zoom', PDFView.currentScale);
var left = store.get('scrollLeft', '0');
var top = store.get('scrollTop', '0');
storedHash = 'page=' + page + '&zoom=' + zoom + ',' + left + ',' + top;
}
self.setInitialView(storedHash, scale); self.setInitialView(storedHash, scale);
}); });
@ -2198,11 +2215,13 @@ function updateViewarea() {
pdfOpenParams += ',' + Math.round(topLeft[0]) + ',' + Math.round(topLeft[1]); pdfOpenParams += ',' + Math.round(topLeft[0]) + ',' + Math.round(topLeft[1]);
var store = PDFView.store; var store = PDFView.store;
store.initializedPromise.then(function() {
store.set('exists', true); store.set('exists', true);
store.set('page', pageNumber); store.set('page', pageNumber);
store.set('zoom', normalizedScaleValue); store.set('zoom', normalizedScaleValue);
store.set('scrollLeft', Math.round(topLeft[0])); store.set('scrollLeft', Math.round(topLeft[0]));
store.set('scrollTop', Math.round(topLeft[1])); store.set('scrollTop', Math.round(topLeft[1]));
});
var href = PDFView.getAnchorUrl(pdfOpenParams); var href = PDFView.getAnchorUrl(pdfOpenParams);
document.getElementById('viewBookmark').href = href; document.getElementById('viewBookmark').href = href;
} }