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')}