diff --git a/packages/console/package.json b/packages/console/package.json index 2bee7a2a1..c58761761 100644 --- a/packages/console/package.json +++ b/packages/console/package.json @@ -105,6 +105,7 @@ "react-loading-skeleton": "^1.1.2", "react-query": "3.3.0", "react-query-devtools": "3.0.0-beta.1", + "react-syntax-highlighter": "^15.5.0", "react-virtualized": "^9.21.1", "shallowequal": "^1.1.0", "url-search-params": "^0.10.0", diff --git a/packages/console/src/components/Executions/ExecutionDetails/ExecutionNodeURL.tsx b/packages/console/src/components/Executions/ExecutionDetails/ExecutionNodeURL.tsx new file mode 100644 index 000000000..fdabb6618 --- /dev/null +++ b/packages/console/src/components/Executions/ExecutionDetails/ExecutionNodeURL.tsx @@ -0,0 +1,65 @@ +import * as React from 'react'; +import { Core } from '@flyteorg/flyteidl-types'; +import { Button } from '@material-ui/core'; +import { Prism as SyntaxHighlighter } from 'react-syntax-highlighter'; +import { darcula } from 'react-syntax-highlighter/dist/esm/styles/prism'; + +/** Fetches and renders the deck data for a given `nodeExecutionId` */ +export const ExecutionNodeURL: React.FC<{ + nodeExecutionId: Core.NodeExecutionIdentifier; + suffix: string; +}> = ({ nodeExecutionId, suffix }) => { + const project = nodeExecutionId.executionId?.project; + const domain = nodeExecutionId.executionId?.domain; + const executionName = nodeExecutionId.executionId?.name; + const nodeId = nodeExecutionId.nodeId; + const url = `flyte://v1/${project}/${domain}/${executionName}/${nodeId}/${suffix}`; + const code = `from flytekit.remote.remote import FlyteRemote +from flytekit.configuration import Config +rr = FlyteRemote( + Config.auto(config_file="~/.flyte/config.yaml"), + default_project="${project}", + default_domain="${domain}", +) +url = "${url}" +rr.get(url)`; + const handleClick = event => { + if (event.shiftKey) { + navigator.clipboard.writeText(code); + } else { + navigator.clipboard.writeText(url); + } + }; + + const logoStyle = { + width: '20px', + height: '20px', + }; + + const codeStyle = { + fontSize: '10px', // Adjust the font size as desired + }; + + return ( + <> + +
+ navigator.clipboard.writeText(code)} + > + {code} + +
+ + ); +}; diff --git a/packages/console/src/components/Executions/ExecutionDetails/NodeExecutionTabs/NodeExecutionInputs.tsx b/packages/console/src/components/Executions/ExecutionDetails/NodeExecutionTabs/NodeExecutionInputs.tsx index 02c92329f..0959c363c 100644 --- a/packages/console/src/components/Executions/ExecutionDetails/NodeExecutionTabs/NodeExecutionInputs.tsx +++ b/packages/console/src/components/Executions/ExecutionDetails/NodeExecutionTabs/NodeExecutionInputs.tsx @@ -4,6 +4,7 @@ import { useNodeExecutionData } from 'components/hooks/useNodeExecution'; import { LiteralMapViewer } from 'components/Literals/LiteralMapViewer'; import { NodeExecution } from 'models/Execution/types'; import * as React from 'react'; +import { ExecutionNodeURL } from '../ExecutionNodeURL'; /** Fetches and renders the input data for a given `NodeExecution` */ export const NodeExecutionInputs: React.FC<{ @@ -11,6 +12,7 @@ export const NodeExecutionInputs: React.FC<{ taskIndex?: number; }> = ({ execution, taskIndex }) => { const executionData = useNodeExecutionData(execution.id); + return ( @@ -18,6 +20,10 @@ export const NodeExecutionInputs: React.FC<{ map={executionData.value.fullInputs} mapTaskIndex={taskIndex} /> + ); diff --git a/packages/console/src/components/Executions/ExecutionDetails/NodeExecutionTabs/NodeExecutionOutputs.tsx b/packages/console/src/components/Executions/ExecutionDetails/NodeExecutionTabs/NodeExecutionOutputs.tsx index 0aa836661..b0eac665e 100644 --- a/packages/console/src/components/Executions/ExecutionDetails/NodeExecutionTabs/NodeExecutionOutputs.tsx +++ b/packages/console/src/components/Executions/ExecutionDetails/NodeExecutionTabs/NodeExecutionOutputs.tsx @@ -4,6 +4,7 @@ import { useNodeExecutionData } from 'components/hooks/useNodeExecution'; import { LiteralMapViewer } from 'components/Literals/LiteralMapViewer'; import { NodeExecution } from 'models/Execution/types'; import * as React from 'react'; +import { ExecutionNodeURL } from '../ExecutionNodeURL'; /** Fetches and renders the output data for a given `NodeExecution` */ export const NodeExecutionOutputs: React.FC<{ @@ -11,6 +12,7 @@ export const NodeExecutionOutputs: React.FC<{ taskIndex?: number; }> = ({ execution, taskIndex }) => { const executionData = useNodeExecutionData(execution.id); + return ( @@ -18,6 +20,10 @@ export const NodeExecutionOutputs: React.FC<{ map={executionData.value.fullOutputs} mapTaskIndex={taskIndex} /> + ); diff --git a/yarn.lock b/yarn.lock index 910e383ff..ae2cf92a5 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2132,6 +2132,7 @@ __metadata: react-loading-skeleton: ^1.1.2 react-query: 3.3.0 react-query-devtools: 3.0.0-beta.1 + react-syntax-highlighter: ^15.5.0 react-virtualized: ^9.21.1 shallowequal: ^1.1.0 url-search-params: ^0.10.0 @@ -11351,6 +11352,15 @@ __metadata: languageName: node linkType: hard +"fault@npm:^1.0.0": + version: 1.0.4 + resolution: "fault@npm:1.0.4" + dependencies: + format: ^0.2.0 + checksum: 5ac610d8b09424e0f2fa8cf913064372f2ee7140a203a79957f73ed557c0e79b1a3d096064d7f40bde8132a69204c1fe25ec23634c05c6da2da2039cff26c4e7 + languageName: node + linkType: hard + "faye-websocket@npm:^0.11.3": version: 0.11.4 resolution: "faye-websocket@npm:0.11.4" @@ -11851,6 +11861,13 @@ __metadata: languageName: node linkType: hard +"format@npm:^0.2.0": + version: 0.2.2 + resolution: "format@npm:0.2.2" + checksum: 646a60e1336250d802509cf24fb801e43bd4a70a07510c816fa133aa42cdbc9c21e66e9cc0801bb183c5b031c9d68be62e7fbb6877756e52357850f92aa28799 + languageName: node + linkType: hard + "forwarded@npm:0.2.0": version: 0.2.0 resolution: "forwarded@npm:0.2.0" @@ -12655,6 +12672,13 @@ __metadata: languageName: node linkType: hard +"highlight.js@npm:^10.4.1, highlight.js@npm:~10.7.0": + version: 10.7.3 + resolution: "highlight.js@npm:10.7.3" + checksum: defeafcd546b535d710d8efb8e650af9e3b369ef53e28c3dc7893eacfe263200bba4c5fcf43524ae66d5c0c296b1af0870523ceae3e3104d24b7abf6374a4fea + languageName: node + linkType: hard + "history@npm:^4.9.0": version: 4.10.1 resolution: "history@npm:4.10.1" @@ -15540,6 +15564,16 @@ __metadata: languageName: node linkType: hard +"lowlight@npm:^1.17.0": + version: 1.20.0 + resolution: "lowlight@npm:1.20.0" + dependencies: + fault: ^1.0.0 + highlight.js: ~10.7.0 + checksum: 14a1815d6bae202ddee313fc60f06d46e5235c02fa483a77950b401d85b4c1e12290145ccd17a716b07f9328bd5864aa2d402b6a819ff3be7c833d9748ff8ba7 + languageName: node + linkType: hard + "lru-cache@npm:^5.1.1": version: 5.1.1 resolution: "lru-cache@npm:5.1.1" @@ -18170,6 +18204,20 @@ __metadata: languageName: node linkType: hard +"prismjs@npm:^1.27.0": + version: 1.29.0 + resolution: "prismjs@npm:1.29.0" + checksum: 007a8869d4456ff8049dc59404e32d5666a07d99c3b0e30a18bd3b7676dfa07d1daae9d0f407f20983865fd8da56de91d09cb08e6aa61f5bc420a27c0beeaf93 + languageName: node + linkType: hard + +"prismjs@npm:~1.27.0": + version: 1.27.0 + resolution: "prismjs@npm:1.27.0" + checksum: 85c7f4a3e999073502cc9e1882af01e3709706369ec254b60bff1149eda701f40d02512acab956012dc7e61cfd61743a3a34c1bd0737e8dbacd79141e5698bbc + languageName: node + linkType: hard + "proc-log@npm:^3.0.0": version: 3.0.0 resolution: "proc-log@npm:3.0.0" @@ -18884,6 +18932,21 @@ __metadata: languageName: node linkType: hard +"react-syntax-highlighter@npm:^15.5.0": + version: 15.5.0 + resolution: "react-syntax-highlighter@npm:15.5.0" + dependencies: + "@babel/runtime": ^7.3.1 + highlight.js: ^10.4.1 + lowlight: ^1.17.0 + prismjs: ^1.27.0 + refractor: ^3.6.0 + peerDependencies: + react: ">= 0.14.0" + checksum: c082b48f30f8ba8d0c55ed1d761910630860077c7ff5793c4c912adcb5760df06436ed0ad62be0de28113aac9ad2af55eccd995f8eee98df53382e4ced2072fb + languageName: node + linkType: hard + "react-textarea-autosize@npm:^8.3.2": version: 8.4.0 resolution: "react-textarea-autosize@npm:8.4.0" @@ -19130,6 +19193,17 @@ __metadata: languageName: node linkType: hard +"refractor@npm:^3.6.0": + version: 3.6.0 + resolution: "refractor@npm:3.6.0" + dependencies: + hastscript: ^6.0.0 + parse-entities: ^2.0.0 + prismjs: ~1.27.0 + checksum: 39b01c4168c77c5c8486f9bf8907bbb05f257f15026057ba5728535815a2d90eed620468a4bfbb2b8ceefbb3ce3931a1be8b17152dbdbc8b0eef92450ff750a2 + languageName: node + linkType: hard + "regenerate-unicode-properties@npm:^10.1.0": version: 10.1.0 resolution: "regenerate-unicode-properties@npm:10.1.0"