ende 0.2.21 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,1613 @@
1
+ /**
2
+ * @license Input Mask plugin for jquery
3
+ * http://github.com/RobinHerbots/jquery.inputmask
4
+ * Copyright (c) 2010 - 2014 Robin Herbots
5
+ * Licensed under the MIT license (http://www.opensource.org/licenses/mit-license.php)
6
+ * Version: 0.0.0
7
+ */
8
+
9
+ (function ($) {
10
+ if ($.fn.inputmask === undefined) {
11
+ //helper functions
12
+ function isInputEventSupported(eventName) {
13
+ var el = document.createElement('input'),
14
+ eventName = 'on' + eventName,
15
+ isSupported = (eventName in el);
16
+ if (!isSupported) {
17
+ el.setAttribute(eventName, 'return;');
18
+ isSupported = typeof el[eventName] == 'function';
19
+ }
20
+ el = null;
21
+ return isSupported;
22
+ }
23
+
24
+ function resolveAlias(aliasStr, options, opts) {
25
+ var aliasDefinition = opts.aliases[aliasStr];
26
+ if (aliasDefinition) {
27
+ if (aliasDefinition.alias) resolveAlias(aliasDefinition.alias, undefined, opts); //alias is another alias
28
+ $.extend(true, opts, aliasDefinition); //merge alias definition in the options
29
+ $.extend(true, opts, options); //reapply extra given options
30
+ return true;
31
+ }
32
+ return false;
33
+ }
34
+
35
+
36
+ function generateMaskSets(opts) {
37
+ var ms = [];
38
+ var genmasks = []; //used to keep track of the masks that where processed, to avoid duplicates
39
+ function getMaskTemplate(mask) {
40
+ if (opts.numericInput) {
41
+ mask = mask.split('').reverse().join('');
42
+ }
43
+ var escaped = false, outCount = 0, greedy = opts.greedy, repeat = opts.repeat;
44
+ if (repeat == "*") greedy = false;
45
+ //if (greedy == true && opts.placeholder == "") opts.placeholder = " ";
46
+ if (mask.length == 1 && greedy == false && repeat != 0) { opts.placeholder = ""; } //hide placeholder with single non-greedy mask
47
+ var singleMask = $.map(mask.split(""), function (element, index) {
48
+ var outElem = [];
49
+ if (element == opts.escapeChar) {
50
+ escaped = true;
51
+ }
52
+ else if ((element != opts.optionalmarker.start && element != opts.optionalmarker.end) || escaped) {
53
+ var maskdef = opts.definitions[element];
54
+ if (maskdef && !escaped) {
55
+ for (var i = 0; i < maskdef.cardinality; i++) {
56
+ outElem.push(opts.placeholder.charAt((outCount + i) % opts.placeholder.length));
57
+ }
58
+ } else {
59
+ outElem.push(element);
60
+ escaped = false;
61
+ }
62
+ outCount += outElem.length;
63
+ return outElem;
64
+ }
65
+ });
66
+
67
+ //allocate repetitions
68
+ var repeatedMask = singleMask.slice();
69
+ for (var i = 1; i < repeat && greedy; i++) {
70
+ repeatedMask = repeatedMask.concat(singleMask.slice());
71
+ }
72
+
73
+ return { "mask": repeatedMask, "repeat": repeat, "greedy": greedy };
74
+ }
75
+ //test definition => {fn: RegExp/function, cardinality: int, optionality: bool, newBlockMarker: bool, offset: int, casing: null/upper/lower, def: definitionSymbol}
76
+ function getTestingChain(mask) {
77
+ if (opts.numericInput) {
78
+ mask = mask.split('').reverse().join('');
79
+ }
80
+ var isOptional = false, escaped = false;
81
+ var newBlockMarker = false; //indicates wheter the begin/ending of a block should be indicated
82
+
83
+ return $.map(mask.split(""), function (element, index) {
84
+ var outElem = [];
85
+
86
+ if (element == opts.escapeChar) {
87
+ escaped = true;
88
+ } else if (element == opts.optionalmarker.start && !escaped) {
89
+ isOptional = true;
90
+ newBlockMarker = true;
91
+ }
92
+ else if (element == opts.optionalmarker.end && !escaped) {
93
+ isOptional = false;
94
+ newBlockMarker = true;
95
+ }
96
+ else {
97
+ var maskdef = opts.definitions[element];
98
+ if (maskdef && !escaped) {
99
+ var prevalidators = maskdef["prevalidator"], prevalidatorsL = prevalidators ? prevalidators.length : 0;
100
+ for (var i = 1; i < maskdef.cardinality; i++) {
101
+ var prevalidator = prevalidatorsL >= i ? prevalidators[i - 1] : [], validator = prevalidator["validator"], cardinality = prevalidator["cardinality"];
102
+ outElem.push({ fn: validator ? typeof validator == 'string' ? new RegExp(validator) : new function () { this.test = validator; } : new RegExp("."), cardinality: cardinality ? cardinality : 1, optionality: isOptional, newBlockMarker: isOptional == true ? newBlockMarker : false, offset: 0, casing: maskdef["casing"], def: maskdef["definitionSymbol"] || element });
103
+ if (isOptional == true) //reset newBlockMarker
104
+ newBlockMarker = false;
105
+ }
106
+ outElem.push({ fn: maskdef.validator ? typeof maskdef.validator == 'string' ? new RegExp(maskdef.validator) : new function () { this.test = maskdef.validator; } : new RegExp("."), cardinality: maskdef.cardinality, optionality: isOptional, newBlockMarker: newBlockMarker, offset: 0, casing: maskdef["casing"], def: maskdef["definitionSymbol"] || element });
107
+ } else {
108
+ outElem.push({ fn: null, cardinality: 0, optionality: isOptional, newBlockMarker: newBlockMarker, offset: 0, casing: null, def: element });
109
+ escaped = false;
110
+ }
111
+ //reset newBlockMarker
112
+ newBlockMarker = false;
113
+ return outElem;
114
+ }
115
+ });
116
+ }
117
+ function markOptional(maskPart) { //needed for the clearOptionalTail functionality
118
+ return opts.optionalmarker.start + maskPart + opts.optionalmarker.end;
119
+ }
120
+ function splitFirstOptionalEndPart(maskPart) {
121
+ var optionalStartMarkers = 0, optionalEndMarkers = 0, mpl = maskPart.length;
122
+ for (var i = 0; i < mpl; i++) {
123
+ if (maskPart.charAt(i) == opts.optionalmarker.start) {
124
+ optionalStartMarkers++;
125
+ }
126
+ if (maskPart.charAt(i) == opts.optionalmarker.end) {
127
+ optionalEndMarkers++;
128
+ }
129
+ if (optionalStartMarkers > 0 && optionalStartMarkers == optionalEndMarkers)
130
+ break;
131
+ }
132
+ var maskParts = [maskPart.substring(0, i)];
133
+ if (i < mpl) {
134
+ maskParts.push(maskPart.substring(i + 1, mpl));
135
+ }
136
+ return maskParts;
137
+ }
138
+ function splitFirstOptionalStartPart(maskPart) {
139
+ var mpl = maskPart.length;
140
+ for (var i = 0; i < mpl; i++) {
141
+ if (maskPart.charAt(i) == opts.optionalmarker.start) {
142
+ break;
143
+ }
144
+ }
145
+ var maskParts = [maskPart.substring(0, i)];
146
+ if (i < mpl) {
147
+ maskParts.push(maskPart.substring(i + 1, mpl));
148
+ }
149
+ return maskParts;
150
+ }
151
+ function generateMask(maskPrefix, maskPart, metadata) {
152
+ var maskParts = splitFirstOptionalEndPart(maskPart);
153
+ var newMask, maskTemplate;
154
+
155
+ var masks = splitFirstOptionalStartPart(maskParts[0]);
156
+ if (masks.length > 1) {
157
+ newMask = maskPrefix + masks[0] + markOptional(masks[1]) + (maskParts.length > 1 ? maskParts[1] : "");
158
+ if ($.inArray(newMask, genmasks) == -1 && newMask != "") {
159
+ genmasks.push(newMask);
160
+ maskTemplate = getMaskTemplate(newMask);
161
+ ms.push({
162
+ "mask": newMask,
163
+ "_buffer": maskTemplate["mask"],
164
+ "buffer": maskTemplate["mask"].slice(),
165
+ "tests": getTestingChain(newMask),
166
+ "lastValidPosition": -1,
167
+ "greedy": maskTemplate["greedy"],
168
+ "repeat": maskTemplate["repeat"],
169
+ "metadata": metadata
170
+ });
171
+ }
172
+ newMask = maskPrefix + masks[0] + (maskParts.length > 1 ? maskParts[1] : "");
173
+ if ($.inArray(newMask, genmasks) == -1 && newMask != "") {
174
+ genmasks.push(newMask);
175
+ maskTemplate = getMaskTemplate(newMask);
176
+ ms.push({
177
+ "mask": newMask,
178
+ "_buffer": maskTemplate["mask"],
179
+ "buffer": maskTemplate["mask"].slice(),
180
+ "tests": getTestingChain(newMask),
181
+ "lastValidPosition": -1,
182
+ "greedy": maskTemplate["greedy"],
183
+ "repeat": maskTemplate["repeat"],
184
+ "metadata": metadata
185
+ });
186
+ }
187
+ if (splitFirstOptionalStartPart(masks[1]).length > 1) { //optional contains another optional
188
+ generateMask(maskPrefix + masks[0], masks[1] + maskParts[1], metadata);
189
+ }
190
+ if (maskParts.length > 1 && splitFirstOptionalStartPart(maskParts[1]).length > 1) {
191
+ generateMask(maskPrefix + masks[0] + markOptional(masks[1]), maskParts[1], metadata);
192
+ generateMask(maskPrefix + masks[0], maskParts[1], metadata);
193
+ }
194
+ }
195
+ else {
196
+ newMask = maskPrefix + maskParts;
197
+ if ($.inArray(newMask, genmasks) == -1 && newMask != "") {
198
+ genmasks.push(newMask);
199
+ maskTemplate = getMaskTemplate(newMask);
200
+ ms.push({
201
+ "mask": newMask,
202
+ "_buffer": maskTemplate["mask"],
203
+ "buffer": maskTemplate["mask"].slice(),
204
+ "tests": getTestingChain(newMask),
205
+ "lastValidPosition": -1,
206
+ "greedy": maskTemplate["greedy"],
207
+ "repeat": maskTemplate["repeat"],
208
+ "metadata": metadata
209
+ });
210
+ }
211
+ }
212
+
213
+ }
214
+
215
+ if ($.isFunction(opts.mask)) { //allow mask to be a preprocessing fn - should return a valid mask
216
+ opts.mask = opts.mask.call(this, opts);
217
+ }
218
+ if ($.isArray(opts.mask)) {
219
+ $.each(opts.mask, function (ndx, msk) {
220
+ if (msk["mask"] != undefined) {
221
+ generateMask("", msk["mask"].toString(), msk);
222
+ } else
223
+ generateMask("", msk.toString());
224
+ });
225
+ } else generateMask("", opts.mask.toString());
226
+
227
+ return opts.greedy ? ms : ms.sort(function (a, b) { return a["mask"].length - b["mask"].length; });
228
+ }
229
+
230
+
231
+ var msie10 = navigator.userAgent.match(new RegExp("msie 10", "i")) !== null,
232
+ iphone = navigator.userAgent.match(new RegExp("iphone", "i")) !== null,
233
+ android = navigator.userAgent.match(new RegExp("android.*safari.*", "i")) !== null,
234
+ androidchrome = navigator.userAgent.match(new RegExp("android.*chrome.*", "i")) !== null,
235
+ pasteEvent = isInputEventSupported('paste') && !msie10 ? 'paste' : isInputEventSupported('input') ? 'input' : "propertychange";
236
+
237
+
238
+ //masking scope
239
+
240
+ function maskScope(masksets, activeMasksetIndex, opts) {
241
+ var isRTL = false,
242
+ valueOnFocus = getActiveBuffer().join(''),
243
+ $el, chromeValueOnInput;
244
+
245
+ //maskset helperfunctions
246
+
247
+ function getActiveMaskSet() {
248
+ return masksets[activeMasksetIndex];
249
+ }
250
+
251
+ function getActiveTests() {
252
+ return getActiveMaskSet()['tests'];
253
+ }
254
+
255
+ function getActiveBufferTemplate() {
256
+ return getActiveMaskSet()['_buffer'];
257
+ }
258
+
259
+ function getActiveBuffer() {
260
+ return getActiveMaskSet()['buffer'];
261
+ }
262
+
263
+ function isValid(pos, c, strict) { //strict true ~ no correction or autofill
264
+ strict = strict === true; //always set a value to strict to prevent possible strange behavior in the extensions
265
+
266
+ function _isValid(position, activeMaskset, c, strict) {
267
+ var testPos = determineTestPosition(position), loopend = c ? 1 : 0, chrs = '', buffer = activeMaskset["buffer"];
268
+ for (var i = activeMaskset['tests'][testPos].cardinality; i > loopend; i--) {
269
+ chrs += getBufferElement(buffer, testPos - (i - 1));
270
+ }
271
+
272
+ if (c) {
273
+ chrs += c;
274
+ }
275
+
276
+ //return is false or a json object => { pos: ??, c: ??} or true
277
+ return activeMaskset['tests'][testPos].fn != null ?
278
+ activeMaskset['tests'][testPos].fn.test(chrs, buffer, position, strict, opts)
279
+ : (c == getBufferElement(activeMaskset['_buffer'], position, true) || c == opts.skipOptionalPartCharacter) ?
280
+ { "refresh": true, c: getBufferElement(activeMaskset['_buffer'], position, true), pos: position }
281
+ : false;
282
+ }
283
+
284
+ function PostProcessResults(maskForwards, results) {
285
+ var hasValidActual = false;
286
+ $.each(results, function (ndx, rslt) {
287
+ hasValidActual = $.inArray(rslt["activeMasksetIndex"], maskForwards) == -1 && rslt["result"] !== false;
288
+ if (hasValidActual) return false;
289
+ });
290
+ if (hasValidActual) { //strip maskforwards
291
+ results = $.map(results, function (rslt, ndx) {
292
+ if ($.inArray(rslt["activeMasksetIndex"], maskForwards) == -1) {
293
+ return rslt;
294
+ } else {
295
+ masksets[rslt["activeMasksetIndex"]]["lastValidPosition"] = actualLVP;
296
+ }
297
+ });
298
+ } else { //keep maskforwards with the least forward
299
+ var lowestPos = -1, lowestIndex = -1, rsltValid;
300
+ $.each(results, function (ndx, rslt) {
301
+ if ($.inArray(rslt["activeMasksetIndex"], maskForwards) != -1 && rslt["result"] !== false & (lowestPos == -1 || lowestPos > rslt["result"]["pos"])) {
302
+ lowestPos = rslt["result"]["pos"];
303
+ lowestIndex = rslt["activeMasksetIndex"];
304
+ }
305
+ });
306
+ results = $.map(results, function (rslt, ndx) {
307
+ if ($.inArray(rslt["activeMasksetIndex"], maskForwards) != -1) {
308
+ if (rslt["result"]["pos"] == lowestPos) {
309
+ return rslt;
310
+ } else if (rslt["result"] !== false) {
311
+ for (var i = pos; i < lowestPos; i++) {
312
+ rsltValid = _isValid(i, masksets[rslt["activeMasksetIndex"]], masksets[lowestIndex]["buffer"][i], true);
313
+ if (rsltValid === false) {
314
+ masksets[rslt["activeMasksetIndex"]]["lastValidPosition"] = lowestPos - 1;
315
+ break;
316
+ } else {
317
+ setBufferElement(masksets[rslt["activeMasksetIndex"]]["buffer"], i, masksets[lowestIndex]["buffer"][i], true);
318
+ masksets[rslt["activeMasksetIndex"]]["lastValidPosition"] = i;
319
+ }
320
+ }
321
+ //also check check for the lowestpos with the new input
322
+ rsltValid = _isValid(lowestPos, masksets[rslt["activeMasksetIndex"]], c, true);
323
+ if (rsltValid !== false) {
324
+ setBufferElement(masksets[rslt["activeMasksetIndex"]]["buffer"], lowestPos, c, true);
325
+ masksets[rslt["activeMasksetIndex"]]["lastValidPosition"] = lowestPos;
326
+ }
327
+ //console.log("ndx " + rslt["activeMasksetIndex"] + " validate " + masksets[rslt["activeMasksetIndex"]]["buffer"].join('') + " lv " + masksets[rslt["activeMasksetIndex"]]['lastValidPosition']);
328
+ return rslt;
329
+ }
330
+ }
331
+ });
332
+ }
333
+ return results;
334
+ }
335
+
336
+ if (strict) {
337
+ var result = _isValid(pos, getActiveMaskSet(), c, strict); //only check validity in current mask when validating strict
338
+ if (result === true) {
339
+ result = { "pos": pos }; //always take a possible corrected maskposition into account
340
+ }
341
+ return result;
342
+ }
343
+
344
+ var results = [], result = false, currentActiveMasksetIndex = activeMasksetIndex,
345
+ actualBuffer = getActiveBuffer().slice(), actualLVP = getActiveMaskSet()["lastValidPosition"],
346
+ actualPrevious = seekPrevious(pos),
347
+ maskForwards = [];
348
+ $.each(masksets, function (index, value) {
349
+ if (typeof (value) == "object") {
350
+ activeMasksetIndex = index;
351
+
352
+ var maskPos = pos;
353
+ var lvp = getActiveMaskSet()['lastValidPosition'],
354
+ rsltValid;
355
+ if (lvp == actualLVP) {
356
+ if ((maskPos - actualLVP) > 1) {
357
+ for (var i = lvp == -1 ? 0 : lvp; i < maskPos; i++) {
358
+ rsltValid = _isValid(i, getActiveMaskSet(), actualBuffer[i], true);
359
+ if (rsltValid === false) {
360
+ break;
361
+ } else {
362
+ setBufferElement(getActiveBuffer(), i, actualBuffer[i], true);
363
+ if (rsltValid === true) {
364
+ rsltValid = { "pos": i }; //always take a possible corrected maskposition into account
365
+ }
366
+ var newValidPosition = rsltValid.pos || i;
367
+ if (getActiveMaskSet()['lastValidPosition'] < newValidPosition)
368
+ getActiveMaskSet()['lastValidPosition'] = newValidPosition; //set new position from isValid
369
+ }
370
+ }
371
+ }
372
+ //does the input match on a further position?
373
+ if (!isMask(maskPos) && !_isValid(maskPos, getActiveMaskSet(), c, strict)) {
374
+ var maxForward = seekNext(maskPos) - maskPos;
375
+ for (var fw = 0; fw < maxForward; fw++) {
376
+ if (_isValid(++maskPos, getActiveMaskSet(), c, strict) !== false)
377
+ break;
378
+ }
379
+ maskForwards.push(activeMasksetIndex);
380
+ //console.log('maskforward ' + activeMasksetIndex + " pos " + pos + " maskPos " + maskPos);
381
+ }
382
+ }
383
+
384
+ if (getActiveMaskSet()['lastValidPosition'] >= actualLVP || activeMasksetIndex == currentActiveMasksetIndex) {
385
+ if (maskPos >= 0 && maskPos < getMaskLength()) {
386
+ result = _isValid(maskPos, getActiveMaskSet(), c, strict);
387
+ if (result !== false) {
388
+ if (result === true) {
389
+ result = { "pos": maskPos }; //always take a possible corrected maskposition into account
390
+ }
391
+ var newValidPosition = result.pos || maskPos;
392
+ if (getActiveMaskSet()['lastValidPosition'] < newValidPosition)
393
+ getActiveMaskSet()['lastValidPosition'] = newValidPosition; //set new position from isValid
394
+ }
395
+ //console.log("pos " + pos + " ndx " + activeMasksetIndex + " validate " + getActiveBuffer().join('') + " lv " + getActiveMaskSet()['lastValidPosition']);
396
+ results.push({ "activeMasksetIndex": index, "result": result });
397
+ }
398
+ }
399
+ }
400
+ });
401
+ activeMasksetIndex = currentActiveMasksetIndex; //reset activeMasksetIndex
402
+
403
+ return PostProcessResults(maskForwards, results); //return results of the multiple mask validations
404
+ }
405
+
406
+ function determineActiveMasksetIndex() {
407
+ var currentMasksetIndex = activeMasksetIndex,
408
+ highestValid = { "activeMasksetIndex": 0, "lastValidPosition": -1, "next": -1 };
409
+ $.each(masksets, function (index, value) {
410
+ if (typeof (value) == "object") {
411
+ activeMasksetIndex = index;
412
+ if (getActiveMaskSet()['lastValidPosition'] > highestValid['lastValidPosition']) {
413
+ highestValid["activeMasksetIndex"] = index;
414
+ highestValid["lastValidPosition"] = getActiveMaskSet()['lastValidPosition'];
415
+ highestValid["next"] = seekNext(getActiveMaskSet()['lastValidPosition']);
416
+ } else if (getActiveMaskSet()['lastValidPosition'] == highestValid['lastValidPosition'] &&
417
+ (highestValid['next'] == -1 || highestValid['next'] > seekNext(getActiveMaskSet()['lastValidPosition']))) {
418
+ highestValid["activeMasksetIndex"] = index;
419
+ highestValid["lastValidPosition"] = getActiveMaskSet()['lastValidPosition'];
420
+ highestValid["next"] = seekNext(getActiveMaskSet()['lastValidPosition']);
421
+ }
422
+ }
423
+ });
424
+
425
+ activeMasksetIndex = highestValid["lastValidPosition"] != -1 && masksets[currentMasksetIndex]["lastValidPosition"] == highestValid["lastValidPosition"] ? currentMasksetIndex : highestValid["activeMasksetIndex"];
426
+ if (currentMasksetIndex != activeMasksetIndex) {
427
+ clearBuffer(getActiveBuffer(), seekNext(highestValid["lastValidPosition"]), getMaskLength());
428
+ getActiveMaskSet()["writeOutBuffer"] = true;
429
+ }
430
+ $el.data('_inputmask')['activeMasksetIndex'] = activeMasksetIndex; //store the activeMasksetIndex
431
+ }
432
+
433
+ function isMask(pos) {
434
+ var testPos = determineTestPosition(pos);
435
+ var test = getActiveTests()[testPos];
436
+
437
+ return test != undefined ? test.fn : false;
438
+ }
439
+
440
+ function determineTestPosition(pos) {
441
+ return pos % getActiveTests().length;
442
+ }
443
+
444
+ function getMaskLength() {
445
+ return opts.getMaskLength(getActiveBufferTemplate(), getActiveMaskSet()['greedy'], getActiveMaskSet()['repeat'], getActiveBuffer(), opts);
446
+ }
447
+
448
+ //pos: from position
449
+
450
+ function seekNext(pos) {
451
+ var maskL = getMaskLength();
452
+ if (pos >= maskL) return maskL;
453
+ var position = pos;
454
+ while (++position < maskL && !isMask(position)) {
455
+ }
456
+ return position;
457
+ }
458
+
459
+ //pos: from position
460
+
461
+ function seekPrevious(pos) {
462
+ var position = pos;
463
+ if (position <= 0) return 0;
464
+
465
+ while (--position > 0 && !isMask(position)) {
466
+ }
467
+ ;
468
+ return position;
469
+ }
470
+
471
+ function setBufferElement(buffer, position, element, autoPrepare) {
472
+ if (autoPrepare) position = prepareBuffer(buffer, position);
473
+
474
+ var test = getActiveTests()[determineTestPosition(position)];
475
+ var elem = element;
476
+ if (elem != undefined && test != undefined) {
477
+ switch (test.casing) {
478
+ case "upper":
479
+ elem = element.toUpperCase();
480
+ break;
481
+ case "lower":
482
+ elem = element.toLowerCase();
483
+ break;
484
+ }
485
+ }
486
+
487
+ buffer[position] = elem;
488
+ }
489
+
490
+ function getBufferElement(buffer, position, autoPrepare) {
491
+ if (autoPrepare) position = prepareBuffer(buffer, position);
492
+ return buffer[position];
493
+ }
494
+
495
+ //needed to handle the non-greedy mask repetitions
496
+
497
+ function prepareBuffer(buffer, position) {
498
+ var j;
499
+ while (buffer[position] == undefined && buffer.length < getMaskLength()) {
500
+ j = 0;
501
+ while (getActiveBufferTemplate()[j] !== undefined) { //add a new buffer
502
+ buffer.push(getActiveBufferTemplate()[j++]);
503
+ }
504
+ }
505
+
506
+ return position;
507
+ }
508
+
509
+ function writeBuffer(input, buffer, caretPos) {
510
+ input._valueSet(buffer.join(''));
511
+ if (caretPos != undefined) {
512
+ caret(input, caretPos);
513
+ }
514
+ }
515
+
516
+ function clearBuffer(buffer, start, end, stripNomasks) {
517
+ for (var i = start, maskL = getMaskLength() ; i < end && i < maskL; i++) {
518
+ if (stripNomasks === true) {
519
+ if (!isMask(i))
520
+ setBufferElement(buffer, i, "");
521
+ } else
522
+ setBufferElement(buffer, i, getBufferElement(getActiveBufferTemplate().slice(), i, true));
523
+ }
524
+ }
525
+
526
+ function setReTargetPlaceHolder(buffer, pos) {
527
+ var testPos = determineTestPosition(pos);
528
+ setBufferElement(buffer, pos, getBufferElement(getActiveBufferTemplate(), testPos));
529
+ }
530
+
531
+ function getPlaceHolder(pos) {
532
+ return opts.placeholder.charAt(pos % opts.placeholder.length);
533
+ }
534
+
535
+ function checkVal(input, writeOut, strict, nptvl, intelliCheck) {
536
+ var inputValue = nptvl != undefined ? nptvl.slice() : truncateInput(input._valueGet()).split('');
537
+
538
+ $.each(masksets, function (ndx, ms) {
539
+ if (typeof (ms) == "object") {
540
+ ms["buffer"] = ms["_buffer"].slice();
541
+ ms["lastValidPosition"] = -1;
542
+ ms["p"] = -1;
543
+ }
544
+ });
545
+ if (strict !== true) activeMasksetIndex = 0;
546
+ if (writeOut) input._valueSet(""); //initial clear
547
+ var ml = getMaskLength();
548
+ $.each(inputValue, function (ndx, charCode) {
549
+ if (intelliCheck === true) {
550
+ var p = getActiveMaskSet()["p"], lvp = p == -1 ? p : seekPrevious(p),
551
+ pos = lvp == -1 ? ndx : seekNext(lvp);
552
+ if ($.inArray(charCode, getActiveBufferTemplate().slice(lvp + 1, pos)) == -1) {
553
+ $(input).trigger("_keypress", [true, charCode.charCodeAt(0), writeOut, strict, ndx]);
554
+ }
555
+ } else {
556
+ $(input).trigger("_keypress", [true, charCode.charCodeAt(0), writeOut, strict, ndx]);
557
+ }
558
+ });
559
+
560
+ if (strict === true && getActiveMaskSet()["p"] != -1) {
561
+ getActiveMaskSet()["lastValidPosition"] = seekPrevious(getActiveMaskSet()["p"]);
562
+ }
563
+ }
564
+
565
+ function escapeRegex(str) {
566
+ return $.inputmask.escapeRegex.call(this, str);
567
+ }
568
+
569
+ function truncateInput(inputValue) {
570
+ return inputValue.replace(new RegExp("(" + escapeRegex(getActiveBufferTemplate().join('')) + ")*$"), "");
571
+ }
572
+
573
+ function clearOptionalTail(input) {
574
+ var buffer = getActiveBuffer(), tmpBuffer = buffer.slice(), testPos, pos;
575
+ for (var pos = tmpBuffer.length - 1; pos >= 0; pos--) {
576
+ var testPos = determineTestPosition(pos);
577
+ if (getActiveTests()[testPos].optionality) {
578
+ if (!isMask(pos) || !isValid(pos, buffer[pos], true))
579
+ tmpBuffer.pop();
580
+ else break;
581
+ } else break;
582
+ }
583
+ writeBuffer(input, tmpBuffer);
584
+ }
585
+
586
+ function unmaskedvalue($input, skipDatepickerCheck) {
587
+ if (getActiveTests() && (skipDatepickerCheck === true || !$input.hasClass('hasDatepicker'))) {
588
+ //checkVal(input, false, true);
589
+ var umValue = $.map(getActiveBuffer(), function (element, index) {
590
+ return isMask(index) && isValid(index, element, true) ? element : null;
591
+ });
592
+ var unmaskedValue = (isRTL ? umValue.reverse() : umValue).join('');
593
+ return opts.onUnMask != undefined ? opts.onUnMask.call(this, getActiveBuffer().join(''), unmaskedValue) : unmaskedValue;
594
+ } else {
595
+ return $input[0]._valueGet();
596
+ }
597
+ }
598
+
599
+ function TranslatePosition(pos) {
600
+ if (isRTL && typeof pos == 'number' && (!opts.greedy || opts.placeholder != "")) {
601
+ var bffrLght = getActiveBuffer().length;
602
+ pos = bffrLght - pos;
603
+ }
604
+ return pos;
605
+ }
606
+
607
+ function caret(input, begin, end) {
608
+ var npt = input.jquery && input.length > 0 ? input[0] : input, range;
609
+ if (typeof begin == 'number') {
610
+ begin = TranslatePosition(begin);
611
+ end = TranslatePosition(end);
612
+ if (!$(input).is(':visible')) {
613
+ return;
614
+ }
615
+ end = (typeof end == 'number') ? end : begin;
616
+ npt.scrollLeft = npt.scrollWidth;
617
+ if (opts.insertMode == false && begin == end) end++; //set visualization for insert/overwrite mode
618
+ if (npt.setSelectionRange) {
619
+ npt.selectionStart = begin;
620
+ npt.selectionEnd = android ? begin : end;
621
+
622
+ } else if (npt.createTextRange) {
623
+ range = npt.createTextRange();
624
+ range.collapse(true);
625
+ range.moveEnd('character', end);
626
+ range.moveStart('character', begin);
627
+ range.select();
628
+ }
629
+ } else {
630
+ if (!$(input).is(':visible')) {
631
+ return { "begin": 0, "end": 0 };
632
+ }
633
+ if (npt.setSelectionRange) {
634
+ begin = npt.selectionStart;
635
+ end = npt.selectionEnd;
636
+ } else if (document.selection && document.selection.createRange) {
637
+ range = document.selection.createRange();
638
+ begin = 0 - range.duplicate().moveStart('character', -100000);
639
+ end = begin + range.text.length;
640
+ }
641
+ begin = TranslatePosition(begin);
642
+ end = TranslatePosition(end);
643
+ return { "begin": begin, "end": end };
644
+ }
645
+ }
646
+
647
+ function isComplete(buffer) { //return true / false / undefined (repeat *)
648
+ if (opts.repeat == "*") return undefined;
649
+ var complete = false, highestValidPosition = 0, currentActiveMasksetIndex = activeMasksetIndex;
650
+ $.each(masksets, function (ndx, ms) {
651
+ if (typeof (ms) == "object") {
652
+ activeMasksetIndex = ndx;
653
+ var aml = seekPrevious(getMaskLength());
654
+ if (ms["lastValidPosition"] >= highestValidPosition && ms["lastValidPosition"] == aml) {
655
+ var msComplete = true;
656
+ for (var i = 0; i <= aml; i++) {
657
+ var mask = isMask(i), testPos = determineTestPosition(i);
658
+ if ((mask && (buffer[i] == undefined || buffer[i] == getPlaceHolder(i))) || (!mask && buffer[i] != getActiveBufferTemplate()[testPos])) {
659
+ msComplete = false;
660
+ break;
661
+ }
662
+ }
663
+ complete = complete || msComplete;
664
+ if (complete) //break loop
665
+ return false;
666
+ }
667
+ highestValidPosition = ms["lastValidPosition"];
668
+ }
669
+ });
670
+ activeMasksetIndex = currentActiveMasksetIndex; //reset activeMaskset
671
+ return complete;
672
+ }
673
+
674
+ function isSelection(begin, end) {
675
+ return isRTL ? (begin - end) > 1 || ((begin - end) == 1 && opts.insertMode) :
676
+ (end - begin) > 1 || ((end - begin) == 1 && opts.insertMode);
677
+ }
678
+
679
+ function mask(el) {
680
+ $el = $(el);
681
+ if (!$el.is(":input")) return;
682
+
683
+ //store tests & original buffer in the input element - used to get the unmasked value
684
+ $el.data('_inputmask', {
685
+ 'masksets': masksets,
686
+ 'activeMasksetIndex': activeMasksetIndex,
687
+ 'opts': opts,
688
+ 'isRTL': false
689
+ });
690
+
691
+ //show tooltip
692
+ if (opts.showTooltip) {
693
+ $el.prop("title", getActiveMaskSet()["mask"]);
694
+ }
695
+
696
+ //correct greedy setting if needed
697
+ getActiveMaskSet()['greedy'] = getActiveMaskSet()['greedy'] ? getActiveMaskSet()['greedy'] : getActiveMaskSet()['repeat'] == 0;
698
+
699
+ //handle maxlength attribute
700
+ if ($el.attr("maxLength") != null) //only when the attribute is set
701
+ {
702
+ var maxLength = $el.prop('maxLength');
703
+ if (maxLength > -1) { //handle *-repeat
704
+ $.each(masksets, function (ndx, ms) {
705
+ if (typeof (ms) == "object") {
706
+ if (ms["repeat"] == "*") {
707
+ ms["repeat"] = maxLength;
708
+ }
709
+ }
710
+ });
711
+ }
712
+ if (getMaskLength() >= maxLength && maxLength > -1) { //FF sets no defined max length to -1
713
+ if (maxLength < getActiveBufferTemplate().length) getActiveBufferTemplate().length = maxLength;
714
+ if (getActiveMaskSet()['greedy'] == false) {
715
+ getActiveMaskSet()['repeat'] = Math.round(maxLength / getActiveBufferTemplate().length);
716
+ }
717
+ $el.prop('maxLength', getMaskLength() * 2);
718
+ }
719
+ }
720
+
721
+ patchValueProperty(el);
722
+
723
+ //init vars
724
+ var skipKeyPressEvent = false, //Safari 5.1.x - modal dialog fires keypress twice workaround
725
+ skipInputEvent = false, //skip when triggered from within inputmask
726
+ ignorable = false;
727
+
728
+ if (opts.numericInput) opts.isNumeric = opts.numericInput;
729
+ if (el.dir == "rtl" || (opts.numericInput && opts.rightAlignNumerics) || (opts.isNumeric && opts.rightAlignNumerics))
730
+ $el.css("text-align", "right");
731
+
732
+ if (el.dir == "rtl" || opts.numericInput) {
733
+ el.dir = "ltr";
734
+ $el.removeAttr("dir");
735
+ var inputData = $el.data('_inputmask');
736
+ inputData['isRTL'] = true;
737
+ $el.data('_inputmask', inputData);
738
+ isRTL = true;
739
+ }
740
+
741
+ //unbind all events - to make sure that no other mask will interfere when re-masking
742
+ $el.unbind(".inputmask");
743
+ $el.removeClass('focus.inputmask');
744
+ //bind events
745
+ $el.closest('form').bind("submit", function () { //trigger change on submit if any
746
+ if (valueOnFocus != getActiveBuffer().join('')) {
747
+ $el.change();
748
+ }
749
+ }).bind('reset', function () {
750
+ setTimeout(function () {
751
+ $el.trigger("setvalue");
752
+ }, 0);
753
+ });
754
+ $el.bind("mouseenter.inputmask", function () {
755
+ var $input = $(this), input = this;
756
+ if (!$input.hasClass('focus.inputmask') && opts.showMaskOnHover) {
757
+ if (input._valueGet() != getActiveBuffer().join('')) {
758
+ writeBuffer(input, getActiveBuffer());
759
+ }
760
+ }
761
+ }).bind("blur.inputmask", function () {
762
+ var $input = $(this), input = this, nptValue = input._valueGet(), buffer = getActiveBuffer();
763
+ $input.removeClass('focus.inputmask');
764
+ if (valueOnFocus != getActiveBuffer().join('')) {
765
+ $input.change();
766
+ }
767
+ if (opts.clearMaskOnLostFocus && nptValue != '') {
768
+ if (nptValue == getActiveBufferTemplate().join(''))
769
+ input._valueSet('');
770
+ else { //clearout optional tail of the mask
771
+ clearOptionalTail(input);
772
+ }
773
+ }
774
+ if (isComplete(buffer) === false) {
775
+ $input.trigger("incomplete");
776
+ if (opts.clearIncomplete) {
777
+ $.each(masksets, function (ndx, ms) {
778
+ if (typeof (ms) == "object") {
779
+ ms["buffer"] = ms["_buffer"].slice();
780
+ ms["lastValidPosition"] = -1;
781
+ }
782
+ });
783
+ activeMasksetIndex = 0;
784
+ if (opts.clearMaskOnLostFocus)
785
+ input._valueSet('');
786
+ else {
787
+ buffer = getActiveBufferTemplate().slice();
788
+ writeBuffer(input, buffer);
789
+ }
790
+ }
791
+ }
792
+ }).bind("focus.inputmask", function () {
793
+ var $input = $(this), input = this, nptValue = input._valueGet();
794
+ if (opts.showMaskOnFocus && !$input.hasClass('focus.inputmask') && (!opts.showMaskOnHover || (opts.showMaskOnHover && nptValue == ''))) {
795
+ if (input._valueGet() != getActiveBuffer().join('')) {
796
+ writeBuffer(input, getActiveBuffer(), seekNext(getActiveMaskSet()["lastValidPosition"]));
797
+ }
798
+ }
799
+ $input.addClass('focus.inputmask');
800
+ valueOnFocus = getActiveBuffer().join('');
801
+ }).bind("mouseleave.inputmask", function () {
802
+ var $input = $(this), input = this;
803
+ if (opts.clearMaskOnLostFocus) {
804
+ if (!$input.hasClass('focus.inputmask') && input._valueGet() != $input.attr("placeholder")) {
805
+ if (input._valueGet() == getActiveBufferTemplate().join('') || input._valueGet() == '')
806
+ input._valueSet('');
807
+ else { //clearout optional tail of the mask
808
+ clearOptionalTail(input);
809
+ }
810
+ }
811
+ }
812
+ }).bind("click.inputmask", function () {
813
+ var input = this;
814
+ setTimeout(function () {
815
+ var selectedCaret = caret(input), buffer = getActiveBuffer();
816
+ if (selectedCaret.begin == selectedCaret.end) {
817
+ var clickPosition = opts.isRTL ? TranslatePosition(selectedCaret.begin) : selectedCaret.begin,
818
+ lvp = getActiveMaskSet()["lastValidPosition"],
819
+ lastPosition;
820
+ if (opts.isNumeric) {
821
+ lastPosition = opts.skipRadixDance === false && opts.radixPoint != "" && $.inArray(opts.radixPoint, buffer) != -1 ?
822
+ (opts.numericInput ? seekNext($.inArray(opts.radixPoint, buffer)) : $.inArray(opts.radixPoint, buffer)) :
823
+ seekNext(lvp);
824
+ } else {
825
+ lastPosition = seekNext(lvp);
826
+ }
827
+ if (clickPosition < lastPosition) {
828
+ if (isMask(clickPosition))
829
+ caret(input, clickPosition);
830
+ else caret(input, seekNext(clickPosition));
831
+ } else
832
+ caret(input, lastPosition);
833
+ }
834
+ }, 0);
835
+ }).bind('dblclick.inputmask', function () {
836
+ var input = this;
837
+ setTimeout(function () {
838
+ caret(input, 0, seekNext(getActiveMaskSet()["lastValidPosition"]));
839
+ }, 0);
840
+ }).bind(pasteEvent + ".inputmask dragdrop.inputmask drop.inputmask", function (e) {
841
+ if (skipInputEvent === true) {
842
+ skipInputEvent = false;
843
+ return true;
844
+ }
845
+ var input = this, $input = $(input);
846
+
847
+ //paste event for IE8 and lower I guess ;-)
848
+ if (e.type == "propertychange" && input._valueGet().length <= getMaskLength()) {
849
+ return true;
850
+ }
851
+ setTimeout(function () {
852
+ var pasteValue = opts.onBeforePaste != undefined ? opts.onBeforePaste.call(this, input._valueGet()) : input._valueGet();
853
+ checkVal(input, true, false, pasteValue.split(''), true);
854
+ if (isComplete(getActiveBuffer()) === true)
855
+ $input.trigger("complete");
856
+ $input.click();
857
+ }, 0);
858
+ }).bind('setvalue.inputmask', function () {
859
+ var input = this;
860
+ checkVal(input, true);
861
+ valueOnFocus = getActiveBuffer().join('');
862
+ if (input._valueGet() == getActiveBufferTemplate().join(''))
863
+ input._valueSet('');
864
+ }).bind("_keypress.inputmask", keypressEvent //will be skipped be the eventruler
865
+ ).bind('complete.inputmask', opts.oncomplete
866
+ ).bind('incomplete.inputmask', opts.onincomplete
867
+ ).bind('cleared.inputmask', opts.oncleared
868
+ ).bind("keyup.inputmask", keyupEvent);
869
+
870
+ if (androidchrome) {
871
+ $el.bind("input.inputmask", function (e) {
872
+ if (skipInputEvent === true) {
873
+ skipInputEvent = false;
874
+ return true;
875
+ }
876
+ var input = this, $input = $(input);
877
+
878
+ chromeValueOnInput = getActiveBuffer().join('');
879
+ checkVal(input, false, false);
880
+ writeBuffer(input, getActiveBuffer());
881
+ if (isComplete(getActiveBuffer()) === true)
882
+ $input.trigger("complete");
883
+ $input.click();
884
+ });
885
+ } else {
886
+ $el.bind("keydown.inputmask", keydownEvent
887
+ ).bind("keypress.inputmask", keypressEvent);
888
+ }
889
+
890
+ //apply mask
891
+ checkVal(el, true, false);
892
+ valueOnFocus = getActiveBuffer().join('');
893
+ // Wrap document.activeElement in a try/catch block since IE9 throw "Unspecified error" if document.activeElement is undefined when we are in an IFrame.
894
+ var activeElement;
895
+ try {
896
+ activeElement = document.activeElement;
897
+ } catch (e) {
898
+ }
899
+ if (activeElement === el) { //position the caret when in focus
900
+ $el.addClass('focus.inputmask');
901
+ caret(el, seekNext(getActiveMaskSet()["lastValidPosition"]));
902
+ } else if (opts.clearMaskOnLostFocus) {
903
+ if (getActiveBuffer().join('') == getActiveBufferTemplate().join('')) {
904
+ el._valueSet('');
905
+ } else {
906
+ clearOptionalTail(el);
907
+ }
908
+ } else {
909
+ writeBuffer(el, getActiveBuffer());
910
+ }
911
+
912
+ installEventRuler(el);
913
+
914
+ //private functions
915
+
916
+ function installEventRuler(npt) {
917
+ var events = $._data(npt).events;
918
+
919
+ $.each(events, function (eventType, eventHandlers) {
920
+ $.each(eventHandlers, function (ndx, eventHandler) {
921
+ if (eventHandler.namespace == "inputmask") {
922
+ if (eventHandler.type != "setvalue" && eventHandler.type != "_keypress") {
923
+ var handler = eventHandler.handler;
924
+ eventHandler.handler = function (e) {
925
+ if (this.readOnly || this.disabled)
926
+ e.preventDefault;
927
+ else
928
+ return handler.apply(this, arguments);
929
+ };
930
+ }
931
+ }
932
+ });
933
+ });
934
+ }
935
+
936
+ function patchValueProperty(npt) {
937
+ var valueProperty;
938
+ if (Object.getOwnPropertyDescriptor)
939
+ valueProperty = Object.getOwnPropertyDescriptor(npt, "value");
940
+ if (valueProperty && valueProperty.get) {
941
+ if (!npt._valueGet) {
942
+ var valueGet = valueProperty.get;
943
+ var valueSet = valueProperty.set;
944
+ npt._valueGet = function () {
945
+ return isRTL ? valueGet.call(this).split('').reverse().join('') : valueGet.call(this);
946
+ };
947
+ npt._valueSet = function (value) {
948
+ valueSet.call(this, isRTL ? value.split('').reverse().join('') : value);
949
+ };
950
+
951
+ Object.defineProperty(npt, "value", {
952
+ get: function () {
953
+ var $self = $(this), inputData = $(this).data('_inputmask'), masksets = inputData['masksets'],
954
+ activeMasksetIndex = inputData['activeMasksetIndex'];
955
+ return inputData && inputData['opts'].autoUnmask ? $self.inputmask('unmaskedvalue') : valueGet.call(this) != masksets[activeMasksetIndex]['_buffer'].join('') ? valueGet.call(this) : '';
956
+ },
957
+ set: function (value) {
958
+ valueSet.call(this, value);
959
+ $(this).triggerHandler('setvalue.inputmask');
960
+ }
961
+ });
962
+ }
963
+ } else if (document.__lookupGetter__ && npt.__lookupGetter__("value")) {
964
+ if (!npt._valueGet) {
965
+ var valueGet = npt.__lookupGetter__("value");
966
+ var valueSet = npt.__lookupSetter__("value");
967
+ npt._valueGet = function () {
968
+ return isRTL ? valueGet.call(this).split('').reverse().join('') : valueGet.call(this);
969
+ };
970
+ npt._valueSet = function (value) {
971
+ valueSet.call(this, isRTL ? value.split('').reverse().join('') : value);
972
+ };
973
+
974
+ npt.__defineGetter__("value", function () {
975
+ var $self = $(this), inputData = $(this).data('_inputmask'), masksets = inputData['masksets'],
976
+ activeMasksetIndex = inputData['activeMasksetIndex'];
977
+ return inputData && inputData['opts'].autoUnmask ? $self.inputmask('unmaskedvalue') : valueGet.call(this) != masksets[activeMasksetIndex]['_buffer'].join('') ? valueGet.call(this) : '';
978
+ });
979
+ npt.__defineSetter__("value", function (value) {
980
+ valueSet.call(this, value);
981
+ $(this).triggerHandler('setvalue.inputmask');
982
+ });
983
+ }
984
+ } else {
985
+ if (!npt._valueGet) {
986
+ npt._valueGet = function () { return isRTL ? this.value.split('').reverse().join('') : this.value; };
987
+ npt._valueSet = function (value) { this.value = isRTL ? value.split('').reverse().join('') : value; };
988
+ }
989
+ if ($.valHooks.text == undefined || $.valHooks.text.inputmaskpatch != true) {
990
+ var valueGet = $.valHooks.text && $.valHooks.text.get ? $.valHooks.text.get : function (elem) { return elem.value; };
991
+ var valueSet = $.valHooks.text && $.valHooks.text.set ? $.valHooks.text.set : function (elem, value) {
992
+ elem.value = value;
993
+ return elem;
994
+ };
995
+
996
+ jQuery.extend($.valHooks, {
997
+ text: {
998
+ get: function (elem) {
999
+ var $elem = $(elem);
1000
+ if ($elem.data('_inputmask')) {
1001
+ if ($elem.data('_inputmask')['opts'].autoUnmask)
1002
+ return $elem.inputmask('unmaskedvalue');
1003
+ else {
1004
+ var result = valueGet(elem),
1005
+ inputData = $elem.data('_inputmask'), masksets = inputData['masksets'],
1006
+ activeMasksetIndex = inputData['activeMasksetIndex'];
1007
+ return result != masksets[activeMasksetIndex]['_buffer'].join('') ? result : '';
1008
+ }
1009
+ } else return valueGet(elem);
1010
+ },
1011
+ set: function (elem, value) {
1012
+ var $elem = $(elem);
1013
+ var result = valueSet(elem, value);
1014
+ if ($elem.data('_inputmask')) $elem.triggerHandler('setvalue.inputmask');
1015
+ return result;
1016
+ },
1017
+ inputmaskpatch: true
1018
+ }
1019
+ });
1020
+ }
1021
+ }
1022
+ }
1023
+
1024
+ //shift chars to left from start to end and put c at end position if defined
1025
+
1026
+ function shiftL(start, end, c, maskJumps) {
1027
+ var buffer = getActiveBuffer();
1028
+ if (maskJumps !== false) //jumping over nonmask position
1029
+ while (!isMask(start) && start - 1 >= 0) start--;
1030
+ for (var i = start; i < end && i < getMaskLength() ; i++) {
1031
+ if (isMask(i)) {
1032
+ setReTargetPlaceHolder(buffer, i);
1033
+ var j = seekNext(i);
1034
+ var p = getBufferElement(buffer, j);
1035
+ if (p != getPlaceHolder(j)) {
1036
+ if (j < getMaskLength() && isValid(i, p, true) !== false && getActiveTests()[determineTestPosition(i)].def == getActiveTests()[determineTestPosition(j)].def) {
1037
+ setBufferElement(buffer, i, p, true);
1038
+ } else {
1039
+ if (isMask(i))
1040
+ break;
1041
+ }
1042
+ }
1043
+ } else {
1044
+ setReTargetPlaceHolder(buffer, i);
1045
+ }
1046
+ }
1047
+ if (c != undefined)
1048
+ setBufferElement(buffer, seekPrevious(end), c);
1049
+
1050
+ if (getActiveMaskSet()["greedy"] == false) {
1051
+ var trbuffer = truncateInput(buffer.join('')).split('');
1052
+ buffer.length = trbuffer.length;
1053
+ for (var i = 0, bl = buffer.length; i < bl; i++) {
1054
+ buffer[i] = trbuffer[i];
1055
+ }
1056
+ if (buffer.length == 0) getActiveMaskSet()["buffer"] = getActiveBufferTemplate().slice();
1057
+ }
1058
+ return start; //return the used start position
1059
+ }
1060
+
1061
+ function shiftR(start, end, c) {
1062
+ var buffer = getActiveBuffer();
1063
+ if (getBufferElement(buffer, start, true) != getPlaceHolder(start)) {
1064
+ for (var i = seekPrevious(end) ; i > start && i >= 0; i--) {
1065
+ if (isMask(i)) {
1066
+ var j = seekPrevious(i);
1067
+ var t = getBufferElement(buffer, j);
1068
+ if (t != getPlaceHolder(j)) {
1069
+ if (isValid(j, t, true) !== false && getActiveTests()[determineTestPosition(i)].def == getActiveTests()[determineTestPosition(j)].def) {
1070
+ setBufferElement(buffer, i, t, true);
1071
+ setReTargetPlaceHolder(buffer, j);
1072
+ } //else break;
1073
+ }
1074
+ } else
1075
+ setReTargetPlaceHolder(buffer, i);
1076
+ }
1077
+ }
1078
+ if (c != undefined && getBufferElement(buffer, start) == getPlaceHolder(start))
1079
+ setBufferElement(buffer, start, c);
1080
+ var lengthBefore = buffer.length;
1081
+ if (getActiveMaskSet()["greedy"] == false) {
1082
+ var trbuffer = truncateInput(buffer.join('')).split('');
1083
+ buffer.length = trbuffer.length;
1084
+ for (var i = 0, bl = buffer.length; i < bl; i++) {
1085
+ buffer[i] = trbuffer[i];
1086
+ }
1087
+ if (buffer.length == 0) getActiveMaskSet()["buffer"] = getActiveBufferTemplate().slice();
1088
+ }
1089
+ return end - (lengthBefore - buffer.length); //return new start position
1090
+ }
1091
+
1092
+ ;
1093
+
1094
+
1095
+ function HandleRemove(input, k, pos) {
1096
+ if (opts.numericInput || isRTL) {
1097
+ switch (k) {
1098
+ case opts.keyCode.BACKSPACE:
1099
+ k = opts.keyCode.DELETE;
1100
+ break;
1101
+ case opts.keyCode.DELETE:
1102
+ k = opts.keyCode.BACKSPACE;
1103
+ break;
1104
+ }
1105
+ if (isRTL) {
1106
+ var pend = pos.end;
1107
+ pos.end = pos.begin;
1108
+ pos.begin = pend;
1109
+ }
1110
+ }
1111
+
1112
+ var isSelection = true;
1113
+ if (pos.begin == pos.end) {
1114
+ var posBegin = k == opts.keyCode.BACKSPACE ? pos.begin - 1 : pos.begin;
1115
+ if (opts.isNumeric && opts.radixPoint != "" && getActiveBuffer()[posBegin] == opts.radixPoint) {
1116
+ pos.begin = (getActiveBuffer().length - 1 == posBegin) /* radixPoint is latest? delete it */ ? pos.begin : k == opts.keyCode.BACKSPACE ? posBegin : seekNext(posBegin);
1117
+ pos.end = pos.begin;
1118
+ }
1119
+ isSelection = false;
1120
+ if (k == opts.keyCode.BACKSPACE)
1121
+ pos.begin--;
1122
+ else if (k == opts.keyCode.DELETE)
1123
+ pos.end++;
1124
+ } else if (pos.end - pos.begin == 1 && !opts.insertMode) {
1125
+ isSelection = false;
1126
+ if (k == opts.keyCode.BACKSPACE)
1127
+ pos.begin--;
1128
+ }
1129
+
1130
+ clearBuffer(getActiveBuffer(), pos.begin, pos.end);
1131
+
1132
+ var ml = getMaskLength();
1133
+ if (opts.greedy == false) {
1134
+ shiftL(pos.begin, ml, undefined, !isRTL && (k == opts.keyCode.BACKSPACE && !isSelection));
1135
+ } else {
1136
+ var newpos = pos.begin;
1137
+ for (var i = pos.begin; i < pos.end; i++) { //seeknext to skip placeholders at start in selection
1138
+ if (isMask(i) || !isSelection)
1139
+ newpos = shiftL(pos.begin, ml, undefined, !isRTL && (k == opts.keyCode.BACKSPACE && !isSelection));
1140
+ }
1141
+ if (!isSelection) pos.begin = newpos;
1142
+ }
1143
+ var firstMaskPos = seekNext(-1);
1144
+ clearBuffer(getActiveBuffer(), pos.begin, pos.end, true);
1145
+ checkVal(input, false, masksets[1] == undefined || firstMaskPos >= pos.end, getActiveBuffer());
1146
+ if (getActiveMaskSet()['lastValidPosition'] < firstMaskPos) {
1147
+ getActiveMaskSet()["lastValidPosition"] = -1;
1148
+ getActiveMaskSet()["p"] = firstMaskPos;
1149
+ } else {
1150
+ getActiveMaskSet()["p"] = pos.begin;
1151
+ }
1152
+ }
1153
+
1154
+ function keydownEvent(e) {
1155
+ //Safari 5.1.x - modal dialog fires keypress twice workaround
1156
+ skipKeyPressEvent = false;
1157
+ var input = this, $input = $(input), k = e.keyCode, pos = caret(input);
1158
+
1159
+ //backspace, delete, and escape get special treatment
1160
+ if (k == opts.keyCode.BACKSPACE || k == opts.keyCode.DELETE || (iphone && k == 127) || e.ctrlKey && k == 88) { //backspace/delete
1161
+ e.preventDefault(); //stop default action but allow propagation
1162
+ if (k == 88) valueOnFocus = getActiveBuffer().join('');
1163
+ HandleRemove(input, k, pos);
1164
+ determineActiveMasksetIndex();
1165
+ writeBuffer(input, getActiveBuffer(), getActiveMaskSet()["p"]);
1166
+ if (input._valueGet() == getActiveBufferTemplate().join(''))
1167
+ $input.trigger('cleared');
1168
+
1169
+ if (opts.showTooltip) { //update tooltip
1170
+ $input.prop("title", getActiveMaskSet()["mask"]);
1171
+ }
1172
+ } else if (k == opts.keyCode.END || k == opts.keyCode.PAGE_DOWN) { //when END or PAGE_DOWN pressed set position at lastmatch
1173
+ setTimeout(function () {
1174
+ var caretPos = seekNext(getActiveMaskSet()["lastValidPosition"]);
1175
+ if (!opts.insertMode && caretPos == getMaskLength() && !e.shiftKey) caretPos--;
1176
+ caret(input, e.shiftKey ? pos.begin : caretPos, caretPos);
1177
+ }, 0);
1178
+ } else if ((k == opts.keyCode.HOME && !e.shiftKey) || k == opts.keyCode.PAGE_UP) { //Home or page_up
1179
+ caret(input, 0, e.shiftKey ? pos.begin : 0);
1180
+ } else if (k == opts.keyCode.ESCAPE || (k == 90 && e.ctrlKey)) { //escape && undo
1181
+ checkVal(input, true, false, valueOnFocus.split(''));
1182
+ $input.click();
1183
+ } else if (k == opts.keyCode.INSERT && !(e.shiftKey || e.ctrlKey)) { //insert
1184
+ opts.insertMode = !opts.insertMode;
1185
+ caret(input, !opts.insertMode && pos.begin == getMaskLength() ? pos.begin - 1 : pos.begin);
1186
+ } else if (opts.insertMode == false && !e.shiftKey) {
1187
+ if (k == opts.keyCode.RIGHT) {
1188
+ setTimeout(function () {
1189
+ var caretPos = caret(input);
1190
+ caret(input, caretPos.begin);
1191
+ }, 0);
1192
+ } else if (k == opts.keyCode.LEFT) {
1193
+ setTimeout(function () {
1194
+ var caretPos = caret(input);
1195
+ caret(input, caretPos.begin - 1);
1196
+ }, 0);
1197
+ }
1198
+ }
1199
+
1200
+ var currentCaretPos = caret(input);
1201
+ if (opts.onKeyDown.call(this, e, getActiveBuffer(), opts) === true) //extra stuff to execute on keydown
1202
+ caret(input, currentCaretPos.begin, currentCaretPos.end);
1203
+ ignorable = $.inArray(k, opts.ignorables) != -1;
1204
+ }
1205
+
1206
+
1207
+ function keypressEvent(e, checkval, k, writeOut, strict, ndx) {
1208
+ //Safari 5.1.x - modal dialog fires keypress twice workaround
1209
+ if (k == undefined && skipKeyPressEvent) return false;
1210
+ skipKeyPressEvent = true;
1211
+
1212
+ var input = this, $input = $(input);
1213
+
1214
+ e = e || window.event;
1215
+ var k = k || e.which || e.charCode || e.keyCode;
1216
+
1217
+ if ((!(e.ctrlKey && e.altKey) && (e.ctrlKey || e.metaKey || ignorable)) && checkval !== true) {
1218
+ return true;
1219
+ } else {
1220
+ if (k) {
1221
+ //special treat the decimal separator
1222
+ if (checkval !== true && k == 46 && e.shiftKey == false && opts.radixPoint == ",") k = 44;
1223
+
1224
+ var pos, results, result, c = String.fromCharCode(k);
1225
+ if (checkval) {
1226
+ var pcaret = strict ? ndx : getActiveMaskSet()["lastValidPosition"] + 1;
1227
+ pos = { begin: pcaret, end: pcaret };
1228
+ } else {
1229
+ pos = caret(input);
1230
+ }
1231
+
1232
+ //should we clear a possible selection??
1233
+ var isSlctn = isSelection(pos.begin, pos.end), redetermineLVP = false,
1234
+ initialIndex = activeMasksetIndex;
1235
+ if (isSlctn) {
1236
+ activeMasksetIndex = initialIndex;
1237
+ $.each(masksets, function (ndx, lmnt) { //init undobuffer for recovery when not valid
1238
+ if (typeof (lmnt) == "object") {
1239
+ activeMasksetIndex = ndx;
1240
+ getActiveMaskSet()["undoBuffer"] = getActiveBuffer().join('');
1241
+ }
1242
+ });
1243
+ HandleRemove(input, opts.keyCode.DELETE, pos);
1244
+ if (!opts.insertMode) { //preserve some space
1245
+ $.each(masksets, function (ndx, lmnt) {
1246
+ if (typeof (lmnt) == "object") {
1247
+ activeMasksetIndex = ndx;
1248
+ shiftR(pos.begin, getMaskLength());
1249
+ getActiveMaskSet()["lastValidPosition"] = seekNext(getActiveMaskSet()["lastValidPosition"]);
1250
+ }
1251
+ });
1252
+ }
1253
+ activeMasksetIndex = initialIndex; //restore index
1254
+ }
1255
+
1256
+ var radixPosition = getActiveBuffer().join('').indexOf(opts.radixPoint);
1257
+ if (opts.isNumeric && checkval !== true && radixPosition != -1) {
1258
+ if (opts.greedy && pos.begin <= radixPosition) {
1259
+ pos.begin = seekPrevious(pos.begin);
1260
+ pos.end = pos.begin;
1261
+ } else if (c == opts.radixPoint) {
1262
+ pos.begin = radixPosition;
1263
+ pos.end = pos.begin;
1264
+ }
1265
+ }
1266
+
1267
+
1268
+ var p = pos.begin;
1269
+ results = isValid(p, c, strict);
1270
+ if (strict === true) results = [{ "activeMasksetIndex": activeMasksetIndex, "result": results }];
1271
+ var minimalForwardPosition = -1;
1272
+ $.each(results, function (index, result) {
1273
+ activeMasksetIndex = result["activeMasksetIndex"];
1274
+ getActiveMaskSet()["writeOutBuffer"] = true;
1275
+ var np = result["result"];
1276
+ if (np !== false) {
1277
+ var refresh = false, buffer = getActiveBuffer();
1278
+ if (np !== true) {
1279
+ refresh = np["refresh"]; //only rewrite buffer from isValid
1280
+ p = np.pos != undefined ? np.pos : p; //set new position from isValid
1281
+ c = np.c != undefined ? np.c : c; //set new char from isValid
1282
+ }
1283
+ if (refresh !== true) {
1284
+ if (opts.insertMode == true) {
1285
+ var lastUnmaskedPosition = getMaskLength();
1286
+ var bfrClone = buffer.slice();
1287
+ while (getBufferElement(bfrClone, lastUnmaskedPosition, true) != getPlaceHolder(lastUnmaskedPosition) && lastUnmaskedPosition >= p) {
1288
+ lastUnmaskedPosition = lastUnmaskedPosition == 0 ? -1 : seekPrevious(lastUnmaskedPosition);
1289
+ }
1290
+ if (lastUnmaskedPosition >= p) {
1291
+ shiftR(p, getMaskLength(), c);
1292
+ //shift the lvp if needed
1293
+ var lvp = getActiveMaskSet()["lastValidPosition"], nlvp = seekNext(lvp);
1294
+ if (nlvp != getMaskLength() && lvp >= p && (getBufferElement(getActiveBuffer(), nlvp, true) != getPlaceHolder(nlvp))) {
1295
+ getActiveMaskSet()["lastValidPosition"] = nlvp;
1296
+ }
1297
+ } else getActiveMaskSet()["writeOutBuffer"] = false;
1298
+ } else setBufferElement(buffer, p, c, true);
1299
+ if (minimalForwardPosition == -1 || minimalForwardPosition > seekNext(p)) {
1300
+ minimalForwardPosition = seekNext(p);
1301
+ }
1302
+ } else if (!strict) {
1303
+ var nextPos = p < getMaskLength() ? p + 1 : p;
1304
+ if (minimalForwardPosition == -1 || minimalForwardPosition > nextPos) {
1305
+ minimalForwardPosition = nextPos;
1306
+ }
1307
+ }
1308
+ if (minimalForwardPosition > getActiveMaskSet()["p"])
1309
+ getActiveMaskSet()["p"] = minimalForwardPosition; //needed for checkval strict
1310
+ }
1311
+ });
1312
+
1313
+ if (strict !== true) {
1314
+ activeMasksetIndex = initialIndex;
1315
+ determineActiveMasksetIndex();
1316
+ }
1317
+ if (writeOut !== false) {
1318
+ $.each(results, function (ndx, rslt) {
1319
+ if (rslt["activeMasksetIndex"] == activeMasksetIndex) {
1320
+ result = rslt;
1321
+ return false;
1322
+ }
1323
+ });
1324
+ if (result != undefined) {
1325
+ var self = this;
1326
+ setTimeout(function () { opts.onKeyValidation.call(self, result["result"], opts); }, 0);
1327
+ if (getActiveMaskSet()["writeOutBuffer"] && result["result"] !== false) {
1328
+ var buffer = getActiveBuffer();
1329
+
1330
+ var newCaretPosition;
1331
+ if (checkval) {
1332
+ newCaretPosition = undefined;
1333
+ } else if (opts.numericInput) {
1334
+ if (p > radixPosition) {
1335
+ newCaretPosition = seekPrevious(minimalForwardPosition);
1336
+ } else if (c == opts.radixPoint) {
1337
+ newCaretPosition = minimalForwardPosition - 1;
1338
+ } else newCaretPosition = seekPrevious(minimalForwardPosition - 1);
1339
+ } else {
1340
+ newCaretPosition = minimalForwardPosition;
1341
+ }
1342
+
1343
+ writeBuffer(input, buffer, newCaretPosition);
1344
+ if (checkval !== true) {
1345
+ setTimeout(function () { //timeout needed for IE
1346
+ if (isComplete(buffer) === true)
1347
+ $input.trigger("complete");
1348
+ skipInputEvent = true;
1349
+ $input.trigger("input");
1350
+ }, 0);
1351
+ }
1352
+ } else if (isSlctn) {
1353
+ getActiveMaskSet()["buffer"] = getActiveMaskSet()["undoBuffer"].split('');
1354
+ }
1355
+ }
1356
+ }
1357
+
1358
+ if (opts.showTooltip) { //update tooltip
1359
+ $input.prop("title", getActiveMaskSet()["mask"]);
1360
+ }
1361
+ e.preventDefault();
1362
+ }
1363
+ }
1364
+ }
1365
+
1366
+ function keyupEvent(e) {
1367
+ var $input = $(this), input = this, k = e.keyCode, buffer = getActiveBuffer();
1368
+
1369
+ if (androidchrome && k == opts.keyCode.BACKSPACE) {
1370
+ if (chromeValueOnInput == input._valueGet())
1371
+ keydownEvent.call(this, e);
1372
+ }
1373
+
1374
+ opts.onKeyUp.call(this, e, buffer, opts); //extra stuff to execute on keyup
1375
+ if (k == opts.keyCode.TAB && opts.showMaskOnFocus) {
1376
+ if ($input.hasClass('focus.inputmask') && input._valueGet().length == 0) {
1377
+ buffer = getActiveBufferTemplate().slice();
1378
+ writeBuffer(input, buffer);
1379
+ caret(input, 0);
1380
+ valueOnFocus = getActiveBuffer().join('');
1381
+ } else {
1382
+ writeBuffer(input, buffer);
1383
+ if (buffer.join('') == getActiveBufferTemplate().join('') && $.inArray(opts.radixPoint, buffer) != -1) {
1384
+ caret(input, TranslatePosition(0));
1385
+ $input.click();
1386
+ } else
1387
+ caret(input, TranslatePosition(0), TranslatePosition(getMaskLength()));
1388
+ }
1389
+ }
1390
+ }
1391
+ }
1392
+
1393
+ return {
1394
+ isComplete: function (buffer) {
1395
+ return isComplete(buffer);
1396
+ },
1397
+ unmaskedvalue: function ($input, skipDatepickerCheck) {
1398
+ isRTL = $input.data('_inputmask')['isRTL'];
1399
+ return unmaskedvalue($input, skipDatepickerCheck);
1400
+ },
1401
+ mask: function (el) {
1402
+ mask(el);
1403
+ }
1404
+ };
1405
+ };
1406
+
1407
+ $.inputmask = {
1408
+ //options default
1409
+ defaults: {
1410
+ placeholder: "_",
1411
+ optionalmarker: { start: "[", end: "]" },
1412
+ quantifiermarker: { start: "{", end: "}" },
1413
+ groupmarker: { start: "(", end: ")" },
1414
+ escapeChar: "\\",
1415
+ mask: null,
1416
+ oncomplete: $.noop, //executes when the mask is complete
1417
+ onincomplete: $.noop, //executes when the mask is incomplete and focus is lost
1418
+ oncleared: $.noop, //executes when the mask is cleared
1419
+ repeat: 0, //repetitions of the mask: * ~ forever, otherwise specify an integer
1420
+ greedy: true, //true: allocated buffer for the mask and repetitions - false: allocate only if needed
1421
+ autoUnmask: false, //automatically unmask when retrieving the value with $.fn.val or value if the browser supports __lookupGetter__ or getOwnPropertyDescriptor
1422
+ clearMaskOnLostFocus: true,
1423
+ insertMode: true, //insert the input or overwrite the input
1424
+ clearIncomplete: false, //clear the incomplete input on blur
1425
+ aliases: {}, //aliases definitions => see jquery.inputmask.extensions.js
1426
+ onKeyUp: $.noop, //override to implement autocomplete on certain keys for example
1427
+ onKeyDown: $.noop, //override to implement autocomplete on certain keys for example
1428
+ onBeforePaste: undefined, //executes before masking the pasted value to allow preprocessing of the pasted value. args => pastedValue => return processedValue
1429
+ onUnMask: undefined, //executes after unmasking to allow postprocessing of the unmaskedvalue. args => maskedValue, unmaskedValue
1430
+ showMaskOnFocus: true, //show the mask-placeholder when the input has focus
1431
+ showMaskOnHover: true, //show the mask-placeholder when hovering the empty input
1432
+ onKeyValidation: $.noop, //executes on every key-press with the result of isValid. Params: result, opts
1433
+ skipOptionalPartCharacter: " ", //a character which can be used to skip an optional part of a mask
1434
+ showTooltip: false, //show the activemask as tooltip
1435
+ numericInput: false, //numericInput input direction style (input shifts to the left while holding the caret position)
1436
+ //numeric basic properties
1437
+ isNumeric: false, //enable numeric features
1438
+ radixPoint: "", //".", // | ","
1439
+ skipRadixDance: false, //disable radixpoint caret positioning
1440
+ rightAlignNumerics: true, //align numerics to the right
1441
+ //numeric basic properties
1442
+ definitions: {
1443
+ '9': {
1444
+ validator: "[0-9]",
1445
+ cardinality: 1
1446
+ },
1447
+ 'a': {
1448
+ validator: "[A-Za-z\u0410-\u044F\u0401\u0451]",
1449
+ cardinality: 1
1450
+ },
1451
+ '*': {
1452
+ validator: "[A-Za-z\u0410-\u044F\u0401\u04510-9]",
1453
+ cardinality: 1
1454
+ }
1455
+ },
1456
+ keyCode: {
1457
+ 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,
1458
+ 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
1459
+ },
1460
+ //specify keycodes which should not be considered in the keypress event, otherwise the preventDefault will stop their default behavior especially in FF
1461
+ ignorables: [8, 9, 13, 19, 27, 33, 34, 35, 36, 37, 38, 39, 40, 45, 46, 93, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123],
1462
+ getMaskLength: function (buffer, greedy, repeat, currentBuffer, opts) {
1463
+ var calculatedLength = buffer.length;
1464
+ if (!greedy) {
1465
+ if (repeat == "*") {
1466
+ calculatedLength = currentBuffer.length + 1;
1467
+ } else if (repeat > 1) {
1468
+ calculatedLength += (buffer.length * (repeat - 1));
1469
+ }
1470
+ }
1471
+ return calculatedLength;
1472
+ }
1473
+ },
1474
+ escapeRegex: function (str) {
1475
+ var specials = ['/', '.', '*', '+', '?', '|', '(', ')', '[', ']', '{', '}', '\\'];
1476
+ return str.replace(new RegExp('(\\' + specials.join('|\\') + ')', 'gim'), '\\$1');
1477
+ },
1478
+ format: function (value, opts) {
1479
+
1480
+ }
1481
+ };
1482
+
1483
+ $.fn.inputmask = function (fn, options) {
1484
+ var opts = $.extend(true, {}, $.inputmask.defaults, options),
1485
+ masksets,
1486
+ activeMasksetIndex = 0;
1487
+
1488
+ if (typeof fn === "string") {
1489
+ switch (fn) {
1490
+ case "mask":
1491
+ //resolve possible aliases given by options
1492
+ resolveAlias(opts.alias, options, opts);
1493
+ masksets = generateMaskSets(opts);
1494
+ if (masksets.length == 0) { return this; }
1495
+
1496
+ return this.each(function () {
1497
+ maskScope($.extend(true, {}, masksets), 0, opts).mask(this);
1498
+ });
1499
+ case "unmaskedvalue":
1500
+ var $input = $(this), input = this;
1501
+ if ($input.data('_inputmask')) {
1502
+ masksets = $input.data('_inputmask')['masksets'];
1503
+ activeMasksetIndex = $input.data('_inputmask')['activeMasksetIndex'];
1504
+ opts = $input.data('_inputmask')['opts'];
1505
+ return maskScope(masksets, activeMasksetIndex, opts).unmaskedvalue($input);
1506
+ } else return $input.val();
1507
+ case "remove":
1508
+ return this.each(function () {
1509
+ var $input = $(this), input = this;
1510
+ if ($input.data('_inputmask')) {
1511
+ masksets = $input.data('_inputmask')['masksets'];
1512
+ activeMasksetIndex = $input.data('_inputmask')['activeMasksetIndex'];
1513
+ opts = $input.data('_inputmask')['opts'];
1514
+ //writeout the unmaskedvalue
1515
+ input._valueSet(maskScope(masksets, activeMasksetIndex, opts).unmaskedvalue($input, true));
1516
+ //clear data
1517
+ $input.removeData('_inputmask');
1518
+ //unbind all events
1519
+ $input.unbind(".inputmask");
1520
+ $input.removeClass('focus.inputmask');
1521
+ //restore the value property
1522
+ var valueProperty;
1523
+ if (Object.getOwnPropertyDescriptor)
1524
+ valueProperty = Object.getOwnPropertyDescriptor(input, "value");
1525
+ if (valueProperty && valueProperty.get) {
1526
+ if (input._valueGet) {
1527
+ Object.defineProperty(input, "value", {
1528
+ get: input._valueGet,
1529
+ set: input._valueSet
1530
+ });
1531
+ }
1532
+ } else if (document.__lookupGetter__ && input.__lookupGetter__("value")) {
1533
+ if (input._valueGet) {
1534
+ input.__defineGetter__("value", input._valueGet);
1535
+ input.__defineSetter__("value", input._valueSet);
1536
+ }
1537
+ }
1538
+ try { //try catch needed for IE7 as it does not supports deleting fns
1539
+ delete input._valueGet;
1540
+ delete input._valueSet;
1541
+ } catch (e) {
1542
+ input._valueGet = undefined;
1543
+ input._valueSet = undefined;
1544
+
1545
+ }
1546
+ }
1547
+ });
1548
+ break;
1549
+ case "getemptymask": //return the default (empty) mask value, usefull for setting the default value in validation
1550
+ if (this.data('_inputmask')) {
1551
+ masksets = this.data('_inputmask')['masksets'];
1552
+ activeMasksetIndex = this.data('_inputmask')['activeMasksetIndex'];
1553
+ return masksets[activeMasksetIndex]['_buffer'].join('');
1554
+ }
1555
+ else return "";
1556
+ case "hasMaskedValue": //check wheter the returned value is masked or not; currently only works reliable when using jquery.val fn to retrieve the value
1557
+ return this.data('_inputmask') ? !this.data('_inputmask')['opts'].autoUnmask : false;
1558
+ case "isComplete":
1559
+ masksets = this.data('_inputmask')['masksets'];
1560
+ activeMasksetIndex = this.data('_inputmask')['activeMasksetIndex'];
1561
+ opts = this.data('_inputmask')['opts'];
1562
+ return maskScope(masksets, activeMasksetIndex, opts).isComplete(this[0]._valueGet().split(''));
1563
+ case "getmetadata": //return mask metadata if exists
1564
+ if (this.data('_inputmask')) {
1565
+ masksets = this.data('_inputmask')['masksets'];
1566
+ activeMasksetIndex = this.data('_inputmask')['activeMasksetIndex'];
1567
+ return masksets[activeMasksetIndex]['metadata'];
1568
+ }
1569
+ else return undefined;
1570
+ default:
1571
+ //check if the fn is an alias
1572
+ if (!resolveAlias(fn, options, opts)) {
1573
+ //maybe fn is a mask so we try
1574
+ //set mask
1575
+ opts.mask = fn;
1576
+ }
1577
+ masksets = generateMaskSets(opts);
1578
+ if (masksets.length == 0) { return this; }
1579
+ return this.each(function () {
1580
+ maskScope($.extend(true, {}, masksets), activeMasksetIndex, opts).mask(this);
1581
+ });
1582
+
1583
+ break;
1584
+ }
1585
+ } else if (typeof fn == "object") {
1586
+ opts = $.extend(true, {}, $.inputmask.defaults, fn);
1587
+
1588
+ resolveAlias(opts.alias, fn, opts); //resolve aliases
1589
+ masksets = generateMaskSets(opts);
1590
+ if (masksets.length == 0) { return this; }
1591
+ return this.each(function () {
1592
+ maskScope($.extend(true, {}, masksets), activeMasksetIndex, opts).mask(this);
1593
+ });
1594
+ } else if (fn == undefined) {
1595
+ //look for data-inputmask atribute - the attribute should only contain optipns
1596
+ return this.each(function () {
1597
+ var attrOptions = $(this).attr("data-inputmask");
1598
+ if (attrOptions && attrOptions != "") {
1599
+ try {
1600
+ attrOptions = attrOptions.replace(new RegExp("'", "g"), '"');
1601
+ var dataoptions = $.parseJSON("{" + attrOptions + "}");
1602
+ $.extend(true, dataoptions, options);
1603
+ opts = $.extend(true, {}, $.inputmask.defaults, dataoptions);
1604
+ resolveAlias(opts.alias, dataoptions, opts);
1605
+ opts.alias = undefined;
1606
+ $(this).inputmask(opts);
1607
+ } catch (ex) { } //need a more relax parseJSON
1608
+ }
1609
+ });
1610
+ }
1611
+ };
1612
+ }
1613
+ })(jQuery);