* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/. */
-// Get the best-available indexedDB object.
+// Get the best-available objects for indexedDB and requestAnimationFrame.
window.indexedDB = window.indexedDB || window.webkitIndexedDB || window.mozIndexedDB || window.msIndexedDB;
-var mainDB;
+window.requestAnimationFrame = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame;
+var mainDB;
+var gAppInitDone = false;
var gUIHideCountdown = 0;
var gWaitCounter = 0;
var gAction, gActionLabel;
mSel.add(opt, null);
}
- var areas = document.getElementsByClassName('overlayArea');
+ var areas = document.getElementsByClassName("overlayArea");
for (var i = 0; i <= areas.length - 1; i++) {
areas[i].addEventListener("mouseup", uiEvHandler, false);
areas[i].addEventListener("mousemove", uiEvHandler, false);
gAction.removeEventListener(aEvent.type, postInit, false);
console.log("init done, draw map.");
gMapPrefsLoaded = true;
- resizeAndDraw();
+ gAppInitDone = true;
+ //gMap.resizeAndDraw(); <-- HACK: This triggers bug 1001853, work around with a delay.
+ window.setTimeout(gMap.resizeAndDraw, 100);
gActionLabel.textContent = "";
gAction.style.display = "none";
setTracking(document.getElementById("trackCheckbox"));
}
window.onresize = function() {
- resizeAndDraw();
+ gMap.resizeAndDraw();
}
function initDB(aEvent) {
function maybeHideUI() {
gUIHideCountdown--;
+ if (document.getElementById("trackArea").style.display == "block") {
+ // If track area is visible, update track data.
+ document.getElementById("trackLength").textContent = calcTrackLength().toFixed(1);
+ document.getElementById("trackDuration").textContent = Math.round(calcTrackDuration()/60);
+ }
if (gUIHideCountdown <= 0) {
var areas = document.getElementsByClassName('overlayArea');
for (var i = 0; i <= areas.length - 1; i++) {
dia.classList.remove("hidden");
}
+function showGLWarningDialog() {
+ var dia = document.getElementById("dialogArea");
+ var areas = dia.children;
+ for (var i = 0; i <= areas.length - 1; i++) {
+ areas[i].style.display = "none";
+ }
+ document.getElementById("noGLwarning").style.display = "block";
+ dia.classList.remove("hidden");
+}
+
function cancelDialog() {
document.getElementById("dialogArea").classList.add("hidden");
document.getElementById("uploadTrackButton").disabled = false;
function makeISOString(aTimestamp) {
// ISO time format is YYYY-MM-DDTHH:mm:ssZ
var tsDate = new Date(aTimestamp);
+ // Note that .getUTCMonth() returns a number between 0 and 11 (0 for January)!
return tsDate.getUTCFullYear() + "-" +
- (tsDate.getUTCMonth() < 10 ? "0" : "") + tsDate.getUTCMonth() + "-" +
+ (tsDate.getUTCMonth() < 9 ? "0" : "") + (tsDate.getUTCMonth() + 1 ) + "-" +
(tsDate.getUTCDate() < 10 ? "0" : "") + tsDate.getUTCDate() + "T" +
(tsDate.getUTCHours() < 10 ? "0" : "") + tsDate.getUTCHours() + ":" +
(tsDate.getUTCMinutes() < 10 ? "0" : "") + tsDate.getUTCMinutes() + ":" +
document.getElementById("uploadStatusCloseButton").disabled = true;
document.getElementById("uploadInProgress").style.display = "block";
document.getElementById("uploadSuccess").style.display = "none";
- document.getElementById("uploadErrorMsg").textContent = "";
+ document.getElementById("uploadFailed").style.display = "none";
document.getElementById("uploadError").style.display = "none";
+ document.getElementById("uploadErrorMsg").textContent = "";
// Now show the status area.
document.getElementById("uploadStatus").style.display = "block";
// then ask for credentials, and then send again.
var hXHR = new XMLHttpRequest();
hXHR.onreadystatechange = function() {
- if (hXHR.readyState == 4 && (XHR.status == 200 || hXHR.status == 400)) {
+ if (hXHR.readyState == 4 && (hXHR.status == 200 || hXHR.status == 400)) {
// 400 is Bad Request, but that's expected as this was empty.
// So far so good, init actual upload.
var XHR = new XMLHttpRequest();