mirror of
https://github.com/uqbar-dao/nectar.git
synced 2024-12-22 16:11:38 +03:00
Merge pull request #551 from kinode-dao/bp/appstoreuistore
app_store UI: don't persist local UI store
This commit is contained in:
commit
e0f7a716ef
@ -21,16 +21,24 @@ const MirrorSelector: React.FC<MirrorSelectorProps> = ({ packageId, onMirrorSele
|
||||
if (!appData) return;
|
||||
const mirrors = [appData.package_id.publisher_node, ...(appData.metadata?.properties?.mirrors || [])];
|
||||
setAvailableMirrors(mirrors);
|
||||
setSelectedMirror(appData.package_id.publisher_node);
|
||||
|
||||
mirrors.forEach(mirror => {
|
||||
// Start with the publisher node
|
||||
setSelectedMirror(appData.package_id.publisher_node);
|
||||
setMirrorStatuses(prev => ({ ...prev, [appData.package_id.publisher_node]: null }));
|
||||
|
||||
for (const mirror of mirrors) {
|
||||
if (mirror.startsWith('http')) {
|
||||
setMirrorStatuses(prev => ({ ...prev, [mirror]: 'http' }));
|
||||
setSelectedMirror(mirror);
|
||||
break;
|
||||
} else {
|
||||
setMirrorStatuses(prev => ({ ...prev, [mirror]: null }));
|
||||
checkMirrorStatus(mirror);
|
||||
const status = await checkMirrorStatus(mirror);
|
||||
if (status) {
|
||||
setSelectedMirror(mirror);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
}, [packageId, fetchListing, checkMirror]);
|
||||
|
||||
useEffect(() => {
|
||||
@ -41,8 +49,10 @@ const MirrorSelector: React.FC<MirrorSelectorProps> = ({ packageId, onMirrorSele
|
||||
try {
|
||||
const status = await checkMirror(mirror);
|
||||
setMirrorStatuses(prev => ({ ...prev, [mirror]: status?.is_online ?? false }));
|
||||
return status?.is_online ?? false;
|
||||
} catch {
|
||||
setMirrorStatuses(prev => ({ ...prev, [mirror]: false }));
|
||||
return false;
|
||||
}
|
||||
}, [checkMirror]);
|
||||
|
||||
@ -62,7 +72,6 @@ const MirrorSelector: React.FC<MirrorSelectorProps> = ({ packageId, onMirrorSele
|
||||
setIsCustomMirrorSelected(false);
|
||||
setCustomMirror("");
|
||||
if (!value.startsWith('http')) {
|
||||
// Recheck the status when a non-HTTP mirror is selected
|
||||
setMirrorStatuses(prev => ({ ...prev, [value]: null }));
|
||||
await checkMirrorStatus(value);
|
||||
}
|
||||
@ -92,7 +101,6 @@ const MirrorSelector: React.FC<MirrorSelectorProps> = ({ packageId, onMirrorSele
|
||||
return (
|
||||
<div className="mirror-selector">
|
||||
<select value={selectedMirror || ""} onChange={handleMirrorChange}>
|
||||
<option value="">Select a mirror</option>
|
||||
{availableMirrors.map((mirror, index) => (
|
||||
<option key={`${mirror}-${index}`} value={mirror}>
|
||||
{mirror} {getMirrorStatus(mirror, mirrorStatuses[mirror])}
|
||||
|
@ -45,9 +45,7 @@ interface AppsStore {
|
||||
|
||||
}
|
||||
|
||||
const useAppsStore = create<AppsStore>()(
|
||||
persist(
|
||||
(set, get): AppsStore => ({
|
||||
const useAppsStore = create<AppsStore>()((set, get) => ({
|
||||
listings: {},
|
||||
installed: {},
|
||||
downloads: {},
|
||||
@ -220,6 +218,13 @@ const useAppsStore = create<AppsStore>()(
|
||||
});
|
||||
if (res.status === HTTP_STATUS.CREATED) {
|
||||
await get().fetchInstalled();
|
||||
|
||||
// hacky: a small delay (500ms) before fetching homepage apps
|
||||
// to give the app time to add itself to the homepage
|
||||
// might make sense to add more state and do retry logic instead.
|
||||
await new Promise(resolve => setTimeout(resolve, 500));
|
||||
|
||||
await get().fetchHomepageApps();
|
||||
}
|
||||
} catch (error) {
|
||||
console.error("Error installing app:", error);
|
||||
@ -395,11 +400,6 @@ const useAppsStore = create<AppsStore>()(
|
||||
console.error('WebSocket error:', error);
|
||||
},
|
||||
}),
|
||||
}),
|
||||
{
|
||||
name: 'app_store',
|
||||
}
|
||||
)
|
||||
)
|
||||
}))
|
||||
|
||||
export default useAppsStore
|
Loading…
Reference in New Issue
Block a user