From 01aa88f5eb9e8a47a18e55364c21de636723936e Mon Sep 17 00:00:00 2001 From: Coki <92775570+HashCookie@users.noreply.github.com> Date: Thu, 18 Jul 2024 18:04:55 +0800 Subject: [PATCH] fix: White screen issue and persevering and recovering modelKind in shared links (#133) * refactor: improve type safety and default handling in share content loading and sharing * refactor: remove commented-out reactStrictMode config * Fix: Preserve and restore modelKind in shared links * style: reformat return statement in useIndex hook --- app/components/editor/hooks/useIndex.tsx | 16 ++++--- app/components/editor/hooks/useShareInfo.tsx | 46 +++++++++++++------- app/components/editor/index.tsx | 2 +- 3 files changed, 43 insertions(+), 21 deletions(-) diff --git a/app/components/editor/hooks/useIndex.tsx b/app/components/editor/hooks/useIndex.tsx index ce7f95d..2c903f1 100644 --- a/app/components/editor/hooks/useIndex.tsx +++ b/app/components/editor/hooks/useIndex.tsx @@ -48,11 +48,17 @@ export default function useIndex() { }) .then((content) => { const sharedContent = JSON.parse(content) as ShareFormat; - setPolicyPersistent(sharedContent.policy); - setModelTextPersistent(sharedContent.model); - setCustomConfigPersistent(sharedContent.customConfig); - setRequestPersistent(sharedContent.request); - setModelKind(sharedContent.modelKind); + // Use empty string as default value with type checking + setPolicyPersistent(sharedContent.policy ?? ''); + setModelTextPersistent(sharedContent.model ?? ''); + setCustomConfigPersistent(sharedContent.customConfig ?? ''); + setRequestPersistent(sharedContent.request ?? ''); + // Make sure it's a valid ModelKind type + if (sharedContent.modelKind && example[sharedContent.modelKind as ModelKind]) { + setModelKind(sharedContent.modelKind as ModelKind); + } else { + setModelKind('basic'); // Use Default + } window.location.hash = ''; // prevent duplicate load setEcho(
Shared Content Loaded.
); }) diff --git a/app/components/editor/hooks/useShareInfo.tsx b/app/components/editor/hooks/useShareInfo.tsx index 15697c8..d2aa692 100644 --- a/app/components/editor/hooks/useShareInfo.tsx +++ b/app/components/editor/hooks/useShareInfo.tsx @@ -19,12 +19,12 @@ interface ShareProps extends ShareFormat { } export interface ShareFormat { - modelKind: string; - model: string; - policy: string; - customConfig: string; - request: string; - requestResult: object; + modelKind?: string; + model?: string; + policy?: string; + customConfig?: string; + request?: string; + requestResult?: object; } async function dpaste(content: string) { @@ -43,19 +43,35 @@ export default function useShareInfo() { if (sharing) return; setSharing(true); props.onResponse(
Sharing...
); + + // Create an object that contains only non-null values const shareContent: ShareFormat = { + ...Object.entries(props).reduce((acc, [key, value]) => { + if (key !== 'onResponse' && value != null && value !== '') { + acc[key as keyof ShareFormat] = value; + } + return acc; + }, {} as ShareFormat), modelKind: props.modelKind, - model: props.model, - policy: props.policy, - customConfig: props.customConfig, - request: props.request, - requestResult: props.requestResult, }; - dpaste(JSON.stringify(shareContent)).then((url: string) => { + + // Check if there are any non-null values to share + if (Object.keys(shareContent).length === 0) { setSharing(false); - const hash = url.split('/')[3]; - props.onResponse(hash); - }); + props.onResponse(
No content to share
); + return; + } + + dpaste(JSON.stringify(shareContent)) + .then((url: string) => { + setSharing(false); + const hash = url.split('/')[3]; + props.onResponse(hash); + }) + .catch((error) => { + setSharing(false); + props.onResponse(
Error sharing content: {error.message}
); + }); } return { diff --git a/app/components/editor/index.tsx b/app/components/editor/index.tsx index 6289a78..12346f8 100755 --- a/app/components/editor/index.tsx +++ b/app/components/editor/index.tsx @@ -144,7 +144,7 @@ export const EditorScreen = () => {
{t('Model')}