webshims-rails 1.11.3.1 → 1.11.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (72) hide show
  1. checksums.yaml +4 -4
  2. data/lib/webshims-rails/version.rb +2 -2
  3. data/vendor/assets/javascripts/webshims/extras/modernizr-custom.js +114 -104
  4. data/vendor/assets/javascripts/webshims/extras/mousepress.js +5 -5
  5. data/vendor/assets/javascripts/webshims/polyfiller.js +156 -207
  6. data/vendor/assets/javascripts/webshims/shims/$ajax.js +862 -0
  7. data/vendor/assets/javascripts/webshims/shims/FlashCanvas/flashcanvas.js +20 -0
  8. data/vendor/assets/javascripts/webshims/shims/FlashCanvasPro/flashcanvas.js +20 -0
  9. data/vendor/assets/javascripts/webshims/shims/color-picker.js +12 -12
  10. data/vendor/assets/javascripts/webshims/shims/combos/1.js +62 -32
  11. data/vendor/assets/javascripts/webshims/shims/combos/10.js +192 -509
  12. data/vendor/assets/javascripts/webshims/shims/combos/11.js +96 -415
  13. data/vendor/assets/javascripts/webshims/shims/combos/12.js +36 -26
  14. data/vendor/assets/javascripts/webshims/shims/combos/13.js +36 -26
  15. data/vendor/assets/javascripts/webshims/shims/combos/14.js +1007 -359
  16. data/vendor/assets/javascripts/webshims/shims/combos/15.js +310 -235
  17. data/vendor/assets/javascripts/webshims/shims/combos/16.js +313 -237
  18. data/vendor/assets/javascripts/webshims/shims/combos/17.js +96 -415
  19. data/vendor/assets/javascripts/webshims/shims/combos/18.js +1003 -678
  20. data/vendor/assets/javascripts/webshims/shims/combos/19.js +1085 -387
  21. data/vendor/assets/javascripts/webshims/shims/combos/2.js +161 -127
  22. data/vendor/assets/javascripts/webshims/shims/combos/20.js +1086 -388
  23. data/vendor/assets/javascripts/webshims/shims/combos/21.js +168 -96
  24. data/vendor/assets/javascripts/webshims/shims/combos/22.js +36 -27
  25. data/vendor/assets/javascripts/webshims/shims/combos/23.js +2 -1
  26. data/vendor/assets/javascripts/webshims/shims/combos/24.js +411 -172
  27. data/vendor/assets/javascripts/webshims/shims/combos/25.js +1085 -387
  28. data/vendor/assets/javascripts/webshims/shims/combos/26.js +96 -94
  29. data/vendor/assets/javascripts/webshims/shims/combos/3.js +163 -140
  30. data/vendor/assets/javascripts/webshims/shims/combos/30.js +166 -141
  31. data/vendor/assets/javascripts/webshims/shims/combos/31.js +159 -126
  32. data/vendor/assets/javascripts/webshims/shims/combos/4.js +103 -109
  33. data/vendor/assets/javascripts/webshims/shims/combos/5.js +98 -417
  34. data/vendor/assets/javascripts/webshims/shims/combos/6.js +101 -418
  35. data/vendor/assets/javascripts/webshims/shims/combos/7.js +168 -142
  36. data/vendor/assets/javascripts/webshims/shims/combos/8.js +165 -141
  37. data/vendor/assets/javascripts/webshims/shims/combos/9.js +195 -510
  38. data/vendor/assets/javascripts/webshims/shims/details.js +2 -2
  39. data/vendor/assets/javascripts/webshims/shims/dom-extend.js +96 -94
  40. data/vendor/assets/javascripts/webshims/shims/es5.js +908 -264
  41. data/vendor/assets/javascripts/webshims/shims/excanvas.js +16 -1
  42. data/vendor/assets/javascripts/webshims/shims/form-combat.js +147 -0
  43. data/vendor/assets/javascripts/webshims/shims/form-core.js +60 -31
  44. data/vendor/assets/javascripts/webshims/shims/form-datalist-lazy.js +114 -33
  45. data/vendor/assets/javascripts/webshims/shims/form-datalist.js +3 -1
  46. data/vendor/assets/javascripts/webshims/shims/form-message.js +7 -15
  47. data/vendor/assets/javascripts/webshims/shims/form-native-extend.js +2 -2
  48. data/vendor/assets/javascripts/webshims/shims/form-number-date-ui.js +88 -410
  49. data/vendor/assets/javascripts/webshims/shims/form-shim-extend.js +143 -93
  50. data/vendor/assets/javascripts/webshims/shims/form-shim-extend2.js +268 -79
  51. data/vendor/assets/javascripts/webshims/shims/form-validation.js +116 -81
  52. data/vendor/assets/javascripts/webshims/shims/form-validators.js +23 -10
  53. data/vendor/assets/javascripts/webshims/shims/forms-picker.js +605 -9
  54. data/vendor/assets/javascripts/webshims/shims/geolocation.js +51 -39
  55. data/vendor/assets/javascripts/webshims/shims/i18n/formcfg-de.js +78 -33
  56. data/vendor/assets/javascripts/webshims/shims/i18n/formcfg-en.js +24 -6
  57. data/vendor/assets/javascripts/webshims/shims/i18n/formcfg-nl.js +110 -49
  58. data/vendor/assets/javascripts/webshims/shims/json-storage.js +3 -1
  59. data/vendor/assets/javascripts/webshims/shims/mediaelement-core.js +2 -1
  60. data/vendor/assets/javascripts/webshims/shims/mediaelement-jaris.js +81 -30
  61. data/vendor/assets/javascripts/webshims/shims/mediaelement-yt.js +131 -54
  62. data/vendor/assets/javascripts/webshims/shims/plugins/jquery.ui.position.js +497 -0
  63. data/vendor/assets/javascripts/webshims/shims/range-ui.js +8 -5
  64. data/vendor/assets/javascripts/webshims/shims/sizzle.js +2026 -0
  65. data/vendor/assets/javascripts/webshims/shims/styles/forms-ext.css +401 -521
  66. data/vendor/assets/javascripts/webshims/shims/styles/scss/forms-ext.scss +1 -1
  67. data/vendor/assets/javascripts/webshims/shims/styles/scss/shim.scss +94 -82
  68. data/vendor/assets/javascripts/webshims/shims/styles/shim.css +250 -321
  69. data/vendor/assets/javascripts/webshims/shims/swf/JarisFLVPlayer.swf +0 -0
  70. data/vendor/assets/javascripts/webshims/shims/track-ui.js +1 -1
  71. data/vendor/assets/javascripts/webshims/shims/track.js +34 -25
  72. metadata +7 -3
@@ -920,5 +920,20 @@ if (!document.createElement('canvas').getContext) {
920
920
  CanvasPattern = CanvasPattern_;
921
921
 
922
922
  })();
923
-
923
+ (function(document){
924
+ webshims.addReady(function(context, elem){
925
+ if(context == document){
926
+ if(window.G_vmlCanvasManager && G_vmlCanvasManager.init_ ){
927
+ G_vmlCanvasManager.init_(document);
928
+ }
929
+ }
930
+ webshims.$('canvas', context).add(elem.filter('canvas')).each(function(){
931
+ var hasContext = this.getContext;
932
+ if(!hasContext && window.G_vmlCanvasManager){
933
+ G_vmlCanvasManager.initElement(this);
934
+ }
935
+ });
936
+ });
937
+ webshims.isReady('canvas', true);
938
+ })(document);
924
939
  } // if
@@ -0,0 +1,147 @@
1
+ //
2
+ webshims.register('form-combat', function($,webshims){
3
+ "use strict";
4
+
5
+ var replacementDatas = {
6
+
7
+ };
8
+ var addReplacement = function(pName, dataName, obj){
9
+ if($.fn[pName]){
10
+ if(typeof dataName == 'object'){
11
+ obj = dataName;
12
+ dataName = pName;
13
+ }
14
+ replacementDatas[dataName] = obj;
15
+ webshims.info('detected use of '+ pName +' try to add support.');
16
+ }
17
+ };
18
+
19
+ addReplacement('select2', {
20
+ shadow: 'container',
21
+ shadowFocus: 'focusser',
22
+ _create: function(elem, shadow, shadowFocus, widgetData){
23
+
24
+ if(('container' in widgetData) && $.isFunction(widgetData.opened)){
25
+ var onValidate = function(e){
26
+ if (!webshims.wsPopover.isInElement([elem, shadow, shadowFocus, $(widgetData.container)], e.target)) {
27
+ $(elem).trigger('refreshvalidityui');
28
+ }
29
+ };
30
+
31
+ $(shadow).on('wsallowinstantvalidation', function(e, data){
32
+ $(document).off('focusin', onValidate);
33
+ if(data.type == 'focusout' && data.target != elem && widgetData.opened()){
34
+ $(document).on('focusin', onValidate);
35
+ return false;
36
+ }
37
+ });
38
+ }
39
+ }
40
+ });
41
+
42
+ addReplacement('chosen', {
43
+ shadow: 'container',
44
+ shadowFocus: 'search_field'
45
+ });
46
+
47
+ addReplacement('selectpicker', {
48
+ shadow: '$newElement',
49
+ shadowFocus: '$button',
50
+ _create: function(elem, shadow, shadowFocus, widgetData){
51
+ if(('$menu' in widgetData)){
52
+ var onValidate = function(e){
53
+ if (!webshims.wsPopover.isInElement([elem, shadow, shadowFocus, $(widgetData.$menu)], e.target)) {
54
+ $(elem).trigger('refreshvalidityui');
55
+ }
56
+ };
57
+
58
+ $(shadow).on('wsallowinstantvalidation', function(e, data){
59
+ $(document).off('focusin', onValidate);
60
+ if(data.type == 'focusout' && data.target != elem){
61
+ $(document).on('focusin', onValidate);
62
+ return false;
63
+ }
64
+ });
65
+ }
66
+ }
67
+ });
68
+
69
+ addReplacement('selectBoxIt', {
70
+ shadow: 'dropdownContainer',
71
+ shadowFocus: 'dropdown'
72
+ });
73
+
74
+ addReplacement('checkboxradio', 'mobileCheckboxradio', {
75
+ shadow: 'label',
76
+ shadowFocus: 'element'
77
+ });
78
+
79
+ addReplacement('selectmenu', 'mobileSelectmenu', {
80
+ shadow: 'button',
81
+ shadowFocus: function(data, elem){
82
+ return data.options.nativeMenu ? data.element : data.button;
83
+ },
84
+ _create: function(elem, shadow, shadowFocus, widgetData){
85
+ if(('listbox' in widgetData)){
86
+ var onValidate = function(e){
87
+ if (!webshims.wsPopover.isInElement([elem, shadow, shadowFocus, $(widgetData.listbox).parent()], e.target)) {
88
+ $(elem).trigger('refreshvalidityui');
89
+ }
90
+ };
91
+
92
+ $(shadow).on('wsallowinstantvalidation', function(e, data){
93
+ if(data.type == 'focusout' && data.target != elem && widgetData.isOpen){
94
+ setTimeout(function(){
95
+ $(document).off('focusin', onValidate).on('focusin', onValidate);
96
+ }, 1);
97
+ return false;
98
+ }
99
+ });
100
+ }
101
+ }
102
+ });
103
+
104
+ function find(context){
105
+ $('select:not(.ui-select-nativeonly), input[type="radio"], input[type="checkbox"]', context).each(find.detectReplacement);
106
+ }
107
+
108
+ find.register = function(elem, data, pluginDescriptor, plugin){
109
+ var shadow = typeof pluginDescriptor.shadow == 'string' ? data[pluginDescriptor.shadow] : pluginDescriptor.shadow(data, elem);
110
+ var shadowFocus = typeof pluginDescriptor.shadowFocus == 'string' ? data[pluginDescriptor.shadowFocus] : pluginDescriptor.shadowFocus(data, elem);
111
+ if(!shadowFocus){
112
+ shadowFocus = shadow;
113
+ }
114
+ if(shadow && (replacementDatas.success || ($(shadowFocus).attr('tabindex') || $(shadowFocus).prop('tabIndex') > -1))){
115
+ webshims.addShadowDom(elem, shadow, {shadowFocusElement: shadowFocus});
116
+ if(pluginDescriptor._create){
117
+ pluginDescriptor._create(elem, shadow, shadowFocus, data);
118
+ }
119
+ replacementDatas.success = true;
120
+ } else {
121
+ webshims.error("webshim could not add support for "+plugin);
122
+ if(plugin in replacementDatas){
123
+ delete replacementDatas[plugin];
124
+ }
125
+ }
126
+ };
127
+
128
+ find.detectReplacement = function(){
129
+ var plugin;
130
+ var data = $(this).data();
131
+ if(data && !(webshims.data(this) || {}).hasShadow){
132
+ for(plugin in replacementDatas){
133
+ if(data[plugin]){
134
+ find.register(this, data[plugin], replacementDatas[plugin], plugin);
135
+ break;
136
+ }
137
+ }
138
+ }
139
+ };
140
+
141
+ webshims.addReady(function(context){
142
+
143
+ setTimeout(function(){
144
+ find(context);
145
+ }, 4);
146
+ });
147
+ });
@@ -61,39 +61,65 @@ webshims.register('form-core', function($, webshims, window, document, undefined
61
61
  return ret;
62
62
  };
63
63
 
64
- $.extend($.expr[":"], {
65
- "valid-element": function(elem){
66
- return rElementsGroup.test(elem.nodeName || '') ? !hasInvalid(elem) :!!($.prop(elem, 'willValidate') && isValid(elem));
67
- },
68
- "invalid-element": function(elem){
69
- return rElementsGroup.test(elem.nodeName || '') ? hasInvalid(elem) : !!($.prop(elem, 'willValidate') && !isValid(elem));
70
- },
71
- "required-element": function(elem){
72
- return !!($.prop(elem, 'willValidate') && $.prop(elem, 'required'));
73
- },
74
- "user-error": function(elem){
75
- return ($.prop(elem, 'willValidate') && $(elem).hasClass('user-error'));
76
- },
77
- "optional-element": function(elem){
78
- return !!($.prop(elem, 'willValidate') && $.prop(elem, 'required') === false);
64
+ var extendSels = function(){
65
+ var exp = $.expr[":"];
66
+ $.extend(exp, {
67
+ "valid-element": function(elem){
68
+ return rElementsGroup.test(elem.nodeName || '') ? !hasInvalid(elem) :!!($.prop(elem, 'willValidate') && isValid(elem));
69
+ },
70
+ "invalid-element": function(elem){
71
+ return rElementsGroup.test(elem.nodeName || '') ? hasInvalid(elem) : !!($.prop(elem, 'willValidate') && !isValid(elem));
72
+ },
73
+ "required-element": function(elem){
74
+ return !!($.prop(elem, 'willValidate') && $.prop(elem, 'required'));
75
+ },
76
+ "user-error": function(elem){
77
+ return ($.prop(elem, 'willValidate') && $(elem).hasClass('user-error'));
78
+ },
79
+ "optional-element": function(elem){
80
+ return !!($.prop(elem, 'willValidate') && $.prop(elem, 'required') === false);
81
+ }
82
+ });
83
+
84
+ ['valid', 'invalid', 'required', 'optional'].forEach(function(name){
85
+ exp[name] = $.expr[":"][name+"-element"];
86
+ });
87
+
88
+ // sizzle/jQuery has a bug with :disabled/:enabled selectors
89
+ if(Modernizr.fieldsetdisabled && !$('<fieldset disabled=""><input /><fieldset>').find('input').is(':disabled')){
90
+ $.extend(exp, {
91
+ "enabled": function( elem ) {
92
+ return elem.disabled === false && !$(elem).is('fieldset[disabled] *');
93
+ },
94
+
95
+ "disabled": function( elem ) {
96
+ return elem.disabled === true || ('disabled' in elem && $(elem).is('fieldset[disabled] *'));
97
+ }
98
+ });
79
99
  }
80
- });
81
-
82
- ['valid', 'invalid', 'required', 'optional'].forEach(function(name){
83
- $.expr[":"][name] = $.expr.filters[name+"-element"];
84
- });
85
-
86
- //bug was partially fixed in 1.10.0 for IE9, but not IE8 (move to es5 as soon as 1.10.2 is used)
87
- var pseudoFocus = $.expr[":"].focus;
88
- $.expr[":"].focus = function(){
89
- try {
90
- return pseudoFocus.apply(this, arguments);
91
- } catch(e){
92
- webshims.error(e);
100
+
101
+
102
+ //bug was partially fixed in 1.10.0 for IE9, but not IE8 (move to es5 as soon as 1.10.2 is used)
103
+ if(typeof document.activeElement == 'unknown'){
104
+ var pseudoFocus = exp.focus;
105
+ exp.focus = function(){
106
+ try {
107
+ return pseudoFocus.apply(this, arguments);
108
+ } catch(e){
109
+ webshims.error(e);
110
+ }
111
+ return false;
112
+ };
93
113
  }
94
- return false;
95
114
  };
96
115
 
116
+ if($.expr.filters){
117
+ extendSels();
118
+ } else {
119
+ webshims.ready('sizzle', extendSels);
120
+ }
121
+
122
+
97
123
  webshims.triggerInlineForm = function(elem, event){
98
124
  $(elem).trigger(event);
99
125
  };
@@ -161,7 +187,10 @@ webshims.register('form-core', function($, webshims, window, document, undefined
161
187
 
162
188
 
163
189
  webshims.getContentValidationMessage = function(elem, validity, key){
164
- var message = $(elem).data('errormessage') || elem.getAttribute('x-moz-errormessage') || '';
190
+ if(webshims.errorbox && webshims.errorbox.initIvalContentMessage){
191
+ webshims.errorbox.initIvalContentMessage(elem);
192
+ }
193
+ var message = (webshims.getOptions && webshims.errorbox ? webshims.getOptions(elem, 'errormessage') : $(elem).data('errormessage')) || elem.getAttribute('x-moz-errormessage') || '';
165
194
  if(key && message[key]){
166
195
  message = message[key];
167
196
  } else if(message) {
@@ -207,7 +236,7 @@ webshims.register('form-core', function($, webshims, window, document, undefined
207
236
 
208
237
 
209
238
  $(document).on('focusin.lazyloadvalidation', function(e){
210
- if('form' in e.target && (e.target.list || $(e.target).is(':invalid'))){
239
+ if('form' in e.target){
211
240
  lazyLoad();
212
241
  }
213
242
  });
@@ -32,18 +32,18 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
32
32
  var that = this;
33
33
  this.hideList = $.proxy(that, 'hideList');
34
34
 
35
-
36
-
37
- this.popover = webshims.objectCreate(webshims.wsPopover, {}, options.datalistPopover);
38
- this.shadowList = this.popover.element.addClass('datalist-polyfill');
39
-
40
-
41
35
  this.index = -1;
42
36
  this.input = opts.input;
43
37
  this.arrayOptions = [];
44
38
 
39
+ this._updateOptions();
40
+
41
+ this.popover = webshims.objectCreate(webshims.wsPopover, {}, this.options.popover);
42
+ this.shadowList = this.popover.element.addClass('datalist-polyfill');
43
+
45
44
  this.shadowList
46
- .delegate('li', 'mouseenter.datalistWidget mousedown.datalistWidget click.datalistWidget', function(e){
45
+ .on('mouseenter.datalistWidget mousedown.datalistWidget click.datalistWidget', 'li', function(e){
46
+ if(that._stopMouseOver && e && e.type == 'mouseenter'){return;}
47
47
  var items = $('li:not(.hidden-item)', that.shadowList);
48
48
  var select = (e.type == 'mousedown' || e.type == 'click');
49
49
  that.markItem(items.index(e.currentTarget), select, items);
@@ -58,6 +58,7 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
58
58
  ;
59
59
 
60
60
  opts.input.setAttribute('autocomplete', 'off');
61
+ this.lastCompletedValue = "";
61
62
 
62
63
  $(opts.input)
63
64
  .attr({
@@ -112,7 +113,8 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
112
113
  }
113
114
  },
114
115
  'focus.datalistWidget': function(){
115
- if($(this).hasClass('list-focus')){
116
+ that.lastCompletedValue = "";
117
+ if(that.options.focus){
116
118
  that.showList();
117
119
  }
118
120
  },
@@ -124,13 +126,12 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
124
126
  })
125
127
  ;
126
128
 
127
-
128
129
  $(this.datalist)
129
130
  .off('updateDatalist.datalistWidget')
130
131
  .on('updateDatalist.datalistWidget', $.proxy(this, '_resetListCached'))
131
132
  .on('remove', function(e){
132
133
  if(!e.originalEvent){
133
- that.detroy();
134
+ that.destroy();
134
135
  }
135
136
  })
136
137
  ;
@@ -175,17 +176,57 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
175
176
  }
176
177
  }
177
178
  },
179
+ _updateOptions: function(){
180
+ this.options = webshims.getOptions(this.input, 'list', options.list);
181
+
182
+ if($(this.input).prop('multiple') && $(this.input).prop('type') == 'email'){
183
+ this.options.multiple = true;
184
+ }
185
+
186
+ if( this.options.getOptionContent && !$.isFunction(this.options.getOptionContent) ){
187
+ this.options.getOptionContent = false;
188
+ }
189
+
190
+ //depreacated option settings:
191
+ if(options.getOptionContent){
192
+ webshims.error('getOptionContent is depreacated use $(input).on("getoptioncontent")');
193
+ }
194
+
195
+ if($(this.input).hasClass('list-focus')){
196
+ webshims.error(".list-focus is depreacated. Use focus option.");
197
+ }
198
+
199
+ if(options.datalistPopover && !this.options.popover){
200
+ this.options.popover = options.datalistPopover;
201
+ webshims.error("datalistPopover is depreacated. Use popover option.");
202
+ }
203
+
204
+ if($(this.input).hasClass('mark-option-text')){
205
+ this.options.highlight = true;
206
+ webshims.error(".mark-option-text is depreacated. Use highlight option.");
207
+ }
208
+
209
+ if($(this.input).hasClass('list-multiple')){
210
+ this.options.multiple = true;
211
+ webshims.error(".list-multiple is depreacated. Use multiple option.");
212
+ }
213
+
214
+ if($(this.input).hasClass('value-completion')){
215
+ this.options.valueCompletion = true;
216
+ webshims.error(".value-completion is depreacated. Use valueCompletion option.");
217
+ }
218
+
219
+ if(this.options.valueCompletion && this.options.multiple){
220
+ webshims.warn("valueCompletion and multiple shouldn't be set together");
221
+ }
222
+ },
178
223
  updateListOptions: function(_forceShow){
179
224
  this.needsUpdate = false;
180
225
  clearTimeout(this.updateTimer);
181
226
  this.updateTimer = false;
182
227
 
183
- if($(this.input).hasClass('ws-nosearch') || $(this.input).hasClass('search-start')){
184
- webshims.error('please use listFilter/data-list-filer configuration with values: "*", "^" or "!"');
185
- }
186
- this.addMarkElement = options.addMark || $(this.input).hasClass('mark-option-text');
187
- this.listFilter = $(this.input).data('listFilter') || options.listFilter || '*';
188
- this.multiple = $(this.input).hasClass('list-multiple') || ($(this.input).prop('multiple') && $(this.input).prop('type') == 'email');
228
+ this.lastCompletedValue = "";
229
+
189
230
  var list = [];
190
231
 
191
232
  var values = [];
@@ -195,7 +236,7 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
195
236
  rElem = rOptions[rI];
196
237
  if(!rElem.disabled && (value = $(rElem).val())){
197
238
  rItem = {
198
- value: value.replace(lReg, '&lt;').replace(gReg, '&gt;'),
239
+ value: this.options.noHtmlEscape ? value : value.replace(lReg, '&lt;').replace(gReg, '&gt;'),
199
240
  label: $.trim($.attr(rElem, 'label')) || '',
200
241
  className: rElem.className || '',
201
242
  elem: options.getOptionContent ? rElem : null
@@ -237,11 +278,9 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
237
278
  },
238
279
  getOptionContent: function(item){
239
280
  var content;
240
- if(options.getOptionContent){
241
- content = options.getOptionContent.apply(this, arguments);
242
- if(content != null){
243
- content += '<span class="option-value" style="display: none;">'+ item.value +'</span>'
244
- }
281
+ var args = [{instance: this, item: item}];
282
+ if( ( content = $(this.input).triggerHandler('getoptioncontent', args) || (this.options.getOptionContent && this.options.getOptionContent.apply(this.input, args)) ) && content.indexOf && content.indexOf('option-value') == -1 ){
283
+ content += '<span class="option-value" style="display: none;">'+ item.value +'</span>';
245
284
  }
246
285
  if(content == null){
247
286
  content = '<span class="option-value">'+ item.value +'</span>';
@@ -251,15 +290,51 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
251
290
  }
252
291
  return content || '';
253
292
  },
293
+ setCompletedValue: function(value, foundItem){
294
+
295
+ if(!this.options.valueCompletion || !foundItem || this.lastCompletedValue.length >= value.length ){
296
+ this.lastCompletedValue = value;
297
+ return;
298
+ }
299
+
300
+ var newValue;
301
+ var input = this.input;
302
+ var end = $.prop(input, 'selectionEnd');
303
+
304
+ this.lastCompletedValue = value;
305
+
306
+ if(value.length == end){
307
+
308
+ newValue = value + foundItem.value.substr(value.length);
309
+
310
+ $(input).triggerHandler('triggerinput');
311
+ $.prop(input, 'value', newValue);
312
+ $(input).triggerHandler('updateInput');
313
+ $(input).callProp('setSelectionRange', [value.length, newValue.length]);
314
+
315
+ //safari workaround || needs more investigation
316
+ setTimeout(function(){
317
+ if(newValue == $.prop(input, 'value') && $.prop(input, 'selectionEnd') != newValue.length){
318
+ $.prop(input, 'selectionEnd', newValue.length);
319
+ }
320
+ }, 0);
321
+
322
+ }
323
+ },
254
324
  showHideOptions: function(_fromShowList){
255
- var value = $.prop(this.input, 'value').toLowerCase();
256
-
325
+ var lis, firstFoundValue;
326
+ var inputValue = $.prop(this.input, 'value');
327
+ var value = inputValue.toLowerCase();
328
+ var found = false;
329
+ var startSearch = this.options.filter == '^';
330
+ var that = this;
331
+
257
332
  //first check prevent infinite loop, second creates simple lazy optimization
258
333
  if(value === this.lastUpdatedValue){
259
334
  return;
260
335
  }
261
336
 
262
- if(this.multiple){
337
+ if(this.options.multiple){
263
338
  value = value.split(splitReg);
264
339
  value = value[value.length - 1] || '';
265
340
  }
@@ -271,13 +346,11 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
271
346
 
272
347
 
273
348
  this.lastUpdatedValue = value;
274
- var found = false;
275
- var startSearch = this.listFilter == '^';
276
- var lis = $('li', this.shadowList);
277
- var that = this;
349
+ lis = $('li', this.shadowList);
350
+
278
351
 
279
352
 
280
- if(value && this.listFilter != '!'){
353
+ if(value && this.options.filter != '!'){
281
354
 
282
355
 
283
356
  this.arrayOptions.forEach(function(item, i){
@@ -294,6 +367,9 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
294
367
  search = startSearch ? !searchIndex : searchIndex !== -1;
295
368
  if(search){
296
369
  foundName = 'value';
370
+ if(!firstFoundValue && !searchIndex){
371
+ firstFoundValue = item;
372
+ }
297
373
  } else if(item.lowerLabel){
298
374
  searchIndex = item.lowerLabel.indexOf(value);
299
375
  search = startSearch ? !searchIndex : searchIndex !== -1;
@@ -316,7 +392,11 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
316
392
  this.hasViewableData = found;
317
393
  if(!_fromShowList && found){
318
394
  if(this.popover.isVisible && this.popover.element.attr('data-vertical') == 'bottom'){
395
+ that._stopMouseOver = true;
319
396
  this.popover.element.triggerHandler('pospopover');
397
+ setTimeout(function(){
398
+ that._stopMouseOver = false;
399
+ }, 9);
320
400
  }
321
401
  this.showList();
322
402
  }
@@ -325,6 +405,7 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
325
405
  this.lastUnfoundValue = value;
326
406
  this.hideList();
327
407
  } else {
408
+ this.setCompletedValue(inputValue, firstFoundValue);
328
409
  this.lastUnfoundValue = false;
329
410
  }
330
411
  },
@@ -333,7 +414,7 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
333
414
  label: 'value'
334
415
  },
335
416
  addMark: function(elem, item, prop, start, length){
336
- if(this.addMarkElement){
417
+ if(this.options.highlight){
337
418
  var text = item[prop].substr(start, length);
338
419
  text = item[prop].replace(text ,'<mark>'+ text +'</mark>');
339
420
  $('.option-'+ this.otherType[prop] +' > mark', elem).each(this._replaceMark);
@@ -346,7 +427,7 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
346
427
  $(this).replaceWith(content);
347
428
  },
348
429
  removeMark: function(lis){
349
- if(this.addMarkElement){
430
+ if(this.options.highlight){
350
431
  $('mark', lis).each(this._replaceMark);
351
432
  }
352
433
  },
@@ -404,7 +485,7 @@ webshims.register('form-datalist-lazy', function($, webshims, window, document,
404
485
  var newValue = $('span.option-value', activeItem).text();
405
486
  var oldValue = $.prop(this.input, 'value');
406
487
 
407
- if(this.multiple){
488
+ if(this.options.multiple){
408
489
  tmpValue = oldValue.split(splitReg);
409
490
  tmpValue[tmpValue.length - 1] = newValue;
410
491
 
@@ -282,7 +282,9 @@ webshims.register('form-datalist', function($, webshims, window, document, undef
282
282
  noAutoCallback: true,
283
283
  options: $.extend(options, {shadowListProto: shadowListProto})
284
284
  });
285
-
285
+ if(!options.list){
286
+ options.list = {};
287
+ }
286
288
  //init datalist update
287
289
  initializeDatalist();
288
290
  })();
@@ -30,6 +30,7 @@ webshims.register('form-message', function($, webshims, window, document, undefi
30
30
  },
31
31
  stepMismatch: 'Invalid input.',
32
32
  tooLong: 'Please enter at most {%maxlength} character(s). You entered {%valueLen}.',
33
+ tooShort: 'Please enter at least {%minlength} character(s). You entered {%valueLen}.',
33
34
  patternMismatch: 'Invalid input. {%title}',
34
35
  valueMissing: {
35
36
  defaultMessage: 'Please fill out this field.',
@@ -86,6 +87,7 @@ webshims.register('form-message', function($, webshims, window, document, undefi
86
87
  },
87
88
  stepMismatch: 'Der Wert {%value} ist in diesem Feld nicht zulässig. Hier sind nur bestimmte Werte zulässig. {%title}',
88
89
  tooLong: 'Der eingegebene Text ist zu lang! Sie haben {%valueLen} Zeichen eingegeben, dabei sind {%maxlength} das Maximum.',
90
+ tooShort: 'Der eingegebene Text ist zu kurz! Sie haben {%valueLen} Zeichen eingegeben, dabei sind {%minlength} das Minimum.',
89
91
  patternMismatch: '{%value} hat für dieses Eingabefeld ein falsches Format. {%title}',
90
92
  valueMissing: {
91
93
  defaultMessage: 'Bitte geben Sie einen Wert ein.',
@@ -137,7 +139,7 @@ webshims.register('form-message', function($, webshims, window, document, undefi
137
139
  webshims.info('could not find errormessage for: '+ name +' / '+ type +'. in language: '+webshims.activeLang());
138
140
  }
139
141
  if(message){
140
- ['value', 'min', 'max', 'title', 'maxlength', 'label'].forEach(function(attr){
142
+ ['value', 'min', 'max', 'title', 'maxlength', 'minlength', 'label'].forEach(function(attr){
141
143
  if(message.indexOf('{%'+attr) === -1){return;}
142
144
  var val = ((attr == 'label') ? $.trim($('label[for="'+ elem.id +'"]', elem.form).text()).replace(/\*$|:$/, '') : $.prop(elem, attr)) || '';
143
145
  if(name == 'patternMismatch' && attr == 'title' && !val){
@@ -167,20 +169,10 @@ webshims.register('form-message', function($, webshims, window, document, undefi
167
169
  implementProperties.push('validationMessage');
168
170
  }
169
171
 
170
- webshims.activeLang({
171
- langObj: validityMessages,
172
- module: 'form-core',
173
- callback: function(langObj){
174
- currentValidationMessage = langObj;
175
- }
176
- });
177
- webshims.activeLang({
178
- register: 'form-core',
179
- callback: function(val){
180
- if(validityMessages[val]){
181
- currentValidationMessage = validityMessages[val];
182
- }
183
- }
172
+ currentValidationMessage = webshims.activeLang(validityMessages);
173
+
174
+ $(validityMessages).on('change', function(e, data){
175
+ currentValidationMessage = validityMessages.__active;
184
176
  });
185
177
 
186
178
  implementProperties.forEach(function(messageProp){
@@ -49,7 +49,7 @@ webshims.register('form-native-extend', function($, webshims, window, doc, undef
49
49
 
50
50
  var formsExtModule = webshims.modules['form-number-date-api'];
51
51
  var overrideValidity = formsExtModule.loaded && !formsExtModule.test();
52
- var validityProps = ['customError', 'badInput','typeMismatch','rangeUnderflow','rangeOverflow','stepMismatch','tooLong','patternMismatch','valueMissing','valid'];
52
+ var validityProps = ['customError', 'badInput','typeMismatch','rangeUnderflow','rangeOverflow','stepMismatch','tooLong', 'tooShort','patternMismatch','valueMissing','valid'];
53
53
 
54
54
  var validityChanger = ['value'];
55
55
  var validityElements = [];
@@ -107,7 +107,7 @@ webshims.register('form-native-extend', function($, webshims, window, doc, undef
107
107
  }
108
108
  var validityState = {};
109
109
  validityProps.forEach(function(prop){
110
- validityState[prop] = validity[prop];
110
+ validityState[prop] = validity[prop] || false;
111
111
  });
112
112
 
113
113
  if( !$.prop(elem, 'willValidate') ){