Skip to content
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

NodeExecutionRow refactor #610

Merged
merged 102 commits into from
Oct 12, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
102 commits
Select commit Hold shift + click to select a range
286e1f8
chore: move src to a new location
anrusina Apr 24, 2022
0efd1df
ci: allow branch to be built again
anrusina Apr 24, 2022
b49fed5
chore: replace link to github repository to a proper one
anrusina Apr 25, 2022
9503a4c
ci: basic test and test-coverage setup
anrusina Apr 25, 2022
3091c4b
chore: add first plugin package
anrusina Apr 25, 2022
3573659
chore: allow to start test from main directory
anrusina Apr 25, 2022
8d1fef9
ci: update lowest mkdirp version (#423)
anrusina Apr 25, 2022
48a1c92
chore: add build scripts for console app (#429)
ursucarina Apr 26, 2022
caaf5c2
fix: hide the legend (#435)
eugenejahn Apr 28, 2022
133038a
ci: move storybook related packages to top level (#434)
anrusina Apr 28, 2022
1651a6f
fix: fix issue 386 (#437)
eugenejahn Apr 28, 2022
eeb551b
ci: ensure unified tsconfig and remove mocks, test, stories from buil…
anrusina Apr 28, 2022
b6e9941
Make whole row clickable to open TaskExecutionDetails panel (#444)
eugenejahn May 2, 2022
b513280
ci: allow to start jest config for all project at once (#447)
anrusina May 3, 2022
ecfdd4c
minor: unable to view all the workflow versions (#446)
ursucarina May 4, 2022
5b44539
chore(tsc): exclude test/stories/mock files only from build (#451)
anrusina May 5, 2022
560b645
ci: ensure that webpack too doesn't include test/mock/specs files (#452)
anrusina May 6, 2022
5e2bcbc
minor: add support for StructuredDataSet Input/Output type (#445)
ursucarina May 6, 2022
86d5636
chore: Provide basic repo structure and ensure that stories, tests, v…
anrusina May 11, 2022
acf3cb9
ci: minimize babel presence (#457)
anrusina May 11, 2022
38a4e96
fix: update node executions to display map tasks (#455)
olga-union May 13, 2022
c2ee154
ci: resolve docker build issues (#462)
anrusina May 13, 2022
e84a3c0
Chore: Rebase devmain on top of master (#464)
anrusina May 13, 2022
0853680
fix: ensure that admin version is fully shown (#465)
anrusina May 14, 2022
093210b
chore: fix for console not respecting admin url (#468)
ursucarina May 17, 2022
1859cf5
chore: rebase on top of master
anrusina May 17, 2022
42d2632
fix: trigger release #patch (#477)
anrusina May 18, 2022
324b4f5
feat: add task version info (#485)
apTalya May 19, 2022
821299e
chore: update Readme with python note + package version update (#486)
apTalya May 19, 2022
c25daea
hotfix ci pipeline (#487)
yindia May 20, 2022
747b100
[Mapping][TaskInfo] V.2 - Update Task details to allow check informat…
olga-union May 18, 2022
b70d14b
fix: add eventVersion check for map tasks (#484)
olga-union May 19, 2022
7f6305f
fix: resolve minimist package to v1.2.6 (#492)
anrusina May 19, 2022
144349c
ci: add flyte-api plugin package (#490)
anrusina May 19, 2022
64b2793
fix: update/add graph related stories (#493)
olga-union May 23, 2022
7ea0c9f
fix: separate api auth to plugin folder (#495)
anrusina May 25, 2022
4a23f4e
feat: rerun task action in execution page (#488)
eugenejahn May 26, 2022
aaca9db
chore: update release version (#501)
anrusina Jun 2, 2022
d407301
chore(deps-dev): bump protobufjs from 6.8.9 to 6.11.3 (#502)
dependabot[bot] Jun 3, 2022
606e37e
chore: add package generator for basics/composites/plugins (#503)
anrusina Jun 6, 2022
1a0dc0f
fix(bug-508): executions can not be filtered by start time (#509)
anrusina Jun 9, 2022
1013deb
chore(deps-dev): bump semantic-release from 17.2.3 to 19.0.3 (#510)
dependabot[bot] Jun 10, 2022
32686cc
feat: support flyte decks (#504)
james-union Jun 13, 2022
1386b40
feat: navbar navigation dropdown (#511)
anrusina Jun 16, 2022
7606fdf
chore: support internal/external navigsation better (#513)
anrusina Jun 17, 2022
075a1f9
Update Contributing.md (#515)
anrusina Jun 23, 2022
161d7ee
chore: update navigationDropdown usage (#517)
anrusina Jun 23, 2022
32b92b4
chore(deps): bump jsdom from 16.4.0 to 16.7.0 (#516)
dependabot[bot] Jun 23, 2022
c1c386c
feat: launch plans list & detail page #none; (#507)
james-union Jun 27, 2022
54c8ca1
chore: release 1.1.3 (#520)
anrusina Jun 27, 2022
e933f21
fix: cache icon fro map task (#519)
eugenejahn Jun 28, 2022
1be5572
fix: Relaunch form does not persist security context values when chan…
james-union Jun 29, 2022
4006e3b
fix: release process (#529)
yindia Jun 30, 2022
a05e295
fix: fix semantic-release config (#532)
yindia Jul 1, 2022
daf28e6
test: fix time sensitive test (#533)
anrusina Jul 1, 2022
d191445
Rename upgrade idl workflow (#534)
yindia Jul 1, 2022
506b953
fix: support mapped tasks (#494)
james-union Jul 1, 2022
59d5d2a
fix(491): remove favicon package + use favicon.svg by default (#537)
anrusina Jul 1, 2022
7e44dca
Fixed undefined task input types access in NodeExecutionActions (#538)
Jul 6, 2022
f6f8283
feat: support union type for launch plan (#540)
eugenejahn Jul 13, 2022
64440c0
fix: graph has realtime updates as execution progresses (#543)
olga-union Jul 15, 2022
168d383
fix: make sure groups used in graph aren't undefined (#545)
olga-union Jul 19, 2022
7d196cd
Hotfix docker push GHWF (#547)
yindia Jul 20, 2022
e62b43b
fix: Graph Center on initial render (#541)
james-union Jul 20, 2022
28a224e
fix: graph edge overlaps nodes (#542)
james-union Jul 20, 2022
33b1cee
fix: flyteconsole tag in ci pipeline (#550)
yindia Jul 25, 2022
16d70a9
enable docker push for console (#552)
yindia Jul 26, 2022
bcdd464
chore(deps): bump terser from 4.8.0 to 4.8.1 (#548)
dependabot[bot] Jul 26, 2022
3f2bbfb
Update Flyteidl version (#558)
flyte-bot Aug 10, 2022
1f89e2b
fix: fix searchbar X button (#564)
ursucarina Aug 16, 2022
9b10e5f
fix: update timeline view to show dynamic wf internals on first rende…
olga-union Aug 17, 2022
a4bf213
fix: webmanifest missing crossorigin attribute (#566)
ursucarina Aug 17, 2022
cdd94b7
fix: console showing subworkflows as unknown (#570)
olga-union Aug 19, 2022
b6e1e40
fix: Dict value loses 1 trailing character on UI Launch. (#561)
james-union Aug 22, 2022
9c2632a
fix: launchform validation (#557)
james-union Aug 25, 2022
a3bbeb0
fix: integrate timeline and graph tabs wrappers under one component (…
olga-union Aug 31, 2022
e453bfe
chore(deps-dev): bump moment from 2.29.3 to 2.29.4 (#549)
dependabot[bot] Aug 31, 2022
dc1c73f
added none type in union type (#577)
eugenejahn Sep 6, 2022
7e3c6db
fix: correctly coerce `defaultValue` when rendering LaunchPlan detail…
rahul-theorem Sep 6, 2022
f027c43
#minor: inputHelpers InputProps (#579)
ursucarina Sep 7, 2022
afd85bf
fix: fix test of launchform (#581)
james-union Sep 7, 2022
250ab96
Pruning some unused packages (#583)
jsonporter Sep 8, 2022
ce59d55
feat: minor change (#584)
jsonporter Sep 9, 2022
786bced
fix: floor seconds to int in the edge case moment returns it as float…
olga-union Sep 9, 2022
9a1ae4c
Update Flyteidl version (#575)
flyte-bot Sep 12, 2022
a5cad5d
fix: add BASE_URL to dev startup, open deeply nested urls (#589)
ursucarina Sep 13, 2022
6fa1cc1
fix: add default disabled state for only mine filter (#585)
olga-union Sep 14, 2022
64e55be
Update Flyteidl version (#590)
flyte-bot Sep 15, 2022
b9eed42
Launch plan ref v2 (#601)
jsonporter Sep 29, 2022
d649546
fix: enable deeplinks in development (#602)
ursucarina Sep 29, 2022
b9ffd81
chore: release 1.3.5 (#605)
jsonporter Sep 30, 2022
2139738
Merge branch 'master' of https://github.com/flyteorg/flyteconsole int…
olga-union Sep 30, 2022
907363a
Merge branch 'devmain' of https://github.com/flyteorg/flyteconsole in…
olga-union Sep 30, 2022
bf7a750
Merge branch 'devmain' of https://github.com/flyteorg/flyteconsole in…
olga-union Oct 3, 2022
a2e1723
fix: refactor contexts around node executions table and rows
olga-union Oct 3, 2022
d07e461
fix: add missing file
olga-union Oct 3, 2022
1837bc8
fix: add temp row component
olga-union Oct 7, 2022
a91ade8
Merge branch 'devmain' of https://github.com/flyteorg/flyteconsole in…
olga-union Oct 10, 2022
4f11ef3
fix: refactor final touch-ups
olga-union Oct 11, 2022
feafef0
Merge branch 'devmain' of https://github.com/flyteorg/flyteconsole in…
olga-union Oct 11, 2022
0349ffb
fix: add/update unit tests
olga-union Oct 11, 2022
eebfc62
fix: replace getBy with queryBy
olga-union Oct 11, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { NodeExecutionIdentifier } from 'models/Execution/types';
import { createContext } from 'react';

export interface DetailsPanelContextData {
selectedExecution?: NodeExecutionIdentifier | null;
setSelectedExecution: (selectedExecutionId: NodeExecutionIdentifier | null) => void;
}

export const DetailsPanelContext = createContext<DetailsPanelContextData>(
{} as DetailsPanelContextData,
);
Original file line number Diff line number Diff line change
Expand Up @@ -57,11 +57,11 @@ export const ExecutionNodeViews: React.FC<ExecutionNodeViewsProps> = ({ executio
const filterState = useNodeExecutionFiltersState();
const tabState = useTabState(tabs, defaultTab);
const queryClient = useQueryClient();
const requestConfig = useContext(NodeExecutionsRequestConfigContext);
const requestConfig = useContext(NodeExecutionsRequestConfigContext); // Can't find initialization of the provider
const [nodeExecutionsLoading, setNodeExecutionsLoading] = useState<boolean>(true);

const {
closure: { abortMetadata, workflowId },
closure: { workflowId },
} = execution;

const [nodeExecutions, setNodeExecutions] = useState<NodeExecution[]>([]);
Expand Down Expand Up @@ -161,11 +161,7 @@ export const ExecutionNodeViews: React.FC<ExecutionNodeViewsProps> = ({ executio
loadingComponent={LoadingComponent}
>
{() => (
<ExecutionTab
tabType={tabType}
abortMetadata={abortMetadata ?? undefined}
filteredNodeExecutions={nodeExecutionsQuery.data ?? []}
/>
<ExecutionTab tabType={tabType} filteredNodeExecutions={nodeExecutionsQuery.data ?? []} />
)}
</WaitForQuery>
);
Expand All @@ -188,8 +184,8 @@ export const ExecutionNodeViews: React.FC<ExecutionNodeViewsProps> = ({ executio
)}
<WaitForQuery
errorComponent={DataError}
loadingComponent={LoadingComponent}
query={nodeExecutionsQuery}
loadingComponent={LoadingComponent}
>
{() => renderTab(tabState.value)}
</WaitForQuery>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { WaitForQuery } from 'components/common/WaitForQuery';
import { DataError } from 'components/Errors/DataError';
import { makeWorkflowQuery } from 'components/Workflow/workflowQueries';
import { Admin } from 'flyteidl';
import { Workflow } from 'models/Workflow/types';
import * as React from 'react';
import { useQuery, useQueryClient } from 'react-query';
Expand All @@ -12,16 +11,11 @@ import { ExecutionTabContent } from './ExecutionTabContent';

export interface ExecutionTabProps {
tabType: string;
abortMetadata?: Admin.IAbortMetadata;
filteredNodeExecutions: NodeExecution[];
}

/** Contains the available ways to visualize the nodes of a WorkflowExecution */
export const ExecutionTab: React.FC<ExecutionTabProps> = ({
tabType,
abortMetadata,
filteredNodeExecutions,
}) => {
export const ExecutionTab: React.FC<ExecutionTabProps> = ({ tabType, filteredNodeExecutions }) => {
const queryClient = useQueryClient();
const { workflowId } = useNodeExecutionContext();
const workflowQuery = useQuery<Workflow, Error>(makeWorkflowQuery(queryClient, workflowId));
Expand All @@ -30,11 +24,7 @@ export const ExecutionTab: React.FC<ExecutionTabProps> = ({
<ScaleProvider>
<WaitForQuery errorComponent={DataError} query={workflowQuery}>
{() => (
<ExecutionTabContent
tabType={tabType}
abortMetadata={abortMetadata}
filteredNodeExecutions={filteredNodeExecutions}
/>
<ExecutionTabContent tabType={tabType} filteredNodeExecutions={filteredNodeExecutions} />
)}
</WaitForQuery>
</ScaleProvider>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import { WorkflowGraph } from 'components/WorkflowGraph/WorkflowGraph';
import { TaskExecutionPhase } from 'models/Execution/enums';
import { NodeExecution, NodeExecutionIdentifier } from 'models/Execution/types';
import { startNodeId, endNodeId } from 'models/Node/constants';
import { Admin } from 'flyteidl';
import * as React from 'react';
import { transformerWorkflowToDag } from 'components/WorkflowGraph/transformerWorkflowToDag';
import { checkForDynamicExecutions } from 'components/common/utils';
Expand All @@ -17,14 +16,13 @@ import { NodeExecutionsByIdContext } from '../contexts';
import { NodeExecutionsTable } from '../Tables/NodeExecutionsTable';
import { tabs } from './constants';
import { NodeExecutionDetailsPanelContent } from './NodeExecutionDetailsPanelContent';
import { NodeExecutionsTimelineContext } from './Timeline/context';
import { ExecutionTimeline } from './Timeline/ExecutionTimeline';
import { ExecutionTimelineFooter } from './Timeline/ExecutionTimelineFooter';
import { convertToPlainNodes, TimeZone } from './Timeline/helpers';
import { DetailsPanelContext } from './DetailsPanelContext';

export interface ExecutionTabContentProps {
tabType: string;
abortMetadata?: Admin.IAbortMetadata;
filteredNodeExecutions: NodeExecution[];
}

Expand All @@ -43,7 +41,6 @@ const useStyles = makeStyles(() => ({

export const ExecutionTabContent: React.FC<ExecutionTabContentProps> = ({
tabType,
abortMetadata,
filteredNodeExecutions,
}) => {
const styles = useStyles();
Expand Down Expand Up @@ -115,7 +112,7 @@ export const ExecutionTabContent: React.FC<ExecutionTabContentProps> = ({

const handleTimezoneChange = (tz) => setChartTimezone(tz);

const timelineContext = useMemo(
const detailsPanelContext = useMemo(
() => ({ selectedExecution, setSelectedExecution }),
[selectedExecution, setSelectedExecution],
);
Expand All @@ -139,19 +136,14 @@ export const ExecutionTabContent: React.FC<ExecutionTabContentProps> = ({
setSelectedExecution(newSelectedExecution);
};

const onExecutionSelectionChanged = (execution: NodeExecutionIdentifier | null) =>
setSelectedExecution(execution);

const renderContent = () => {
switch (tabType) {
case tabs.timeline.id:
case tabs.nodes.id:
return (
<div className={styles.wrapper}>
<div className={styles.container}>
<ExecutionTimeline chartTimezone={chartTimezone} initialNodes={initialNodes} />
</div>
<ExecutionTimelineFooter onTimezoneChange={handleTimezoneChange} />
</div>
<NodeExecutionsTable
initialNodes={initialNodes}
filteredNodeExecutions={filteredNodeExecutions}
/>
);
case tabs.graph.id:
return (
Expand All @@ -166,15 +158,14 @@ export const ExecutionTabContent: React.FC<ExecutionTabContentProps> = ({
isDetailsTabClosed={isDetailsTabClosed}
/>
);
case tabs.nodes.id:
case tabs.timeline.id:
return (
<NodeExecutionsTable
abortMetadata={abortMetadata}
initialNodes={initialNodes}
selectedExecution={selectedExecution}
setSelectedExecution={onExecutionSelectionChanged}
filteredNodeExecutions={filteredNodeExecutions}
/>
<div className={styles.wrapper}>
<div className={styles.container}>
<ExecutionTimeline chartTimezone={chartTimezone} initialNodes={initialNodes} />
</div>
<ExecutionTimelineFooter onTimezoneChange={handleTimezoneChange} />
</div>
);
default:
return null;
Expand All @@ -183,9 +174,9 @@ export const ExecutionTabContent: React.FC<ExecutionTabContentProps> = ({

return (
<>
<NodeExecutionsTimelineContext.Provider value={timelineContext}>
<DetailsPanelContext.Provider value={detailsPanelContext}>
{renderContent()}
</NodeExecutionsTimelineContext.Provider>
</DetailsPanelContext.Provider>
{/* Side panel, shows information for specific node */}
<DetailsPanel open={!isDetailsTabClosed} onClose={onCloseDetailsPanel}>
{!isDetailsTabClosed && selectedExecution && (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import { useScaleContext } from './scaleContext';
import { TaskNames } from './TaskNames';
import { getChartDurationData } from './TimelineChart/chartData';
import { TimelineChart } from './TimelineChart';
import t from '../strings';

interface StyleProps {
chartWidth: number;
Expand Down Expand Up @@ -165,7 +166,7 @@ export const ExecutionTimeline: React.FC<ExProps> = ({ chartTimezone, initialNod
return (
<>
<div className={styles.taskNames}>
<Typography className={styles.taskNamesHeader}>Task Name</Typography>
<Typography className={styles.taskNamesHeader}>{t('taskNameColumnHeader')}</Typography>
<TaskNames
nodes={showNodes}
ref={taskNamesRef}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,47 +1,86 @@
import { makeStyles, Theme } from '@material-ui/core';
import Typography from '@material-ui/core/Typography';
import { useCommonStyles } from 'components/common/styles';
import { useNodeExecutionContext } from 'components/Executions/contextProvider/NodeExecutionDetails';
import { SelectNodeExecutionLink } from 'components/Executions/Tables/SelectNodeExecutionLink';
import { isEqual } from 'lodash';
import { NodeExecutionPhase } from 'models/Execution/enums';
import { NodeExecution } from 'models/Execution/types';
import * as React from 'react';
import { useContext } from 'react';
import { NodeExecutionsTimelineContext } from './context';
import { useContext, useEffect, useState } from 'react';
import { DetailsPanelContext } from '../DetailsPanelContext';

interface NodeExecutionTimelineNameData {
name: string;
execution: NodeExecution;
templateName?: string;
execution?: NodeExecution;
}

const useStyles = makeStyles((_theme: Theme) => ({
selectedExecutionName: {
fontWeight: 'bold',
},
displayName: {
marginTop: 4,
textOverflow: 'ellipsis',
width: '100%',
overflow: 'hidden',
},
}));

export const NodeExecutionName: React.FC<NodeExecutionTimelineNameData> = ({ name, execution }) => {
export const NodeExecutionName: React.FC<NodeExecutionTimelineNameData> = ({
name,
templateName,
execution,
}) => {
const commonStyles = useCommonStyles();
const styles = useStyles();

const { selectedExecution, setSelectedExecution } = useContext(NodeExecutionsTimelineContext);
const { getNodeExecutionDetails } = useNodeExecutionContext();
const { selectedExecution, setSelectedExecution } = useContext(DetailsPanelContext);
const [displayName, setDisplayName] = useState<string | undefined>();

useEffect(() => {
let isCurrent = true;
getNodeExecutionDetails(execution).then((res) => {
if (isCurrent) {
setDisplayName(res.displayName);
}
});
return () => {
isCurrent = false;
};
});

if (!execution) {
// to avoid crash - disable items which do not have associated execution.
// as we won't be able to provide task info for them anyway.
return <Typography variant="body1">{name}</Typography>;
}

const isSelected = selectedExecution != null && isEqual(execution.id, selectedExecution);
return isSelected ? (
<Typography variant="body1" className={styles.selectedExecutionName}>
{name}
</Typography>
) : (
<SelectNodeExecutionLink
className={commonStyles.primaryLink}
execution={execution}
linkText={name}
setSelectedExecution={setSelectedExecution}
/>

const defaultName = displayName ?? name;
const truncatedName = defaultName?.split('.').pop() || defaultName;

return (
<>
{isSelected || execution.closure.phase === NodeExecutionPhase.UNDEFINED ? (
<Typography variant="body1" className={styles.selectedExecutionName}>
{truncatedName}
</Typography>
) : (
<SelectNodeExecutionLink
className={commonStyles.primaryLink}
execution={execution}
linkText={truncatedName || ''}
setSelectedExecution={setSelectedExecution}
/>
)}
{templateName && (
<Typography variant="subtitle1" color="textSecondary" className={styles.displayName}>
{templateName}
</Typography>
)}
</>
);
};
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import * as React from 'react';
import { IconButton, makeStyles, Theme, Tooltip, Typography } from '@material-ui/core';
import { IconButton, makeStyles, Theme, Tooltip } from '@material-ui/core';

import { RowExpander } from 'components/Executions/Tables/RowExpander';
import { getNodeTemplateName } from 'components/WorkflowGraph/utils';
Expand Down Expand Up @@ -38,12 +38,6 @@ const useStyles = makeStyles((theme: Theme) => ({
height: '100%',
overflow: 'hidden',
},
displayName: {
marginTop: 4,
textOverflow: 'ellipsis',
width: '100%',
overflow: 'hidden',
},
leaf: {
width: 30,
},
Expand All @@ -63,7 +57,6 @@ export const TaskNames = React.forwardRef<HTMLDivElement, TaskNamesProps>(
return (
<div className={styles.taskNamesList} ref={ref} onScroll={onScroll}>
{nodes.map((node) => {
const templateName = getNodeTemplateName(node);
const nodeLevel = node?.level ?? 0;
return (
<div
Expand Down Expand Up @@ -98,15 +91,9 @@ export const TaskNames = React.forwardRef<HTMLDivElement, TaskNamesProps>(
<div className={styles.namesContainerBody}>
<NodeExecutionName
name={node.name}
execution={node.execution!} // some nodes don't have associated execution
templateName={getNodeTemplateName(node)}
execution={node.execution}
/>
<Typography
variant="subtitle1"
color="textSecondary"
className={styles.displayName}
>
{templateName}
</Typography>
</div>
</div>
{onAction && (
Expand Down

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ const str = {
rerun: 'RERUN',
flyteDeck: 'Flyte Deck',
resume: 'Resume',
taskNameColumnHeader: 'Task Name',
};

export { patternKey } from '@flyteconsole/locale';
Expand Down
Loading