Browse Source

Rewrote utils.js to TS

master
morethanwords 4 years ago
parent
commit
498ca4be9f
  1. 4
      src/components/emoticonsDropdown.ts
  2. 2
      src/lib/appManagers/appDialogsManager.ts
  3. 8
      src/lib/appManagers/appImManager.ts
  4. 10
      src/lib/appManagers/appMediaViewer.ts
  5. 171
      src/lib/utils.ts

4
src/components/emoticonsDropdown.ts

@ -817,7 +817,7 @@ class EmoticonsDropdown {
public static menuOnClick = (menu: HTMLUListElement, heights: number[], scroll: Scrollable, menuScroll?: Scrollable) => { public static menuOnClick = (menu: HTMLUListElement, heights: number[], scroll: Scrollable, menuScroll?: Scrollable) => {
menu.addEventListener('click', function(e) { menu.addEventListener('click', function(e) {
let target = e.target as HTMLLIElement; let target = e.target as HTMLElement;
target = findUpTag(target, 'LI'); target = findUpTag(target, 'LI');
if(!target) { if(!target) {
@ -880,7 +880,7 @@ class EmoticonsDropdown {
}; };
public static onMediaClick = (e: MouseEvent) => { public static onMediaClick = (e: MouseEvent) => {
let target = e.target as HTMLDivElement; let target = e.target as HTMLElement;
target = findUpTag(target, 'DIV'); target = findUpTag(target, 'DIV');
if(!target) return; if(!target) return;

2
src/lib/appManagers/appDialogsManager.ts

@ -169,7 +169,7 @@ class DialogsContextMenu {
} }
onContextMenu = (e: MouseEvent | Touch) => { onContextMenu = (e: MouseEvent | Touch) => {
let li: HTMLDivElement = null; let li: HTMLElement = null;
try { try {
li = findUpTag(e.target, 'LI'); li = findUpTag(e.target, 'LI');

8
src/lib/appManagers/appImManager.ts

@ -62,7 +62,7 @@ class ChatContextMenu {
parseMenuButtonsTo(this.buttons, this.element.children); parseMenuButtonsTo(this.buttons, this.element.children);
attachContextMenuListener(attachTo, (e) => { attachContextMenuListener(attachTo, (e) => {
let bubble: HTMLDivElement = null; let bubble: HTMLElement = null;
try { try {
bubble = findUpClassName(e.target, 'bubble__container'); bubble = findUpClassName(e.target, 'bubble__container');
@ -784,7 +784,7 @@ export class AppImManager {
}); });
this.topbar.addEventListener('click', (e) => { this.topbar.addEventListener('click', (e) => {
const pinned = findUpClassName(e.target, 'pinned-container'); const pinned: HTMLElement = findUpClassName(e.target, 'pinned-container');
if(pinned) { if(pinned) {
cancelEvent(e); cancelEvent(e);
@ -799,7 +799,7 @@ export class AppImManager {
this.bubblesContainer.addEventListener('click', (e) => { this.bubblesContainer.addEventListener('click', (e) => {
let target = e.target as HTMLElement; let target = e.target as HTMLElement;
let bubble: HTMLDivElement = null; let bubble: HTMLElement = null;
try { try {
bubble = findUpClassName(target, 'bubble'); bubble = findUpClassName(target, 'bubble');
} catch(err) {} } catch(err) {}
@ -822,7 +822,7 @@ export class AppImManager {
return; return;
} }
let contactDiv = findUpClassName(target, 'contact'); let contactDiv: HTMLElement = findUpClassName(target, 'contact');
if(contactDiv) { if(contactDiv) {
this.setPeer(+contactDiv.dataset.peerID); this.setPeer(+contactDiv.dataset.peerID);
return; return;

10
src/lib/appManagers/appMediaViewer.ts

@ -164,7 +164,7 @@ export class AppMediaViewer {
if(target.tagName == 'A') return; if(target.tagName == 'A') return;
cancelEvent(e); cancelEvent(e);
let mover: HTMLDivElement = null; let mover: HTMLElement = null;
['media-viewer-mover', 'media-viewer-buttons', 'media-viewer-author'].find(s => { ['media-viewer-mover', 'media-viewer-buttons', 'media-viewer-author'].find(s => {
try { try {
mover = findUpClassName(target, s); mover = findUpClassName(target, s);
@ -213,7 +213,7 @@ export class AppMediaViewer {
this.log('setMoverToTarget', target, closing, wasActive, fromRight); this.log('setMoverToTarget', target, closing, wasActive, fromRight);
let realParent: HTMLDivElement; let realParent: HTMLElement;
let rect: DOMRect; let rect: DOMRect;
if(target) { if(target) {
@ -221,7 +221,7 @@ export class AppMediaViewer {
realParent = findUpClassName(target, 'attachment'); realParent = findUpClassName(target, 'attachment');
rect = realParent.getBoundingClientRect(); rect = realParent.getBoundingClientRect();
} else { } else {
realParent = target.parentElement as HTMLDivElement; realParent = target.parentElement as HTMLElement;
rect = target.getBoundingClientRect(); rect = target.getBoundingClientRect();
} }
} }
@ -358,7 +358,7 @@ export class AppMediaViewer {
// код ниже нужен только чтобы скрыть моргание до момента как сработает таймаут // код ниже нужен только чтобы скрыть моргание до момента как сработает таймаут
let d: string; let d: string;
let br = borderRadius.split(' ').map(v => parseInt(v)); let br: [number, number, number, number] = borderRadius.split(' ').map(v => parseInt(v)) as any;
if(isOut) d = generatePathData(0, 0, width - 9 / scaleX, height, ...br); if(isOut) d = generatePathData(0, 0, width - 9 / scaleX, height, ...br);
else d = generatePathData(9 / scaleX, 0, width - 9 / scaleX, height, ...br); else d = generatePathData(9 / scaleX, 0, width - 9 / scaleX, height, ...br);
path.setAttributeNS(null, 'd', d); path.setAttributeNS(null, 'd', d);
@ -515,7 +515,7 @@ export class AppMediaViewer {
if(progress > 1) progress = 1; if(progress > 1) progress = 1;
if(upscale) progress = 1 - progress; if(upscale) progress = 1 - progress;
let _br = br.map(v => v * progress); let _br: [number, number, number, number] = br.map(v => v * progress) as any;
let d: string; let d: string;
if(isOut) d = generatePathData(0, 0, width - (9 / scaleX * progress), height, ..._br); if(isOut) d = generatePathData(0, 0, width - (9 / scaleX * progress), height, ..._br);

171
src/lib/utils.js → src/lib/utils.ts

@ -9,7 +9,7 @@ export function dT () {
return '[' + ((Date.now() - _logTimer) / 1000).toFixed(3) + ']'; return '[' + ((Date.now() - _logTimer) / 1000).toFixed(3) + ']';
} }
export function isInDOM(element, parentNode) { export function isInDOM(element: Element, parentNode?: HTMLElement): boolean {
if(!element) { if(!element) {
return false; return false;
} }
@ -18,27 +18,28 @@ export function isInDOM(element, parentNode) {
if(element == parentNode) { if(element == parentNode) {
return true; return true;
} }
return isInDOM(element.parentNode, parentNode); return isInDOM(element.parentNode as HTMLElement, parentNode);
} }
export function checkDragEvent(e) { export function checkDragEvent(e: any) {
if(!e || e.target && (e.target.tagName == 'IMG' || e.target.tagName == 'A')) return false if(!e || e.target && (e.target.tagName == 'IMG' || e.target.tagName == 'A')) return false
if(e.dataTransfer && e.dataTransfer.types) { if(e.dataTransfer && e.dataTransfer.types) {
for(var i = 0; i < e.dataTransfer.types.length; i++) { for(var i = 0; i < e.dataTransfer.types.length; i++) {
if(e.dataTransfer.types[i] == 'Files') { if(e.dataTransfer.types[i] == 'Files') {
return true return true;
} }
} }
} else { } else {
return true return true;
} }
return false return false;
} }
export function cancelEvent (event) { export function cancelEvent (event: Event) {
event = event || window.event; event = event || window.event;
if(event) { if(event) {
// @ts-ignore
event = event.originalEvent || event; event = event.originalEvent || event;
try { try {
@ -52,35 +53,36 @@ export function cancelEvent (event) {
return false; return false;
} }
export function getRichValue (field) { export function getRichValue(field: any) {
if(!field) { if(!field) {
return '' return '';
} }
var lines = [] var lines: string[] = [];
var line = [] var line: string[] = [];
getRichElementValue(field, lines, line) getRichElementValue(field, lines, line);
if (line.length) { if (line.length) {
lines.push(line.join('')) lines.push(line.join(''));
} }
var value = lines.join('\n') var value = lines.join('\n');
value = value.replace(/\u00A0/g, ' ') value = value.replace(/\u00A0/g, ' ');
return value return value;
} }
export function placeCaretAtEnd(el) { export function placeCaretAtEnd(el: HTMLElement) {
el.focus(); el.focus();
if (typeof window.getSelection != "undefined" if(typeof window.getSelection != "undefined" && typeof document.createRange != "undefined") {
&& typeof document.createRange != "undefined") {
var range = document.createRange(); var range = document.createRange();
range.selectNodeContents(el); range.selectNodeContents(el);
range.collapse(false); range.collapse(false);
var sel = window.getSelection(); var sel = window.getSelection();
sel.removeAllRanges(); sel.removeAllRanges();
sel.addRange(range); sel.addRange(range);
// @ts-ignore
} else if(typeof document.body.createTextRange != "undefined") { } else if(typeof document.body.createTextRange != "undefined") {
// @ts-ignore
var textRange = document.body.createTextRange(); var textRange = document.body.createTextRange();
textRange.moveToElementText(el); textRange.moveToElementText(el);
textRange.collapse(false); textRange.collapse(false);
@ -88,7 +90,7 @@ export function placeCaretAtEnd(el) {
} }
} }
export function getRichElementValue (node, lines, line, selNode, selOffset) { export function getRichElementValue(node: any, lines: string[], line: string[], selNode?: Node, selOffset?: number) {
if(node.nodeType == 3) { // TEXT if(node.nodeType == 3) { // TEXT
if(selNode === node) { if(selNode === node) {
var value = node.nodeValue var value = node.nodeValue
@ -107,26 +109,29 @@ export function getRichElementValue (node, lines, line, selNode, selOffset) {
if(isBlock && line.length || node.tagName == 'BR') { if(isBlock && line.length || node.tagName == 'BR') {
lines.push(line.join('')) lines.push(line.join(''))
line.splice(0, line.length) line.splice(0, line.length)
} } else if(node.tagName == 'IMG') {
else if (node.tagName == 'IMG') {
if(node.alt) { if(node.alt) {
line.push(node.alt) line.push(node.alt);
} }
} }
if(isSelected && !selOffset) { if(isSelected && !selOffset) {
line.push('\x01') line.push('\x01');
} }
var curChild = node.firstChild
var curChild = node.firstChild;
while(curChild) { while(curChild) {
getRichElementValue(curChild, lines, line, selNode, selOffset) getRichElementValue(curChild, lines, line, selNode, selOffset);
curChild = curChild.nextSibling curChild = curChild.nextSibling;
} }
if(isSelected && selOffset) { if(isSelected && selOffset) {
line.push('\x01') line.push('\x01');
} }
if(isBlock && line.length) { if(isBlock && line.length) {
lines.push(line.join('')) lines.push(line.join(''));
line.splice(0, line.length) line.splice(0, line.length);
} }
} }
@ -144,7 +149,7 @@ export function getRichElementValue (node, lines, line, selNode, selOffset) {
} */ } */
export const $rootScope = { export const $rootScope = {
$broadcast: (name/* : string */, detail/*? : any */) => { $broadcast: (name: string, detail?: any) => {
if(name != 'user_update') { if(name != 'user_update') {
console.debug(dT(), 'Broadcasting ' + name + ' event, with args:', detail); console.debug(dT(), 'Broadcasting ' + name + ' event, with args:', detail);
} }
@ -152,7 +157,7 @@ export const $rootScope = {
let myCustomEvent = new CustomEvent(name, {detail}); let myCustomEvent = new CustomEvent(name, {detail});
document.dispatchEvent(myCustomEvent); document.dispatchEvent(myCustomEvent);
}, },
$on: (name/* : string */, callback/* : any */) => { $on: (name: string, callback: any) => {
document.addEventListener(name, callback); document.addEventListener(name, callback);
}, },
@ -165,7 +170,7 @@ export const $rootScope = {
// generate a path's arc data parameter // generate a path's arc data parameter
// http://www.w3.org/TR/SVG/paths.html#PathDataEllipticalArcCommands // http://www.w3.org/TR/SVG/paths.html#PathDataEllipticalArcCommands
var arcParameter = function(rx, ry, xAxisRotation, largeArcFlag, sweepFlag, x, y) { var arcParameter = function(rx: number, ry: number, xAxisRotation: number, largeArcFlag: number, sweepFlag: number, x: number, y: number) {
return [rx, ',', ry, ' ', return [rx, ',', ry, ' ',
xAxisRotation, ' ', xAxisRotation, ' ',
largeArcFlag, ',', largeArcFlag, ',',
@ -173,7 +178,7 @@ var arcParameter = function(rx, ry, xAxisRotation, largeArcFlag, sweepFlag, x, y
x, ',', y ].join(''); x, ',', y ].join('');
}; };
export function generatePathData( x, y, width, height, tl, tr, br, bl ) { export function generatePathData(x: number, y: number, width: number, height: number, tl: number, tr: number, br: number, bl: number) {
var data = []; var data = [];
// start point in top-middle of the rectangle // start point in top-middle of the rectangle
@ -243,41 +248,37 @@ export const langPack = {
"messageActionPhoneCall.out_missed": "Cancelled Call", "messageActionPhoneCall.out_missed": "Cancelled Call",
}; };
export const _ = (str/* : string */) => { export function isObject(object: any) {
str = str.replace('_raw', '');
return langPack[str] ? langPack[str] : str;
};
export function isObject(object) {
return typeof(object) === 'object' && object !== null; return typeof(object) === 'object' && object !== null;
} }
export function tsNow (seconds) { export function tsNow(seconds?: boolean) {
var t = +new Date(); var t = +new Date();
return seconds ? Math.floor(t / 1000) : t; return seconds ? Math.floor(t / 1000) : t;
} }
export function safeReplaceObject (wasObject, newObject) { export function safeReplaceObject(wasObject: any, newObject: any) {
for(var key in wasObject) { for(var key in wasObject) {
if(!newObject.hasOwnProperty(key) && key.charAt(0) != '$') { if(!newObject.hasOwnProperty(key) && key.charAt(0) != '$') {
delete wasObject[key] delete wasObject[key];
} }
} }
for(var key in newObject) { for(var key in newObject) {
//if (newObject.hasOwnProperty(key)) { // useless //if (newObject.hasOwnProperty(key)) { // useless
wasObject[key] = newObject[key] wasObject[key] = newObject[key];
//} //}
} }
} }
export function numberWithCommas(x) { export function numberWithCommas(x: number) {
var parts = x.toString().split("."); var parts = x.toString().split(".");
parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ","); parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ",");
return parts.join("."); return parts.join(".");
} }
export function findUpClassName(el, className) { //export function findUpClassName<T>(el: any, className: string): T;
export function findUpClassName(el: any, className: string): HTMLElement {
if(el.classList.contains(className)) return el; // 03.02.2020 if(el.classList.contains(className)) return el; // 03.02.2020
while(el.parentElement) { while(el.parentElement) {
@ -288,7 +289,7 @@ export function findUpClassName(el, className) {
return null; return null;
} }
export function findUpTag(el, tag) { export function findUpTag(el: any, tag: string): HTMLElement {
if(el.tagName == tag) return el; // 03.02.2020 if(el.tagName == tag) return el; // 03.02.2020
while(el.parentElement) { while(el.parentElement) {
@ -299,7 +300,7 @@ export function findUpTag(el, tag) {
return null; return null;
} }
export function findUpAttribute(el, attribute) { export function findUpAttribute(el: any, attribute: string): HTMLElement {
if(el.getAttribute(attribute) != null) return el; // 03.02.2020 if(el.getAttribute(attribute) != null) return el; // 03.02.2020
while(el.parentElement) { while(el.parentElement) {
@ -310,14 +311,14 @@ export function findUpAttribute(el, attribute) {
return null; return null;
} }
export function whichChild(elem/* : Node */) { export function whichChild(elem: Node) {
let i = 0; let i = 0;
// @ts-ignore // @ts-ignore
while((elem = elem.previousElementSibling) != null) ++i; while((elem = elem.previousElementSibling) != null) ++i;
return i; return i;
}; };
export function copy(obj) { export function copy(obj: any) {
//in case of premitives //in case of premitives
if(obj===null || typeof obj !== "object"){ if(obj===null || typeof obj !== "object"){
return obj; return obj;
@ -330,7 +331,7 @@ export function copy(obj) {
//handle Array //handle Array
if(Array.isArray(obj)){ if(Array.isArray(obj)){
var clonedArr = []; var clonedArr: any = [];
obj.forEach(function(element){ obj.forEach(function(element){
clonedArr.push(copy(element)) clonedArr.push(copy(element))
}); });
@ -347,7 +348,7 @@ export function copy(obj) {
return clonedObj; return clonedObj;
} }
export function formatBytes(bytes, decimals = 2) { export function formatBytes(bytes: number, decimals = 2) {
if (bytes === 0) return '0 Bytes'; if (bytes === 0) return '0 Bytes';
const k = 1024; const k = 1024;
@ -359,7 +360,7 @@ export function formatBytes(bytes, decimals = 2) {
return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + ' ' + sizes[i]; return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + ' ' + sizes[i];
} }
export function formatNumber(bytes, decimals = 2) { export function formatNumber(bytes: number, decimals = 2) {
if(bytes === 0) return '0'; if(bytes === 0) return '0';
const k = 1000; const k = 1000;
@ -371,7 +372,7 @@ export function formatNumber(bytes, decimals = 2) {
return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + sizes[i]; return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + sizes[i];
} }
export function deepEqual(x, y) { export function deepEqual(x: any, y: any): boolean {
const ok = Object.keys, tx = typeof x, ty = typeof y; const ok = Object.keys, tx = typeof x, ty = typeof y;
return x && y && tx === 'object' && tx === ty ? ( return x && y && tx === 'object' && tx === ty ? (
ok(x).length === ok(y).length && ok(x).length === ok(y).length &&
@ -379,40 +380,40 @@ export function deepEqual(x, y) {
) : (x === y); ) : (x === y);
} }
export function listMergeSorted (list1, list2) { export function listMergeSorted(list1: any, list2: any) {
list1 = list1 || [] list1 = list1 || [];
list2 = list2 || [] list2 = list2 || [];
var result = copy(list1); var result = copy(list1);
var minID = list1.length ? list1[list1.length - 1] : 0xFFFFFFFF var minID = list1.length ? list1[list1.length - 1] : 0xFFFFFFFF;
for (var i = 0; i < list2.length; i++) { for (var i = 0; i < list2.length; i++) {
if (list2[i] < minID) { if (list2[i] < minID) {
result.push(list2[i]) result.push(list2[i]);
} }
} }
return result return result;
} }
// credits to https://github.com/sindresorhus/escape-string-regexp/blob/master/index.js // credits to https://github.com/sindresorhus/escape-string-regexp/blob/master/index.js
export function escapeRegExp(str) { export function escapeRegExp(str: string) {
return str return str
.replace(/[|\\{}()[\]^$+*?.]/g, '\\$&') .replace(/[|\\{}()[\]^$+*?.]/g, '\\$&')
.replace(/-/g, '\\x2d'); .replace(/-/g, '\\x2d');
} }
export function encodeEntities (value) { export function encodeEntities(value: string) {
return value.replace(/&/g, '&amp;').replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g, function (value) { return value.replace(/&/g, '&amp;').replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g, (value) => {
var hi = value.charCodeAt(0) var hi = value.charCodeAt(0);
var low = value.charCodeAt(1) var low = value.charCodeAt(1);
return '&#' + (((hi - 0xD800) * 0x400) + (low - 0xDC00) + 0x10000) + ';' return '&#' + (((hi - 0xD800) * 0x400) + (low - 0xDC00) + 0x10000) + ';';
}).replace(/([^\#-~| |!])/g, function (value) { // non-alphanumeric }).replace(/([^\#-~| |!])/g, (value) => { // non-alphanumeric
return '&#' + value.charCodeAt(0) + ';' return '&#' + value.charCodeAt(0) + ';';
}).replace(/</g, '&lt;').replace(/>/g, '&gt;') }).replace(/</g, '&lt;').replace(/>/g, '&gt;');
} }
export function fillPropertyValue(str) { export function fillPropertyValue(str: string) {
let splitted = str.split(' '); let splitted = str.split(' ');
if(splitted.length != 4) { if(splitted.length != 4) {
if(!splitted[0]) splitted[0] = '0px'; if(!splitted[0]) splitted[0] = '0px';
@ -424,21 +425,21 @@ export function fillPropertyValue(str) {
return splitted; return splitted;
} }
export function calcImageInBox (imageW, imageH, boxW, boxH, noZooom) { export function calcImageInBox (imageW: number, imageH: number, boxW: number, boxH: number, noZoom?: boolean) {
if(imageW < boxW && imageH < boxH) { if(imageW < boxW && imageH < boxH) {
return {w: imageW, h: imageH}; return {w: imageW, h: imageH};
} }
var boxedImageW = boxW var boxedImageW = boxW;
var boxedImageH = boxH var boxedImageH = boxH;
if((imageW / imageH) > (boxW / boxH)) { if((imageW / imageH) > (boxW / boxH)) {
boxedImageH = parseInt(imageH * boxW / imageW) boxedImageH = (imageH * boxW / imageW) | 0;
} else { } else {
boxedImageW = parseInt(imageW * boxH / imageH) boxedImageW = (imageW * boxH / imageH) | 0;
if(boxedImageW > boxW) { if(boxedImageW > boxW) {
boxedImageH = parseInt(boxedImageH * boxW / boxedImageW) boxedImageH = (boxedImageH * boxW / boxedImageW) | 0;
boxedImageW = boxW boxedImageW = boxW;
} }
} }
@ -447,12 +448,12 @@ export function calcImageInBox (imageW, imageH, boxW, boxH, noZooom) {
// imageH = Math.floor(imageH / 2) // imageH = Math.floor(imageH / 2)
// } // }
if(noZooom && boxedImageW >= imageW && boxedImageH >= imageH) { if(noZoom && boxedImageW >= imageW && boxedImageH >= imageH) {
boxedImageW = imageW boxedImageW = imageW;
boxedImageH = imageH boxedImageH = imageH;
} }
return {w: boxedImageW, h: boxedImageH} return {w: boxedImageW, h: boxedImageH};
} }
/** /**
@ -464,7 +465,7 @@ export function calcImageInBox (imageW, imageH, boxW, boxH, noZooom) {
* @param {String} input The emoji character. * @param {String} input The emoji character.
* @returns {String} The base 16 unicode code. * @returns {String} The base 16 unicode code.
*/ */
export function emojiUnicode(input) { export function emojiUnicode(input: string) {
let pairs = emojiUnicode.raw(input).split(' ').map(val => parseInt(val).toString(16))/* .filter(p => p != 'fe0f') */; let pairs = emojiUnicode.raw(input).split(' ').map(val => parseInt(val).toString(16))/* .filter(p => p != 'fe0f') */;
if(pairs.length && pairs[0].length == 2) pairs[0] = '00' + pairs[0]; if(pairs.length && pairs[0].length == 2) pairs[0] = '00' + pairs[0];
return pairs.join('-'); return pairs.join('-');
@ -479,7 +480,7 @@ export function emojiUnicode(input) {
* @param {String} input The emoji character. * @param {String} input The emoji character.
* @returns {String} The unicode code points. * @returns {String} The unicode code points.
*/ */
emojiUnicode.raw = function(input) { emojiUnicode.raw = function(input: string) {
if(input.length === 1) { if(input.length === 1) {
return input.charCodeAt(0).toString(); return input.charCodeAt(0).toString();
} else if(input.length > 1) { } else if(input.length > 1) {
@ -506,7 +507,7 @@ emojiUnicode.raw = function(input) {
return ''; return '';
}; };
export function getEmojiToneIndex(input) { export function getEmojiToneIndex(input: string) {
let match = input.match(/[\uDFFB-\uDFFF]/); let match = input.match(/[\uDFFB-\uDFFF]/);
return match ? 5 - (57343 - match[0].charCodeAt(0)) : 0; return match ? 5 - (57343 - match[0].charCodeAt(0)) : 0;
} }
Loading…
Cancel
Save