Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(platofrm): Added online/offline status detection in the platform #585

Conversation

Allan2000-Git
Copy link
Contributor

@Allan2000-Git Allan2000-Git commented Dec 9, 2024

User description

Description

This PR introduces functionality to detect and display the online/offline status of the platform using a toast message.

Fixes #499

Dependencies

N/A

Future Improvements

N/A

Mentions

@rajdip-b

Screenshots of relevant screens

I have throttled the network for testing the functionality.

https://www.loom.com/share/10eb3fcf518b40179a4ce52f92b46fa7

Developer's checklist

  • My PR follows the style guidelines of this project
  • I have performed a self-check on my work

If changes are made in the code:

  • I have followed the coding guidelines
  • My changes in code generate no new warnings
  • My changes are breaking another fix/feature of the project
  • I have added test cases to show that my feature works
  • I have added relevant screenshots in my PR
  • There are no UI/UX issues

Documentation Update

  • This PR requires an update to the documentation at docs.keyshade.xyz
  • I have made the necessary updates to the documentation, or no documentation changes are required.

PR Type

enhancement


Description

  • Introduced OnlineStatusHandler component to manage online/offline status detection.
  • Implemented useOnlineStatus hook to listen for network status changes and display toast notifications.
  • Integrated the OnlineStatusHandler into the main application layout to provide real-time feedback on internet connectivity.

Changes walkthrough 📝

Relevant files
Enhancement
layout.tsx
Integrate online status handler in the application layout

apps/platform/src/app/layout.tsx

  • Added OnlineStatusHandler component to the layout.
  • Ensured OnlineStatusHandler is wrapped by JotaiProvider.
  • +5/-1     
    online-status-handler.tsx
    Create OnlineStatusHandler component for status detection

    apps/platform/src/components/common/online-status-handler.tsx

  • Created OnlineStatusHandler component.
  • Utilized useOnlineStatus hook within the component.
  • +10/-0   
    use-online-status.ts
    Implement useOnlineStatus hook for connection status         

    apps/platform/src/hooks/use-online-status.ts

  • Implemented useOnlineStatus hook.
  • Added event listeners for online and offline status.
  • Displayed toast notifications for status changes.
  • +25/-0   

    💡 PR-Agent usage: Comment /help "your question" on any pull request to receive relevant information

    Copy link
    Contributor

    PR Reviewer Guide 🔍

    Here are some key observations to aid the review process:

    🎫 Ticket compliance analysis 🔶

    499 - Partially compliant

    Compliant requirements:

    • Show toaster notification when user goes offline
    • Show toaster notification when user comes back online
    • Reset and sync platform state when reconnecting (via page reload)

    Non-compliant requirements:

    • Display a red bar at the top of interface when user is offline
    ⏱️ Estimated effort to review: 2 🔵🔵⚪⚪⚪
    🧪 No relevant tests
    🔒 No security concerns identified
    ⚡ Recommended focus areas for review

    User Experience
    The 1 second delay before refresh may be too short for the user to read the success message. Consider increasing the timeout duration.

    Error Handling
    The page reload functionality should have error handling in case the reload fails or network is still unstable

    Copy link
    Contributor

    codiumai-pr-agent-free bot commented Dec 9, 2024

    PR Code Suggestions ✨

    Explore these optional code suggestions:

    CategorySuggestion                                                                                                                                    Score
    Possible issue
    Avoid forcing page reload when reconnecting to prevent potential data loss and unnecessary refreshes

    Add a check to prevent the page reload if the user is already on the latest version
    or if there are unsaved changes. Consider using a more graceful refresh strategy.

    apps/platform/src/hooks/use-online-status.ts [5-10]

     if (navigator.onLine) {
    -    toast.success("You are back online! Refreshing...");
    -    setTimeout(() => {
    -        window.location.reload();
    -    }, 1000);
    +    toast.success("You are back online!");
    +    if (document.documentElement.dataset.needsRefresh === 'true') {
    +        toast.info("Refreshing to get latest changes...");
    +        setTimeout(() => {
    +            window.location.reload();
    +        }, 1000);
    +    }
     }
    • Apply this suggestion
    Suggestion importance[1-10]: 9

    Why: The suggestion addresses a critical UX issue by preventing unnecessary page reloads that could lead to data loss. The improved code adds a smart check for determining if a refresh is actually needed.

    9
    ✅ Prevent multiple notifications and reloads during unstable network conditions

    Add debouncing to the status handler to prevent rapid-fire notifications and reloads
    during unstable connections.

    apps/platform/src/hooks/use-online-status.ts [4-10]

    +let statusTimeout: NodeJS.Timeout;
     const statusHandler = () => {
    -    if (navigator.onLine) {
    -        toast.success("You are back online! Refreshing...");
    -        setTimeout(() => {
    -            window.location.reload();
    -        }, 1000);
    -    }
    +    clearTimeout(statusTimeout);
    +    statusTimeout = setTimeout(() => {
    +        if (navigator.onLine) {
    +            toast.success("You are back online! Refreshing...");
    +            setTimeout(() => {
    +                window.location.reload();
    +            }, 1000);
    +        }
    +    }, 2000);
    +}

    [Suggestion has been applied]

    Suggestion importance[1-10]: 8

    Why: This suggestion addresses an important edge case where unstable connections could trigger multiple notifications and reloads in quick succession, significantly improving user experience during network instability.

    8
    Add error handling to prevent component crashes from network monitoring failures

    Add error boundary to prevent potential crashes from network status monitoring
    failures.

    apps/platform/src/components/common/online-status-handler.tsx [5-8]

     function OnlineStatusHandler() {
    -    useOnlineStatus();
    +    try {
    +        useOnlineStatus();
    +    } catch (error) {
    +        console.error('Failed to initialize online status handler:', error);
    +    }
         return null;
     }
    • Apply this suggestion
    Suggestion importance[1-10]: 4

    Why: While error handling is good practice, network status monitoring is a fairly stable browser API, and the current implementation is simple enough that catastrophic failures are unlikely. The improvement adds defensive programming but has moderate impact.

    4

    💡 Need additional feedback ? start a PR chat

    @rajdip-b
    Copy link
    Member

    rajdip-b commented Dec 9, 2024

    @kriptonian1 @poswalsameer can you drop your reviews?

    @Allan2000-Git
    Copy link
    Contributor Author

    @rajdip-b I can implement suggestions given my code bot reviewer.

    @rajdip-b
    Copy link
    Member

    rajdip-b commented Dec 9, 2024

    Just the one that I marked, the others are not needed

    @rajdip-b I can implement suggestions given my code bot reviewer.

    @poswalsameer
    Copy link
    Contributor

    @kriptonian1 @poswalsameer can you drop your reviews?

    Yeah sure1

    @poswalsameer
    Copy link
    Contributor

    Hi @Allan2000-Git, can you please attach some screenshots with the PR?

    @poswalsameer
    Copy link
    Contributor

    @kriptonian1 @poswalsameer can you drop your reviews?

    All looks good to me. I think instead of using setTimeout, we should have a boolean state to check the online/offline status of the user. And as this state changes, we can re-render the page using useEffect and show the corresponding toast message.

    @Allan2000-Git
    Copy link
    Contributor Author

    @kriptonian1 @poswalsameer can you drop your reviews?

    All looks good to me. I think instead of using setTimeout, we should have a boolean state to check the online/offline status of the user. And as this state changes, we can re-render the page using useEffect and show the corresponding toast message.

    Cool, will make the change & update

    @poswalsameer
    Copy link
    Contributor

    @kriptonian1 @poswalsameer can you drop your reviews?

    All looks good to me. I think instead of using setTimeout, we should have a boolean state to check the online/offline status of the user. And as this state changes, we can re-render the page using useEffect and show the corresponding toast message.

    Cool, will make the change & update

    did the state thing worked?

    @Allan2000-Git
    Copy link
    Contributor Author

    Allan2000-Git commented Dec 10, 2024

    @kriptonian1 @poswalsameer can you drop your reviews?

    All looks good to me. I think instead of using setTimeout, we should have a boolean state to check the online/offline status of the user. And as this state changes, we can re-render the page using useEffect and show the corresponding toast message.

    Cool, will make the change & update

    did the state thing worked?

    went through code, to keep it much cleaner, we do not require state actually as we're directly using the hook in the client component. state usage would be much more useful if we're using that state anywhere apart from self component

    @poswalsameer
    Copy link
    Contributor

    @kriptonian1 @poswalsameer can you drop your reviews?

    All looks good to me. I think instead of using setTimeout, we should have a boolean state to check the online/offline status of the user. And as this state changes, we can re-render the page using useEffect and show the corresponding toast message.

    Cool, will make the change & update

    did the state thing worked?

    went through code, to keep it much cleaner, we do not require state actually as we're directly using the hook in the client component. state usage would be much more useful if we're using that state anywhere apart from self component

    Sounds fine. @rajdip-b, I think we can merge this.

    @rajdip-b
    Copy link
    Member

    @kriptonian1 final thoughts? if you can approve it, I'll merge it asap

    @rajdip-b rajdip-b changed the title feat: Added online/offline status detection in the platform feat(platofrm): Added online/offline status detection in the platform Dec 13, 2024
    Copy link
    Contributor

    @kriptonian1 kriptonian1 left a comment

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    LGTM

    @rajdip-b rajdip-b merged commit 89aa84f into keyshade-xyz:develop Dec 14, 2024
    4 checks passed
    @Allan2000-Git Allan2000-Git deleted the feat/internet-connection-status-feedback branch December 14, 2024 07:47
    rajdip-b pushed a commit that referenced this pull request Jan 23, 2025
    ## [2.9.0](v2.8.0...v2.9.0) (2025-01-23)
    
    ### 🚀 Features
    
    * **api-client:** Get all workspace invitation ([#619](#619)) ([8a23850](8a23850))
    * **api,cli,api-client,schema:** Enhance permissions to allow filtering by environments through project roles ([#599](#599)) ([030b539](030b539))
    * **api:** Add `ADMIN` authority for API keys ([#609](#609)) ([fb6aba7](fb6aba7))
    * **api:** Add email template for inviting user to workspace ([#480](#480)) ([f5ddf7a](f5ddf7a))
    * **api:** Add email template for sending OTP to the user ([#582](#582)) ([cb6bbcb](cb6bbcb))
    * **api:** Add endpoint to fetch all workspace invitations for a user ([#586](#586)) ([d45417a](d45417a))
    * **api:** Add logout endpoint to clear token cookie ([#581](#581)) ([27f81ba](27f81ba))
    * **api:** Add slack integration ([#531](#531)) ([fe124d8](fe124d8))
    * **cli:** Add CLI command to check version flag using `--version` or `-v` ([#650](#650)) ([31b5efe](31b5efe))
    * **cli:** Add functionality to operate on Workspace Membership ([#589](#589)) ([0fde62b](0fde62b))
    * **cli:** Add import sub commmand for project. ([#594](#594)) ([9896f27](9896f27))
    * **cli:** Add List-invitation command ([#633](#633)) ([874f8c2](874f8c2))
    * **cli:** Added keyshade command to cli ([cf260ae](cf260ae))
    * **cli:** Api health probe ([#645](#645)) ([dd854f4](dd854f4))
    * **cli:** Create basic README.md ([a1b74e9](a1b74e9))
    * **cli:** Log publicKey, privacyKey, & accessLevel after project creation ([#623](#623)) ([5d5b329](5d5b329))
    * **cli:** Supports to specify environment(s) and its optional description ([#634](#634)) ([62083b1](62083b1))
    * **cli:** update README with feature and installation ([#644](#644)) ([a4d2a6a](a4d2a6a))
    * **platform:** Add a new [secure] and added loader on project screen ([#603](#603)) ([c3a08cc](c3a08cc))
    * **platform:** Add new variables to a project ([#593](#593)) ([d6c6252](d6c6252))
    * **platform:** Delete variable from a project ([#600](#600)) ([e64a738](e64a738))
    * **platform:** Edit existing variables in a project ([#602](#602)) ([bb48f6c](bb48f6c))
    * **platform:** Show all the existing variables inside a project ([#591](#591)) ([5276bb8](5276bb8))
    * **platofrm:** Added online/offline status detection in the platform ([#585](#585)) ([89aa84f](89aa84f))
    * **schema:** Add workspace invitation schema ([#612](#612)) ([1a5721b](1a5721b))
    * **web:** Add Google Analytics integration ([#649](#649)) ([397d6da](397d6da))
    
    ### 🐛 Bug Fixes
    
    * **api:** Empty name `""` accepted as a valid name while creating environments ([#583](#583)) ([a33f4b5](a33f4b5))
    * **api:** Enable global project access ([#580](#580)) ([b3a0309](b3a0309))
    * **api:** Update build command ([0ddfa59](0ddfa59))
    * **cli:** Add keywords for improved package discoverability ([#641](#641)) ([57ce10b](57ce10b))
    * **cli:** Check for .keyshade dir if profile isn't found ([#636](#636)) ([a69665d](a69665d))
    * **cli:** Create project --store-private-key option default value removed ([#638](#638)) ([20f16c6](20f16c6))
    * **cli:** Fixed binary path in package.json ([e531af0](e531af0))
    * **cli:** Fixed binary path in package.json ([81d674d](81d674d))
    * **cli:** Incorrect message on listing projects ([#624](#624)) ([eeffa42](eeffa42))
    * **cli:** Module errors ([d3432c5](d3432c5))
    * **cli:** Module errors ([a639065](a639065))
    * **cli:** Module errors ([a7742b1](a7742b1))
    * **cli:** Module errors ([e96300e](e96300e))
    * **cli:** Profile name now can use - and _ and updated error message ([#639](#639)) ([00dd66a](00dd66a))
    * **cli:** Prompt users for all values if no option set and show default values ([#640](#640)) ([fe862ab](fe862ab))
    * **docker:** Update build script ([40ef3e2](40ef3e2))
    * **platform:** Check if `Env. Name` is left empty ([#646](#646)) ([5f3fac8](5f3fac8))
    * **platform:** Clickable Workspaces combobox options ([#630](#630)) ([acc96f7](acc96f7))
    * **platform:** Optimized user update request body ([#605](#605)) ([ee1adf0](ee1adf0))
    * **platform:** Type error in navbar ([8199de8](8199de8))
    * **README:** Update Discord badge ([6f9382e](6f9382e))
    * **schema:** Add versions field to project [secure]s and variables response ([#590](#590)) ([755ea46](755ea46))
    
    ### 📚 Documentation
    
    * **cli:** Update changelog to include missed out changes ([8910c5c](8910c5c))
    * Updated alignment of pictures in API Testing page ([5d69223](5d69223))
    * Updated alignment of pictures in API Testing page ([e31eeca](e31eeca))
    
    ### 🔧 Miscellaneous Chores
    
    * Add Sentry and update CI ([#653](#653)) ([ca96862](ca96862))
    * **ci:** Add CLI deployment script ([51de9d1](51de9d1))
    * **ci:** Add internal package dependencies to existing workflows ([#592](#592)) ([a9fc39e](a9fc39e))
    * **ci:** Add scope ([8ef89a8](8ef89a8))
    * **ci:** Bug fix in workflow ([d583a46](d583a46))
    * **ci:** Bug fix in workflow ([eb9d60f](eb9d60f))
    * **ci:** Bump version to 2.2.0 ([951bd14](951bd14))
    * **ci:** Deploy DB migrations ([ea1beed](ea1beed))
    * **ci:** Fixed chaining and scripts ([6a009eb](6a009eb))
    * **ci:** Fixed environment name ([172c348](172c348))
    * **ci:** Fixed errors ([f28e3b5](f28e3b5))
    * **ci:** Minor fixes ([c7f05a0](c7f05a0))
    * **ci:** Push docker images of platform and API to ACR ([5f79dd7](5f79dd7))
    * **ci:** Remove npm ci ([3d45a4c](3d45a4c))
    * **ci:** Remove pnpm cache ([f45970c](f45970c))
    * **ci:** Update app redeployment ([18cf765](18cf765))
    * **ci:** Update web deployment to push to ACR ([26d4bed](26d4bed))
    * **cli:** Bumped CLI to v2.4.0 ([09efcd9](09efcd9))
    * **cli:** Rearranged dependency ([b6e344d](b6e344d))
    * **cli:** Removed changeset ([6c436de](6c436de))
    * **cli:** Update package name ([23552a1](23552a1))
    * **cli:** Update package name ([480cf54](480cf54))
    * **cli:** Update package.json ([871679a](871679a))
    * **cli:** Updated build scripts ([2e2b42d](2e2b42d))
    * **docker:** Update port of platform docker build ([c79d886](c79d886))
    * Housekeeping ([2ed31c0](2ed31c0))
    * **platoform:** Swapped all legacy API calls with `@keyshade/api-client` ([#584](#584)) ([c600db7](c600db7))
    * Removed .postman folder ([4b2b675](4b2b675))
    * Reverted back registry ([1699a89](1699a89))
    * **schema:** Add describe blocks in tests for each kind of schema ([#577](#577)) ([c0763f3](c0763f3))
    * Update npmrc ([9f7f495](9f7f495))
    * Update pipelines; fixed api docker ([3f36a17](3f36a17))
    * Update platform build command ([83a1851](83a1851))
    * **web:** Fix CI ([d1bc740](d1bc740))
    * **web:** Update dockerfile and ci to include google analytics env ([f2df4f4](f2df4f4))
    
    ### 🔨 Code Refactoring
    
    * **cli:** Replace arguments with options ([#615](#615)) ([498f44e](498f44e))
    * **platform:** Optimized codebase ([#629](#629)) ([d411081](d411081))
    * **platform:** Refactor project components ([#626](#626)) ([5b70805](5b70805))
    * **web:** Changed the text in the hero section of the web application ([#579](#579)) ([a92925f](a92925f))
    @rajdip-b
    Copy link
    Member

    🎉 This PR is included in version 2.9.0 🎉

    The release is available on GitHub release

    Your semantic-release bot 📦🚀

    Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
    Projects
    None yet
    Development

    Successfully merging this pull request may close these issues.

    PLATFORM: No Visual Feedback for Internet Connection Status
    4 participants