JSON structure

main
Amēlija I 2024-10-17 22:13:16 +03:00
parent d384a11e83
commit 3ac758d73b
1 changed files with 34 additions and 21 deletions

View File

@ -1,45 +1,64 @@
function createEventJSON(eventType, data) {
const timeStamp = new Date().toISOString();
return {
"@version": 1,
"type": `browserext.${eventType}`,
"TimeStamp": timeStamp,
"data": data,
"@timestamp": timeStamp
};
}
document.addEventListener( "keydown", (event) => {
const key = event.key;
const code = event.code;
let description;
if (key.match(/^\p{Number}$/u)) {
console.log(`Клавиша: number`);
description = "number";
}
else if (key.match(/^\p{Letter}$/u)) {
console.log(`Клавиша: letter`);
description = "letter";
}
else if (key.match(/^\p{Punctuation}$|^\p{Symbol}$/u)) {
console.log(`Клавиша: symbol`);
description = "symbol";
}
else {
console.log(`Клавиша: ${key} Код: ${code}`);
description = `Клавиша: ${key} Код: ${code}`;
}
const eventData = {description};
console.log(JSON.stringify(createEventJSON('keydown', eventData)));
});
document.addEventListener( "mousedown", (event) => {
console.log(`Клик мышью: ${event.button}`)
const eventData = { button: event.button, description: `Клик мышью: ${event.button}`};
console.log(JSON.stringify(createEventJSON('mousedown', eventData)));
});
document.addEventListener( "click", (event) => {
const clickedElement = event.target;
const tag = clickedElement.tagName;
const id = clickedElement.id ? clickedElement.id : "отсутствует";
const className = clickedElement.className ? clickedElement.className : "отсутствует";
const id = clickedElement.id || "отсутствует";
const className = clickedElement.className || "отсутствует";
let eventData;
if (tag === 'A') {
event.preventDefault();
const href = clickedElement.href;
eventData = { tag, id, className, href, description: "Клик по ссылке" };
localStorage.setItem('clickedElementInfo', `Тэг: ${tag}, ID: ${id}, Класс: ${className} Ссылка: ${href}`)
localStorage.setItem('clickedElementInfo', JSON.stringify(eventData));
console.log(JSON.stringify(createEventJSON('click', eventData)));
navigateWithPromise(href);
}
else if (tag === 'INPUT') {
const placeholder = clickedElement.placeholder ? clickedElement.placeholder : "отсутствует";
console.log(`Тэг: ${tag}, ID: ${id}, Класс: ${className}, Плейсхолдер: ${placeholder}`)
const placeholder = clickedElement.placeholder || "отсутствует";
eventData = { tag, id, className, placeholder, description: "Клик по полю ввода" };
console.log(JSON.stringify(createEventJSON('click', eventData)));
}
});
@ -73,16 +92,10 @@ document.addEventListener( "copy", (event) => {
const pageUrl = window.location.href;
const selectedText = window.getSelection().toString();
let outputText = selectedText.length > 50 ? selectedText.substring(0, 49) + '…' : selectedText;
if (selectedText.length > 0) {
let outputText;
if (selectedText.length > 50) {
outputText = selectedText.substring(0, 49) + '…';
} else {
outputText = selectedText;
}
console.log(`Скопирован текст: ${outputText}, Скопировано из: ${pageUrl}`)
const eventData = { selectedText: outputText, pageUrl, description: "Скопирован текст" };
console.log(JSON.stringify(createEventJSON('copy', eventData)));
}
});