-
Notifications
You must be signed in to change notification settings - Fork 324
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
chore: unify duplicate code in FormPage #7538
Conversation
{#if showEmptyScreen} | ||
<NoContainerEngineEmptyScreen /> | ||
{:else} |
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 do not see why we need to have a 'layout' enum property inside this component
it's not this component that should do the change and display a nocontainerengine but the callee/parent
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 put this here bc the FormPage is already a wrapper for the FormPage from the ui package, so this is really tight to podman desktop and its needs. There are multiple components using the same emptyscreen/content pattern so i thought that the formPage could have different layouts and handle it.
Do you prefer every single component to handle its own css/empty screen and leave the formPage as it was?
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 some small code savings but feels odd to me as well - saying 'engine' changes the layout, and we have a fixed empty screen but only show it based on a reason the page has to provide. Maybe it'd work better as an EngineFormPage that extends FormPage and automatically shows the empty screen when needed? (or whenever the slot isn't provided?) It currently feels more like 'hard-coded requirements for specific children' than 'optional feature' like tabs or breadcrumb.
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.
Added an EngineFormPage component
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've been looking at the component hierarchy and some of the history here, and child pages set their own background and rounded corners on the form because originally this was the same parent as the dashboard or troubleshooting where we couldn't draw the tiles because we didn't know how many there would be on the page.
IMHO it's time to clean that up - FormPage should exist to provide a single form for the user to fill out, sub-files should just be adding content to the form.
What I think that means:
- Troubleshooting & Help should be changed or moved off of FormPage to avoid breakage in the next steps. Likely Troubleshooting to DetailsPage and Help to NavPage?
- bg-charcoal-900 & rounded-lg - should be moved 'up' to FormPage.
- All 5 p* classes - should also be moved to FormPage, but simplified to just 'p-5' (or the different px/py) b/c we don't need this to be responsive and were only doing it for 1 page out of ~10.
- If we need empty screen to not be 'in' the form, FormPage should provide an alternate slot.
- It feels like the form could be setting the space-y instead of having this different in each form.
So how does this PR fit? I'm ok if this is a stepping stone to get to the above, as it cleans up most of the work in this set of child pages. The only things I don't love:
- Inconsistent space-y - could be opened as future issue.
- it feels like the showEmptyScreen should be automatic: i.e. this property doesn't exist and all pages get the empty screen if there are no providers. Again, I'm ok if this was a follow up.
- The simplified padding. Could you just simplify this before merging?
Signed-off-by: lstocchi <[email protected]>
Signed-off-by: lstocchi <[email protected]>
Signed-off-by: lstocchi <[email protected]>
Signed-off-by: lstocchi <[email protected]>
Signed-off-by: lstocchi <[email protected]>
@deboer-tim ok for me. Not sure about the space-y as it changes the layout but we can check it in separate PR. Rebased, fixed an issue on the runimage page and simplified the padding. |
What does this PR do?
This PR is made in preparation to fix #7214
By looking at the code of each component using the FormPage i noticed that we were using almost everywhere
or something very close.
This PR updates the FormPage to accept a value to customize the layout. When the value
engine
is used those div/classes are automatically set so to reduce the duplicate code in all pages using it.You will see a lot of code changed but it is mostly a change in the indentation. i just deleted the useless wrapping classes/div
Screenshot / video of UI
N/A - should be the same as before
What issues does this PR fix or reference?
it is part of #7214
How to test this PR?
N/A - it should be like before