Skip to content

Commit

Permalink
feat(search): visualize compute and storage kind tags in search results
Browse files Browse the repository at this point in the history
  • Loading branch information
rexledesma committed Jun 7, 2024
1 parent a804e08 commit 29bd967
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import {
linkToAssetTableWithStorageKindFilter,
} from '../search/useGlobalSearch';

export const isCanonicalComputeKindTag = (tag: DefinitionTag) => tag.key === 'dagster/compute_kind';
export const isCanonicalStorageKindTag = (tag: DefinitionTag) => tag.key === 'dagster/storage_kind';
export const buildStorageKindTag = (storageKind: string): DefinitionTag =>
buildDefinitionTag({key: 'dagster/storage_kind', value: storageKind});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ import {
SearchResultType,
isAssetFilterSearchResultType,
} from './types';
import {isCanonicalComputeKindTag, isCanonicalStorageKindTag} from '../graph/KindTags';
import {TagIcon, KNOWN_TAGS} from '../graph/OpTags';

const iconForType = (type: SearchResultType | AssetFilterSearchResultType): IconName => {
switch (type) {
Expand Down Expand Up @@ -121,6 +123,47 @@ function buildSearchLabel(result: Fuse.FuseResult<SearchResult>): JSX.Element[]
return labelComponents;
}

function buildSearchIcons(item: SearchResult, isHighlight: boolean): JSX.Element[] {
const icons = [];

if (item.type == SearchResultType.Asset) {
const computeKindTag = item.tags?.find(isCanonicalComputeKindTag);
if (computeKindTag && KNOWN_TAGS[computeKindTag.value]) {
const computeKindSearchIcon = <TagIcon label={computeKindTag.value} />;

icons.push(computeKindSearchIcon);
}

const storageKindTag = item.tags?.find(isCanonicalStorageKindTag);
if (storageKindTag && KNOWN_TAGS[storageKindTag.value]) {
const storageKindSearchIcon = <TagIcon label={storageKindTag.value} />;

icons.push(storageKindSearchIcon);
}
}

if (item.type == AssetFilterSearchResultType.ComputeKind) {
if (KNOWN_TAGS[item.label]) {
const computeKindSearchIcon = <TagIcon label={item.label} />;

icons.push(computeKindSearchIcon);
}
}

if (icons.length == 0) {
const defaultSearchIcon = (
<Icon
name={iconForType(item.type)}
color={isHighlight ? Colors.textDefault() : Colors.textLight()}
/>
);

icons.push(defaultSearchIcon);
}

return icons;
}

export const SearchResultItem = React.memo(({isHighlight, onClickResult, result}: ItemProps) => {
const {item} = result;
const element = React.useRef<HTMLLIElement>(null);
Expand Down Expand Up @@ -152,11 +195,8 @@ export const SearchResultItem = React.memo(({isHighlight, onClickResult, result}
$interactive={false}
$textColor={Colors.textDefault()}
>
<Box flex={{gap: 4}}>
<Icon
name={iconForType(item.type)}
color={isHighlight ? Colors.textDefault() : Colors.textLight()}
/>
<Box flex={{direction: 'row', gap: 4, alignItems: 'center'}}>
{buildSearchIcons(item, isHighlight)}
{isAssetFilterSearchResultType(item.type) && (
<Caption>{assetFilterPrefixString(item.type)}:</Caption>
)}
Expand Down
3 changes: 2 additions & 1 deletion js_modules/dagster-ui/packages/ui-core/src/search/types.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import Fuse from 'fuse.js';
import {DefinitionTag} from '../graphql/types';

export enum SearchResultType {
AssetGroup,
Expand Down Expand Up @@ -43,7 +44,7 @@ export type SearchResult = {
description: string;
href: string;
type: SearchResultType | AssetFilterSearchResultType;
tags?: string;
tags?: DefinitionTag[];
numResults?: number;
repoPath?: string;
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@ import {CloudOSSContext} from '../app/CloudOSSContext';
import {PYTHON_ERROR_FRAGMENT} from '../app/PythonErrorFragment';
import {displayNameForAssetKey, isHiddenAssetGroupJob} from '../asset-graph/Utils';
import {assetDetailsPathForKey} from '../assets/assetDetailsPathForKey';
import {buildStorageKindTag} from '../graph/KindTags';
import {DefinitionTag} from '../graphql/types';
import {buildStorageKindTag, isCanonicalStorageKindTag} from '../graph/KindTags';
import {DefinitionTag, buildDefinitionTag} from '../graphql/types';
import {buildTagString} from '../ui/tagAsString';
import {buildRepoPathForHuman} from '../workspace/buildRepoAddress';
import {repoAddressAsURLString} from '../workspace/repoAddressAsString';
Expand Down Expand Up @@ -192,20 +192,24 @@ const secondaryDataToSearchResults = (

const {nodes} = data.assetsOrError;

const assets = nodes
const assets: SearchResult[] = nodes
.filter(({definition}) => definition !== null)
.map(({key, definition}) => {
return {
label: displayNameForAssetKey(key),
href: assetDetailsPathForKey(key),
segments: key.path,
description: `Asset in ${buildRepoPathForHuman(
definition!.repository.name,
definition!.repository.location.name,
)}`,
type: SearchResultType.Asset,
};
});
.map(({key, definition}) => ({
label: displayNameForAssetKey(key),
description: `Asset in ${buildRepoPathForHuman(
definition!.repository.name,
definition!.repository.location.name,
)}`,
href: assetDetailsPathForKey(key),
type: SearchResultType.Asset,
tags: definition!.tags
.filter(isCanonicalStorageKindTag)
.concat(
definition!.computeKind
? buildDefinitionTag({key: 'dagster/compute_kind', value: definition!.computeKind})
: [],
),
}));

if (!includeAssetFilters) {
return [...assets];
Expand Down

0 comments on commit 29bd967

Please sign in to comment.