|
1 | | -define(["sugar-web/graphics/palette","sugar-web/env","webL10n"], function (palette,env,l10n) { |
| 1 | +define(["sugar-web/graphics/palette","sugar-web/env","webL10n","sugar-web/datastore"], function (palette,env,l10n,datastore) { |
2 | 2 |
|
3 | 3 | var canvas = document.getElementById("canvas"); |
4 | 4 | var ctx = canvas.getContext('2d'); |
@@ -42,54 +42,49 @@ define(["sugar-web/graphics/palette","sugar-web/env","webL10n"], function (palet |
42 | 42 |
|
43 | 43 | function init(){ |
44 | 44 | speech = Speech(); |
45 | | - getSettings(function(settings) { |
46 | | - sugarSettings = settings; |
47 | | - speech.init(sugarSettings); |
48 | | - // If not IE, setup mouse for capture |
49 | | - if (!IE){ |
50 | | - document.captureEvents(Event.MOUSEMOVE) |
51 | | - } |
52 | | - var FPS = 30; |
53 | | - setInterval(function() { |
54 | | - updateCanvas(); |
55 | | - }, 1000/FPS); |
56 | | - window.addEventListener('localized', function() { |
57 | | - if (first) { |
58 | | - l10n.language.code = sugarSettings.language; |
59 | | - first = false; |
60 | | - return; |
61 | | - } else { |
62 | | - localize(); |
63 | | - var timer = window.setTimeout(function() { |
64 | | - window.clearTimeout(timer); |
65 | | - var language = document.getElementById('speaklang').innerHTML; |
66 | | - var text = l10n.get("TypeSomething", {name:sugarSettings.name}); |
67 | | - speech.playVoice(language, text); |
68 | | - moveMouth(text); |
69 | | - }, 100); |
| 45 | + datastore.localStorage.load(function() { |
| 46 | + getSettings(function(settings) { |
| 47 | + sugarSettings = settings; |
| 48 | + speech.init(sugarSettings); |
| 49 | + // If not IE, setup mouse for capture |
| 50 | + if (!IE){ |
| 51 | + document.captureEvents(Event.MOUSEMOVE) |
70 | 52 | } |
| 53 | + var FPS = 30; |
| 54 | + setInterval(function() { |
| 55 | + updateCanvas(); |
| 56 | + }, 1000/FPS); |
| 57 | + window.addEventListener('localized', function() { |
| 58 | + if (first) { |
| 59 | + l10n.language.code = sugarSettings.language; |
| 60 | + first = false; |
| 61 | + return; |
| 62 | + } else { |
| 63 | + localize(); |
| 64 | + var timer = window.setTimeout(function() { |
| 65 | + window.clearTimeout(timer); |
| 66 | + var language = document.getElementById('speaklang').innerHTML; |
| 67 | + var text = l10n.get("TypeSomething", {name:sugarSettings.name}); |
| 68 | + speech.playVoice(language, text); |
| 69 | + moveMouth(text); |
| 70 | + }, 100); |
| 71 | + } |
| 72 | + }); |
71 | 73 | }); |
72 | 74 | }); |
73 | 75 | } |
74 | 76 |
|
75 | 77 | function getSettings(callback) { |
76 | 78 | var defaultSettings = { |
77 | 79 | name: "", |
78 | | - language: navigator.language |
| 80 | + language: (typeof chrome != 'undefined' && chrome.app && chrome.app.runtime) ? chrome.i18n.getUILanguage() : navigator.language |
79 | 81 | }; |
80 | 82 | if (!env.isSugarizer()) { |
81 | 83 | callback(defaultSettings); |
82 | 84 | return; |
83 | 85 | } |
84 | | - if (typeof chrome != 'undefined' && chrome.app && chrome.app.runtime) { |
85 | | - var loadedSettings = JSON.parse(values.sugar_settings); |
86 | | - chrome.storage.local.get('sugar_settings', function(values) { |
87 | | - callback(loadedSettings); |
88 | | - }); |
89 | | - } else { |
90 | | - var loadedSettings = JSON.parse(localStorage.sugar_settings); |
91 | | - callback(loadedSettings); |
92 | | - } |
| 86 | + var loadedSettings = datastore.localStorage.getValue('sugar_settings'); |
| 87 | + callback(loadedSettings); |
93 | 88 | } |
94 | 89 |
|
95 | 90 | function hidePalettes(){ |
|
0 commit comments