coursepoint OMN

helps study for tests

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey, Greasemonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да инсталирате разширение, като например Tampermonkey .

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Userscripts.

За да инсталирате скрипта, трябва да инсталирате разширение като Tampermonkey.

За да инсталирате този скрипт, трябва да имате инсталиран скриптов мениджър.

(Вече имам скриптов мениджър, искам да го инсталирам!)

Advertisement:

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

(Вече имам инсталиран мениджър на стиловете, искам да го инсталирам!)

Advertisement:

// ==UserScript==
// @name         coursepoint OMN
// @description  helps study for tests
// @version      1.3
// @match        https://qp-examengine.hlrptech.com/*
// @grant        GM_setClipboard
// @namespace https://greasyfork.org/users/1617665
// ==/UserScript==

let questionMap = {};
let currentSequence = 1;

const origOpen = XMLHttpRequest.prototype.open;
const origSend = XMLHttpRequest.prototype.send;

XMLHttpRequest.prototype.open = function(method, url) {
  this._url = url;
  return origOpen.apply(this, arguments);
};

XMLHttpRequest.prototype.send = function() {
  this.addEventListener('load', function() {
    if (!this._url) return;
    try {
      const data = JSON.parse(this.responseText);
      if (!data?.promptText) return;

      const seq = data.sequence;
      const q = data.promptText;
      const c = data.choiceInteraction.simpleChoices.map(x => x.label);

      questionMap[seq] = { q, c };

      // First question — set current to 1
      if (!this._url.match(/\/items\/\d+/)) {
        currentSequence = 1;
      }

      btn.innerText = 'Copy Question';
      btn.style.background = '#fff';
    } catch(e) {}
  });
  return origSend.apply(this, arguments);
};

const btn = document.createElement('button');
btn.innerText = 'Copy Question';
btn.style.cssText = 'position:fixed;top:10px;right:10px;z-index:9999;padding:8px 12px;background:#fff;color:#111;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:14px;';

btn.addEventListener('mouseenter', () => { btn.style.background = '#eee'; });
btn.addEventListener('mouseleave', () => { if (btn.innerText !== 'Copied!') btn.style.background = '#fff'; });

btn.addEventListener('click', () => {
  const entry = questionMap[currentSequence];
  if (entry) {
    GM_setClipboard(entry.q + '\n\n' + entry.c.join('\n'));
    btn.innerText = 'Copied!';
    btn.style.background = '#eee';
    if (questionMap[currentSequence + 1]) {
      currentSequence++;
      btn.innerText = 'Copy Question';
      btn.style.background = '#fff';
    }
  }
});

document.body.appendChild(btn);