-
Notifications
You must be signed in to change notification settings - Fork 73
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
Data catalog UI: MVP #5628
base: main
Are you sure you want to change the base?
Data catalog UI: MVP #5628
Conversation
…taset-lifecycle-top-tables
The latest updates on your projects. Learn more about Vercel for Git ↗︎
|
fides Run #11891
Run Properties:
|
Project |
fides
|
Branch Review |
refs/pull/5628/merge
|
Run status |
Passed #11891
|
Run duration | 00m 39s |
Commit |
831ead06a6 ℹ️: Merge 4629acbb1e4c0f39dfaf8356b53fc3d17573734e into 7043171c4d6f3564c93e39b48abf...
|
Committer | jpople |
View all properties for this run ↗︎ |
Test results | |
---|---|
Failures |
0
|
Flaky |
0
|
Pending |
0
|
Skipped |
0
|
Passing |
4
|
Upgrade your plan to view test results. | |
View all changes introduced in this branch ↗︎ |
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.
Overall looking good. Loving a lot of the abstractions for clean and more reusable code. Left a few comments, questions, and nit-picks for potential improvement.
import { Badge, BadgeProps } from "fidesui"; | ||
import React from "react"; | ||
|
||
const ResultStatusBadge = React.forwardRef<HTMLSpanElement, BadgeProps>( |
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.
What about this makes it specific to Result Status? Would this be better as a more generically named component, or does it need specific properties required with more strict type? (eg. colorScheme
which has to be of STATUS_COLOR_MAP
enum type). You might consider exporting the STATUS_COLOR_MAP
enum from this 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.
Good callout-- deleted this component and changed all of its uses to use the more generic BadgeCell.
gap={2} | ||
overflowX="auto" | ||
> | ||
<TaxonomyCellContainer> |
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 wonder if this file should be renamed/moved since it's specific to TableV2 cells
import { ChevronDownIcon, Collapse, Flex, Text, useDisclosure } from "fidesui"; | ||
import { ReactNode } from "react"; | ||
|
||
const AdvancedSettings = ({ children }: { children: ReactNode }) => { |
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 component just seems superfluous. It's either too specifically named (where the label could be another prop), or not specific enough about the children it accepts. Does it always need to be inside a form or can it be moved out to the "common" parent directory?
clients/admin-ui/src/features/data-catalog/systems/EditMinimalDataUseModal.tsx
Show resolved
Hide resolved
</Stack> | ||
</AdvancedSettings> | ||
</Flex> | ||
<div className="flex w-full justify-between"> |
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 file also uses Chakra's Box
quite a bit. What do you think about updating those to use tailwind like this for consistency? This could potentially use Ant's Flex
component as well.
<Flex | ||
alignItems="center" | ||
gap={1.5} | ||
cursor={onClick ? "pointer" : "default"} |
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 know you are just moving this down, but this method is better for a11y and automatically gets the correct cursor so we might as well do that while we're here :)
cursor={onClick ? "pointer" : "default"} | |
as={onClick ? "button" : undefined} |
<Button | ||
size="small" | ||
icon={<SmallAddIcon mb="1px" />} | ||
className=" max-h-[20px] max-w-[20px] rounded-sm border-gray-200 bg-white hover:!bg-gray-100" |
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 only be using tailwind for layout and never for colors as we don't plan to maintain it with the palette. Isn't this just a variation of one of our defined button types anyway? That's by far the more preferred method for this so that the theme gets applied. Review the Order of priority for styling if needed.
const TaxonomyAddButton = (props: ButtonProps) => ( | ||
<Button | ||
size="small" | ||
icon={<SmallAddIcon mb="1px" />} |
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.
can we use the Carbon version of the icon in this new component?
alignItems="center" | ||
gap={1.5} |
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 alignment of the + button is off during testing, I think this alignItems
and gap
still belongs in the parent (probably both?). Probably don't need a margin on the button with gap
on parent.
if (isLoading || isFetching || systemIsLoading) { | ||
return <TableSkeletonLoader rowHeight={36} numRows={36} />; | ||
} |
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.
Since this falls outside of the Layout
the skeleton is taking up the entire page (bleeding edge to edge) which I don't think is the desired effect. This should probably be moved in lower.
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.
None of the breadcrumbs seem to be working properly. Clicking down in to a child level and then clicking a breadcrumb to go back just results in an empty table.
<Button | ||
size="small" | ||
icon={<Icons.Add />} | ||
className=" max-h-[20px] max-w-[20px]" |
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.
nitpick:
className=" max-h-[20px] max-w-[20px]" | |
className=" max-h-5 max-w-5" |
}, | ||
}); | ||
|
||
if (isLoading || isFetching) { |
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 would suggest only using isLoading
here so the skeleton appears on initial load, but not every time a new Data Use is added.
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.
A few nitpicks, but overall looking great.
Closes HJ-333
Description Of Changes
First pass at data catalog (new D&D view).
Code Changes
Steps to Confirm
To test, run a Plus backend (using the
fidesplus
image) on this Plus branch. Pinrequirements.txt
to use the latest commit from this Fides branch, e.g.:Make systems:
with an integration with a database layer (e.g. BigQuery); add a monitor to the integration and scan it
with an integration without a database layer (e.g. DynamoDB); add a monitor to the integration and scan it
with no integration, but a dataset in the system's "dataset reference" field
with none of these
In nav, click on "data catalog" view
In systems table:
On clicking through to the system, should see databases/projects for the system with databases/projects and datasets for the other
Should be able to click through to staged resources under the dataset level
Should be able to classify a resource in the table, then optionally change data categories and confirm classification
Pre-Merge Checklist
CHANGELOG.md
updatedmain
downgrade()
migration is correct and works