inputmask.numeric.extensions.js 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425
  1. /*!
  2. * inputmask.numeric.extensions.js
  3. * http://github.com/RobinHerbots/jquery.inputmask
  4. * Copyright (c) 2010 - 2015 Robin Herbots
  5. * Licensed under the MIT license (http://www.opensource.org/licenses/mit-license.php)
  6. * Version: 3.1.64-150
  7. */
  8. !function(factory) {
  9. "function" == typeof define && define.amd ? define([ "jquery", "./inputmask" ], factory) : "object" == typeof exports ? module.exports = factory(require("jquery"), require("./inputmask")) : factory(jQuery);
  10. }(function($) {
  11. return Inputmask.extendAliases({
  12. numeric: {
  13. mask: function(opts) {
  14. function autoEscape(txt) {
  15. for (var escapedTxt = "", i = 0; i < txt.length; i++) escapedTxt += opts.definitions[txt[i]] ? "\\" + txt[i] : txt[i];
  16. return escapedTxt;
  17. }
  18. if (0 !== opts.repeat && isNaN(opts.integerDigits) && (opts.integerDigits = opts.repeat),
  19. opts.repeat = 0, opts.groupSeparator === opts.radixPoint && ("." === opts.radixPoint ? opts.groupSeparator = "," : "," === opts.radixPoint ? opts.groupSeparator = "." : opts.groupSeparator = ""),
  20. " " === opts.groupSeparator && (opts.skipOptionalPartCharacter = void 0), opts.autoGroup = opts.autoGroup && "" !== opts.groupSeparator,
  21. opts.autoGroup && ("string" == typeof opts.groupSize && isFinite(opts.groupSize) && (opts.groupSize = parseInt(opts.groupSize)),
  22. isFinite(opts.integerDigits))) {
  23. var seps = Math.floor(opts.integerDigits / opts.groupSize), mod = opts.integerDigits % opts.groupSize;
  24. opts.integerDigits = parseInt(opts.integerDigits) + (0 === mod ? seps - 1 : seps),
  25. opts.integerDigits < 1 && (opts.integerDigits = "*");
  26. }
  27. opts.placeholder.length > 1 && (opts.placeholder = opts.placeholder.charAt(0)),
  28. opts.definitions[";"] = opts.definitions["~"], opts.definitions[";"].definitionSymbol = "~",
  29. opts.numericInput === !0 && (opts.radixFocus = !1, opts.digitsOptional = !1, isNaN(opts.digits) && (opts.digits = 2),
  30. opts.decimalProtect = !1);
  31. var mask = autoEscape(opts.prefix);
  32. return mask += "[+]", mask += "~{1," + opts.integerDigits + "}", void 0 !== opts.digits && (isNaN(opts.digits) || parseInt(opts.digits) > 0) && (mask += opts.digitsOptional ? "[" + (opts.decimalProtect ? ":" : opts.radixPoint) + ";{" + opts.digits + "}]" : (opts.decimalProtect ? ":" : opts.radixPoint) + ";{" + opts.digits + "}"),
  33. "" !== opts.negationSymbol.back && (mask += "[-]"), mask += autoEscape(opts.suffix),
  34. opts.greedy = !1, mask;
  35. },
  36. placeholder: "",
  37. greedy: !1,
  38. digits: "*",
  39. digitsOptional: !0,
  40. radixPoint: ".",
  41. radixFocus: !0,
  42. groupSize: 3,
  43. groupSeparator: "",
  44. autoGroup: !1,
  45. allowPlus: !0,
  46. allowMinus: !0,
  47. negationSymbol: {
  48. front: "-",
  49. back: ""
  50. },
  51. integerDigits: "+",
  52. prefix: "",
  53. suffix: "",
  54. rightAlign: !0,
  55. decimalProtect: !0,
  56. min: void 0,
  57. max: void 0,
  58. step: 1,
  59. insertMode: !0,
  60. autoUnmask: !1,
  61. unmaskAsNumber: !1,
  62. postFormat: function(buffer, pos, reformatOnly, opts) {
  63. opts.numericInput === !0 && (buffer = buffer.reverse(), isFinite(pos) && (pos = buffer.join("").length - pos - 1));
  64. var suffixStripped = !1;
  65. buffer.length >= opts.suffix.length && buffer.join("").indexOf(opts.suffix) === buffer.length - opts.suffix.length && (buffer.length = buffer.length - opts.suffix.length,
  66. suffixStripped = !0), pos = pos >= buffer.length ? buffer.length - 1 : pos < opts.prefix.length ? opts.prefix.length : pos;
  67. var needsRefresh = !1, charAtPos = buffer[pos];
  68. if ("" === opts.groupSeparator || opts.numericInput !== !0 && -1 !== $.inArray(opts.radixPoint, buffer) && pos > $.inArray(opts.radixPoint, buffer) || new RegExp("[" + Inputmask.escapeRegex(opts.negationSymbol.front) + "+]").test(charAtPos)) {
  69. if (suffixStripped) for (var i = 0, l = opts.suffix.length; l > i; i++) buffer.push(opts.suffix.charAt(i));
  70. return {
  71. pos: pos
  72. };
  73. }
  74. var cbuf = buffer.slice();
  75. charAtPos === opts.groupSeparator && (cbuf.splice(pos--, 1), charAtPos = cbuf[pos]),
  76. reformatOnly ? charAtPos !== opts.radixPoint && (cbuf[pos] = "?") : cbuf.splice(pos, 0, "?");
  77. var bufVal = cbuf.join(""), bufValOrigin = bufVal;
  78. if (bufVal.length > 0 && opts.autoGroup || reformatOnly && -1 !== bufVal.indexOf(opts.groupSeparator)) {
  79. var escapedGroupSeparator = Inputmask.escapeRegex(opts.groupSeparator);
  80. needsRefresh = 0 === bufVal.indexOf(opts.groupSeparator), bufVal = bufVal.replace(new RegExp(escapedGroupSeparator, "g"), "");
  81. var radixSplit = bufVal.split(opts.radixPoint);
  82. if (bufVal = "" === opts.radixPoint ? bufVal : radixSplit[0], bufVal !== opts.prefix + "?0" && bufVal.length >= opts.groupSize + opts.prefix.length) for (var reg = new RegExp("([-+]?[\\d?]+)([\\d?]{" + opts.groupSize + "})"); reg.test(bufVal); ) bufVal = bufVal.replace(reg, "$1" + opts.groupSeparator + "$2"),
  83. bufVal = bufVal.replace(opts.groupSeparator + opts.groupSeparator, opts.groupSeparator);
  84. "" !== opts.radixPoint && radixSplit.length > 1 && (bufVal += opts.radixPoint + radixSplit[1]);
  85. }
  86. needsRefresh = bufValOrigin !== bufVal, buffer.length = bufVal.length;
  87. for (var i = 0, l = bufVal.length; l > i; i++) buffer[i] = bufVal.charAt(i);
  88. var newPos = $.inArray("?", buffer);
  89. if (-1 === newPos && charAtPos === opts.radixPoint && (newPos = $.inArray(opts.radixPoint, buffer)),
  90. reformatOnly ? buffer[newPos] = charAtPos : buffer.splice(newPos, 1), !needsRefresh && suffixStripped) for (var i = 0, l = opts.suffix.length; l > i; i++) buffer.push(opts.suffix.charAt(i));
  91. return {
  92. pos: opts.numericInput && isFinite(pos) ? buffer.join("").length - newPos - 1 : newPos,
  93. refreshFromBuffer: needsRefresh,
  94. buffer: opts.numericInput === !0 ? buffer.reverse() : buffer
  95. };
  96. },
  97. onBeforeWrite: function(e, buffer, caretPos, opts) {
  98. if (e && "blur" == e.type) {
  99. var maskedValue = buffer.join(""), processValue = maskedValue.replace(opts.prefix, "");
  100. if (processValue = processValue.replace(opts.suffix, ""), processValue = processValue.replace(new RegExp(Inputmask.escapeRegex(opts.groupSeparator), "g"), ""),
  101. "," === opts.radixPoint && (processValue = processValue.replace(Inputmask.escapeRegex(opts.radixPoint), ".")),
  102. isFinite(processValue) && isFinite(opts.min) && parseFloat(processValue) < parseFloat(opts.min)) return $.extend(!0, {
  103. refreshFromBuffer: !0,
  104. buffer: (opts.prefix + opts.min).split("")
  105. }, opts.postFormat((opts.prefix + opts.min).split(""), 0, !0, opts));
  106. if (opts.numericInput !== !0) {
  107. var tmpBufSplit = "" != opts.radixPoint ? buffer.join("").split(opts.radixPoint) : [ buffer.join("") ], matchRslt = tmpBufSplit[0].match(opts.regex.integerPart(opts)), matchRsltDigits = 2 == tmpBufSplit.length ? tmpBufSplit[1].match(opts.regex.integerNPart(opts)) : void 0;
  108. !matchRslt || matchRslt[0] != opts.negationSymbol.front + "0" && matchRslt[0] != opts.negationSymbol.front && "+" != matchRslt[0] || void 0 != matchRsltDigits && !matchRsltDigits[0].match(/^0+$/) || buffer.splice(matchRslt.index, 1);
  109. var radixPosition = $.inArray(opts.radixPoint, buffer);
  110. if (-1 != radixPosition) {
  111. if (isFinite(opts.digits) && !opts.digitsOptional) {
  112. for (var i = 1; i <= opts.digits; i++) (void 0 == buffer[radixPosition + i] || buffer[radixPosition + i] == opts.placeholder.charAt(0)) && (buffer[radixPosition + i] = "0");
  113. return {
  114. refreshFromBuffer: !0,
  115. buffer: buffer
  116. };
  117. }
  118. if (radixPosition == buffer.length - opts.suffix.length - 1) return buffer.splice(radixPosition, 1),
  119. {
  120. refreshFromBuffer: !0,
  121. buffer: buffer
  122. };
  123. }
  124. }
  125. }
  126. if (opts.autoGroup) {
  127. var rslt = opts.postFormat(buffer, caretPos - 1, !0, opts);
  128. return rslt.caret = caretPos <= opts.prefix.length ? rslt.pos : rslt.pos + 1, rslt;
  129. }
  130. },
  131. regex: {
  132. integerPart: function(opts) {
  133. return new RegExp("[" + Inputmask.escapeRegex(opts.negationSymbol.front) + "+]?\\d+");
  134. },
  135. integerNPart: function(opts) {
  136. return new RegExp("[\\d" + Inputmask.escapeRegex(opts.groupSeparator) + "]+");
  137. }
  138. },
  139. signHandler: function(chrs, maskset, pos, strict, opts) {
  140. if (!strict && opts.allowMinus && "-" === chrs || opts.allowPlus && "+" === chrs) {
  141. var matchRslt = maskset.buffer.join("").match(opts.regex.integerPart(opts));
  142. if (matchRslt && matchRslt[0].length > 0) return maskset.buffer[matchRslt.index] == ("-" === chrs ? "+" : opts.negationSymbol.front) ? "-" == chrs ? "" != opts.negationSymbol.back ? {
  143. pos: matchRslt.index,
  144. c: opts.negationSymbol.front,
  145. remove: matchRslt.index,
  146. caret: pos,
  147. insert: {
  148. pos: maskset.buffer.length - opts.suffix.length - 1,
  149. c: opts.negationSymbol.back
  150. }
  151. } : {
  152. pos: matchRslt.index,
  153. c: opts.negationSymbol.front,
  154. remove: matchRslt.index,
  155. caret: pos
  156. } : "" != opts.negationSymbol.back ? {
  157. pos: matchRslt.index,
  158. c: "+",
  159. remove: [ matchRslt.index, maskset.buffer.length - opts.suffix.length - 1 ],
  160. caret: pos
  161. } : {
  162. pos: matchRslt.index,
  163. c: "+",
  164. remove: matchRslt.index,
  165. caret: pos
  166. } : maskset.buffer[matchRslt.index] == ("-" === chrs ? opts.negationSymbol.front : "+") ? "-" == chrs && "" != opts.negationSymbol.back ? {
  167. remove: [ matchRslt.index, maskset.buffer.length - opts.suffix.length - 1 ],
  168. caret: pos - 1
  169. } : {
  170. remove: matchRslt.index,
  171. caret: pos - 1
  172. } : "-" == chrs ? "" != opts.negationSymbol.back ? {
  173. pos: matchRslt.index,
  174. c: opts.negationSymbol.front,
  175. caret: pos + 1,
  176. insert: {
  177. pos: maskset.buffer.length - opts.suffix.length,
  178. c: opts.negationSymbol.back
  179. }
  180. } : {
  181. pos: matchRslt.index,
  182. c: opts.negationSymbol.front,
  183. caret: pos + 1
  184. } : {
  185. pos: matchRslt.index,
  186. c: chrs,
  187. caret: pos + 1
  188. };
  189. }
  190. return !1;
  191. },
  192. radixHandler: function(chrs, maskset, pos, strict, opts) {
  193. if (!strict && (-1 != $.inArray(chrs, [ ",", "." ]) && (chrs = opts.radixPoint),
  194. chrs === opts.radixPoint && void 0 != opts.digits && (isNaN(opts.digits) || parseInt(opts.digits) > 0))) {
  195. var radixPos = $.inArray(opts.radixPoint, maskset.buffer), integerValue = maskset.buffer.join("").match(opts.regex.integerPart(opts));
  196. if (-1 != radixPos && maskset.validPositions[radixPos]) return maskset.validPositions[radixPos - 1] ? {
  197. caret: radixPos + 1
  198. } : {
  199. pos: integerValue.index,
  200. c: integerValue[0],
  201. caret: radixPos + 1
  202. };
  203. if (!integerValue || "0" == integerValue[0] && integerValue.index + 1 != pos) return maskset.buffer[integerValue ? integerValue.index : pos] = "0",
  204. {
  205. pos: (integerValue ? integerValue.index : pos) + 1,
  206. c: opts.radixPoint
  207. };
  208. }
  209. return !1;
  210. },
  211. leadingZeroHandler: function(chrs, maskset, pos, strict, opts) {
  212. if (1 == opts.numericInput) {
  213. if ("0" == maskset.buffer[maskset.buffer.length - opts.prefix.length - 1]) return {
  214. pos: pos,
  215. remove: maskset.buffer.length - opts.prefix.length - 1
  216. };
  217. } else {
  218. var matchRslt = maskset.buffer.join("").match(opts.regex.integerNPart(opts)), radixPosition = $.inArray(opts.radixPoint, maskset.buffer);
  219. if (matchRslt && !strict && (-1 == radixPosition || radixPosition >= pos)) if (0 == matchRslt[0].indexOf("0")) {
  220. pos < opts.prefix.length && (pos = matchRslt.index);
  221. var _radixPosition = $.inArray(opts.radixPoint, maskset._buffer), digitsMatch = maskset._buffer && maskset.buffer.slice(radixPosition).join("") == maskset._buffer.slice(_radixPosition).join("") || 0 == parseInt(maskset.buffer.slice(radixPosition + 1).join("")), integerMatch = maskset._buffer && maskset.buffer.slice(matchRslt.index, radixPosition).join("") == maskset._buffer.slice(opts.prefix.length, _radixPosition).join("") || "0" == maskset.buffer.slice(matchRslt.index, radixPosition).join("");
  222. if (-1 == radixPosition || digitsMatch && integerMatch) return maskset.buffer.splice(matchRslt.index, 1),
  223. pos = pos > matchRslt.index ? pos - 1 : matchRslt.index, {
  224. pos: pos,
  225. remove: matchRslt.index
  226. };
  227. if (matchRslt.index + 1 == pos || "0" == chrs) return maskset.buffer.splice(matchRslt.index, 1),
  228. pos = matchRslt.index, {
  229. pos: pos,
  230. remove: matchRslt.index
  231. };
  232. } else if ("0" === chrs && pos <= matchRslt.index && matchRslt[0] != opts.groupSeparator) return !1;
  233. }
  234. return !0;
  235. },
  236. postValidation: function(buffer, opts) {
  237. var isValid = !0, maskedValue = buffer.join(""), processValue = maskedValue.replace(opts.prefix, "");
  238. return processValue = processValue.replace(opts.suffix, ""), processValue = processValue.replace(new RegExp(Inputmask.escapeRegex(opts.groupSeparator), "g"), ""),
  239. "," === opts.radixPoint && (processValue = processValue.replace(Inputmask.escapeRegex(opts.radixPoint), ".")),
  240. processValue = processValue.replace(new RegExp("^" + Inputmask.escapeRegex(opts.negationSymbol.front)), "-"),
  241. processValue = processValue.replace(new RegExp(Inputmask.escapeRegex(opts.negationSymbol.back) + "$"), ""),
  242. processValue = processValue == opts.negationSymbol.front ? processValue + "0" : processValue,
  243. isFinite(processValue) && (isFinite(opts.max) && (isValid = parseFloat(processValue) <= parseFloat(opts.max)),
  244. isValid && isFinite(opts.min) && (0 >= processValue || processValue.toString().length >= opts.min.toString().length) && (isValid = parseFloat(processValue) >= parseFloat(opts.min),
  245. isValid || (isValid = $.extend(!0, {
  246. refreshFromBuffer: !0,
  247. buffer: (opts.prefix + opts.min).split("")
  248. }, opts.postFormat((opts.prefix + opts.min).split(""), 0, !0, opts)), isValid.refreshFromBuffer = !0))),
  249. isValid;
  250. },
  251. definitions: {
  252. "~": {
  253. validator: function(chrs, maskset, pos, strict, opts) {
  254. var isValid = opts.signHandler(chrs, maskset, pos, strict, opts);
  255. if (!isValid && (isValid = opts.radixHandler(chrs, maskset, pos, strict, opts),
  256. !isValid && (isValid = strict ? new RegExp("[0-9" + Inputmask.escapeRegex(opts.groupSeparator) + "]").test(chrs) : new RegExp("[0-9]").test(chrs),
  257. isValid === !0 && (isValid = opts.leadingZeroHandler(chrs, maskset, pos, strict, opts),
  258. isValid === !0)))) {
  259. var radixPosition = $.inArray(opts.radixPoint, maskset.buffer);
  260. isValid = -1 != radixPosition && opts.digitsOptional === !1 && pos > radixPosition && !strict ? {
  261. pos: pos,
  262. remove: pos
  263. } : {
  264. pos: pos
  265. };
  266. }
  267. return isValid;
  268. },
  269. cardinality: 1,
  270. prevalidator: null
  271. },
  272. "+": {
  273. validator: function(chrs, maskset, pos, strict, opts) {
  274. var isValid = opts.signHandler(chrs, maskset, pos, strict, opts);
  275. return !isValid && (strict && opts.allowMinus && chrs === opts.negationSymbol.front || opts.allowMinus && "-" == chrs || opts.allowPlus && "+" == chrs) && (isValid = "-" == chrs ? "" != opts.negationSymbol.back ? {
  276. pos: pos,
  277. c: "-" === chrs ? opts.negationSymbol.front : "+",
  278. caret: pos + 1,
  279. insert: {
  280. pos: maskset.buffer.length,
  281. c: opts.negationSymbol.back
  282. }
  283. } : {
  284. pos: pos,
  285. c: "-" === chrs ? opts.negationSymbol.front : "+",
  286. caret: pos + 1
  287. } : !0), isValid;
  288. },
  289. cardinality: 1,
  290. prevalidator: null,
  291. placeholder: ""
  292. },
  293. "-": {
  294. validator: function(chrs, maskset, pos, strict, opts) {
  295. var isValid = opts.signHandler(chrs, maskset, pos, strict, opts);
  296. return !isValid && strict && opts.allowMinus && chrs === opts.negationSymbol.back && (isValid = !0),
  297. isValid;
  298. },
  299. cardinality: 1,
  300. prevalidator: null,
  301. placeholder: ""
  302. },
  303. ":": {
  304. validator: function(chrs, maskset, pos, strict, opts) {
  305. var isValid = opts.signHandler(chrs, maskset, pos, strict, opts);
  306. if (!isValid) {
  307. var radix = "[" + Inputmask.escapeRegex(opts.radixPoint) + ",\\.]";
  308. isValid = new RegExp(radix).test(chrs), isValid && maskset.validPositions[pos] && maskset.validPositions[pos].match.placeholder == opts.radixPoint && (isValid = {
  309. caret: pos + 1
  310. });
  311. }
  312. return isValid ? {
  313. c: opts.radixPoint
  314. } : isValid;
  315. },
  316. cardinality: 1,
  317. prevalidator: null,
  318. placeholder: function(opts) {
  319. return opts.radixPoint;
  320. }
  321. }
  322. },
  323. onUnMask: function(maskedValue, unmaskedValue, opts) {
  324. var processValue = maskedValue.replace(opts.prefix, "");
  325. return processValue = processValue.replace(opts.suffix, ""), processValue = processValue.replace(new RegExp(Inputmask.escapeRegex(opts.groupSeparator), "g"), ""),
  326. opts.unmaskAsNumber ? (processValue = processValue.replace(Inputmask.escapeRegex.call(this, opts.radixPoint), "."),
  327. Number(processValue)) : processValue;
  328. },
  329. isComplete: function(buffer, opts) {
  330. var maskedValue = buffer.join(""), bufClone = buffer.slice();
  331. if (opts.postFormat(bufClone, 0, !0, opts), bufClone.join("") !== maskedValue) return !1;
  332. var processValue = maskedValue.replace(opts.prefix, "");
  333. return processValue = processValue.replace(opts.suffix, ""), processValue = processValue.replace(new RegExp(Inputmask.escapeRegex(opts.groupSeparator), "g"), ""),
  334. "," === opts.radixPoint && (processValue = processValue.replace(Inputmask.escapeRegex(opts.radixPoint), ".")),
  335. isFinite(processValue);
  336. },
  337. onBeforeMask: function(initialValue, opts) {
  338. if ("" !== opts.radixPoint && isFinite(initialValue)) initialValue = initialValue.toString().replace(".", opts.radixPoint); else {
  339. var kommaMatches = initialValue.match(/,/g), dotMatches = initialValue.match(/\./g);
  340. dotMatches && kommaMatches ? dotMatches.length > kommaMatches.length ? (initialValue = initialValue.replace(/\./g, ""),
  341. initialValue = initialValue.replace(",", opts.radixPoint)) : kommaMatches.length > dotMatches.length ? (initialValue = initialValue.replace(/,/g, ""),
  342. initialValue = initialValue.replace(".", opts.radixPoint)) : initialValue = initialValue.indexOf(".") < initialValue.indexOf(",") ? initialValue.replace(/\./g, "") : initialValue = initialValue.replace(/,/g, "") : initialValue = initialValue.replace(new RegExp(Inputmask.escapeRegex(opts.groupSeparator), "g"), "");
  343. }
  344. if (0 == opts.digits && (-1 !== initialValue.indexOf(".") ? initialValue = initialValue.substring(0, initialValue.indexOf(".")) : -1 !== initialValue.indexOf(",") && (initialValue = initialValue.substring(0, initialValue.indexOf(",")))),
  345. "" !== opts.radixPoint && isFinite(opts.digits) && -1 !== initialValue.indexOf(opts.radixPoint)) {
  346. var valueParts = initialValue.split(opts.radixPoint), decPart = valueParts[1].match(new RegExp("\\d*"))[0];
  347. if (parseInt(opts.digits) < decPart.toString().length) {
  348. var digitsFactor = Math.pow(10, parseInt(opts.digits));
  349. initialValue = initialValue.replace(Inputmask.escapeRegex(opts.radixPoint), "."),
  350. initialValue = Math.round(parseFloat(initialValue) * digitsFactor) / digitsFactor,
  351. initialValue = initialValue.toString().replace(".", opts.radixPoint);
  352. }
  353. }
  354. return initialValue.toString();
  355. },
  356. canClearPosition: function(maskset, position, lvp, strict, opts) {
  357. var positionInput = maskset.validPositions[position].input, canClear = positionInput != opts.radixPoint || null != maskset.validPositions[position].match.fn && 0 == opts.decimalProtect || isFinite(positionInput) || position === lvp || positionInput === opts.groupSeparator || positionInput === opts.negationSymbol.front || positionInput === opts.negationSymbol.back;
  358. if (canClear && isFinite(positionInput)) {
  359. var matchRslt;
  360. if (!strict && maskset.buffer) {
  361. matchRslt = maskset.buffer.join("").substr(0, position).match(opts.regex.integerNPart(opts));
  362. var pos = position + 1, isNull = null == matchRslt || 0 == parseInt(matchRslt[0].replace(new RegExp(Inputmask.escapeRegex(opts.groupSeparator), "g"), ""));
  363. if (isNull) for (;maskset.validPositions[pos] && (maskset.validPositions[pos].input == opts.groupSeparator || "0" == maskset.validPositions[pos].input); ) delete maskset.validPositions[pos],
  364. pos++;
  365. }
  366. var buffer = [];
  367. for (var vp in maskset.validPositions) buffer.push(maskset.validPositions[vp].input);
  368. 1 == opts.numericInput && (position = buffer.join("").length - position, buffer.reverse()),
  369. matchRslt = buffer.join("").match(opts.regex.integerNPart(opts));
  370. var radixPosition = $.inArray(opts.radixPoint, maskset.buffer);
  371. if (matchRslt && (-1 == radixPosition || radixPosition >= position)) if (0 == matchRslt[0].indexOf("0")) canClear = matchRslt.index != position || -1 == radixPosition; else {
  372. var intPart = parseInt(matchRslt[0].replace(new RegExp(Inputmask.escapeRegex(opts.groupSeparator), "g"), ""));
  373. -1 != radixPosition && 10 > intPart && maskset.validPositions[position] && (maskset.validPositions[position].input = "0",
  374. maskset.p = opts.prefix.length + 1, canClear = !1);
  375. }
  376. }
  377. return canClear;
  378. },
  379. onKeyDown: function(e, buffer, caretPos, opts) {
  380. var $input = $(this);
  381. if (e.ctrlKey) switch (e.keyCode) {
  382. case inputmask.keyCode.UP:
  383. $input.val(parseFloat(this.inputmask.unmaskedvalue()) + parseInt(opts.step)), $input.triggerHandler("setvalue.inputmask");
  384. break;
  385. case inputmask.keyCode.DOWN:
  386. $input.val(parseFloat(this.inputmask.unmaskedvalue()) - parseInt(opts.step)), $input.triggerHandler("setvalue.inputmask");
  387. }
  388. }
  389. },
  390. currency: {
  391. prefix: "$ ",
  392. groupSeparator: ",",
  393. alias: "numeric",
  394. placeholder: "0",
  395. autoGroup: !0,
  396. digits: 2,
  397. digitsOptional: !1,
  398. clearMaskOnLostFocus: !1
  399. },
  400. decimal: {
  401. alias: "numeric"
  402. },
  403. integer: {
  404. alias: "numeric",
  405. digits: 0,
  406. radixPoint: ""
  407. },
  408. percentage: {
  409. alias: "numeric",
  410. digits: 2,
  411. radixPoint: ".",
  412. placeholder: "0",
  413. autoGroup: !1,
  414. min: 0,
  415. max: 100,
  416. suffix: " %",
  417. allowPlus: !1,
  418. allowMinus: !1
  419. },
  420. numeric2: {
  421. alias: "numeric"
  422. }
  423. }), Inputmask;
  424. });