Skip to content

Instantly share code, notes, and snippets.

@Fil
Created July 30, 2018 14:28
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save Fil/83f6cec7a8a6b3d3c85dbf55be80773b to your computer and use it in GitHub Desktop.
Save Fil/83f6cec7a8a6b3d3c85dbf55be80773b to your computer and use it in GitHub Desktop.
fullscreen.js, no dependency
var fullscreenEnabled = !document.location.hash.match(/^#nofullscreen/);
if (fullscreenEnabled) {
setTimeout(function() {
const button = document.createElement("button");
document.body.appendChild(button);
button.setAttribute("id", "fullscreen");
button.setAttribute("style", "cursor:pointer;");
button.innerHTML = "Fullscreen";
button.addEventListener("click", goFullscreen);
}, 200);
}
function goFullscreen() {
this._exitFired = false;
if (fullScreenApi.supportsFullScreen) {
if (fullScreenApi.isFullScreen(document.body)) {
fullScreenApi.cancelFullScreen(document.body);
} else {
fullScreenApi.requestFullScreen(document.body);
}
setTimeout(redraw, 200);
}
}
/*
Native FullScreen JavaScript API
-------------
Assumes Mozilla naming conventions instead of W3C for now
source : http://johndyer.name/native-fullscreen-javascript-api-plus-jquery-plugin/
*/
(function() {
var fullScreenApi = {
supportsFullScreen: false,
isFullScreen: function() {
return false;
},
requestFullScreen: function() {},
cancelFullScreen: function() {},
fullScreenEventName: "",
prefix: ""
},
browserPrefixes = "webkit moz o ms khtml".split(" ");
// check for native support
if (typeof document.cancelFullScreen != "undefined") {
fullScreenApi.supportsFullScreen = true;
} else {
// check for fullscreen support by vendor prefix
for (var i = 0, il = browserPrefixes.length; i < il; i++) {
fullScreenApi.prefix = browserPrefixes[i];
if (
typeof document[fullScreenApi.prefix + "CancelFullScreen"] !=
"undefined"
) {
fullScreenApi.supportsFullScreen = true;
break;
}
}
}
// update methods to do something useful
if (fullScreenApi.supportsFullScreen) {
fullScreenApi.fullScreenEventName =
fullScreenApi.prefix + "fullscreenchange";
fullScreenApi.isFullScreen = function() {
switch (this.prefix) {
case "":
return document.fullScreen;
case "webkit":
return document.webkitIsFullScreen;
default:
return document[this.prefix + "FullScreen"];
}
};
fullScreenApi.requestFullScreen = function(el) {
return this.prefix === ""
? el.requestFullScreen()
: el[this.prefix + "RequestFullScreen"]();
};
fullScreenApi.cancelFullScreen = function(el) {
return this.prefix === ""
? document.cancelFullScreen()
: document[this.prefix + "CancelFullScreen"]();
};
document.addEventListener(fullScreenApi.fullScreenEventName, function() {
if (fullScreenApi.isFullScreen(document.body)) {
document.getElementById("fullscreen").innerHTML = "&times;";
} else {
document.getElementById("fullscreen").innerHTML = "Fullscreen";
}
});
}
// export api
window.fullScreenApi = fullScreenApi;
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment