webshims-rails 0.4.7 → 1.10.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (168) hide show
  1. checksums.yaml +15 -0
  2. data/lib/webshims-rails/version.rb +2 -2
  3. data/vendor/assets/javascripts/webshims/extras/custom-validity.js +1 -1
  4. data/vendor/assets/javascripts/webshims/extras/mousepress.js +1 -1
  5. data/vendor/assets/javascripts/webshims/polyfiller.js +197 -166
  6. data/vendor/assets/javascripts/webshims/shims/combos/1.js +1711 -1609
  7. data/vendor/assets/javascripts/webshims/shims/combos/10.js +2575 -2253
  8. data/vendor/assets/javascripts/webshims/shims/combos/11.js +2452 -1476
  9. data/vendor/assets/javascripts/webshims/shims/combos/12.js +1405 -1159
  10. data/vendor/assets/javascripts/webshims/shims/combos/13.js +1316 -963
  11. data/vendor/assets/javascripts/webshims/shims/combos/14.js +1862 -179
  12. data/vendor/assets/javascripts/webshims/shims/combos/15.js +4327 -287
  13. data/vendor/assets/javascripts/webshims/shims/combos/16.js +3887 -586
  14. data/vendor/assets/javascripts/webshims/shims/combos/17.js +2911 -2159
  15. data/vendor/assets/javascripts/webshims/shims/combos/18.js +3425 -1730
  16. data/vendor/assets/javascripts/webshims/shims/combos/19.js +2854 -1203
  17. data/vendor/assets/javascripts/webshims/shims/combos/2.js +3351 -2130
  18. data/vendor/assets/javascripts/webshims/shims/combos/20.js +2426 -581
  19. data/vendor/assets/javascripts/webshims/shims/combos/21.js +1915 -1574
  20. data/vendor/assets/javascripts/webshims/shims/combos/22.js +864 -2275
  21. data/vendor/assets/javascripts/webshims/shims/combos/23.js +609 -1811
  22. data/vendor/assets/javascripts/webshims/shims/combos/3.js +1655 -2736
  23. data/vendor/assets/javascripts/webshims/shims/combos/4.js +1037 -603
  24. data/vendor/assets/javascripts/webshims/shims/combos/5.js +3100 -773
  25. data/vendor/assets/javascripts/webshims/shims/combos/6.js +3631 -840
  26. data/vendor/assets/javascripts/webshims/shims/combos/7.js +3596 -1354
  27. data/vendor/assets/javascripts/webshims/shims/combos/8.js +1731 -188
  28. data/vendor/assets/javascripts/webshims/shims/combos/9.js +3243 -1431
  29. data/vendor/assets/javascripts/webshims/shims/dom-extend.js +107 -18
  30. data/vendor/assets/javascripts/webshims/shims/es5.js +1 -0
  31. data/vendor/assets/javascripts/webshims/shims/form-core.js +553 -464
  32. data/vendor/assets/javascripts/webshims/shims/form-datalist.js +160 -154
  33. data/vendor/assets/javascripts/webshims/shims/form-message.js +73 -49
  34. data/vendor/assets/javascripts/webshims/shims/form-native-extend.js +18 -1
  35. data/vendor/assets/javascripts/webshims/shims/form-number-date-api.js +161 -36
  36. data/vendor/assets/javascripts/webshims/shims/form-number-date-ui.js +2130 -813
  37. data/vendor/assets/javascripts/webshims/shims/form-shim-extend.js +206 -58
  38. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-ar.js → formcfg-ar.js} +30 -0
  39. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-ch-ZN.js → formcfg-ch-ZN.js} +31 -0
  40. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-de.txt → formcfg-de.txt} +50 -11
  41. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-el.js → formcfg-el.js} +31 -0
  42. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-en.txt → formcfg-en.txt} +44 -11
  43. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-es.js → formcfg-es.js} +31 -0
  44. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-fr.js → formcfg-fr.js} +31 -0
  45. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-he.js → formcfg-he.js} +31 -0
  46. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-hi.js → formcfg-hi.js} +31 -0
  47. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-hu.js → formcfg-hu.js} +31 -0
  48. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-it.js → formcfg-it.js} +31 -0
  49. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-ja.js → formcfg-ja.js} +31 -0
  50. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-nl.js → formcfg-nl.js} +31 -0
  51. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-pt-PT.js → formcfg-pt-PT.js} +31 -0
  52. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-ru.js → formcfg-ru.js} +31 -0
  53. data/vendor/assets/javascripts/webshims/shims/i18n/{errormessages-sv.js → formcfg-sv.js} +32 -0
  54. data/vendor/assets/javascripts/webshims/shims/json-storage.js +16 -10
  55. data/vendor/assets/javascripts/webshims/shims/mediaelement-core.js +155 -122
  56. data/vendor/assets/javascripts/webshims/shims/mediaelement-jaris.js +76 -41
  57. data/vendor/assets/javascripts/webshims/shims/mediaelement-yt.js +8 -16
  58. data/vendor/assets/javascripts/webshims/shims/range-ui.js +388 -0
  59. data/vendor/assets/javascripts/webshims/shims/styles/config.rb +12 -0
  60. data/vendor/assets/javascripts/webshims/shims/styles/forms.png +0 -0
  61. data/vendor/assets/javascripts/webshims/shims/styles/scss/shim.scss +1186 -0
  62. data/vendor/assets/javascripts/webshims/shims/styles/shim.css +868 -548
  63. data/vendor/assets/javascripts/webshims/shims/styles/vertical-range.png +0 -0
  64. data/vendor/assets/javascripts/webshims/shims/swf/JarisFLVPlayer.swf +0 -0
  65. data/vendor/assets/javascripts/webshims/shims/swfmini.js +497 -0
  66. data/vendor/assets/javascripts/webshims/shims/track-ui.js +3 -0
  67. data/vendor/assets/javascripts/webshims/shims/track.js +29 -29
  68. metadata +26 -125
  69. data/vendor/assets/javascripts/webshims/minified/extras/custom-validity.js +0 -1
  70. data/vendor/assets/javascripts/webshims/minified/extras/modernizr-custom.js +0 -1
  71. data/vendor/assets/javascripts/webshims/minified/extras/mousepress.js +0 -1
  72. data/vendor/assets/javascripts/webshims/minified/polyfiller.js +0 -1
  73. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvas/canvas2png.js +0 -1
  74. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvas/flashcanvas.js +0 -1
  75. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvas/flashcanvas.swf +0 -0
  76. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvas/proxy.php +0 -73
  77. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvas/save.php +0 -49
  78. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvasPro/canvas2png.js +0 -1
  79. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvasPro/flash10canvas.swf +0 -0
  80. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvasPro/flash9canvas.swf +0 -0
  81. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvasPro/flashcanvas.js +0 -1
  82. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvasPro/proxy.php +0 -73
  83. data/vendor/assets/javascripts/webshims/minified/shims/FlashCanvasPro/save.php +0 -49
  84. data/vendor/assets/javascripts/webshims/minified/shims/combos/1.js +0 -1
  85. data/vendor/assets/javascripts/webshims/minified/shims/combos/10.js +0 -1
  86. data/vendor/assets/javascripts/webshims/minified/shims/combos/11.js +0 -1
  87. data/vendor/assets/javascripts/webshims/minified/shims/combos/12.js +0 -1
  88. data/vendor/assets/javascripts/webshims/minified/shims/combos/13.js +0 -1
  89. data/vendor/assets/javascripts/webshims/minified/shims/combos/14.js +0 -1
  90. data/vendor/assets/javascripts/webshims/minified/shims/combos/15.js +0 -1
  91. data/vendor/assets/javascripts/webshims/minified/shims/combos/16.js +0 -1
  92. data/vendor/assets/javascripts/webshims/minified/shims/combos/17.js +0 -1
  93. data/vendor/assets/javascripts/webshims/minified/shims/combos/18.js +0 -1
  94. data/vendor/assets/javascripts/webshims/minified/shims/combos/19.js +0 -1
  95. data/vendor/assets/javascripts/webshims/minified/shims/combos/2.js +0 -1
  96. data/vendor/assets/javascripts/webshims/minified/shims/combos/20.js +0 -1
  97. data/vendor/assets/javascripts/webshims/minified/shims/combos/21.js +0 -1
  98. data/vendor/assets/javascripts/webshims/minified/shims/combos/22.js +0 -1
  99. data/vendor/assets/javascripts/webshims/minified/shims/combos/23.js +0 -1
  100. data/vendor/assets/javascripts/webshims/minified/shims/combos/24.js +0 -1
  101. data/vendor/assets/javascripts/webshims/minified/shims/combos/25.js +0 -1
  102. data/vendor/assets/javascripts/webshims/minified/shims/combos/26.js +0 -1
  103. data/vendor/assets/javascripts/webshims/minified/shims/combos/27.js +0 -1
  104. data/vendor/assets/javascripts/webshims/minified/shims/combos/3.js +0 -1
  105. data/vendor/assets/javascripts/webshims/minified/shims/combos/4.js +0 -1
  106. data/vendor/assets/javascripts/webshims/minified/shims/combos/5.js +0 -1
  107. data/vendor/assets/javascripts/webshims/minified/shims/combos/59.js +0 -1
  108. data/vendor/assets/javascripts/webshims/minified/shims/combos/6.js +0 -1
  109. data/vendor/assets/javascripts/webshims/minified/shims/combos/7.js +0 -1
  110. data/vendor/assets/javascripts/webshims/minified/shims/combos/8.js +0 -1
  111. data/vendor/assets/javascripts/webshims/minified/shims/combos/9.js +0 -1
  112. data/vendor/assets/javascripts/webshims/minified/shims/details.js +0 -1
  113. data/vendor/assets/javascripts/webshims/minified/shims/dom-extend.js +0 -1
  114. data/vendor/assets/javascripts/webshims/minified/shims/es5.js +0 -1
  115. data/vendor/assets/javascripts/webshims/minified/shims/excanvas.js +0 -1
  116. data/vendor/assets/javascripts/webshims/minified/shims/form-core.js +0 -1
  117. data/vendor/assets/javascripts/webshims/minified/shims/form-datalist.js +0 -1
  118. data/vendor/assets/javascripts/webshims/minified/shims/form-message.js +0 -1
  119. data/vendor/assets/javascripts/webshims/minified/shims/form-native-extend.js +0 -1
  120. data/vendor/assets/javascripts/webshims/minified/shims/form-number-date-api.js +0 -1
  121. data/vendor/assets/javascripts/webshims/minified/shims/form-number-date-ui.js +0 -1
  122. data/vendor/assets/javascripts/webshims/minified/shims/form-shim-extend.js +0 -1
  123. data/vendor/assets/javascripts/webshims/minified/shims/geolocation.js +0 -1
  124. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-ar.js +0 -1
  125. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-ch-ZN.js +0 -1
  126. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-de.txt +0 -33
  127. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-el.js +0 -1
  128. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-en.txt +0 -34
  129. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-es.js +0 -1
  130. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-fr.js +0 -1
  131. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-he.js +0 -1
  132. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-hi.js +0 -1
  133. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-hu.js +0 -1
  134. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-it.js +0 -1
  135. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-ja.js +0 -1
  136. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-nl.js +0 -1
  137. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-pt-PT.js +0 -1
  138. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-ru.js +0 -1
  139. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-sv.js +0 -1
  140. data/vendor/assets/javascripts/webshims/minified/shims/json-storage.js +0 -1
  141. data/vendor/assets/javascripts/webshims/minified/shims/jwplayer/license.txt +0 -1
  142. data/vendor/assets/javascripts/webshims/minified/shims/jwplayer/player.swf +0 -0
  143. data/vendor/assets/javascripts/webshims/minified/shims/jwplayer/readme.html +0 -87
  144. data/vendor/assets/javascripts/webshims/minified/shims/mediaelement-core.js +0 -1
  145. data/vendor/assets/javascripts/webshims/minified/shims/mediaelement-jaris.js +0 -1
  146. data/vendor/assets/javascripts/webshims/minified/shims/mediaelement-native-fix.js +0 -1
  147. data/vendor/assets/javascripts/webshims/minified/shims/mediaelement-swf.js +0 -1
  148. data/vendor/assets/javascripts/webshims/minified/shims/mediaelement-yt.js +0 -1
  149. data/vendor/assets/javascripts/webshims/minified/shims/styles/details-arrows.png +0 -0
  150. data/vendor/assets/javascripts/webshims/minified/shims/styles/forms.png +0 -0
  151. data/vendor/assets/javascripts/webshims/minified/shims/styles/polyfill-loader.gif +0 -0
  152. data/vendor/assets/javascripts/webshims/minified/shims/styles/shim.css +0 -1
  153. data/vendor/assets/javascripts/webshims/minified/shims/swf/JarisFLVPlayer.swf +0 -0
  154. data/vendor/assets/javascripts/webshims/minified/shims/swf/jwwebshims.swf +0 -0
  155. data/vendor/assets/javascripts/webshims/minified/shims/swf/localStorage.swf +0 -0
  156. data/vendor/assets/javascripts/webshims/minified/shims/track-ui.js +0 -1
  157. data/vendor/assets/javascripts/webshims/minified/shims/track.js +0 -1
  158. data/vendor/assets/javascripts/webshims/shims/FlashCanvas/README +0 -62
  159. data/vendor/assets/javascripts/webshims/shims/FlashCanvasPro/README +0 -82
  160. data/vendor/assets/javascripts/webshims/shims/combos/24.js +0 -2872
  161. data/vendor/assets/javascripts/webshims/shims/combos/25.js +0 -2376
  162. data/vendor/assets/javascripts/webshims/shims/combos/26.js +0 -3009
  163. data/vendor/assets/javascripts/webshims/shims/combos/27.js +0 -4150
  164. data/vendor/assets/javascripts/webshims/shims/combos/59.js +0 -1747
  165. data/vendor/assets/javascripts/webshims/shims/jwplayer/license.txt +0 -1
  166. data/vendor/assets/javascripts/webshims/shims/jwplayer/player.swf +0 -0
  167. data/vendor/assets/javascripts/webshims/shims/jwplayer/readme.html +0 -87
  168. data/vendor/assets/javascripts/webshims/shims/mediaelement-swf.js +0 -972
@@ -1,6 +1,17 @@
1
1
  //DOM-Extension helper
2
2
  jQuery.webshims.register('dom-extend', function($, webshims, window, document, undefined){
3
3
  "use strict";
4
+
5
+ webshims.assumeARIA = Modernizr.localstorage || Modernizr.video || Modernizr.boxsizing;
6
+
7
+ if($('<input type="email" />').attr('type') == 'text' || $('<form />').attr('novalidate') === "" || ('required' in $('<input />')[0].attributes)){
8
+ webshims.error("IE browser modes are busted in IE10. Please test your HTML/CSS/JS with a real IE version or at least IETester or similiar tools");
9
+ }
10
+
11
+ if(!$.parseHTML){
12
+ webshims.error("Webshims needs jQuery 1.8+ to work properly. Please update your jQuery version or downgrade webshims.");
13
+ }
14
+
4
15
  //shortcus
5
16
  var modules = webshims.modules;
6
17
  var listReg = /\s*,\s*/;
@@ -17,10 +28,7 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
17
28
  return (_argless) ? oldVal.call($(elem)) : oldVal.call($(elem), val);
18
29
  };
19
30
 
20
- $.fn.onTrigger = function(evt, fn){
21
- return this.on(evt, fn).each(fn);
22
- };
23
-
31
+
24
32
  $.fn.val = function(val){
25
33
  var elem = this[0];
26
34
  if(arguments.length && val == null){
@@ -49,6 +57,9 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
49
57
  }
50
58
  });
51
59
  };
60
+ $.fn.onTrigger = function(evt, fn){
61
+ return this.on(evt, fn).each(fn);
62
+ };
52
63
 
53
64
  var dataID = '_webshimsLib'+ (Math.round(Math.random() * 1000));
54
65
  var elementData = function(elem, key, val){
@@ -70,13 +81,69 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
70
81
 
71
82
  [{name: 'getNativeElement', prop: 'nativeElement'}, {name: 'getShadowElement', prop: 'shadowElement'}, {name: 'getShadowFocusElement', prop: 'shadowFocusElement'}].forEach(function(data){
72
83
  $.fn[data.name] = function(){
73
- return this.map(function(){
84
+ var elems = [];
85
+ this.each(function(){
74
86
  var shadowData = elementData(this, 'shadowData');
75
- return shadowData && shadowData[data.prop] || this;
87
+ var elem = shadowData && shadowData[data.prop] || this;
88
+ if($.inArray(elem, elems) == -1){
89
+ elems.push(elem);
90
+ }
76
91
  });
92
+ return this.pushStack(elems);
77
93
  };
78
94
  });
79
95
 
96
+ if($.Tween.propHooks._default && $.css){
97
+ (function(){
98
+ var isjQ8 = false;
99
+ try {
100
+ isjQ8 = $.css($('<b style="width: 10px" />')[0], 'width', '') == '10px';
101
+ } catch(er){
102
+ webshims.error(er);
103
+ }
104
+ var css = isjQ8 ?
105
+ function(elem, prop){
106
+ return $.css( elem, prop, false, "" );
107
+ } :
108
+ function(elem, prop){
109
+ return $.css( elem, prop, "" );
110
+ }
111
+ ;
112
+
113
+ $.extend($.Tween.propHooks._default, {
114
+ get: function( tween ) {
115
+ var result;
116
+
117
+ if ( (tween.elem[ tween.prop ] != null || havePolyfill[ tween.prop ]) &&
118
+ (!tween.elem.style || tween.elem.style[ tween.prop ] == null) ) {
119
+ return havePolyfill[ tween.prop ] ? $.prop(tween.elem, tween.prop) : tween.elem[ tween.prop ];
120
+ }
121
+
122
+ // passing an empty string as a 3rd parameter to .css will automatically
123
+ // attempt a parseFloat and fallback to a string if the parse fails
124
+ // so, simple values such as "10px" are parsed to Float.
125
+ // complex values such as "rotate(1rad)" are returned as is.
126
+ result = css( tween.elem, tween.prop );
127
+ // Empty strings, null, undefined and "auto" are converted to 0.
128
+ return !result || result === "auto" ? 0 : result;
129
+ },
130
+ set: function( tween ) {
131
+ // use step hook for back compat - use cssHook if its there - use .style if its
132
+ // available and use plain properties where available
133
+ if ( jQuery.fx.step[ tween.prop ] ) {
134
+ jQuery.fx.step[ tween.prop ]( tween );
135
+ } else if ( tween.elem.style && ( tween.elem.style[ jQuery.cssProps[ tween.prop ] ] != null || jQuery.cssHooks[ tween.prop ] ) ) {
136
+ jQuery.style( tween.elem, tween.prop, tween.now + tween.unit );
137
+ } else if( !havePolyfill[ tween.prop ] ) {
138
+ tween.elem[ tween.prop ] = tween.now;
139
+ } else {
140
+ $.prop(tween.elem, tween.prop, tween.now);
141
+ }
142
+ }
143
+ });
144
+ })();
145
+ }
146
+
80
147
 
81
148
  ['removeAttr', 'prop', 'attr'].forEach(function(type){
82
149
  olds[type] = $[type];
@@ -196,7 +263,7 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
196
263
  getSup('set', desc, oldDesc) :
197
264
  (webshims.cfg.useStrict && prop == 'prop') ?
198
265
  function(){throw(prop +' is readonly on '+ nodeName);} :
199
- $.noop
266
+ function(){webshims.info(prop +' is readonly on '+ nodeName);}
200
267
  ;
201
268
  }
202
269
  if(!desc.get){
@@ -214,15 +281,14 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
214
281
 
215
282
  });
216
283
 
217
- //see also: https://github.com/lojjic/PIE/issues/40 | https://prototype.lighthouseapp.com/projects/8886/tickets/1107-ie8-fatal-crash-when-prototypejs-is-loaded-with-rounded-cornershtc
218
- var isExtendNativeSave = Modernizr.ES5;
219
284
  var extendNativeValue = (function(){
220
285
  var UNKNOWN = webshims.getPrototypeOf(document.createElement('foobar'));
221
286
  var has = Object.prototype.hasOwnProperty;
287
+ //see also: https://github.com/lojjic/PIE/issues/40 | https://prototype.lighthouseapp.com/projects/8886/tickets/1107-ie8-fatal-crash-when-prototypejs-is-loaded-with-rounded-cornershtc
288
+ var isExtendNativeSave = Modernizr.advancedObjectProperties && Modernizr.objectAccessor;
222
289
  return function(nodeName, prop, desc){
223
- var elem;
224
- var elemProto;
225
- if( isExtendNativeSave && (elem = document.createElement(nodeName)) && (elemProto = webshims.getPrototypeOf(elem)) && UNKNOWN !== elemProto && ( !elem[prop] || !has.call(elem, prop) ) ){
290
+ var elem , elemProto;
291
+ if( isExtendNativeSave && (elem = document.createElement(nodeName)) && (elemProto = webshims.getPrototypeOf(elem)) && UNKNOWN !== elemProto && ( !elem[prop] || !has.call(elem, prop) ) ){
226
292
  var sup = elem[prop];
227
293
  desc._supvalue = function(){
228
294
  if(sup && sup.apply){
@@ -344,15 +410,24 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
344
410
  var ID = new Date().getTime();
345
411
  return function(elem){
346
412
  elem = $(elem);
347
- var id = elem.attr('id');
413
+ var id = elem.prop('id');
348
414
  if(!id){
349
415
  ID++;
350
416
  id = 'ID-'+ ID;
351
- elem.attr('id', id);
417
+ elem.eq(0).prop('id', id);
352
418
  }
353
419
  return id;
354
420
  };
355
421
  })(),
422
+ implement: function(elem, type){
423
+ var data = elementData(elem, 'implemented') || elementData(elem, 'implemented', {});
424
+ if(data[type]){
425
+ webshims.info(type +' already implemented for element #'+elem.id);
426
+ return false;
427
+ }
428
+ data[type] = true;
429
+ return true;
430
+ },
356
431
  extendUNDEFProp: function(obj, props){
357
432
  $.each(props, function(name, prop){
358
433
  if( !(name in obj) ){
@@ -831,7 +906,7 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
831
906
  var callRegister = function(module){
832
907
  if(registeredCallbacks[module]){
833
908
  registeredCallbacks[module].forEach(function(data){
834
- data.callback();
909
+ data.callback(currentLang, shortLang, '');
835
910
  });
836
911
  }
837
912
  };
@@ -872,7 +947,7 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
872
947
  registeredCallbacks[lang.register] = [];
873
948
  }
874
949
  registeredCallbacks[lang.register].push(lang);
875
- lang.callback();
950
+ lang.callback(currentLang, shortLang, '');
876
951
  } else {
877
952
  if(!lang.activeLang){
878
953
  lang.activeLang = '';
@@ -909,8 +984,20 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
909
984
  });
910
985
  //html5a11y
911
986
  (function($, document){
912
- //if we support basic styleing or do not support ARIA (assumed) abort
913
- if(!Modernizr.localstorage || ('hidden' in document.createElement('a'))){return;}
987
+ if(!$.webshims.assumeARIA || ('content' in document.createElement('template'))){return;}
988
+
989
+ $(function(){
990
+ var main = $('main').attr({role: 'main'});
991
+ if(main.length > 1){
992
+ webshims.error('only one main element allowed in document');
993
+ } else if(main.is('article *, section *')) {
994
+ webshims.error('main not allowed inside of article/section elements');
995
+ }
996
+ });
997
+
998
+ if(('hidden' in document.createElement('a'))){
999
+ return;
1000
+ }
914
1001
 
915
1002
  var elemMappings = {
916
1003
  article: "article",
@@ -926,6 +1013,7 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
926
1013
  }
927
1014
  };
928
1015
 
1016
+
929
1017
  $.webshims.addReady(function(context, contextElem){
930
1018
  $.each(elemMappings, function(name, role){
931
1019
  var elems = $(name, context).add(contextElem.filter(name));
@@ -937,6 +1025,7 @@ jQuery.webshims.register('dom-extend', function($, webshims, window, document, u
937
1025
  var header = document.getElementsByTagName('header')[0];
938
1026
  var footers = document.getElementsByTagName('footer');
939
1027
  var footerLen = footers.length;
1028
+
940
1029
  if (header && !$(header).closest('section, article')[0]) {
941
1030
  addRole(header, 'banner');
942
1031
  }
@@ -664,6 +664,7 @@ var prepareString = "a"[0] != "a",
664
664
  var defineProperty = 'defineProperty';
665
665
  var advancedObjectProperties = !!(Object.create && Object.defineProperties && Object.getOwnPropertyDescriptor);
666
666
  //safari5 has defineProperty-interface, but it can't be used on dom-object
667
+ //only do this test in non-IE browsers, because this hurts dhtml-behavior in some IE8 versions
667
668
  if (advancedObjectProperties && Object[defineProperty] && Object.prototype.__defineGetter__) {
668
669
  (function(){
669
670
  try {
@@ -1,7 +1,7 @@
1
1
  //additional tests for partial implementation of forms features
2
2
  (function($){
3
3
  "use strict";
4
- var isWebkit = /webkit/i.test(navigator.userAgent);
4
+ var isWebkit = 'webkitURL' in window;
5
5
  var Modernizr = window.Modernizr;
6
6
  var webshims = $.webshims;
7
7
  var bugs = webshims.bugs;
@@ -46,7 +46,6 @@
46
46
  testRequiredFind();
47
47
  } else {
48
48
  //create delegatable events
49
- webshims.capturingEvents(['input']);
50
49
  webshims.capturingEvents(['invalid'], true);
51
50
 
52
51
  if(window.opera || window.testGoodWithFix){
@@ -116,518 +115,608 @@
116
115
  })();
117
116
  }
118
117
  }
119
-
120
-
121
118
 
122
- jQuery.webshims.register('form-core', function($, webshims, window, document, undefined, options){
123
- "use strict";
119
+ $.webshims.register('form-core', function($, webshims, window, document, undefined, options){
124
120
 
125
-
126
- var checkTypes = {checkbox: 1, radio: 1};
127
- var emptyJ = $([]);
128
- var bugs = webshims.bugs;
129
- var groupTypes = {radio: 1};
130
- var getGroupElements = function(elem){
131
- elem = $(elem);
132
- var name;
133
- var form;
134
- var ret = emptyJ;
135
- if(groupTypes[elem[0].type]){
136
- form = elem.prop('form');
137
- name = elem[0].name;
138
- if(!name){
139
- ret = elem;
140
- } else if(form){
141
- ret = $(form[name]);
142
- } else {
143
- ret = $(document.getElementsByName(name)).filter(function(){
144
- return !$.prop(this, 'form');
145
- });
146
- }
147
- ret = ret.filter('[type="radio"]');
148
- }
149
- return ret;
150
- };
151
-
152
- var getContentValidationMessage = webshims.getContentValidationMessage = function(elem, validity, key){
153
- var message = $(elem).data('errormessage') || elem.getAttribute('x-moz-errormessage') || '';
154
- if(key && message[key]){
155
- message = message[key];
156
- }
157
- if(typeof message == 'object'){
158
- validity = validity || $.prop(elem, 'validity') || {valid: 1};
159
- if(!validity.valid){
160
- $.each(validity, function(name, prop){
161
- if(prop && name != 'valid' && message[name]){
162
- message = message[name];
163
- return false;
164
- }
165
- });
121
+ var checkTypes = {checkbox: 1, radio: 1};
122
+ var emptyJ = $([]);
123
+ var bugs = webshims.bugs;
124
+ var getGroupElements = function(elem){
125
+ elem = $(elem);
126
+ var name;
127
+ var form;
128
+ var ret = emptyJ;
129
+ if(elem[0].type == 'radio'){
130
+ form = elem.prop('form');
131
+ name = elem[0].name;
132
+ if(!name){
133
+ ret = elem;
134
+ } else if(form){
135
+ ret = $(form[name]);
136
+ } else {
137
+ ret = $(document.getElementsByName(name)).filter(function(){
138
+ return !$.prop(this, 'form');
139
+ });
140
+ }
141
+ ret = ret.filter('[type="radio"]');
166
142
  }
167
- }
143
+ return ret;
144
+ };
168
145
 
169
- if(typeof message == 'object'){
170
- message = message.defaultMessage;
171
- }
172
- return message || '';
173
- };
174
-
175
- /*
176
- * Selectors for all browsers
177
- */
178
- var rangeTypes = {number: 1, range: 1, date: 1/*, time: 1, 'datetime-local': 1, datetime: 1, month: 1, week: 1*/};
179
- var hasInvalid = function(elem){
180
- var ret = false;
181
- $($.prop(elem, 'elements')).each(function(){
182
- ret = $(this).is(':invalid');
183
- if(ret){
184
- return false;
146
+ var getContentValidationMessage = webshims.getContentValidationMessage = function(elem, validity, key){
147
+ var message = $(elem).data('errormessage') || elem.getAttribute('x-moz-errormessage') || '';
148
+ if(key && message[key]){
149
+ message = message[key];
185
150
  }
186
- });
187
- return ret;
188
- };
189
- $.extend($.expr[":"], {
190
- "valid-element": function(elem){
191
- return $.nodeName(elem, 'form') ? !hasInvalid(elem) :!!($.prop(elem, 'willValidate') && isValid(elem));
192
- },
193
- "invalid-element": function(elem){
194
- return $.nodeName(elem, 'form') ? hasInvalid(elem) : !!($.prop(elem, 'willValidate') && !isValid(elem));
195
- },
196
- "required-element": function(elem){
197
- return !!($.prop(elem, 'willValidate') && $.prop(elem, 'required'));
198
- },
199
- "user-error": function(elem){
200
- return ($.prop(elem, 'willValidate') && $(elem).hasClass('user-error'));
201
- },
202
- "optional-element": function(elem){
203
- return !!($.prop(elem, 'willValidate') && $.prop(elem, 'required') === false);
204
- },
205
- "in-range": function(elem){
206
- if(!rangeTypes[$.prop(elem, 'type')] || !$.prop(elem, 'willValidate')){
207
- return false;
151
+ if(typeof message == 'object'){
152
+ validity = validity || $.prop(elem, 'validity') || {valid: 1};
153
+ if(!validity.valid){
154
+ $.each(validity, function(name, prop){
155
+ if(prop && name != 'valid' && message[name]){
156
+ message = message[name];
157
+ return false;
158
+ }
159
+ });
160
+ }
208
161
  }
209
- var val = $.prop(elem, 'validity');
210
- return !!(val && !val.rangeOverflow && !val.rangeUnderflow);
211
- },
212
- "out-of-range": function(elem){
213
- if(!rangeTypes[$.prop(elem, 'type')] || !$.prop(elem, 'willValidate')){
214
- return false;
162
+
163
+ if(typeof message == 'object'){
164
+ message = message.defaultMessage;
215
165
  }
216
- var val = $.prop(elem, 'validity');
217
- return !!(val && (val.rangeOverflow || val.rangeUnderflow));
218
- }
166
+ return message || '';
167
+ };
219
168
 
220
- });
221
-
222
- ['valid', 'invalid', 'required', 'optional'].forEach(function(name){
223
- $.expr[":"][name] = $.expr.filters[name+"-element"];
224
- });
225
-
226
-
227
- $.expr[":"].focus = function( elem ) {
228
- try {
229
- var doc = elem.ownerDocument;
230
- return elem === doc.activeElement && (!doc.hasFocus || doc.hasFocus());
231
- } catch(e){}
232
- return false;
233
- };
234
-
235
- if(Modernizr.formvalidation && isWebkit && !webshims.bugs.bustedValidity){
236
- (function(){
237
- var retriggerRadioValidity = function(){
238
- var validity;
239
- if((validity = this.validity) && !validity.customError){
240
- this.setCustomValidity('');
241
- }
242
- };
243
-
244
- webshims.addReady(function(context, insertedElement){
245
- if(context !== document){
246
- $('input[type="radio"]:invalid', context)
247
- .add(insertedElement.filter('input[type="radio"]:invalid'))
248
- .each(retriggerRadioValidity)
249
- ;
169
+ /*
170
+ * Selectors for all browsers
171
+ */
172
+ var rangeTypes = {number: 1, range: 1, date: 1/*, time: 1, 'datetime-local': 1, datetime: 1, month: 1, week: 1*/};
173
+ var hasInvalid = function(elem){
174
+ var ret = false;
175
+ $($.prop(elem, 'elements')).each(function(){
176
+ ret = $(this).is(':invalid');
177
+ if(ret){
178
+ return false;
250
179
  }
251
180
  });
252
- })();
253
- }
254
-
255
- var customEvents = $.event.customEvent || {};
256
- var isValid = function(elem){
257
- return ($.prop(elem, 'validity') || {valid: 1}).valid;
258
- };
259
-
260
- if (bugs.bustedValidity || bugs.findRequired) {
261
- (function(){
262
- var find = $.find;
263
- var matchesSelector = $.find.matchesSelector;
264
-
265
- var regExp = /(\:valid|\:invalid|\:optional|\:required|\:in-range|\:out-of-range)(?=[\s\[\~\.\+\>\:\#*]|$)/ig;
266
- var regFn = function(sel){
267
- return sel + '-element';
268
- };
181
+ return ret;
182
+ };
183
+ $.extend($.expr[":"], {
184
+ "valid-element": function(elem){
185
+ return $.nodeName(elem, 'form') ? !hasInvalid(elem) :!!($.prop(elem, 'willValidate') && isValid(elem));
186
+ },
187
+ "invalid-element": function(elem){
188
+ return $.nodeName(elem, 'form') ? hasInvalid(elem) : !!($.prop(elem, 'willValidate') && !isValid(elem));
189
+ },
190
+ "required-element": function(elem){
191
+ return !!($.prop(elem, 'willValidate') && $.prop(elem, 'required'));
192
+ },
193
+ "user-error": function(elem){
194
+ return ($.prop(elem, 'willValidate') && $(elem).hasClass('user-error'));
195
+ },
196
+ "optional-element": function(elem){
197
+ return !!($.prop(elem, 'willValidate') && $.prop(elem, 'required') === false);
198
+ },
199
+ "in-range": function(elem){
200
+ if(!rangeTypes[$.prop(elem, 'type')] || !$.prop(elem, 'willValidate')){
201
+ return false;
202
+ }
203
+ var val = $.prop(elem, 'validity');
204
+ return !!(val && !val.rangeOverflow && !val.rangeUnderflow);
205
+ },
206
+ "out-of-range": function(elem){
207
+ if(!rangeTypes[$.prop(elem, 'type')] || !$.prop(elem, 'willValidate')){
208
+ return false;
209
+ }
210
+ var val = $.prop(elem, 'validity');
211
+ return !!(val && (val.rangeOverflow || val.rangeUnderflow));
212
+ }
269
213
 
270
- $.find = (function(){
271
- var slice = Array.prototype.slice;
272
- var fn = function(sel){
273
- var ar = arguments;
274
- ar = slice.call(ar, 1, ar.length);
275
- ar.unshift(sel.replace(regExp, regFn));
276
- return find.apply(this, ar);
214
+ });
215
+
216
+ ['valid', 'invalid', 'required', 'optional'].forEach(function(name){
217
+ $.expr[":"][name] = $.expr.filters[name+"-element"];
218
+ });
219
+
220
+
221
+ $.expr[":"].focus = function( elem ) {
222
+ try {
223
+ var doc = elem.ownerDocument;
224
+ return elem === doc.activeElement && (!doc.hasFocus || doc.hasFocus());
225
+ } catch(e){}
226
+ return false;
227
+ };
228
+
229
+
230
+ var customEvents = $.event.customEvent || {};
231
+ var isValid = function(elem){
232
+ return ($.prop(elem, 'validity') || {valid: 1}).valid;
233
+ };
234
+
235
+ if (bugs.bustedValidity || bugs.findRequired) {
236
+ (function(){
237
+ var find = $.find;
238
+ var matchesSelector = $.find.matchesSelector;
239
+
240
+ var regExp = /(\:valid|\:invalid|\:optional|\:required|\:in-range|\:out-of-range)(?=[\s\[\~\.\+\>\:\#*]|$)/ig;
241
+ var regFn = function(sel){
242
+ return sel + '-element';
277
243
  };
278
- for (var i in find) {
279
- if(find.hasOwnProperty(i)){
280
- fn[i] = find[i];
244
+
245
+ $.find = (function(){
246
+ var slice = Array.prototype.slice;
247
+ var fn = function(sel){
248
+ var ar = arguments;
249
+ ar = slice.call(ar, 1, ar.length);
250
+ ar.unshift(sel.replace(regExp, regFn));
251
+ return find.apply(this, ar);
252
+ };
253
+ for (var i in find) {
254
+ if(find.hasOwnProperty(i)){
255
+ fn[i] = find[i];
256
+ }
281
257
  }
258
+ return fn;
259
+ })();
260
+ if(!Modernizr.prefixed || Modernizr.prefixed("matchesSelector", document.documentElement)){
261
+ $.find.matchesSelector = function(node, expr){
262
+ expr = expr.replace(regExp, regFn);
263
+ return matchesSelector.call(this, node, expr);
264
+ };
282
265
  }
283
- return fn;
266
+
284
267
  })();
285
- if(!Modernizr.prefixed || Modernizr.prefixed("matchesSelector", document.documentElement)){
286
- $.find.matchesSelector = function(node, expr){
287
- expr = expr.replace(regExp, regFn);
288
- return matchesSelector.call(this, node, expr);
289
- };
290
- }
291
-
292
- })();
293
- }
294
-
295
- //ToDo needs testing
296
- var oldAttr = $.prop;
297
- var changeVals = {selectedIndex: 1, value: 1, checked: 1, disabled: 1, readonly: 1};
298
- $.prop = function(elem, name, val){
299
- var ret = oldAttr.apply(this, arguments);
300
- if(elem && 'form' in elem && changeVals[name] && val !== undefined && $(elem).hasClass(invalidClass)){
301
- if(isValid(elem)){
302
- $(elem).getShadowElement().removeClass(invalidClasses);
303
- if(name == 'checked' && val) {
304
- getGroupElements(elem).not(elem).removeClass(invalidClasses).removeAttr('aria-invalid');
305
- }
306
- }
307
268
  }
308
- return ret;
309
- };
310
-
311
- var returnValidityCause = function(validity, elem){
312
- var ret;
313
- $.each(validity, function(name, value){
314
- if(value){
315
- ret = (name == 'customError') ? $.prop(elem, 'validationMessage') : name;
316
- return false;
317
- }
318
- });
319
- return ret;
320
- };
321
-
322
- var isInGroup = function(name){
323
- var ret;
324
- try {
325
- ret = document.activeElement.name === name;
326
- } catch(e){}
327
- return ret;
328
- };
329
- /* form-ui-invalid/form-ui-valid are deprecated. use user-error/user-success instead */
330
- var invalidClass = 'user-error';
331
- var invalidClasses = 'user-error form-ui-invalid';
332
- var validClass = 'user-success';
333
- var validClasses = 'user-success form-ui-valid';
334
- var switchValidityClass = function(e){
335
- var elem, timer;
336
- if(!e.target){return;}
337
- elem = $(e.target).getNativeElement()[0];
338
- if(elem.type == 'submit' || !$.prop(elem, 'willValidate')){return;}
339
- timer = $.data(elem, 'webshimsswitchvalidityclass');
340
- var switchClass = function(){
341
- if(e.type == 'focusout' && elem.type == 'radio' && isInGroup(elem.name)){return;}
342
- var validity = $.prop(elem, 'validity');
343
- var shadowElem = $(elem).getShadowElement();
344
- var addClass, removeClass, trigger, generaltrigger, validityCause;
345
-
346
- $(elem).trigger('refreshCustomValidityRules');
347
- if(validity.valid){
348
- if(!shadowElem.hasClass(validClass)){
349
- addClass = validClasses;
350
- removeClass = invalidClasses;
351
- generaltrigger = 'changedvaliditystate';
352
- trigger = 'changedvalid';
353
- if(checkTypes[elem.type] && elem.checked){
354
- getGroupElements(elem).not(elem).removeClass(removeClass).addClass(addClass).removeAttr('aria-invalid');
269
+
270
+ //ToDo needs testing
271
+ var oldAttr = $.prop;
272
+ var changeVals = {selectedIndex: 1, value: 1, checked: 1, disabled: 1, readonly: 1};
273
+ $.prop = function(elem, name, val){
274
+ var ret = oldAttr.apply(this, arguments);
275
+ if(elem && 'form' in elem && changeVals[name] && val !== undefined && $(elem).hasClass(invalidClass)){
276
+ if(isValid(elem)){
277
+ $(elem).getShadowElement().removeClass(invalidClass);
278
+ if(name == 'checked' && val) {
279
+ getGroupElements(elem).not(elem).removeClass(invalidClass).removeAttr('aria-invalid');
355
280
  }
356
- $.removeData(elem, 'webshimsinvalidcause');
357
281
  }
358
- } else {
359
- validityCause = returnValidityCause(validity, elem);
360
- if($.data(elem, 'webshimsinvalidcause') != validityCause){
361
- $.data(elem, 'webshimsinvalidcause', validityCause);
362
- generaltrigger = 'changedvaliditystate';
282
+ }
283
+ return ret;
284
+ };
285
+
286
+ var returnValidityCause = function(validity, elem){
287
+ var ret;
288
+ $.each(validity, function(name, value){
289
+ if(value){
290
+ ret = (name == 'customError') ? $.prop(elem, 'validationMessage') : name;
291
+ return false;
363
292
  }
364
- if(!shadowElem.hasClass(invalidClass)){
365
- addClass = invalidClasses;
366
- removeClass = validClasses;
367
- if (checkTypes[elem.type] && !elem.checked) {
368
- getGroupElements(elem).not(elem).removeClass(removeClass).addClass(addClass);
293
+ });
294
+ return ret;
295
+ };
296
+
297
+ var isInGroup = function(name){
298
+ var ret;
299
+ try {
300
+ ret = document.activeElement.name === name;
301
+ } catch(e){}
302
+ return ret;
303
+ };
304
+ /* form-ui-invalid/form-ui-valid are deprecated. use user-error/user-success instead */
305
+ var invalidClass = 'user-error';
306
+ var validClass = 'user-success';
307
+ var stopChangeTypes = {
308
+ time: 1,
309
+ date: 1,
310
+ month: 1,
311
+ datetime: 1,
312
+ week: 1,
313
+ 'datetime-local': 1
314
+ };
315
+ var switchValidityClass = function(e){
316
+ var elem, timer;
317
+ if(!e.target){return;}
318
+ elem = $(e.target).getNativeElement()[0];
319
+ if(elem.type == 'submit' || !$.prop(elem, 'willValidate')){return;}
320
+ timer = $.data(elem, 'webshimsswitchvalidityclass');
321
+ var switchClass = function(){
322
+ if(e.type == 'focusout' && elem.type == 'radio' && isInGroup(elem.name)){return;}
323
+ var validity = $.prop(elem, 'validity');
324
+ var shadowElem = $(elem).getShadowElement();
325
+ var addClass, removeClass, trigger, generaltrigger, validityCause;
326
+
327
+ if(isWebkit && e.type == 'change' && !bugs.bustedValidity && stopChangeTypes[shadowElem.prop('type')] && shadowElem.is(':focus')){return;}
328
+
329
+ $(elem).trigger('refreshCustomValidityRules');
330
+
331
+ if(validity.valid){
332
+ if(!shadowElem.hasClass(validClass)){
333
+ addClass = validClass;
334
+ removeClass = invalidClass;
335
+ generaltrigger = 'changedvaliditystate';
336
+ trigger = 'changedvalid';
337
+ if(checkTypes[elem.type] && elem.checked){
338
+ getGroupElements(elem).not(elem).removeClass(removeClass).addClass(addClass).removeAttr('aria-invalid');
339
+ }
340
+ $.removeData(elem, 'webshimsinvalidcause');
341
+ }
342
+ } else {
343
+ validityCause = returnValidityCause(validity, elem);
344
+ if($.data(elem, 'webshimsinvalidcause') != validityCause){
345
+ $.data(elem, 'webshimsinvalidcause', validityCause);
346
+ generaltrigger = 'changedvaliditystate';
347
+ }
348
+ if(!shadowElem.hasClass(invalidClass)){
349
+ addClass = invalidClass;
350
+ removeClass = validClass;
351
+ if (checkTypes[elem.type] && !elem.checked) {
352
+ getGroupElements(elem).not(elem).removeClass(removeClass).addClass(addClass);
353
+ }
354
+ trigger = 'changedinvalid';
369
355
  }
370
- trigger = 'changedinvalid';
371
356
  }
357
+
358
+ if(addClass){
359
+ shadowElem.addClass(addClass).removeClass(removeClass);
360
+ //jQuery 1.6.1 IE9 bug (doubble trigger bug)
361
+ setTimeout(function(){
362
+ $(elem).trigger(trigger);
363
+ }, 0);
364
+ }
365
+ if(generaltrigger){
366
+ setTimeout(function(){
367
+ $(elem).trigger(generaltrigger);
368
+ }, 0);
369
+ }
370
+
371
+ $.removeData(elem, 'webshimsswitchvalidityclass');
372
+ };
373
+
374
+ if(timer){
375
+ clearTimeout(timer);
372
376
  }
373
- if(addClass){
374
- shadowElem.addClass(addClass).removeClass(removeClass);
375
- //jQuery 1.6.1 IE9 bug (doubble trigger bug)
376
- setTimeout(function(){
377
- $(elem).trigger(trigger);
378
- }, 0);
379
- }
380
- if(generaltrigger){
381
- setTimeout(function(){
382
- $(elem).trigger(generaltrigger);
383
- }, 0);
377
+ if(e.type == 'refreshvalidityui'){
378
+ switchClass();
379
+ } else {
380
+ $.data(elem, 'webshimsswitchvalidityclass', setTimeout(switchClass, 9));
384
381
  }
385
- $.removeData(e.target, 'webshimsswitchvalidityclass');
386
382
  };
387
383
 
388
- if(timer){
389
- clearTimeout(timer);
390
- }
391
- if(e.type == 'refreshvalidityui'){
392
- switchClass();
393
- } else {
394
- $.data(elem, 'webshimsswitchvalidityclass', setTimeout(switchClass, 9));
395
- }
396
- };
397
-
398
- $(document).on(options.validityUIEvents || 'focusout change refreshvalidityui', switchValidityClass);
399
- customEvents.changedvaliditystate = true;
400
- customEvents.refreshCustomValidityRules = true;
401
- customEvents.changedvalid = true;
402
- customEvents.changedinvalid = true;
403
- customEvents.refreshvalidityui = true;
404
-
405
-
406
- webshims.triggerInlineForm = function(elem, event){
407
- $(elem).trigger(event);
408
- };
409
-
410
- webshims.modules["form-core"].getGroupElements = getGroupElements;
411
-
412
-
413
- var setRoot = function(){
414
- webshims.scrollRoot = (isWebkit || document.compatMode == 'BackCompat') ?
415
- $(document.body) :
416
- $(document.documentElement)
384
+ $(document).on(options.validityUIEvents || 'focusout change refreshvalidityui', switchValidityClass);
385
+ customEvents.changedvaliditystate = true;
386
+ customEvents.refreshCustomValidityRules = true;
387
+ customEvents.changedvalid = true;
388
+ customEvents.changedinvalid = true;
389
+ customEvents.refreshvalidityui = true;
390
+
391
+
392
+ webshims.triggerInlineForm = function(elem, event){
393
+ $(elem).trigger(event);
394
+ };
395
+
396
+ webshims.modules["form-core"].getGroupElements = getGroupElements;
397
+
398
+
399
+ var setRoot = function(){
400
+ webshims.scrollRoot = (isWebkit || document.compatMode == 'BackCompat') ?
401
+ $(document.body) :
402
+ $(document.documentElement)
403
+ ;
404
+ };
405
+ var minWidth = (Modernizr.boxSizing || Modernizr['display-table'] || $.support.getSetAttribute) ?
406
+ 'minWidth' :
407
+ 'width'
417
408
  ;
418
- };
419
- setRoot();
420
- webshims.ready('DOM', setRoot);
421
-
422
- webshims.getRelOffset = function(posElem, relElem){
423
- posElem = $(posElem);
424
- var offset = $(relElem).offset();
425
- var bodyOffset;
426
- $.swap($(posElem)[0], {visibility: 'hidden', display: 'inline-block', left: 0, top: 0}, function(){
427
- bodyOffset = posElem.offset();
428
- });
429
- offset.top -= bodyOffset.top;
430
- offset.left -= bodyOffset.left;
431
- return offset;
432
- };
433
-
434
- /* some extra validation UI */
435
- webshims.validityAlert = (function(){
436
- var alertElem = 'span';
437
- var errorBubble;
438
- var hideTimer = false;
439
- var focusTimer = false;
440
- var resizeTimer = false;
441
- var boundHide;
409
+ setRoot();
410
+ webshims.ready('DOM', setRoot);
442
411
 
443
- var api = {
444
- hideDelay: 5000,
445
-
446
- showFor: function(elem, message, noFocusElem, noBubble){
447
- api._create();
448
- elem = $(elem);
449
- var visual = $(elem).getShadowElement();
450
- var offset = api.getOffsetFromBody(visual);
451
- api.clear();
452
- if(noBubble){
453
- this.hide();
454
- } else {
455
-
456
- this.getMessage(elem, message);
457
- this.position(visual, offset);
458
-
459
- this.show();
460
- if(this.hideDelay){
461
- hideTimer = setTimeout(boundHide, this.hideDelay);
462
- }
463
- $(window)
464
- .on('resize.validityalert reposoverlay.validityalert', function(){
465
- clearTimeout(resizeTimer);
466
- resizeTimer = setTimeout(function(){
467
- api.position(visual);
468
- }, 9);
469
- })
470
- ;
471
- }
412
+ webshims.getRelOffset = function(posElem, relElem){
413
+ posElem = $(posElem);
414
+ var offset = $(relElem).offset();
415
+ var bodyOffset;
416
+ $.swap($(posElem)[0], {visibility: 'hidden', display: 'inline-block', left: 0, top: 0}, function(){
417
+ bodyOffset = posElem.offset();
418
+ });
419
+ offset.top -= bodyOffset.top;
420
+ offset.left -= bodyOffset.left;
421
+ return offset;
422
+ };
423
+
424
+ webshims.wsPopover = {
425
+ _create: function(){
426
+ this.options = $.extend({}, webshims.cfg.wspopover, this.options);
427
+ this.id = webshims.wsPopover.id++;
428
+ this.eventns = '.wsoverlay'+this.id;
429
+ this.timers = {};
430
+ this.element = $('<div class="ws-popover" tabindex="-1"><div class="ws-po-outerbox"><div class="ws-po-arrow"><div class="ws-po-arrowbox" /></div><div class="ws-po-box" /></div></div>');
431
+ this.contentElement = $('.ws-po-box', this.element);
432
+ this.lastElement = $([]);
433
+ this.bindElement();
472
434
 
473
- if(!noFocusElem){
474
- this.setFocus(visual, offset);
475
- }
435
+ this.element.data('wspopover', this);
436
+
437
+ },
438
+ options: {},
439
+ content: function(html){
440
+ this.contentElement.html(html);
441
+ },
442
+ bindElement: function(){
443
+ var that = this;
444
+ var stopBlur = function(){
445
+ that.stopBlur = false;
446
+ };
447
+ this.preventBlur = function(e){
448
+ that.stopBlur = true;
449
+ clearTimeout(that.timers.stopBlur);
450
+ that.timers.stopBlur = setTimeout(stopBlur, 9);
451
+ };
452
+ this.element.on({
453
+ 'mousedown': this.preventBlur
454
+ });
476
455
  },
477
- getOffsetFromBody: function(elem){
478
- return webshims.getRelOffset(errorBubble, elem);
456
+
457
+ isInElement: function(container, contained){
458
+ return container == contained || $.contains(container, contained);
479
459
  },
480
- setFocus: function(visual, offset){
481
- var focusElem = $(visual).getShadowFocusElement();
482
- var scrollTop = webshims.scrollRoot.scrollTop();
483
- var elemTop = ((offset || focusElem.offset()).top) - 30;
484
- var smooth;
460
+ show: function(element){
461
+ var e = $.Event('wspopoverbeforeshow');
462
+ this.element.trigger(e);
463
+ if(e.isDefaultPrevented() || this.isVisible){return;}
464
+ this.isVisible = true;
465
+ element = $(element || this.options.prepareFor).getNativeElement() ;
485
466
 
486
- if(webshims.getID && alertElem == 'label'){
487
- errorBubble.attr('for', webshims.getID(focusElem));
488
- }
467
+ var that = this;
468
+ var visual = $(element).getShadowElement();
469
+
470
+ this.clear();
471
+ this.element.removeClass('ws-po-visible').css('display', 'none');
489
472
 
490
- if(scrollTop > elemTop){
491
- webshims.scrollRoot.animate(
492
- {scrollTop: elemTop - 5},
493
- {
494
- queue: false,
495
- duration: Math.max( Math.min( 600, (scrollTop - elemTop) * 1.5 ), 80 )
496
- }
497
- );
498
- smooth = true;
499
- }
500
- try {
501
- focusElem[0].focus();
502
- } catch(e){}
503
- if(smooth){
504
- webshims.scrollRoot.scrollTop(scrollTop);
505
- setTimeout(function(){
506
- webshims.scrollRoot.scrollTop(scrollTop);
507
- }, 0);
508
- }
509
- setTimeout(function(){
510
- $(document).on('focusout.validityalert', boundHide);
511
- }, 10);
512
- $(window).triggerHandler('reposoverlay');
473
+ this.prepareFor(element, visual);
474
+
475
+ this.position(visual);
476
+ that.timers.show = setTimeout(function(){
477
+ that.element.css('display', '');
478
+ that.timers.show = setTimeout(function(){
479
+ that.element.addClass('ws-po-visible').trigger('wspopovershow');
480
+ }, 9);
481
+ }, 9);
482
+ $(document).on('focusin'+this.eventns+' mousedown'+this.eventns, function(e){
483
+ if(that.options.hideOnBlur && !that.stopBlur && !that.isInElement(that.lastElement[0] || document.body, e.target) && !that.isInElement(element[0] || document.body, e.target) && !that.isInElement(that.element[0], e.target)){
484
+ that.hide();
485
+ }
486
+ });
487
+ $(window).on('resize'+this.eventns + ' pospopover'+this.eventns, function(){
488
+ clearTimeout(that.timers.repos);
489
+ that.timers.repos = setTimeout(function(){
490
+ that.position(visual);
491
+ }, 900);
492
+ });
513
493
  },
514
- getMessage: function(elem, message){
515
- if (!message) {
516
- message = getContentValidationMessage(elem[0]) || elem.prop('customValidationMessage') || elem.prop('validationMessage');
494
+ prepareFor: function(element, visual){
495
+ var onBlur;
496
+ var opts = $.extend({}, this.options, $(element.prop('form') || []).data('wspopover') || {}, element.data('wspopover'));
497
+ var that = this;
498
+ var css = {};
499
+ this.lastElement = $(element).getShadowFocusElement();
500
+ if(opts.appendTo == 'element'){
501
+ this.element.insertAfter(element);
502
+ } else {
503
+ this.element.appendTo(opts.appendTo);
517
504
  }
518
- if (message) {
519
- $('span.va-box', errorBubble).text(message);
505
+
506
+ this.element.attr({
507
+ 'data-class': element.prop('className'),
508
+ 'data-id': element.prop('id')
509
+ });
510
+
511
+ css[minWidth] = opts.constrainWidth ? visual.outerWidth() : '';
512
+
513
+ this.element.css(css);
514
+
515
+ if(opts.hideOnBlur){
516
+ onBlur = function(e){
517
+ if(that.stopBlur){
518
+ e.stopImmediatePropagation();
519
+ } else {
520
+ that.hide();
521
+ }
522
+ };
523
+
524
+ that.timers.bindBlur = setTimeout(function(){
525
+ that.lastElement.off(that.eventns).on('focusout'+that.eventns + ' blur'+that.eventns, onBlur);
526
+ that.lastElement.getNativeElement().off(that.eventns);
527
+ }, 10);
528
+
529
+
520
530
  }
521
- else {
522
- this.hide();
531
+
532
+ if(!this.prepared){
533
+
534
+ if($.fn.bgIframe){
535
+ this.element.bgIframe();
536
+ }
523
537
  }
538
+ this.prepared = true;
524
539
  },
525
- position: function(elem, offset){
526
- offset = offset ? $.extend({}, offset) : api.getOffsetFromBody(elem);
527
- offset.top += elem.outerHeight();
528
- errorBubble.css(offset);
529
- },
530
- show: function(){
531
- if(errorBubble.css('display') === 'none'){
532
- errorBubble.css({opacity: 0}).show();
533
- }
534
- errorBubble.addClass('va-visible').fadeTo(400, 1);
540
+ clear: function(){
541
+ $(window).off(this.eventns);
542
+ $(document).off(this.eventns);
543
+
544
+ this.stopBlur = false;
545
+ $.each(this.timers, function(timerName, val){
546
+ clearTimeout(val);
547
+ });
535
548
  },
536
549
  hide: function(){
537
- errorBubble.removeClass('va-visible').fadeOut();
538
- },
539
- clear: function(){
540
- clearTimeout(focusTimer);
541
- clearTimeout(hideTimer);
542
- $(document).unbind('.validityalert');
543
- $(window).unbind('.validityalert');
544
- errorBubble.stop().removeAttr('for');
550
+ var e = $.Event('wspopoverbeforehide');
551
+ this.element.trigger(e);
552
+ if(e.isDefaultPrevented() || !this.isVisible){return;}
553
+ this.isVisible = false;
554
+ var that = this;
555
+ var forceHide = function(){
556
+ that.element.css('display', 'none').attr({'data-id': '', 'data-class': '', 'hidden': 'hidden'});
557
+ clearTimeout(that.timers.forcehide);
558
+ };
559
+ this.clear();
560
+ this.element.removeClass('ws-po-visible').trigger('wspopoverhide');
561
+ $(window).on('resize'+this.eventns, forceHide);
562
+ that.timers.forcehide = setTimeout(forceHide, 999);
545
563
  },
546
- _create: function(){
547
- if(errorBubble){return;}
548
- errorBubble = api.errorBubble = $('<'+alertElem+' class="validity-alert-wrapper" role="alert"><span class="validity-alert"><span class="va-arrow"><span class="va-arrow-box"></span></span><span class="va-box"></span></span></'+alertElem+'>').css({position: 'absolute', display: 'none'});
549
- webshims.ready('DOM', function(){
550
- errorBubble.appendTo('body');
551
- if($.fn.bgIframe){
552
- errorBubble.bgIframe();
553
- }
554
- });
564
+ position: function(element){
565
+ var offset = webshims.getRelOffset(this.element.css({marginTop: 0, marginLeft: 0, marginRight: 0, marginBottom: 0}).removeAttr('hidden'), element);
566
+ offset.top += element.outerHeight();
567
+ this.element.css({marginTop: '', marginLeft: '', marginRight: '', marginBottom: ''}).css(offset);
555
568
  }
556
569
  };
557
570
 
571
+ webshims.wsPopover.id = 0;
558
572
 
559
- boundHide = $.proxy(api, 'hide');
573
+ /* some extra validation UI */
574
+ webshims.validityAlert = (function(){
575
+
576
+
577
+ var focusTimer = false;
578
+
579
+ var api = webshims.objectCreate(webshims.wsPopover, {}, options.messagePopover);
580
+ var boundHide = api.hide.bind(api);
581
+
582
+ api.element.addClass('validity-alert').attr({role: 'alert'});
583
+ $.extend(api, {
584
+ hideDelay: 5000,
585
+ showFor: function(elem, message, noFocusElem, noBubble){
586
+
587
+ elem = $(elem).getNativeElement();
588
+ this.clear();
589
+ this.hide();
590
+ if(!noBubble){
591
+ this.getMessage(elem, message);
592
+
593
+ this.show(elem);
594
+ if(this.hideDelay){
595
+ this.timers.delayedHide = setTimeout(boundHide, this.hideDelay);
596
+ }
597
+
598
+ }
599
+
600
+ if(!noFocusElem){
601
+ this.setFocus(elem);
602
+ }
603
+ },
604
+ setFocus: function(element){
605
+ var focusElem = $(element).getShadowFocusElement();
606
+ var scrollTop = webshims.scrollRoot.scrollTop();
607
+ var elemTop = focusElem.offset().top - 30;
608
+ var smooth;
609
+
610
+ if(scrollTop > elemTop){
611
+ webshims.scrollRoot.animate(
612
+ {scrollTop: elemTop - 5},
613
+ {
614
+ queue: false,
615
+ duration: Math.max( Math.min( 600, (scrollTop - elemTop) * 1.5 ), 80 )
616
+ }
617
+ );
618
+ smooth = true;
619
+ }
620
+ try {
621
+ focusElem[0].focus();
622
+ } catch(e){}
623
+ if(smooth){
624
+ webshims.scrollRoot.scrollTop(scrollTop);
625
+ setTimeout(function(){
626
+ webshims.scrollRoot.scrollTop(scrollTop);
627
+ }, 0);
628
+ }
629
+
630
+ $(window).triggerHandler('pospopover'+this.eventns);
631
+ },
632
+ getMessage: function(elem, message){
633
+ if (!message) {
634
+ message = getContentValidationMessage(elem[0]) || elem.prop('customValidationMessage') || elem.prop('validationMessage');
635
+ }
636
+ if (message) {
637
+ api.contentElement.text(message);
638
+ } else {
639
+ this.hide();
640
+ }
641
+ }
642
+ });
643
+
644
+
645
+ return api;
646
+ })();
560
647
 
561
- return api;
562
- })();
563
-
564
-
565
- /* extension, but also used to fix native implementation workaround/bugfixes */
566
- (function(){
567
- var firstEvent,
568
- invalids = [],
569
- stopSubmitTimer,
570
- form
571
- ;
572
648
 
573
- $(document).on('invalid', function(e){
574
- if(e.wrongWebkitInvalid){return;}
575
- var jElm = $(e.target);
576
- var shadowElem = jElm.getShadowElement();
577
- if(!shadowElem.hasClass(invalidClass)){
578
- shadowElem.addClass(invalidClasses).removeClass(validClasses);
579
- setTimeout(function(){
580
- $(e.target).trigger('changedinvalid').trigger('changedvaliditystate');
581
- }, 0);
582
- }
649
+ /* extension, but also used to fix native implementation workaround/bugfixes */
650
+ (function(){
651
+ var firstEvent,
652
+ invalids = [],
653
+ stopSubmitTimer,
654
+ form
655
+ ;
583
656
 
584
- if(!firstEvent){
585
- //trigger firstinvalid
586
- firstEvent = $.Event('firstinvalid');
587
- firstEvent.isInvalidUIPrevented = e.isDefaultPrevented;
588
- var firstSystemInvalid = $.Event('firstinvalidsystem');
589
- $(document).triggerHandler(firstSystemInvalid, {element: e.target, form: e.target.form, isInvalidUIPrevented: e.isDefaultPrevented});
590
- jElm.trigger(firstEvent);
591
- }
592
-
593
- //if firstinvalid was prevented all invalids will be also prevented
594
- if( firstEvent && firstEvent.isDefaultPrevented() ){
595
- e.preventDefault();
596
- }
597
- invalids.push(e.target);
598
- e.extraData = 'fix';
599
- clearTimeout(stopSubmitTimer);
600
- stopSubmitTimer = setTimeout(function(){
601
- var lastEvent = {type: 'lastinvalid', cancelable: false, invalidlist: $(invalids)};
602
- //reset firstinvalid
603
- firstEvent = false;
604
- invalids = [];
605
- $(e.target).trigger(lastEvent, lastEvent);
606
- }, 9);
607
- jElm = null;
608
- shadowElem = null;
609
- });
610
- })();
611
-
612
- $.fn.getErrorMessage = function(){
613
- var message = '';
614
- var elem = this[0];
615
- if(elem){
616
- message = getContentValidationMessage(elem) || $.prop(elem, 'customValidationMessage') || $.prop(elem, 'validationMessage');
617
- }
618
- return message;
619
- };
657
+ $(document).on('invalid', function(e){
658
+ if(e.wrongWebkitInvalid){return;}
659
+ var jElm = $(e.target);
660
+ var shadowElem = jElm.getShadowElement();
661
+ if(!shadowElem.hasClass(invalidClass)){
662
+ shadowElem.addClass(invalidClass).removeClass(validClass);
663
+ setTimeout(function(){
664
+ $(e.target).trigger('changedinvalid').trigger('changedvaliditystate');
665
+ }, 0);
666
+ }
667
+
668
+ if(!firstEvent){
669
+ //trigger firstinvalid
670
+ firstEvent = $.Event('firstinvalid');
671
+ firstEvent.isInvalidUIPrevented = e.isDefaultPrevented;
672
+ var firstSystemInvalid = $.Event('firstinvalidsystem');
673
+ $(document).triggerHandler(firstSystemInvalid, {element: e.target, form: e.target.form, isInvalidUIPrevented: e.isDefaultPrevented});
674
+ jElm.trigger(firstEvent);
675
+ }
620
676
 
621
- if(options.replaceValidationUI){
622
- webshims.ready('DOM forms', function(){
623
- $(document).on('firstinvalid', function(e){
624
- if(!e.isInvalidUIPrevented()){
677
+ //if firstinvalid was prevented all invalids will be also prevented
678
+ if( firstEvent && firstEvent.isDefaultPrevented() ){
625
679
  e.preventDefault();
626
- $.webshims.validityAlert.showFor( e.target );
627
680
  }
681
+ invalids.push(e.target);
682
+ e.extraData = 'fix';
683
+ clearTimeout(stopSubmitTimer);
684
+ stopSubmitTimer = setTimeout(function(){
685
+ var lastEvent = {type: 'lastinvalid', cancelable: false, invalidlist: $(invalids)};
686
+ //reset firstinvalid
687
+ firstEvent = false;
688
+ invalids = [];
689
+ $(e.target).trigger(lastEvent, lastEvent);
690
+ }, 9);
691
+ jElm = null;
692
+ shadowElem = null;
628
693
  });
629
- });
630
- }
631
- });
694
+ })();
695
+
696
+ $.fn.getErrorMessage = function(){
697
+ var message = '';
698
+ var elem = this[0];
699
+ if(elem){
700
+ message = getContentValidationMessage(elem) || $.prop(elem, 'customValidationMessage') || $.prop(elem, 'validationMessage');
701
+ }
702
+ return message;
703
+ };
704
+
705
+ if(options.replaceValidationUI){
706
+ if(options.overrideMessages && (options.customMessages || options.customMessages == null)){
707
+ options.customMessages = true;
708
+ options.overrideMessages = false;
709
+ webshims.info("set overrideMessages to false. Use customMessages instead");
710
+ }
711
+ webshims.ready('DOM forms', function(){
712
+ $(document).on('firstinvalid', function(e){
713
+ if(!e.isInvalidUIPrevented()){
714
+ e.preventDefault();
715
+ $.webshims.validityAlert.showFor( e.target );
716
+ }
717
+ });
718
+ });
719
+ }
720
+ });
632
721
 
633
722
  })(jQuery);