From 728218d1c4386674308ba3054c9b18fec82ae6cb Mon Sep 17 00:00:00 2001 From: Keyrxng <106303466+Keyrxng@users.noreply.github.com> Date: Wed, 27 Nov 2024 20:15:39 +0000 Subject: [PATCH 1/2] chore: single push method, commit title update --- static/scripts/config-parser.ts | 2 +- static/scripts/rendering/write-add-remove.ts | 79 +++++++------------- 2 files changed, 28 insertions(+), 53 deletions(-) diff --git a/static/scripts/config-parser.ts b/static/scripts/config-parser.ts index 8f3ac27..25ea64e 100644 --- a/static/scripts/config-parser.ts +++ b/static/scripts/config-parser.ts @@ -142,7 +142,7 @@ export class ConfigParser { owner: org, repo: repo, path, - message: `chore: updating config`, + message: `chore: Plugin Installer UI - update`, content: btoa(this.newConfigYml), sha, }); diff --git a/static/scripts/rendering/write-add-remove.ts b/static/scripts/rendering/write-add-remove.ts index abfd3ca..f069d30 100644 --- a/static/scripts/rendering/write-add-remove.ts +++ b/static/scripts/rendering/write-add-remove.ts @@ -81,34 +81,7 @@ function handleAddPlugin(renderer: ManifestRenderer, plugin: Plugin, pluginManif type: "success", actionText: "Push to GitHub", shouldAutoDismiss: true, - action: async () => { - const octokit = renderer.auth.octokit; - if (!octokit) { - throw new Error("Octokit not found"); - } - - const org = localStorage.getItem("selectedOrg"); - - if (!org) { - throw new Error("No selected org found"); - } - - try { - await renderer.configParser.updateConfig(org, octokit); - } catch (error) { - console.error("Error pushing config to GitHub:", error); - toastNotification("An error occurred while pushing the configuration to GitHub.", { - type: "error", - shouldAutoDismiss: true, - }); - return; - } - - toastNotification("Configuration pushed to GitHub successfully.", { - type: "success", - shouldAutoDismiss: true, - }); - }, + action: () => notificationConfigPush(renderer), }); } @@ -118,34 +91,36 @@ function handleRemovePlugin(renderer: ManifestRenderer, plugin: Plugin, pluginMa type: "success", actionText: "Push to GitHub", shouldAutoDismiss: true, - action: async () => { - const octokit = renderer.auth.octokit; - if (!octokit) { - throw new Error("Octokit not found"); - } + action: () => notificationConfigPush(renderer), + }); +} + +async function notificationConfigPush(renderer: ManifestRenderer) { + const octokit = renderer.auth.octokit; + if (!octokit) { + throw new Error("Octokit not found"); + } - const org = localStorage.getItem("selectedOrg"); + const org = localStorage.getItem("selectedOrg"); - if (!org) { - throw new Error("No selected org found"); - } + if (!org) { + throw new Error("No selected org found"); + } - try { - await renderer.configParser.updateConfig(org, octokit); - } catch (error) { - console.error("Error pushing config to GitHub:", error); - toastNotification("An error occurred while pushing the configuration to GitHub.", { - type: "error", - shouldAutoDismiss: true, - }); - return; - } + try { + await renderer.configParser.updateConfig(org, octokit); + } catch (error) { + console.error("Error pushing config to GitHub:", error); + toastNotification("An error occurred while pushing the configuration to GitHub.", { + type: "error", + shouldAutoDismiss: true, + }); + return; + } - toastNotification("Configuration pushed to GitHub successfully.", { - type: "success", - shouldAutoDismiss: true, - }); - }, + toastNotification("Configuration pushed to GitHub successfully.", { + type: "success", + shouldAutoDismiss: true, }); } From 1ac5807e9bd0ec2b0c4681f06ba4235fdb82f6f4 Mon Sep 17 00:00:00 2001 From: Keyrxng <106303466+Keyrxng@users.noreply.github.com> Date: Thu, 28 Nov 2024 16:57:44 +0000 Subject: [PATCH 2/2] fix: check for boolean input on user config injection --- static/scripts/rendering/config-editor.ts | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/static/scripts/rendering/config-editor.ts b/static/scripts/rendering/config-editor.ts index d3fd371..3c30f43 100644 --- a/static/scripts/rendering/config-editor.ts +++ b/static/scripts/rendering/config-editor.ts @@ -51,8 +51,10 @@ export function renderConfigEditor(renderer: ManifestRenderer, pluginManifest: M let value: string; - if (typeof currentObj === "object") { + if (typeof currentObj === "object" || Array.isArray(currentObj)) { value = JSON.stringify(currentObj, null, 2); + } else if (typeof currentObj === "boolean") { + value = currentObj ? "true" : "false"; } else { value = currentObj as string; } @@ -62,6 +64,10 @@ export function renderConfigEditor(renderer: ManifestRenderer, pluginManifest: M } else { (input as HTMLInputElement).value = value; } + + if (input.tagName === "INPUT" && (input as HTMLInputElement).type === "checkbox") { + (input as HTMLInputElement).checked = value === "true"; + } }); }