-
Notifications
You must be signed in to change notification settings - Fork 43
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
🐛 Shows client side loading state for jira tracker #1409
Conversation
6e05cb0
to
e4c2be5
Compare
Codecov ReportAll modified lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #1409 +/- ##
=======================================
Coverage 41.07% 41.07%
=======================================
Files 139 139
Lines 4404 4404
Branches 1010 1010
=======================================
Hits 1809 1809
Misses 2583 2583
Partials 12 12
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. |
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.
I don't mind the artificial spinner after kicking off the create or update.
The hook should be able to cancel the timers that are set. So maybe change the setUpdatingTrackerId()
to addUpdatingTrackerId()
and adjust a few calls?
connected={tracker.connected} | ||
message={tracker.message} | ||
/> | ||
{updatingTrackerId === tracker.id ? ( |
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.
This will be "the most recently updated/created tracker". Might want to track an array of tracker ids just to be sure that you get a spinner on multiple trackers if they're both edited very close together.
Maybe a Set would work better? But then since a Set is mutable, getting useState()
to track changes would be a bit of a challenge. Some stackoverflow discussion: https://stackoverflow.com/questions/58806883/how-to-use-set-with-reacts-usestate
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.
Converted to use a set internal to the hook but exported the readonly state as an array. Interesting on the mutable workaround. Updated the hook to use the approach you linked.
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.
I haven't tested this yet, but I'm not sure updating 2 trackers will show 2 spinners.
{updatingTrackerIds.includes(tracker.id) ? ( | ||
<Spinner size="sm" /> | ||
) : ( | ||
<TrackerStatus | ||
name={tracker.name} | ||
connected={tracker.connected} | ||
message={tracker.message} | ||
/> | ||
)} |
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.
I don't mind this setup, but you could push the spinner in to TrackerStatus
and just set a prop isTrackerUpdating={updatingTrackerIds.includes(tracker.id)}
. That way, all of the render code for the column is in a single component.
if (updatingTrackerIds.size > 0) { | ||
timerId = window.setTimeout(() => { | ||
setUpdatingTrackerIds(new Set()); | ||
}, delay); | ||
} | ||
|
||
return () => { | ||
if (timerId !== null) { | ||
window.clearTimeout(timerId); | ||
} | ||
}; |
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.
Does this work if you updated 2 trackers within the 10 second interval?
The addUpdatingTrackerId
function looks right, but the removal of the ids seems off since I don't see something like new Set(prevSet.remove(expiredId))
.
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.
It is actually working because on refetch this hook is remounted / cleaned up. Only works because we are routinely polling for trackers.
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.
Ah I see what you mean. The entire set is wiped when one timeout expires. Fixing.
… instance Signed-off-by: ibolton336 <[email protected]>
Signed-off-by: ibolton336 <[email protected]>
eab8b43
to
07c96b1
Compare
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.
The hook is a bit confusing but looks like it'll be ok. Everything else LGTM.
Signed-off-by: ibolton336 <[email protected]>
Closes False 'not connected' status for new Jira instance