2013-11-19 07:51:06 +09:00
|
|
|
/* Copyright 2013 Mozilla Foundation
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2014-04-04 03:23:18 +09:00
|
|
|
/* globals DEFAULT_PREFERENCES, Promise */
|
2013-11-19 07:51:06 +09:00
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
//#include default_preferences.js
|
|
|
|
|
2014-04-28 23:07:53 +09:00
|
|
|
var SidebarView = {
|
|
|
|
NONE: 0,
|
|
|
|
THUMBS: 1,
|
|
|
|
OUTLINE: 2,
|
|
|
|
ATTACHMENTS: 3
|
|
|
|
};
|
|
|
|
|
2014-03-17 06:33:39 +09:00
|
|
|
/**
|
|
|
|
* Preferences - Utility for storing persistent settings.
|
|
|
|
* Used for settings that should be applied to all opened documents,
|
|
|
|
* or every time the viewer is loaded.
|
|
|
|
*/
|
|
|
|
var Preferences = {
|
|
|
|
prefs: Object.create(DEFAULT_PREFERENCES),
|
|
|
|
isInitializedPromiseResolved: false,
|
|
|
|
initializedPromise: null,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize and fetch the current preference values from storage.
|
|
|
|
* @return {Promise} A promise that is resolved when the preferences
|
|
|
|
* have been initialized.
|
|
|
|
*/
|
|
|
|
initialize: function preferencesInitialize() {
|
|
|
|
return this.initializedPromise =
|
|
|
|
this._readFromStorage(DEFAULT_PREFERENCES).then(function(prefObj) {
|
|
|
|
this.isInitializedPromiseResolved = true;
|
|
|
|
if (prefObj) {
|
|
|
|
this.prefs = prefObj;
|
|
|
|
}
|
|
|
|
}.bind(this));
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stub function for writing preferences to storage.
|
|
|
|
* NOTE: This should be overridden by a build-specific function defined below.
|
|
|
|
* @param {Object} prefObj The preferences that should be written to storage.
|
|
|
|
* @return {Promise} A promise that is resolved when the preference values
|
|
|
|
* have been written.
|
|
|
|
*/
|
|
|
|
_writeToStorage: function preferences_writeToStorage(prefObj) {
|
|
|
|
return Promise.resolve();
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stub function for reading preferences from storage.
|
|
|
|
* NOTE: This should be overridden by a build-specific function defined below.
|
|
|
|
* @param {Object} prefObj The preferences that should be read from storage.
|
|
|
|
* @return {Promise} A promise that is resolved with an {Object} containing
|
|
|
|
* the preferences that have been read.
|
|
|
|
*/
|
|
|
|
_readFromStorage: function preferences_readFromStorage(prefObj) {
|
|
|
|
return Promise.resolve();
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reset the preferences to their default values and update storage.
|
|
|
|
* @return {Promise} A promise that is resolved when the preference values
|
|
|
|
* have been reset.
|
|
|
|
*/
|
|
|
|
reset: function preferencesReset() {
|
|
|
|
return this.initializedPromise.then(function() {
|
|
|
|
this.prefs = Object.create(DEFAULT_PREFERENCES);
|
|
|
|
return this._writeToStorage(DEFAULT_PREFERENCES);
|
|
|
|
}.bind(this));
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Replace the current preference values with the ones from storage.
|
|
|
|
* @return {Promise} A promise that is resolved when the preference values
|
|
|
|
* have been updated.
|
|
|
|
*/
|
|
|
|
reload: function preferencesReload() {
|
|
|
|
return this.initializedPromise.then(function () {
|
|
|
|
this._readFromStorage(DEFAULT_PREFERENCES).then(function(prefObj) {
|
2014-01-31 02:09:31 +09:00
|
|
|
if (prefObj) {
|
|
|
|
this.prefs = prefObj;
|
|
|
|
}
|
|
|
|
}.bind(this));
|
2014-03-17 06:33:39 +09:00
|
|
|
}.bind(this));
|
|
|
|
},
|
2013-11-19 07:51:06 +09:00
|
|
|
|
2014-03-17 06:33:39 +09:00
|
|
|
/**
|
|
|
|
* Set the value of a preference.
|
|
|
|
* @param {string} name The name of the preference that should be changed.
|
|
|
|
* @param {boolean|number|string} value The new value of the preference.
|
|
|
|
* @return {Promise} A promise that is resolved when the value has been set,
|
|
|
|
* provided that the preference exists and the types match.
|
|
|
|
*/
|
|
|
|
set: function preferencesSet(name, value) {
|
|
|
|
return this.initializedPromise.then(function () {
|
|
|
|
if (DEFAULT_PREFERENCES[name] === undefined) {
|
|
|
|
throw new Error('preferencesSet: \'' + name + '\' is undefined.');
|
2013-11-19 07:51:06 +09:00
|
|
|
} else if (value === undefined) {
|
2014-03-17 06:33:39 +09:00
|
|
|
throw new Error('preferencesSet: no value is specified.');
|
2013-11-19 07:51:06 +09:00
|
|
|
}
|
|
|
|
var valueType = typeof value;
|
|
|
|
var defaultType = typeof DEFAULT_PREFERENCES[name];
|
|
|
|
|
|
|
|
if (valueType !== defaultType) {
|
|
|
|
if (valueType === 'number' && defaultType === 'string') {
|
|
|
|
value = value.toString();
|
|
|
|
} else {
|
2014-03-17 06:33:39 +09:00
|
|
|
throw new Error('Preferences_set: \'' + value + '\' is a \"' +
|
|
|
|
valueType + '\", expected \"' + defaultType + '\".');
|
2013-11-19 07:51:06 +09:00
|
|
|
}
|
2014-01-31 02:09:31 +09:00
|
|
|
} else {
|
|
|
|
if (valueType === 'number' && (value | 0) !== value) {
|
2014-03-17 06:33:39 +09:00
|
|
|
throw new Error('Preferences_set: \'' + value +
|
|
|
|
'\' must be an \"integer\".');
|
2014-01-31 02:09:31 +09:00
|
|
|
}
|
2013-11-19 07:51:06 +09:00
|
|
|
}
|
|
|
|
this.prefs[name] = value;
|
2014-03-17 06:33:39 +09:00
|
|
|
return this._writeToStorage(this.prefs);
|
|
|
|
}.bind(this));
|
|
|
|
},
|
2013-11-19 07:51:06 +09:00
|
|
|
|
2014-03-17 06:33:39 +09:00
|
|
|
/**
|
|
|
|
* Get the value of a preference.
|
|
|
|
* @param {string} name The name of the preference whose value is requested.
|
|
|
|
* @return {Promise} A promise that is resolved with a {boolean|number|string}
|
|
|
|
* containing the value of the preference.
|
|
|
|
*/
|
|
|
|
get: function preferencesGet(name) {
|
|
|
|
return this.initializedPromise.then(function () {
|
|
|
|
var defaultValue = DEFAULT_PREFERENCES[name];
|
2013-11-19 07:51:06 +09:00
|
|
|
|
2014-03-17 06:33:39 +09:00
|
|
|
if (defaultValue === undefined) {
|
|
|
|
throw new Error('preferencesGet: \'' + name + '\' is undefined.');
|
|
|
|
} else {
|
|
|
|
var prefValue = this.prefs[name];
|
2013-11-19 07:51:06 +09:00
|
|
|
|
2014-03-17 06:33:39 +09:00
|
|
|
if (prefValue !== undefined) {
|
|
|
|
return prefValue;
|
2013-11-19 07:51:06 +09:00
|
|
|
}
|
|
|
|
}
|
2014-03-17 06:33:39 +09:00
|
|
|
return defaultValue;
|
|
|
|
}.bind(this));
|
|
|
|
}
|
|
|
|
};
|
2013-11-19 07:51:06 +09:00
|
|
|
|
2014-07-25 06:19:17 +09:00
|
|
|
//#if CHROME
|
|
|
|
//Preferences._writeToStorage = function (prefObj) {
|
|
|
|
// return new Promise(function (resolve) {
|
|
|
|
// if (prefObj == DEFAULT_PREFERENCES) {
|
|
|
|
// var keysToRemove = Object.keys(DEFAULT_PREFERENCES);
|
|
|
|
// // If the storage is reset, remove the keys so that the values from
|
|
|
|
// // managed storage are applied again.
|
|
|
|
// chrome.storage.local.remove(keysToRemove, function() {
|
|
|
|
// resolve();
|
|
|
|
// });
|
|
|
|
// } else {
|
|
|
|
// chrome.storage.local.set(prefObj, function() {
|
|
|
|
// resolve();
|
|
|
|
// });
|
|
|
|
// }
|
|
|
|
// });
|
|
|
|
//};
|
|
|
|
//
|
|
|
|
//Preferences._readFromStorage = function (prefObj) {
|
|
|
|
// return new Promise(function (resolve) {
|
|
|
|
// if (chrome.storage.managed) {
|
|
|
|
// // Get preferences as set by the system administrator.
|
|
|
|
// // See extensions/chromium/preferences_schema.json for more information.
|
|
|
|
// // These preferences can be overridden by the user.
|
|
|
|
// chrome.storage.managed.get(DEFAULT_PREFERENCES, getPreferences);
|
|
|
|
// } else {
|
2014-09-06 07:37:30 +09:00
|
|
|
// // Managed storage not supported, e.g. in old Chromium versions.
|
2014-07-25 06:19:17 +09:00
|
|
|
// getPreferences(DEFAULT_PREFERENCES);
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// function getPreferences(defaultPrefs) {
|
2014-09-06 07:37:30 +09:00
|
|
|
// if (chrome.runtime.lastError) {
|
|
|
|
// // Managed storage not supported, e.g. in Opera.
|
|
|
|
// defaultPrefs = DEFAULT_PREFERENCES;
|
|
|
|
// }
|
2014-07-25 06:19:17 +09:00
|
|
|
// chrome.storage.local.get(defaultPrefs, function(readPrefs) {
|
|
|
|
// resolve(readPrefs);
|
|
|
|
// });
|
|
|
|
// }
|
|
|
|
// });
|
|
|
|
//};
|
|
|
|
//#endif
|
|
|
|
|
2015-06-20 00:53:03 +09:00
|
|
|
//#if !(FIREFOX || MOZCENTRAL || CHROME)
|
2014-03-17 06:33:39 +09:00
|
|
|
Preferences._writeToStorage = function (prefObj) {
|
|
|
|
return new Promise(function (resolve) {
|
2014-04-04 03:23:18 +09:00
|
|
|
localStorage.setItem('pdfjs.preferences', JSON.stringify(prefObj));
|
2014-03-17 06:33:39 +09:00
|
|
|
resolve();
|
|
|
|
});
|
2013-11-19 07:51:06 +09:00
|
|
|
};
|
|
|
|
|
2014-03-17 06:33:39 +09:00
|
|
|
Preferences._readFromStorage = function (prefObj) {
|
|
|
|
return new Promise(function (resolve) {
|
2014-04-04 03:23:18 +09:00
|
|
|
var readPrefs = JSON.parse(localStorage.getItem('pdfjs.preferences'));
|
2014-03-17 06:33:39 +09:00
|
|
|
resolve(readPrefs);
|
2014-01-04 09:17:05 +09:00
|
|
|
});
|
2013-11-19 07:51:06 +09:00
|
|
|
};
|
|
|
|
//#endif
|