aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authormrmr19932017-02-08 17:42:25 +0000
committermrmr19932017-04-16 15:24:15 +0100
commit905fc2d147d1bc656c9e9fec74cda364a686d638 (patch)
tree38159a4a20eb0e1da45595d1d0090eceee3f78ba /lib
parentf4f017b8fd496b1b4ccd79504ca76cc144cc233e (diff)
downloadvimium-905fc2d147d1bc656c9e9fec74cda364a686d638.tar.bz2
Fallback to storage.local if storage.sync is not available
Diffstat (limited to 'lib')
-rw-r--r--lib/settings.coffee10
1 files changed, 6 insertions, 4 deletions
diff --git a/lib/settings.coffee b/lib/settings.coffee
index e16261d0..65e097ea 100644
--- a/lib/settings.coffee
+++ b/lib/settings.coffee
@@ -10,9 +10,11 @@
#
# In all cases except Settings.defaults, values are stored as jsonified strings.
+storageArea = if chrome.storage.sync? then "sync" else "local"
+
Settings =
debug: false
- storage: chrome.storage.sync
+ storage: chrome.storage[storageArea]
cache: {}
isLoaded: false
onLoadedCallbacks: []
@@ -32,7 +34,7 @@ Settings =
@handleUpdateFromChromeStorage key, value for own key, value of extend localItems, syncedItems
chrome.storage.onChanged.addListener (changes, area) =>
- @propagateChangesFromChromeStorage changes if area == "sync"
+ @propagateChangesFromChromeStorage changes if area == storageArea
@runOnLoadedCallbacks()
@@ -71,7 +73,7 @@ Settings =
if @shouldSyncKey key
if shouldSetInSyncedStorage
setting = {}; setting[key] = @cache[key]
- @log " chrome.storage.sync.set(#{key})"
+ @log " chrome.storage.#{storageArea}.set(#{key})"
@storage.set setting
if Utils.isBackgroundPage()
# Remove options installed by the "copyNonDefaultsToChromeStorage-20150717" migration; see below.
@@ -98,7 +100,7 @@ Settings =
nuke: (key) ->
delete localStorage[key]
chrome.storage.local.remove key
- chrome.storage.sync.remove key
+ chrome.storage.sync?.remove key
# For development only.
log: (args...) ->