diff --git a/packages/compatibility/backend/sirius-components-compatibility/src/main/java/org/eclipse/sirius/components/compatibility/diagrams/SelectModelElementVariableConverter.java b/packages/compatibility/backend/sirius-components-compatibility/src/main/java/org/eclipse/sirius/components/compatibility/diagrams/SelectModelElementVariableConverter.java index d0b051aaf1b..fb374bf0db6 100644 --- a/packages/compatibility/backend/sirius-components-compatibility/src/main/java/org/eclipse/sirius/components/compatibility/diagrams/SelectModelElementVariableConverter.java +++ b/packages/compatibility/backend/sirius-components-compatibility/src/main/java/org/eclipse/sirius/components/compatibility/diagrams/SelectModelElementVariableConverter.java @@ -12,17 +12,12 @@ *******************************************************************************/ package org.eclipse.sirius.components.compatibility.diagrams; -import java.util.List; import java.util.Objects; -import org.eclipse.sirius.components.compatibility.api.IAQLInterpreterFactory; import org.eclipse.sirius.components.compatibility.api.IIdentifierProvider; import org.eclipse.sirius.components.compatibility.services.selection.api.ISelectModelElementVariableConverter; import org.eclipse.sirius.components.core.api.IObjectService; -import org.eclipse.sirius.components.interpreter.AQLInterpreter; -import org.eclipse.sirius.components.interpreter.Result; import org.eclipse.sirius.components.representations.VariableManager; -import org.eclipse.sirius.components.selection.Selection; import org.eclipse.sirius.components.selection.description.SelectionDescription; import org.eclipse.sirius.viewpoint.description.tool.SelectModelElementVariable; import org.springframework.stereotype.Service; @@ -41,24 +36,15 @@ public class SelectModelElementVariableConverter implements ISelectModelElementV private final IIdentifierProvider identifierProvider; - private final IAQLInterpreterFactory interpreterFactory; - public SelectModelElementVariableConverter(IObjectService objectService, IIdentifierProvider identifierProvider, IAQLInterpreterFactory interpreterFactory) { + public SelectModelElementVariableConverter(IObjectService objectService, IIdentifierProvider identifierProvider) { this.objectService = Objects.requireNonNull(objectService); this.identifierProvider = Objects.requireNonNull(identifierProvider); - this.interpreterFactory = Objects.requireNonNull(interpreterFactory); } @Override public SelectionDescription convert(SelectModelElementVariable selectModelElementVariable, org.eclipse.sirius.diagram.description.DiagramDescription diagramDescription) { - AQLInterpreter interpreter = this.interpreterFactory.create(diagramDescription); return SelectionDescription.newSelectionDescription(this.identifierProvider.getIdentifier(selectModelElementVariable)) - .objectsProvider(variableManager -> { - Result result = interpreter.evaluateExpression(variableManager.getVariables(), selectModelElementVariable.getCandidatesExpression()); - return result.asObjects().orElse(List.of()).stream() - .filter(Objects::nonNull) - .toList(); - }) .messageProvider(variableManager -> { String message = selectModelElementVariable.getMessage(); if (message == null) { @@ -66,11 +52,9 @@ public SelectionDescription convert(SelectModelElementVariable selectModelElemen } return message; }) - .idProvider(variableManager -> Selection.PREFIX) + .idProvider(variableManager -> "selection://") .labelProvider(variableManager -> variableManager.get(VariableManager.SELF, Object.class).map(this.objectService::getLabel).orElse(null)) - .iconURLProvider(variableManager -> variableManager.get(VariableManager.SELF, Object.class).map(this.objectService::getImagePath).orElse(List.of())) .targetObjectIdProvider(variableManager -> variableManager.get(VariableManager.SELF, Object.class).map(this.objectService::getId).orElse(null)) - .selectionObjectsIdProvider(variableManager -> variableManager.get(VariableManager.SELF, Object.class).map(this.objectService::getId).orElse(null)) .label("Selection Description") .canCreatePredicate(variableManager -> false) .build(); diff --git a/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/DefaultIdentityService.java b/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/DefaultIdentityService.java index c87997e0d5b..38afaa5be66 100644 --- a/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/DefaultIdentityService.java +++ b/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/DefaultIdentityService.java @@ -54,6 +54,8 @@ public String getId(Object object) { id = representation.getId(); } else if (object instanceof IEditingContext editingContext) { id = editingContext.getId(); + } else if (object instanceof Resource resource) { + id = resource.getURI().path().substring(1); } return id; } diff --git a/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/DefaultLabelService.java b/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/DefaultLabelService.java index b1b8351ce70..d7ea6b284e0 100644 --- a/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/DefaultLabelService.java +++ b/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/DefaultLabelService.java @@ -24,12 +24,14 @@ import org.eclipse.emf.common.util.URI; import org.eclipse.emf.ecore.EAttribute; import org.eclipse.emf.ecore.EObject; +import org.eclipse.emf.ecore.resource.Resource; import org.eclipse.emf.edit.provider.ComposedAdapterFactory; import org.eclipse.emf.edit.provider.ComposedImage; import org.eclipse.emf.edit.provider.IItemLabelProvider; import org.eclipse.emf.edit.provider.ReflectiveItemProvider; import org.eclipse.sirius.components.collaborative.api.IRepresentationImageProvider; import org.eclipse.sirius.components.core.api.IDefaultLabelService; +import org.eclipse.sirius.components.emf.ResourceMetadataAdapter; import org.eclipse.sirius.components.representations.IRepresentation; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -66,10 +68,20 @@ public String getLabel(Object object) { .orElse(""); } else if (object instanceof IRepresentation representation) { label = representation.getLabel(); + } else if (object instanceof Resource resource) { + label = this.getResourceLabel(resource); } return label; } + private String getResourceLabel(Resource resource) { + return resource.eAdapters().stream() + .filter(ResourceMetadataAdapter.class::isInstance) + .map(ResourceMetadataAdapter.class::cast).findFirst() + .map(ResourceMetadataAdapter::getName) + .orElse(resource.getURI().lastSegment()); + } + @Override public String getFullLabel(Object object) { String fullLabel = ""; @@ -81,6 +93,8 @@ public String getFullLabel(Object object) { } } else if (object instanceof IRepresentation representation) { fullLabel = representation.getLabel(); + } else if (object instanceof Resource resource) { + fullLabel = this.getResourceLabel(resource); } else { fullLabel = this.getLabel(object); } @@ -137,6 +151,8 @@ public List getImagePath(Object object) { .map(provider -> provider.getImageURL(representation.getKind())) .flatMap(Optional::stream) .toList(); + } else if (object instanceof Resource) { + result = List.of("/icons/Resource.svg"); } return result; } diff --git a/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/EMFImagePathService.java b/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/EMFImagePathService.java index 5e67d44aab6..3ed377987d6 100644 --- a/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/EMFImagePathService.java +++ b/packages/emf/backend/sirius-components-emf/src/main/java/org/eclipse/sirius/components/emf/services/EMFImagePathService.java @@ -25,7 +25,7 @@ @Service public class EMFImagePathService implements IImagePathService { - private static final List IMAGES_PATHS = List.of("/icons/full/obj16", "/icons/full/ovr16"); + private static final List IMAGES_PATHS = List.of("/icons/full/obj16", "/icons/full/ovr16", "/icons"); @Override public List getPaths() { diff --git a/packages/emf/backend/sirius-components-emf/src/main/resources/icons/Resource.svg b/packages/emf/backend/sirius-components-emf/src/main/resources/icons/Resource.svg new file mode 100644 index 00000000000..1a76ef6435a --- /dev/null +++ b/packages/emf/backend/sirius-components-emf/src/main/resources/icons/Resource.svg @@ -0,0 +1,8 @@ + + + + diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/SelectionEventProcessor.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/SelectionEventProcessor.java deleted file mode 100644 index 5fd7ef82ac4..00000000000 --- a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/SelectionEventProcessor.java +++ /dev/null @@ -1,173 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2021, 2024 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.collaborative.selection; - -import java.util.Objects; -import java.util.concurrent.atomic.AtomicReference; - -import org.eclipse.sirius.components.collaborative.api.ChangeDescription; -import org.eclipse.sirius.components.collaborative.api.ChangeKind; -import org.eclipse.sirius.components.collaborative.api.IRepresentationRefreshPolicy; -import org.eclipse.sirius.components.collaborative.api.IRepresentationRefreshPolicyRegistry; -import org.eclipse.sirius.components.collaborative.api.ISubscriptionManager; -import org.eclipse.sirius.components.collaborative.selection.api.ISelectionEventProcessor; -import org.eclipse.sirius.components.collaborative.selection.dto.SelectionRefreshedEventPayload; -import org.eclipse.sirius.components.core.api.IEditingContext; -import org.eclipse.sirius.components.core.api.IInput; -import org.eclipse.sirius.components.core.api.IObjectService; -import org.eclipse.sirius.components.core.api.IPayload; -import org.eclipse.sirius.components.core.api.IRepresentationInput; -import org.eclipse.sirius.components.representations.GetOrCreateRandomIdProvider; -import org.eclipse.sirius.components.representations.IRepresentation; -import org.eclipse.sirius.components.representations.VariableManager; -import org.eclipse.sirius.components.selection.Selection; -import org.eclipse.sirius.components.selection.description.SelectionDescription; -import org.eclipse.sirius.components.selection.renderer.SelectionRenderer; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import reactor.core.publisher.Flux; -import reactor.core.publisher.Mono; -import reactor.core.publisher.Sinks; -import reactor.core.publisher.Sinks.EmitResult; -import reactor.core.publisher.Sinks.Many; -import reactor.core.publisher.Sinks.One; - -/** - * Reacts to the input that target the selection and publishes updated versions of the {@link Selection} to interested - * subscribers. - * - * @author arichard - */ -public class SelectionEventProcessor implements ISelectionEventProcessor { - - private final Logger logger = LoggerFactory.getLogger(SelectionEventProcessor.class); - - private final IEditingContext editingContext; - - private final SelectionDescription selectionDescription; - - private final IObjectService objectService; - - private final String id; - - private final String objectId; - - private final IRepresentationRefreshPolicyRegistry representationRefreshPolicyRegistry; - - private final ISubscriptionManager subscriptionManager; - - private final Many sink = Sinks.many().multicast().directBestEffort(); - - private final AtomicReference currentSelection = new AtomicReference<>(); - - public SelectionEventProcessor(IEditingContext editingContext, IObjectService objectService, SelectionDescription selectionDescription, String id, String objectId, ISubscriptionManager subscriptionManager, - IRepresentationRefreshPolicyRegistry representationRefreshPolicyRegistry) { - this.logger.trace("Creating the selection event processor {}", id); - this.objectService = Objects.requireNonNull(objectService); - this.selectionDescription = Objects.requireNonNull(selectionDescription); - this.editingContext = Objects.requireNonNull(editingContext); - this.id = Objects.requireNonNull(id); - this.objectId = Objects.requireNonNull(objectId); - this.subscriptionManager = Objects.requireNonNull(subscriptionManager); - this.representationRefreshPolicyRegistry = Objects.requireNonNull(representationRefreshPolicyRegistry); - - Selection selection = this.refreshSelection(); - this.currentSelection.set(selection); - - } - - @Override - public IRepresentation getRepresentation() { - return this.currentSelection.get(); - } - - @Override - public ISubscriptionManager getSubscriptionManager() { - return this.subscriptionManager; - } - - @Override - public void handle(One payloadSink, Many changeDescriptionSink, IRepresentationInput representationInput) { - // Do nothing - } - - @Override - public void refresh(ChangeDescription changeDescription) { - if (this.shouldRefresh(changeDescription)) { - Selection selection = this.refreshSelection(); - - this.currentSelection.set(selection); - if (this.sink.currentSubscriberCount() > 0) { - EmitResult emitResult = this.sink.tryEmitNext(new SelectionRefreshedEventPayload(changeDescription.getInput().id(), selection)); - if (emitResult.isFailure()) { - String pattern = "An error has occurred while emitting a SelectionRefreshedEventPayload: {}"; - this.logger.warn(pattern, emitResult); - } - } - } - } - - private boolean shouldRefresh(ChangeDescription changeDescription) { - // @formatter:off - return this.representationRefreshPolicyRegistry.getRepresentationRefreshPolicy(this.selectionDescription) - .orElseGet(this::getDefaultRefreshPolicy) - .shouldRefresh(changeDescription); - // @formatter:on - } - - private IRepresentationRefreshPolicy getDefaultRefreshPolicy() { - return (changeDescription) -> ChangeKind.SEMANTIC_CHANGE.equals(changeDescription.getKind()); - } - - private Selection refreshSelection() { - VariableManager variableManager = new VariableManager(); - var optionalObject = this.objectService.getObject(this.editingContext, this.objectId); - variableManager.put(VariableManager.SELF, optionalObject.orElse(null)); - variableManager.put(IEditingContext.EDITING_CONTEXT, this.editingContext); - variableManager.put(GetOrCreateRandomIdProvider.PREVIOUS_REPRESENTATION_ID, this.id); - - Selection selection = new SelectionRenderer(variableManager, this.selectionDescription).render(); - - this.logger.trace("Selection refreshed: {}", selection.getId()); - - return selection; - } - - @Override - public Flux getOutputEvents(IInput input) { - var initialRefresh = Mono.fromCallable(() -> new SelectionRefreshedEventPayload(input.id(), this.currentSelection.get())); - var refreshEventFlux = Flux.concat(initialRefresh, this.sink.asFlux()); - - // @formatter:off - return Flux.merge( - refreshEventFlux, - this.subscriptionManager.getFlux(input) - ); - // @formatter:on - } - - @Override - public void dispose() { - this.logger.trace("Disposing the selection event processor {}", this.id); - - this.subscriptionManager.dispose(); - - EmitResult emitResult = this.sink.tryEmitComplete(); - if (emitResult.isFailure()) { - String pattern = "An error has occurred while marking the publisher as complete: {}"; - this.logger.warn(pattern, emitResult); - } - } - -} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/SelectionEventProcessorFactory.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/SelectionEventProcessorFactory.java deleted file mode 100644 index 5cb65314a8c..00000000000 --- a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/SelectionEventProcessorFactory.java +++ /dev/null @@ -1,84 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2021, 2024 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.collaborative.selection; - -import java.util.Objects; -import java.util.Optional; - -import org.eclipse.sirius.components.collaborative.api.IRepresentationConfiguration; -import org.eclipse.sirius.components.collaborative.api.IRepresentationEventProcessor; -import org.eclipse.sirius.components.collaborative.api.IRepresentationEventProcessorFactory; -import org.eclipse.sirius.components.collaborative.api.IRepresentationRefreshPolicyRegistry; -import org.eclipse.sirius.components.collaborative.api.ISubscriptionManagerFactory; -import org.eclipse.sirius.components.collaborative.api.RepresentationEventProcessorFactoryConfiguration; -import org.eclipse.sirius.components.collaborative.selection.api.SelectionConfiguration; -import org.eclipse.sirius.components.core.api.IEditingContext; -import org.eclipse.sirius.components.core.api.IObjectService; -import org.eclipse.sirius.components.core.api.IRepresentationDescriptionSearchService; -import org.eclipse.sirius.components.selection.description.SelectionDescription; -import org.springframework.stereotype.Service; - -/** - * Used to create the selection event processors. - * - * @author arichard - */ -@Service -public class SelectionEventProcessorFactory implements IRepresentationEventProcessorFactory { - - private final IRepresentationDescriptionSearchService representationDescriptionSearchService; - - private final IObjectService objectService; - - private final ISubscriptionManagerFactory subscriptionManagerFactory; - - private final IRepresentationRefreshPolicyRegistry representationRefreshPolicyRegistry; - - public SelectionEventProcessorFactory(RepresentationEventProcessorFactoryConfiguration configuration, IObjectService objectService) { - this.representationDescriptionSearchService = Objects.requireNonNull(configuration.getRepresentationDescriptionSearchService()); - this.objectService = Objects.requireNonNull(objectService); - this.subscriptionManagerFactory = Objects.requireNonNull(configuration.getSubscriptionManagerFactory()); - this.representationRefreshPolicyRegistry = Objects.requireNonNull(configuration.getRepresentationRefreshPolicyRegistry()); - } - - @Override - public boolean canHandle(IRepresentationConfiguration configuration) { - return configuration instanceof SelectionConfiguration; - } - - @Override - public Optional createRepresentationEventProcessor(IRepresentationConfiguration configuration, IEditingContext editingContext) { - if (configuration instanceof SelectionConfiguration selectionConfiguration) { - - // @formatter:off - Optional optionalSelectionDescription = this.representationDescriptionSearchService - .findById(editingContext, selectionConfiguration.getSelectionId()) - .filter(SelectionDescription.class::isInstance) - .map(SelectionDescription.class::cast); - // @formatter:on - - Optional optionalObject = this.objectService.getObject(editingContext, selectionConfiguration.getTargetObjectId()); - if (optionalSelectionDescription.isPresent() && optionalObject.isPresent()) { - SelectionDescription selectionDescription = optionalSelectionDescription.get(); - String objectId = this.objectService.getId(optionalObject.get()); - - IRepresentationEventProcessor selectionEventProcessor = new SelectionEventProcessor(editingContext, this.objectService, selectionDescription, selectionConfiguration.getId(), objectId, - this.subscriptionManagerFactory.create(), this.representationRefreshPolicyRegistry); - - return Optional.of(selectionEventProcessor); - } - } - return Optional.empty(); - } - -} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/api/ISelectionEventProcessor.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/api/ISelectionEventProcessor.java deleted file mode 100644 index 173bcff2140..00000000000 --- a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/api/ISelectionEventProcessor.java +++ /dev/null @@ -1,31 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2021 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.collaborative.selection.api; - -import org.eclipse.sirius.components.collaborative.api.IRepresentationEventProcessor; - -/** - * Interface implemented by the selection event processor. - * - * @author arichard - */ -public interface ISelectionEventProcessor extends IRepresentationEventProcessor { - /** - * Implementation which does nothing, used for mocks in unit tests. - * - * @author sbegaudeau - */ - class NoOp extends IRepresentationEventProcessor.NoOp implements ISelectionEventProcessor { - - } -} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/api/ISelectionInput.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/api/ISelectionInput.java deleted file mode 100644 index edb738b09ea..00000000000 --- a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/api/ISelectionInput.java +++ /dev/null @@ -1,24 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2021 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.collaborative.selection.api; - -import org.eclipse.sirius.components.core.api.IRepresentationInput; - -/** - * Represents an input sent by a client which concerns a selection representation. - * - * @author arichard - */ -public interface ISelectionInput extends IRepresentationInput { - -} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/api/SelectionConfiguration.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/api/SelectionConfiguration.java deleted file mode 100644 index 34ef60fb98e..00000000000 --- a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/api/SelectionConfiguration.java +++ /dev/null @@ -1,51 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2021, 2022 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.collaborative.selection.api; - -import java.util.Objects; - -import org.eclipse.sirius.components.collaborative.api.IRepresentationConfiguration; - -/** - * The configuration used to create a selection event processor. - * - * @author arichard - */ -public class SelectionConfiguration implements IRepresentationConfiguration { - - private final String id; - - private final String selectionId; - - private final String targetObjectId; - - public SelectionConfiguration(String id, String selectionId, String targetObjectId) { - this.id = Objects.requireNonNull(id); - this.selectionId = Objects.requireNonNull(selectionId); - this.targetObjectId = Objects.requireNonNull(targetObjectId); - } - - @Override - public String getId() { - return this.id; - } - - public String getSelectionId() { - return this.selectionId; - } - - public String getTargetObjectId() { - return this.targetObjectId; - } - -} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionMessageInput.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionMessageInput.java new file mode 100644 index 00000000000..7644176de42 --- /dev/null +++ b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionMessageInput.java @@ -0,0 +1,32 @@ +/******************************************************************************* + * Copyright (c) 2024 Obeo. + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Obeo - initial API and implementation + *******************************************************************************/ +package org.eclipse.sirius.components.collaborative.selection.dto; + +import java.util.Objects; +import java.util.UUID; + +import org.eclipse.sirius.components.core.api.IInput; +import org.eclipse.sirius.components.selection.description.SelectionDescription; + +/** + * The input for the Selection Description message query. + * + * @author fbarbin + */ +public record SelectionDescriptionMessageInput(UUID id, String targetObjectId, SelectionDescription selectionDescription) implements IInput { + public SelectionDescriptionMessageInput { + Objects.requireNonNull(id); + Objects.requireNonNull(targetObjectId); + Objects.requireNonNull(selectionDescription); + } +} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionRefreshedEventPayload.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionMessagePayload.java similarity index 66% rename from packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionRefreshedEventPayload.java rename to packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionMessagePayload.java index 6a5a9e4453f..c1451c2b42d 100644 --- a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionRefreshedEventPayload.java +++ b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionMessagePayload.java @@ -1,5 +1,5 @@ /******************************************************************************* - * Copyright (c) 2021, 2023 Obeo. + * Copyright (c) 2024 Obeo. * This program and the accompanying materials * are made available under the terms of the Eclipse Public License v2.0 * which accompanies this distribution, and is available at @@ -16,16 +16,15 @@ import java.util.UUID; import org.eclipse.sirius.components.core.api.IPayload; -import org.eclipse.sirius.components.selection.Selection; /** - * Payload used to indicate that the selection has been refreshed. - * - * @author arichard + * The input for the Selection Description message query. + * @author fbarbin */ -public record SelectionRefreshedEventPayload(UUID id, Selection selection) implements IPayload { - public SelectionRefreshedEventPayload { +public record SelectionDescriptionMessagePayload(UUID id, String message) implements IPayload { + + public SelectionDescriptionMessagePayload { Objects.requireNonNull(id); - Objects.requireNonNull(selection); + Objects.requireNonNull(message); } } diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionEventInput.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionTreeDescriptionIdInput.java similarity index 56% rename from packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionEventInput.java rename to packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionTreeDescriptionIdInput.java index 94e46521c40..1b4e5bdaf6e 100644 --- a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionEventInput.java +++ b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionTreeDescriptionIdInput.java @@ -1,5 +1,5 @@ /******************************************************************************* - * Copyright (c) 2021, 2023 Obeo. + * Copyright (c) 2024 Obeo. * This program and the accompanying materials * are made available under the terms of the Eclipse Public License v2.0 * which accompanies this distribution, and is available at @@ -12,14 +12,20 @@ *******************************************************************************/ package org.eclipse.sirius.components.collaborative.selection.dto; +import java.util.Objects; import java.util.UUID; import org.eclipse.sirius.components.core.api.IInput; +import org.eclipse.sirius.components.selection.description.SelectionDescription; /** - * The input of the selection event subscription. + * The input for the Selection Description message query. * - * @author arichard + * @author fbarbin */ -public record SelectionEventInput(UUID id, String editingContextId, String selectionId, String targetObjectId) implements IInput { +public record SelectionDescriptionTreeDescriptionIdInput(UUID id, SelectionDescription selectionDescription) implements IInput { + public SelectionDescriptionTreeDescriptionIdInput { + Objects.requireNonNull(id); + Objects.requireNonNull(selectionDescription); + } } diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionTreeDescriptionIdPayload.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionTreeDescriptionIdPayload.java new file mode 100644 index 00000000000..72b27f88f11 --- /dev/null +++ b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/dto/SelectionDescriptionTreeDescriptionIdPayload.java @@ -0,0 +1,30 @@ +/******************************************************************************* + * Copyright (c) 2024 Obeo. + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Obeo - initial API and implementation + *******************************************************************************/ +package org.eclipse.sirius.components.collaborative.selection.dto; + +import java.util.Objects; +import java.util.UUID; + +import org.eclipse.sirius.components.core.api.IPayload; + +/** + * The input for the Selection Description message query. + * @author fbarbin + */ +public record SelectionDescriptionTreeDescriptionIdPayload(UUID id, String treeDescriptionId) implements IPayload { + + public SelectionDescriptionTreeDescriptionIdPayload { + Objects.requireNonNull(id); + Objects.requireNonNull(treeDescriptionId); + } +} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/handlers/SelectionDescriptionMessageEventHandler.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/handlers/SelectionDescriptionMessageEventHandler.java new file mode 100644 index 00000000000..4e2e859ceb2 --- /dev/null +++ b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/handlers/SelectionDescriptionMessageEventHandler.java @@ -0,0 +1,66 @@ +/******************************************************************************* + * Copyright (c) 2024 Obeo. + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Obeo - initial API and implementation + *******************************************************************************/ +package org.eclipse.sirius.components.collaborative.selection.handlers; + +import java.util.Objects; +import java.util.Optional; + +import org.eclipse.sirius.components.collaborative.api.ChangeDescription; +import org.eclipse.sirius.components.collaborative.api.IEditingContextEventHandler; +import org.eclipse.sirius.components.collaborative.selection.dto.SelectionDescriptionMessageInput; +import org.eclipse.sirius.components.collaborative.selection.dto.SelectionDescriptionMessagePayload; +import org.eclipse.sirius.components.core.api.IEditingContext; +import org.eclipse.sirius.components.core.api.IInput; +import org.eclipse.sirius.components.core.api.IObjectService; +import org.eclipse.sirius.components.core.api.IPayload; +import org.eclipse.sirius.components.representations.VariableManager; +import org.eclipse.sirius.components.selection.description.SelectionDescription; +import org.springframework.stereotype.Service; + +import reactor.core.publisher.Sinks.Many; +import reactor.core.publisher.Sinks.One; + +/** + * Handler for the SelectionDescriptionMessageInput. + * + * @author fbarbin + */ +@Service +public class SelectionDescriptionMessageEventHandler implements IEditingContextEventHandler { + + private final IObjectService objectService; + + public SelectionDescriptionMessageEventHandler(IObjectService objectService) { + this.objectService = Objects.requireNonNull(objectService); + } + + @Override + public boolean canHandle(IEditingContext editingContext, IInput input) { + return input instanceof SelectionDescriptionMessageInput; + } + + @Override + public void handle(One payloadSink, Many changeDescriptionSink, IEditingContext editingContext, IInput input) { + if (input instanceof SelectionDescriptionMessageInput selectionDescriptionMessageInput) { + String targetObjectId = selectionDescriptionMessageInput.targetObjectId(); + Optional optionalTargetObject = this.objectService.getObject(editingContext, targetObjectId); + if (optionalTargetObject.isPresent()) { + VariableManager variableManager = new VariableManager(); + variableManager.put(VariableManager.SELF, optionalTargetObject.get()); + SelectionDescription selectionDescription = selectionDescriptionMessageInput.selectionDescription(); + String message = selectionDescription.getMessageProvider().apply(variableManager); + payloadSink.tryEmitValue(new SelectionDescriptionMessagePayload(input.id(), message)); + } + } + } +} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/handlers/SelectionDescriptionTreeDescriptionIdEventHandler.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/handlers/SelectionDescriptionTreeDescriptionIdEventHandler.java new file mode 100644 index 00000000000..ca5c8e3ff75 --- /dev/null +++ b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/handlers/SelectionDescriptionTreeDescriptionIdEventHandler.java @@ -0,0 +1,50 @@ +/******************************************************************************* + * Copyright (c) 2024 Obeo. + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Obeo - initial API and implementation + *******************************************************************************/ +package org.eclipse.sirius.components.collaborative.selection.handlers; + +import org.eclipse.sirius.components.collaborative.api.ChangeDescription; +import org.eclipse.sirius.components.collaborative.api.IEditingContextEventHandler; +import org.eclipse.sirius.components.collaborative.selection.dto.SelectionDescriptionTreeDescriptionIdInput; +import org.eclipse.sirius.components.collaborative.selection.dto.SelectionDescriptionTreeDescriptionIdPayload; +import org.eclipse.sirius.components.core.api.IEditingContext; +import org.eclipse.sirius.components.core.api.IInput; +import org.eclipse.sirius.components.core.api.IPayload; +import org.eclipse.sirius.components.selection.description.SelectionDescription; +import org.springframework.stereotype.Service; + +import reactor.core.publisher.Sinks.Many; +import reactor.core.publisher.Sinks.One; + +/** + * Handler for the SelectionDescriptionMessageInput. + * + * @author fbarbin + */ +@Service +public class SelectionDescriptionTreeDescriptionIdEventHandler implements IEditingContextEventHandler { + + + @Override + public boolean canHandle(IEditingContext editingContext, IInput input) { + return input instanceof SelectionDescriptionTreeDescriptionIdInput; + } + + @Override + public void handle(One payloadSink, Many changeDescriptionSink, IEditingContext editingContext, IInput input) { + if (input instanceof SelectionDescriptionTreeDescriptionIdInput selectionDescriptionTreeDescriptionIdInput) { + SelectionDescription selectionDescription = selectionDescriptionTreeDescriptionIdInput.selectionDescription(); + String treeDescriptionId = selectionDescription.getTreeDescription().getId(); + payloadSink.tryEmitValue(new SelectionDescriptionTreeDescriptionIdPayload(input.id(), treeDescriptionId)); + } + } +} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/services/SelectionRepresentationMetadataProvider.java b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/services/SelectionRepresentationMetadataProvider.java new file mode 100644 index 00000000000..eb5e558e35d --- /dev/null +++ b/packages/selection/backend/sirius-components-collaborative-selection/src/main/java/org/eclipse/sirius/components/collaborative/selection/services/SelectionRepresentationMetadataProvider.java @@ -0,0 +1,36 @@ +/******************************************************************************* + * Copyright (c) 2024 Obeo. + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Obeo - initial API and implementation + *******************************************************************************/ +package org.eclipse.sirius.components.collaborative.selection.services; + +import java.util.Optional; + +import org.eclipse.sirius.components.core.RepresentationMetadata; +import org.eclipse.sirius.components.core.api.IRepresentationMetadataProvider; +import org.springframework.stereotype.Service; + +/** + * A Service to provide metadata for the Selection Dialog Representation. + * @author fbarbin + */ +@Service +public class SelectionRepresentationMetadataProvider implements IRepresentationMetadataProvider { + + @Override + public Optional getMetadata(String representationId) { + if (representationId.startsWith("siriusComponents://selectionDialogDescription")) { + return Optional.of(new RepresentationMetadata("selectionDialogID", "SelectionRepresentation", "Selection Representation", representationId)); + } + return Optional.empty(); + } + +} diff --git a/packages/selection/backend/sirius-components-collaborative-selection/src/main/resources/schema/selection.graphqls b/packages/selection/backend/sirius-components-collaborative-selection/src/main/resources/schema/selection.graphqls index 35ff9563065..b6020307c59 100644 --- a/packages/selection/backend/sirius-components-collaborative-selection/src/main/resources/schema/selection.graphqls +++ b/packages/selection/backend/sirius-components-collaborative-selection/src/main/resources/schema/selection.graphqls @@ -1,36 +1,6 @@ -extend type Subscription { - selectionEvent(input: SelectionEventInput!): SelectionEventPayload! -} - -input SelectionEventInput { - id: ID! - editingContextId: ID! - selectionId: ID! - targetObjectId: ID! -} - -union SelectionEventPayload = ErrorPayload | SelectionRefreshedEventPayload - -type SelectionRefreshedEventPayload { - id: ID! - selection: Selection! -} - -type Selection implements Representation { - id: ID! - metadata: RepresentationMetadata! - targetObjectId: String! - message: String - objects: [SelectionObject!]! -} - -type SelectionObject { - id: ID! - label: String! - iconURL: [String!]! -} - type SelectionDescription implements RepresentationDescription { id: ID! label: String! + message(targetObjectId: ID!): String! + treeDescriptionId: String! } diff --git a/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/selection/SelectionDescriptionMessageDataFetcher.java b/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/selection/SelectionDescriptionMessageDataFetcher.java new file mode 100644 index 00000000000..05ea23c433d --- /dev/null +++ b/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/selection/SelectionDescriptionMessageDataFetcher.java @@ -0,0 +1,66 @@ +/******************************************************************************* + * Copyright (c) 2024 Obeo. + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Obeo - initial API and implementation + *******************************************************************************/ +package org.eclipse.sirius.components.selection.graphql.datafetchers.selection; + +import java.util.Map; +import java.util.Objects; +import java.util.Optional; +import java.util.UUID; +import java.util.concurrent.CompletableFuture; + +import org.eclipse.sirius.components.annotations.spring.graphql.QueryDataFetcher; +import org.eclipse.sirius.components.collaborative.api.IEditingContextEventProcessorRegistry; +import org.eclipse.sirius.components.collaborative.selection.dto.SelectionDescriptionMessageInput; +import org.eclipse.sirius.components.collaborative.selection.dto.SelectionDescriptionMessagePayload; +import org.eclipse.sirius.components.graphql.api.IDataFetcherWithFieldCoordinates; +import org.eclipse.sirius.components.graphql.api.LocalContextConstants; +import org.eclipse.sirius.components.selection.description.SelectionDescription; + +import graphql.schema.DataFetchingEnvironment; +import reactor.core.publisher.Mono; + +/** + * The data fetcher use to compute the message defined in the Selection Dialog Description. + * @author fbarbin + */ +@QueryDataFetcher(type = "SelectionDescription", field = "message") +public class SelectionDescriptionMessageDataFetcher implements IDataFetcherWithFieldCoordinates> { + + private static final String TARGET_OBJECT_ID = "targetObjectId"; + + private final IEditingContextEventProcessorRegistry editingContextEventProcessorRegistry; + + public SelectionDescriptionMessageDataFetcher(IEditingContextEventProcessorRegistry editingContextEventProcessorRegistry) { + this.editingContextEventProcessorRegistry = Objects.requireNonNull(editingContextEventProcessorRegistry); + } + + @Override + public CompletableFuture get(DataFetchingEnvironment environment) throws Exception { + SelectionDescription selectionDescription = environment.getSource(); + + Map localContext = environment.getLocalContext(); + var editingContextId = Optional.ofNullable(localContext.get(LocalContextConstants.EDITING_CONTEXT_ID)).map(Object::toString); + String targetObjectId = environment.getArgument(TARGET_OBJECT_ID); + + if (editingContextId.isPresent() && targetObjectId != null && selectionDescription != null) { + var input = new SelectionDescriptionMessageInput(UUID.randomUUID(), targetObjectId, selectionDescription); + return this.editingContextEventProcessorRegistry.dispatchEvent(editingContextId.get(), input) + .filter(SelectionDescriptionMessagePayload.class::isInstance) + .map(SelectionDescriptionMessagePayload.class::cast) + .map(SelectionDescriptionMessagePayload::message) + .toFuture(); + } + return Mono. empty().toFuture(); + } + +} diff --git a/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/selection/SelectionDescriptionTreeDescriptionIdDataFetcher.java b/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/selection/SelectionDescriptionTreeDescriptionIdDataFetcher.java new file mode 100644 index 00000000000..8e2686e9051 --- /dev/null +++ b/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/selection/SelectionDescriptionTreeDescriptionIdDataFetcher.java @@ -0,0 +1,63 @@ +/******************************************************************************* + * Copyright (c) 2024 Obeo. + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Obeo - initial API and implementation + *******************************************************************************/ +package org.eclipse.sirius.components.selection.graphql.datafetchers.selection; + +import java.util.Map; +import java.util.Objects; +import java.util.Optional; +import java.util.UUID; +import java.util.concurrent.CompletableFuture; + +import org.eclipse.sirius.components.annotations.spring.graphql.QueryDataFetcher; +import org.eclipse.sirius.components.collaborative.api.IEditingContextEventProcessorRegistry; +import org.eclipse.sirius.components.collaborative.selection.dto.SelectionDescriptionTreeDescriptionIdInput; +import org.eclipse.sirius.components.collaborative.selection.dto.SelectionDescriptionTreeDescriptionIdPayload; +import org.eclipse.sirius.components.graphql.api.IDataFetcherWithFieldCoordinates; +import org.eclipse.sirius.components.graphql.api.LocalContextConstants; +import org.eclipse.sirius.components.selection.description.SelectionDescription; + +import graphql.schema.DataFetchingEnvironment; +import reactor.core.publisher.Mono; + +/** + * The data fetcher use to compute the treeDescriptionId defined in the Selection Dialog Description. + * @author fbarbin + */ +@QueryDataFetcher(type = "SelectionDescription", field = "treeDescriptionId") +public class SelectionDescriptionTreeDescriptionIdDataFetcher implements IDataFetcherWithFieldCoordinates> { + + private final IEditingContextEventProcessorRegistry editingContextEventProcessorRegistry; + + public SelectionDescriptionTreeDescriptionIdDataFetcher(IEditingContextEventProcessorRegistry editingContextEventProcessorRegistry) { + this.editingContextEventProcessorRegistry = Objects.requireNonNull(editingContextEventProcessorRegistry); + } + + @Override + public CompletableFuture get(DataFetchingEnvironment environment) throws Exception { + SelectionDescription selectionDescription = environment.getSource(); + + Map localContext = environment.getLocalContext(); + var editingContextId = Optional.ofNullable(localContext.get(LocalContextConstants.EDITING_CONTEXT_ID)).map(Object::toString); + + if (editingContextId.isPresent() && selectionDescription != null) { + var input = new SelectionDescriptionTreeDescriptionIdInput(UUID.randomUUID(), selectionDescription); + return this.editingContextEventProcessorRegistry.dispatchEvent(editingContextId.get(), input) + .filter(SelectionDescriptionTreeDescriptionIdPayload.class::isInstance) + .map(SelectionDescriptionTreeDescriptionIdPayload.class::cast) + .map(SelectionDescriptionTreeDescriptionIdPayload::treeDescriptionId) + .toFuture(); + } + return Mono. empty().toFuture(); + } + +} diff --git a/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/selection/SelectionObjectIconURLDataFetcher.java b/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/selection/SelectionObjectIconURLDataFetcher.java deleted file mode 100644 index d0d3f69ef17..00000000000 --- a/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/selection/SelectionObjectIconURLDataFetcher.java +++ /dev/null @@ -1,47 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2022, 2024 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.selection.graphql.datafetchers.selection; - -import java.util.List; -import java.util.Objects; - -import org.eclipse.sirius.components.annotations.spring.graphql.QueryDataFetcher; -import org.eclipse.sirius.components.core.api.IImageURLSanitizer; -import org.eclipse.sirius.components.graphql.api.IDataFetcherWithFieldCoordinates; -import org.eclipse.sirius.components.graphql.api.URLConstants; -import org.eclipse.sirius.components.selection.SelectionObject; - -import graphql.schema.DataFetchingEnvironment; - -/** - * The data fetcher used to concatenate the server image URL to the SelectionObject icon path. - * - * @author arichard - */ -@QueryDataFetcher(type = "SelectionObject", field = "iconURL") -public class SelectionObjectIconURLDataFetcher implements IDataFetcherWithFieldCoordinates> { - - private final IImageURLSanitizer imageURLSanitizer; - - public SelectionObjectIconURLDataFetcher(IImageURLSanitizer imageURLSanitizer) { - this.imageURLSanitizer = Objects.requireNonNull(imageURLSanitizer); - } - - @Override - public List get(DataFetchingEnvironment environment) throws Exception { - SelectionObject selectionObject = environment.getSource(); - return selectionObject.getIconURL().stream() - .map(url -> this.imageURLSanitizer.sanitize(URLConstants.IMAGE_BASE_PATH, url)) - .toList(); - } -} diff --git a/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/subscription/SelectionRefreshedEventPayloadSelectionDataFetcher.java b/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/subscription/SelectionRefreshedEventPayloadSelectionDataFetcher.java deleted file mode 100644 index 5b967184324..00000000000 --- a/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/subscription/SelectionRefreshedEventPayloadSelectionDataFetcher.java +++ /dev/null @@ -1,38 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2023 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.selection.graphql.datafetchers.subscription; - -import org.eclipse.sirius.components.annotations.spring.graphql.QueryDataFetcher; -import org.eclipse.sirius.components.collaborative.selection.dto.SelectionRefreshedEventPayload; -import org.eclipse.sirius.components.graphql.api.IDataFetcherWithFieldCoordinates; -import org.eclipse.sirius.components.selection.Selection; - -import graphql.execution.DataFetcherResult; -import graphql.schema.DataFetchingEnvironment; - -/** - * Used to retrieve the selection from its payload. - * - * @author sbegaudeau - */ -@QueryDataFetcher(type = "SelectionRefreshedEventPayload", field = "selection") -public class SelectionRefreshedEventPayloadSelectionDataFetcher implements IDataFetcherWithFieldCoordinates> { - @Override - public DataFetcherResult get(DataFetchingEnvironment environment) throws Exception { - SelectionRefreshedEventPayload payload = environment.getSource(); - return DataFetcherResult.newResult() - .data(payload.selection()) - .localContext(environment.getLocalContext()) - .build(); - } -} diff --git a/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/subscription/SubscriptionSelectionEventDataFetcher.java b/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/subscription/SubscriptionSelectionEventDataFetcher.java deleted file mode 100644 index a6a6537fe5f..00000000000 --- a/packages/selection/backend/sirius-components-selection-graphql/src/main/java/org/eclipse/sirius/components/selection/graphql/datafetchers/subscription/SubscriptionSelectionEventDataFetcher.java +++ /dev/null @@ -1,73 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2022, 2024 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.selection.graphql.datafetchers.subscription; - -import com.fasterxml.jackson.databind.ObjectMapper; -import java.util.HashMap; -import java.util.Map; -import java.util.Objects; -import java.util.UUID; - -import org.eclipse.sirius.components.annotations.spring.graphql.SubscriptionDataFetcher; -import org.eclipse.sirius.components.collaborative.selection.api.SelectionConfiguration; -import org.eclipse.sirius.components.collaborative.selection.dto.SelectionEventInput; -import org.eclipse.sirius.components.core.api.IPayload; -import org.eclipse.sirius.components.graphql.api.IDataFetcherWithFieldCoordinates; -import org.eclipse.sirius.components.graphql.api.IEventProcessorSubscriptionProvider; -import org.eclipse.sirius.components.graphql.api.IExceptionWrapper; -import org.eclipse.sirius.components.graphql.api.LocalContextConstants; -import org.reactivestreams.Publisher; - -import graphql.execution.DataFetcherResult; -import graphql.schema.DataFetchingEnvironment; - -/** - * The data fetcher used to send the refreshed tree to a subscription. - * - * @author arichard - */ -@SubscriptionDataFetcher(type = "Subscription", field = "selectionEvent") -public class SubscriptionSelectionEventDataFetcher implements IDataFetcherWithFieldCoordinates>> { - - private static final String INPUT_ARGUMENT = "input"; - - private final ObjectMapper objectMapper; - - private final IExceptionWrapper exceptionWrapper; - - private final IEventProcessorSubscriptionProvider eventProcessorSubscriptionProvider; - - public SubscriptionSelectionEventDataFetcher(ObjectMapper objectMapper, IExceptionWrapper exceptionWrapper, IEventProcessorSubscriptionProvider eventProcessorSubscriptionProvider) { - this.objectMapper = Objects.requireNonNull(objectMapper); - this.exceptionWrapper = Objects.requireNonNull(exceptionWrapper); - this.eventProcessorSubscriptionProvider = Objects.requireNonNull(eventProcessorSubscriptionProvider); - } - - @Override - public Publisher> get(DataFetchingEnvironment environment) throws Exception { - Object argument = environment.getArgument(INPUT_ARGUMENT); - var input = this.objectMapper.convertValue(argument, SelectionEventInput.class); - var selectionConfiguration = new SelectionConfiguration(UUID.randomUUID().toString(), input.selectionId(), input.targetObjectId()); - - Map localContext = new HashMap<>(); - localContext.put(LocalContextConstants.EDITING_CONTEXT_ID, input.editingContextId()); - localContext.put(LocalContextConstants.REPRESENTATION_ID, selectionConfiguration.getId()); - - return this.exceptionWrapper.wrapFlux(() -> this.eventProcessorSubscriptionProvider.getSubscription(input.editingContextId(), selectionConfiguration, input), input) - .map(payload -> DataFetcherResult.newResult() - .data(payload) - .localContext(localContext) - .build()); - } - -} diff --git a/packages/selection/backend/sirius-components-selection/pom.xml b/packages/selection/backend/sirius-components-selection/pom.xml index 1e74cbc8f68..030d000480c 100644 --- a/packages/selection/backend/sirius-components-selection/pom.xml +++ b/packages/selection/backend/sirius-components-selection/pom.xml @@ -51,6 +51,11 @@ 2024.7.10 test + + org.eclipse.sirius + sirius-components-trees + 2024.7.10 + diff --git a/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/Selection.java b/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/Selection.java deleted file mode 100644 index 269f2560b0e..00000000000 --- a/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/Selection.java +++ /dev/null @@ -1,159 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2021, 2024 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.selection; - -import java.text.MessageFormat; -import java.util.List; -import java.util.Objects; - -import org.eclipse.sirius.components.annotations.Immutable; -import org.eclipse.sirius.components.representations.IRepresentation; - -/** - * The root concept of the selection representation. - * - * @author arichard - */ -@Immutable -public final class Selection implements IRepresentation { - - public static final String KIND = IRepresentation.KIND_PREFIX + "?type=Selection"; - - public static final String PREFIX = "selection://"; - - public static final String TITLE = "Selection"; - - private String id; - - private String kind; - - private String descriptionId; - - private String label; - - private String targetObjectId; - - private String message; - - private List objects; - - private Selection() { - // Prevent instantiation - } - - @Override - public String getId() { - return this.id; - } - - @Override - public String getDescriptionId() { - return this.descriptionId; - } - - @Override - public String getKind() { - return this.kind; - } - - @Override - public String getLabel() { - return this.label; - } - - @Override - public String getTargetObjectId() { - return this.targetObjectId; - } - - public String getMessage() { - return this.message; - } - - public List getObjects() { - return this.objects; - } - - public static Builder newSelection(String id) { - return new Builder(id); - } - - @Override - public String toString() { - String pattern = "{0} '{'id: {1}, descriptionId: {2}, targetObjectId: {3}, label: {4}, message: {5}, objectsCount: {6}'}'"; - return MessageFormat.format(pattern, this.getClass().getSimpleName(), this.id, this.descriptionId, this.targetObjectId, this.label, this.message, this.objects.size()); - } - - /** - * The builder used to create the selection. - * - * @author arichard - */ - @SuppressWarnings("checkstyle:HiddenField") - public static final class Builder { - private String id; - - private String kind = KIND; - - private String descriptionId; - - private String label; - - private String targetObjectId; - - private String message; - - private List objects; - - private Builder(String id) { - this.id = Objects.requireNonNull(id); - } - - public Builder descriptionId(String descriptionId) { - this.descriptionId = Objects.requireNonNull(descriptionId); - return this; - } - - public Builder label(String label) { - this.label = Objects.requireNonNull(label); - return this; - } - - public Builder targetObjectId(String targetObjectId) { - this.targetObjectId = Objects.requireNonNull(targetObjectId); - return this; - } - - public Builder message(String message) { - this.message = message; - return this; - } - - public Builder objects(List objects) { - this.objects = Objects.requireNonNull(objects); - return this; - } - - public Selection build() { - Selection selection = new Selection(); - selection.id = Objects.requireNonNull(this.id); - selection.kind = Objects.requireNonNull(this.kind); - selection.descriptionId = Objects.requireNonNull(this.descriptionId); - selection.label = Objects.requireNonNull(this.label); - selection.targetObjectId = Objects.requireNonNull(this.targetObjectId); - selection.message = this.message; - selection.objects = Objects.requireNonNull(this.objects); - return selection; - } - } -} diff --git a/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/description/SelectionDescription.java b/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/description/SelectionDescription.java index f1b2c8a4ab5..d325d18c26e 100644 --- a/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/description/SelectionDescription.java +++ b/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/description/SelectionDescription.java @@ -13,7 +13,6 @@ package org.eclipse.sirius.components.selection.description; import java.text.MessageFormat; -import java.util.List; import java.util.Objects; import java.util.function.Function; import java.util.function.Predicate; @@ -21,6 +20,7 @@ import org.eclipse.sirius.components.annotations.Immutable; import org.eclipse.sirius.components.representations.IRepresentationDescription; import org.eclipse.sirius.components.representations.VariableManager; +import org.eclipse.sirius.components.trees.description.TreeDescription; /** * The root concept of the description of a selection representation. @@ -40,16 +40,12 @@ public final class SelectionDescription implements IRepresentationDescription { private Function targetObjectIdProvider; - private Function> iconURLProvider; - private Function messageProvider; - private Function> objectsProvider; - - private Function selectionObjectsIdProvider; - private Predicate canCreatePredicate; + private TreeDescription treeDescription; + private SelectionDescription() { // Prevent instantiation } @@ -80,27 +76,20 @@ public Function getTargetObjectIdProvider() { return this.targetObjectIdProvider; } - public Function> getIconURLProvider() { - return this.iconURLProvider; - } public Function getMessageProvider() { return this.messageProvider; } - public Function> getObjectsProvider() { - return this.objectsProvider; - } - - public Function getSelectionObjectsIdProvider() { - return this.selectionObjectsIdProvider; - } - @Override public Predicate getCanCreatePredicate() { return this.canCreatePredicate; } + public TreeDescription getTreeDescription() { + return this.treeDescription; + } + @Override public String toString() { String pattern = "{0} '{'id: {1}, label: {2}'}'"; @@ -125,16 +114,12 @@ public static final class Builder { private Function targetObjectIdProvider; - private Function> iconURLProvider; - private Function messageProvider; - private Function> objectsProvider; - - private Function selectionObjectsIdProvider; - private Predicate canCreatePredicate; + private TreeDescription treeDescription; + private Builder(String id) { this.id = Objects.requireNonNull(id); } @@ -159,28 +144,18 @@ public Builder targetObjectIdProvider(Function targetOb return this; } - public Builder iconURLProvider(Function> iconURLProvider) { - this.iconURLProvider = Objects.requireNonNull(iconURLProvider); - return this; - } - public Builder messageProvider(Function messageProvider) { this.messageProvider = Objects.requireNonNull(messageProvider); return this; } - public Builder objectsProvider(Function> objectsProvider) { - this.objectsProvider = Objects.requireNonNull(objectsProvider); - return this; - } - - public Builder selectionObjectsIdProvider(Function selectionObjectsIdProvider) { - this.selectionObjectsIdProvider = Objects.requireNonNull(selectionObjectsIdProvider); + public Builder canCreatePredicate(Predicate canCreatePredicate) { + this.canCreatePredicate = Objects.requireNonNull(canCreatePredicate); return this; } - public Builder canCreatePredicate(Predicate canCreatePredicate) { - this.canCreatePredicate = Objects.requireNonNull(canCreatePredicate); + public Builder treeDescription(TreeDescription treeDescription) { + this.treeDescription = Objects.requireNonNull(treeDescription); return this; } @@ -191,13 +166,12 @@ public SelectionDescription build() { selectionDescription.idProvider = Objects.requireNonNull(this.idProvider); selectionDescription.labelProvider = Objects.requireNonNull(this.labelProvider); selectionDescription.targetObjectIdProvider = Objects.requireNonNull(this.targetObjectIdProvider); - selectionDescription.iconURLProvider = Objects.requireNonNull(this.iconURLProvider); selectionDescription.messageProvider = Objects.requireNonNull(this.messageProvider); - selectionDescription.objectsProvider = Objects.requireNonNull(this.objectsProvider); - selectionDescription.selectionObjectsIdProvider = Objects.requireNonNull(this.selectionObjectsIdProvider); selectionDescription.canCreatePredicate = Objects.requireNonNull(this.canCreatePredicate); + selectionDescription.treeDescription = Objects.requireNonNull(this.treeDescription); return selectionDescription; } } + } diff --git a/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/renderer/SelectionRenderer.java b/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/renderer/SelectionRenderer.java deleted file mode 100644 index df62719d1be..00000000000 --- a/packages/selection/backend/sirius-components-selection/src/main/java/org/eclipse/sirius/components/selection/renderer/SelectionRenderer.java +++ /dev/null @@ -1,76 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2021, 2023 Obeo. - * This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v2.0 - * which accompanies this distribution, and is available at - * https://www.eclipse.org/legal/epl-2.0/ - * - * SPDX-License-Identifier: EPL-2.0 - * - * Contributors: - * Obeo - initial API and implementation - *******************************************************************************/ -package org.eclipse.sirius.components.selection.renderer; - -import java.util.ArrayList; -import java.util.List; -import java.util.Objects; -import java.util.UUID; - -import org.eclipse.sirius.components.representations.VariableManager; -import org.eclipse.sirius.components.selection.Selection; -import org.eclipse.sirius.components.selection.SelectionObject; -import org.eclipse.sirius.components.selection.description.SelectionDescription; - -/** - * Renderer used to create the selection representation from its description and some variables. - * - * @author arichard - */ -public class SelectionRenderer { - - private final VariableManager variableManager; - - private final SelectionDescription selectionDescription; - - public SelectionRenderer(VariableManager variableManager, SelectionDescription selectionDescription) { - this.variableManager = Objects.requireNonNull(variableManager); - this.selectionDescription = Objects.requireNonNull(selectionDescription); - } - - public Selection render() { - String id = this.selectionDescription.getIdProvider().apply(this.variableManager); - String label = this.selectionDescription.getLabelProvider().apply(this.variableManager); - String message = this.selectionDescription.getMessageProvider().apply(this.variableManager); - String targetObjectId = this.selectionDescription.getTargetObjectIdProvider().apply(this.variableManager); - - List selectionObjects = this.selectionDescription.getObjectsProvider().apply(this.variableManager); - List objects = new ArrayList<>(selectionObjects.size()); - for (Object selectionObject : selectionObjects) { - VariableManager selectionObjectVariableManager = this.variableManager.createChild(); - selectionObjectVariableManager.put(VariableManager.SELF, selectionObject); - objects.add(this.renderSelectionObject(selectionObjectVariableManager)); - } - - // @formatter:off - return Selection.newSelection(id) - .descriptionId(this.selectionDescription.getId()) - .label(label) - .targetObjectId(targetObjectId) - .message(message) - .objects(objects) - .build(); - // @formatter:on - } - - private SelectionObject renderSelectionObject(VariableManager selectionObjectVariableManager) { - String id = this.selectionDescription.getSelectionObjectsIdProvider().apply(selectionObjectVariableManager); - String label = this.selectionDescription.getLabelProvider().apply(selectionObjectVariableManager); - List iconURL = this.selectionDescription.getIconURLProvider().apply(selectionObjectVariableManager); - - return SelectionObject.newSelectionObject(UUID.fromString(id)) - .label(label) - .iconURL(iconURL) - .build(); - } -} diff --git a/packages/selection/frontend/sirius-components-selection/src/SelectionDialog.tsx b/packages/selection/frontend/sirius-components-selection/src/SelectionDialog.tsx index af41701f836..931ae1804d2 100644 --- a/packages/selection/frontend/sirius-components-selection/src/SelectionDialog.tsx +++ b/packages/selection/frontend/sirius-components-selection/src/SelectionDialog.tsx @@ -10,64 +10,51 @@ * Contributors: * Obeo - initial API and implementation *******************************************************************************/ -import { gql, useSubscription } from '@apollo/client'; -import { IconOverlay, Toast } from '@eclipse-sirius/sirius-components-core'; +import { Selection, SelectionContext } from '@eclipse-sirius/sirius-components-core'; import { DiagramDialogComponentProps } from '@eclipse-sirius/sirius-components-diagrams'; +import { TreeItemActionProps, TreeView } from '@eclipse-sirius/sirius-components-trees'; +import UnfoldMoreIcon from '@mui/icons-material/UnfoldMore'; import Button from '@mui/material/Button'; import Dialog from '@mui/material/Dialog'; import DialogActions from '@mui/material/DialogActions'; import DialogContent from '@mui/material/DialogContent'; import DialogContentText from '@mui/material/DialogContentText'; import DialogTitle from '@mui/material/DialogTitle'; -import List from '@mui/material/List'; -import ListItem from '@mui/material/ListItem'; -import ListItemIcon from '@mui/material/ListItemIcon'; -import ListItemText from '@mui/material/ListItemText'; -import { makeStyles } from 'tss-react/mui'; -import CropDinIcon from '@mui/icons-material/CropDin'; -import { useMachine } from '@xstate/react'; -import { useEffect } from 'react'; -import { - HandleCompleteEvent, - HandleSelectionUpdatedEvent, - HandleSubscriptionResultEvent, - HideToastEvent, - SchemaValue, - SelectionDialogContext, - SelectionDialogEvent, - ShowToastEvent, - selectionDialogMachine, -} from './SelectionDialogMachine'; -import { GQLSelectionEventSubscription } from './SelectionEvent.types'; +import IconButton from '@mui/material/IconButton'; +import { useEffect, useState } from 'react'; +import { DiagramDialogComponentState } from './SelectionDialog.types'; +import { useSelectionDescription } from './useSelectionDescription'; +// import { useEffect } from 'react'; +// import { GQLSelectionEventSubscription } from './SelectionEvent.types'; -const selectionEventSubscription = gql` - subscription selectionEvent($input: SelectionEventInput!) { - selectionEvent(input: $input) { - __typename - ... on SelectionRefreshedEventPayload { - selection { - id - targetObjectId - message - objects { - id - label - iconURL - } - } - } - } - } -`; +// const selectionEventSubscription = gql` +// subscription selectionEvent($input: SelectionEventInput!) { +// selectionEvent(input: $input) { +// __typename +// ... on SelectionRefreshedEventPayload { +// selection { +// id +// targetObjectId +// message +// objects { +// id +// label +// iconURL +// } +// } +// } +// } +// } +// `; -const useSelectionObjectModalStyles = makeStyles()((_theme) => ({ - root: { - width: '100%', - position: 'relative', - overflow: 'auto', - maxHeight: 300, - }, -})); +// const useSelectionObjectModalStyles = makeStyles()((_theme) => ({ +// root: { +// width: '100%', +// position: 'relative', +// overflow: 'auto', +// maxHeight: 300, +// }, +// })); export const SELECTION_DIALOG_TYPE: string = 'selectionDialogDescription'; @@ -78,58 +65,101 @@ export const SelectionDialog = ({ onClose, onFinish, }: DiagramDialogComponentProps) => { - const { classes } = useSelectionObjectModalStyles(); - - const [{ value, context }, dispatch] = useMachine( - selectionDialogMachine - ); - const { toast, selectionDialog } = value as SchemaValue; - const { id, selection, message, selectedObjectId } = context; + // const { classes } = useSelectionObjectModalStyles(); + const initialState: DiagramDialogComponentState = { + treeDescriptionId: '', + message: '', + selectedObjects: { entries: [] }, + }; + const [state, setState] = useState(initialState); - const { error } = useSubscription(selectionEventSubscription, { - variables: { - input: { - id, - editingContextId, - selectionId: dialogDescriptionId, - targetObjectId, - }, - }, - fetchPolicy: 'no-cache', - skip: selectionDialog === 'complete', - onData: ({ data }) => { - const handleDataEvent: HandleSubscriptionResultEvent = { - type: 'HANDLE_SUBSCRIPTION_RESULT', - result: data, - }; - dispatch(handleDataEvent); - }, - onComplete: () => { - const completeEvent: HandleCompleteEvent = { type: 'HANDLE_COMPLETE' }; - dispatch(completeEvent); - }, + const { loading, selectionDescription } = useSelectionDescription({ + editingContextId, + selectionId: dialogDescriptionId, + targetObjectId, }); - useEffect(() => { - if (error) { - const { message } = error; - const showToastEvent: ShowToastEvent = { type: 'SHOW_TOAST', message }; - dispatch(showToastEvent); - } - }, [error, dispatch]); + const setDialogSelection = (selectedObjects: Selection) => { + setState((prevState) => ({ ...prevState, selectedObjects })); + }; useEffect(() => { - if (selectionDialog === 'complete') { - onClose(); + if (!loading && selectionDescription) { + setState((prevState) => ({ + ...prevState, + message: selectionDescription.message, + treeDescriptionId: selectionDescription.treeDescriptionId, + })); } - }, [selectionDialog, onClose]); + }, [loading, selectionDescription]); + // const [{ value, context }, dispatch] = useMachine( + // selectionDialogMachine + // ); + // const { toast, selectionDialog } = value as SchemaValue; + // const { id, selection, message, selectedObjectId } = context; - const handleListItemClick = (selectedObjectId: string) => { - dispatch({ type: 'HANDLE_SELECTION_UPDATED', selectedObjectId } as HandleSelectionUpdatedEvent); - }; + // const { error } = useSubscription(selectionEventSubscription, { + // variables: { + // input: { + // id, + // editingContextId, + // selectionId: dialogDescriptionId, + // targetObjectId, + // }, + // }, + // fetchPolicy: 'no-cache', + // skip: selectionDialog === 'complete', + // onData: ({ data }) => { + // const handleDataEvent: HandleSubscriptionResultEvent = { + // type: 'HANDLE_SUBSCRIPTION_RESULT', + // result: data, + // }; + // dispatch(handleDataEvent); + // }, + // onComplete: () => { + // const completeEvent: HandleCompleteEvent = { type: 'HANDLE_COMPLETE' }; + // dispatch(completeEvent); + // }, + // }); + + // useEffect(() => { + // if (error) { + // const { message } = error; + // const showToastEvent: ShowToastEvent = { type: 'SHOW_TOAST', message }; + // dispatch(showToastEvent); + // } + // }, [error, dispatch]); + // useEffect(() => { + // if (selectionDialog === 'complete') { + // onClose(); + // } + // }, [selectionDialog, onClose]); + + // const handleListItemClick = (selectedObjectId: string) => { + // dispatch({ type: 'HANDLE_SELECTION_UPDATED', selectedObjectId } as HandleSelectionUpdatedEvent); + // }; + let content: JSX.Element | null = null; + + if (state.treeDescriptionId) { + content = ( + } + /> + ); + } return ( - <> + Selection Dialog - {selection?.message} - + {state.message} + {/* {selection?.objects.map((selectionObject) => ( ))} - + */} + {content} - dispatch({ type: 'HIDE_TOAST' } as HideToastEvent)} - /> - + /> */} + + ); +}; + +const SelectionDialogTreeItemAction = ({ onExpandAll, item, isHovered }: TreeItemActionProps) => { + if (!onExpandAll || !item || !item.hasChildren || !isHovered) { + return null; + } + return ( + { + onExpandAll(item); + }}> + + ); }; diff --git a/packages/selection/frontend/sirius-components-selection/src/SelectionDialog.types.ts b/packages/selection/frontend/sirius-components-selection/src/SelectionDialog.types.ts index b833448a9a1..ab949bcf462 100644 --- a/packages/selection/frontend/sirius-components-selection/src/SelectionDialog.types.ts +++ b/packages/selection/frontend/sirius-components-selection/src/SelectionDialog.types.ts @@ -11,6 +11,8 @@ * Obeo - initial API and implementation *******************************************************************************/ +import { Selection } from '@eclipse-sirius/sirius-components-core'; + export interface SelectionDialogProps { editingContextId: string; selectionRepresentationId: string; @@ -18,3 +20,9 @@ export interface SelectionDialogProps { onClose: () => void; onFinish: (selectedObjectId: string) => void; } + +export interface DiagramDialogComponentState { + treeDescriptionId: string; + message: string; + selectedObjects: Selection; +} diff --git a/packages/selection/frontend/sirius-components-selection/src/useSelectionDescription.ts b/packages/selection/frontend/sirius-components-selection/src/useSelectionDescription.ts new file mode 100644 index 00000000000..6460939af30 --- /dev/null +++ b/packages/selection/frontend/sirius-components-selection/src/useSelectionDescription.ts @@ -0,0 +1,72 @@ +/******************************************************************************* + * Copyright (c) 2024 Obeo. + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Obeo - initial API and implementation + *******************************************************************************/ +import { gql, useQuery } from '@apollo/client'; +import { useMultiToast } from '@eclipse-sirius/sirius-components-core'; +import { useEffect } from 'react'; +import { + GetSelectionDescriptionData, + GetSelectionDescriptionVariables, + SelectionDescription, + UseSelectionDescriptionProps, + UseSelectionDescriptionValue, +} from './useSelectionDescription.types'; +const getSelectionDescription = gql` + query getSelectionDescription($editingContextId: ID!, $selectionId: ID!, $targetObjectId: ID!) { + viewer { + editingContext(editingContextId: $editingContextId) { + representation(representationId: $selectionId) { + description { + ... on SelectionDescription { + message(targetObjectId: $targetObjectId) + treeDescriptionId + } + } + } + } + } + } +`; + +export const useSelectionDescription = ({ + editingContextId, + selectionId, + targetObjectId, +}: UseSelectionDescriptionProps): UseSelectionDescriptionValue => { + const { loading, data, error } = useQuery( + getSelectionDescription, + { + variables: { + editingContextId, + selectionId, + targetObjectId, + }, + } + ); + + const { addErrorMessage } = useMultiToast(); + + useEffect(() => { + if (error) { + const { message } = error; + addErrorMessage(message); + } + }, [error]); + + const selectionDescription: SelectionDescription | undefined = + data?.viewer.editingContext.representation.description || undefined; + + return { + selectionDescription, + loading, + }; +}; diff --git a/packages/selection/frontend/sirius-components-selection/src/useSelectionDescription.types.ts b/packages/selection/frontend/sirius-components-selection/src/useSelectionDescription.types.ts new file mode 100644 index 00000000000..981c2b3699b --- /dev/null +++ b/packages/selection/frontend/sirius-components-selection/src/useSelectionDescription.types.ts @@ -0,0 +1,37 @@ +export interface UseSelectionDescriptionProps { + editingContextId: string; + selectionId: string; + targetObjectId: string; +} + +export interface UseSelectionDescriptionValue { + loading: boolean; + selectionDescription: SelectionDescription | undefined; +} + +export interface GetSelectionDescriptionVariables { + editingContextId: string; + selectionId: string; + targetObjectId: string; +} + +export interface SelectionDescription { + message: string; + treeDescriptionId: string; +} + +export interface GetSelectionDescriptionData { + viewer: GetSelectionDescriptionViewer; +} + +export interface GetSelectionDescriptionViewer { + editingContext: GetSelectionDescriptionEditingContext; +} + +export interface GetSelectionDescriptionEditingContext { + representation: GetSelectionDescriptionRepresentation; +} + +export interface GetSelectionDescriptionRepresentation { + description: SelectionDescription; +} diff --git a/packages/sirius-web/backend/sirius-web/src/test/java/org/eclipse/sirius/web/services/selection/SelectionDescriptionProvider.java b/packages/sirius-web/backend/sirius-web/src/test/java/org/eclipse/sirius/web/services/selection/SelectionDescriptionProvider.java index f801fe22477..4031e671280 100644 --- a/packages/sirius-web/backend/sirius-web/src/test/java/org/eclipse/sirius/web/services/selection/SelectionDescriptionProvider.java +++ b/packages/sirius-web/backend/sirius-web/src/test/java/org/eclipse/sirius/web/services/selection/SelectionDescriptionProvider.java @@ -21,9 +21,10 @@ import org.eclipse.sirius.components.core.api.IEditingContextProcessor; import org.eclipse.sirius.components.core.api.IIdentityService; import org.eclipse.sirius.components.core.api.ILabelService; +import org.eclipse.sirius.components.representations.Failure; import org.eclipse.sirius.components.representations.VariableManager; -import org.eclipse.sirius.components.selection.Selection; import org.eclipse.sirius.components.selection.description.SelectionDescription; +import org.eclipse.sirius.components.trees.description.TreeDescription; import org.eclipse.sirius.web.application.editingcontext.EditingContext; import org.springframework.stereotype.Service; @@ -39,6 +40,10 @@ public class SelectionDescriptionProvider implements IEditingContextProcessor { public static final String REPRESENTATION_DESCRIPTION_ID = "siriusComponents://representationDescription?kind=selectionDescription&sourceElementId=Test"; + public static final String TREE_DESCRIPTION_ID = "siriusComponents://selectionDialogTreeDescription"; + + private static final String SELECTION_PREFIX = "selection://"; + private final IIdentityService identityService; private final ILabelService labelService; @@ -60,6 +65,10 @@ private SelectionDescription getSelectionDescription() { .map(this.labelService::getLabel) .orElse(""); + Function kindProvider = variableManager -> variableManager.get(VariableManager.SELF, Object.class) + .map(this.identityService::getKind) + .orElse(""); + Function> iconURLProvider = variableManager -> variableManager.get(VariableManager.SELF, Object.class) .map(this.labelService::getImagePath) .orElse(null); @@ -74,20 +83,33 @@ private SelectionDescription getSelectionDescription() { .map(this.identityService::getId) .orElse(null); - Function selectionObjectsIdProvider = variableManager -> variableManager.get(VariableManager.SELF, Object.class) - .map(this.identityService::getId) - .orElse(null); + TreeDescription treeDescription = TreeDescription.newTreeDescription(TREE_DESCRIPTION_ID) + .canCreatePredicate(variableManager -> false) + .childrenProvider(objectsProvider) + .deletableProvider(variableManager -> false) + .deleteHandler(variableManager -> new Failure("")) + .editableProvider(variableManager -> false) + .elementsProvider(objectsProvider) + .hasChildrenProvider(variableManager -> true) + .iconURLProvider(iconURLProvider) + .idProvider(variableManager -> SELECTION_PREFIX) + .labelProvider(labelProvider) + .kindProvider(kindProvider) + .label(LABEL) + .renameHandler((variableManager, newName) -> new Failure("")) + .selectableProvider(variableManager -> true) + .targetObjectIdProvider(targetObjectIdProvider) + .treeItemIdProvider(targetObjectIdProvider) + .build(); return SelectionDescription.newSelectionDescription(REPRESENTATION_DESCRIPTION_ID) .label(LABEL) - .idProvider(variableManager -> Selection.PREFIX) + .idProvider(variableManager -> SELECTION_PREFIX) .labelProvider(labelProvider) - .iconURLProvider(iconURLProvider) .messageProvider(variableManager -> "Select the objects to consider") - .objectsProvider(objectsProvider) .targetObjectIdProvider(targetObjectIdProvider) - .selectionObjectsIdProvider(selectionObjectsIdProvider) .canCreatePredicate(variableManager -> false) + .treeDescription(treeDescription) .build(); } } diff --git a/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/ViewConverter.java b/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/ViewConverter.java index 50cb375c68b..3393bc1bcf9 100644 --- a/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/ViewConverter.java +++ b/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/ViewConverter.java @@ -18,6 +18,9 @@ import java.util.Optional; import java.util.Spliterator; import java.util.Spliterators; +import java.util.function.BiFunction; +import java.util.function.Function; +import java.util.function.Predicate; import java.util.stream.Stream; import java.util.stream.StreamSupport; @@ -27,17 +30,22 @@ import org.eclipse.emf.ecore.EObject; import org.eclipse.emf.ecore.EPackage; import org.eclipse.sirius.components.collaborative.diagrams.DiagramServices; +import org.eclipse.sirius.components.core.api.IEditingContext; import org.eclipse.sirius.components.core.api.IObjectService; +import org.eclipse.sirius.components.core.api.IURLParser; import org.eclipse.sirius.components.diagrams.Node; import org.eclipse.sirius.components.interpreter.AQLInterpreter; import org.eclipse.sirius.components.interpreter.Result; +import org.eclipse.sirius.components.representations.Failure; import org.eclipse.sirius.components.representations.IRepresentationDescription; +import org.eclipse.sirius.components.representations.IStatus; import org.eclipse.sirius.components.representations.VariableManager; -import org.eclipse.sirius.components.selection.Selection; import org.eclipse.sirius.components.selection.description.SelectionDescription; +import org.eclipse.sirius.components.trees.description.TreeDescription; import org.eclipse.sirius.components.view.RepresentationDescription; import org.eclipse.sirius.components.view.View; import org.eclipse.sirius.components.view.diagram.DiagramDescription; +import org.eclipse.sirius.components.view.diagram.SelectionDialogDescription; import org.eclipse.sirius.components.view.diagram.SelectionDialogTreeDescription; import org.eclipse.sirius.components.view.emf.diagram.IDiagramIdProvider; import org.slf4j.Logger; @@ -55,6 +63,16 @@ @Service public class ViewConverter implements IViewConverter { + private static final String TARGET_OBJECT_ID = "targetObjectId"; + + private static final String TREE_DESCRIPTION_ID = "treeDescriptionId"; + + private static final String SELECTION_PREFIX = "selection://"; + + private static final String TREE_ID = "treeId"; + + private static final String DIALOG_DESCRIPTION_TREE_REPRESENTATION_NAME = "Selection Dialog Tree Representation"; + private final Logger logger = LoggerFactory.getLogger(ViewConverter.class); private final List javaServiceProviders; @@ -67,7 +85,9 @@ public class ViewConverter implements IViewConverter { private final IDiagramIdProvider diagramIdProvider; - public ViewConverter(List javaServiceProviders, List representationDescriptionConverters, ApplicationContext applicationContext, IObjectService objectService, IDiagramIdProvider diagramIdProvider) { + private final IURLParser urlParser; + + public ViewConverter(List javaServiceProviders, List representationDescriptionConverters, ApplicationContext applicationContext, IObjectService objectService, IDiagramIdProvider diagramIdProvider, IURLParser urlParser) { this.javaServiceProviders = new ArrayList<>(); this.javaServiceProviders.addAll(Objects.requireNonNull(javaServiceProviders)); IServiceProvider nodeServiceProvider = (IReadOnlyQueryEnvironment queryEnvironment) -> ServiceUtils.getReceiverServices(null, Node.class).stream().toList(); @@ -76,6 +96,7 @@ public ViewConverter(List javaServiceProviders, List convert(List views, List } private List convertSelectionsDialogs(View view, AQLInterpreter interpreter) { - return view.getDescriptions().stream().filter(DiagramDescription.class::isInstance) - .flatMap(this::getAllContent) - .filter(org.eclipse.sirius.components.view.diagram.SelectionDialogDescription.class::isInstance) - .map(org.eclipse.sirius.components.view.diagram.SelectionDialogDescription.class::cast) - .map(selectionDescription -> this.convertSelectionDialog(selectionDescription, interpreter)) - .toList(); + List representationDescriptions = new ArrayList<>(); + view.getDescriptions().stream() + .filter(DiagramDescription.class::isInstance) + .flatMap(this::getAllContent) + .filter(org.eclipse.sirius.components.view.diagram.SelectionDialogDescription.class::isInstance) + .map(org.eclipse.sirius.components.view.diagram.SelectionDialogDescription.class::cast) + .map(selectionDescriptionView -> this.convertSelectionDialog(selectionDescriptionView, interpreter)) + .forEach(selectionDescription -> { + representationDescriptions.add(selectionDescription); + representationDescriptions.add(selectionDescription.getTreeDescription()); + }); + return representationDescriptions; } - private IRepresentationDescription convertSelectionDialog(org.eclipse.sirius.components.view.diagram.SelectionDialogDescription selectionDescription, AQLInterpreter interpreter) { + private SelectionDescription convertSelectionDialog(org.eclipse.sirius.components.view.diagram.SelectionDialogDescription selectionDescription, AQLInterpreter interpreter) { String selectionDescriptionId = this.diagramIdProvider.getId(selectionDescription); + TreeDescription treeDescription = this.createTreeDescription(selectionDescription, interpreter); return SelectionDescription.newSelectionDescription(selectionDescriptionId) - .objectsProvider(variableManager -> { - String expression = Optional.ofNullable(selectionDescription.getSelectionDialogTreeDescription()) - .map(SelectionDialogTreeDescription::getElementsExpression) - .orElse(""); - Result result = interpreter.evaluateExpression(variableManager.getVariables(), expression); - return result.asObjects().orElse(List.of()).stream() - .filter(Objects::nonNull) - .toList(); - }) .messageProvider(variableManager -> { String message = selectionDescription.getSelectionMessage(); if (message == null) { @@ -133,16 +152,148 @@ private IRepresentationDescription convertSelectionDialog(org.eclipse.sirius.com } return message; }) - .idProvider(variableManager -> Selection.PREFIX) + .idProvider(variableManager -> SELECTION_PREFIX) .labelProvider(variableManager -> variableManager.get(VariableManager.SELF, Object.class).map(this.objectService::getLabel).orElse(null)) - .iconURLProvider(variableManager -> variableManager.get(VariableManager.SELF, Object.class).map(this.objectService::getImagePath).orElse(null)) .targetObjectIdProvider(variableManager -> variableManager.get(VariableManager.SELF, Object.class).map(this.objectService::getId).orElse(null)) - .selectionObjectsIdProvider(variableManager -> variableManager.get(VariableManager.SELF, Object.class).map(this.objectService::getId).orElse(null)) .label("Selection Description") .canCreatePredicate(variableManager -> false) + .treeDescription(treeDescription) .build(); } + private TreeDescription createTreeDescription(SelectionDialogDescription selectionDescription, AQLInterpreter interpreter) { + SelectionDialogTreeDescription selectionDialogTreeDescription = selectionDescription.getSelectionDialogTreeDescription(); + final String treeDescriptionId = this.diagramIdProvider.getId(selectionDialogTreeDescription); + + Function> childrenProvider = variableManager -> { + String childrenExpression = selectionDialogTreeDescription.getChildrenExpression(); + String safeExpression = Optional.ofNullable(childrenExpression).orElse(""); + if (safeExpression.isBlank()) { + return List.of(); + } + else { + Result result = interpreter.evaluateExpression(variableManager.getVariables(), safeExpression); + return result.asObjects() + .orElse(List.of()) + .stream() + .filter(Objects::nonNull) + .toList(); + } + }; + + Function> elementsProvider = this.getElementProvider(interpreter, selectionDialogTreeDescription); + + Function hasChildrenProvider = variableManager -> { + String childrenExpression = selectionDialogTreeDescription.getChildrenExpression(); + String safeExpression = Optional.ofNullable(childrenExpression).orElse(""); + if (safeExpression.isBlank()) { + return false; + } else { + Result result = interpreter.evaluateExpression(variableManager.getVariables(), safeExpression); + return !result.asObjects().orElse(List.of()).isEmpty(); + } + }; + + Function deleteHandler = variableManager -> new Failure("Unexecutable delete handler"); + + BiFunction renameHandler = (variableManager, newValue) -> new Failure("Unexecutable rename handler"); + + Function treeItemIdProvider = variableManager -> { + return variableManager.get(VariableManager.SELF, Object.class) + .map(this.objectService::getId) + .orElse(""); + }; + + Function kindProvider = variableManager -> { + return variableManager.get(VariableManager.SELF, Object.class) + .map(this.objectService::getKind) + .orElse(""); + }; + + Function labelProvider = variableManager -> { + return variableManager.get(VariableManager.SELF, Object.class) + .map(this.objectService::getLabel) + .orElse(""); + }; + + Function targetObjectIdProvider = variableManager -> { + return this.getTargetObjectId(variableManager).orElse(""); + }; + + Function> imageURLProvider = variableManager -> { + return variableManager.get(VariableManager.SELF, Object.class) + .map(this.objectService::getImagePath) + .orElse(List.of()); + }; + + Function isSelectableProvider = variableManager -> { + String isSelectableExpression = selectionDialogTreeDescription.getIsSelectableExpression(); + String safeExpression = Optional.ofNullable(isSelectableExpression).orElse(""); + if (safeExpression.isBlank()) { + return false; + } + Result result = interpreter.evaluateExpression(variableManager.getVariables(), safeExpression); + return result.asBoolean() + .orElse(false); + }; + + Predicate canCreatePredicate = variableManager -> { + return variableManager.get(TREE_ID, String.class) + .filter(id -> id.startsWith(SELECTION_PREFIX)) + .map(this.urlParser::getParameterValues) + .map(parameters -> parameters.get(TREE_DESCRIPTION_ID).get(0)) + .filter(treeDescriptionIdParameter -> treeDescriptionId.equals(treeDescriptionIdParameter)) + .isPresent(); + }; + + return TreeDescription.newTreeDescription(treeDescriptionId) + .label(DIALOG_DESCRIPTION_TREE_REPRESENTATION_NAME) + .idProvider(variableManager -> variableManager.get(TREE_ID, String.class).orElse(null)) + .canCreatePredicate(canCreatePredicate) + .childrenProvider(childrenProvider) + .deletableProvider(variableManager -> false) + .deleteHandler(deleteHandler) + .renameHandler(renameHandler) + .editableProvider(variableManager -> false) + .elementsProvider(elementsProvider) + .hasChildrenProvider(hasChildrenProvider) + .treeItemIdProvider(treeItemIdProvider) + .kindProvider(kindProvider) + .labelProvider(labelProvider) + .targetObjectIdProvider(targetObjectIdProvider) + .iconURLProvider(imageURLProvider) + .selectableProvider(isSelectableProvider) + .build(); + } + + private Function> getElementProvider(AQLInterpreter interpreter, SelectionDialogTreeDescription selectionDialogTreeDescription) { + return variableManager -> { + Optional optionalEditingContext = variableManager.get(IEditingContext.EDITING_CONTEXT, IEditingContext.class); + if (optionalEditingContext.isPresent()) { + //Set the targetObject as the SELF value. + //The targetObjectId is provided by the frontend in the treeId. + this.getTargetObjectId(variableManager) + .flatMap(targetObjectId -> this.objectService.getObject(optionalEditingContext.get(), targetObjectId)) + .ifPresent(targetObject -> variableManager.put(VariableManager.SELF, targetObject)); + + String elementsExpression = selectionDialogTreeDescription.getElementsExpression(); + Result result = interpreter.evaluateExpression(variableManager.getVariables(), elementsExpression); + return result.asObjects() + .orElse(List.of()) + .stream() + .filter(Objects::nonNull) + .toList(); + } + return List.of(); + }; + } + + private Optional getTargetObjectId(VariableManager variableManager) { + return variableManager.get(TREE_ID, String.class) + .map(this.urlParser::getParameterValues) + .map(parameters -> parameters.get(TARGET_OBJECT_ID).get(0)); + } + private Stream getAllContent(EObject representationDescription) { return StreamSupport.stream(Spliterators.spliteratorUnknownSize(representationDescription.eAllContents(), Spliterator.ORDERED), false); } diff --git a/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/diagram/DiagramIdProvider.java b/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/diagram/DiagramIdProvider.java index ecc3211ed93..49e85eb6d9f 100644 --- a/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/diagram/DiagramIdProvider.java +++ b/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/diagram/DiagramIdProvider.java @@ -20,6 +20,7 @@ import org.eclipse.sirius.components.view.diagram.DiagramElementDescription; import org.eclipse.sirius.components.view.diagram.DialogDescription; import org.eclipse.sirius.components.view.diagram.NodeDescription; +import org.eclipse.sirius.components.view.diagram.SelectionDialogTreeDescription; import org.springframework.stereotype.Service; /** @@ -66,6 +67,17 @@ public String getId(DialogDescription dialogDescription) { return null; } + @Override + public String getId(SelectionDialogTreeDescription treeDescription) { + if (treeDescription != null) { + String sourceId = this.getSourceIdFromElementDescription(treeDescription); + String sourceElementId = this.objectService.getId(treeDescription); + return SELECTION_DIALOG_TREE_DESCRIPTION_KIND + "?" + SOURCE_KIND + "=" + VIEW_SOURCE_KIND + "&" + SOURCE_ID + "=" + sourceId + "&" + SOURCE_ELEMENT_ID + "=" + + sourceElementId; + } + return null; + } + private String getDialogDescriptionTypeName(DialogDescription dialogDescription) { String name = dialogDescription.eClass().getName(); String typeName = "siriusComponents://"; diff --git a/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/diagram/IDiagramIdProvider.java b/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/diagram/IDiagramIdProvider.java index ddfeef03f74..87a004fb9c0 100644 --- a/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/diagram/IDiagramIdProvider.java +++ b/packages/view/backend/sirius-components-view-emf/src/main/java/org/eclipse/sirius/components/view/emf/diagram/IDiagramIdProvider.java @@ -16,6 +16,7 @@ import org.eclipse.sirius.components.view.diagram.DiagramDescription; import org.eclipse.sirius.components.view.diagram.DiagramElementDescription; import org.eclipse.sirius.components.view.diagram.DialogDescription; +import org.eclipse.sirius.components.view.diagram.SelectionDialogTreeDescription; import org.eclipse.sirius.components.view.emf.IRepresentationDescriptionIdProvider; /** @@ -31,6 +32,8 @@ public interface IDiagramIdProvider extends IRepresentationDescriptionIdProvider String EDGE_DESCRIPTION_KIND = "siriusComponents://edgeDescription"; + String SELECTION_DIALOG_TREE_DESCRIPTION_KIND = "siriusComponents://selectionDialogTreeDescription"; + @Override String getId(DiagramDescription diagramDescription); @@ -38,6 +41,8 @@ public interface IDiagramIdProvider extends IRepresentationDescriptionIdProvider String getId(DialogDescription dialogDescription); + String getId(SelectionDialogTreeDescription selectionDialogTreeDescription); + /** * Implementation which does nothing, used for mocks in unit tests. * @@ -60,6 +65,11 @@ public String getId(DialogDescription dialogDescription) { return ""; } + @Override + public String getId(SelectionDialogTreeDescription selectionDialogTreeDescription) { + return ""; + } + } } diff --git a/packages/view/backend/sirius-components-view-emf/src/test/java/org/eclipse/sirius/components/view/emf/view/DynamicDiagramsTests.java b/packages/view/backend/sirius-components-view-emf/src/test/java/org/eclipse/sirius/components/view/emf/view/DynamicDiagramsTests.java index 380634761c3..c47b0364ea0 100644 --- a/packages/view/backend/sirius-components-view-emf/src/test/java/org/eclipse/sirius/components/view/emf/view/DynamicDiagramsTests.java +++ b/packages/view/backend/sirius-components-view-emf/src/test/java/org/eclipse/sirius/components/view/emf/view/DynamicDiagramsTests.java @@ -30,6 +30,7 @@ import org.eclipse.sirius.components.core.api.IFeedbackMessageService; import org.eclipse.sirius.components.core.api.IObjectService; import org.eclipse.sirius.components.core.api.IRepresentationDescriptionSearchService; +import org.eclipse.sirius.components.core.api.IURLParser; import org.eclipse.sirius.components.diagrams.Diagram; import org.eclipse.sirius.components.emf.services.JSONResourceFactory; import org.eclipse.sirius.components.emf.services.api.IEMFEditingContext; @@ -151,7 +152,7 @@ private Diagram render(DiagramDescription diagramDescription, Object target) { ViewDiagramDescriptionConverter diagramDescriptionConverter = new ViewDiagramDescriptionConverter(new IObjectService.NoOp(), new IEditService.NoOp(), List.of(), new IDiagramIdProvider.NoOp(), new IViewToolImageProvider.NoOp(), new IFeedbackMessageService.NoOp()); - var viewConverter = new ViewConverter(List.of(), List.of(diagramDescriptionConverter), new StaticApplicationContext(), new IObjectService.NoOp(), new IDiagramIdProvider.NoOp()); + var viewConverter = new ViewConverter(List.of(), List.of(diagramDescriptionConverter), new StaticApplicationContext(), new IObjectService.NoOp(), new IDiagramIdProvider.NoOp(), new IURLParser.NoOp()); List conversionResult = viewConverter.convert(List.of(view), List.of(EcorePackage.eINSTANCE)); assertThat(conversionResult).hasSize(1); assertThat(conversionResult.get(0)).isInstanceOf(org.eclipse.sirius.components.diagrams.description.DiagramDescription.class); diff --git a/packages/view/backend/sirius-components-view-emf/src/test/java/org/eclipse/sirius/components/view/emf/view/DynamicFormsTests.java b/packages/view/backend/sirius-components-view-emf/src/test/java/org/eclipse/sirius/components/view/emf/view/DynamicFormsTests.java index af9927d7cf3..a456b33ce01 100644 --- a/packages/view/backend/sirius-components-view-emf/src/test/java/org/eclipse/sirius/components/view/emf/view/DynamicFormsTests.java +++ b/packages/view/backend/sirius-components-view-emf/src/test/java/org/eclipse/sirius/components/view/emf/view/DynamicFormsTests.java @@ -33,6 +33,7 @@ import org.eclipse.sirius.components.core.api.IEditingContext; import org.eclipse.sirius.components.core.api.IFeedbackMessageService; import org.eclipse.sirius.components.core.api.IObjectService; +import org.eclipse.sirius.components.core.api.IURLParser; import org.eclipse.sirius.components.forms.AbstractFontStyle; import org.eclipse.sirius.components.forms.AbstractWidget; import org.eclipse.sirius.components.forms.Button; @@ -1365,7 +1366,7 @@ public Optional getObject(IEditingContext editingContext, String objectI }; ViewFormDescriptionConverter formDescriptionConverter = new ViewFormDescriptionConverter(objectService, editService, new IFormIdProvider.NoOp(), List.of(), new IFeedbackMessageService.NoOp()); - var viewConverter = new ViewConverter(List.of(), List.of(formDescriptionConverter), new StaticApplicationContext(), new IObjectService.NoOp(), new IDiagramIdProvider.NoOp()); + var viewConverter = new ViewConverter(List.of(), List.of(formDescriptionConverter), new StaticApplicationContext(), new IObjectService.NoOp(), new IDiagramIdProvider.NoOp(), new IURLParser.NoOp()); List conversionResult = viewConverter.convert(List.of(view), List.of(EcorePackage.eINSTANCE)); assertThat(conversionResult).hasSize(1); assertThat(conversionResult.get(0)).isInstanceOf(org.eclipse.sirius.components.forms.description.FormDescription.class);