inputmask.numeric.extensions.js 27 KB

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