Skip to content

Commit

Permalink
Detect SSR in installers and bail out
Browse files Browse the repository at this point in the history
  • Loading branch information
torokati44 committed Nov 4, 2024
1 parent 3906212 commit d6ad854
Showing 1 changed file with 37 additions and 27 deletions.
64 changes: 37 additions & 27 deletions src/app/installers.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,34 +22,44 @@ export default function Installers({
release: GithubRelease | null;
}) {
const recommended: RecommendedDownload[] = [];
if (typeof window !== "undefined") {
// seems like this is sometimes server-rendered, despite "use client" at the top
const [selectors] = useDeviceSelectors(window.navigator.userAgent);
const currentDevice: CurrentDevice = {
windows: selectors.isWindows,
mac: selectors.isMacOs,
android: selectors.isAndroid,
linux: selectors.osName.toLowerCase() == "linux", // https://github.com/duskload/react-device-detect/issues/200
ios: selectors.isIOS,
firefox: selectors.isFirefox,
chrome: selectors.isChrome,
edge: selectors.isEdge,
safari: selectors.isSafari,
desktop: selectors.isDesktop,
mobile: selectors.isMobile,
};

for (const link of allLinks) {
if (link.isDeviceRelevant(currentDevice)) {
const url = link.recommendedUrl || release?.downloads[link.key];
if (url) {
recommended.push({
icon: link.icon,
name: link.longName,
target: "_blank",
url,
});
}
const [isClient, setIsClient] = React.useState(false);

React.useEffect(() => {
// This effect will run only on the client
setIsClient(true);
}, []);

// Only render on the client-side
if (!isClient) {
return null; // On the server, return null to avoid mismatches
}

const [selectors] = useDeviceSelectors(window.navigator.userAgent);
const currentDevice: CurrentDevice = {
windows: selectors.isWindows,
mac: selectors.isMacOs,
android: selectors.isAndroid,
linux: selectors.osName.toLowerCase() == "linux", // https://github.com/duskload/react-device-detect/issues/200
ios: selectors.isIOS,
firefox: selectors.isFirefox,
chrome: selectors.isChrome,
edge: selectors.isEdge,
safari: selectors.isSafari,
desktop: selectors.isDesktop,
mobile: selectors.isMobile,
};

for (const link of allLinks) {
if (link.isDeviceRelevant(currentDevice)) {
const url = link.recommendedUrl || release?.downloads[link.key];
if (url) {
recommended.push({
icon: link.icon,
name: link.longName,
target: "_blank",
url,
});
}
}
}
Expand Down

0 comments on commit d6ad854

Please sign in to comment.