Carsten Sandtner (@casarock) 2014 - code.talks 14
                Carsten Sandtner
                Head of Development at //mediaman GmbH
                Mozilla representative
                
                Javascript enthusiast and web developer since 1998.
            
 
         
                Microsoft vs. Netscape!
Everyone invented new and "better" features!
support other features? Hell, NO!
 
                
             
                
            Implemented pretty good browser detection
Browser Vendors wanted to be "supported"
Mosaic/0.9                                     // grandmother of all!
Mozilla/2.02 [fr] (WinNT; I)                   // Netscapes first!
Mozilla/4.0 (compatible; MSIE 4.0; Windows 98) // IE4!
                
                Funny? There is more...
Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.11) Gecko/20071127 Firefox/2.0.0.11  // Firefox!
Mozilla/5.0 (compatible; Konqueror/Version; OS-or-CPU) KHTML/KHTMLVersion (like Gecko)        // Konqueror
Mozilla/5.0 (Macintosh; U; PPC Mac OS X; en) AppleWebKit/124 (KHTML, like Gecko) Safari/125.1 // Safari!
                
                And Chrome?
Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US) AppleWebKit/525.13 (KHTML, like Gecko) Chrome/0.2.149.29 Safari/525.13
                
                But Opera?
Opera/8.0 (Windows NT 5.1; U; en)
                
                <9 ... >9 has...
Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; en) Opera 9.50
Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/28.0.1500.95 Safari/537.36 OPR/15.0.1147.153
                
                *sigh*
 
                and Internet Explorer won the first browser war
 
            
         
                The rise of the others
Other browser vendors raised
They keep standards in mind and develop them together
There is not only one "tool" for the internet
Still exisits, but:
Standardized
Add ons, technical features, developer tools etc..
Developers are being targeted.
“Make the Internet a better place”
 
            eh? no.
 
            We want ...
We got it!
But: Lessons learned from the past
Standards!
Vendors work together
“The web is everywhere”
“The web in your hands”
 
                
            Firefox OS is open source and with standards in mind
Mozilla introduced new APIs for mobile devices
Consistent use of APIs
more features, more fun!
tell me more
“WebAPI is a term used to refer to a suite of device compatibility and access APIs that allow Web apps and content to access device hardware (such as battery status or the device vibration hardware), as well as access to data stored on the device (such as the calendar or contacts list).
By adding these APIs, we hope to expand what the Web can do today and only proprietary platforms were able to do in the past.”
Some WebAPIs are not (yet) a standard
I've marked them with a *
Web APIs could be categorized
 
            Information about the system's connection
var connection = navigator.connection ||
                 navigator.mozConnection ||
                 navigator.webkitConnection;
var type = connection.type;
function updateConnectionStatus() {
  console.log("Connection type is change from " + type + " to " + connection.type);
  type = connection.type;
}
connection.addEventListener('typechange', updateConnectionStatus);
                Firefox 12+, Firefox Mobile, Firefox OS, Android 2.2+
“IndexedDB is an API for client-side storage of significant amounts of structured data and for high performance searches on this data using indexes. ”
NoSQL DB for Browsers...
Deserves an own talk... too complex for this one...
Supported by: Every major Browser on Desktop and every major mobile browser ...
... excepted: Safari on iOS < 8
// At first, let's check if we have permission for notification
// If not, let's ask for it
if (Notification && Notification.permission !== "granted") {
    Notification.requestPermission(function (status) {
          if (Notification.permission !== status) {
                Notification.permission = status;
          }
});
}
if (Notification && Notification.permission === "granted") {
    var n = new Notification("Hi!");
}
                
                    Desktop: Chrome 5+, Firefox 4+, Opera 25, Safari 6+
                    Mobile: Firefox Mobile 4+, Firefox OS
                
Get current ambient light intensity
window.ondevicelight = function (event) {
    // Read out the lux value
    console.log(event.value);
};
                Current lux: 0
Desktop: Firefox 22+
                Mobile: Firefox Mobile
Information about the system's battery charge level and lets you be notified by events that are sent when the battery level changes
var battery = navigator.battery ||
              navigator.mozBattery ||
              navigator.webkitBattery,
    info = {
        charging: battery.charging,
        chargingTime: parseInt(battery.chargingTime / 60, 10),
        dischargingTime: parseInt(battery.dischargingTime / 60, 10),
        level: Math.round(battery.level * 100)
    };
function updateBatteryStatus() {
    batterylevel.innerHTML = battery.level * 100 + " %";
    batterystatus.innerHTML = battery.charging ? "" : "not";
}
battery.addEventListener("chargingchange", updateBatteryStatus);
battery.addEventListener("levelchange", updateBatteryStatus);
                Battery: Level is and it's charging.
Desktop: Firefox 10+ Mobile: Firefox Mobile 10+
The proximity events are a handy way to know when a user is close to a device
window.addEventListener('userproximity', function(event) {
    if (event.near) {
        console.log('Phone probably on users ear...');
    } else {
        console.log('phone in your hand...');
    }
});
                Detection orientation and motion events
window.addEventListener("deviceorientation", handleOrientation, true);
function handleOrientation(event) {
    var alpha    = event.alpha; // Z-Axis
    var beta     = event.beta; // Y-Axis
    var gamma    = event.gamma; // X-Axis
    // Do stuff with the new orientation data
}
                
window.addEventListener("devicemotion", handleMotion, true);
function handleMotion(event) {
    var x = event.accelerationIncludingGravity.x;
    var y = event.accelerationIncludingGravity.y;
    var z = event.accelerationIncludingGravity.z;
    var r = event.rotationRate;
}
                Information about the speed of changes for the device's position and orientation.
Desktop: Chrome 7+, 3.6+
                Mobile: Android 3.0, Firefox Mobile 3.6+, Safari Mobile 4.2+
Rumble in your pocket!
var pattern = [200, 100, 200, 200, 100],
goodVibration = navigator.vibrate(pattern);
                Mobile: Android, Firefox Mobile 11+
Listening orientation change
screen.addEventListener("orientationchange", function () {
  console.log("The orientation of the screen is: " + screen.orientation);
});
                Preventing orientation change
screen.lockOrientation('landscape');
                Support is complex: This API is experimental and currently available on Firefox OS and Firefox for Android with a moz prefix, and for Internet Explorer on Windows 8.1 and above with a ms prefix.
Request pointer lock on an element
canvas.requestPointerLock = canvas.requestPointerLock ||
                            canvas.mozRequestPointerLock ||
                            canvas.webkitRequestPointerLock;
canvas.requestPointerLock();
                Listen for changes
document.addEventListener('pointerlockchange', lockChangeAlert, false);
document.addEventListener('mozpointerlockchange', lockChangeAlert, false);
document.addEventListener('webkitpointerlockchange', lockChangeAlert, false);
                Exit pointer lock
document.exitPointerLock = document.exitPointerLock    ||
                           document.mozExitPointerLock ||
                           document.webkitExitPointerLock;
// Attempt to unlock
document.exitPointerLock();
                Desktop: Chrome, Firefox
The Page Visibility API lets you know when a webpage is visible or in focus
if (document.hidden) {
    // stop video etc.
}
                
document.addEventListener("visibilitychange", handleVisibilityChange, false);
function handleVisibilityChange() {
    if (document.hidden) {
        // stop something. e.g. stop a video, audio etc...
    } else {
        // do something else ;) play video, audio... you got it?
    }
}
                Currently prefixed (moz, webkit, ms)
Desktop: Chrome, Firefox 30+, Safari 7+, Opera 24+, IE10+
                    Mobile: Chrome Android, Android 4.4+, Firefox Mobile, Firefox OS
 
            ... but these examples are just....
... examples
Some live examples...
... some real world examples
Warns when cellular connection detected and video should be played
 
            Paying via carrier billing - Cellular detected
 
            When WIFI is detected
 
                Confirmation code via SMS
 
            NOW! Some live examples...
                Carsten Sandtner
                @casarock
                Slides & Examples: casarock.github.io