-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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
API connection status notifications #1237
Conversation
@alexcjohnson I love the idea of capturing the state of the backend connection in an unobtrusive way, rather than silencing the notifications altogether.
I'd be inclined to either silence it when hot reloading is disabled, or consider adding a parameter to the the dev tools UI set of options which disables the "heartbeat" upon request (keeping it active if debug mode is on). |
Do we want to use “connected” or “reachable” or “available” or something like that instead? I want to avoid confusing people into thinking there is a live “connection” like a web socket or whatever. Also re “backend” should we talk about “hot reload” instead? |
Good point @nicolaskruchten - also as we've discussed "back end" doesn't mean the same thing to everyone. But I don't think we want to just describe it as about "hot reload" as then people may not connect it to "the server has crashed and needs to be restarted" How about "server available / unavailable"? |
Updated styling - with help from @angeladaodao 🎉 |
Feedback on the new images: the check and cross look too similar in my view... They do or indicate very different things so they should look different. We have 4 things there now, two of which pop things up (callback graph, error list), two of which indicate something (error list, backend-status) and one of which closes the panel. The close button should probably look quite different from the other three, and maybe the backend-status can be the same size as the other two? |
The new one is just an indicator, not a toggle button like the callback graph and errors. And the close button for that matter, which toggles the menu itself, so if anything it seems like the new status indicator is the one odd one out. Now I'm thinking of maybe having the blue |
Now it looks odd to have a small one... I say make it the same size and maybe pop up a little explanation on click instead of just on hover? |
I like it a lot! Maybe some text on the new icon like “Server” to match the others? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
💃 beautiful!
Co-authored-by: Chris Parmer <[email protected]>
Closes #920 - turn
_reload-hash
fetch failures into a status indicator rather than recurring errors.When the back end is connected and the debug menu is closed there are no extra indicators, but an indicator appears where the error count would be if disconnected:
data:image/s3,"s3://crabby-images/6e0f6/6e0f671eb62f3b9e0e7ffe0afae6198c607619d5" alt="Screen Shot 2020-05-09 at 2 54 21 AM"
data:image/s3,"s3://crabby-images/e9cd8/e9cd8f3165099f80c69afc7e979661e5b3a18077" alt="Screen Shot 2020-05-09 at 2 39 05 AM"
data:image/s3,"s3://crabby-images/751d2/751d2d8f60d56a628d98c6d393757909b0fc568b" alt="Screen Shot 2020-05-09 at 2 37 35 AM"
data:image/s3,"s3://crabby-images/1f89a/1f89ab3b9e5152bca790fcf6604e5b50bbd62675" alt="Screen Shot 2020-05-09 at 2 37 58 AM"
And next to the error count if there are errors too:
With the debug menu open, we show both connected and disconnected states:
Styling could use some work - I feel like the small 🚫 icon is pretty good, but the large 🚫 and ✅ are a bit ugly and out of place with the rest of the debug menu, probably we want dedicated svg icons for this purpose?
I also put the connection status in the heading of the error display:
data:image/s3,"s3://crabby-images/80cba/80cbafedc07f5acf0440eff2542f5cf387763749" alt="Screen Shot 2020-05-09 at 2 39 23 AM"
data:image/s3,"s3://crabby-images/948b7/948b7ee9e99c473aa379e6a6a280ed49395fcda4" alt="Screen Shot 2020-05-09 at 2 49 08 AM"
Note that callbacks that fail to fetch still show up in the error log, because these go through their own fetch call.
I think this makes sense, but it raise the question whether we should do something different if hot reloading is disabled but the error UI is enabled. Callback fetch failures don't currently show as
backEndConnected: false
, but without hot reloading to provide a heartbeat any "connected" status would be out of date most of the time. Maybe without hot reloading we just shouldn't show connection status at all?Contributor Checklist
CHANGELOG.md