// ==UserScript==
// @name Edge-nuity Megascript
// @version 2.3
// @description Completes through instructional, summary, and warm-up sections by guessing answers (they don’t impact grades). You can begin activities while the instructor is speaking, when theres an activity, a "Search clipboard" button appears for quick access to answers during quizzes (will search your copied text on brainly and auto-redirect) And much more (read desc).
// @author TTT
// @license MIT
// @include *://*nuity.com*/*
// @include https://brainly.com/*
// @grant none
// @namespace https://www.tampermonkey.net/
// ==/UserScript==
function redirectToStudent() {
const currentHref = window.location.href;
const newHref = currentHref.replace("core.learn", "student");
window.location.href = newHref;
}
if (window.location.href.includes("core.learn") && window.location.href.includes("/EdgeAuth/lti/goodbye")) {
setInterval(redirectToStudent, 1000);
}
function clickVisibleElementWithClass() {
const elements = document.getElementsByClassName('btn btn-primary modal-dialog-button');
for (let i = 0; i < elements.length; i++) {
const targetElement = elements[i];
const computedStyle = window.getComputedStyle(targetElement);
const boundingRect = targetElement.getBoundingClientRect();
const isVisible =
computedStyle.opacity !== '0' &&
computedStyle.visibility !== 'hidden' &&
computedStyle.display !== 'none' &&
boundingRect.width > 0 &&
boundingRect.height > 0;
if (isVisible) {
const simulatedClickEvent = new MouseEvent('click', {
view: window,
bubbles: true,
cancelable: true
});
targetElement.dispatchEvent(simulatedClickEvent);
console.log('Clicked a visible button!');
addBeforeUnloadListener();
break;
}
}
}
setInterval(clickVisibleElementWithClass, 1000);
const checkElementVisibility = (element) => {
const boundingRect = element.getBoundingClientRect();
const computedStyle = window.getComputedStyle(element);
return (
computedStyle.opacity !== '0' &&
computedStyle.visibility !== 'hidden' &&
computedStyle.display !== 'none' &&
boundingRect.width > 0 &&
boundingRect.height > 0
);
};
const checkForTimerStayElement = () => {
const targetElement = document.getElementById('timerStay');
if (targetElement && checkElementVisibility(targetElement)) {
const simulatedClickEvent = new MouseEvent('click', {
view: window,
bubbles: true,
cancelable: true
});
targetElement.dispatchEvent(simulatedClickEvent);
console.log('Clicked timerStay element!');
addBeforeUnloadListener();
}
};
if (window.top === window.self) {
const intervalId = setInterval(checkForTimerStayElement, 100);
}
const addBeforeUnloadListener = () => {
window.onbeforeunload = function (event) {
const message = 'Are you sure you want to leave this page?';
event.returnValue = message;
return message;
};
};
let videoElement = null;
let alertTriggered = false;
let alertScheduled = false;
const callback = function(mutationsList, observer) {
for (const mutation of mutationsList) {
if (mutation.type === 'childList') {
videoElement = document.getElementById("home_video_js");
if (videoElement) {
startCheckingVideo();
observer.disconnect();
}
}
}
};
const config = {
attributes: false,
childList: true,
subtree: true
};
const targetNode = document.body;
const observer = new MutationObserver(callback);
observer.observe(targetNode, config);
function insertDiv() {
let logoImage = document.querySelector('img.course-logo-bug[src="/images/logobug-edge-ex.png"][alt="Edge EX"]');
if (logoImage && !document.getElementById('testDiv')) {
const testDiv = document.createElement('div');
testDiv.id = 'testDiv';
testDiv.style.fontFamily = 'Atkinson Hyperlegible';
testDiv.style.color = 'black';
testDiv.style.margin = '10px';
testDiv.style.width = 'calc(100% - 20px)';
testDiv.style.maxWidth = '999px';
testDiv.style.marginLeft = 'auto';
testDiv.style.marginRight = 'auto';
testDiv.style.position = 'fixed';
testDiv.style.top = '50%';
testDiv.style.left = '50%';
testDiv.style.transform = 'translate(-50%, -50%)';
testDiv.style.backgroundColor = 'aqua';
testDiv.style.padding = '10px';
testDiv.style.borderRadius = '5px';
testDiv.style.zIndex = '2147483647';
const firstItemContainer = document.createElement('div');
const textSpan = document.createElement('span');
textSpan.style.display = 'inline';
textSpan.textContent = "Sadly, the script you downloaded (Edge-nuity Megascript) Does not support Edge-x classes, which you have one or more of. (Each marked by):";
firstItemContainer.appendChild(textSpan);
const imageContainer = document.createElement('span');
imageContainer.style.display = 'inline';
imageContainer.style.marginLeft = '10px';
const imgElement1 = document.createElement('img');
imgElement1.src = '';
imgElement1.alt = 'Embedded Image';
imgElement1.style.maxHeight = '50px';
imageContainer.appendChild(imgElement1);
firstItemContainer.appendChild(imageContainer);
testDiv.appendChild(firstItemContainer);
const additionalInfoDiv = document.createElement('div');
additionalInfoDiv.style.marginTop = '10px';
additionalInfoDiv.textContent = "However, I'm gonna work on adding it as soon as possible, join ";
const link = document.createElement('a');
link.href = "https://discord.gg/6qJwkYSmrQ";
link.target = "_blank";
link.style.color = 'blue';
link.style.textDecoration = 'underline';
link.textContent = "HERE";
additionalInfoDiv.appendChild(link);
additionalInfoDiv.append(" and ping me \"@TallTacoTristan\" in any chat if you want to volunteer your own class, which I will complete for you in return.");
testDiv.appendChild(additionalInfoDiv);
const line3Div = document.createElement('div');
line3Div.style.marginTop = '10px';
line3Div.textContent = "If not, simply note: only normal classes are supported, any normal class is marked by:";
const imageContainer2 = document.createElement('span');
imageContainer2.style.display = 'inline';
imageContainer2.style.marginLeft = '10px';
const imgElement2 = document.createElement('img');
imgElement2.src = '';
imgElement2.alt = 'Courseware Image';
imgElement2.style.maxHeight = '50px';
imageContainer2.appendChild(imgElement2);
line3Div.appendChild(imageContainer2);
testDiv.appendChild(line3Div);
document.body.appendChild(testDiv);
}
}
setInterval(function () {
if (window.location.href.includes("student.") && window.location.href.includes(".com/")) {
insertDiv();
}
}, 1000);
function startCheckingVideo() {
setInterval(() => {
if (videoElement) {
const currentTime = videoElement.currentTime;
const duration = videoElement.duration;
if (currentTime >= duration) {
if (!alertScheduled) {
alertScheduled = true;
let checksCount = 0;
let allChecksPassed = true;
const intervalId = setInterval(() => {
const homeVideoContainer = document.getElementById("home_video_container");
if (homeVideoContainer && homeVideoContainer.parentNode.style.opacity == 1) {
checksCount++;
} else {
allChecksPassed = false;
}
if (checksCount === 10) {
clearInterval(intervalId);
if (allChecksPassed) {
new Notification("Reload!");
alertTriggered = true;
}
alertScheduled = false;
}
}, 100);
}
} else {
alertTriggered = false;
}
}
}, 550);
}
(function() {
'use strict';
let completeCount = 0;
const originalConsoleLog = console.log;
console.log = function() {
const message = Array.from(arguments).join(' ');
if (message.includes('complete')) {
completeCount++;
if (completeCount === 2) {
const goRightButton = document.querySelector('li.FrameRight a');
if (goRightButton) {
goRightButton.click();
completeCount = 0;
}
}
}
originalConsoleLog.apply(console, arguments);
};
})();
function checkAutoplay() {
const autoplayCheckbox = document.getElementById('autoplayCheckbox');
// Check if the checkbox exists before accessing its properties
if (autoplayCheckbox && autoplayCheckbox.checked) {
playVideo();
}
}
if (window.top === window.self && window.location.href.includes('core.learn')) {
setInterval(checkAutoplay, 1000);
}
function playVideo() {
var playButton = window.frames[0].document.getElementById("uid1_play");
if (playButton != undefined) {
setTimeout(function() {
if (playButton.className == "play") {
playButton.children[0].click();
}
}, 1000);
}
}
function showColumn() {
try {
window.frames[0].frames[0].document.getElementsByClassName("right-column")[0].children[0].style.display = "block";
} catch (TypeError) {}
try {
window.frames[0].frames[0].document.getElementsByClassName("left-column")[0].children[0].style.display = "block";
} catch (TypeError) {}
}
if (window.top === window.self) {
setInterval(showColumn, 1000);}
function clearLocalStorage() {
try {
localStorage.clear();
} catch (error) {}
}
function removeElementsByClassName(className) {
var elements = document.getElementsByClassName(className);
Array.prototype.forEach.call(elements, function(element) {
try {
element.parentNode.removeChild(element);
} catch (error) {}
});
}
function handleOnload() {
var classNamesToRemove = [
"brn-expanded-bottom-banner",
"brn-brainly-plus-box",
"brn-fullscreen-toplayer",
"sg-overlay sg-overlay--dark"
];
classNamesToRemove.forEach(function(className) {
removeElementsByClassName(className);
});
}
if (window.location.href.includes("brainly.com")) {
clearLocalStorage();
handleOnload();
}
function redirectToFirstSearchItem() {
if (window.location.href.startsWith('https://brainly.com/app/ask')) {
const searchItem = document.querySelector('[data-testid="search-item-facade-wrapper"]');
if (searchItem) {
const anchorElement = searchItem.querySelector('a');
if (anchorElement) {
const href = anchorElement.getAttribute('href');
const fullUrl = `https://brainly.com${href}`;
window.location.href = fullUrl;
clearInterval(interval);
}
}
}
}
const interval = setInterval(redirectToFirstSearchItem, 1000);
function checkElement() {
const element = document.querySelector('[data-testid="answer_box"][data-test="locked_answer"]');
if (element && document.location.href.includes("brainly.com/question")) {
location.reload();
}
}if (window.top === window.self) {
setInterval(checkElement, 750);}
function extractTextFromIframe() {
var iframeDocument = window.frames[0].document;
var targetElements = iframeDocument.getElementsByClassName("Assessment_Main_Body_Content_Question");
var visibleElements = Array.from(targetElements).filter(function(element) {
return element.style.display !== "none" && element.id.includes("q_");
});
if (visibleElements.length > 0) {
var finalTextOutput = [];
var regex = />([^<]+)</g;
var regexSpecial = /»([^«]+)«/g;
var regexCleanUp = /[\n\r]+|<[^>]*>| | /g;
visibleElements.forEach(function(targetElement) {
var elementText = "";
let matches;
while ((matches = regex.exec(targetElement.innerHTML)) !== null) {
var extractedText = matches[1].trim();
if (extractedText && !/(class|src|align|style)=/i.test(extractedText)) {
elementText += extractedText + " ";
}
}
while ((matches = regexSpecial.exec(targetElement.innerHTML)) !== null) {
var extractedText = matches[1].trim();
if (extractedText && !/(class|src|align|style)=/i.test(extractedText)) {
elementText += extractedText + " ";
}
}
var imgElements = targetElement.getElementsByTagName("img");
Array.from(imgElements).forEach(function(img) {
if (img.alt) {
elementText += img.alt.trim() + " ";
}
});
elementText = elementText.replace(regexCleanUp, ' ').trim();
elementText = elementText.replace(/\u00A0/g, ' ');
if (elementText) {
finalTextOutput.push(elementText);
}
});
// Using the Clipboard API to copy text
const textToCopy = finalTextOutput.join("\n").replace(/\s+/g, ' ');
navigator.clipboard.writeText(textToCopy)
.then(() => {
console.log('Text copied to clipboard');
// Optional: Trigger the search clipboard button if it exists
setTimeout(function() {
var buttons = Array.from(document.getElementsByTagName('button'));
var searchClipboardButton = buttons.find(button => button.innerText === "Search Clipboard");
if (searchClipboardButton) {
searchClipboardButton.click();
} else {
alert("Make sure the Search Clipboard button is checked in the options pane.");
}
}, 101);
})
.catch(err => {
console.error('Failed to copy: ', err);
});
}
}
const activityTitleElement = document.getElementById("activity-title");
if (activityTitleElement) {
const activityTitleText = activityTitleElement.textContent || activityTitleElement.innerText;
function handleAssessment() {
setTimeout(() => {
extractTextFromIframe();
}, 250);
const iframe = window.frames[0];
const iframeDocument = iframe.document;
const targetElements = iframeDocument.getElementsByClassName("Assessment_Main_Body_Content_Question");
const visibleElements = Array.from(targetElements).filter(function(element) {
return element.style.display !== "none" && element.id.includes("q_");
});
}
function handleAssignment() {
const nestedIframeDocument = window.frames[0].frames[0].document;
const contentElements = nestedIframeDocument.getElementsByClassName("content");
const altElements = nestedIframeDocument.querySelectorAll('[alt]');
let contentText = '';
if (contentElements.length > 0) {
contentText = Array.from(contentElements)
.map(element => element.innerText)
.join('\n');
}
const altValues = Array.from(altElements)
.map(element => element.getAttribute('alt'))
.join('\n');
const combinedText = contentText + (contentText && altValues ? '\n' : '') + altValues;
if (combinedText) {
navigator.clipboard.writeText(combinedText)
.then(() => {
console.log('Content copied to clipboard!');
setTimeout(() => {
clickSearchClipboard();
}, 100);
});
}
}
document.addEventListener('keydown', function(event) {
if (event.key === '3') {
if (activityTitleText.includes("Test") || activityTitleText.includes("Exam") || activityTitleText.includes("Quiz")) {
handleAssessment();
} else if (activityTitleText.includes("Assignment")) {
handleAssignment();
}
}
});
}
function clickSearchClipboard() {
const buttons = Array.from(document.querySelectorAll('button'));
const buttonToClick = buttons.find(button => button.innerText === 'Search Clipboard');
if (buttonToClick) {
buttonToClick.click();
} else {
alert("Make sure the Search Clipboard button is checked in the options pane.");
}
}
function addKeyListener() {
const frame = window.frames[0];
const initialButtonCheck = document.getElementById('searchActionButton');
if (!window.location.href.includes("nuity")) {
return;
}
if (frame && !frame.keyListenerAdded) {
frame.keyListenerAdded = true;
frame.document.addEventListener('keydown', function(event) {
if (event.key === '3') {
const activityTitleText = document.getElementById('activity-title')?.textContent || '';
if (activityTitleText.includes("Assignment")) {
handleAssignment();
}
if (activityTitleText.includes("Test") || activityTitleText.includes("Exam") || activityTitleText.includes("Quiz")) {
handleAssessment();
}
if (initialButtonCheck) {
initialButtonCheck.click();
}
}
});
}
}
if (window.location.href.includes('core.learn')) {
setInterval(addKeyListener, 1000);
}
function checkForButton() {
const iframeDocument = window.frames[0].document;
const audioEntryButton = iframeDocument.getElementById('btnEntryAudio');
if (audioEntryButton) {
const existingButton = iframeDocument.getElementById('searchActionButton');
if (!existingButton) {
const searchActionButton = iframeDocument.createElement('button');
searchActionButton.innerText = "Search question";
searchActionButton.id = "searchActionButton";
searchActionButton.style.webkitTextSizeAdjust = "100%";
searchActionButton.style.borderSpacing = "0";
searchActionButton.style.borderCollapse = "collapse";
searchActionButton.style.fontFamily = '"Helvetica Neue", Helvetica, Arial, sans-serif';
searchActionButton.style.display = "inline-block";
searchActionButton.style.boxSizing = "border-box";
searchActionButton.style.height = "28px";
searchActionButton.style.border = "1px solid #8d8e8f";
searchActionButton.style.color = "#ffffff";
searchActionButton.style.fontSize = "13px";
searchActionButton.style.lineHeight = "28px";
searchActionButton.style.fontWeight = "bold";
searchActionButton.style.textDecoration = "none";
searchActionButton.style.webkitFontSmoothing = "antialiased";
searchActionButton.style.whiteSpace = "nowrap";
searchActionButton.style.textShadow = "0 0 5px rgba(255, 255, 255, 0.6)";
searchActionButton.style.zoom = "1";
searchActionButton.style.webkitBorderRadius = "3px";
searchActionButton.style.backgroundColor = "#1a1a1a";
searchActionButton.style.backgroundPosition = "center bottom";
searchActionButton.style.backgroundSize = "100% 100%";
searchActionButton.style.boxShadow = "inset 0 1px 0 rgba(255, 255, 255, 0.2), inset 0 -1px 0 rgba(0, 0, 0, 0.05), 0 1px 2px rgba(0, 0, 0, 0.1)";
searchActionButton.style.cursor = "pointer";
searchActionButton.style.userSelect = "none";
searchActionButton.style.position = "relative";
searchActionButton.style.padding = "0 40px";
searchActionButton.style.textAlign = "center";
searchActionButton.style.margin = "0 10px";
audioEntryButton.parentElement.appendChild(searchActionButton);
searchActionButton.style.position = "absolute";
searchActionButton.style.left = "50%";
searchActionButton.style.transform = "translateX(-50%)";
const bottomTrayElements = iframeDocument.querySelectorAll('[class*="bottom-tray"]');
bottomTrayElements.forEach(trayElement => {
trayElement.style.position = 'relative';
const buttonClone = searchActionButton.cloneNode(true);
trayElement.appendChild(buttonClone);
buttonClone.style.position = "absolute";
buttonClone.style.left = "50%";
buttonClone.style.transform = "translateX(-50%)";
});
}
}
}
if (window.top === window.self && window.location.href.includes('core.learn')) {
const buttonCheckInterval = setInterval(checkForButton, 500);
}
const observerConfig = {
attributes: false,
childList: true,
subtree: true
};
const mutationCallback = function(mutations, observerInstance) {
for (const mutation of mutations) {
if (mutation.type === 'childList') {
const detectedElements = document.querySelectorAll('.mark-return');
if (detectedElements.length > 0) {
appendSearchButton(detectedElements[0].parentNode);
}
}
}
};
const appendSearchButton = function(parentContainer) {
const existingButton = document.getElementById('uniqueSearchButtonId');
if (existingButton) return;
const searchActionButton = document.createElement('button');
searchActionButton.innerText = "Search question";
searchActionButton.id = "uniqueSearchButtonId";
searchActionButton.style.webkitTextSizeAdjust = "100%";
searchActionButton.style.borderSpacing = "0";
searchActionButton.style.borderCollapse = "collapse";
searchActionButton.style.fontFamily = '"Helvetica Neue", Helvetica, Arial, sans-serif';
searchActionButton.style.display = "inline-block";
searchActionButton.style.boxSizing = "border-box";
searchActionButton.style.height = "28px";
searchActionButton.style.border = "1px solid #8d8e8f";
searchActionButton.style.color = "#ffffff";
searchActionButton.style.fontSize = "13px";
searchActionButton.style.lineHeight = "28px";
searchActionButton.style.fontWeight = "bold";
searchActionButton.style.textDecoration = "none";
searchActionButton.style.webkitFontSmoothing = "antialiased";
searchActionButton.style.whiteSpace = "nowrap";
searchActionButton.style.textShadow = "0 0 5px rgba(255, 255, 255, 0.6)";
searchActionButton.style.zoom = "1";
searchActionButton.style.webkitBorderRadius = "3px";
searchActionButton.style.backgroundColor = "#1a1a1a";
searchActionButton.style.backgroundPosition = "center bottom";
searchActionButton.style.backgroundSize = "100% 100%";
searchActionButton.style.boxShadow = "inset 0 1px 0 rgba(255, 255, 255, 0.2), inset 0 -1px 0 rgba(0, 0, 0, 0.05), 0 1px 2px rgba(0, 0, 0, 0.1)";
searchActionButton.style.cursor = "pointer";
searchActionButton.style.userSelect = "none";
searchActionButton.style.position = "absolute";
searchActionButton.style.left = "35%";
searchActionButton.style.top = "50%";
searchActionButton.style.transform = "translate(-70%, -50%)";
parentContainer.style.position = "relative";
parentContainer.appendChild(searchActionButton);
};
const targetElement = document.body;
const observerInstance = new MutationObserver(mutationCallback);
observerInstance.observe(targetElement, observerConfig);
(function() {
function checkAndAddListener() {
const frame = window.frames[0];
if (frame && frame.document) {
const button = frame.document.getElementById("searchActionButton");
if (button) {
if (!button.dataset.listenerAdded) {
button.addEventListener('click', handleAssignment);
button.dataset.listenerAdded = true;
console.log("Listener added to the button within the iframe.");
}
}
}
}
if (window.top === window.self && window.location.href.includes('core.learn')) {
setInterval(checkAndAddListener, 500);}
})();
if (window.top === window.self) {
function monitorFrameForButton() {
const frame = window.frames[0];
const checkInterval = setInterval(() => {
if (frame && frame.document) {
const button = frame.document.getElementById('uniqueSearchButtonId');
if (button) {
if (!frame.hasListenerAdded) {
button.addEventListener('click', handleAssessment);
frame.hasListenerAdded = true;
console.log('Listener added to the button.');
clearInterval(checkInterval);
}
}
}
}, 100);
}
monitorFrameForButton();
}
let buttonsClicked = false;
function updateTextareaAndClickButtonsOnce() {
try {
const frame = window.frames[0];
const innerFrame = frame ? frame.frames[0] : null;
if (innerFrame) {
const iframeDoc = innerFrame.document;
if (iframeDoc.readyState === 'complete') {
const textarea = iframeDoc.querySelector('.QuestionTextArea');
// Check if textarea is empty before updating
if (textarea && textarea.value.trim() === '') {
const answerChoices = iframeDoc.querySelectorAll('.answer-choice-label');
let allText = '';
answerChoices.forEach(choice => {
allText += choice.textContent.trim() + '\n';
});
// Update the textarea
textarea.value = allText.trim();
// Call the API check after 1 second
setTimeout(() => {
window.frames[0].API.Frame.check();
}, 1000);
const buttons = iframeDoc.querySelectorAll('.answer-choice-button');
buttons.forEach(button => {
if (button) {
button.click();
}
});
const doneButtons = iframeDoc.querySelectorAll('.done-start');
setTimeout(() => {
doneButtons.forEach(doneButton => {
if (doneButton) {
doneButton.click();
}
});
const retryButtons = iframeDoc.querySelectorAll('.done-retry');
setTimeout(() => {
retryButtons.forEach(retryButton => {
if (retryButton) {
retryButton.click();
}
});
}, 400);
}, 200);
}
}
}
} catch (error) {
console.error("An error occurred:", error); // Optional: Log the error to the console
}
}
function checkUpdateTextareaAndClickButtonsOnce() {
const isAutoWritingChecked = document.getElementById('autoWritingCheckbox').checked;
if (isAutoWritingChecked) {
updateTextareaAndClickButtonsOnce();
}
}
if (window.top === window.self && window.location.href.includes('core.learn')) {
setInterval(checkUpdateTextareaAndClickButtonsOnce, 1000);
}
function checkOpacity() {
if (frames[0] && frames[0].document) {
var homeVideoContainer = frames[0].document.getElementById("home_video_container");
if (homeVideoContainer && homeVideoContainer.parentNode.style.opacity == 1) {
} else {
try {
if (document.getElementById("activity-title").innerText == "Assignment") {}
if (["Instruction", "Summary", "Warm-Up"].includes(document.getElementById("activity-title").innerText)) {
try {
window.options = window.frames[0].frames[0].document.getElementsByClassName("answer-choice-button");
window.options[Math.floor(Math.random() * window.options.length)].click();
} catch (TypeError) {}
try {
window.frames[0].API.Frame.check();
} catch (TypeError) {}
}
} catch (TypeError) {}
}
}
}
function checkcheckOpacity() {
const isGuessingChecked = document.getElementById('guessingCheckbox').checked;
if (isGuessingChecked) {
checkOpacity();
}
}
if (window.top === window.self && window.location.href.includes('core.learn')) {
setInterval(checkcheckOpacity, 1000);
}
function clickOnFootnavWhenGradebarVisible() {
// Function to check if an element is visible
function isElementVisible(element) {
return !!(element && element.offsetWidth && element.offsetHeight);
}
// Select the gradebar element
var gradeBar = document.querySelector('.gradebar');
// Check if gradeBar is visible and its innerText includes "completed"
if (isElementVisible(gradeBar) && gradeBar.innerText.includes('completed')) {
// Select the element to click
var footNav = document.querySelector('.footnav.goRight');
// Check if the footNav element exists
if (footNav) {
footNav.click(); // Simulate a click on the footNav element
}
}
}
function clickOnFootnavWhenGradebarVisible() {
// Function to check if an element is visible
function isElementVisible(element) {
return !!(element && element.offsetWidth && element.offsetHeight);
}
// Select the gradebar element
var gradeBar = document.querySelector('.gradebar');
// Check if gradeBar is visible and its innerText includes "completed"
if (isElementVisible(gradeBar) && gradeBar.innerText.includes('completed')) {
// Select the element to click
var footNav = document.querySelector('.footnav.goRight');
// Check if the footNav element exists
if (footNav) {
footNav.click(); // Simulate a click on the footNav element
}
}
}
setInterval(function() {
const autoAdvanceCheckbox = document.getElementById('autoAdvanceCheckbox'); // Check for checkbox existence
if (autoAdvanceCheckbox && autoAdvanceCheckbox.checked) { // Only proceed if checkbox exists and is checked
if (frames[0] && frames[0].document) { // Check if frames[0] and its document exist
const homeVideoContainer = frames[0].document.getElementById("home_video_container"); // Access the home video container
if (homeVideoContainer && homeVideoContainer.parentNode && homeVideoContainer.parentNode.style.opacity == 1) {
// Do nothing if the container is visible
} else {
// Call the function to click foot navigation and go to the next frame
clickFootnavAndNextFrame();
clickOnFootnavWhenGradebarVisible();
}
}
}
}, 1000); // Executes every 1000 milliseconds (1 second)
setInterval(function() {
var element = document.getElementById("invis-o-div");
if (element) {
element.remove();
}
}, 1000);
if (window.top === window.self && window.location.href.includes('core.learn')) {
setInterval(() => {
const checkBox = document.getElementById('autoShowCheckbox'); // Check for existence in each interval.
if (checkBox && checkBox.checked) { // Use the presence check before accessing 'checked'.
updateDisplay();
clickShowButtons();
}
}, 1000);
}
function updateDisplay() {
const outerFrame = window.frames[0];
if (outerFrame && outerFrame.frames && outerFrame.frames[0]) {
const elements = outerFrame.frames[0].document.getElementsByClassName("uibtn mathButton");
for (let i = 0; i < elements.length; i++) {
if (elements[i].innerText.includes("Show")) {
elements[i].style.display = "block";
}
}
}
}
function clickShowButtons() {
const outerFrame = window.frames[0];
if (outerFrame && outerFrame.frames && outerFrame.frames[0]) {
const elements = outerFrame.frames[0].document.getElementsByClassName("uibtn mathButton");
for (let i = 0; i < elements.length; i++) {
if (elements[i].innerText.includes("Show")) {
elements[i].click();
}
}
}
}
function clickFootnavAndNextFrame() {
try {
document.getElementsByClassName("footnav goRight")[0].click();
} catch (TypeError) {}
try {
window.frames[0].API.FrameChain.nextFrame();
} catch (TypeError) {}
}
var clipboardButton;
function createClipboardSearchButton() {
try {
var iframe = document.querySelector("iframe");
if (iframe) {
var rect = iframe.getBoundingClientRect();
var iframeTop = rect.top + window.scrollY;
var iframeRight = rect.right + window.scrollX;
var buttonContainer = document.createElement('div');
buttonContainer.style.position = 'fixed';
buttonContainer.style.top = (iframeTop + 10) + 'px';
buttonContainer.style.left = (iframeRight - 150) + 'px';
buttonContainer.style.zIndex = '9999';
document.body.appendChild(buttonContainer);
clipboardButton = document.createElement('button');
clipboardButton.innerText = 'Search Clipboard';
buttonContainer.appendChild(clipboardButton);
}
} catch (error) {
console.error('Error accessing the first iframe:', error);
}
}
function checkClipboardSearchButton() {
const isClipboardChecked = document.getElementById('searchClipboardCheckbox').checked;
if (isClipboardChecked) {
if (!clipboardButton) {
createClipboardSearchButton();
}
} else {
if (clipboardButton) {
clipboardButton.parentElement.removeChild(clipboardButton);
clipboardButton = null;
}
}
}
if (window.top === window.self && window.location.href.includes('core.learn')) {
setInterval(checkClipboardSearchButton, 1000);}
document.addEventListener('click', function(event) {
if (event.target.tagName === 'BUTTON' && event.target.innerText.includes('Clipboard')) {
navigator.clipboard.readText().then(function(clipboardText) {
if (clipboardText) {
var isBrainlyChecked = document.getElementById('searchInBrainlyCheckbox').checked;
var searchUrl = 'https://brainly.com/app/ask?entry=top&q=' + encodeURIComponent(clipboardText);
if (isBrainlyChecked) {
var brainlyIframe = document.getElementById('brainly-chat-iframe');
if (brainlyIframe) {
brainlyIframe.src = searchUrl;
}
} else {
window.open(searchUrl, '_blank');
}
}
}).catch(function(err) {
console.error('Failed to read clipboard contents: ', err);
});
}
});
function addDeepaiIframes() {
const wrapElement = document.getElementById('wrap');
if (!document.getElementById('deepai-chat-iframe')) {
const deepaiIframe = document.createElement('iframe');
deepaiIframe.id = 'deepai-chat-iframe';
deepaiIframe.src = 'https://deepai.org/chat';
deepaiIframe.style.width = '25%';
deepaiIframe.style.height = '100vh';
deepaiIframe.style.border = 'none';
deepaiIframe.style.position = 'absolute';
deepaiIframe.style.top = '0';
deepaiIframe.style.right = '0';
deepaiIframe.style.zIndex = '20000';
wrapElement.style.position = 'relative';
deepaiIframe.style.opacity = '0';
deepaiIframe.style.transition = 'opacity 0.5s';
deepaiIframe.sandbox = 'allow-same-origin allow-scripts';
document.body.appendChild(deepaiIframe);
}
}
function addBrainlyIframes() {
const wrapElement = document.getElementById('wrap');
if (!document.getElementById('brainly-chat-iframe')) {
const brainlyIframe = document.createElement('iframe');
brainlyIframe.id = 'brainly-chat-iframe';
brainlyIframe.src = 'https://brainly.com/search';
brainlyIframe.style.width = '25%';
brainlyIframe.style.height = '100vh';
brainlyIframe.style.border = 'none';
brainlyIframe.style.position = 'absolute';
brainlyIframe.style.top = '0';
brainlyIframe.style.left = '0';
brainlyIframe.style.zIndex = '20000';
wrapElement.style.position = 'relative';
brainlyIframe.style.opacity = '0';
brainlyIframe.style.transition = 'opacity 0.5s';
brainlyIframe.sandbox = 'allow-same-origin allow-scripts';
document.body.appendChild(brainlyIframe);
}
}
addDeepaiIframes();
addBrainlyIframes();
function updateDeepaiIframeVisibility() {
const deepaiIframe = document.getElementById('deepai-chat-iframe');
const isAiChatChecked = document.getElementById('aiChatCheckbox').checked;
if (deepaiIframe) {
if (isAiChatChecked) {
deepaiIframe.style.opacity = '1';
deepaiIframe.style.display = 'block';
} else {
deepaiIframe.style.opacity = '0';
setTimeout(() => deepaiIframe.style.display = 'none', 500);
}
}
}
function updateBrainlyIframeVisibility() {
const brainlyIframe = document.getElementById('brainly-chat-iframe');
const isBrainlyChecked = document.getElementById('searchInBrainlyCheckbox').checked;
if (brainlyIframe) {
if (isBrainlyChecked) {
brainlyIframe.style.opacity = '1';
brainlyIframe.style.display = 'block';
} else {
brainlyIframe.style.opacity = '0';
setTimeout(() => brainlyIframe.style.display = 'none', 500);
}
}
}
if (window.top === window.self && window.location.href.includes('core.learn')) {
setInterval(() => {
updateDeepaiIframeVisibility();
updateBrainlyIframeVisibility();
}, 1000);
}
function createButtonAndPane() {
if (document.querySelector('#tweaksButton')) return;
const mainFootDiv = document.querySelector('.mainfoot');
const toggleButton = document.createElement('button');
toggleButton.id = 'tweaksButton';
toggleButton.textContent = 'Toggle Options';
toggleButton.style.border = "1px solid #5f5f5f";
toggleButton.style.boxShadow = "inset 0 0 5px rgba(0, 0, 0, 0.6)";
toggleButton.style.backgroundColor = "rgb(39, 39, 39)";
toggleButton.style.color = "#f9a619";
toggleButton.style.borderRadius = "3px";
toggleButton.style.marginLeft = "40%";
toggleButton.style.zIndex = "2";
toggleButton.style.padding = '5px 10px';
mainFootDiv.appendChild(toggleButton);
if (!window.pane) {
window.pane = document.createElement('div');
window.pane.style.display = 'none';
document.body.appendChild(window.pane);
const popupMenu = document.createElement('div');
popupMenu.className = 'popup-menu';
const aiChatItem = createMenuItem('AI Chat', 'aiChatCheckbox');
popupMenu.appendChild(aiChatItem);
const searchInBrainlyItem = createMenuItem('Search in Brainly frame', 'searchInBrainlyCheckbox');
popupMenu.appendChild(searchInBrainlyItem);
const autoVocabItem = createMenuItem('Auto Vocab', 'autoVocabCheckbox');
popupMenu.appendChild(autoVocabItem);
const autoWritingItem = createMenuItem('Auto Writing', 'autoWritingCheckbox');
popupMenu.appendChild(autoWritingItem);
const autoplayItem = createMenuItem('Autoplay', 'autoplayCheckbox');
popupMenu.appendChild(autoplayItem);
const searchClipboardItem = createMenuItem('Search Clipboard Button', 'searchClipboardCheckbox');
popupMenu.appendChild(searchClipboardItem);
const guessingItem = createMenuItem('Guessing', 'guessingCheckbox');
popupMenu.appendChild(guessingItem);
// Add new menu items here
const autoAdvanceItem = createMenuItem('AutoAdvance', 'autoAdvanceCheckbox');
popupMenu.appendChild(autoAdvanceItem);
// Add the new 'AutoShow' item
const autoShowItem = createMenuItem('AutoShow', 'autoShowCheckbox');
popupMenu.appendChild(autoShowItem);
window.pane.appendChild(popupMenu);
const footerText = document.createElement('div');
footerText.style.marginTop = '20px';
footerText.style.color = 'rgb(249, 166, 25)';
footerText.style.textAlign = "center";
footerText.textContent = "This was made by me, TallTacoTristan, as a way to make edge-nuity " +
"classes MUCH easier and skip by the tedious bits but it took a long time, over " +
"100 hours of just coding, to write over a thousand lines, it has many features, " +
"the ones above are less than half, just the ones that need a toggle. " +
"So please leave a good review on my page for all the time I spent to save yours, Thank you.";
const discordMessage = document.createElement('div');
discordMessage.textContent = "Join this discord if you have any issues, questions, or suggestions! Or simply to download the newest version which also includes a nicer gui, autoexam, autoassignment, and multitab, as well as more.";
discordMessage.style.marginTop = '10px';
const discordLink = document.createElement('a');
discordLink.textContent = "https://discord.gg/6qJwkYSmrQ";
discordLink.href = "https://discord.gg/6qJwkYSmrQ";
discordLink.target = "_blank";
discordLink.style.marginTop = '5px';
discordLink.style.color = 'cyan';
discordLink.style.textDecoration = 'underline';
footerText.appendChild(discordMessage);
footerText.appendChild(discordLink);
window.pane.appendChild(footerText);
loadCheckboxState('aiChat', 'aiChatCheckbox');
loadCheckboxState('searchInBrainly', 'searchInBrainlyCheckbox');
loadCheckboxState('autoVocab', 'autoVocabCheckbox');
loadCheckboxState('autoWriting', 'autoWritingCheckbox');
loadCheckboxState('autoplay', 'autoplayCheckbox');
loadCheckboxState('searchClipboard', 'searchClipboardCheckbox');
loadCheckboxState('guessing', 'guessingCheckbox');
// Load new checkbox states
loadCheckboxState('autoAssignment', 'autoAssignmentCheckbox');
loadCheckboxState('autoShow', 'autoShowCheckbox'); // New
makeDraggable(window.pane);
}
toggleButton.addEventListener('click', function() {
console.log('Button clicked! Toggling pane visibility.');
if (window.pane.style.display === 'none' || window.pane.style.display === '') {
window.pane.style.width = "50%";
window.pane.style.height = "auto";
window.pane.style.position = "absolute";
window.pane.style.marginTop = "20vh";
window.pane.style.marginLeft = "25%";
window.pane.style.border = "1px solid rgb(95, 95, 95)";
window.pane.style.borderRadius = "3px";
window.pane.style.backgroundColor = "rgb(39, 39, 39)";
window.pane.style.overflow = "hidden";
window.pane.style.color = "rgb(249, 166, 25)";
window.pane.style.textAlign = "center";
window.pane.style.overflowY = "scroll";
window.pane.style.display = 'block';
checkCheckboxState('aiChatCheckbox');
checkCheckboxState('searchInBrainlyCheckbox');
checkCheckboxState('autoVocabCheckbox');
checkCheckboxState('autoWritingCheckbox');
checkCheckboxState('autoplayCheckbox');
checkCheckboxState('searchClipboardCheckbox');
checkCheckboxState('guessingCheckbox');
// Check new checkbox states
checkCheckboxState('autoAdvanceCheckbox');
checkCheckboxState('autoShowCheckbox'); // New
} else {
window.pane.style.display = 'none';
}
});
}
function makeDraggable(element) {
let offsetX, offsetY;
element.addEventListener('mousedown', function(e) {
e.preventDefault();
offsetX = e.clientX - element.getBoundingClientRect().left + element.offsetWidth / 2;
offsetY = e.clientY - element.getBoundingClientRect().top + element.offsetHeight / 2;
element.classList.add('dragging');
document.addEventListener('mousemove', dragElement);
document.addEventListener('mouseup', stopDragging);
});
function dragElement(e) {
e.preventDefault();
let x = e.clientX - offsetX;
let y = e.clientY - offsetY;
element.style.left = x + 'px';
element.style.top = y + 'px';
}
function stopDragging() {
element.classList.remove('dragging');
document.removeEventListener('mousemove', dragElement);
document.removeEventListener('mouseup', stopDragging);
}
}
function createMenuItem(text, checkboxId) {
const itemDiv = document.createElement('div');
itemDiv.className = 'menu-item';
const checkbox = document.createElement('input');
checkbox.type = 'checkbox';
checkbox.id = checkboxId;
const storedValue = localStorage.getItem(checkboxId);
if (storedValue !== null) {
checkbox.checked = (storedValue === 'true');
}
const label = document.createElement('label');
label.innerText = text;
label.setAttribute('for', checkboxId);
itemDiv.appendChild(checkbox);
itemDiv.appendChild(label);
checkbox.addEventListener('change', () => {
console.log(`${text} checkbox is now ${checkbox.checked ? 'checked' : 'unchecked'}`);
localStorage.setItem(checkboxId, checkbox.checked);
});
return itemDiv;
}
function loadCheckboxState(checkboxId) {
const storedValue = localStorage.getItem(checkboxId);
if (storedValue !== null) {
const checkbox = document.getElementById(checkboxId);
if (checkbox) {
checkbox.checked = (storedValue === 'true');
}
}
}
function checkCheckboxState(checkboxId) {
const checkbox = document.getElementById(checkboxId);
const storedValue = localStorage.getItem(checkboxId);
if (storedValue !== null && checkbox) {
if (checkbox.checked !== (storedValue === 'true')) {
checkbox.checked = (storedValue === 'true');
}
}
}
if (window.top === window.self && window.location.href.includes('core.learn')) {
setInterval(createButtonAndPane, 1000);
}
var checkbox = document.getElementById('searchInBrainlyCheckbox');
let lastTitle = '';
function checkForAssignment() {
const element = document.getElementById('activity-title');
if (element) {
const currentTitle = element.textContent || element.innerText;
const excludedKeywords = [
"Summary", "Warm-Up", "Instruction", "Quiz",
"Assignment", "Unit Test",
"Unit Review", "Cumulative Exam Review",
"Vocab","Cumulative Exam"
];
const containsExcludedKeyword = excludedKeywords.some(keyword => currentTitle.includes(keyword));
const currentContainsAssignment = currentTitle.includes("Assignment");
if (currentTitle !== lastTitle) {
if (currentContainsAssignment || !containsExcludedKeyword) {
new Notification("Done!");
}
lastTitle = currentTitle;
}
}
}if (window.top === window.self) {
setInterval(checkForAssignment, 1000);}
const isAutoVocabChecked = document.getElementById('autoVocabCheckbox').checked;
function clickSubmitIfVisible() {
const submitButton = window.frames[0].document.querySelector('a[data-bind="visible:lastWord == currentWord(), click: submit"]');
if (submitButton && submitButton.style.display !== 'none') {
submitButton.click();
}
}
function vocabCompleter() {
if (document.getElementById("activity-title").innerText == "Vocabulary") {
$("#stageFrame").contents().find(".uibtn.uibtn-blue.uibtn-arrow-next")[0].click()
var i = 0;
try{
var txt = window.frames[0].document.getElementsByClassName("word-background")[0].value
window.frames[0].document.getElementsByClassName("word-textbox")[0].value = txt;
$("#stageFrame").contents().find(".word-textbox.word-normal")[0].dispatchEvent(new Event("keyup"));
} catch{return;}
var speed = 50;
output += ("Vocab Completer, ")
$("#stageFrame").contents().find(".playbutton.vocab-play")[0].click()
$("#stageFrame").contents().find(".playbutton.vocab-play")[1].click()
$("#stageFrame").contents().find(".uibtn.uibtn-blue.uibtn-arrow-next")[0].click()
}
}
function checkAndExecuteFunctions() {
const isAutoVocabChecked = document.getElementById('autoVocabCheckbox').checked;
if (isAutoVocabChecked) {
clickSubmitIfVisible();
vocabCompleter();
}
}
if (window.top === window.self && window.location.href.includes('core.learn')) {
setInterval(checkAndExecuteFunctions, 1000);
}