tests.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439
  1. var keyCodes = {
  2. ALT: 18, BACKSPACE: 8, CAPS_LOCK: 20, COMMA: 188, COMMAND: 91, COMMAND_LEFT: 91, COMMAND_RIGHT: 93, CONTROL: 17, DELETE: 46, DOWN: 40, END: 35, ENTER: 13, ESCAPE: 27, HOME: 36, INSERT: 45, LEFT: 37, MENU: 93, NUMPAD_ADD: 107, NUMPAD_DECIMAL: 110, NUMPAD_DIVIDE: 111, NUMPAD_ENTER: 108,
  3. NUMPAD_MULTIPLY: 106, NUMPAD_SUBTRACT: 109, PAGE_DOWN: 34, PAGE_UP: 33, PERIOD: 190, RIGHT: 39, SHIFT: 16, SPACE: 32, TAB: 9, UP: 38, WINDOWS: 91
  4. }
  5. $.fn.SendKey = function (keyCode) {
  6. var sendDummyKeydown = false;
  7. if ( Object.prototype.toString.call(keyCode) == '[object String]') {
  8. keyCode = keyCode.charCodeAt(0);
  9. sendDummyKeydown = true;
  10. }
  11. function caret(input, begin, end) {
  12. var npt = input.jquery && input.length > 0 ? input[0] : input, range;
  13. if (typeof begin == 'number') {
  14. if (!$(input).is(':visible')) {
  15. return;
  16. }
  17. end = (typeof end == 'number') ? end : begin;
  18. if (npt.setSelectionRange) {
  19. npt.selectionStart = begin;
  20. npt.selectionEnd = end;
  21. } else if (npt.createTextRange) {
  22. range = npt.createTextRange();
  23. range.collapse(true);
  24. range.moveEnd('character', end);
  25. range.moveStart('character', begin);
  26. range.select();
  27. }
  28. } else {
  29. if (!$(input).is(':visible')) {
  30. return { "begin": 0, "end": 0 };
  31. }
  32. if (npt.setSelectionRange) {
  33. begin = npt.selectionStart;
  34. end = npt.selectionEnd;
  35. } else if (document.selection && document.selection.createRange) {
  36. range = document.selection.createRange();
  37. begin = 0 - range.duplicate().moveStart('character', -100000);
  38. end = begin + range.text.length;
  39. }
  40. return { "begin": begin, "end": end };
  41. }
  42. };
  43. switch (keyCode) {
  44. case keyCodes.LEFT: {
  45. var pos = caret(this);
  46. caret(this, pos.begin - 1);
  47. break;
  48. }
  49. case keyCodes.RIGHT: {
  50. var pos = caret(this);
  51. caret(this, pos.begin + 1);
  52. break;
  53. }
  54. default: {
  55. var keydown = $.Event("keydown"),
  56. keypress = $.Event("keypress"),
  57. keyup = $.Event("keyup");
  58. if(!sendDummyKeydown) keydown.keyCode = keyCode;
  59. $(this).trigger(keydown);
  60. if (!keydown.isDefaultPrevented()) {
  61. keypress.keyCode = keyCode;
  62. $(this).trigger(keypress);
  63. if (!keypress.isDefaultPrevented()) {
  64. keyup.keyCode = keyCode;
  65. $(this).trigger(keyup);
  66. }
  67. }
  68. }
  69. }
  70. }
  71. module("Simple masking");
  72. test("inputmask(\"99-99-99\", { clearMaskOnLostFocus: false}", function () {
  73. $('body').append('<input type="text" id="testmask" />');
  74. $("#testmask").inputmask("99-99-99", { clearMaskOnLostFocus: false });
  75. equal(document.getElementById("testmask").value, "__-__-__", "Result " + document.getElementById("testmask").value);
  76. $("#testmask").remove();
  77. });
  78. test("inputmask(\"99-99-99\", { clearMaskOnLostFocus: true}", function () {
  79. $('body').append('<input type="text" id="testmask" />');
  80. $("#testmask").inputmask("99-99-99", { clearMaskOnLostFocus: true });
  81. equal(document.getElementById("testmask").value, "", "Result " + document.getElementById("testmask").value);
  82. $("#testmask").remove();
  83. });
  84. test("inputmask(\"999.999.999\")", function () {
  85. $('body').append('<input type="text" id="testmask" />');
  86. $("#testmask").inputmask("999.999.999");
  87. $("#testmask")[0].focus();
  88. var event;
  89. $("#testmask").SendKey(49);
  90. $("#testmask").SendKey(50);
  91. $("#testmask").SendKey(51);
  92. equal($("#testmask").val(), "123.___.___", "Result " + $("#testmask").val());
  93. $("#testmask").remove();
  94. });
  95. asyncTest("inputmask(\"999.999.999\", { oncomplete: ... })", 1, function () {
  96. $('body').append('<input type="text" id="testmask" />');
  97. $("#testmask").inputmask("999.999.999", {
  98. oncomplete: function () {
  99. equal($("#testmask").val(), "123.456.789", "Result " + $("#testmask").val());
  100. start();
  101. $("#testmask").remove();
  102. }
  103. });
  104. $("#testmask")[0].focus();
  105. $("#testmask").SendKey(49);
  106. $("#testmask").SendKey(50);
  107. $("#testmask").SendKey(51);
  108. $("#testmask").SendKey(52);
  109. $("#testmask").SendKey(53);
  110. $("#testmask").SendKey(54);
  111. $("#testmask").SendKey(55);
  112. $("#testmask").SendKey(56);
  113. $("#testmask").SendKey(57);
  114. });
  115. asyncTest("inputmask(\"9-AAA.999\") - change event", 1, function () {
  116. $('body').append('<input type="text" id="testmask" />');
  117. $("#testmask").inputmask("9-AAA.999").change(function () {
  118. ok(true, "Change triggered");
  119. setTimeout(function () {
  120. $("#testmask").remove();
  121. start();
  122. });
  123. });
  124. $("#testmask")[0].focus();
  125. $("#testmask").SendKey(49);
  126. $("#testmask").SendKey(65);
  127. $("#testmask").SendKey(66);
  128. $("#testmask").SendKey(67);
  129. $("#testmask").SendKey(50);
  130. $("#testmask").SendKey(51);
  131. $("#testmask").blur();
  132. });
  133. asyncTest("inputmask(\"9-AAA.999\", { onincomplete: ... })", 1, function () {
  134. $('body').append('<input type="text" id="testmask" />');
  135. $("#testmask").inputmask("9-AAA.999", {
  136. onincomplete: function () {
  137. equal($("#testmask").val(), "1-ABC.12_", "Result " + $("#testmask").val());
  138. start();
  139. $("#testmask").remove();
  140. }
  141. });
  142. $("#testmask")[0].focus();
  143. $("#testmask").SendKey(49);
  144. $("#testmask").SendKey(65);
  145. $("#testmask").SendKey(66);
  146. $("#testmask").SendKey(67);
  147. $("#testmask").SendKey(49);
  148. $("#testmask").SendKey(50);
  149. $("#testmask").blur();
  150. });
  151. test("inputmask(\"999.999.999\") - delete 2nd with backspace, continue the mask", function () {
  152. $('body').append('<input type="text" id="testmask" />');
  153. $("#testmask").inputmask("999.999.999");
  154. $("#testmask")[0].focus();
  155. var event;
  156. $("#testmask").SendKey(49);
  157. $("#testmask").SendKey(50);
  158. $("#testmask").SendKey(51);
  159. $("#testmask").SendKey(keyCodes.LEFT);
  160. $("#testmask").SendKey(keyCodes.LEFT);
  161. $("#testmask").SendKey(keyCodes.BACKSPACE);
  162. $("#testmask").SendKey(52);
  163. $("#testmask").SendKey(keyCodes.RIGHT);
  164. $("#testmask").SendKey(53);
  165. $("#testmask").SendKey(54);
  166. equal($("#testmask").val(), "143.56_.___", "Result " + $("#testmask").val());
  167. $("#testmask").remove();
  168. });
  169. test("inputmask(\"999.999.999\") - delete 2nd with delete, continue the mask", function () {
  170. $('body').append('<input type="text" id="testmask" />');
  171. $("#testmask").inputmask("999.999.999");
  172. $("#testmask")[0].focus();
  173. var event;
  174. $("#testmask").SendKey(49);
  175. $("#testmask").SendKey(50);
  176. $("#testmask").SendKey(51);
  177. $("#testmask").SendKey(keyCodes.LEFT);
  178. $("#testmask").SendKey(keyCodes.LEFT);
  179. $("#testmask").SendKey(keyCodes.LEFT);
  180. $("#testmask").SendKey(keyCodes.DELETE);
  181. $("#testmask").SendKey(52);
  182. $("#testmask").SendKey(keyCodes.RIGHT);
  183. $("#testmask").SendKey(53);
  184. $("#testmask").SendKey(54);
  185. equal($("#testmask").val(), "143.56_.___", "Result " + $("#testmask").val());
  186. $("#testmask").remove();
  187. });
  188. test("RTL inputmask(\"999.999.999\") - delete 2nd with backspace, continue the mask", function () {
  189. $('body').append('<input type="text" id="testmask" dir="rtl" />');
  190. $("#testmask").inputmask("999.999.999");
  191. $("#testmask")[0].focus();
  192. var event;
  193. $("#testmask").SendKey("1");
  194. $("#testmask").SendKey("2");
  195. $("#testmask").SendKey("3");
  196. $("#testmask").SendKey(keyCodes.RIGHT);
  197. $("#testmask").SendKey(keyCodes.RIGHT);
  198. $("#testmask").SendKey(keyCodes.BACKSPACE);
  199. $("#testmask").SendKey("4");
  200. $("#testmask").SendKey(keyCodes.LEFT);
  201. $("#testmask").SendKey("5");
  202. $("#testmask").SendKey("6");
  203. equal($("#testmask").val(), "___._65.341", "Result " + $("#testmask").val());
  204. $("#testmask").remove();
  205. });
  206. test("RTL inputmask(\"999.999.999\") - delete 2nd with delete, continue the mask", function () {
  207. $('body').append('<input type="text" id="testmask" dir="rtl" />');
  208. $("#testmask").inputmask("999.999.999");
  209. $("#testmask")[0].focus();
  210. var event;
  211. $("#testmask").SendKey("1");
  212. $("#testmask").SendKey("2");
  213. $("#testmask").SendKey("3");
  214. $("#testmask").SendKey(keyCodes.RIGHT);
  215. $("#testmask").SendKey(keyCodes.DELETE);
  216. $("#testmask").SendKey("4");
  217. $("#testmask").SendKey(keyCodes.LEFT);
  218. $("#testmask").SendKey("5");
  219. $("#testmask").SendKey("6");
  220. equal($("#testmask").val(), "___._65.341", "Result " + $("#testmask").val());
  221. $("#testmask").remove();
  222. });
  223. module("Initial value setting");
  224. test("inputmask(\"999:99\", { placeholder: \"0\"}) value=\"007:20\"", function () {
  225. $('body').append('<input type="text" id="testmask" value="007:20" />');
  226. $("#testmask").inputmask("999:99", { placeholder: "0" });
  227. equal($("#testmask").val(), "007:20", "Result " + $("#testmask").val());
  228. $("#testmask").remove();
  229. });
  230. test("inputmask(\"99 999 999 999 9999 \\D\\E*** 9999\") ~ value=\"01 650 103 002 0001 DE101 5170\"", function () {
  231. $('body').append('<input type="text" id="testmask" value="01 650 103 002 0001 DE101 5170" />');
  232. $("#testmask").inputmask("99 999 999 999 9999 \\D\\E*** 9999");
  233. equal($("#testmask").val(), "01 650 103 002 0001 DE101 5170", "Result " + $("#testmask").val());
  234. $("#testmask").remove();
  235. });
  236. test("inputmask(\"99 999 999 999 9999 \\D\\E*** 9999\") ~ value=\"016501030020001DE1015170\"", function () {
  237. $('body').append('<input type="text" id="testmask" value="016501030020001DE1015170" />');
  238. $("#testmask").inputmask("99 999 999 999 9999 \\D\\E*** 9999");
  239. equal($("#testmask").val(), "01 650 103 002 0001 DE101 5170", "Result " + $("#testmask").val());
  240. $("#testmask").remove();
  241. });
  242. test("inputmask(\"\\D\\E***\") ~ value=\"DE001\"", function () {
  243. $('body').append('<input type="text" id="testmask" value="DE001" />');
  244. $("#testmask").inputmask("\\D\\E***");
  245. equal($("#testmask").val(), "DE001", "Result " + $("#testmask").val());
  246. $("#testmask").remove();
  247. });
  248. test("inputmask(\"decimal\") ~ value=\"123.45\"", function () {
  249. $('body').append('<input type="text" id="testmask" value="123.45" />');
  250. $("#testmask").inputmask("decimal");
  251. equal($("#testmask").val(), "123.45", "Result " + $("#testmask").val());
  252. $("#testmask").remove();
  253. });
  254. module("Set value with fn.val");
  255. test("inputmask(\"decimal\") ~ value=\"123.45\"", function () {
  256. $('body').append('<input type="text" id="testmask" />');
  257. $("#testmask").inputmask("decimal");
  258. $("#testmask").val("123.45");
  259. equal($("#testmask").val(), "123.45", "Result " + $("#testmask").val());
  260. $("#testmask").remove();
  261. });
  262. test("inputmask(\"+7 (999) 999-99-99\") ~ value=\"+7 (+79114041112___) ___-__-__\"", function () {
  263. $('body').append('<input type="text" id="testmask" />');
  264. $("#testmask").inputmask("+7 (999) 999-99-99");
  265. $("#testmask").val("+7 (+79114041112___) ___-__-__");
  266. equal($("#testmask").val(), "+7 (911) 404-11-12", "Result " + $("#testmask").val());
  267. $("#testmask").remove();
  268. });
  269. module("Optional & multi masks");
  270. test("inputmask(\"(99) 9999[9]-99999\") - input 121234-12345", function () {
  271. $('body').append('<input type="text" id="testmask" />');
  272. $("#testmask").inputmask("(99) 9999[9]-99999");
  273. $("#testmask")[0].focus();
  274. var event;
  275. $("#testmask").SendKey("1");
  276. $("#testmask").SendKey("2");
  277. $("#testmask").SendKey("1");
  278. $("#testmask").SendKey("2");
  279. $("#testmask").SendKey("3");
  280. $("#testmask").SendKey("4");
  281. $("#testmask").SendKey("-");
  282. $("#testmask").SendKey("1");
  283. $("#testmask").SendKey("2");
  284. $("#testmask").SendKey("3");
  285. $("#testmask").SendKey("4");
  286. $("#testmask").SendKey("5");
  287. equal($("#testmask").val(), "(12) 1234-12345", "Result " + $("#testmask").val());
  288. $("#testmask").remove();
  289. });
  290. test("inputmask(\"(99) 9999[9]-99999\") - input 121234512345", function () {
  291. $('body').append('<input type="text" id="testmask" />');
  292. $("#testmask").inputmask("(99) 9999[9]-99999");
  293. $("#testmask")[0].focus();
  294. var event;
  295. $("#testmask").SendKey("1");
  296. $("#testmask").SendKey("2");
  297. $("#testmask").SendKey("1");
  298. $("#testmask").SendKey("2");
  299. $("#testmask").SendKey("3");
  300. $("#testmask").SendKey("4");
  301. $("#testmask").SendKey("5");
  302. $("#testmask").SendKey("1");
  303. $("#testmask").SendKey("2");
  304. $("#testmask").SendKey("3");
  305. $("#testmask").SendKey("4");
  306. $("#testmask").SendKey("5");
  307. equal($("#testmask").val(), "(12) 12345-12345", "Result " + $("#testmask").val());
  308. $("#testmask").remove();
  309. });
  310. test("inputmask({ mask: [\"999.999.999-99\", \"99.999.999/9999-99\"]}) - input 12312312312", function () {
  311. $('body').append('<input type="text" id="testmask" />');
  312. $("#testmask").inputmask({ mask: ["999.999.999-99", "99.999.999/9999-99"] });
  313. $("#testmask")[0].focus();
  314. var event;
  315. $("#testmask").SendKey("1");
  316. $("#testmask").SendKey("2");
  317. $("#testmask").SendKey("3");
  318. $("#testmask").SendKey("1");
  319. $("#testmask").SendKey("2");
  320. $("#testmask").SendKey("3");
  321. $("#testmask").SendKey("1");
  322. $("#testmask").SendKey("2");
  323. $("#testmask").SendKey("3");
  324. $("#testmask").SendKey("1");
  325. $("#testmask").SendKey("2");
  326. equal($("#testmask").val(), "123.123.123-12", "Result " + $("#testmask").val());
  327. $("#testmask").remove();
  328. });
  329. test("inputmask({ mask: [\"999.999.999-99\", \"99.999.999/9999-99\"]}) - input 12.123123123412", function () {
  330. $('body').append('<input type="text" id="testmask" />');
  331. $("#testmask").inputmask({ mask: ["999.999.999-99", "99.999.999/9999-99"] });
  332. $("#testmask")[0].focus();
  333. var event;
  334. $("#testmask").SendKey("1");
  335. $("#testmask").SendKey("2");
  336. $("#testmask").SendKey(".");
  337. $("#testmask").SendKey("1");
  338. $("#testmask").SendKey("2");
  339. $("#testmask").SendKey("3");
  340. $("#testmask").SendKey("1");
  341. $("#testmask").SendKey("2");
  342. $("#testmask").SendKey("3");
  343. $("#testmask").SendKey("1");
  344. $("#testmask").SendKey("2");
  345. $("#testmask").SendKey("3");
  346. $("#testmask").SendKey("4");
  347. $("#testmask").SendKey("1");
  348. $("#testmask").SendKey("2");
  349. equal($("#testmask").val(), "12.123.123/1234-12", "Result " + $("#testmask").val());
  350. $("#testmask").remove();
  351. });