From 2a1be5603de3d1dce6d8c3848ec6a70d60363365 Mon Sep 17 00:00:00 2001 From: Ryan Wang Date: Mon, 25 Jul 2022 20:02:52 +0800 Subject: [PATCH] feat: handling front-end plugin loading failure exceptions Signed-off-by: Ryan Wang --- src/main.ts | 34 ++++++++++++++++++++++++---------- 1 file changed, 24 insertions(+), 10 deletions(-) diff --git a/src/main.ts b/src/main.ts index 47597ed9..23990def 100644 --- a/src/main.ts +++ b/src/main.ts @@ -100,6 +100,8 @@ function loadStyle(href: string) { }); } +const pluginErrorMessages: Array = []; + async function loadPluginModules() { const { data } = await apiClient.extension.plugin.listpluginHaloRunV1alpha1Plugin(); @@ -116,16 +118,22 @@ async function loadPluginModules() { }; if (entry) { - const { load } = useScriptTag( - `${import.meta.env.VITE_API_URL}${plugin.status?.entry}` - ); - await load(); - const pluginModule = window[plugin.metadata.name]; + try { + const { load } = useScriptTag( + `${import.meta.env.VITE_API_URL}${plugin.status?.entry}` + ); + await load(); + const pluginModule = window[plugin.metadata.name]; - if (pluginModule) { - // @ts-ignore - plugin.spec.module = pluginModule; - registerModule(pluginModule); + if (pluginModule) { + // @ts-ignore + plugin.spec.module = pluginModule; + registerModule(pluginModule); + } + } catch (e) { + const message = `${plugin.metadata.name}: Failed load plugin entry module`; + console.error(message, e); + pluginErrorMessages.push(message); } } @@ -133,12 +141,18 @@ async function loadPluginModules() { try { await loadStyle(`${import.meta.env.VITE_API_URL}${stylesheet}`); } catch (e) { - console.error(e); + const message = `${plugin.metadata.name}: Failed load plugin stylesheet`; + console.error(message, e); + pluginErrorMessages.push(message); } } pluginStore.registerPlugin(plugin); } + + if (pluginErrorMessages.length > 0) { + alert(pluginErrorMessages.join("\n")); + } } async function loadCurrentUser() {