From 74438a31458af8bddd08d90eacc6d63677bab844 Mon Sep 17 00:00:00 2001 From: Jonas Dellinger Date: Fri, 13 May 2022 19:14:47 +0200 Subject: Work on react frontend loader --- plugin_loader/static/library.js | 71 --------------------------- plugin_loader/static/plugin_page.js | 98 ------------------------------------- plugin_loader/static/styles.css | 3 -- 3 files changed, 172 deletions(-) delete mode 100644 plugin_loader/static/library.js delete mode 100644 plugin_loader/static/plugin_page.js delete mode 100644 plugin_loader/static/styles.css (limited to 'plugin_loader/static') diff --git a/plugin_loader/static/library.js b/plugin_loader/static/library.js deleted file mode 100644 index 744cc77f..00000000 --- a/plugin_loader/static/library.js +++ /dev/null @@ -1,71 +0,0 @@ -class PluginEventTarget extends EventTarget { } -method_call_ev_target = new PluginEventTarget(); - -window.addEventListener("message", function(evt) { - let ev = new Event(evt.data.call_id); - ev.data = evt.data.result; - method_call_ev_target.dispatchEvent(ev); -}, false); - -async function call_server_method(method_name, arg_object={}) { - let id = `${uuidv4()}`; - console.debug(JSON.stringify({ - "id": id, - "method": method_name, - "args": arg_object - })); - return new Promise((resolve, reject) => { - method_call_ev_target.addEventListener(`${id}`, function (event) { - if (event.data.success) resolve(event.data.result); - else reject(event.data.result); - }); - }); -} - -// Source: https://stackoverflow.com/a/2117523 Thanks! -function uuidv4() { - return ([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g, c => - (c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16) - ); -} - -async function fetch_nocors(url, request={}) { - let args = { method: "POST", headers: {}, body: "" }; - request = {...args, ...request}; - request.url = url; - request.data = request.body; - delete request.body; //maintain api-compatibility with fetch - return await call_server_method("http_request", request); -} - -async function call_plugin_method(method_name, arg_object={}) { - if (plugin_name == undefined) - throw new Error("Plugin methods can only be called from inside plugins (duh)"); - return await call_server_method("plugin_method", { - 'plugin_name': plugin_name, - 'method_name': method_name, - 'args': arg_object - }); -} - -async function execute_in_tab(tab, run_async, code) { - return await call_server_method("execute_in_tab", { - 'tab': tab, - 'run_async': run_async, - 'code': code - }); -} - -async function inject_css_into_tab(tab, style) { - return await call_server_method("inject_css_into_tab", { - 'tab': tab, - 'style': style - }); -} - -async function remove_css_from_tab(tab, css_id) { - return await call_server_method("remove_css_from_tab", { - 'tab': tab, - 'css_id': css_id - }); -} \ No newline at end of file diff --git a/plugin_loader/static/plugin_page.js b/plugin_loader/static/plugin_page.js deleted file mode 100644 index 0531f04e..00000000 --- a/plugin_loader/static/plugin_page.js +++ /dev/null @@ -1,98 +0,0 @@ -function reloadIframe() { - document.getElementById("plugin_iframe").contentWindow.location.href = "http://127.0.0.1:1337/plugins/iframe"; -} - -function resolveMethodCall(call_id, result) { - let iframe = document.getElementById("plugin_iframe").contentWindow; - iframe.postMessage({'call_id': call_id, 'result': result}, "http://127.0.0.1:1337"); -} - -function installPlugin(request_id) { - let id = `${new Date().getTime()}`; - console.debug(JSON.stringify({ - "id": id, - "method": "confirm_plugin_install", - "args": {"request_id": request_id} - })); - document.getElementById('plugin_install_list').removeChild(document.getElementById(`plugin_install_prompt_${request_id}`)); -} - -function addPluginInstallPrompt(artifact, version, request_id) { - let text = ` - - -
-

Install Plugin?

-

- ${artifact} - Version: ${version} -

- -

- -
- `; - document.getElementById('plugin_install_list').innerHTML = text; - - execute_in_tab('SP', false, 'FocusNavController.DispatchVirtualButtonClick(28)') -} - -(function () { - const PLUGIN_ICON = ` - - - - `; - - function createTitle(text) { - return `
${text}
`; - } - - function createPluginList() { - let pages = document.getElementsByClassName("quickaccessmenu_AllTabContents_2yKG4 quickaccessmenu_Down_3rR0o")[0]; - let pluginPage = pages.children[pages.children.length - 1]; - pluginPage.innerHTML = createTitle("Plugins"); - - pluginPage.innerHTML += `
` - - pluginPage.innerHTML += ``; - } - - function inject() { - let tabs = document.getElementsByClassName("quickaccessmenu_TabContentColumn_2z5NL Panel Focusable")[0]; - tabs.children[tabs.children.length - 1].innerHTML = PLUGIN_ICON; - - createPluginList(); - } - - let injector = setInterval(function () { - if (document.hasFocus()) { - inject(); - document.getElementById("plugin_title").onclick = function() { - reloadIframe(); - document.getElementById("plugin_title").innerText = "Plugins"; - } - window.onmessage = function(ev) { - let title = ev.data; - if (title.startsWith("PLUGIN_LOADER__")) { - document.getElementById("plugin_title").innerHTML = ` - - - - ${title.replace("PLUGIN_LOADER__", "")} - `; - } - } - clearInterval(injector); - } - }, 100); -})(); \ No newline at end of file diff --git a/plugin_loader/static/styles.css b/plugin_loader/static/styles.css deleted file mode 100644 index 8d27a538..00000000 --- a/plugin_loader/static/styles.css +++ /dev/null @@ -1,3 +0,0 @@ -@import url("/steam_resource/css/2.css"); -@import url("/steam_resource/css/39.css"); -@import url("/steam_resource/css/library.css"); -- cgit v1.2.3