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.
- checksums.yaml +4 -4
- data/lib/webshims-rails/version.rb +2 -2
- data/vendor/assets/javascripts/webshims/extras/modernizr-custom.js +114 -104
- data/vendor/assets/javascripts/webshims/extras/mousepress.js +5 -5
- data/vendor/assets/javascripts/webshims/polyfiller.js +156 -207
- data/vendor/assets/javascripts/webshims/shims/$ajax.js +862 -0
- data/vendor/assets/javascripts/webshims/shims/FlashCanvas/flashcanvas.js +20 -0
- data/vendor/assets/javascripts/webshims/shims/FlashCanvasPro/flashcanvas.js +20 -0
- data/vendor/assets/javascripts/webshims/shims/color-picker.js +12 -12
- data/vendor/assets/javascripts/webshims/shims/combos/1.js +62 -32
- data/vendor/assets/javascripts/webshims/shims/combos/10.js +192 -509
- data/vendor/assets/javascripts/webshims/shims/combos/11.js +96 -415
- data/vendor/assets/javascripts/webshims/shims/combos/12.js +36 -26
- data/vendor/assets/javascripts/webshims/shims/combos/13.js +36 -26
- data/vendor/assets/javascripts/webshims/shims/combos/14.js +1007 -359
- data/vendor/assets/javascripts/webshims/shims/combos/15.js +310 -235
- data/vendor/assets/javascripts/webshims/shims/combos/16.js +313 -237
- data/vendor/assets/javascripts/webshims/shims/combos/17.js +96 -415
- data/vendor/assets/javascripts/webshims/shims/combos/18.js +1003 -678
- data/vendor/assets/javascripts/webshims/shims/combos/19.js +1085 -387
- data/vendor/assets/javascripts/webshims/shims/combos/2.js +161 -127
- data/vendor/assets/javascripts/webshims/shims/combos/20.js +1086 -388
- data/vendor/assets/javascripts/webshims/shims/combos/21.js +168 -96
- data/vendor/assets/javascripts/webshims/shims/combos/22.js +36 -27
- data/vendor/assets/javascripts/webshims/shims/combos/23.js +2 -1
- data/vendor/assets/javascripts/webshims/shims/combos/24.js +411 -172
- data/vendor/assets/javascripts/webshims/shims/combos/25.js +1085 -387
- data/vendor/assets/javascripts/webshims/shims/combos/26.js +96 -94
- data/vendor/assets/javascripts/webshims/shims/combos/3.js +163 -140
- data/vendor/assets/javascripts/webshims/shims/combos/30.js +166 -141
- data/vendor/assets/javascripts/webshims/shims/combos/31.js +159 -126
- data/vendor/assets/javascripts/webshims/shims/combos/4.js +103 -109
- data/vendor/assets/javascripts/webshims/shims/combos/5.js +98 -417
- data/vendor/assets/javascripts/webshims/shims/combos/6.js +101 -418
- data/vendor/assets/javascripts/webshims/shims/combos/7.js +168 -142
- data/vendor/assets/javascripts/webshims/shims/combos/8.js +165 -141
- data/vendor/assets/javascripts/webshims/shims/combos/9.js +195 -510
- data/vendor/assets/javascripts/webshims/shims/details.js +2 -2
- data/vendor/assets/javascripts/webshims/shims/dom-extend.js +96 -94
- data/vendor/assets/javascripts/webshims/shims/es5.js +908 -264
- data/vendor/assets/javascripts/webshims/shims/excanvas.js +16 -1
- data/vendor/assets/javascripts/webshims/shims/form-combat.js +147 -0
- data/vendor/assets/javascripts/webshims/shims/form-core.js +60 -31
- data/vendor/assets/javascripts/webshims/shims/form-datalist-lazy.js +114 -33
- data/vendor/assets/javascripts/webshims/shims/form-datalist.js +3 -1
- data/vendor/assets/javascripts/webshims/shims/form-message.js +7 -15
- data/vendor/assets/javascripts/webshims/shims/form-native-extend.js +2 -2
- data/vendor/assets/javascripts/webshims/shims/form-number-date-ui.js +88 -410
- data/vendor/assets/javascripts/webshims/shims/form-shim-extend.js +143 -93
- data/vendor/assets/javascripts/webshims/shims/form-shim-extend2.js +268 -79
- data/vendor/assets/javascripts/webshims/shims/form-validation.js +116 -81
- data/vendor/assets/javascripts/webshims/shims/form-validators.js +23 -10
- data/vendor/assets/javascripts/webshims/shims/forms-picker.js +605 -9
- data/vendor/assets/javascripts/webshims/shims/geolocation.js +51 -39
- data/vendor/assets/javascripts/webshims/shims/i18n/formcfg-de.js +78 -33
- data/vendor/assets/javascripts/webshims/shims/i18n/formcfg-en.js +24 -6
- data/vendor/assets/javascripts/webshims/shims/i18n/formcfg-nl.js +110 -49
- data/vendor/assets/javascripts/webshims/shims/json-storage.js +3 -1
- data/vendor/assets/javascripts/webshims/shims/mediaelement-core.js +2 -1
- data/vendor/assets/javascripts/webshims/shims/mediaelement-jaris.js +81 -30
- data/vendor/assets/javascripts/webshims/shims/mediaelement-yt.js +131 -54
- data/vendor/assets/javascripts/webshims/shims/plugins/jquery.ui.position.js +497 -0
- data/vendor/assets/javascripts/webshims/shims/range-ui.js +8 -5
- data/vendor/assets/javascripts/webshims/shims/sizzle.js +2026 -0
- data/vendor/assets/javascripts/webshims/shims/styles/forms-ext.css +401 -521
- data/vendor/assets/javascripts/webshims/shims/styles/scss/forms-ext.scss +1 -1
- data/vendor/assets/javascripts/webshims/shims/styles/scss/shim.scss +94 -82
- data/vendor/assets/javascripts/webshims/shims/styles/shim.css +250 -321
- data/vendor/assets/javascripts/webshims/shims/swf/JarisFLVPlayer.swf +0 -0
- data/vendor/assets/javascripts/webshims/shims/track-ui.js +1 -1
- data/vendor/assets/javascripts/webshims/shims/track.js +34 -25
- 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
|
-
|
65
|
-
"
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
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
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
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
|
-
|
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
|
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
|
-
.
|
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
|
-
|
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.
|
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
|
-
|
184
|
-
|
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, '<').replace(gReg, '>'),
|
239
|
+
value: this.options.noHtmlEscape ? value : value.replace(lReg, '<').replace(gReg, '>'),
|
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
|
-
|
241
|
-
|
242
|
-
|
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
|
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
|
-
|
275
|
-
|
276
|
-
var lis = $('li', this.shadowList);
|
277
|
-
var that = this;
|
349
|
+
lis = $('li', this.shadowList);
|
350
|
+
|
278
351
|
|
279
352
|
|
280
|
-
if(value && this.
|
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.
|
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.
|
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
|
-
|
172
|
-
|
173
|
-
|
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') ){
|