Skip to content

Commit

Permalink
fix: remove tag when DoubleTag's label has empty children
Browse files Browse the repository at this point in the history
  • Loading branch information
agatha197 committed Nov 8, 2024
1 parent d286c90 commit 2c6d6e1
Show file tree
Hide file tree
Showing 15 changed files with 126 additions and 145 deletions.
29 changes: 17 additions & 12 deletions react/src/components/AgentList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import { useBAIPaginationOptionState } from '../hooks/reactPaginationQueryOption
import { useThemeMode } from '../hooks/useThemeMode';
import AgentDetailModal from './AgentDetailModal';
import AgentSettingModal from './AgentSettingModal';
import BAIIntervalText from './BAIIntervalText';
import BAIIntervalView from './BAIIntervalView';
import BAIProgressWithLabel from './BAIProgressWithLabel';
import BAIPropertyFilter from './BAIPropertyFilter';
import DoubleTag from './DoubleTag';
Expand Down Expand Up @@ -247,16 +247,21 @@ const AgentList: React.FC<AgentListProps> = ({
return (
<Flex direction="column">
<Typography.Text>{dayjs(value).format('ll LTS')}</Typography.Text>
<DoubleTag
values={[
t('agent.Running'),
<BAIIntervalText
callback={() => {
return baiClient.utils.elapsedTime(value, Date.now());
}}
delay={1000}
/>,
]}
<BAIIntervalView
callback={() => {
return baiClient.utils.elapsedTime(value, Date.now());
}}
delay={1000}
render={(intervalValue) => (
<DoubleTag
values={[
{ label: t('agent.Running') },
{
label: intervalValue,
},
]}
/>
)}
/>
</Flex>
);
Expand Down Expand Up @@ -640,7 +645,7 @@ const AgentList: React.FC<AgentListProps> = ({
values={[
{ label: 'Agent' },
{
label: record?.version,
label: record?.version as string,
color:
value === 'ALIVE'
? 'green'
Expand Down
15 changes: 4 additions & 11 deletions react/src/components/AliasedImageDoubleTags.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { useBackendAIImageMetaData } from '../hooks';
import DoubleTag, { DoubleTagObjectValue } from './DoubleTag';
import Flex from './Flex';
import TextHighlighter from './TextHighlighter';
import { AliasedImageDoubleTagsFragment$key } from './__generated__/AliasedImageDoubleTagsFragment.graphql';
import graphql from 'babel-plugin-relay/macro';
import _ from 'lodash';
Expand Down Expand Up @@ -50,20 +49,14 @@ const AliasedImageDoubleTags: React.FC<AliasedImageDoubleTagsProps> = ({
key={tag.key}
values={[
{
label: (
<TextHighlighter keyword={highlightKeyword} key={tag.key}>
{tagAlias(tag.key)}
</TextHighlighter>
),
label: tagAlias(tag.key),
color: isCustomized ? 'cyan' : doubleTagProps.color,
highlightKeyword: highlightKeyword,
},
{
label: (
<TextHighlighter keyword={highlightKeyword} key={tagValue}>
{tagValue}
</TextHighlighter>
),
label: tagValue ?? '',
color: isCustomized ? 'cyan' : doubleTagProps.color,
highlightKeyword: highlightKeyword,
},
]}
{...doubleTagProps}
Expand Down
13 changes: 0 additions & 13 deletions react/src/components/BAIIntervalText.tsx

This file was deleted.

21 changes: 21 additions & 0 deletions react/src/components/BAIIntervalView.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import { useIntervalValue } from '../hooks/useIntervalValue';
import _ from 'lodash';
import React from 'react';

type RenderProp<T> = (data: T) => React.ReactNode;
const BAIIntervalView = <T,>({
callback,
render,
delay,
triggerKey,
}: {
callback: () => T;
render?: RenderProp<T>;
delay: number;
triggerKey?: string;
}) => {
const value = useIntervalValue(callback, delay, triggerKey);
return _.isUndefined(render) ? value : render(value);
};

export default BAIIntervalView;
4 changes: 2 additions & 2 deletions react/src/components/BatchSessionScheduledTimeSetting.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import BAIIntervalText from './BAIIntervalText';
import BAIIntervalView from './BAIIntervalView';
import DatePickerISO, { DatePickerISOProps } from './DatePickerISO';
import { useWebComponentInfo } from './DefaultProviders';
import Flex from './Flex';
Expand Down Expand Up @@ -86,7 +86,7 @@ const BatchSessionScheduledTimeSetting: React.FC<Props> = ({
style={{ fontSize: token.fontSizeSM - 2 }}
>
({t('session.launcher.StartAfter')}
<BAIIntervalText
<BAIIntervalView
callback={() => {
return dayjs(scheduleTime).fromNow();
}}
Expand Down
35 changes: 19 additions & 16 deletions react/src/components/ComputeSessionNodeItems/SessionReservation.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { useSuspendedBackendaiClient } from '../../hooks';
import BAIIntervalText from '../BAIIntervalText';
import BAIIntervalView from '../BAIIntervalView';
import DoubleTag from '../DoubleTag';
import { SessionReservationFragment$key } from './__generated__/SessionReservationFragment.graphql';
import graphql from 'babel-plugin-relay/macro';
Expand All @@ -26,21 +26,24 @@ const SessionReservation: React.FC<{
return (
<>
{dayjs(session.created_at).format('lll')}
<DoubleTag
values={[
t('session.ElapsedTime'),
<BAIIntervalText
callback={() => {
return session?.created_at
? baiClient.utils.elapsedTime(
session.created_at,
session?.terminated_at,
)
: '-';
}}
delay={1000}
/>,
]}
<BAIIntervalView
callback={() => {
return session?.created_at
? baiClient.utils.elapsedTime(
session.created_at,
session?.terminated_at,
)
: '-';
}}
delay={1000}
render={(intervalValue) => (
<DoubleTag
values={[
{ label: t('session.ElapsedTime') },
{ label: intervalValue },
]}
/>
)}
/>
</>
);
Expand Down
2 changes: 1 addition & 1 deletion react/src/components/CustomizedImageList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -284,8 +284,8 @@ const CustomizedImageList: React.FC<PropsWithChildren> = ({ children }) => {
render: (text, row) => (
<AliasedImageDoubleTags
imageFrgmt={row}
label={undefined}
highlightKeyword={imageSearch}
label={''}
/>
),
},
Expand Down
25 changes: 16 additions & 9 deletions react/src/components/DoubleTag.tsx
Original file line number Diff line number Diff line change
@@ -1,19 +1,20 @@
import Flex from './Flex';
import TextHighlighter from './TextHighlighter';
import { Tag } from 'antd';
import _ from 'lodash';
import React from 'react';

export type DoubleTagObjectValue = {
label: ValueType;
label: string;
color?: string;
highlightKeyword?: string;
};

type ValueType = string | React.ReactNode;
const DoubleTag: React.FC<{
values?: ValueType[] | DoubleTagObjectValue[];
values?: Array<string> | Array<DoubleTagObjectValue>;
}> = ({ values = [] }) => {
if (values.length === 0) return null;
let objectValues: DoubleTagObjectValue[];
let objectValues: Array<DoubleTagObjectValue>;
if (
values[0] &&
(typeof values[0] === 'string' || React.isValidElement(values[0]))
Expand All @@ -31,8 +32,8 @@ const DoubleTag: React.FC<{

return (
<Flex direction="row">
{_.map(objectValues, (objValue, idx) => {
return !_.isEmpty(objValue.label) ? (
{_.map(objectValues, (objValue, idx) =>
!_.isEmpty(objValue.label) ? (
<Tag
key={idx}
style={
Expand All @@ -42,10 +43,16 @@ const DoubleTag: React.FC<{
}
color={objValue.color}
>
{objValue.label}
{!_.isEmpty(objValue.highlightKeyword) ? (
<TextHighlighter keyword={objValue.highlightKeyword}>
{objValue.label}
</TextHighlighter>
) : (
objValue.label
)}
</Tag>
) : null;
})}
) : null,
)}
</Flex>
);
};
Expand Down
52 changes: 12 additions & 40 deletions react/src/components/ImageEnvironmentSelectFormItems.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -651,14 +651,10 @@ const ImageEnvironmentSelectFormItems: React.FC<
':',
).map((str) => {
extraFilterValues.push(str);
return (
<TextHighlighter
keyword={versionSearch}
key={str}
>
{str}
</TextHighlighter>
);
return {
label: str,
highlightKeyword: versionSearch,
};
})}
/>
))
Expand All @@ -684,26 +680,14 @@ const ImageEnvironmentSelectFormItems: React.FC<
key={requirementTags.length + 1}
values={[
{
label: (
<TextHighlighter
keyword={versionSearch}
key="Customized"
>
Customized
</TextHighlighter>
),
label: 'Customized',
color: 'cyan',
highlightKeyword: versionSearch,
},
{
label: (
<TextHighlighter
keyword={versionSearch}
key={tag}
>
{tag}
</TextHighlighter>
),
label: tag ?? '',
color: 'cyan',
highlightKeyword: versionSearch,
},
]}
/>,
Expand Down Expand Up @@ -750,26 +734,14 @@ const ImageEnvironmentSelectFormItems: React.FC<
key={tag.key}
values={[
{
label: (
<TextHighlighter
keyword={versionSearch}
key={tag.key}
>
{tagAlias(tag.key)}
</TextHighlighter>
),
label: tagAlias(tag.key),
color: isCustomized ? 'cyan' : 'blue',
highlightKeyword: versionSearch,
},
{
label: (
<TextHighlighter
keyword={versionSearch}
key={tagValue}
>
{tagValue}
</TextHighlighter>
),
label: tagValue ?? '',
color: isCustomized ? 'cyan' : 'blue',
highlightKeyword: versionSearch,
},
]}
/>
Expand Down
14 changes: 4 additions & 10 deletions react/src/components/ImageList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -229,20 +229,14 @@ const ImageList: React.FC<{ style?: React.CSSProperties }> = ({ style }) => {
key={tag.key}
values={[
{
label: (
<TextHighlighter keyword={imageSearch} key={tag.key}>
{tagAlias(tag.key)}
</TextHighlighter>
),
label: tagAlias(tag.key),
color: isCustomized ? 'cyan' : 'blue',
highlightKeyword: imageSearch,
},
{
label: (
<TextHighlighter keyword={imageSearch} key={tagValue}>
{tagValue}
</TextHighlighter>
),
label: tagValue ?? '',
color: isCustomized ? 'cyan' : 'blue',
highlightKeyword: imageSearch,
},
]}
/>
Expand Down
14 changes: 4 additions & 10 deletions react/src/components/ImageTags.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -122,20 +122,14 @@ export const ConstraintTags: React.FC<ConstraintTagsProps> = ({
color="cyan"
values={[
{
label: (
<TextHighlighter keyword={highlightKeyword}>
Customized
</TextHighlighter>
),
label: 'Customized',
color: 'cyan',
highlightKeyword: highlightKeyword,
},
{
label: (
<TextHighlighter keyword={highlightKeyword}>
{constraints[1]}
</TextHighlighter>
),
label: constraints[1],
color: 'cyan',
highlightKeyword: highlightKeyword,
},
]}
{...props}
Expand Down
Loading

0 comments on commit 2c6d6e1

Please sign in to comment.