From 0610e34f673eb984d563e75c06fbe30f04011538 Mon Sep 17 00:00:00 2001 From: Julia Abdullaeva Date: Fri, 12 May 2017 13:28:09 +0300 Subject: [PATCH] androidInputEvent remove --- dist/jquery.maskedinput.js | 28 ++++++++-------------------- dist/jquery.maskedinput.min.js | 4 ++-- src/jquery.maskedinput.js | 6 ------ 3 files changed, 10 insertions(+), 28 deletions(-) diff --git a/dist/jquery.maskedinput.js b/dist/jquery.maskedinput.js index 4ac3cfc..603f13c 100644 --- a/dist/jquery.maskedinput.js +++ b/dist/jquery.maskedinput.js @@ -1,13 +1,14 @@ /* jQuery Masked Input Plugin - Copyright (c) 2007 - 2015 Josh Bush (digitalbush.com) + Copyright (c) 2007 - 2017 Josh Bush (digitalbush.com) Licensed under the MIT license (http://digitalbush.com/projects/masked-input-plugin/#license) Version: 1.4.1 */ !function(factory) { "function" == typeof define && define.amd ? define([ "jquery" ], factory) : factory("object" == typeof exports ? require("jquery") : jQuery); }(function($) { - var caretTimeoutId, ua = navigator.userAgent, iPhone = /iphone/i.test(ua), chrome = /chrome/i.test(ua), android = /android/i.test(ua); + var caretTimeoutId, ua = navigator.userAgent, iPhone = /iphone/i.test(ua), android = (/chrome/i.test(ua), + /android/i.test(ua)); $.mask = { definitions: { "9": "[0-9]", @@ -20,7 +21,7 @@ }, $.fn.extend({ caret: function(begin, end) { var range; - if (0 !== this.length && !this.is(":hidden")) return "number" == typeof begin ? (end = "number" == typeof end ? end : begin, + if (0 !== this.length && !this.is(":hidden") && this.get(0) === document.activeElement) return "number" == typeof begin ? (end = "number" == typeof end ? end : begin, this.each(function() { this.setSelectionRange ? this.setSelectionRange(begin, end) : this.createTextRange && (range = this.createTextRange(), range.collapse(!0), range.moveEnd("character", end), range.moveStart("character", begin), @@ -47,7 +48,7 @@ placeholder: $.mask.placeholder, completed: null }, settings), defs = $.mask.definitions, tests = [], partialPosition = len = mask.length, - firstNonMaskPos = null, $.each(mask.split(""), function(i, c) { + firstNonMaskPos = null, mask = String(mask), $.each(mask.split(""), function(i, c) { "?" == c ? (len--, partialPosition = i) : defs[c] ? (tests.push(new RegExp(defs[c])), null === firstNonMaskPos && (firstNonMaskPos = tests.length - 1), partialPosition > i && (lastRequiredNonMaskPos = tests.length - 1)) : tests.push(null); }), this.trigger("unmask").each(function() { @@ -58,7 +59,7 @@ } } function getPlaceholder(i) { - return settings.placeholder.charAt(i < settings.placeholder.length ? i : 0); + return i < settings.placeholder.length ? settings.placeholder.charAt(i) : settings.placeholder.charAt(0); } function seekNext(pos) { for (;++pos < len && !tests[pos]; ) ; @@ -85,19 +86,7 @@ c = t; } } - function androidInputEvent() { - var curVal = input.val(), pos = input.caret(); - if (oldVal && oldVal.length && oldVal.length > curVal.length) { - for (checkVal(!0); pos.begin > 0 && !tests[pos.begin - 1]; ) pos.begin--; - if (0 === pos.begin) for (;pos.begin < firstNonMaskPos && !tests[pos.begin]; ) pos.begin++; - input.caret(pos.begin, pos.begin); - } else { - for (checkVal(!0); pos.begin < len && !tests[pos.begin]; ) pos.begin++; - input.caret(pos.begin, pos.begin); - } - tryFireCompleted(); - } - function blurEvent() { + function blurEvent(e) { checkVal(), input.val() != focusText && input.change(); } function keydownEvent(e) { @@ -174,8 +163,7 @@ var pos = checkVal(!0); input.caret(pos), tryFireCompleted(); }, 0); - }), chrome && android && input.off("input.mask").on("input.mask", androidInputEvent), - checkVal(); + }), checkVal(); }); } }); diff --git a/dist/jquery.maskedinput.min.js b/dist/jquery.maskedinput.min.js index d4dfd01..3fe8811 100644 --- a/dist/jquery.maskedinput.min.js +++ b/dist/jquery.maskedinput.min.js @@ -1,7 +1,7 @@ /* jQuery Masked Input Plugin - Copyright (c) 2007 - 2015 Josh Bush (digitalbush.com) + Copyright (c) 2007 - 2017 Josh Bush (digitalbush.com) Licensed under the MIT license (http://digitalbush.com/projects/masked-input-plugin/#license) Version: 1.4.1 */ -!function(a){"function"==typeof define&&define.amd?define(["jquery"],a):a("object"==typeof exports?require("jquery"):jQuery)}(function(a){var b,c=navigator.userAgent,d=/iphone/i.test(c),e=/chrome/i.test(c),f=/android/i.test(c);a.mask={definitions:{9:"[0-9]",a:"[A-Za-z]","*":"[A-Za-z0-9]"},autoclear:!0,dataName:"rawMaskFn",placeholder:"_"},a.fn.extend({caret:function(a,b){var c;if(0!==this.length&&!this.is(":hidden"))return"number"==typeof a?(b="number"==typeof b?b:a,this.each(function(){this.setSelectionRange?this.setSelectionRange(a,b):this.createTextRange&&(c=this.createTextRange(),c.collapse(!0),c.moveEnd("character",b),c.moveStart("character",a),c.select())})):(this[0].setSelectionRange?(a=this[0].selectionStart,b=this[0].selectionEnd):document.selection&&document.selection.createRange&&(c=document.selection.createRange(),a=0-c.duplicate().moveStart("character",-1e5),b=a+c.text.length),{begin:a,end:b})},unmask:function(){return this.trigger("unmask")},mask:function(c,g){var h,i,j,k,l,m,n,o;if(!c&&this.length>0){h=a(this[0]);var p=h.data(a.mask.dataName);return p?p():void 0}return g=a.extend({autoclear:a.mask.autoclear,placeholder:a.mask.placeholder,completed:null},g),i=a.mask.definitions,j=[],k=n=c.length,l=null,a.each(c.split(""),function(a,b){"?"==b?(n--,k=a):i[b]?(j.push(new RegExp(i[b])),null===l&&(l=j.length-1),k>a&&(m=j.length-1)):j.push(null)}),this.trigger("unmask").each(function(){function h(){if(g.completed){for(var a=l;m>=a;a++)if(j[a]&&C[a]===p(a))return;g.completed.call(B)}}function p(a){return g.placeholder.charAt(a=0&&!j[a];);return a}function s(a,b){var c,d;if(!(0>a)){for(c=a,d=q(b);n>c;c++)if(j[c]){if(!(n>d&&j[c].test(C[d])))break;C[c]=C[d],C[d]=p(d),d=q(d)}z(),B.caret(Math.max(l,a))}}function t(a){var b,c,d,e;for(b=a,c=p(a);n>b;b++)if(j[b]){if(d=q(b),e=C[b],C[b]=c,!(n>d&&j[d].test(e)))break;c=e}}function u(){var a=B.val(),b=B.caret();if(o&&o.length&&o.length>a.length){for(A(!0);b.begin>0&&!j[b.begin-1];)b.begin--;if(0===b.begin)for(;b.beging)&&g&&13!==g){if(i.end-i.begin!==0&&(y(i.begin,i.end),s(i.begin,i.end-1)),c=q(i.begin-1),n>c&&(d=String.fromCharCode(g),j[c].test(d))){if(t(c),C[c]=d,z(),e=q(c),f){var k=function(){a.proxy(a.fn.caret,B,e)()};setTimeout(k,0)}else B.caret(e);i.begin<=m&&h()}b.preventDefault()}}}function y(a,b){var c;for(c=a;b>c&&n>c;c++)j[c]&&(C[c]=p(c))}function z(){B.val(C.join(""))}function A(a){var b,c,d,e=B.val(),f=-1;for(b=0,d=0;n>b;b++)if(j[b]){for(C[b]=p(b);d++e.length){y(b+1,n);break}}else C[b]===e.charAt(d)&&d++,k>b&&(f=b);return a?z():k>f+1?g.autoclear||C.join("")===D?(B.val()&&B.val(""),y(0,n)):z():(z(),B.val(B.val().substring(0,f+1))),k?b:l}var B=a(this),C=a.map(c.split(""),function(a,b){return"?"!=a?i[a]?p(b):a:void 0}),D=C.join(""),E=B.val();B.data(a.mask.dataName,function(){return a.map(C,function(a,b){return j[b]&&a!=p(b)?a:null}).join("")}),B.one("unmask",function(){B.off(".mask").removeData(a.mask.dataName)}).on("focus.mask",function(){if(!B.prop("readonly")){clearTimeout(b);var a;E=B.val(),a=A(),b=setTimeout(function(){B.get(0)===document.activeElement&&(z(),a==c.replace("?","").length?B.caret(0,a):B.caret(a))},10)}}).on("blur.mask",v).on("keydown.mask",w).on("keypress.mask",x).on("input.mask paste.mask",function(){B.prop("readonly")||setTimeout(function(){var a=A(!0);B.caret(a),h()},0)}),e&&f&&B.off("input.mask").on("input.mask",u),A()})}})}); \ No newline at end of file +!function(a){"function"==typeof define&&define.amd?define(["jquery"],a):a("object"==typeof exports?require("jquery"):jQuery)}(function(a){var b,c=navigator.userAgent,d=/iphone/i.test(c),e=(/chrome/i.test(c),/android/i.test(c));a.mask={definitions:{9:"[0-9]",a:"[A-Za-z]","*":"[A-Za-z0-9]"},autoclear:!0,dataName:"rawMaskFn",placeholder:"_"},a.fn.extend({caret:function(a,b){var c;if(0!==this.length&&!this.is(":hidden")&&this.get(0)===document.activeElement)return"number"==typeof a?(b="number"==typeof b?b:a,this.each(function(){this.setSelectionRange?this.setSelectionRange(a,b):this.createTextRange&&(c=this.createTextRange(),c.collapse(!0),c.moveEnd("character",b),c.moveStart("character",a),c.select())})):(this[0].setSelectionRange?(a=this[0].selectionStart,b=this[0].selectionEnd):document.selection&&document.selection.createRange&&(c=document.selection.createRange(),a=0-c.duplicate().moveStart("character",-1e5),b=a+c.text.length),{begin:a,end:b})},unmask:function(){return this.trigger("unmask")},mask:function(c,f){var g,h,i,j,k,l,m,n;if(!c&&this.length>0){g=a(this[0]);var o=g.data(a.mask.dataName);return o?o():void 0}return f=a.extend({autoclear:a.mask.autoclear,placeholder:a.mask.placeholder,completed:null},f),h=a.mask.definitions,i=[],j=m=c.length,k=null,c=String(c),a.each(c.split(""),function(a,b){"?"==b?(m--,j=a):h[b]?(i.push(new RegExp(h[b])),null===k&&(k=i.length-1),j>a&&(l=i.length-1)):i.push(null)}),this.trigger("unmask").each(function(){function g(){if(f.completed){for(var a=k;l>=a;a++)if(i[a]&&A[a]===o(a))return;f.completed.call(z)}}function o(a){return a=0&&!i[a];);return a}function r(a,b){var c,d;if(!(0>a)){for(c=a,d=p(b);m>c;c++)if(i[c]){if(!(m>d&&i[c].test(A[d])))break;A[c]=A[d],A[d]=o(d),d=p(d)}x(),z.caret(Math.max(k,a))}}function s(a){var b,c,d,e;for(b=a,c=o(a);m>b;b++)if(i[b]){if(d=p(b),e=A[b],A[b]=c,!(m>d&&i[d].test(e)))break;c=e}}function t(a){y(),z.val()!=C&&z.change()}function u(a){if(!z.prop("readonly")){var b,c,e,f=a.which||a.keyCode;n=z.val(),8===f||46===f||d&&127===f?(b=z.caret(),c=b.begin,e=b.end,e-c===0&&(c=46!==f?q(c):e=p(c-1),e=46===f?p(e):e),w(c,e),r(c,e-1),a.preventDefault()):13===f?t.call(this,a):27===f&&(z.val(C),z.caret(0,y()),a.preventDefault())}}function v(b){if(!z.prop("readonly")){var c,d,f,h=b.which||b.keyCode,j=z.caret();if(!(b.ctrlKey||b.altKey||b.metaKey||32>h)&&h&&13!==h){if(j.end-j.begin!==0&&(w(j.begin,j.end),r(j.begin,j.end-1)),c=p(j.begin-1),m>c&&(d=String.fromCharCode(h),i[c].test(d))){if(s(c),A[c]=d,x(),f=p(c),e){var k=function(){a.proxy(a.fn.caret,z,f)()};setTimeout(k,0)}else z.caret(f);j.begin<=l&&g()}b.preventDefault()}}}function w(a,b){var c;for(c=a;b>c&&m>c;c++)i[c]&&(A[c]=o(c))}function x(){z.val(A.join(""))}function y(a){var b,c,d,e=z.val(),g=-1;for(b=0,d=0;m>b;b++)if(i[b]){for(A[b]=o(b);d++e.length){w(b+1,m);break}}else A[b]===e.charAt(d)&&d++,j>b&&(g=b);return a?x():j>g+1?f.autoclear||A.join("")===B?(z.val()&&z.val(""),w(0,m)):x():(x(),z.val(z.val().substring(0,g+1))),j?b:k}var z=a(this),A=a.map(c.split(""),function(a,b){return"?"!=a?h[a]?o(b):a:void 0}),B=A.join(""),C=z.val();z.data(a.mask.dataName,function(){return a.map(A,function(a,b){return i[b]&&a!=o(b)?a:null}).join("")}),z.one("unmask",function(){z.off(".mask").removeData(a.mask.dataName)}).on("focus.mask",function(){if(!z.prop("readonly")){clearTimeout(b);var a;C=z.val(),a=y(),b=setTimeout(function(){z.get(0)===document.activeElement&&(x(),a==c.replace("?","").length?z.caret(0,a):z.caret(a))},10)}}).on("blur.mask",t).on("keydown.mask",u).on("keypress.mask",v).on("input.mask paste.mask",function(){z.prop("readonly")||setTimeout(function(){var a=y(!0);z.caret(a),g()},0)}),y()})}})}); \ No newline at end of file diff --git a/src/jquery.maskedinput.js b/src/jquery.maskedinput.js index d0f8a2d..fef155c 100644 --- a/src/jquery.maskedinput.js +++ b/src/jquery.maskedinput.js @@ -435,12 +435,6 @@ $.fn.extend({ tryFireCompleted(); }, 0); }); - if (chrome && android) - { - input - .off('input.mask') - .on('input.mask', androidInputEvent); - } checkVal(); //Perform initial check for existing values }); }