DocumentationPropertySection.java
/**
* Copyright (c) 2004-2025 Carnegie Mellon University and others. (see Contributors file).
* All Rights Reserved.
*
* NO WARRANTY. ALL MATERIAL IS FURNISHED ON AN "AS-IS" BASIS. CARNEGIE MELLON UNIVERSITY MAKES NO WARRANTIES OF ANY
* KIND, EITHER EXPRESSED OR IMPLIED, AS TO ANY MATTER INCLUDING, BUT NOT LIMITED TO, WARRANTY OF FITNESS FOR PURPOSE
* OR MERCHANTABILITY, EXCLUSIVITY, OR RESULTS OBTAINED FROM USE OF THE MATERIAL. CARNEGIE MELLON UNIVERSITY DOES NOT
* MAKE ANY WARRANTY OF ANY KIND WITH RESPECT TO FREEDOM FROM PATENT, TRADEMARK, OR COPYRIGHT INFRINGEMENT.
*
* This program and the accompanying materials are made available under the terms of the Eclipse Public License 2.0
* which is available at https://www.eclipse.org/legal/epl-2.0/
* SPDX-License-Identifier: EPL-2.0
*
* Created, in part, with funding and support from the United States Government. (see Acknowledgments file).
*
* This program includes and/or can make use of certain third party source code, object code, documentation and other
* files ("Third Party Software"). The Third Party Software that is used by this program is dependent upon your system
* configuration. By using this program, You agree to comply with any and all relevant Third Party Software terms and
* conditions contained in any such Third Party Software or separate license file distributed with such Third Party
* Software. The parties who own the Third Party Software ("Third Party Licensors") are intended third party benefici-
* aries to this license with respect to the terms applicable to their Third Party Software. Third Party Software li-
* censes only apply to the Third Party Software and not any other portion of this program or this program as a whole.
*/
package org.osate.ge.internal.ui.properties;
import java.util.List;
import java.util.stream.Collectors;
import org.eclipse.core.runtime.Adapters;
import org.eclipse.emf.ecore.EObject;
import org.eclipse.jface.layout.GridDataFactory;
import org.eclipse.jface.layout.GridLayoutFactory;
import org.eclipse.jface.viewers.IFilter;
import org.eclipse.jface.viewers.ISelection;
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Text;
import org.eclipse.ui.IWorkbenchPart;
import org.eclipse.ui.views.properties.tabbed.AbstractPropertySection;
import org.eclipse.ui.views.properties.tabbed.TabbedPropertySheetPage;
import org.eclipse.xtext.util.Strings;
import org.osate.ge.BusinessObjectSelection;
import org.osate.ge.internal.ui.util.InternalPropertySectionUtil;
import org.osate.ge.internal.util.EObjectDocumentationUtil;
import org.osate.ge.ui.PropertySectionUtil;
/**
* Property section which displays the documentation associated with a business object.
* @see EObjectDocumentationUtil#getPlainTextDocumentation(Object)
*/
public class DocumentationPropertySection extends AbstractPropertySection {
/**
* Filter which determines if the property section is compatible with an object.
*/
public static class Filter implements IFilter {
@Override
public boolean select(final Object toTest) {
return PropertySectionUtil.isBoCompatible(toTest,
bo -> EObjectDocumentationUtil.getDocumentationProvider(bo) != null);
}
}
private BusinessObjectSelection selectedBos;
private Text documentationField;
@Override
public boolean shouldUseExtraSpace() {
return true;
}
@Override
public void createControls(final Composite parent, final TabbedPropertySheetPage aTabbedPropertySheetPage) {
super.createControls(parent, aTabbedPropertySheetPage);
final Composite composite = getWidgetFactory().createPlainComposite(parent, SWT.NONE);
composite.setLayout(GridLayoutFactory.swtDefaults().numColumns(1).create());
documentationField = getWidgetFactory().createText(composite, "",
SWT.MULTI | SWT.WRAP | SWT.READ_ONLY | SWT.V_SCROLL);
documentationField.setEnabled(false);
documentationField.setLayoutData(
GridDataFactory.swtDefaults().align(SWT.FILL, SWT.FILL).grab(true, true).hint(100, 100).create());
InternalPropertySectionUtil.setPropertiesHelp(aTabbedPropertySheetPage.getControl());
}
@Override
public void setInput(final IWorkbenchPart part, final ISelection selection) {
super.setInput(part, selection);
selectedBos = Adapters.adapt(selection, BusinessObjectSelection.class);
}
@Override
public void refresh() {
final List<EObject> bos = selectedBos.boStream(EObject.class).collect(Collectors.toList());
final String doc = getDocumentation(bos);
documentationField.setEnabled(doc != null);
if (bos.size() > 1) {
documentationField.setText("<Multiple diagram elements are selected>");
} else {
documentationField.setText(Strings.emptyIfNull(doc));
}
}
private static String getDocumentation(final List<EObject> selectedBos) {
if (selectedBos.size() == 1) {
final EObject bo = selectedBos.get(0);
return EObjectDocumentationUtil.getPlainTextDocumentation(bo);
}
return null;
}
}