From 0c26c33a45923fce536cc4fa12970ecfee1b7baa Mon Sep 17 00:00:00 2001 From: cfoe <cfoe@ispconfig3> Date: Fri, 6 Jul 2012 19:40:00 +0000 Subject: [PATCH] add html5shiv html5 compatibility library --- interface/web/themes/default-v2/CHANGELOG | 3 +- .../web/themes/default-v2/js/html5shiv.js | 220 ++++++++++++++++++ .../themes/default-v2/templates/main.tpl.htm | 8 +- 3 files changed, 223 insertions(+), 8 deletions(-) create mode 100644 interface/web/themes/default-v2/js/html5shiv.js diff --git a/interface/web/themes/default-v2/CHANGELOG b/interface/web/themes/default-v2/CHANGELOG index b9e98bea44..d217e2c5b5 100644 --- a/interface/web/themes/default-v2/CHANGELOG +++ b/interface/web/themes/default-v2/CHANGELOG @@ -17,4 +17,5 @@ source: default $3241 07/06/2012 @ 12:00 UTC+2 - rm css/screen/* - mv css media-recognition from css-files to <head>-link tag - change most div-containers to new html5 tags in main.tpl.htm -- +- rm dom elements from main.tpl.htm +- add html5shiv.js \ No newline at end of file diff --git a/interface/web/themes/default-v2/js/html5shiv.js b/interface/web/themes/default-v2/js/html5shiv.js new file mode 100644 index 0000000000..c2d551258f --- /dev/null +++ b/interface/web/themes/default-v2/js/html5shiv.js @@ -0,0 +1,220 @@ +/*! HTML5 Shiv v3.5 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed */ +;(function(window, document) { + + /** Preset options */ + var options = window.html5 || {}; + + /** Used to skip problem elements */ + var reSkip = /^<|^(?:button|form|map|select|textarea|object|iframe|option|optgroup)$/i; + + /** Not all elements can be cloned in IE (this list can be shortend) **/ + var saveClones = /^<|^(?:a|b|button|code|div|fieldset|form|h1|h2|h3|h4|h5|h6|i|iframe|img|input|label|li|link|ol|option|p|param|q|script|select|span|strong|style|table|tbody|td|textarea|tfoot|th|thead|tr|ul)$/i; + + /** Detect whether the browser supports default html5 styles */ + var supportsHtml5Styles; + + /** Detect whether the browser supports unknown elements */ + var supportsUnknownElements; + + (function() { + var a = document.createElement('a'); + + a.innerHTML = '<xyz></xyz>'; + + //if the hidden property is implemented we can assume, that the browser supports HTML5 Styles | this fails in Chrome 8 + supportsHtml5Styles = ('hidden' in a); + //if we are part of Modernizr, we do an additional test to solve the Chrome 8 fail + if(supportsHtml5Styles && typeof injectElementWithStyles == 'function'){ + injectElementWithStyles('#modernizr{}', function(node){ + node.hidden = true; + supportsHtml5Styles = (window.getComputedStyle ? + getComputedStyle(node, null) : + node.currentStyle).display == 'none'; + }); + } + + supportsUnknownElements = a.childNodes.length == 1 || (function() { + // assign a false positive if unable to shiv + try { + (document.createElement)('a'); + } catch(e) { + return true; + } + var frag = document.createDocumentFragment(); + return ( + typeof frag.cloneNode == 'undefined' || + typeof frag.createDocumentFragment == 'undefined' || + typeof frag.createElement == 'undefined' + ); + }()); + + }()); + + /*--------------------------------------------------------------------------*/ + + /** + * Creates a style sheet with the given CSS text and adds it to the document. + * @private + * @param {Document} ownerDocument The document. + * @param {String} cssText The CSS text. + * @returns {StyleSheet} The style element. + */ + function addStyleSheet(ownerDocument, cssText) { + var p = ownerDocument.createElement('p'), + parent = ownerDocument.getElementsByTagName('head')[0] || ownerDocument.documentElement; + + p.innerHTML = 'x<style>' + cssText + '</style>'; + return parent.insertBefore(p.lastChild, parent.firstChild); + } + + /** + * Returns the value of `html5.elements` as an array. + * @private + * @returns {Array} An array of shived element node names. + */ + function getElements() { + var elements = html5.elements; + return typeof elements == 'string' ? elements.split(' ') : elements; + } + + /** + * Shivs the `createElement` and `createDocumentFragment` methods of the document. + * @private + * @param {Document|DocumentFragment} ownerDocument The document. + */ + function shivMethods(ownerDocument) { + var cache = {}, + docCreateElement = ownerDocument.createElement, + docCreateFragment = ownerDocument.createDocumentFragment, + frag = docCreateFragment(); + + ownerDocument.createElement = function(nodeName) { + //abort shiv + if(!html5.shivMethods){ + return docCreateElement(nodeName); + } + + var node; + + if(cache[nodeName]){ + node = cache[nodeName].cloneNode(); + } else if(saveClones.test(nodeName)){ + node = (cache[nodeName] = docCreateElement(nodeName)).cloneNode(); + } else { + node = docCreateElement(nodeName); + } + + // Avoid adding some elements to fragments in IE < 9 because + // * Attributes like `name` or `type` cannot be set/changed once an element + // is inserted into a document/fragment + // * Link elements with `src` attributes that are inaccessible, as with + // a 403 response, will cause the tab/window to crash + // * Script elements appended to fragments will execute when their `src` + // or `text` property is set + return node.canHaveChildren && !reSkip.test(nodeName) ? frag.appendChild(node) : node; + }; + + ownerDocument.createDocumentFragment = Function('h,f', 'return function(){' + + 'var n=f.cloneNode(),c=n.createElement;' + + 'h.shivMethods&&(' + + // unroll the `createElement` calls + getElements().join().replace(/\w+/g, function(nodeName) { + docCreateElement(nodeName); + frag.createElement(nodeName); + return 'c("' + nodeName + '")'; + }) + + ');return n}' + )(html5, frag); + } + + /*--------------------------------------------------------------------------*/ + + /** + * Shivs the given document. + * @memberOf html5 + * @param {Document} ownerDocument The document to shiv. + * @returns {Document} The shived document. + */ + function shivDocument(ownerDocument) { + var shived; + if (ownerDocument.documentShived) { + return ownerDocument; + } + if (html5.shivCSS && !supportsHtml5Styles) { + shived = !!addStyleSheet(ownerDocument, + // corrects block display not defined in IE6/7/8/9 + 'article,aside,details,figcaption,figure,footer,header,hgroup,nav,section{display:block}' + + // corrects audio display not defined in IE6/7/8/9 + 'audio{display:none}' + + // corrects canvas and video display not defined in IE6/7/8/9 + 'canvas,video{display:inline-block;*display:inline;*zoom:1}' + + // corrects 'hidden' attribute and audio[controls] display not present in IE7/8/9 + '[hidden]{display:none}audio[controls]{display:inline-block;*display:inline;*zoom:1}' + + // adds styling not present in IE6/7/8/9 + 'mark{background:#FF0;color:#000}' + ); + } + if (!supportsUnknownElements) { + shived = !shivMethods(ownerDocument); + } + if (shived) { + ownerDocument.documentShived = shived; + } + return ownerDocument; + } + + /*--------------------------------------------------------------------------*/ + + /** + * The `html5` object is exposed so that more elements can be shived and + * existing shiving can be detected on iframes. + * @type Object + * @example + * + * // options can be changed before the script is included + * html5 = { 'elements': 'mark section', 'shivCSS': false, 'shivMethods': false }; + */ + var html5 = { + + /** + * An array or space separated string of node names of the elements to shiv. + * @memberOf html5 + * @type Array|String + */ + 'elements': options.elements || 'abbr article aside audio bdi canvas data datalist details figcaption figure footer header hgroup mark meter nav output progress section summary time video', + + /** + * A flag to indicate that the HTML5 style sheet should be inserted. + * @memberOf html5 + * @type Boolean + */ + 'shivCSS': !(options.shivCSS === false), + + /** + * A flag to indicate that the document's `createElement` and `createDocumentFragment` + * methods should be overwritten. + * @memberOf html5 + * @type Boolean + */ + 'shivMethods': !(options.shivMethods === false), + + /** + * A string to describe the type of `html5` object ("default" or "default print"). + * @memberOf html5 + * @type String + */ + 'type': 'default', + + // shivs the document according to the specified `html5` object options + 'shivDocument': shivDocument + }; + + /*--------------------------------------------------------------------------*/ + + // expose html5 + window.html5 = html5; + + // shiv the document + shivDocument(document); + +}(this, document)); \ No newline at end of file diff --git a/interface/web/themes/default-v2/templates/main.tpl.htm b/interface/web/themes/default-v2/templates/main.tpl.htm index e0184d1958..ca5737bc68 100644 --- a/interface/web/themes/default-v2/templates/main.tpl.htm +++ b/interface/web/themes/default-v2/templates/main.tpl.htm @@ -18,14 +18,8 @@ <script type="text/javascript" src="js/uni-form/uni-form.jquery.js"></script> <script type="text/javascript" src="js/jquery.ispconfigsearch.js"></script> <script type="text/javascript" src="js/jquery.tipsy.js"></script> + <script type="text/javascript" src="themes/default-v2/js/html5shiv.js"></script> <script language="JavaScript" type="text/javascript"> - var is_chrome = navigator.userAgent.toLowerCase().indexOf('chrome') > -1; - if(!is_chrome && getInternetExplorerVersion() > 8.0) { - var style = document.createElement('style'); - style.innerHTML = '#page_margins { min-width: 980px; max-width: 80%; background: #fff; display: table;}'; - document.getElementsByTagName("head")[0].appendChild(style); - } - jQuery(document).ready(function() { loadInitContent(); -- GitLab