-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
80 lines (80 loc) · 2.56 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// @ts-check
const options = require("./phonemasks.json");
module.exports = function (sel) {
document.addEventListener("DOMContentLoaded", function () {
const selector = sel || "input[data-phone-input]",
phoneInputs = document.querySelectorAll(selector);
options["handleEvent"] = onPhoneInput;
phoneInputs.forEach((it) => {
it.addEventListener("keydown", onPhoneKeyDown);
it.addEventListener("input", options);
it.addEventListener("paste", onPhonePaste);
});
});
};
function getInputNumbersValue(input) {
return input.value.replace(/\D/g, "");
}
function onPhonePaste(e) {
const input = e.target,
pasted = e.clipboardData;
let inputNumbersValue = getInputNumbersValue(input);
if (pasted) {
const pastedText = pasted.getData("Text");
if (/\D/g.test(pastedText)) {
input.value = inputNumbersValue;
return;
}
}
}
function onPhoneInput(e) {
const input = e.target,
selectionStart = input.selectionStart;
let inputNumbersValue = getInputNumbersValue(input),
formattedInputValue = "";
if (!inputNumbersValue) {
input.value = "";
return;
}
if (input.value.length != selectionStart) {
if (e.data && isNaN(+e.data)) {
input.setSelectionRange(input.selectionStart - 1, input.selectionStart, "backward");
input.setRangeText("");
}
return;
}
if (~["7", "8", "9"].indexOf(inputNumbersValue[0])) {
if (inputNumbersValue[0] == "9") inputNumbersValue = "7" + inputNumbersValue;
const firstSymbols = inputNumbersValue[0] == "8" ? "8" : "+7";
renderMask(firstSymbols, this.ru);
} else if (inputNumbersValue.startsWith("375")) {
const firstSymbols = "+375";
renderMask(firstSymbols, this.by);
} else {
if (inputNumbersValue) {
formattedInputValue = "+" + inputNumbersValue.substring(0, 16);
}
}
input.value = formattedInputValue;
function renderMask(firstSymbols, opt) {
formattedInputValue = input.value = firstSymbols;
if (inputNumbersValue.length > +opt.fb.from) {
formattedInputValue += " (" + inputNumbersValue.substring(+opt.fb.from, +opt.fb.to);
}
if (inputNumbersValue.length > +opt.sb.from) {
formattedInputValue += ") " + inputNumbersValue.substring(+opt.sb.from, +opt.sb.to);
}
if (inputNumbersValue.length > +opt.fn.from) {
formattedInputValue += "-" + inputNumbersValue.substring(+opt.fn.from, +opt.fn.to);
}
if (inputNumbersValue.length > +opt.sn.from) {
formattedInputValue += "-" + inputNumbersValue.substring(+opt.sn.from, +opt.sn.to);
}
}
}
function onPhoneKeyDown(e) {
const inputValue = e.target.value.replace(/\D/g, "");
if (e.keyCode == 8 && inputValue.length == 1) {
e.target.value = "";
}
}