(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 = "
" + "" + "

Mocker

" + "
" + "

" + "Click the buttons below or hit "+ "ENTER to " + "mock interaction with the engine. Type " + "engine.hideOverlay() " + "in the console to hide this overlay. See " + "the " + "" + "docs for details." + "

" + "

" + "Call / trigger this UI " + "function / event:" + "

" + "

with arguments:

" + "" + "
" + "

"+ "Call / trigger this Engine " + "function / event:" + "

" + "

with arguments:

" + "" + "
" + "
" + "" + "
"; 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 || {});