-
-
Notifications
You must be signed in to change notification settings - Fork 338
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
Handle API errors on schema page #2829
Handle API errors on schema page #2829
Conversation
Hi, @rajatvijay, this PR needs to be modified accordingly once the design is available. Did I address the problem correctly? Let me know your views on this. |
@Aritra8438 I am assigning this to myself until I reply to you back with the design questions that you asked. |
This is blocked on the work design, recorded under the concerned issue. |
@Aritra8438 I have updated the description to include the design. It also contains a link to the figma file |
Hi, @rajatvijay. I have completed adding the design. |
@Aritra8438 thanks, I will review this between today and tomorrow. |
This pull request has not been updated in 45 days and is being marked as stale. It will automatically be closed in 30 days if not updated by then. |
@rajatvijay! A friendly ping. |
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.
@Aritra8438 Apologies for the delay. I have added some review comments, let me know if you need more clarity on any of them.
<div class="table-fetch-error"> | ||
<div> | ||
<Icon {...iconWarning} /> | ||
<span>Error fetching tables</span> | ||
</div> | ||
<div> | ||
<Button | ||
on:click={() => { | ||
if ($currentSchemaId) { | ||
void refetchTablesForSchema($currentSchemaId); | ||
} | ||
}} | ||
> | ||
<Icon {...iconRefresh} /> | ||
<span>Retry</span> | ||
</Button> | ||
<a href="../"> | ||
<Button> | ||
<span>Go to Database</span> | ||
</Button> | ||
</a> | ||
</div> | ||
</div> |
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.
We should use ErrorBox
component for this. This might lead to a minor difference in the UI as compared to the figma but that is fine
<div class="exploration-fetch-error"> | ||
<div> | ||
<Icon {...iconWarning} /> | ||
<span>Error fetching explorations</span> | ||
</div> | ||
<div> | ||
<Button | ||
on:click={() => { | ||
if ($currentSchemaId) { | ||
void refetchQueriesForSchema($currentSchemaId); | ||
} | ||
}} | ||
> | ||
<Icon {...iconRefresh} /> | ||
<span>Retry</span> | ||
</Button> | ||
<a href="../"> | ||
<Button> | ||
<span>Go to Database</span> | ||
</Button> | ||
</a> | ||
</div> | ||
</div> |
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.
We should use ErrorBox component for this. This might lead to a minor difference in the UI as compared to the figma but that is fine
justify-content: center; | ||
align-items: flex-start; | ||
padding: 16px; | ||
gap: 16px; |
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 does not have good browser support. You can use :global(* + *)
. You can also do a global search for this code piece to see how it's being used at other places.
@@ -114,6 +173,45 @@ | |||
} | |||
} | |||
|
|||
.table-fetch-error { | |||
font-weight: 600; | |||
box-sizing: border-box; |
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 is added to all elements by default in base.html
no need here again.
@@ -114,6 +173,45 @@ | |||
} | |||
} | |||
|
|||
.table-fetch-error { | |||
font-weight: 600; |
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.
padding: 16px; | ||
gap: 16px; | ||
width: 616px; | ||
height: 105px; |
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.
no need for a fixed height
background: #fdeeed; | ||
border: 1px solid #f9cdc8; |
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.
please use css variables for colors.
height: 105px; | ||
background: #fdeeed; | ||
border: 1px solid #f9cdc8; | ||
border-radius: 8px; |
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.
please use css variables for this. --border-radius-l
.exploration-fetch-error { | ||
font-weight: 600; | ||
box-sizing: border-box; | ||
display: flex; | ||
flex-direction: column; | ||
justify-content: center; | ||
align-items: flex-start; | ||
padding: 16px; | ||
gap: 16px; | ||
width: 304px; | ||
height: 105px; | ||
background: #fdeeed; | ||
border: 1px solid #f9cdc8; | ||
border-radius: 8px; | ||
flex: none; | ||
order: 1; | ||
align-self: stretch; | ||
} |
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.
look at the comments in the similar CSS above (table-fetch-error
class)
$: isTablesLoading = $tablesStore.state === States.Loading; | ||
$: isTablesUnfetchable = $tablesStore.state === States.Error; | ||
$: isExplorationsLoading = $queries.requestStatus.state === 'processing'; | ||
$: isExplorationsUnfetchable = $queries.requestStatus.state === 'failure'; |
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.
instead of passing separate variables for loading & error, please use RequestStatus
(refer: mathesar_ui/src/api/utils/requestUtils.ts). This will let you pass error message too to the child component.
You can then use the error
string to show on the UI instead a generic message("Error fetching tables") from Figma. This give more information to the user and help him/her to report better errors .
Thanks, @rajatvijay. However, my scary mid-sem is going on. It will take one week and a half for me to get back to this. |
@Aritra8438 are you still planning to finish this PR? |
Yes, @seancolsen. |
I'm closing this because it's not been updated in a while, and the issue now seems to have been solved by #3323. |
This PR is related to #2644.
Technical details:
Currently, when one of the APIs
fails, the schema page shows no errors, assuming no results with success state. This PR will,
Screencast:
Schema_fetch_failure.mp4
Design Reference:
Figma link: https://www.figma.com/file/xHb5oIqye3fnXtb2heRH34/Styling?type=design&node-id=5807%3A31921&t=O8X0oEtOLpfjubpU-1
Checklist
Update index.md
).develop
branch of the repositoryvisible errors.
Developer Certificate of Origin
Developer Certificate of Origin