From 6184a73d3f07b5c7c7e9b4ea6e4b6d47b9b7d5b4 Mon Sep 17 00:00:00 2001 From: "Ricardo M." Date: Thu, 2 May 2024 17:45:38 +0200 Subject: [PATCH] feat(Canvas): Rename steps context menu items --- .../ui-tests/cypress/support/cypress.d.ts | 2 +- .../cypress/support/next-commands/design.ts | 2 +- .../Visualization/Custom/CustomGroup.tsx | 52 ++++- .../Visualization/Custom/CustomNode.tsx | 130 ++++++++--- .../Visualization/Custom/ItemAddNode.tsx | 58 ----- .../Visualization/Custom/ItemAddStep.tsx | 39 ++++ .../Visualization/Custom/ItemDeleteGroup.tsx | 26 +++ .../Visualization/Custom/ItemDeleteStep.tsx | 25 ++ .../Custom/ItemInsertChildNode.tsx | 54 ----- .../Visualization/Custom/ItemInsertStep.tsx | 44 ++++ .../Visualization/Custom/ItemRemoveGroup.tsx | 29 --- .../Visualization/Custom/ItemRemoveNode.tsx | 24 -- .../Visualization/Custom/ItemReplaceNode.tsx | 39 ---- .../Visualization/Custom/ItemReplaceStep.tsx | 42 ++++ ....timestamp-1714723669439-6cc1a24356891.mjs | 220 ++++++++++++++++++ 15 files changed, 540 insertions(+), 246 deletions(-) delete mode 100644 packages/ui/src/components/Visualization/Custom/ItemAddNode.tsx create mode 100644 packages/ui/src/components/Visualization/Custom/ItemAddStep.tsx create mode 100644 packages/ui/src/components/Visualization/Custom/ItemDeleteGroup.tsx create mode 100644 packages/ui/src/components/Visualization/Custom/ItemDeleteStep.tsx delete mode 100644 packages/ui/src/components/Visualization/Custom/ItemInsertChildNode.tsx create mode 100644 packages/ui/src/components/Visualization/Custom/ItemInsertStep.tsx delete mode 100644 packages/ui/src/components/Visualization/Custom/ItemRemoveGroup.tsx delete mode 100644 packages/ui/src/components/Visualization/Custom/ItemRemoveNode.tsx delete mode 100644 packages/ui/src/components/Visualization/Custom/ItemReplaceNode.tsx create mode 100644 packages/ui/src/components/Visualization/Custom/ItemReplaceStep.tsx create mode 100644 packages/ui/vite.config.js.timestamp-1714723669439-6cc1a24356891.mjs diff --git a/packages/ui-tests/cypress/support/cypress.d.ts b/packages/ui-tests/cypress/support/cypress.d.ts index d9d70da61..1bb79b94a 100644 --- a/packages/ui-tests/cypress/support/cypress.d.ts +++ b/packages/ui-tests/cypress/support/cypress.d.ts @@ -5,7 +5,7 @@ export {}; declare global { - type ActionType = 'append' | 'prepend' | 'replace' | 'insert' | 'insert-special' | 'remove'; + type ActionType = 'append' | 'prepend' | 'replace' | 'insert' | 'insert-special' | 'delete'; namespace Cypress { interface Chainable { diff --git a/packages/ui-tests/cypress/support/next-commands/design.ts b/packages/ui-tests/cypress/support/next-commands/design.ts index dbfd2e1fd..72cffc82e 100644 --- a/packages/ui-tests/cypress/support/next-commands/design.ts +++ b/packages/ui-tests/cypress/support/next-commands/design.ts @@ -43,7 +43,7 @@ Cypress.Commands.add('checkConfigInputObject', (inputName: string, value: string }); Cypress.Commands.add('removeNodeByName', (nodeName: string, nodeIndex?: number) => { - cy.performNodeAction(nodeName, 'remove', nodeIndex); + cy.performNodeAction(nodeName, 'delete', nodeIndex); cy.get(nodeName).should('not.exist'); // wait for the canvas rerender cy.wait(1000); diff --git a/packages/ui/src/components/Visualization/Custom/CustomGroup.tsx b/packages/ui/src/components/Visualization/Custom/CustomGroup.tsx index 38d53ea9c..460ad25f3 100644 --- a/packages/ui/src/components/Visualization/Custom/CustomGroup.tsx +++ b/packages/ui/src/components/Visualization/Custom/CustomGroup.tsx @@ -1,5 +1,8 @@ +import { CodeBranchIcon } from '@patternfly/react-icons'; import { + ContextMenuSeparator, DefaultGroup, + ElementModel, GraphElement, Layer, isNode, @@ -7,11 +10,11 @@ import { withContextMenu, withSelection, } from '@patternfly/react-topology'; -import { FunctionComponent } from 'react'; +import { FunctionComponent, ReactElement } from 'react'; import { AddStepMode } from '../../../models/visualization/base-visual-entity'; import { CanvasNode } from '../Canvas/canvas.models'; -import { ItemInsertChildNode } from './ItemInsertChildNode'; -import { ItemRemoveGroup } from './ItemRemoveGroup'; +import { ItemDeleteGroup } from './ItemDeleteGroup'; +import { ItemInsertStep } from './ItemInsertStep'; type IDefaultGroup = Parameters[0]; interface ICustomGroup extends IDefaultGroup { @@ -45,11 +48,38 @@ const CustomGroup: FunctionComponent = observer(({ element, ...res ); }); -export const CustomGroupWithSelection = withContextMenu(() => [ - , - , -])(withSelection()(CustomGroup)); +export const CustomGroupWithSelection = withSelection()( + withContextMenu((element: GraphElement) => { + const items: ReactElement[] = []; + const vizNode = element.getData()?.vizNode; + if (!vizNode) return items; + + const nodeInteractions = vizNode.getNodeInteraction(); + + if (nodeInteractions.canHaveSpecialChildren) { + items.push( + + Add branch + , + ); + items.push(); + } + + if (nodeInteractions.canRemoveFlow) { + items.push( + , + ); + } + + return items; + })(CustomGroup), +); diff --git a/packages/ui/src/components/Visualization/Custom/CustomNode.tsx b/packages/ui/src/components/Visualization/Custom/CustomNode.tsx index 56e1d7d70..41b4ae3e8 100644 --- a/packages/ui/src/components/Visualization/Custom/CustomNode.tsx +++ b/packages/ui/src/components/Visualization/Custom/CustomNode.tsx @@ -1,23 +1,27 @@ +import { Tooltip } from '@patternfly/react-core'; +import { ArrowDownIcon, ArrowUpIcon, CodeBranchIcon, PlusIcon } from '@patternfly/react-icons'; import { + ContextMenuSeparator, DefaultNode, + ElementModel, + GraphElement, Node, NodeStatus, + WithSelectionProps, observer, withContextMenu, withSelection, - WithSelectionProps, } from '@patternfly/react-topology'; -import { Tooltip } from '@patternfly/react-core'; -import { FunctionComponent } from 'react'; +import { FunctionComponent, ReactElement } from 'react'; import { AddStepMode } from '../../../models/visualization/base-visual-entity'; import { CanvasDefaults } from '../Canvas/canvas.defaults'; import { CanvasNode } from '../Canvas/canvas.models'; import './CustomNode.scss'; -import { ItemAddNode } from './ItemAddNode'; -import { ItemInsertChildNode } from './ItemInsertChildNode'; -import { ItemRemoveNode } from './ItemRemoveNode'; -import { ItemReplaceNode } from './ItemReplaceNode'; -import { ItemRemoveGroup } from './ItemRemoveGroup'; +import { ItemAddStep } from './ItemAddStep'; +import { ItemDeleteGroup } from './ItemDeleteGroup'; +import { ItemDeleteStep } from './ItemDeleteStep'; +import { ItemInsertStep } from './ItemInsertStep'; +import { ItemReplaceStep } from './ItemReplaceStep'; interface CustomNodeProps extends WithSelectionProps { element: Node; @@ -60,24 +64,92 @@ const CustomNode: FunctionComponent = observer(({ element, ...r ); }); -export const CustomNodeWithSelection: typeof DefaultNode = withContextMenu(() => [ - , - , - , - , - , - , - , -])(withSelection()(CustomNode) as typeof DefaultNode) as typeof DefaultNode; +export const CustomNodeWithSelection: typeof DefaultNode = withSelection()( + withContextMenu((element: GraphElement) => { + const items: ReactElement[] = []; + const vizNode = element.getData()?.vizNode; + if (!vizNode) return items; + + const nodeInteractions = vizNode.getNodeInteraction(); + + if (nodeInteractions.canHavePreviousStep) { + items.push( + + Prepend + , + ); + } + if (nodeInteractions.canHaveNextStep) { + items.push( + + Append + , + ); + } + if (nodeInteractions.canHavePreviousStep || nodeInteractions.canHaveNextStep) { + items.push(); + } + + if (nodeInteractions.canHaveChildren) { + items.push( + + Add step + , + ); + } + if (nodeInteractions.canHaveSpecialChildren) { + items.push( + + Add branch + , + ); + } + if (nodeInteractions.canHaveChildren || nodeInteractions.canHaveSpecialChildren) { + items.push(); + } + + if (nodeInteractions.canReplaceStep) { + items.push( + , + ); + items.push(); + } + + if (nodeInteractions.canRemoveStep) { + items.push( + , + ); + } + if (nodeInteractions.canRemoveFlow) { + items.push( + , + ); + } + + return items; + })(CustomNode as typeof DefaultNode), +) as typeof DefaultNode; diff --git a/packages/ui/src/components/Visualization/Custom/ItemAddNode.tsx b/packages/ui/src/components/Visualization/Custom/ItemAddNode.tsx deleted file mode 100644 index 920d82bda..000000000 --- a/packages/ui/src/components/Visualization/Custom/ItemAddNode.tsx +++ /dev/null @@ -1,58 +0,0 @@ -import { AngleDownIcon, AngleUpIcon } from '@patternfly/react-icons'; -import { ContextMenuItem, ElementContext, ElementModel, GraphElement } from '@patternfly/react-topology'; -import { FunctionComponent, useCallback, useContext, useMemo } from 'react'; -import { IDataTestID } from '../../../models'; -import { AddStepMode } from '../../../models/visualization/base-visual-entity'; -import { CatalogModalContext } from '../../../providers/catalog-modal.provider'; -import { EntitiesContext } from '../../../providers/entities.provider'; -import { CanvasNode } from '../Canvas/canvas.models'; - -interface ItemAddNodeProps extends IDataTestID { - mode: AddStepMode.PrependStep | AddStepMode.AppendStep; -} - -export const ItemAddNode: FunctionComponent = (props) => { - const entitiesContext = useContext(EntitiesContext); - const catalogModalContext = useContext(CatalogModalContext); - const element: GraphElement = useContext(ElementContext); - - const vizNode = element.getData()?.vizNode; - const shouldRender = useMemo(() => { - const nodeInteractions = vizNode?.getNodeInteraction() ?? { canHavePreviousStep: false, canHaveNextStep: false }; - - return props.mode === AddStepMode.PrependStep - ? nodeInteractions.canHavePreviousStep - : nodeInteractions.canHaveNextStep; - }, [props.mode, vizNode]); - - const onAddNode = useCallback(async () => { - if (!vizNode || !entitiesContext) return; - - /** Get compatible nodes and the location where can be introduced */ - const compatibleNodes = entitiesContext.camelResource.getCompatibleComponents(props.mode, vizNode.data); - - /** Open Catalog modal, filtering the compatible nodes */ - const definedComponent = await catalogModalContext?.getNewComponent(compatibleNodes); - if (!definedComponent) return; - - /** Add new node to the entities */ - vizNode.addBaseEntityStep(definedComponent, props.mode); - - /** Update entity */ - entitiesContext.updateEntitiesFromCamelResource(); - }, [catalogModalContext, entitiesContext, props.mode, vizNode]); - - return shouldRender ? ( - - {props.mode === AddStepMode.PrependStep ? ( - <> - Prepend - - ) : ( - <> - Append - - )} - - ) : null; -}; diff --git a/packages/ui/src/components/Visualization/Custom/ItemAddStep.tsx b/packages/ui/src/components/Visualization/Custom/ItemAddStep.tsx new file mode 100644 index 000000000..689d2d444 --- /dev/null +++ b/packages/ui/src/components/Visualization/Custom/ItemAddStep.tsx @@ -0,0 +1,39 @@ +import { ContextMenuItem } from '@patternfly/react-topology'; +import { FunctionComponent, PropsWithChildren, useCallback, useContext } from 'react'; +import { IDataTestID } from '../../../models'; +import { AddStepMode, IVisualizationNode } from '../../../models/visualization/base-visual-entity'; +import { CatalogModalContext } from '../../../providers/catalog-modal.provider'; +import { EntitiesContext } from '../../../providers/entities.provider'; + +interface ItemAddStepProps extends PropsWithChildren { + mode: AddStepMode.PrependStep | AddStepMode.AppendStep; + vizNode: IVisualizationNode; +} + +export const ItemAddStep: FunctionComponent = (props) => { + const entitiesContext = useContext(EntitiesContext); + const catalogModalContext = useContext(CatalogModalContext); + + const onAddNode = useCallback(async () => { + if (!props.vizNode || !entitiesContext) return; + + /** Get compatible nodes and the location where can be introduced */ + const compatibleNodes = entitiesContext.camelResource.getCompatibleComponents(props.mode, props.vizNode.data); + + /** Open Catalog modal, filtering the compatible nodes */ + const definedComponent = await catalogModalContext?.getNewComponent(compatibleNodes); + if (!definedComponent) return; + + /** Add new node to the entities */ + props.vizNode.addBaseEntityStep(definedComponent, props.mode); + + /** Update entity */ + entitiesContext.updateEntitiesFromCamelResource(); + }, [catalogModalContext, entitiesContext, props.mode, props.vizNode]); + + return ( + + {props.children} + + ); +}; diff --git a/packages/ui/src/components/Visualization/Custom/ItemDeleteGroup.tsx b/packages/ui/src/components/Visualization/Custom/ItemDeleteGroup.tsx new file mode 100644 index 000000000..d5968f556 --- /dev/null +++ b/packages/ui/src/components/Visualization/Custom/ItemDeleteGroup.tsx @@ -0,0 +1,26 @@ +import { TrashIcon } from '@patternfly/react-icons'; +import { ContextMenuItem } from '@patternfly/react-topology'; +import { FunctionComponent, PropsWithChildren, useCallback, useContext } from 'react'; +import { IDataTestID } from '../../../models'; +import { IVisualizationNode } from '../../../models/visualization/base-visual-entity'; +import { EntitiesContext } from '../../../providers/entities.provider'; + +interface ItemDeleteGroupProps extends PropsWithChildren { + vizNode: IVisualizationNode; +} + +export const ItemDeleteGroup: FunctionComponent = (props) => { + const entitiesContext = useContext(EntitiesContext); + const flowId = props.vizNode?.getBaseEntity()?.getId(); + + const onRemoveGroup = useCallback(() => { + entitiesContext?.camelResource.removeEntity(flowId); + entitiesContext?.updateEntitiesFromCamelResource(); + }, [entitiesContext, flowId]); + + return ( + + Delete + + ); +}; diff --git a/packages/ui/src/components/Visualization/Custom/ItemDeleteStep.tsx b/packages/ui/src/components/Visualization/Custom/ItemDeleteStep.tsx new file mode 100644 index 000000000..6539c6e4d --- /dev/null +++ b/packages/ui/src/components/Visualization/Custom/ItemDeleteStep.tsx @@ -0,0 +1,25 @@ +import { TrashIcon } from '@patternfly/react-icons'; +import { ContextMenuItem } from '@patternfly/react-topology'; +import { FunctionComponent, PropsWithChildren, useCallback, useContext } from 'react'; +import { IDataTestID } from '../../../models'; +import { IVisualizationNode } from '../../../models/visualization/base-visual-entity'; +import { EntitiesContext } from '../../../providers/entities.provider'; + +interface ItemDeleteStepProps extends PropsWithChildren { + vizNode: IVisualizationNode; +} + +export const ItemDeleteStep: FunctionComponent = (props) => { + const entitiesContext = useContext(EntitiesContext); + + const onRemoveNode = useCallback(() => { + props.vizNode?.removeChild(); + entitiesContext?.updateEntitiesFromCamelResource(); + }, [entitiesContext, props.vizNode]); + + return ( + + Delete + + ); +}; diff --git a/packages/ui/src/components/Visualization/Custom/ItemInsertChildNode.tsx b/packages/ui/src/components/Visualization/Custom/ItemInsertChildNode.tsx deleted file mode 100644 index ff1b41d61..000000000 --- a/packages/ui/src/components/Visualization/Custom/ItemInsertChildNode.tsx +++ /dev/null @@ -1,54 +0,0 @@ -import { AngleDoubleDownIcon } from '@patternfly/react-icons'; -import { ContextMenuItem, ElementContext, ElementModel, GraphElement } from '@patternfly/react-topology'; -import { FunctionComponent, useCallback, useContext, useMemo } from 'react'; -import { IDataTestID } from '../../../models'; -import { AddStepMode } from '../../../models/visualization/base-visual-entity'; -import { CatalogModalContext } from '../../../providers/catalog-modal.provider'; -import { EntitiesContext } from '../../../providers/entities.provider'; -import { CanvasNode } from '../Canvas/canvas.models'; - -interface ItemInsertChildNodeProps extends IDataTestID { - mode: AddStepMode.InsertChildStep | AddStepMode.InsertSpecialChildStep; -} - -export const ItemInsertChildNode: FunctionComponent = (props) => { - const entitiesContext = useContext(EntitiesContext); - const catalogModalContext = useContext(CatalogModalContext); - const element: GraphElement = useContext(ElementContext); - const vizNode = element.getData()?.vizNode; - const shouldRender = useMemo(() => { - const nodeInteractions = vizNode?.getNodeInteraction() ?? { canHaveChildren: false, canHaveSpecialChildren: false }; - - return props.mode === AddStepMode.InsertChildStep - ? nodeInteractions.canHaveChildren - : nodeInteractions.canHaveSpecialChildren; - }, [props.mode, vizNode]); - - const onInsertNode = useCallback(async () => { - if (!vizNode || !entitiesContext) return; - - /** Get compatible nodes and the location where can be introduced */ - const compatibleNodes = entitiesContext.camelResource.getCompatibleComponents( - props.mode, - vizNode.data, - vizNode.getComponentSchema()?.definition, - ); - - /** Open Catalog modal, filtering the compatible nodes */ - const definedComponent = await catalogModalContext?.getNewComponent(compatibleNodes); - if (!definedComponent) return; - const targetProperty = props.mode === AddStepMode.InsertChildStep ? 'steps' : undefined; - - /** Add new node to the entities */ - vizNode.addBaseEntityStep(definedComponent, props.mode, targetProperty); - - /** Update entity */ - entitiesContext.updateEntitiesFromCamelResource(); - }, [catalogModalContext, entitiesContext, props.mode, vizNode]); - - return shouldRender ? ( - - Insert {props.mode === AddStepMode.InsertSpecialChildStep ? 'special' : ''} step - - ) : null; -}; diff --git a/packages/ui/src/components/Visualization/Custom/ItemInsertStep.tsx b/packages/ui/src/components/Visualization/Custom/ItemInsertStep.tsx new file mode 100644 index 000000000..3fd4fbb0a --- /dev/null +++ b/packages/ui/src/components/Visualization/Custom/ItemInsertStep.tsx @@ -0,0 +1,44 @@ +import { ContextMenuItem } from '@patternfly/react-topology'; +import { FunctionComponent, PropsWithChildren, useCallback, useContext } from 'react'; +import { IDataTestID } from '../../../models'; +import { AddStepMode, IVisualizationNode } from '../../../models/visualization/base-visual-entity'; +import { CatalogModalContext } from '../../../providers/catalog-modal.provider'; +import { EntitiesContext } from '../../../providers/entities.provider'; + +interface ItemInsertStepProps extends PropsWithChildren { + mode: AddStepMode.InsertChildStep | AddStepMode.InsertSpecialChildStep; + vizNode: IVisualizationNode; +} + +export const ItemInsertStep: FunctionComponent = (props) => { + const entitiesContext = useContext(EntitiesContext); + const catalogModalContext = useContext(CatalogModalContext); + + const onInsertNode = useCallback(async () => { + if (!props.vizNode || !entitiesContext) return; + + /** Get compatible nodes and the location where can be introduced */ + const compatibleNodes = entitiesContext.camelResource.getCompatibleComponents( + props.mode, + props.vizNode.data, + props.vizNode.getComponentSchema()?.definition, + ); + + /** Open Catalog modal, filtering the compatible nodes */ + const definedComponent = await catalogModalContext?.getNewComponent(compatibleNodes); + if (!definedComponent) return; + const targetProperty = props.mode === AddStepMode.InsertChildStep ? 'steps' : undefined; + + /** Add new node to the entities */ + props.vizNode.addBaseEntityStep(definedComponent, props.mode, targetProperty); + + /** Update entity */ + entitiesContext.updateEntitiesFromCamelResource(); + }, [catalogModalContext, entitiesContext, props.mode, props.vizNode]); + + return ( + + {props.children} + + ); +}; diff --git a/packages/ui/src/components/Visualization/Custom/ItemRemoveGroup.tsx b/packages/ui/src/components/Visualization/Custom/ItemRemoveGroup.tsx deleted file mode 100644 index e3cca4b28..000000000 --- a/packages/ui/src/components/Visualization/Custom/ItemRemoveGroup.tsx +++ /dev/null @@ -1,29 +0,0 @@ -import { TrashIcon } from '@patternfly/react-icons'; -import { ContextMenuItem, ElementContext, ElementModel, GraphElement } from '@patternfly/react-topology'; -import { FunctionComponent, useCallback, useContext, useMemo } from 'react'; -import { IDataTestID } from '../../../models'; -import { EntitiesContext } from '../../../providers/entities.provider'; -import { CanvasNode } from '../Canvas/canvas.models'; - -export const ItemRemoveGroup: FunctionComponent = (props) => { - const entitiesContext = useContext(EntitiesContext); - const element: GraphElement = useContext(ElementContext); - const vizNode = element.getData()?.vizNode; - const flowId = vizNode?.getBaseEntity()?.getId(); - const shouldRender = useMemo(() => { - const nodeInteractions = vizNode?.getNodeInteraction() ?? { canRemoveFlow: false }; - - return nodeInteractions.canRemoveFlow; - }, [vizNode]); - - const onRemoveGroup = useCallback(() => { - entitiesContext?.camelResource.removeEntity(flowId); - entitiesContext?.updateEntitiesFromCamelResource(); - }, [entitiesContext, flowId]); - - return shouldRender ? ( - - Delete - - ) : null; -}; diff --git a/packages/ui/src/components/Visualization/Custom/ItemRemoveNode.tsx b/packages/ui/src/components/Visualization/Custom/ItemRemoveNode.tsx deleted file mode 100644 index 31c6bee86..000000000 --- a/packages/ui/src/components/Visualization/Custom/ItemRemoveNode.tsx +++ /dev/null @@ -1,24 +0,0 @@ -import { MinusIcon } from '@patternfly/react-icons'; -import { ContextMenuItem, ElementContext, ElementModel, GraphElement } from '@patternfly/react-topology'; -import { FunctionComponent, useCallback, useContext, useMemo } from 'react'; -import { IDataTestID } from '../../../models'; -import { EntitiesContext } from '../../../providers/entities.provider'; -import { CanvasNode } from '../Canvas/canvas.models'; - -export const ItemRemoveNode: FunctionComponent = (props) => { - const entitiesContext = useContext(EntitiesContext); - const element: GraphElement = useContext(ElementContext); - const vizNode = element.getData()?.vizNode; - const shouldRender = useMemo(() => vizNode?.getNodeInteraction()?.canRemoveStep ?? false, [vizNode]); - - const onRemoveNode = useCallback(() => { - vizNode?.removeChild(); - entitiesContext?.updateEntitiesFromCamelResource(); - }, [entitiesContext, vizNode]); - - return shouldRender ? ( - - Remove - - ) : null; -}; diff --git a/packages/ui/src/components/Visualization/Custom/ItemReplaceNode.tsx b/packages/ui/src/components/Visualization/Custom/ItemReplaceNode.tsx deleted file mode 100644 index efa40bb04..000000000 --- a/packages/ui/src/components/Visualization/Custom/ItemReplaceNode.tsx +++ /dev/null @@ -1,39 +0,0 @@ -import { AngleRightIcon } from '@patternfly/react-icons'; -import { ContextMenuItem, ElementContext, ElementModel, GraphElement } from '@patternfly/react-topology'; -import { FunctionComponent, useCallback, useContext, useMemo } from 'react'; -import { IDataTestID } from '../../../models'; -import { AddStepMode } from '../../../models/visualization/base-visual-entity'; -import { CatalogModalContext } from '../../../providers/catalog-modal.provider'; -import { EntitiesContext } from '../../../providers/entities.provider'; -import { CanvasNode } from '../Canvas/canvas.models'; - -export const ItemReplaceNode: FunctionComponent = (props) => { - const entitiesContext = useContext(EntitiesContext); - const catalogModalContext = useContext(CatalogModalContext); - const element: GraphElement = useContext(ElementContext); - const vizNode = element.getData()?.vizNode; - const shouldRender = useMemo(() => vizNode?.getNodeInteraction()?.canReplaceStep ?? false, [vizNode]); - - const onReplaceNode = useCallback(async () => { - if (!vizNode || !entitiesContext) return; - - /** Find compatible components */ - const catalogFilter = entitiesContext.camelResource.getCompatibleComponents(AddStepMode.ReplaceStep, vizNode.data); - - /** Open Catalog modal, filtering the compatible nodes */ - const definedComponent = await catalogModalContext?.getNewComponent(catalogFilter); - if (!definedComponent) return; - - /** Add new node to the entities */ - vizNode.addBaseEntityStep(definedComponent, AddStepMode.ReplaceStep); - - /** Update entity */ - entitiesContext.updateEntitiesFromCamelResource(); - }, [catalogModalContext, entitiesContext, vizNode]); - - return shouldRender ? ( - - Replace - - ) : null; -}; diff --git a/packages/ui/src/components/Visualization/Custom/ItemReplaceStep.tsx b/packages/ui/src/components/Visualization/Custom/ItemReplaceStep.tsx new file mode 100644 index 000000000..18cbc5547 --- /dev/null +++ b/packages/ui/src/components/Visualization/Custom/ItemReplaceStep.tsx @@ -0,0 +1,42 @@ +import { SyncAltIcon } from '@patternfly/react-icons'; +import { ContextMenuItem } from '@patternfly/react-topology'; +import { FunctionComponent, PropsWithChildren, useCallback, useContext } from 'react'; +import { IDataTestID } from '../../../models'; +import { AddStepMode, IVisualizationNode } from '../../../models/visualization/base-visual-entity'; +import { CatalogModalContext } from '../../../providers/catalog-modal.provider'; +import { EntitiesContext } from '../../../providers/entities.provider'; + +interface ItemReplaceStepProps extends PropsWithChildren { + vizNode: IVisualizationNode; +} + +export const ItemReplaceStep: FunctionComponent = (props) => { + const entitiesContext = useContext(EntitiesContext); + const catalogModalContext = useContext(CatalogModalContext); + + const onReplaceNode = useCallback(async () => { + if (!props.vizNode || !entitiesContext) return; + + /** Find compatible components */ + const catalogFilter = entitiesContext.camelResource.getCompatibleComponents( + AddStepMode.ReplaceStep, + props.vizNode.data, + ); + + /** Open Catalog modal, filtering the compatible nodes */ + const definedComponent = await catalogModalContext?.getNewComponent(catalogFilter); + if (!definedComponent) return; + + /** Add new node to the entities */ + props.vizNode.addBaseEntityStep(definedComponent, AddStepMode.ReplaceStep); + + /** Update entity */ + entitiesContext.updateEntitiesFromCamelResource(); + }, [catalogModalContext, entitiesContext, props.vizNode]); + + return ( + + Replace + + ); +}; diff --git a/packages/ui/vite.config.js.timestamp-1714723669439-6cc1a24356891.mjs b/packages/ui/vite.config.js.timestamp-1714723669439-6cc1a24356891.mjs new file mode 100644 index 000000000..7c3eec62e --- /dev/null +++ b/packages/ui/vite.config.js.timestamp-1714723669439-6cc1a24356891.mjs @@ -0,0 +1,220 @@ +// vite.config.js +import react from "file:///C:/Users/LordR/repos/kaoto/node_modules/@vitejs/plugin-react/dist/index.mjs"; +import { defineConfig } from "file:///C:/Users/LordR/repos/kaoto/node_modules/vite/dist/node/index.js"; +import { viteStaticCopy } from "file:///C:/Users/LordR/repos/kaoto/node_modules/vite-plugin-static-copy/dist/index.js"; + +// scripts/get-camel-catalog-files.js +import { readdirSync } from "node:fs"; +import { createRequire } from "node:module"; +import { dirname, join } from "node:path"; +import { normalizePath } from "file:///C:/Users/LordR/repos/kaoto/node_modules/vite/dist/node/index.js"; +var __vite_injected_original_import_meta_url = "file:///C:/Users/LordR/repos/kaoto/packages/ui/scripts/get-camel-catalog-files.js"; +var require2 = createRequire(__vite_injected_original_import_meta_url); +var getCamelCatalogFiles = () => { + let camelCatalogPath = ""; + try { + const camelCatalogIndexJsonPath = require2.resolve("@kaoto/camel-catalog/index.json"); + camelCatalogPath = normalizePath(dirname(camelCatalogIndexJsonPath)); + } catch (error) { + throw new Error(`Could not find '@kaoto/camel-catalog' + + ${error}`); + } + console.info(`Found '@kaoto/camel-catalog' in ${camelCatalogPath}`, "\n"); + try { + if (readdirSync(camelCatalogPath).length === 0) { + throw new Error(); + } + } catch (error) { + const message = [ + `The '${camelCatalogPath}' folder is empty.`, + "No files found in the Camel Catalog directory.", + "Please run `yarn workspace @kaoto/camel-catalog run build`", + "or `yarn build` in the `@kaoto/camel-catalog` package" + ]; + throw new Error(message.join("\n\n")); + } + const jsonFiles = readdirSync(camelCatalogPath).filter((file) => file.endsWith(".json")).map((file) => normalizePath(join(camelCatalogPath, file))); + return jsonFiles; +}; + +// scripts/get-last-commit-info.js +import simpleGit from "file:///C:/Users/LordR/repos/kaoto/node_modules/simple-git/dist/esm/index.js"; +async function getLastCommitInfo() { + return new Promise((resolve, reject) => { + simpleGit().log({ n: 1 }, (err, status) => { + if (err || !status.latest || status.latest === null) { + reject(err); + } else { + resolve(status.latest); + } + }); + }); +} + +// package.json +var package_default = { + name: "@kaoto/kaoto", + version: "2.0.0-dev", + type: "module", + description: "Kaoto UI", + repository: "https://github.com/KaotoIO/kaoto", + repositoryDirectory: "packages/ui", + author: "The Kaoto Team", + publishConfig: { + access: "public" + }, + license: "Apache License v2.0", + types: "./lib/esm/public-api.d.ts", + module: "./lib/esm/public-api.js", + main: "./lib/cjs/public-api.js", + exports: { + ".": { + import: "./lib/esm/public-api.js", + require: "./lib/cjs/public-api.js" + }, + "./testing": { + import: "./lib/esm/testing-api.js", + require: "./lib/cjs/testing-api.js" + } + }, + files: [ + "lib" + ], + scripts: { + start: "vite", + build: "tsc && vite build --config vite.config.js", + "build:lib": "yarn rimraf ./lib && yarn copy-catalog && yarn build:esm && yarn build:cjs && yarn write-version", + "build:esm": "tsc --project tsconfig.esm.json && copyfiles -u 1 './src/**/*.scss' './src/assets/**' ./lib/esm", + "build:cjs": "tsc --project tsconfig.cjs.json && copyfiles -u 1 './src/**/*.scss' './src/assets/**' ./lib/cjs", + "write-version": "node ./scripts/write-version-file.js", + "copy-catalog": "node ./scripts/copy-camel-catalog-files.js ./lib/camel-catalog", + preview: "vite preview", + test: "jest", + "test:watch": "jest --watch", + lint: 'yarn eslint "src/**/*.{ts,tsx}"', + "lint:fix": "yarn lint --fix", + "lint:style": 'yarn stylelint "src/**/*.{css,scss}"', + "lint:style:fix": "yarn lint:style --fix" + }, + dependencies: { + "@kaoto-next/uniforms-patternfly": "^0.6.8", + "@kie-tools-core/editor": "0.32.0", + "@kie-tools-core/notifications": "0.32.0", + "@patternfly/patternfly": "5.2.1", + "@patternfly/react-code-editor": "5.1.0", + "@patternfly/react-core": "5.2.2", + "@patternfly/react-icons": "5.2.1", + "@patternfly/react-table": "5.2.2", + "@patternfly/react-topology": "5.2.1", + "@types/uuid": "^9.0.2", + ajv: "^8.12.0", + "ajv-draft-04": "^1.0.0", + "ajv-formats": "^2.1.1", + clsx: "^2.1.0", + "html-to-image": "^1.11.11", + "lodash.clonedeep": "^4.5.0", + "lodash.get": "^4.4.2", + "lodash.isempty": "^4.4.0", + "lodash.memoize": "^4.1.2", + "lodash.set": "^4.3.2", + "monaco-editor": "^0.45.0", + "monaco-yaml": "^5.1.1", + react: "^18.2.0", + "react-dom": "^18.2.0", + "react-monaco-editor": "^0.55.0", + "react-router-dom": "^6.14.1", + "simple-zustand-devtools": "^1.1.0", + uniforms: "4.0.0-alpha.5", + "uniforms-bridge-json-schema": "4.0.0-alpha.5", + "usehooks-ts": "^2.15.1", + uuid: "^9.0.0", + yaml: "^2.3.2", + zustand: "^4.3.9" + }, + devDependencies: { + "@babel/core": "^7.23.2", + "@babel/preset-env": "^7.21.5", + "@babel/preset-react": "^7.18.6", + "@babel/preset-typescript": "^7.21.5", + "@kaoto/camel-catalog": "workspace:*", + "@testing-library/dom": "^9.3.0", + "@testing-library/jest-dom": "^6.0.0", + "@testing-library/react": "^14.0.0", + "@testing-library/user-event": "^14.4.3", + "@types/jest": "^29.4.0", + "@types/json-schema": "^7.0.15", + "@types/lodash.clonedeep": "^4.5.7", + "@types/lodash.get": "^4.4.2", + "@types/lodash.isempty": "^4.4.9", + "@types/lodash.memoize": "^4.1.9", + "@types/lodash.set": "^4.3.7", + "@types/node": "^20.0.0", + "@types/react": "^18.2.25", + "@types/react-dom": "^18.2.10", + "@typescript-eslint/eslint-plugin": "^7.0.0", + "@typescript-eslint/parser": "^7.0.0", + "@vitejs/plugin-react": "^4.0.3", + "babel-jest": "^29.4.2", + copyfiles: "^2.4.1", + eslint: "^8.45.0", + "eslint-config-prettier": "^9.0.0", + "eslint-plugin-import": "^2.26.0", + "eslint-plugin-jest": "^27.2.1", + "eslint-plugin-prettier": "^5.0.0", + "eslint-plugin-react-hooks": "^4.6.0", + "eslint-plugin-react-refresh": "^0.4.3", + jest: "^29.4.2", + "jest-canvas-mock": "^2.5.2", + "jest-environment-jsdom": "^29.4.2", + prettier: "^3.0.0", + "react-test-renderer": "^18.2.0", + rimraf: "^5.0.5", + sass: "^1.63.6", + "simple-git": "^3.22.0", + stylelint: "^16.1.0", + "stylelint-config-standard-scss": "^13.0.0", + "stylelint-prettier": "^5.0.0", + "ts-node": "^10.9.1", + typescript: "^5.4.2", + vite: "^4.4.5", + "vite-plugin-dts": "^3.5.1", + "vite-plugin-static-copy": "^1.0.0" + } +}; + +// vite.config.js +var vite_config_default = defineConfig(async () => { + const lastCommitInfo = await getLastCommitInfo(); + return { + plugins: [ + react(), + viteStaticCopy({ + targets: [ + { + src: getCamelCatalogFiles(), + dest: "camel-catalog", + transform: (content, filename) => { + return JSON.stringify(JSON.parse(content)); + } + } + ] + }) + ], + define: { + __GIT_HASH: JSON.stringify(lastCommitInfo.hash), + __GIT_DATE: JSON.stringify(lastCommitInfo.date), + __KAOTO_VERSION: JSON.stringify(package_default.version) + }, + build: { + outDir: "./dist", + sourcemap: true, + emptyOutDir: true + }, + base: "./" + }; +}); +export { + vite_config_default as default +}; +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.js", "scripts/get-camel-catalog-files.js", "scripts/get-last-commit-info.js", "package.json"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"C:\\\\Users\\\\LordR\\\\repos\\\\kaoto\\\\packages\\\\ui\";const __vite_injected_original_filename = \"C:\\\\Users\\\\LordR\\\\repos\\\\kaoto\\\\packages\\\\ui\\\\vite.config.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Users/LordR/repos/kaoto/packages/ui/vite.config.js\";// @ts-check\nimport react from '@vitejs/plugin-react';\nimport { defineConfig } from 'vite';\nimport { viteStaticCopy } from 'vite-plugin-static-copy';\nimport { getCamelCatalogFiles } from './scripts/get-camel-catalog-files';\nimport { getLastCommitInfo } from './scripts/get-last-commit-info';\nimport packageJson from './package.json';\n\n// https://vitejs.dev/config/\nexport default defineConfig(async () => {\n  const lastCommitInfo = await getLastCommitInfo();\n\n  return {\n    plugins: [\n      react(),\n      viteStaticCopy({\n        targets: [\n          {\n            src: getCamelCatalogFiles(),\n            dest: 'camel-catalog',\n            transform: (content, filename) => {\n              return JSON.stringify(JSON.parse(content));\n            },\n          },\n        ],\n      }),\n    ],\n    define: {\n      __GIT_HASH: JSON.stringify(lastCommitInfo.hash),\n      __GIT_DATE: JSON.stringify(lastCommitInfo.date),\n      __KAOTO_VERSION: JSON.stringify(packageJson.version),\n    },\n    build: {\n      outDir: './dist',\n      sourcemap: true,\n      emptyOutDir: true,\n    },\n    base: './',\n  };\n});\n", "const __vite_injected_original_dirname = \"C:\\\\Users\\\\LordR\\\\repos\\\\kaoto\\\\packages\\\\ui\\\\scripts\";const __vite_injected_original_filename = \"C:\\\\Users\\\\LordR\\\\repos\\\\kaoto\\\\packages\\\\ui\\\\scripts\\\\get-camel-catalog-files.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Users/LordR/repos/kaoto/packages/ui/scripts/get-camel-catalog-files.js\";import { readdirSync } from 'node:fs';\nimport { createRequire } from 'node:module';\nimport { dirname, join } from 'node:path';\nimport { normalizePath } from 'vite';\n\nconst require = createRequire(import.meta.url);\n/**\n * Temporary function to copy the built Kaoto Camel Catalog into the assets folder\n *\n * When dynamically importing the Camel Catalog is supported, this function can be removed\n * and this file can be restored to a .ts file.\n * Related issue: https://github.com/sveltejs/vite-plugin-svelte/issues/141#issuecomment-898900239\n */\nexport const getCamelCatalogFiles = () => {\n  let camelCatalogPath = '';\n\n  try {\n    const camelCatalogIndexJsonPath = require.resolve('@kaoto/camel-catalog/index.json');\n    camelCatalogPath = normalizePath(dirname(camelCatalogIndexJsonPath));\n  } catch (error) {\n    throw new Error(`Could not find '@kaoto/camel-catalog' \\n\\n ${error}`);\n  }\n\n  console.info(`Found '@kaoto/camel-catalog' in ${camelCatalogPath}`, '\\n');\n\n  try {\n    if (readdirSync(camelCatalogPath).length === 0) {\n      throw new Error();\n    }\n  } catch (error) {\n    const message = [\n      `The '${camelCatalogPath}' folder is empty.`,\n      'No files found in the Camel Catalog directory.',\n      'Please run `yarn workspace @kaoto/camel-catalog run build`',\n      'or `yarn build` in the `@kaoto/camel-catalog` package',\n    ];\n\n    throw new Error(message.join('\\n\\n'));\n  }\n\n  /** List all the JSON files in the Camel Catalog folder */\n  const jsonFiles = readdirSync(camelCatalogPath)\n    .filter((file) => file.endsWith('.json'))\n    .map((file) => normalizePath(join(camelCatalogPath, file)));\n\n  return jsonFiles;\n};\n", "const __vite_injected_original_dirname = \"C:\\\\Users\\\\LordR\\\\repos\\\\kaoto\\\\packages\\\\ui\\\\scripts\";const __vite_injected_original_filename = \"C:\\\\Users\\\\LordR\\\\repos\\\\kaoto\\\\packages\\\\ui\\\\scripts\\\\get-last-commit-info.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Users/LordR/repos/kaoto/packages/ui/scripts/get-last-commit-info.js\";// @ts-check\nimport simpleGit from 'simple-git';\n\n/**\n * Get the git last commit info\n *\n * @returns {Promise<import('simple-git').DefaultLogFields>} The last commit info\n */\nexport async function getLastCommitInfo() {\n  return new Promise((resolve, reject) => {\n    simpleGit().log({ n: 1 }, (err, status) => {\n      if (err || !status.latest || status.latest === null) {\n        reject(err);\n      } else {\n        resolve(status.latest);\n      }\n    });\n  });\n}\n", "{\n  \"name\": \"@kaoto/kaoto\",\n  \"version\": \"2.0.0-dev\",\n  \"type\": \"module\",\n  \"description\": \"Kaoto UI\",\n  \"repository\": \"https://github.com/KaotoIO/kaoto\",\n  \"repositoryDirectory\": \"packages/ui\",\n  \"author\": \"The Kaoto Team\",\n  \"publishConfig\": {\n    \"access\": \"public\"\n  },\n  \"license\": \"Apache License v2.0\",\n  \"types\": \"./lib/esm/public-api.d.ts\",\n  \"module\": \"./lib/esm/public-api.js\",\n  \"main\": \"./lib/cjs/public-api.js\",\n  \"exports\": {\n    \".\": {\n      \"import\": \"./lib/esm/public-api.js\",\n      \"require\": \"./lib/cjs/public-api.js\"\n    },\n    \"./testing\": {\n      \"import\": \"./lib/esm/testing-api.js\",\n      \"require\": \"./lib/cjs/testing-api.js\"\n    }\n  },\n  \"files\": [\n    \"lib\"\n  ],\n  \"scripts\": {\n    \"start\": \"vite\",\n    \"build\": \"tsc && vite build --config vite.config.js\",\n    \"build:lib\": \"yarn rimraf ./lib && yarn copy-catalog && yarn build:esm && yarn build:cjs && yarn write-version\",\n    \"build:esm\": \"tsc --project tsconfig.esm.json && copyfiles -u 1 './src/**/*.scss' './src/assets/**' ./lib/esm\",\n    \"build:cjs\": \"tsc --project tsconfig.cjs.json && copyfiles -u 1 './src/**/*.scss' './src/assets/**' ./lib/cjs\",\n    \"write-version\": \"node ./scripts/write-version-file.js\",\n    \"copy-catalog\": \"node ./scripts/copy-camel-catalog-files.js ./lib/camel-catalog\",\n    \"preview\": \"vite preview\",\n    \"test\": \"jest\",\n    \"test:watch\": \"jest --watch\",\n    \"lint\": \"yarn eslint \\\"src/**/*.{ts,tsx}\\\"\",\n    \"lint:fix\": \"yarn lint --fix\",\n    \"lint:style\": \"yarn stylelint \\\"src/**/*.{css,scss}\\\"\",\n    \"lint:style:fix\": \"yarn lint:style --fix\"\n  },\n  \"dependencies\": {\n    \"@kaoto-next/uniforms-patternfly\": \"^0.6.8\",\n    \"@kie-tools-core/editor\": \"0.32.0\",\n    \"@kie-tools-core/notifications\": \"0.32.0\",\n    \"@patternfly/patternfly\": \"5.2.1\",\n    \"@patternfly/react-code-editor\": \"5.1.0\",\n    \"@patternfly/react-core\": \"5.2.2\",\n    \"@patternfly/react-icons\": \"5.2.1\",\n    \"@patternfly/react-table\": \"5.2.2\",\n    \"@patternfly/react-topology\": \"5.2.1\",\n    \"@types/uuid\": \"^9.0.2\",\n    \"ajv\": \"^8.12.0\",\n    \"ajv-draft-04\": \"^1.0.0\",\n    \"ajv-formats\": \"^2.1.1\",\n    \"clsx\": \"^2.1.0\",\n    \"html-to-image\": \"^1.11.11\",\n    \"lodash.clonedeep\": \"^4.5.0\",\n    \"lodash.get\": \"^4.4.2\",\n    \"lodash.isempty\": \"^4.4.0\",\n    \"lodash.memoize\": \"^4.1.2\",\n    \"lodash.set\": \"^4.3.2\",\n    \"monaco-editor\": \"^0.45.0\",\n    \"monaco-yaml\": \"^5.1.1\",\n    \"react\": \"^18.2.0\",\n    \"react-dom\": \"^18.2.0\",\n    \"react-monaco-editor\": \"^0.55.0\",\n    \"react-router-dom\": \"^6.14.1\",\n    \"simple-zustand-devtools\": \"^1.1.0\",\n    \"uniforms\": \"4.0.0-alpha.5\",\n    \"uniforms-bridge-json-schema\": \"4.0.0-alpha.5\",\n    \"usehooks-ts\": \"^2.15.1\",\n    \"uuid\": \"^9.0.0\",\n    \"yaml\": \"^2.3.2\",\n    \"zustand\": \"^4.3.9\"\n  },\n  \"devDependencies\": {\n    \"@babel/core\": \"^7.23.2\",\n    \"@babel/preset-env\": \"^7.21.5\",\n    \"@babel/preset-react\": \"^7.18.6\",\n    \"@babel/preset-typescript\": \"^7.21.5\",\n    \"@kaoto/camel-catalog\": \"workspace:*\",\n    \"@testing-library/dom\": \"^9.3.0\",\n    \"@testing-library/jest-dom\": \"^6.0.0\",\n    \"@testing-library/react\": \"^14.0.0\",\n    \"@testing-library/user-event\": \"^14.4.3\",\n    \"@types/jest\": \"^29.4.0\",\n    \"@types/json-schema\": \"^7.0.15\",\n    \"@types/lodash.clonedeep\": \"^4.5.7\",\n    \"@types/lodash.get\": \"^4.4.2\",\n    \"@types/lodash.isempty\": \"^4.4.9\",\n    \"@types/lodash.memoize\": \"^4.1.9\",\n    \"@types/lodash.set\": \"^4.3.7\",\n    \"@types/node\": \"^20.0.0\",\n    \"@types/react\": \"^18.2.25\",\n    \"@types/react-dom\": \"^18.2.10\",\n    \"@typescript-eslint/eslint-plugin\": \"^7.0.0\",\n    \"@typescript-eslint/parser\": \"^7.0.0\",\n    \"@vitejs/plugin-react\": \"^4.0.3\",\n    \"babel-jest\": \"^29.4.2\",\n    \"copyfiles\": \"^2.4.1\",\n    \"eslint\": \"^8.45.0\",\n    \"eslint-config-prettier\": \"^9.0.0\",\n    \"eslint-plugin-import\": \"^2.26.0\",\n    \"eslint-plugin-jest\": \"^27.2.1\",\n    \"eslint-plugin-prettier\": \"^5.0.0\",\n    \"eslint-plugin-react-hooks\": \"^4.6.0\",\n    \"eslint-plugin-react-refresh\": \"^0.4.3\",\n    \"jest\": \"^29.4.2\",\n    \"jest-canvas-mock\": \"^2.5.2\",\n    \"jest-environment-jsdom\": \"^29.4.2\",\n    \"prettier\": \"^3.0.0\",\n    \"react-test-renderer\": \"^18.2.0\",\n    \"rimraf\": \"^5.0.5\",\n    \"sass\": \"^1.63.6\",\n    \"simple-git\": \"^3.22.0\",\n    \"stylelint\": \"^16.1.0\",\n    \"stylelint-config-standard-scss\": \"^13.0.0\",\n    \"stylelint-prettier\": \"^5.0.0\",\n    \"ts-node\": \"^10.9.1\",\n    \"typescript\": \"^5.4.2\",\n    \"vite\": \"^4.4.5\",\n    \"vite-plugin-dts\": \"^3.5.1\",\n    \"vite-plugin-static-copy\": \"^1.0.0\"\n  }\n}\n"],
  "mappings": "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",
  "names": ["require"]
}
