From 652bd5d087428ded705e1c55bb50b736e805f51a Mon Sep 17 00:00:00 2001 From: Michael Charfadi Date: Mon, 16 Dec 2024 13:51:29 +0100 Subject: [PATCH] [4285] Fix direct edit when the palette is closed MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Bug: https://github.com/eclipse-sirius/sirius-web/issues/4285 Signed-off-by: Michaƫl Charfadi --- CHANGELOG.adoc | 1 + .../src/renderer/delete/useDiagramDelete.tsx | 15 ++++-- .../direct-edit/useDiagramDirectEdit.tsx | 13 +++-- .../src/renderer/edge/MultiLabelEdge.tsx | 14 ++--- .../palette/DiagramElementPalette.tsx | 8 +-- .../src/renderer/palette/DiagramPalette.tsx | 18 +------ .../src/renderer/palette/Palette.tsx | 52 ++++++++++++++++--- .../palette/search/PaletteSearchField.tsx | 14 ++--- .../search/PaletteSearchField.types.ts | 2 - .../palette/tool-list/PaletteToolList.tsx | 1 + .../tool-list/PaletteToolSectionList.tsx | 3 +- 11 files changed, 81 insertions(+), 60 deletions(-) diff --git a/CHANGELOG.adoc b/CHANGELOG.adoc index a9c490132d..b39cd372a6 100644 --- a/CHANGELOG.adoc +++ b/CHANGELOG.adoc @@ -60,6 +60,7 @@ This was first fixed in 2022.3.0 but broken in 2024.3.0; it is now fixed again. - https://github.com/eclipse-sirius/sirius-web/issues/4280[#4280] [diagram] Fix direct edit with F2 when the palette is opened - https://github.com/eclipse-sirius/sirius-web/issues/4302[#4302] [diagram] Fix edges label flashing - https://github.com/eclipse-sirius/sirius-web/issues/4312[#4312] [sirius-web] The _Details_ view dit not react to its input is deselected, showing potentially stale information +- https://github.com/eclipse-sirius/sirius-web/issues/4285[#4285] [diagram] Fix direct edit after closing the palette === New Features diff --git a/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/delete/useDiagramDelete.tsx b/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/delete/useDiagramDelete.tsx index 8c4b0e57d9..a8e538c158 100644 --- a/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/delete/useDiagramDelete.tsx +++ b/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/delete/useDiagramDelete.tsx @@ -57,7 +57,7 @@ export const useDiagramDelete = (): UseDiagramDeleteValue => { const { addErrorMessage, addMessages } = useMultiToast(); const { showDeletionConfirmation } = useDeletionConfirmationDialog(); const { diagramId, editingContextId, readOnly } = useContext(DiagramContext); - const { getNodes } = useReactFlow, Edge>(); + const { getNodes, getEdges } = useReactFlow, Edge>(); const [deleteElementsMutation, { data: deleteElementsData, error: deleteElementsError }] = useMutation< GQLDeleteFromDiagramData, @@ -78,23 +78,28 @@ export const useDiagramDelete = (): UseDiagramDeleteValue => { const onDelete = useCallback((event: React.KeyboardEvent) => { const { key } = event; - /*If a modifier key is hit alone, do nothing*/ const isTextField = event.target instanceof HTMLInputElement || event.target instanceof HTMLTextAreaElement; - if ((event.altKey && key === 'Alt') || (event.shiftKey && key === 'Shift') || isTextField) { + + /*If a modifier key is hit alone, do nothing*/ + if ((event.altKey && key === 'Alt') || (event.shiftKey && key === 'Shift') || isTextField || readOnly) { return; } - event.preventDefault(); if (key === 'Delete' && editingContextId && diagramId && !readOnly) { const nodeToDeleteIds: string[] = getNodes() .filter((node) => node.selected) .map((node) => node.id); + + const edgesToDeleteIds: string[] = getEdges() + .filter((edge) => edge.selected) + .map((edge) => edge.id); + const input: GQLDeleteFromDiagramInput = { id: crypto.randomUUID(), editingContextId, representationId: diagramId, nodeIds: nodeToDeleteIds, - edgeIds: [], + edgeIds: edgesToDeleteIds, deletionPolicy: GQLDeletionPolicy.SEMANTIC, }; showDeletionConfirmation(() => { diff --git a/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/direct-edit/useDiagramDirectEdit.tsx b/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/direct-edit/useDiagramDirectEdit.tsx index c95f9981a7..cd43f31a45 100644 --- a/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/direct-edit/useDiagramDirectEdit.tsx +++ b/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/direct-edit/useDiagramDirectEdit.tsx @@ -30,19 +30,25 @@ export const useDiagramDirectEdit = (): UseDiagramDirectEditValue => { const onDirectEdit = useCallback( (event: React.KeyboardEvent) => { const { key } = event; - /*If a modifier key is hit alone, do nothing*/ + const isTextField = event.target instanceof HTMLInputElement || event.target instanceof HTMLTextAreaElement; - if ((event.altKey && key === 'Alt') || (event.shiftKey && key === 'Shift') || isTextField || readOnly) { + + /*If a modifier key is hit alone, do nothing*/ + if ((event.altKey && key === 'Alt') || (event.shiftKey && key === 'Shift') || readOnly) { + return; + } + + if (key !== 'F2' && isTextField) { return; } - event.preventDefault(); const validFirstInputChar = !event.metaKey && !event.ctrlKey && key.length === 1 && directEditActivationValidCharacters.test(key); let currentlyEditedLabelId: string | undefined | null; let isLabelEditable: boolean = false; const nodeData: NodeData | undefined = getNodes().find((node) => node.selected)?.data; + if (nodeData) { if (nodeData.insideLabel) { currentlyEditedLabelId = nodeData.insideLabel.id; @@ -51,6 +57,7 @@ export const useDiagramDirectEdit = (): UseDiagramDirectEditValue => { } isLabelEditable = nodeData.labelEditable; } + if (!currentlyEditedLabelId) { currentlyEditedLabelId = getEdges().find((edge) => edge.selected)?.data?.label?.id; isLabelEditable = getEdges().find((edge) => edge.selected)?.data?.centerLabelEditable || false; diff --git a/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/edge/MultiLabelEdge.tsx b/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/edge/MultiLabelEdge.tsx index f9fd234a3a..3b837e9fde 100644 --- a/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/edge/MultiLabelEdge.tsx +++ b/packages/diagrams/frontend/sirius-components-diagrams/src/renderer/edge/MultiLabelEdge.tsx @@ -94,14 +94,14 @@ export const MultiLabelEdge = memo( markerEnd={selected ? `${markerEnd?.slice(0, markerEnd.length - 2)}--selected')` : markerEnd} markerStart={selected ? `${markerStart?.slice(0, markerStart.length - 2)}--selected')` : markerStart} /> - {selected ? ( - - ) : null} + {selected ? ( + + ) : null} {beginLabel && (