Add Transliteration checkbox
This commit is contained in:
parent
e4b564773d
commit
706f105456
2 changed files with 43 additions and 113 deletions
|
@ -1,5 +1,6 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||
|
@ -7,13 +8,16 @@
|
|||
<link rel="stylesheet" href="main.css">
|
||||
<title>Translite</title>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<h1>Translite</h1>
|
||||
<div class="wrapper">
|
||||
<textarea id="transtxt" cols="30" rows="15" oninput="translit()"></textarea>
|
||||
</div>
|
||||
<input type="checkbox" id="translitCheckbox" onchange="toggleTranslit()" checked> Transliteration
|
||||
<button onclick="copytxt()">Copy text</button>
|
||||
<button onclick="cleartxt()">Clear text</button>
|
||||
<script src="main.js" charset="utf-8"></script>
|
||||
</body>
|
||||
|
||||
</html>
|
152
main.js
152
main.js
|
@ -1,112 +1,42 @@
|
|||
let translitEnabled = true;
|
||||
|
||||
function toggleTranslit() {
|
||||
translitEnabled = document.getElementById("translitCheckbox").checked;
|
||||
}
|
||||
|
||||
function translit() {
|
||||
var dic1 = {
|
||||
A: "А",
|
||||
a: "а",
|
||||
B: "Б",
|
||||
b: "б",
|
||||
V: "В",
|
||||
v: "в",
|
||||
G: "Г",
|
||||
g: "г",
|
||||
D: "Д",
|
||||
d: "д",
|
||||
E: "Е",
|
||||
e: "е",
|
||||
Z: "З",
|
||||
z: "з",
|
||||
I: "И",
|
||||
i: "и",
|
||||
J: "Й",
|
||||
j: "й",
|
||||
K: "К",
|
||||
k: "к",
|
||||
L: "Л",
|
||||
l: "л",
|
||||
M: "М",
|
||||
m: "м",
|
||||
N: "Н",
|
||||
n: "н",
|
||||
O: "О",
|
||||
o: "о",
|
||||
P: "П",
|
||||
p: "п",
|
||||
R: "Р",
|
||||
r: "р",
|
||||
S: "С",
|
||||
s: "с",
|
||||
T: "Т",
|
||||
t: "т",
|
||||
U: "У",
|
||||
u: "у",
|
||||
F: "Ф",
|
||||
f: "ф",
|
||||
X: "Х",
|
||||
x: "х",
|
||||
H: "Х",
|
||||
h: "х",
|
||||
C: "Ц",
|
||||
c: "ц",
|
||||
W: "В",
|
||||
w: "в",
|
||||
"\u0022": "ъ",
|
||||
Y: "Ы",
|
||||
y: "ы",
|
||||
"\u0027": "ь",
|
||||
Ä: "Э",
|
||||
ä: "э",
|
||||
Ö: "Ё",
|
||||
ö: "ё",
|
||||
Ü: "Ю",
|
||||
ü: "ю",
|
||||
Q: "Я",
|
||||
q: "я"
|
||||
if (!translitEnabled) return;
|
||||
|
||||
const dic1 = {
|
||||
A: "А", a: "а", B: "Б", b: "б", V: "В", v: "в", G: "Г", g: "г",
|
||||
D: "Д", d: "д", E: "Е", e: "е", Z: "З", z: "з", I: "И", i: "и",
|
||||
J: "Й", j: "й", K: "К", k: "к", L: "Л", l: "л", M: "М", m: "м",
|
||||
N: "Н", n: "н", O: "О", o: "о", P: "П", p: "п", R: "Р", r: "р",
|
||||
S: "С", s: "с", T: "Т", t: "т", U: "У", u: "у", F: "Ф", f: "ф",
|
||||
X: "Х", x: "х", H: "Х", h: "х", C: "Ц", c: "ц", W: "В", w: "в",
|
||||
"\u0022": "ъ", Y: "Ы", y: "ы", "\u0027": "ь", Ä: "Э", ä: "э",
|
||||
Ö: "Ё", ö: "ё", Ü: "Ю", ü: "ю", Q: "Я", q: "я"
|
||||
};
|
||||
var dic2 = {
|
||||
ЙЕ: "Э",
|
||||
Йе: "Э",
|
||||
йе: "э",
|
||||
ЙО: "Ё",
|
||||
Йо: "Ё",
|
||||
йо: "ё",
|
||||
ЫО: "Ё",
|
||||
Ыо: "Ё",
|
||||
ыо: "ё",
|
||||
ЙУ: "Ю",
|
||||
Йу: "Ю",
|
||||
йу: "ю",
|
||||
ЫУ: "Ю",
|
||||
Ыу: "Ю",
|
||||
ыу: "ю",
|
||||
ЙА: "Я",
|
||||
Йа: "Я",
|
||||
йа: "я",
|
||||
ЫА: "Я",
|
||||
Ыа: "Я",
|
||||
ыа: "я",
|
||||
ЦХ: "Ч",
|
||||
Цх: "Ч",
|
||||
цх: "ч",
|
||||
СХ: "Ш",
|
||||
Сх: "Ш",
|
||||
сх: "ш",
|
||||
ЗХ: "Ж",
|
||||
Зх: "Ж",
|
||||
зх: "ж",
|
||||
ШХ: "Щ",
|
||||
Шх: "Щ",
|
||||
шх: "щ",
|
||||
"ьь": "Ь",
|
||||
"ъъ": "Ъ"
|
||||
const dic2 = {
|
||||
ЙЕ: "Э", Йе: "Э", йе: "э",
|
||||
ЙО: "Ё", Йо: "Ё", йо: "ё", ЫО: "Ё", Ыо: "Ё", ыо: "ё",
|
||||
ЙУ: "Ю", Йу: "Ю", йу: "ю", ЫУ: "Ю", Ыу: "Ю", ыу: "ю",
|
||||
ЙА: "Я", Йа: "Я", йа: "я", ЫА: "Я", Ыа: "Я", ыа: "я",
|
||||
ЦХ: "Ч", Цх: "Ч", цх: "ч",
|
||||
СХ: "Ш", Сх: "Ш", сх: "ш",
|
||||
ЗХ: "Ж", Зх: "Ж", зх: "ж",
|
||||
ШХ: "Щ", Шх: "Щ", шх: "щ",
|
||||
"ьь": "Ь", "ъъ": "Ъ"
|
||||
};
|
||||
|
||||
var ctl = document.getElementById("transtxt");
|
||||
var str = ctl.value;
|
||||
var pos = ctl.selectionStart;
|
||||
const ctl = document.getElementById("transtxt");
|
||||
let str = ctl.value;
|
||||
const pos = ctl.selectionStart;
|
||||
|
||||
var tmp = str.slice(pos - 1, pos);
|
||||
let tmp = str.slice(pos - 1, pos);
|
||||
if (dic1.hasOwnProperty(tmp)) {
|
||||
tmp = dic1[tmp];
|
||||
str = str.replace(str.substring(pos - 1, pos), tmp);
|
||||
str = str.substring(0, pos - 1) + tmp + str.substring(pos);
|
||||
ctl.value = str;
|
||||
ctl.selectionEnd = pos;
|
||||
}
|
||||
|
@ -114,22 +44,18 @@ function translit() {
|
|||
tmp = str.slice(pos - 2, pos);
|
||||
if (dic2.hasOwnProperty(tmp)) {
|
||||
tmp = dic2[tmp];
|
||||
str = str.replace(str.substring(pos - 2, pos), tmp);
|
||||
str = str.substring(0, pos - 2) + tmp + str.substring(pos);
|
||||
ctl.value = str;
|
||||
ctl.selectionEnd = pos - 1;
|
||||
}
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
function copytxt() {
|
||||
var copyctl = document.getElementById("transtxt");
|
||||
const copyctl = document.getElementById("transtxt");
|
||||
copyctl.select();
|
||||
copyctl.setSelectionRange(0, copyctl.value.length);
|
||||
navigator.clipboard.writeText(copyctl.value)
|
||||
};
|
||||
navigator.clipboard.writeText(copyctl.value);
|
||||
}
|
||||
|
||||
function cleartxt() {
|
||||
var clearctl = document.getElementById("transtxt");
|
||||
clearctl.select();
|
||||
clearctl.value = "";
|
||||
};
|
||||
document.getElementById("transtxt").value = "";
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue