simulator.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. (function(factory) {
  2. if (typeof define === "function" && define.amd) {
  3. define(["inputmask.dependencyLib", "inputmask"], factory);
  4. } else {
  5. factory(window.dependencyLib || jQuery, window.Inputmask);
  6. }
  7. }
  8. (function($, Inputmask) {
  9. $.caret = function(input, begin, end) {
  10. input = input.nodeName ? input : input[0];
  11. var range;
  12. if (typeof begin === "number") {
  13. end = (typeof end == "number") ? end : begin;
  14. // if (!$(input).is(":visible")) {
  15. // return;
  16. // }
  17. if (input.setSelectionRange) {
  18. input.selectionStart = begin;
  19. input.selectionEnd = end;
  20. } else if (window.getSelection) {
  21. range = document.createRange();
  22. if (input.firstChild === undefined) {
  23. var textNode = document.createTextNode("");
  24. input.appendChild(textNode);
  25. }
  26. range.setStart(input.firstChild, begin < input.value.length ? begin : input.value.length);
  27. range.setEnd(input.firstChild, end < input.value.length ? end : input.value.length);
  28. range.collapse(true);
  29. var sel = window.getSelection();
  30. sel.removeAllRanges();
  31. sel.addRange(range);
  32. //input.focus();
  33. } else if (input.createTextRange) {
  34. range = input.createTextRange();
  35. range.collapse(true);
  36. range.moveEnd("character", end);
  37. range.moveStart("character", begin);
  38. range.select();
  39. }
  40. } else {
  41. if (input.setSelectionRange) {
  42. begin = input.selectionStart;
  43. end = input.selectionEnd;
  44. } else if (window.getSelection) {
  45. range = window.getSelection().getRangeAt(0);
  46. if (range.commonAncestorContainer.parentNode === input || range.commonAncestorContainer === input) {
  47. begin = range.startOffset;
  48. end = range.endOffset;
  49. }
  50. } else if (document.selection && document.selection.createRange) {
  51. range = document.selection.createRange();
  52. begin = 0 - range.duplicate().moveStart("character", -100000);
  53. end = begin + range.text.length;
  54. }
  55. /*eslint-disable consistent-return */
  56. return {
  57. "begin": begin,
  58. "end": end
  59. };
  60. /*eslint-enable consistent-return */
  61. }
  62. };
  63. $.fn = $.fn || $.prototype;
  64. $.fn.SendKey = function(keyCode, modifier) {
  65. function trigger(elem, evnt) {
  66. elem.focus();
  67. if ($ === jQuery) {
  68. $(elem).trigger(evnt);
  69. } else {
  70. if (document.createEvent) {
  71. elem.dispatchEvent(evnt);
  72. } else {
  73. elem.fireEvent("on" + evnt.eventType, evnt);
  74. }
  75. }
  76. }
  77. var sendDummyKeydown = false;
  78. if (Object.prototype.toString.call(keyCode) == '[object String]') {
  79. keyCode = keyCode.charCodeAt(0);
  80. sendDummyKeydown = true;
  81. }
  82. switch (keyCode) {
  83. case Inputmask.keyCode.LEFT:
  84. {
  85. if (modifier == undefined) {
  86. var pos = $.caret(this);
  87. $.caret(this, pos.begin - 1);
  88. break;
  89. }
  90. }
  91. case Inputmask.keyCode.RIGHT:
  92. {
  93. if (modifier == undefined) {
  94. var pos = $.caret(this);
  95. $.caret(this, pos.begin + 1);
  96. break;
  97. }
  98. }
  99. default:
  100. {
  101. var keydown = new $.Event("keydown"),
  102. keypress = new $.Event("keypress"),
  103. keyup = new $.Event("keyup");
  104. if (!sendDummyKeydown) {
  105. keydown.keyCode = keyCode;
  106. if (modifier == Inputmask.keyCode.CONTROL)
  107. keydown.ctrlKey = true;
  108. }
  109. trigger(this.nodeName ? this : this[0], keydown);
  110. if (!keydown.defaultPrevented) {
  111. keypress.keyCode = keyCode;
  112. if (modifier == Inputmask.keyCode.CONTROL)
  113. keypress.ctrlKey = true;
  114. trigger(this.nodeName ? this : this[0], keypress);
  115. //if (!keypress.isDefaultPrevented()) {
  116. keyup.keyCode = keyCode;
  117. if (modifier == Inputmask.keyCode.CONTROL)
  118. keyup.ctrlKey = true;
  119. trigger(this.nodeName ? this : this[0], keyup);
  120. //}
  121. }
  122. }
  123. }
  124. }
  125. if (!('append' in $.fn)) {
  126. $.fn.append = function(child) {
  127. var input = this.nodeName ? this : this[0];
  128. input.insertAdjacentHTML('beforeend', child);
  129. };
  130. }
  131. if (!('remove' in $.fn)) {
  132. $.fn.remove = function() {
  133. var input = this.nodeName ? this : this[0];
  134. if (input !== undefined && input !== null) {
  135. input.parentElement.removeChild(input);
  136. input = undefined;
  137. }
  138. };
  139. }
  140. if (!('val' in $.fn)) {
  141. $.fn.val = function(value) {
  142. var input = this.nodeName ? this : this[0];
  143. if (value !== undefined) {
  144. if (input.inputmask) {
  145. input.inputmask._valueSet(value);
  146. $(input).trigger("setvalue");
  147. } else input.value = value;
  148. }
  149. return input.value;
  150. };
  151. }
  152. $.fn.Type = function(inputStr) {
  153. var input = this.nodeName ? this : this[0],
  154. $input = $(input);
  155. $.each(inputStr.split(''), function(ndx, lmnt) {
  156. $input.SendKey(lmnt);
  157. });
  158. }
  159. $.fn.paste = function(inputStr) {
  160. var input = this.nodeName ? this : this[0],
  161. $input = $(input),
  162. isRTL = input.inputmask.isRTL;
  163. window.clipboardData ? window.clipboardData.setData("Text", inputStr) : $input[0].inputmask._valueSet(isRTL ? inputStr.split('').reverse().join('') : inputStr);
  164. $input.trigger('paste');
  165. }
  166. }));