webshims-rails 0.3 → 0.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (140) hide show
  1. data/lib/webshims-rails.rb +1 -1
  2. data/lib/webshims-rails/version.rb +2 -2
  3. data/readme.textile +5 -3
  4. data/vendor/assets/javascripts/webshims/dev/extras/custom-validity.js +261 -0
  5. data/vendor/assets/javascripts/webshims/dev/extras/modernizr-custom.js +535 -0
  6. data/vendor/assets/javascripts/webshims/dev/extras/mousepress.js +60 -0
  7. data/vendor/assets/javascripts/webshims/dev/polyfiller.js +1171 -0
  8. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvas/README +62 -0
  9. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvas/canvas2png.js +42 -0
  10. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvas/flashcanvas.js +28 -0
  11. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvas/flashcanvas.swf +0 -0
  12. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvas/proxy.php +73 -0
  13. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvas/save.php +49 -0
  14. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvasPro/README +82 -0
  15. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvasPro/canvas2png.js +42 -0
  16. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvasPro/flash10canvas.swf +0 -0
  17. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvasPro/flash9canvas.swf +0 -0
  18. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvasPro/flashcanvas.js +31 -0
  19. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvasPro/proxy.php +73 -0
  20. data/vendor/assets/javascripts/webshims/dev/shims/FlashCanvasPro/save.php +49 -0
  21. data/vendor/assets/javascripts/webshims/dev/shims/combos/1.js +1710 -0
  22. data/vendor/assets/javascripts/webshims/dev/shims/combos/10.js +3317 -0
  23. data/vendor/assets/javascripts/webshims/dev/shims/combos/11.js +1585 -0
  24. data/vendor/assets/javascripts/webshims/dev/shims/combos/12.js +1587 -0
  25. data/vendor/assets/javascripts/webshims/dev/shims/combos/13.js +1054 -0
  26. data/vendor/assets/javascripts/webshims/dev/shims/combos/14.js +476 -0
  27. data/vendor/assets/javascripts/webshims/dev/shims/combos/15.js +314 -0
  28. data/vendor/assets/javascripts/webshims/dev/shims/combos/16.js +2101 -0
  29. data/vendor/assets/javascripts/webshims/dev/shims/combos/17.js +2264 -0
  30. data/vendor/assets/javascripts/webshims/dev/shims/combos/18.js +2161 -0
  31. data/vendor/assets/javascripts/webshims/dev/shims/combos/19.js +2244 -0
  32. data/vendor/assets/javascripts/webshims/dev/shims/combos/2.js +2294 -0
  33. data/vendor/assets/javascripts/webshims/dev/shims/combos/20.js +1607 -0
  34. data/vendor/assets/javascripts/webshims/dev/shims/combos/21.js +1635 -0
  35. data/vendor/assets/javascripts/webshims/dev/shims/combos/22.js +2409 -0
  36. data/vendor/assets/javascripts/webshims/dev/shims/combos/23.js +2168 -0
  37. data/vendor/assets/javascripts/webshims/dev/shims/combos/24.js +2777 -0
  38. data/vendor/assets/javascripts/webshims/dev/shims/combos/25.js +2204 -0
  39. data/vendor/assets/javascripts/webshims/dev/shims/combos/26.js +2863 -0
  40. data/vendor/assets/javascripts/webshims/dev/shims/combos/27.js +4079 -0
  41. data/vendor/assets/javascripts/webshims/dev/shims/combos/3.js +2971 -0
  42. data/vendor/assets/javascripts/webshims/dev/shims/combos/4.js +823 -0
  43. data/vendor/assets/javascripts/webshims/dev/shims/combos/5.js +1078 -0
  44. data/vendor/assets/javascripts/webshims/dev/shims/combos/59.js +1754 -0
  45. data/vendor/assets/javascripts/webshims/dev/shims/combos/6.js +1230 -0
  46. data/vendor/assets/javascripts/webshims/dev/shims/combos/7.js +1485 -0
  47. data/vendor/assets/javascripts/webshims/dev/shims/combos/8.js +1442 -0
  48. data/vendor/assets/javascripts/webshims/dev/shims/combos/9.js +2515 -0
  49. data/vendor/assets/javascripts/webshims/dev/shims/details.js +146 -0
  50. data/vendor/assets/javascripts/webshims/dev/shims/dom-extend.js +908 -0
  51. data/vendor/assets/javascripts/webshims/dev/shims/es5.js +802 -0
  52. data/vendor/assets/javascripts/webshims/dev/shims/excanvas.js +924 -0
  53. data/vendor/assets/javascripts/webshims/dev/shims/form-core.js +660 -0
  54. data/vendor/assets/javascripts/webshims/dev/shims/form-datalist.js +677 -0
  55. data/vendor/assets/javascripts/webshims/dev/shims/form-message.js +164 -0
  56. data/vendor/assets/javascripts/webshims/dev/shims/form-native-extend.js +256 -0
  57. data/vendor/assets/javascripts/webshims/dev/shims/form-native-fix.js +261 -0
  58. data/vendor/assets/javascripts/webshims/dev/shims/form-number-date-api.js +384 -0
  59. data/vendor/assets/javascripts/webshims/dev/shims/form-number-date-ui.js +847 -0
  60. data/vendor/assets/javascripts/webshims/dev/shims/form-shim-extend.js +1472 -0
  61. data/vendor/assets/javascripts/webshims/dev/shims/geolocation.js +168 -0
  62. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-ar.js +32 -0
  63. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-ch-ZN.js +32 -0
  64. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-de.txt +33 -0
  65. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-el.js +32 -0
  66. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-en.txt +34 -0
  67. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-es.js +32 -0
  68. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-fr.js +32 -0
  69. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-he.js +32 -0
  70. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-hi.js +32 -0
  71. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-hu.js +32 -0
  72. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-it.js +32 -0
  73. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-ja.js +32 -0
  74. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-nl.js +32 -0
  75. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-pt-PT.js +32 -0
  76. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-ru.js +32 -0
  77. data/vendor/assets/javascripts/webshims/dev/shims/i18n/errormessages-sv.js +32 -0
  78. data/vendor/assets/javascripts/webshims/dev/shims/json-storage.js +308 -0
  79. data/vendor/assets/javascripts/webshims/dev/shims/jwplayer/license.txt +1 -0
  80. data/vendor/assets/javascripts/webshims/dev/shims/jwplayer/player.swf +0 -0
  81. data/vendor/assets/javascripts/webshims/dev/shims/jwplayer/readme.html +87 -0
  82. data/vendor/assets/javascripts/webshims/dev/shims/mediaelement-core.js +534 -0
  83. data/vendor/assets/javascripts/webshims/dev/shims/mediaelement-native-fix.js +99 -0
  84. data/vendor/assets/javascripts/webshims/dev/shims/mediaelement-swf.js +1074 -0
  85. data/vendor/assets/javascripts/webshims/dev/shims/mediaelement-yt.js +543 -0
  86. data/vendor/assets/javascripts/webshims/dev/shims/styles/details-arrows.png +0 -0
  87. data/vendor/assets/javascripts/webshims/dev/shims/styles/forms.png +0 -0
  88. data/vendor/assets/javascripts/webshims/dev/shims/styles/polyfill-loader.gif +0 -0
  89. data/vendor/assets/javascripts/webshims/dev/shims/styles/shim.css +677 -0
  90. data/vendor/assets/javascripts/webshims/dev/shims/swf/jwwebshims.swf +0 -0
  91. data/vendor/assets/javascripts/webshims/dev/shims/swf/localStorage.swf +0 -0
  92. data/vendor/assets/javascripts/webshims/dev/shims/track-ui.js +292 -0
  93. data/vendor/assets/javascripts/webshims/dev/shims/track.js +763 -0
  94. data/vendor/assets/javascripts/webshims/minified/extras/modernizr-custom.js +20 -20
  95. data/vendor/assets/javascripts/webshims/minified/polyfiller.js +29 -29
  96. data/vendor/assets/javascripts/webshims/minified/shims/combos/1.js +37 -33
  97. data/vendor/assets/javascripts/webshims/minified/shims/combos/10.js +83 -76
  98. data/vendor/assets/javascripts/webshims/minified/shims/combos/11.js +44 -42
  99. data/vendor/assets/javascripts/webshims/minified/shims/combos/12.js +43 -38
  100. data/vendor/assets/javascripts/webshims/minified/shims/combos/13.js +27 -25
  101. data/vendor/assets/javascripts/webshims/minified/shims/combos/16.js +60 -55
  102. data/vendor/assets/javascripts/webshims/minified/shims/combos/17.js +68 -64
  103. data/vendor/assets/javascripts/webshims/minified/shims/combos/18.js +60 -59
  104. data/vendor/assets/javascripts/webshims/minified/shims/combos/19.js +66 -64
  105. data/vendor/assets/javascripts/webshims/minified/shims/combos/2.js +74 -69
  106. data/vendor/assets/javascripts/webshims/minified/shims/combos/20.js +46 -43
  107. data/vendor/assets/javascripts/webshims/minified/shims/combos/21.js +52 -47
  108. data/vendor/assets/javascripts/webshims/minified/shims/combos/22.js +61 -57
  109. data/vendor/assets/javascripts/webshims/minified/shims/combos/23.js +68 -60
  110. data/vendor/assets/javascripts/webshims/minified/shims/combos/24.js +82 -77
  111. data/vendor/assets/javascripts/webshims/minified/shims/combos/25.js +58 -0
  112. data/vendor/assets/javascripts/webshims/minified/shims/combos/26.js +80 -0
  113. data/vendor/assets/javascripts/webshims/minified/shims/combos/27.js +103 -0
  114. data/vendor/assets/javascripts/webshims/minified/shims/combos/3.js +96 -91
  115. data/vendor/assets/javascripts/webshims/minified/shims/combos/4.js +30 -31
  116. data/vendor/assets/javascripts/webshims/minified/shims/combos/5.js +37 -39
  117. data/vendor/assets/javascripts/webshims/minified/shims/combos/59.js +59 -61
  118. data/vendor/assets/javascripts/webshims/minified/shims/combos/6.js +31 -29
  119. data/vendor/assets/javascripts/webshims/minified/shims/combos/7.js +38 -37
  120. data/vendor/assets/javascripts/webshims/minified/shims/combos/8.js +38 -33
  121. data/vendor/assets/javascripts/webshims/minified/shims/combos/9.js +68 -63
  122. data/vendor/assets/javascripts/webshims/minified/shims/dom-extend.js +22 -20
  123. data/vendor/assets/javascripts/webshims/minified/shims/es5.js +15 -14
  124. data/vendor/assets/javascripts/webshims/minified/shims/form-core.js +22 -22
  125. data/vendor/assets/javascripts/webshims/minified/shims/form-datalist.js +22 -22
  126. data/vendor/assets/javascripts/webshims/minified/shims/form-message.js +8 -9
  127. data/vendor/assets/javascripts/webshims/minified/shims/form-native-extend.js +7 -8
  128. data/vendor/assets/javascripts/webshims/minified/shims/form-number-date-ui.js +23 -21
  129. data/vendor/assets/javascripts/webshims/minified/shims/form-shim-extend.js +44 -33
  130. data/vendor/assets/javascripts/webshims/minified/shims/i18n/errormessages-sv.js +3 -0
  131. data/vendor/assets/javascripts/webshims/minified/shims/jwplayer/player.swf +0 -0
  132. data/vendor/assets/javascripts/webshims/minified/shims/jwplayer/readme.html +86 -86
  133. data/vendor/assets/javascripts/webshims/minified/shims/mediaelement-core.js +16 -13
  134. data/vendor/assets/javascripts/webshims/minified/shims/mediaelement-swf.js +30 -30
  135. data/vendor/assets/javascripts/webshims/minified/shims/mediaelement-yt.js +14 -0
  136. data/vendor/assets/javascripts/webshims/minified/shims/styles/shim.css +71 -10
  137. data/vendor/assets/javascripts/webshims/minified/shims/track-ui.js +9 -0
  138. data/vendor/assets/javascripts/webshims/minified/shims/track.js +20 -0
  139. metadata +101 -5
  140. data/vendor/assets/javascripts/webshims/minified/shims/form-output.js +0 -5
@@ -0,0 +1,1585 @@
1
+ //DOM-Extension helper
2
+ jQuery.webshims.register('dom-extend', function($, webshims, window, document, undefined){
3
+ "use strict";
4
+ //shortcus
5
+ var modules = webshims.modules;
6
+ var listReg = /\s*,\s*/;
7
+
8
+ //proxying attribute
9
+ var olds = {};
10
+ var havePolyfill = {};
11
+ var extendedProps = {};
12
+ var extendQ = {};
13
+ var modifyProps = {};
14
+
15
+ var oldVal = $.fn.val;
16
+ var singleVal = function(elem, name, val, pass, _argless){
17
+ return (_argless) ? oldVal.call($(elem)) : oldVal.call($(elem), val);
18
+ };
19
+ $.fn.val = function(val){
20
+ var elem = this[0];
21
+ if(arguments.length && val == null){
22
+ val = '';
23
+ }
24
+ if(!arguments.length){
25
+ if(!elem || elem.nodeType !== 1){return oldVal.call(this);}
26
+ return $.prop(elem, 'value', val, 'val', true);
27
+ }
28
+ if($.isArray(val)){
29
+ return oldVal.apply(this, arguments);
30
+ }
31
+ var isFunction = $.isFunction(val);
32
+ return this.each(function(i){
33
+ elem = this;
34
+ if(elem.nodeType === 1){
35
+ if(isFunction){
36
+ var genVal = val.call( elem, i, $.prop(elem, 'value', undefined, 'val', true));
37
+ if(genVal == null){
38
+ genVal = '';
39
+ }
40
+ $.prop(elem, 'value', genVal, 'val') ;
41
+ } else {
42
+ $.prop(elem, 'value', val, 'val');
43
+ }
44
+ }
45
+ });
46
+ };
47
+
48
+ var dataID = '_webshimsLib'+ (Math.round(Math.random() * 1000));
49
+ var elementData = function(elem, key, val){
50
+ elem = elem.jquery ? elem[0] : elem;
51
+ if(!elem){return val || {};}
52
+ var data = $.data(elem, dataID);
53
+ if(val !== undefined){
54
+ if(!data){
55
+ data = $.data(elem, dataID, {});
56
+ }
57
+ if(key){
58
+ data[key] = val;
59
+ }
60
+ }
61
+
62
+ return key ? data && data[key] : data;
63
+ };
64
+
65
+
66
+ [{name: 'getNativeElement', prop: 'nativeElement'}, {name: 'getShadowElement', prop: 'shadowElement'}, {name: 'getShadowFocusElement', prop: 'shadowFocusElement'}].forEach(function(data){
67
+ $.fn[data.name] = function(){
68
+ return this.map(function(){
69
+ var shadowData = elementData(this, 'shadowData');
70
+ return shadowData && shadowData[data.prop] || this;
71
+ });
72
+ };
73
+ });
74
+
75
+
76
+ ['removeAttr', 'prop', 'attr'].forEach(function(type){
77
+ olds[type] = $[type];
78
+ $[type] = function(elem, name, value, pass, _argless){
79
+ var isVal = (pass == 'val');
80
+ var oldMethod = !isVal ? olds[type] : singleVal;
81
+ if( !elem || !havePolyfill[name] || elem.nodeType !== 1 || (!isVal && pass && type == 'attr' && $.attrFn[name]) ){
82
+ return oldMethod(elem, name, value, pass, _argless);
83
+ }
84
+
85
+ var nodeName = (elem.nodeName || '').toLowerCase();
86
+ var desc = extendedProps[nodeName];
87
+ var curType = (type == 'attr' && (value === false || value === null)) ? 'removeAttr' : type;
88
+ var propMethod;
89
+ var oldValMethod;
90
+ var ret;
91
+
92
+
93
+ if(!desc){
94
+ desc = extendedProps['*'];
95
+ }
96
+ if(desc){
97
+ desc = desc[name];
98
+ }
99
+
100
+ if(desc){
101
+ propMethod = desc[curType];
102
+ }
103
+
104
+ if(propMethod){
105
+ if(name == 'value'){
106
+ oldValMethod = propMethod.isVal;
107
+ propMethod.isVal = isVal;
108
+ }
109
+ if(curType === 'removeAttr'){
110
+ return propMethod.value.call(elem);
111
+ } else if(value === undefined){
112
+ return (propMethod.get) ?
113
+ propMethod.get.call(elem) :
114
+ propMethod.value
115
+ ;
116
+ } else if(propMethod.set) {
117
+ if(type == 'attr' && value === true){
118
+ value = name;
119
+ }
120
+
121
+ ret = propMethod.set.call(elem, value);
122
+ }
123
+ if(name == 'value'){
124
+ propMethod.isVal = oldValMethod;
125
+ }
126
+ } else {
127
+ ret = oldMethod(elem, name, value, pass, _argless);
128
+ }
129
+ if((value !== undefined || curType === 'removeAttr') && modifyProps[nodeName] && modifyProps[nodeName][name]){
130
+
131
+ var boolValue;
132
+ if(curType == 'removeAttr'){
133
+ boolValue = false;
134
+ } else if(curType == 'prop'){
135
+ boolValue = !!(value);
136
+ } else {
137
+ boolValue = true;
138
+ }
139
+
140
+ modifyProps[nodeName][name].forEach(function(fn){
141
+ if(!fn.only || (fn.only = 'prop' && type == 'prop') || (fn.only == 'attr' && type != 'prop')){
142
+ fn.call(elem, value, boolValue, (isVal) ? 'val' : curType, type);
143
+ }
144
+ });
145
+ }
146
+ return ret;
147
+ };
148
+
149
+ extendQ[type] = function(nodeName, prop, desc){
150
+
151
+ if(!extendedProps[nodeName]){
152
+ extendedProps[nodeName] = {};
153
+ }
154
+ if(!extendedProps[nodeName][prop]){
155
+ extendedProps[nodeName][prop] = {};
156
+ }
157
+ var oldDesc = extendedProps[nodeName][prop][type];
158
+ var getSup = function(propType, descriptor, oDesc){
159
+ if(descriptor && descriptor[propType]){
160
+ return descriptor[propType];
161
+ }
162
+ if(oDesc && oDesc[propType]){
163
+ return oDesc[propType];
164
+ }
165
+ if(type == 'prop' && prop == 'value'){
166
+ return function(value){
167
+ var elem = this;
168
+ return (desc.isVal) ?
169
+ singleVal(elem, prop, value, false, (arguments.length === 0)) :
170
+ olds[type](elem, prop, value)
171
+ ;
172
+ };
173
+ }
174
+ if(type == 'prop' && propType == 'value' && desc.value.apply){
175
+ return function(value){
176
+ var sup = olds[type](this, prop);
177
+ if(sup && sup.apply){
178
+ sup = sup.apply(this, arguments);
179
+ }
180
+ return sup;
181
+ };
182
+ }
183
+ return function(value){
184
+ return olds[type](this, prop, value);
185
+ };
186
+ };
187
+ extendedProps[nodeName][prop][type] = desc;
188
+ if(desc.value === undefined){
189
+ if(!desc.set){
190
+ desc.set = desc.writeable ?
191
+ getSup('set', desc, oldDesc) :
192
+ (webshims.cfg.useStrict && prop == 'prop') ?
193
+ function(){throw(prop +' is readonly on '+ nodeName);} :
194
+ $.noop
195
+ ;
196
+ }
197
+ if(!desc.get){
198
+ desc.get = getSup('get', desc, oldDesc);
199
+ }
200
+
201
+ }
202
+
203
+ ['value', 'get', 'set'].forEach(function(descProp){
204
+ if(desc[descProp]){
205
+ desc['_sup'+descProp] = getSup(descProp, oldDesc);
206
+ }
207
+ });
208
+ };
209
+
210
+ });
211
+
212
+ //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
213
+ var isExtendNativeSave = (!$.browser.msie || parseInt($.browser.version, 10) > 8);
214
+ var extendNativeValue = (function(){
215
+ var UNKNOWN = webshims.getPrototypeOf(document.createElement('foobar'));
216
+ var has = Object.prototype.hasOwnProperty;
217
+ return function(nodeName, prop, desc){
218
+ var elem = document.createElement(nodeName);
219
+ var elemProto = webshims.getPrototypeOf(elem);
220
+ if( isExtendNativeSave && elemProto && UNKNOWN !== elemProto && ( !elem[prop] || !has.call(elem, prop) ) ){
221
+ var sup = elem[prop];
222
+ desc._supvalue = function(){
223
+ if(sup && sup.apply){
224
+ return sup.apply(this, arguments);
225
+ }
226
+ return sup;
227
+ };
228
+ elemProto[prop] = desc.value;
229
+ } else {
230
+ desc._supvalue = function(){
231
+ var data = elementData(this, 'propValue');
232
+ if(data && data[prop] && data[prop].apply){
233
+ return data[prop].apply(this, arguments);
234
+ }
235
+ return data && data[prop];
236
+ };
237
+ initProp.extendValue(nodeName, prop, desc.value);
238
+ }
239
+ desc.value._supvalue = desc._supvalue;
240
+ };
241
+ })();
242
+
243
+ var initProp = (function(){
244
+
245
+ var initProps = {};
246
+
247
+ webshims.addReady(function(context, contextElem){
248
+ var nodeNameCache = {};
249
+ var getElementsByName = function(name){
250
+ if(!nodeNameCache[name]){
251
+ nodeNameCache[name] = $(context.getElementsByTagName(name));
252
+ if(contextElem[0] && $.nodeName(contextElem[0], name)){
253
+ nodeNameCache[name] = nodeNameCache[name].add(contextElem);
254
+ }
255
+ }
256
+ };
257
+
258
+
259
+ $.each(initProps, function(name, fns){
260
+ getElementsByName(name);
261
+ if(!fns || !fns.forEach){
262
+ webshims.warn('Error: with '+ name +'-property. methods: '+ fns);
263
+ return;
264
+ }
265
+ fns.forEach(function(fn){
266
+ nodeNameCache[name].each(fn);
267
+ });
268
+ });
269
+ nodeNameCache = null;
270
+ });
271
+
272
+ var tempCache;
273
+ var emptyQ = $([]);
274
+ var createNodeNameInit = function(nodeName, fn){
275
+ if(!initProps[nodeName]){
276
+ initProps[nodeName] = [fn];
277
+ } else {
278
+ initProps[nodeName].push(fn);
279
+ }
280
+ if($.isDOMReady){
281
+ (tempCache || $( document.getElementsByTagName(nodeName) )).each(fn);
282
+ }
283
+ };
284
+
285
+ var elementExtends = {};
286
+ return {
287
+ createTmpCache: function(nodeName){
288
+ if($.isDOMReady){
289
+ tempCache = tempCache || $( document.getElementsByTagName(nodeName) );
290
+ }
291
+ return tempCache || emptyQ;
292
+ },
293
+ flushTmpCache: function(){
294
+ tempCache = null;
295
+ },
296
+ content: function(nodeName, prop){
297
+ createNodeNameInit(nodeName, function(){
298
+ var val = $.attr(this, prop);
299
+ if(val != null){
300
+ $.attr(this, prop, val);
301
+ }
302
+ });
303
+ },
304
+ createElement: function(nodeName, fn){
305
+ createNodeNameInit(nodeName, fn);
306
+ },
307
+ extendValue: function(nodeName, prop, value){
308
+ createNodeNameInit(nodeName, function(){
309
+ $(this).each(function(){
310
+ var data = elementData(this, 'propValue', {});
311
+ data[prop] = this[prop];
312
+ this[prop] = value;
313
+ });
314
+ });
315
+ }
316
+ };
317
+ })();
318
+
319
+ var createPropDefault = function(descs, removeType){
320
+ if(descs.defaultValue === undefined){
321
+ descs.defaultValue = '';
322
+ }
323
+ if(!descs.removeAttr){
324
+ descs.removeAttr = {
325
+ value: function(){
326
+ descs[removeType || 'prop'].set.call(this, descs.defaultValue);
327
+ descs.removeAttr._supvalue.call(this);
328
+ }
329
+ };
330
+ }
331
+ if(!descs.attr){
332
+ descs.attr = {};
333
+ }
334
+ };
335
+
336
+ $.extend(webshims, {
337
+
338
+ getID: (function(){
339
+ var ID = new Date().getTime();
340
+ return function(elem){
341
+ elem = $(elem);
342
+ var id = elem.attr('id');
343
+ if(!id){
344
+ ID++;
345
+ id = 'ID-'+ ID;
346
+ elem.attr('id', id);
347
+ }
348
+ return id;
349
+ };
350
+ })(),
351
+ extendUNDEFProp: function(obj, props){
352
+ $.each(props, function(name, prop){
353
+ if( !(name in obj) ){
354
+ obj[name] = prop;
355
+ }
356
+ });
357
+ },
358
+ //http://www.w3.org/TR/html5/common-dom-interfaces.html#reflect
359
+ createPropDefault: createPropDefault,
360
+ data: elementData,
361
+ moveToFirstEvent: (function(){
362
+ var getData = $._data ? '_data' : 'data';
363
+ return function(elem, eventType, bindType){
364
+ var events = ($[getData](elem, 'events') || {})[eventType];
365
+ var fn;
366
+
367
+ if(events && events.length > 1){
368
+ fn = events.pop();
369
+ if(!bindType){
370
+ bindType = 'bind';
371
+ }
372
+ if(bindType == 'bind' && events.delegateCount){
373
+ events.splice( events.delegateCount, 0, fn);
374
+ } else {
375
+ events.unshift( fn );
376
+ }
377
+
378
+
379
+ }
380
+ elem = null;
381
+ };
382
+ })(),
383
+ addShadowDom: (function(){
384
+ var resizeTimer;
385
+ var lastHeight;
386
+ var lastWidth;
387
+ var handler;
388
+ var docObserve = {
389
+ init: false,
390
+ start: function(){
391
+ if(!this.init){
392
+ this.init = true;
393
+ this.height = $(document).height();
394
+ this.width = $(document).width();
395
+ setInterval(function(){
396
+ var height = $(document).height();
397
+ var width = $(document).width();
398
+ if(height != docObserve.height || width != docObserve.width){
399
+ docObserve.height = height;
400
+ docObserve.width = width;
401
+ handler({type: 'docresize'});
402
+ }
403
+ }, 400);
404
+ }
405
+ }
406
+ };
407
+
408
+ handler = function(e){
409
+ clearTimeout(resizeTimer);
410
+ resizeTimer = setTimeout(function(){
411
+ if(e.type == 'resize'){
412
+ var width = $(window).width();
413
+ var height = $(window).width();
414
+ if(height == lastHeight && width == lastWidth){
415
+ return;
416
+ }
417
+ lastHeight = height;
418
+ lastWidth = width;
419
+ docObserve.height = $(document).height();
420
+ docObserve.width = $(document).width();
421
+ }
422
+ $.event.trigger('updateshadowdom');
423
+ }, 40);
424
+ };
425
+ $(window).bind('resize', handler);
426
+
427
+ $.event.customEvent.updateshadowdom = true;
428
+
429
+ return function(nativeElem, shadowElem, opts){
430
+ opts = opts || {};
431
+ if(nativeElem.jquery){
432
+ nativeElem = nativeElem[0];
433
+ }
434
+ if(shadowElem.jquery){
435
+ shadowElem = shadowElem[0];
436
+ }
437
+ var nativeData = $.data(nativeElem, dataID) || $.data(nativeElem, dataID, {});
438
+ var shadowData = $.data(shadowElem, dataID) || $.data(shadowElem, dataID, {});
439
+ var shadowFocusElementData = {};
440
+ if(!opts.shadowFocusElement){
441
+ opts.shadowFocusElement = shadowElem;
442
+ } else if(opts.shadowFocusElement){
443
+ if(opts.shadowFocusElement.jquery){
444
+ opts.shadowFocusElement = opts.shadowFocusElement[0];
445
+ }
446
+ shadowFocusElementData = $.data(opts.shadowFocusElement, dataID) || $.data(opts.shadowFocusElement, dataID, shadowFocusElementData);
447
+ }
448
+
449
+ nativeData.hasShadow = shadowElem;
450
+ shadowFocusElementData.nativeElement = shadowData.nativeElement = nativeElem;
451
+ shadowFocusElementData.shadowData = shadowData.shadowData = nativeData.shadowData = {
452
+ nativeElement: nativeElem,
453
+ shadowElement: shadowElem,
454
+ shadowFocusElement: opts.shadowFocusElement
455
+ };
456
+ if(opts.shadowChilds){
457
+ opts.shadowChilds.each(function(){
458
+ elementData(this, 'shadowData', shadowData.shadowData);
459
+ });
460
+ }
461
+
462
+ if(opts.data){
463
+ shadowFocusElementData.shadowData.data = shadowData.shadowData.data = nativeData.shadowData.data = opts.data;
464
+ }
465
+ opts = null;
466
+ docObserve.start();
467
+ }
468
+ })(),
469
+ propTypes: {
470
+ standard: function(descs, name){
471
+ createPropDefault(descs);
472
+ if(descs.prop){return;}
473
+ descs.prop = {
474
+ set: function(val){
475
+ descs.attr.set.call(this, ''+val);
476
+ },
477
+ get: function(){
478
+ return descs.attr.get.call(this) || descs.defaultValue;
479
+ }
480
+ };
481
+
482
+ },
483
+ "boolean": function(descs, name){
484
+
485
+ createPropDefault(descs);
486
+ if(descs.prop){return;}
487
+ descs.prop = {
488
+ set: function(val){
489
+ if(val){
490
+ descs.attr.set.call(this, "");
491
+ } else {
492
+ descs.removeAttr.value.call(this);
493
+ }
494
+ },
495
+ get: function(){
496
+ return descs.attr.get.call(this) != null;
497
+ }
498
+ };
499
+ },
500
+ "src": (function(){
501
+ var anchor = document.createElement('a');
502
+ anchor.style.display = "none";
503
+ return function(descs, name){
504
+
505
+ createPropDefault(descs);
506
+ if(descs.prop){return;}
507
+ descs.prop = {
508
+ set: function(val){
509
+ descs.attr.set.call(this, val);
510
+ },
511
+ get: function(){
512
+ var href = this.getAttribute(name);
513
+ var ret;
514
+ if(href == null){return '';}
515
+
516
+ anchor.setAttribute('href', href+'' );
517
+
518
+ if(!$.support.hrefNormalized){
519
+ try {
520
+ $(anchor).insertAfter(this);
521
+ ret = anchor.getAttribute('href', 4);
522
+ } catch(er){
523
+ ret = anchor.getAttribute('href', 4);
524
+ }
525
+ $(anchor).detach();
526
+ }
527
+ return ret || anchor.href;
528
+ }
529
+ };
530
+ };
531
+ })(),
532
+ enumarated: function(descs, name){
533
+
534
+ createPropDefault(descs);
535
+ if(descs.prop){return;}
536
+ descs.prop = {
537
+ set: function(val){
538
+ descs.attr.set.call(this, val);
539
+ },
540
+ get: function(){
541
+ var val = (descs.attr.get.call(this) || '').toLowerCase();
542
+ if(!val || descs.limitedTo.indexOf(val) == -1){
543
+ val = descs.defaultValue;
544
+ }
545
+ return val;
546
+ }
547
+ };
548
+ }
549
+
550
+ // ,unsignedLong: $.noop
551
+ // ,"doubble": $.noop
552
+ // ,"long": $.noop
553
+ // ,tokenlist: $.noop
554
+ // ,settableTokenlist: $.noop
555
+ },
556
+ reflectProperties: function(nodeNames, props){
557
+ if(typeof props == 'string'){
558
+ props = props.split(listReg);
559
+ }
560
+ props.forEach(function(prop){
561
+ webshims.defineNodeNamesProperty(nodeNames, prop, {
562
+ prop: {
563
+ set: function(val){
564
+ $.attr(this, prop, val);
565
+ },
566
+ get: function(){
567
+ return $.attr(this, prop) || '';
568
+ }
569
+ }
570
+ });
571
+ });
572
+ },
573
+ defineNodeNameProperty: function(nodeName, prop, descs){
574
+ havePolyfill[prop] = true;
575
+
576
+ if(descs.reflect){
577
+ webshims.propTypes[descs.propType || 'standard'](descs, prop);
578
+ }
579
+
580
+ ['prop', 'attr', 'removeAttr'].forEach(function(type){
581
+ var desc = descs[type];
582
+ if(desc){
583
+ if(type === 'prop'){
584
+ desc = $.extend({writeable: true}, desc);
585
+ } else {
586
+ desc = $.extend({}, desc, {writeable: true});
587
+ }
588
+
589
+ extendQ[type](nodeName, prop, desc);
590
+ if(nodeName != '*' && webshims.cfg.extendNative && type == 'prop' && desc.value && $.isFunction(desc.value)){
591
+ extendNativeValue(nodeName, prop, desc);
592
+ }
593
+ descs[type] = desc;
594
+ }
595
+ });
596
+ if(descs.initAttr){
597
+ initProp.content(nodeName, prop);
598
+ }
599
+ return descs;
600
+ },
601
+
602
+ defineNodeNameProperties: function(name, descs, propType, _noTmpCache){
603
+ var olddesc;
604
+ for(var prop in descs){
605
+ if(!_noTmpCache && descs[prop].initAttr){
606
+ initProp.createTmpCache(name);
607
+ }
608
+ if(propType){
609
+ if(descs[prop][propType]){
610
+ webshims.log('override: '+ name +'['+prop +'] for '+ propType);
611
+ } else {
612
+ descs[prop][propType] = {};
613
+ ['value', 'set', 'get'].forEach(function(copyProp){
614
+ if(copyProp in descs[prop]){
615
+ descs[prop][propType][copyProp] = descs[prop][copyProp];
616
+ delete descs[prop][copyProp];
617
+ }
618
+ });
619
+ }
620
+ }
621
+ descs[prop] = webshims.defineNodeNameProperty(name, prop, descs[prop]);
622
+ }
623
+ if(!_noTmpCache){
624
+ initProp.flushTmpCache();
625
+ }
626
+ return descs;
627
+ },
628
+
629
+ createElement: function(nodeName, create, descs){
630
+ var ret;
631
+ if($.isFunction(create)){
632
+ create = {
633
+ after: create
634
+ };
635
+ }
636
+ initProp.createTmpCache(nodeName);
637
+ if(create.before){
638
+ initProp.createElement(nodeName, create.before);
639
+ }
640
+ if(descs){
641
+ ret = webshims.defineNodeNameProperties(nodeName, descs, false, true);
642
+ }
643
+ if(create.after){
644
+ initProp.createElement(nodeName, create.after);
645
+ }
646
+ initProp.flushTmpCache();
647
+ return ret;
648
+ },
649
+ onNodeNamesPropertyModify: function(nodeNames, props, desc, only){
650
+ if(typeof nodeNames == 'string'){
651
+ nodeNames = nodeNames.split(listReg);
652
+ }
653
+ if($.isFunction(desc)){
654
+ desc = {set: desc};
655
+ }
656
+
657
+ nodeNames.forEach(function(name){
658
+ if(!modifyProps[name]){
659
+ modifyProps[name] = {};
660
+ }
661
+ if(typeof props == 'string'){
662
+ props = props.split(listReg);
663
+ }
664
+ if(desc.initAttr){
665
+ initProp.createTmpCache(name);
666
+ }
667
+ props.forEach(function(prop){
668
+ if(!modifyProps[name][prop]){
669
+ modifyProps[name][prop] = [];
670
+ havePolyfill[prop] = true;
671
+ }
672
+ if(desc.set){
673
+ if(only){
674
+ desc.set.only = only;
675
+ }
676
+ modifyProps[name][prop].push(desc.set);
677
+ }
678
+
679
+ if(desc.initAttr){
680
+ initProp.content(name, prop);
681
+ }
682
+ });
683
+ initProp.flushTmpCache();
684
+
685
+ });
686
+ },
687
+ defineNodeNamesBooleanProperty: function(elementNames, prop, descs){
688
+ if(!descs){
689
+ descs = {};
690
+ }
691
+ if($.isFunction(descs)){
692
+ descs.set = descs;
693
+ }
694
+ webshims.defineNodeNamesProperty(elementNames, prop, {
695
+ attr: {
696
+ set: function(val){
697
+ this.setAttribute(prop, val);
698
+ if(descs.set){
699
+ descs.set.call(this, true);
700
+ }
701
+ },
702
+ get: function(){
703
+ var ret = this.getAttribute(prop);
704
+ return (ret == null) ? undefined : prop;
705
+ }
706
+ },
707
+ removeAttr: {
708
+ value: function(){
709
+ this.removeAttribute(prop);
710
+ if(descs.set){
711
+ descs.set.call(this, false);
712
+ }
713
+ }
714
+ },
715
+ reflect: true,
716
+ propType: 'boolean',
717
+ initAttr: descs.initAttr || false
718
+ });
719
+ },
720
+ contentAttr: function(elem, name, val){
721
+ if(!elem.nodeName){return;}
722
+ var attr;
723
+ if(val === undefined){
724
+ attr = (elem.attributes[name] || {});
725
+ val = attr.specified ? attr.value : null;
726
+ return (val == null) ? undefined : val;
727
+ }
728
+
729
+ if(typeof val == 'boolean'){
730
+ if(!val){
731
+ elem.removeAttribute(name);
732
+ } else {
733
+ elem.setAttribute(name, name);
734
+ }
735
+ } else {
736
+ elem.setAttribute(name, val);
737
+ }
738
+ },
739
+
740
+ // set current Lang:
741
+ // - webshims.activeLang(lang:string);
742
+ // get current lang
743
+ // - webshims.activeLang();
744
+ // get current lang
745
+ // webshims.activeLang({
746
+ // register: moduleName:string,
747
+ // callback: callback:function
748
+ // });
749
+ // get/set including removeLang
750
+ // - webshims.activeLang({
751
+ // module: moduleName:string,
752
+ // callback: callback:function,
753
+ // langObj: languageObj:array/object
754
+ // });
755
+ activeLang: (function(){
756
+ var callbacks = [];
757
+ var registeredCallbacks = {};
758
+ var currentLang;
759
+ var shortLang;
760
+ var notLocal = /:\/\/|^\.*\//;
761
+ var loadRemoteLang = function(data, lang, options){
762
+ var langSrc;
763
+ if(lang && options && $.inArray(lang, options.availabeLangs || []) !== -1){
764
+ data.loading = true;
765
+ langSrc = options.langSrc;
766
+ if(!notLocal.test(langSrc)){
767
+ langSrc = webshims.cfg.basePath+langSrc;
768
+ }
769
+ webshims.loader.loadScript(langSrc+lang+'.js', function(){
770
+ if(data.langObj[lang]){
771
+ data.loading = false;
772
+ callLang(data, true);
773
+ } else {
774
+ $(function(){
775
+ if(data.langObj[lang]){
776
+ callLang(data, true);
777
+ }
778
+ data.loading = false;
779
+ });
780
+ }
781
+ });
782
+ return true;
783
+ }
784
+ return false;
785
+ };
786
+ var callRegister = function(module){
787
+ if(registeredCallbacks[module]){
788
+ registeredCallbacks[module].forEach(function(data){
789
+ data.callback();
790
+ });
791
+ }
792
+ };
793
+ var callLang = function(data, _noLoop){
794
+ if(data.activeLang != currentLang && data.activeLang !== shortLang){
795
+ var options = modules[data.module].options;
796
+ if( data.langObj[currentLang] || (shortLang && data.langObj[shortLang]) ){
797
+ data.activeLang = currentLang;
798
+ data.callback(data.langObj[currentLang] || data.langObj[shortLang], currentLang);
799
+ callRegister(data.module);
800
+ } else if( !_noLoop &&
801
+ !loadRemoteLang(data, currentLang, options) &&
802
+ !loadRemoteLang(data, shortLang, options) &&
803
+ data.langObj[''] && data.activeLang !== '' ) {
804
+ data.activeLang = '';
805
+ data.callback(data.langObj[''], currentLang);
806
+ callRegister(data.module);
807
+ }
808
+ }
809
+ };
810
+
811
+
812
+ var activeLang = function(lang){
813
+
814
+ if(typeof lang == 'string' && lang !== currentLang){
815
+ currentLang = lang;
816
+ shortLang = currentLang.split('-')[0];
817
+ if(currentLang == shortLang){
818
+ shortLang = false;
819
+ }
820
+ $.each(callbacks, function(i, data){
821
+ callLang(data);
822
+ });
823
+ } else if(typeof lang == 'object'){
824
+
825
+ if(lang.register){
826
+ if(!registeredCallbacks[lang.register]){
827
+ registeredCallbacks[lang.register] = [];
828
+ }
829
+ registeredCallbacks[lang.register].push(lang);
830
+ lang.callback();
831
+ } else {
832
+ if(!lang.activeLang){
833
+ lang.activeLang = '';
834
+ }
835
+ callbacks.push(lang);
836
+ callLang(lang);
837
+ }
838
+ }
839
+ return currentLang;
840
+ };
841
+
842
+ return activeLang;
843
+ })()
844
+ });
845
+
846
+ $.each({
847
+ defineNodeNamesProperty: 'defineNodeNameProperty',
848
+ defineNodeNamesProperties: 'defineNodeNameProperties',
849
+ createElements: 'createElement'
850
+ }, function(name, baseMethod){
851
+ webshims[name] = function(names, a, b, c){
852
+ if(typeof names == 'string'){
853
+ names = names.split(listReg);
854
+ }
855
+ var retDesc = {};
856
+ names.forEach(function(nodeName){
857
+ retDesc[nodeName] = webshims[baseMethod](nodeName, a, b, c);
858
+ });
859
+ return retDesc;
860
+ };
861
+ });
862
+
863
+ webshims.isReady('webshimLocalization', true);
864
+ });
865
+ //html5a11y
866
+ (function($, document){
867
+ var browserVersion = $.webshims.browserVersion;
868
+ if($.browser.mozilla && browserVersion > 5){return;}
869
+ if (!$.browser.msie || (browserVersion < 12 && browserVersion > 7)) {
870
+ var elemMappings = {
871
+ article: "article",
872
+ aside: "complementary",
873
+ section: "region",
874
+ nav: "navigation",
875
+ address: "contentinfo"
876
+ };
877
+ var addRole = function(elem, role){
878
+ var hasRole = elem.getAttribute('role');
879
+ if (!hasRole) {
880
+ elem.setAttribute('role', role);
881
+ }
882
+ };
883
+
884
+ $.webshims.addReady(function(context, contextElem){
885
+ $.each(elemMappings, function(name, role){
886
+ var elems = $(name, context).add(contextElem.filter(name));
887
+ for (var i = 0, len = elems.length; i < len; i++) {
888
+ addRole(elems[i], role);
889
+ }
890
+ });
891
+ if (context === document) {
892
+ var header = document.getElementsByTagName('header')[0];
893
+ var footers = document.getElementsByTagName('footer');
894
+ var footerLen = footers.length;
895
+ if (header && !$(header).closest('section, article')[0]) {
896
+ addRole(header, 'banner');
897
+ }
898
+ if (!footerLen) {
899
+ return;
900
+ }
901
+ var footer = footers[footerLen - 1];
902
+ if (!$(footer).closest('section, article')[0]) {
903
+ addRole(footer, 'contentinfo');
904
+ }
905
+ }
906
+ });
907
+ }
908
+ })(jQuery, document);
909
+ jQuery.webshims.register('form-datalist', function($, webshims, window, document, undefined){
910
+ var doc = document;
911
+
912
+ /*
913
+ * implement propType "element" currently only used for list-attribute (will be moved to dom-extend, if needed)
914
+ */
915
+ webshims.propTypes.element = function(descs){
916
+ webshims.createPropDefault(descs, 'attr');
917
+ if(descs.prop){return;}
918
+ descs.prop = {
919
+ get: function(){
920
+ var elem = descs.attr.get.call(this);
921
+ if(elem){
922
+ elem = document.getElementById(elem);
923
+ if(elem && descs.propNodeName && !$.nodeName(elem, descs.propNodeName)){
924
+ elem = null;
925
+ }
926
+ }
927
+ return elem || null;
928
+ },
929
+ writeable: false
930
+ };
931
+ };
932
+
933
+
934
+ /*
935
+ * Implements datalist element and list attribute
936
+ */
937
+
938
+ (function(){
939
+ var formsCFG = $.webshims.cfg.forms;
940
+ var listSupport = Modernizr.input.list;
941
+ if(listSupport && !formsCFG.customDatalist){return;}
942
+
943
+ var initializeDatalist = function(){
944
+
945
+
946
+ if(!listSupport){
947
+ webshims.defineNodeNameProperty('datalist', 'options', {
948
+ prop: {
949
+ writeable: false,
950
+ get: function(){
951
+ var elem = this;
952
+ var select = $('select', elem);
953
+ var options;
954
+ if(select[0]){
955
+ options = select[0].options;
956
+ } else {
957
+ options = $('option', elem).get();
958
+ if(options.length){
959
+ webshims.warn('you should wrap your option-elements for a datalist in a select element to support IE and other old browsers.');
960
+ }
961
+ }
962
+ return options;
963
+ }
964
+ }
965
+ });
966
+ }
967
+
968
+ var inputListProto = {
969
+ //override autocomplete
970
+ autocomplete: {
971
+ attr: {
972
+ get: function(){
973
+ var elem = this;
974
+ var data = $.data(elem, 'datalistWidget');
975
+ if(data){
976
+ return data._autocomplete;
977
+ }
978
+ return ('autocomplete' in elem) ? elem.autocomplete : elem.getAttribute('autocomplete');
979
+ },
980
+ set: function(value){
981
+ var elem = this;
982
+ var data = $.data(elem, 'datalistWidget');
983
+ if(data){
984
+ data._autocomplete = value;
985
+ if(value == 'off'){
986
+ data.hideList();
987
+ }
988
+ } else {
989
+ if('autocomplete' in elem){
990
+ elem.autocomplete = value;
991
+ } else {
992
+ elem.setAttribute('autocomplete', value);
993
+ }
994
+ }
995
+ }
996
+ }
997
+ }
998
+ };
999
+
1000
+ // if(formsCFG.customDatalist && (!listSupport || !('selectedOption') in $('<input />')[0])){
1001
+ // //currently not supported x-browser (FF4 has not implemented and is not polyfilled )
1002
+ // inputListProto.selectedOption = {
1003
+ // prop: {
1004
+ // writeable: false,
1005
+ // get: function(){
1006
+ // var elem = this;
1007
+ // var list = $.prop(elem, 'list');
1008
+ // var ret = null;
1009
+ // var value, options;
1010
+ // if(!list){return ret;}
1011
+ // value = $.prop(elem, 'value');
1012
+ // if(!value){return ret;}
1013
+ // options = $.prop(list, 'options');
1014
+ // if(!options.length){return ret;}
1015
+ // $.each(options, function(i, option){
1016
+ // if(value == $.prop(option, 'value')){
1017
+ // ret = option;
1018
+ // return false;
1019
+ // }
1020
+ // });
1021
+ // return ret;
1022
+ // }
1023
+ // }
1024
+ // };
1025
+ // }
1026
+
1027
+ if(!listSupport){
1028
+ inputListProto['list'] = {
1029
+ attr: {
1030
+ get: function(){
1031
+ var val = webshims.contentAttr(this, 'list');
1032
+ return (val == null) ? undefined : val;
1033
+ },
1034
+ set: function(value){
1035
+ var elem = this;
1036
+ webshims.contentAttr(elem, 'list', value);
1037
+ webshims.objectCreate(shadowListProto, undefined, {input: elem, id: value, datalist: $.prop(elem, 'list')});
1038
+ }
1039
+ },
1040
+ initAttr: true,
1041
+ reflect: true,
1042
+ propType: 'element',
1043
+ propNodeName: 'datalist'
1044
+ };
1045
+ } else {
1046
+ //options only return options, if option-elements are rooted: but this makes this part of HTML5 less backwards compatible
1047
+ if(!($('<datalist><select><option></option></select></datalist>').prop('options') || []).length ){
1048
+ webshims.defineNodeNameProperty('datalist', 'options', {
1049
+ prop: {
1050
+ writeable: false,
1051
+ get: function(){
1052
+ var options = this.options || [];
1053
+ if(!options.length){
1054
+ var elem = this;
1055
+ var select = $('select', elem);
1056
+ if(select[0] && select[0].options && select[0].options.length){
1057
+ options = select[0].options;
1058
+ }
1059
+ }
1060
+ return options;
1061
+ }
1062
+ }
1063
+ });
1064
+ }
1065
+ inputListProto['list'] = {
1066
+ attr: {
1067
+ get: function(){
1068
+ var val = webshims.contentAttr(this, 'list');
1069
+ if(val != null){
1070
+ this.removeAttribute('list');
1071
+ } else {
1072
+ val = $.data(this, 'datalistListAttr');
1073
+ }
1074
+
1075
+ return (val == null) ? undefined : val;
1076
+ },
1077
+ set: function(value){
1078
+ var elem = this;
1079
+ $.data(elem, 'datalistListAttr', value);
1080
+ webshims.objectCreate(shadowListProto, undefined, {input: elem, id: value, datalist: $.prop(elem, 'list')});
1081
+ }
1082
+ },
1083
+ initAttr: true,
1084
+ reflect: true,
1085
+ propType: 'element',
1086
+ propNodeName: 'datalist'
1087
+ };
1088
+ }
1089
+
1090
+
1091
+ webshims.defineNodeNameProperties('input', inputListProto);
1092
+
1093
+ if($.event.customEvent){
1094
+ $.event.customEvent.updateDatalist = true;
1095
+ $.event.customEvent.updateInput = true;
1096
+ $.event.customEvent.datalistselect = true;
1097
+ }
1098
+ webshims.addReady(function(context, contextElem){
1099
+ contextElem
1100
+ .filter('datalist > select, datalist, datalist > option, datalist > select > option')
1101
+ .closest('datalist')
1102
+ .triggerHandler('updateDatalist')
1103
+ ;
1104
+
1105
+ });
1106
+
1107
+
1108
+ };
1109
+
1110
+
1111
+ /*
1112
+ * ShadowList
1113
+ */
1114
+ var listidIndex = 0;
1115
+
1116
+ var noDatalistSupport = {
1117
+ submit: 1,
1118
+ button: 1,
1119
+ reset: 1,
1120
+ hidden: 1,
1121
+
1122
+ //ToDo
1123
+ range: 1,
1124
+ date: 1
1125
+ };
1126
+ var lteie6 = ($.browser.msie && parseInt($.browser.version, 10) < 7);
1127
+ var globStoredOptions = {};
1128
+ var getStoredOptions = function(name){
1129
+ if(!name){return [];}
1130
+ if(globStoredOptions[name]){
1131
+ return globStoredOptions[name];
1132
+ }
1133
+ var data;
1134
+ try {
1135
+ data = JSON.parse(localStorage.getItem('storedDatalistOptions'+name));
1136
+ } catch(e){}
1137
+ globStoredOptions[name] = data || [];
1138
+ return data || [];
1139
+ };
1140
+ var storeOptions = function(name, val){
1141
+ if(!name){return;}
1142
+ val = val || [];
1143
+ try {
1144
+ localStorage.setItem( 'storedDatalistOptions'+name, JSON.stringify(val) );
1145
+ } catch(e){}
1146
+ };
1147
+
1148
+ var getText = function(elem){
1149
+ return (elem.textContent || elem.innerText || $.text([ elem ]) || '');
1150
+ };
1151
+
1152
+ var shadowListProto = {
1153
+ _create: function(opts){
1154
+
1155
+ if(noDatalistSupport[$.prop(opts.input, 'type')]){return;}
1156
+ var datalist = opts.datalist;
1157
+ var data = $.data(opts.input, 'datalistWidget');
1158
+ if(datalist && data && data.datalist !== datalist){
1159
+ data.datalist = datalist;
1160
+ data.id = opts.id;
1161
+
1162
+ data.shadowList.prop('className', 'datalist-polyfill '+ (data.datalist.className || '') + ' '+ data.datalist.id +'-shadowdom');
1163
+ if(formsCFG.positionDatalist){
1164
+ data.shadowList.insertAfter(opts.input);
1165
+ } else {
1166
+ data.shadowList.appendTo('body');
1167
+ }
1168
+ $(data.datalist)
1169
+ .unbind('updateDatalist.datalistWidget')
1170
+ .bind('updateDatalist.datalistWidget', $.proxy(data, '_resetListCached'))
1171
+ ;
1172
+ data._resetListCached();
1173
+ return;
1174
+ } else if(!datalist){
1175
+ if(data){
1176
+ data.destroy();
1177
+ }
1178
+ return;
1179
+ } else if(data && data.datalist === datalist){
1180
+ return;
1181
+ }
1182
+ listidIndex++;
1183
+ var that = this;
1184
+ this.hideList = $.proxy(that, 'hideList');
1185
+ this.timedHide = function(){
1186
+ clearTimeout(that.hideTimer);
1187
+ that.hideTimer = setTimeout(that.hideList, 9);
1188
+ };
1189
+ this.datalist = datalist;
1190
+ this.id = opts.id;
1191
+ this.hasViewableData = true;
1192
+ this._autocomplete = $.attr(opts.input, 'autocomplete');
1193
+ $.data(opts.input, 'datalistWidget', this);
1194
+ this.shadowList = $('<div class="datalist-polyfill '+ (this.datalist.className || '') + ' '+ this.datalist.id +'-shadowdom' +'" />');
1195
+
1196
+ if(formsCFG.positionDatalist || $(opts.input).hasClass('position-datalist')){
1197
+ this.shadowList.insertAfter(opts.input);
1198
+ } else {
1199
+ this.shadowList.appendTo('body');
1200
+ }
1201
+
1202
+ this.index = -1;
1203
+ this.input = opts.input;
1204
+ this.arrayOptions = [];
1205
+
1206
+ this.shadowList
1207
+ .delegate('li', 'mouseenter.datalistWidget mousedown.datalistWidget click.datalistWidget', function(e){
1208
+ var items = $('li:not(.hidden-item)', that.shadowList);
1209
+ var select = (e.type == 'mousedown' || e.type == 'click');
1210
+ that.markItem(items.index(e.currentTarget), select, items);
1211
+ if(e.type == 'click'){
1212
+ that.hideList();
1213
+ if(formsCFG.customDatalist){
1214
+ $(opts.input).trigger('datalistselect');
1215
+ }
1216
+ }
1217
+ return (e.type != 'mousedown');
1218
+ })
1219
+ .bind('focusout', this.timedHide)
1220
+ ;
1221
+
1222
+ opts.input.setAttribute('autocomplete', 'off');
1223
+
1224
+ $(opts.input)
1225
+ .attr({
1226
+ //role: 'combobox',
1227
+ 'aria-haspopup': 'true'
1228
+ })
1229
+ .bind('input.datalistWidget', function(){
1230
+ if(!that.triggeredByDatalist){
1231
+ that.changedValue = false;
1232
+ that.showHideOptions();
1233
+ }
1234
+ })
1235
+
1236
+ .bind('keydown.datalistWidget', function(e){
1237
+ var keyCode = e.keyCode;
1238
+ var activeItem;
1239
+ var items;
1240
+ if(keyCode == 40 && !that.showList()){
1241
+ that.markItem(that.index + 1, true);
1242
+ return false;
1243
+ }
1244
+
1245
+ if(!that.isListVisible){return;}
1246
+
1247
+
1248
+ if(keyCode == 38){
1249
+ that.markItem(that.index - 1, true);
1250
+ return false;
1251
+ }
1252
+ if(!e.shiftKey && (keyCode == 33 || keyCode == 36)){
1253
+ that.markItem(0, true);
1254
+ return false;
1255
+ }
1256
+ if(!e.shiftKey && (keyCode == 34 || keyCode == 35)){
1257
+ items = $('li:not(.hidden-item)', that.shadowList);
1258
+ that.markItem(items.length - 1, true, items);
1259
+ return false;
1260
+ }
1261
+ if(keyCode == 13 || keyCode == 27){
1262
+ if (keyCode == 13){
1263
+ activeItem = $('li.active-item:not(.hidden-item)', that.shadowList);
1264
+ that.changeValue( $('li.active-item:not(.hidden-item)', that.shadowList) );
1265
+ }
1266
+ that.hideList();
1267
+ if(formsCFG.customDatalist && activeItem && activeItem[0]){
1268
+ $(opts.input).trigger('datalistselect');
1269
+ }
1270
+ return false;
1271
+ }
1272
+ })
1273
+ .bind('focus.datalistWidget', function(){
1274
+ if($(this).hasClass('list-focus')){
1275
+ that.showList();
1276
+ }
1277
+ })
1278
+ .bind('mousedown.datalistWidget', function(){
1279
+ if($(this).is(':focus')){
1280
+ that.showList();
1281
+ }
1282
+ })
1283
+ .bind('blur.datalistWidget', this.timedHide)
1284
+ ;
1285
+
1286
+
1287
+ $(this.datalist)
1288
+ .unbind('updateDatalist.datalistWidget')
1289
+ .bind('updateDatalist.datalistWidget', $.proxy(this, '_resetListCached'))
1290
+ ;
1291
+
1292
+ this._resetListCached();
1293
+
1294
+ if(opts.input.form && (opts.input.name || opts.input.id)){
1295
+ $(opts.input.form).bind('submit.datalistWidget'+opts.input.id, function(){
1296
+ if(!$(opts.input).hasClass('no-datalist-cache') && that._autocomplete != 'off'){
1297
+ var val = $.prop(opts.input, 'value');
1298
+ var name = (opts.input.name || opts.input.id) + $.prop(opts.input, 'type');
1299
+ if(!that.storedOptions){
1300
+ that.storedOptions = getStoredOptions( name );
1301
+ }
1302
+ if(val && that.storedOptions.indexOf(val) == -1){
1303
+ that.storedOptions.push(val);
1304
+ storeOptions(name, that.storedOptions );
1305
+ }
1306
+ }
1307
+ });
1308
+ }
1309
+ $(window).bind('unload.datalist'+this.id+' beforeunload.datalist'+this.id, function(){
1310
+ that.destroy();
1311
+ });
1312
+ },
1313
+ destroy: function(){
1314
+ var autocomplete = $.attr(this.input, 'autocomplete');
1315
+ $(this.input)
1316
+ .unbind('.datalistWidget')
1317
+ .removeData('datalistWidget')
1318
+ ;
1319
+ this.shadowList.remove();
1320
+ $(document).unbind('.datalist'+this.id);
1321
+ $(window).unbind('.datalist'+this.id);
1322
+ if(this.input.form && this.input.id){
1323
+ $(this.input.form).unbind('submit.datalistWidget'+this.input.id);
1324
+ }
1325
+ this.input.removeAttribute('aria-haspopup');
1326
+ if(autocomplete === undefined){
1327
+ this.input.removeAttribute('autocomplete');
1328
+ } else {
1329
+ $(this.input).attr('autocomplete', autocomplete);
1330
+ }
1331
+ },
1332
+ _resetListCached: function(e){
1333
+ var that = this;
1334
+ var forceShow;
1335
+ this.needsUpdate = true;
1336
+ this.lastUpdatedValue = false;
1337
+ this.lastUnfoundValue = '';
1338
+
1339
+ if(!this.updateTimer){
1340
+ if(window.QUnit || (forceShow = (e && document.activeElement == that.input))){
1341
+ that.updateListOptions(forceShow);
1342
+ } else {
1343
+ webshims.ready('WINDOWLOAD', function(){
1344
+ that.updateTimer = setTimeout(function(){
1345
+ that.updateListOptions();
1346
+ that = null;
1347
+ listidIndex = 1;
1348
+ }, 200 + (100 * listidIndex));
1349
+ });
1350
+ }
1351
+ }
1352
+ },
1353
+ updateListOptions: function(_forceShow){
1354
+ this.needsUpdate = false;
1355
+ clearTimeout(this.updateTimer);
1356
+ this.updateTimer = false;
1357
+ this.shadowList
1358
+ .css({
1359
+ fontSize: $.css(this.input, 'fontSize'),
1360
+ fontFamily: $.css(this.input, 'fontFamily')
1361
+ })
1362
+ ;
1363
+ this.searchStart = formsCFG.customDatalist && $(this.input).hasClass('search-start');
1364
+
1365
+ var list = [];
1366
+
1367
+ var values = [];
1368
+ var allOptions = [];
1369
+ var rElem, rItem, rOptions, rI, rLen, item;
1370
+ for(rOptions = $.prop(this.datalist, 'options'), rI = 0, rLen = rOptions.length; rI < rLen; rI++){
1371
+ rElem = rOptions[rI];
1372
+ if(rElem.disabled){return;}
1373
+ rItem = {
1374
+ value: $(rElem).val() || '',
1375
+ text: $.trim($.attr(rElem, 'label') || getText(rElem)),
1376
+ className: rElem.className || '',
1377
+ style: $.attr(rElem, 'style') || ''
1378
+ };
1379
+ if(!rItem.text){
1380
+ rItem.text = rItem.value;
1381
+ } else if(rItem.text != rItem.value){
1382
+ rItem.className += ' different-label-value';
1383
+ }
1384
+ values[rI] = rItem.value;
1385
+ allOptions[rI] = rItem;
1386
+ }
1387
+
1388
+ if(!this.storedOptions){
1389
+ this.storedOptions = ($(this.input).hasClass('no-datalist-cache') || this._autocomplete == 'off') ? [] : getStoredOptions((this.input.name || this.input.id) + $.prop(this.input, 'type'));
1390
+ }
1391
+
1392
+ this.storedOptions.forEach(function(val, i){
1393
+ if(values.indexOf(val) == -1){
1394
+ allOptions.push({value: val, text: val, className: 'stored-suggest', style: ''});
1395
+ }
1396
+ });
1397
+
1398
+ for(rI = 0, rLen = allOptions.length; rI < rLen; rI++){
1399
+ item = allOptions[rI];
1400
+ list[rI] = '<li class="'+ item.className +'" style="'+ item.style +'" tabindex="-1" role="listitem"><span class="option-label">'+ item.text +'</span> <span class="option-value">'+item.value+'</span></li>';
1401
+ }
1402
+
1403
+ this.arrayOptions = allOptions;
1404
+ this.shadowList.html('<div class="datalist-outer-box"><div class="datalist-box"><ul role="list">'+ list.join("\n") +'</ul></div></div>');
1405
+
1406
+ if($.fn.bgIframe && lteie6){
1407
+ this.shadowList.bgIframe();
1408
+ }
1409
+
1410
+ if(_forceShow || this.isListVisible){
1411
+ this.showHideOptions();
1412
+ }
1413
+ },
1414
+ showHideOptions: function(_fromShowList){
1415
+ var value = $.prop(this.input, 'value').toLowerCase();
1416
+ //first check prevent infinite loop, second creates simple lazy optimization
1417
+ if(value === this.lastUpdatedValue || (this.lastUnfoundValue && value.indexOf(this.lastUnfoundValue) === 0)){
1418
+ return;
1419
+ }
1420
+
1421
+ this.lastUpdatedValue = value;
1422
+ var found = false;
1423
+ var startSearch = this.searchStart;
1424
+ var lis = $('li', this.shadowList);
1425
+ if(value){
1426
+ this.arrayOptions.forEach(function(item, i){
1427
+ var search;
1428
+ if(!('lowerText' in item)){
1429
+ if(item.text != item.value){
1430
+ item.lowerText = item.value.toLowerCase() + item.text.toLowerCase();
1431
+ } else {
1432
+ item.lowerText = item.text.toLowerCase();
1433
+ }
1434
+ }
1435
+ search = item.lowerText.indexOf(value);
1436
+ search = startSearch ? !search : search !== -1;
1437
+ if(search){
1438
+ $(lis[i]).removeClass('hidden-item');
1439
+ found = true;
1440
+ } else {
1441
+ $(lis[i]).addClass('hidden-item');
1442
+ }
1443
+ });
1444
+ } else if(lis.length) {
1445
+ lis.removeClass('hidden-item');
1446
+ found = true;
1447
+ }
1448
+
1449
+ this.hasViewableData = found;
1450
+ if(!_fromShowList && found){
1451
+ this.showList();
1452
+ }
1453
+ if(!found){
1454
+ this.lastUnfoundValue = value;
1455
+ this.hideList();
1456
+ }
1457
+ },
1458
+ setPos: function(){
1459
+ this.shadowList.css({marginTop: 0, marginLeft: 0, marginRight: 0, marginBottom: 0});
1460
+ var css = (formsCFG.positionDatalist) ? $(this.input).position() : webshims.getRelOffset(this.shadowList, this.input);
1461
+ css.top += $(this.input).outerHeight();
1462
+ css.width = $(this.input).outerWidth() - (parseInt(this.shadowList.css('borderLeftWidth'), 10) || 0) - (parseInt(this.shadowList.css('borderRightWidth'), 10) || 0);
1463
+ this.shadowList.css({marginTop: '', marginLeft: '', marginRight: '', marginBottom: ''}).css(css);
1464
+ return css;
1465
+ },
1466
+ showList: function(){
1467
+ if(this.isListVisible){return false;}
1468
+ if(this.needsUpdate){
1469
+ this.updateListOptions();
1470
+ }
1471
+ this.showHideOptions(true);
1472
+ if(!this.hasViewableData){return false;}
1473
+ this.isListVisible = true;
1474
+ var that = this;
1475
+
1476
+ that.setPos();
1477
+ that.shadowList.addClass('datalist-visible').find('li.active-item').removeClass('active-item');
1478
+
1479
+ $(window).unbind('.datalist'+that.id);
1480
+ $(document)
1481
+ .unbind('.datalist'+that.id)
1482
+ .bind('mousedown.datalist'+that.id +' focusin.datalist'+that.id, function(e){
1483
+ if(e.target === that.input || that.shadowList[0] === e.target || $.contains( that.shadowList[0], e.target )){
1484
+ clearTimeout(that.hideTimer);
1485
+ setTimeout(function(){
1486
+ clearTimeout(that.hideTimer);
1487
+ }, 9);
1488
+ } else {
1489
+ that.timedHide();
1490
+ }
1491
+ })
1492
+ .bind('updateshadowdom.datalist'+that.id, function(){
1493
+ that.setPos();
1494
+ })
1495
+ ;
1496
+ return true;
1497
+ },
1498
+ hideList: function(){
1499
+ if(!this.isListVisible){return false;}
1500
+ var that = this;
1501
+ var triggerChange = function(e){
1502
+ if(that.changedValue){
1503
+ $(that.input).trigger('change');
1504
+ }
1505
+ that.changedValue = false;
1506
+ };
1507
+
1508
+ that.shadowList.removeClass('datalist-visible list-item-active');
1509
+ that.index = -1;
1510
+ that.isListVisible = false;
1511
+ if(that.changedValue){
1512
+ that.triggeredByDatalist = true;
1513
+ webshims.triggerInlineForm && webshims.triggerInlineForm(that.input, 'input');
1514
+ if($(that.input).is(':focus')){
1515
+ $(that.input).one('blur', triggerChange);
1516
+ } else {
1517
+ triggerChange();
1518
+ }
1519
+ that.triggeredByDatalist = false;
1520
+ }
1521
+ $(document).unbind('.datalist'+that.id);
1522
+ $(window)
1523
+ .unbind('.datalist'+that.id)
1524
+ .one('resize.datalist'+that.id, function(){
1525
+ that.shadowList.css({top: 0, left: 0});
1526
+ })
1527
+ ;
1528
+ return true;
1529
+ },
1530
+ scrollIntoView: function(elem){
1531
+ var ul = $('ul', this.shadowList);
1532
+ var div = $('div.datalist-box', this.shadowList);
1533
+ var elemPos = elem.position();
1534
+ var containerHeight;
1535
+ elemPos.top -= (parseInt(ul.css('paddingTop'), 10) || 0) + (parseInt(ul.css('marginTop'), 10) || 0) + (parseInt(ul.css('borderTopWidth'), 10) || 0);
1536
+ if(elemPos.top < 0){
1537
+ div.scrollTop( div.scrollTop() + elemPos.top - 2);
1538
+ return;
1539
+ }
1540
+ elemPos.top += elem.outerHeight();
1541
+ containerHeight = div.height();
1542
+ if(elemPos.top > containerHeight){
1543
+ div.scrollTop( div.scrollTop() + (elemPos.top - containerHeight) + 2);
1544
+ }
1545
+ },
1546
+ changeValue: function(activeItem){
1547
+ if(!activeItem[0]){return;}
1548
+ var newValue = $('span.option-value', activeItem).text();
1549
+ var oldValue = $.prop(this.input, 'value');
1550
+ if(newValue != oldValue){
1551
+ $(this.input)
1552
+ .prop('value', newValue)
1553
+ .triggerHandler('updateInput')
1554
+ ;
1555
+ this.changedValue = true;
1556
+ }
1557
+ },
1558
+ markItem: function(index, doValue, items){
1559
+ var activeItem;
1560
+ var goesUp;
1561
+
1562
+ items = items || $('li:not(.hidden-item)', this.shadowList);
1563
+ if(!items.length){return;}
1564
+ if(index < 0){
1565
+ index = items.length - 1;
1566
+ } else if(index >= items.length){
1567
+ index = 0;
1568
+ }
1569
+ items.removeClass('active-item');
1570
+ this.shadowList.addClass('list-item-active');
1571
+ activeItem = items.filter(':eq('+ index +')').addClass('active-item');
1572
+
1573
+ if(doValue){
1574
+ this.changeValue(activeItem);
1575
+ this.scrollIntoView(activeItem);
1576
+ }
1577
+ this.index = index;
1578
+ }
1579
+ };
1580
+
1581
+ //init datalist update
1582
+ initializeDatalist();
1583
+ })();
1584
+
1585
+ });