re_lpc_lobby_custom/custom_lobby/static/js/coherent.mock.js
2025-06-26 18:54:56 -03:00

166 lines
9.3 KiB
JavaScript

(function (engine) {
if (engine.isAttached && !engine.forceEnableMocking) {
return;
}
var OVERLAY_ID = "coherent-browser-debug-overlay",
JS_CALLS_LIST_ID = "coherent-browser-debug-js-list",
CPP_CALLS_LIST_ID = 'coherent-browser-debug-cpp-list';
var logoDataUrl = "";
var docsLink = "http://coherent-labs.com/Documentation/cpp/db/dbc/_java_script.html";
var createBrowserOverlay = function () {
var overlay = document.createElement("nav");
overlay.id = OVERLAY_ID;
overlay.classList.add("open");
var html = "<div class='contents'>" +
"<img src='" + logoDataUrl + "'></img>" +
"<h1>Mocker</h1>" +
"<hr>" +
"<p>" +
"Click the buttons below or hit "+
"<strong>ENTER</strong> to " +
"mock interaction with the engine. Type " +
"<code>engine.hideOverlay()</code> " +
"in the console to hide this overlay. See " +
"the " +
"<a target='_blank' href='" + docsLink + "'>" +
"docs</a> for details." +
"</p>" +
"<h2 class='left'>" +
"Call / trigger this <em>UI</em> " +
"function / event:" +
"</h2>" +
"<h2 class='right'>with arguments:</h2>" +
"<ul id='" + JS_CALLS_LIST_ID + "'></ul>" +
"<hr>" +
"<h2 class='left'>"+
"Call / trigger this <em>Engine</em> " +
"function / event:" +
"</h2>" +
"<h2 class='right'>with arguments:</h2>" +
"<ul id='" + CPP_CALLS_LIST_ID + "'></ul>" +
"</div>" +
"<div class='docked-contents'>" +
"<button id='coherent-dock-overlay-button'>" +
"Dock me!" +
"</button>" +
"</div>";
overlay.innerHTML = html;
var OverlayState = {
Open: 0,
Docked: 1,
Hidden: 2
};
overlay.state = OverlayState.Open;
overlay.querySelector("#coherent-dock-overlay-button")
.addEventListener("click", function () {
if (overlay.state == OverlayState.Open) {
overlay.state = OverlayState.Docked;
overlay.classList.remove("open");
overlay.classList.add("docked");
}
else if (overlay.state == OverlayState.Docked) {
overlay.state = OverlayState.Open;
overlay.classList.remove("docked");
overlay.classList.add("open");
}
});
return overlay;
};
var executeMock = function (name, isCppCall, isEvent, argsInput) {
var functionArgs = "'" + name + "'";
if (argsInput.value.length !== 0) {
functionArgs += ", " + argsInput.value;
}
var command = (isCppCall && !isEvent) ? "call" : "trigger";
try {
eval("engine." + command + "(" + functionArgs + ")");
}
catch (e) {
var text = "An error occured while executing mock function: ";
console.warn(text, e);
};
};
var LI_ID_PREFIX = "COHERENT_MOCKING_";
var addMockButton = function (name, args, isCppCall, isEvent) {
var id = LI_ID_PREFIX + name;
if (document.getElementById(id) !== null) {
// Button has already been created
return;
}
var li = document.createElement("li");
li.id = id;
var button = document.createElement("button");
button.textContent = name;
button.classList.add("left");
li.appendChild(button);
var argsInput = document.createElement("input");
argsInput.placeholder = args;
argsInput.classList.add("right");
argsInput.addEventListener("keyup", function (eventArgs) {
if (eventArgs.keyCode === 13) { // Enter
button.onclick();
}
}, false);
li.appendChild(argsInput);
button.onclick = executeMock.bind(undefined,
name,
isCppCall,
isEvent,
argsInput);
var parentId = isCppCall ? CPP_CALLS_LIST_ID : JS_CALLS_LIST_ID;
var parentSelector = "#" + OVERLAY_ID + " #" + parentId;
var menu = document.querySelector(parentSelector);
menu.appendChild(li);
};
var removeMockButton = function (name, isFunctionCall) {
var li = document.getElementById(LI_ID_PREFIX + name);
if (li && li.parentNode) {
li.parentNode.removeChild(li);
}
};
var systemEvents = [
"_coherentCreateImageData",
"_coherentUpdatedImageData",
'_Result',
'_Register',
'_Unregister',
'_OnReady',
'_OnError',
'replayEventsRecord'
]
engine.browserCallbackOn = function (name, callback) {
if (systemEvents.indexOf(name) === -1)
this._mockImpl(name, callback, false, true);
};
engine.browserCallbackOff = function (name) {
if (systemEvents.indexOf(name) === -1)
removeMockButton(name);
};
engine.browserCallbackMock = addMockButton;
var overlay = createBrowserOverlay();
document.body.appendChild(overlay);
engine.hideOverlay = function () {
overlay.classList.add("hidden");
overlay.classList.remove("shown");
};
engine.showOverlay = function () {
overlay.classList.add("shown");
overlay.classList.remove("hidden");
};
})(engine || {});