Skip to content

Commit

Permalink
Implement data sandboxing updates (#20258)
Browse files Browse the repository at this point in the history
## Summary & Motivation

Implements updates to data sandboxing [more
context](https://linear.app/dagster-labs/issue/FE-201/implement-data-sandboxing-ui-updates)

## How I Tested These Changes

Asset graph:
![Screenshot 2024-03-06 at 1 01
18 PM](https://github.com/dagster-io/dagster/assets/2286579/709e24c0-eb26-42cd-ab96-bdceeb23246d)
![Screenshot 2024-03-06 at 1 01
14 PM](https://github.com/dagster-io/dagster/assets/2286579/8248c1de-f8c9-482d-a496-af34c3dffd93)

Asset catalog:
![Screenshot 2024-03-06 at 1 43
52 PM](https://github.com/dagster-io/dagster/assets/2286579/ba201b68-b27c-40c8-94e7-5d11bf8cf15c)
  • Loading branch information
salazarm authored and PedramNavid committed Mar 28, 2024
1 parent bda6cd3 commit 0ba71d1
Show file tree
Hide file tree
Showing 22 changed files with 845 additions and 440 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,7 @@ import menu_book from '../icon-svgs/menu_book.svg';
import more_horiz from '../icon-svgs/more_horiz.svg';
import ms_teams from '../icon-svgs/ms_teams.svg';
import multi_asset from '../icon-svgs/multi_asset.svg';
import new_in_branch from '../icon-svgs/new_in_branch.svg';
import nightlight from '../icon-svgs/nightlight.svg';
import no_access from '../icon-svgs/no_access.svg';
import observation from '../icon-svgs/observation.svg';
Expand Down Expand Up @@ -310,6 +311,7 @@ export const Icons = {
menu,
menu_book,
more_horiz,
new_in_branch,
nightlight,
no_access,
people,
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions js_modules/dagster-ui/packages/ui-core/src/app/Flags.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ export const FeatureFlag = {
flagDisableAutoLoadDefaults: 'flagDisableAutoLoadDefaults' as const,
flagUseNewAutomationPage: 'flagUseNewAutomationPage' as const,
flagUseNewOverviewPage: 'flagUseNewOverviewPage' as const,
flagExperimentalBranchDiff: 'flagExperimentalBranchDiff' as const,
};
export type FeatureFlagType = keyof typeof FeatureFlag;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,7 @@ export const ASSET_NODE_LIVE_FRAGMENT = gql`
}
}
}
changedReasons
freshnessInfo {
...AssetNodeLiveFreshnessInfo
}
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@ import {AssetNodeFragment} from './types/AssetNode.types';
import {withMiddleTruncation} from '../app/Util';
import {useAssetLiveData} from '../asset-data/AssetLiveDataProvider';
import {PartitionCountTags} from '../assets/AssetNodePartitionCounts';
import {StaleReasonsTags} from '../assets/Stale';
import {ChangedReasonsTag, MinimalNodeChangedDot} from '../assets/ChangedReasons';
import {MinimalNodeStaleDot, StaleReasonsTag, isAssetStale} from '../assets/Stale';
import {AssetChecksStatusSummary} from '../assets/asset-checks/AssetChecksStatusSummary';
import {assetDetailsPathForKey} from '../assets/assetDetailsPathForKey';
import {AssetComputeKindTag} from '../graph/OpTags';
Expand All @@ -34,7 +35,13 @@ export const AssetNode = React.memo(({definition, selected}: Props) => {

return (
<AssetInsetForHoverEffect>
<AssetTopTags definition={definition} liveData={liveData} />
<Box flex={{direction: 'row', justifyContent: 'space-between', alignItems: 'center'}}>
<StaleReasonsTag liveData={liveData} assetKey={definition.assetKey} include="upstream" />
<ChangedReasonsTag
changedReasons={liveData?.changedReasons}
assetKey={definition.assetKey}
/>
</Box>
<AssetNodeContainer $selected={selected}>
<AssetNodeBox $selected={selected} $isSource={isSource}>
<AssetName $isSource={isSource}>
Expand Down Expand Up @@ -63,7 +70,6 @@ export const AssetNode = React.memo(({definition, selected}: Props) => {
{definition.isPartitioned && !definition.isSource && (
<PartitionCountTags definition={definition} liveData={liveData} />
)}
<StaleReasonsTags liveData={liveData} assetKey={definition.assetKey} include="self" />
</Box>

<AssetNodeStatusRow definition={definition} liveData={liveData} />
Expand All @@ -77,17 +83,6 @@ export const AssetNode = React.memo(({definition, selected}: Props) => {
);
}, isEqual);

interface AssetTopTagsProps {
definition: AssetNodeFragment;
liveData?: LiveDataForNode;
}

const AssetTopTags = ({definition, liveData}: AssetTopTagsProps) => (
<Box flex={{gap: 4}} padding={{left: 4}} style={{height: 24}}>
<StaleReasonsTags liveData={liveData} assetKey={definition.assetKey} include="upstream" />
</Box>
);

const AssetNodeRowBox = styled(Box)`
white-space: nowrap;
line-height: 12px;
Expand Down Expand Up @@ -181,6 +176,9 @@ export const AssetNodeMinimal = ({
const {border, background} = buildAssetNodeStatusContent({assetKey, definition, liveData});
const displayName = assetKey.path[assetKey.path.length - 1]!;

const isChanged = liveData?.changedReasons?.length;
const isStale = isAssetStale(liveData);

return (
<AssetInsetForHoverEffect>
<MinimalAssetNodeContainer $selected={selected} style={{paddingTop: height / 2 - 50}}>
Expand All @@ -196,6 +194,15 @@ export const AssetNodeMinimal = ({
$background={background}
$border={border}
>
{isChanged ? (
<MinimalNodeChangedDot
changedReasons={liveData.changedReasons!}
assetKey={assetKey}
/>
) : null}
{isStale ? (
<MinimalNodeStaleDot assetKey={assetKey} liveData={liveData} include="upstream" />
) : null}
<AssetNodeSpinnerContainer>
<AssetLatestRunSpinner liveData={liveData} purpose="section" />
</AssetNodeSpinnerContainer>
Expand All @@ -219,6 +226,7 @@ export const ASSET_NODE_FRAGMENT = gql`
graphName
hasMaterializePermission
jobNames
changedReasons
opNames
opVersion
description
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ import {
AssetNodeLiveMaterializationFragment,
AssetNodeLiveObservationFragment,
} from '../asset-data/types/AssetLiveDataProvider.types';
import {RunStatus, StaleStatus} from '../graphql/types';
import {ChangeReason, RunStatus, StaleStatus} from '../graphql/types';

/**
* IMPORTANT: This file is used by the WebWorker so make sure we don't indirectly import React or anything that relies on window/document
Expand Down Expand Up @@ -154,6 +154,7 @@ export interface LiveDataForNode {
staleStatus: StaleStatus | null;
staleCauses: AssetGraphLiveQuery['assetNodes'][0]['staleCauses'];
assetChecks: AssetCheckLiveFragment[];
changedReasons?: Array<ChangeReason>;
partitionStats: {
numMaterialized: number;
numMaterializing: number;
Expand All @@ -165,6 +166,7 @@ export interface LiveDataForNode {

export const MISSING_LIVE_DATA: LiveDataForNode = {
unstartedRunIds: [],
changedReasons: [],
inProgressRunIds: [],
runWhichFailedToMaterialize: null,
freshnessInfo: null,
Expand Down Expand Up @@ -217,6 +219,7 @@ export const buildLiveDataForNode = (

return {
lastMaterialization,
changedReasons: assetNode.changedReasons,
lastMaterializationRunStatus:
latestRunForAsset && lastMaterialization?.runId === latestRunForAsset?.id
? latestRunForAsset.status
Expand Down
Loading

0 comments on commit 0ba71d1

Please sign in to comment.