பயனர்:Keerthichandran/wiktAnywhere.js
Appearance
குறிப்பு - சேமித்த பின்னர், நீங்கள் செய்த மாற்றங்களைக் காண்பதற்கு உங்கள் உலவியின் இடைமாற்று அகற்றப்பட வேண்டும்.
- மொஸில்லா பயர்பாக்ஸ் / சபாரி: Shift+Reload, அல்லது Ctrl-F5 அல்லது Ctrl-R (⌘-R Mac ல்)
- கூகிள் குரோம் Ctrl-Shift-R அழுத்தவும். (⌘-Shift-R Mac ல்) ;
- இண்டர்நெட் எக்ஸ்ப்ளோரர்: Ctrl-Refresh அல்லது Ctrl-F5 ஐ அழுத்தவும்.
- ஒபேரா: Tools → Preferences இல் இடைமாற்றை அகற்றவும்;
var body_tag = document.getElementsByTagName("body")[0]
body_tag.setAttribute("onmouseup", "showMeaning()")
var DEFAULT_LANGUAGE = "en",
DEFAULT_TRIGGER_KEY = "none",
LANGUAGE,
TRIGGER_KEY;
function showMeaning() {
console.log("event", event);
var createdDiv,
info = getSelectionInfo(event);
if (!info) {
return;
}
console.log(event, info);
// retrieveMeaning(info)
var word = info.word;
var classes = event.tagName;
console.log({ classes });
url = `https://en.wikipedia.org/api/rest_v1/page/summary/${word}`;
let fetchRes = fetch(url, {
method: "GET",
});
console.log(fetchRes);
fetchRes
.then((response) => response.status === 200 && response.json())
.then((response) => {
console.log("res", response);
if (!response.extract) {
console.log("no found");
return noMeaningFound(createdDiv);
}
console.log("found word");
appendToDiv(createdDiv, { word: word, meaning: response.extract });
});
// Creating this div while we are fetching meaning to make extension more fast.
createdDiv = createDiv(info);
}
function getSelectionInfo(event) {
console.log("came selection info");
var word;
var boundingRect;
if (window.getSelection().toString().length > 1) {
word = window.getSelection().toString();
boundingRect = getSelectionCoords(window.getSelection());
} else {
return null;
}
var top = boundingRect.top + window.scrollY,
bottom = boundingRect.bottom + window.scrollY,
left = boundingRect.left + window.scrollX;
if (boundingRect.height == 0) {
top = event.pageY;
bottom = event.pageY;
left = event.pageX;
}
return {
top: top,
bottom: bottom,
left: left,
word: word,
clientY: event.clientY,
height: boundingRect.height,
};
}
// function retrieveMeaning(info){
// console.log(info)
// return browser.runtime.sendMessage({ word: info.word, lang: LANGUAGE, time: Date.now() });
// }
function createDiv(info) {
var hostDiv = document.createElement("div");
hostDiv.className = "dictionaryDiv";
hostDiv.style.left = info.left - 10 + "px";
hostDiv.style.position = "absolute";
hostDiv.style.zIndex = "1000";
hostDiv.attachShadow({ mode: "open" });
var shadow = hostDiv.shadowRoot;
var style = document.createElement("style");
style.textContent =
".mwe-popups{background:#fff;position:absolute;z-index:110;-webkit-box-shadow:0 30px 90px -20px rgba(0,0,0,0.3),0 0 1px #a2a9b1;box-shadow:0 30px 90px -20px rgba(0,0,0,0.3),0 0 1px #a2a9b1;padding:0;font-size:14px;min-width:300px;border-radius:2px}.mwe-popups.mwe-popups-is-not-tall{width:320px}.mwe-popups .mwe-popups-container{color:#222;margin-top:-9px;padding-top:9px;text-decoration:none}.mwe-popups.mwe-popups-is-not-tall .mwe-popups-extract{min-height:40px;max-height:140px;overflow:hidden;margin-bottom:47px;padding-bottom:0}.mwe-popups .mwe-popups-extract{margin:16px;display:block;color:#222;text-decoration:none;position:relative} .mwe-popups.flipped_y:before{content:'';position:absolute;border:8px solid transparent;border-bottom:0;border-top: 8px solid #a2a9b1;bottom:-8px;left:10px}.mwe-popups.flipped_y:after{content:'';position:absolute;border:11px solid transparent;border-bottom:0;border-top:11px solid #fff;bottom:-7px;left:7px} .mwe-popups.mwe-popups-no-image-tri:before{content:'';position:absolute;border:8px solid transparent;border-top:0;border-bottom: 8px solid #a2a9b1;top:-8px;left:10px}.mwe-popups.mwe-popups-no-image-tri:after{content:'';position:absolute;border:11px solid transparent;border-top:0;border-bottom:11px solid #fff;top:-7px;left:7px} .audio{background-image: url();background-position: center;background-repeat: no-repeat;cursor:pointer;margin-left: 8px;opacity: 0.5; width: 16px; display: inline-block;} .audio:hover {opacity: 1;}";
shadow.appendChild(style);
var encapsulateDiv = document.createElement("div");
encapsulateDiv.style =
"all: initial; text-shadow: transparent 0px 0px 0px, rgba(0,0,0,1) 0px 0px 0px !important;";
shadow.appendChild(encapsulateDiv);
var popupDiv = document.createElement("div");
popupDiv.style =
"font-family: arial,sans-serif; border-radius: 12px; border: 1px solid #a2a9b1; box-shadow: 0 0 17px rgba(0,0,0,0.5)";
encapsulateDiv.appendChild(popupDiv);
var contentContainer = document.createElement("div");
contentContainer.className = "mwe-popups-container";
popupDiv.appendChild(contentContainer);
var content = document.createElement("div");
content.className = "mwe-popups-extract";
content.style =
"line-height: 1.4; margin-top: 0px; margin-bottom: 11px; max-height: none";
contentContainer.appendChild(content);
var heading = document.createElement("h3");
heading.style = "margin-block-end: 0px; display:inline-block;";
heading.textContent = "Searching";
var meaning = document.createElement("p");
meaning.style = "margin-top: 10px";
meaning.textContent = "Please Wait...";
var audio = document.createElement("div");
audio.className = "audio";
audio.innerHTML = " ";
audio.style.display = "none";
var moreInfo = document.createElement("a");
console.log({ LANGUAGE });
moreInfo.href = ` https://en.wikipedia.org/wiki/${info.word}`;
moreInfo.style = "float: right; text-decoration: none;";
moreInfo.target = "_blank";
content.appendChild(heading);
content.appendChild(audio);
content.appendChild(meaning);
content.appendChild(moreInfo);
document.body.appendChild(hostDiv);
if (info.clientY < window.innerHeight / 2) {
popupDiv.className =
"mwe-popups mwe-popups-no-image-tri mwe-popups-is-not-tall";
hostDiv.style.top = info.bottom + 10 + "px";
if (info.height == 0) {
hostDiv.style.top = parseInt(hostDiv.style.top) + 8 + "px";
}
} else {
popupDiv.className = "mwe-popups flipped_y mwe-popups-is-not-tall";
hostDiv.style.top = info.top - 10 - popupDiv.clientHeight + "px";
if (info.height == 0) {
hostDiv.style.top = parseInt(hostDiv.style.top) - 8 + "px";
}
}
return {
heading,
meaning,
moreInfo,
audio,
};
}
function getSelectionCoords(selection) {
var oRange = selection.getRangeAt(0); //get the text range
var oRect = oRange.getBoundingClientRect();
return oRect;
}
function appendToDiv(createdDiv, content) {
console.log(content);
var hostDiv = createdDiv.heading.getRootNode().host;
var popupDiv = createdDiv.heading.getRootNode().querySelectorAll("div")[1];
var heightBefore = popupDiv.clientHeight;
createdDiv.heading.textContent = content.word;
createdDiv.meaning.textContent = content.meaning;
createdDiv.moreInfo.textContent = "For More Details >>";
var heightAfter = popupDiv.clientHeight;
var difference = heightAfter - heightBefore;
if (popupDiv.classList.contains("flipped_y")) {
hostDiv.style.top = parseInt(hostDiv.style.top) - difference + 1 + "px";
}
if (content.audioSrc) {
var sound = document.createElement("audio");
sound.src = content.audioSrc;
createdDiv.audio.style.display = "inline-block";
createdDiv.audio.addEventListener("click", function () {
sound.play();
});
}
}
function noMeaningFound(createdDiv) {
console.log("came no found");
createdDiv.heading.textContent = "Sorry";
createdDiv.meaning.textContent = "No definition found.";
}
function removeMeaning(event) {
var element = event.target;
if (!element.classList.contains("dictionaryDiv")) {
document.querySelectorAll(".dictionaryDiv").forEach(function (Node) {
Node.remove();
});
}
}
document.addEventListener("click", removeMeaning);