/* * Copyright (c) 2012 Data Harmonisation Panel * * All rights reserved. This program and the accompanying materials are made * available under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the License, * or (at your option) any later version. * * You should have received a copy of the GNU Lesser General Public License * along with this distribution. If not, see <http://www.gnu.org/licenses/>. * * Contributors: * HUMBOLDT EU Integrated Project #030962 * Data Harmonisation Panel <http://www.dhpanel.eu> */ package eu.esdihumboldt.hale.ui.util.bbr.properties; import org.eclipse.swt.SWT; import org.eclipse.swt.custom.CLabel; import org.eclipse.swt.layout.FormAttachment; import org.eclipse.swt.layout.FormData; import org.eclipse.swt.widgets.Composite; import org.eclipse.swt.widgets.Text; import org.eclipse.ui.PlatformUI; import org.eclipse.ui.views.properties.tabbed.AbstractPropertySection; import org.eclipse.ui.views.properties.tabbed.ITabbedPropertyConstants; import org.eclipse.ui.views.properties.tabbed.TabbedPropertySheetPage; import eu.esdihumboldt.hale.common.schema.model.Definition; import eu.esdihumboldt.hale.ui.util.bbr.Documentation; import eu.esdihumboldt.hale.ui.util.bbr.DocumentationService; import eu.esdihumboldt.hale.ui.views.properties.definition.DefaultDefinitionSection; /** * Properties section with text from a BBR documentation. * * @author Simon Templer */ public abstract class AbstractDocumentationTextSection extends DefaultDefinitionSection<Definition<?>> { private Text descriptionText; private CLabel label; @Override public void createControls(Composite parent, TabbedPropertySheetPage aTabbedPropertySheetPage) { super.createControls(parent, aTabbedPropertySheetPage); Composite composite = getWidgetFactory().createFlatFormComposite(parent); FormData data; if (useMultilineText()) { descriptionText = getWidgetFactory().createText(composite, "", //$NON-NLS-1$ SWT.MULTI | SWT.WRAP | SWT.V_SCROLL | SWT.BORDER); } else { descriptionText = getWidgetFactory().createText(composite, "", //$NON-NLS-1$ SWT.SINGLE | SWT.BORDER); } descriptionText.setEditable(false); // TODO improve layout data = new FormData(); data.width = 100; if (useMultilineText()) { data.height = 85; } data.left = new FormAttachment(0, 100); // STANDARD_LABEL_WIDTH); data.right = new FormAttachment(100, 0); data.top = new FormAttachment(0, ITabbedPropertyConstants.VSPACE); data.bottom = new FormAttachment(100, -ITabbedPropertyConstants.VSPACE); descriptionText.setLayoutData(data); label = getWidgetFactory().createCLabel(composite, getDocumentationLabel()); // $NON-NLS-1$ data = new FormData(); data.left = new FormAttachment(0, 0); data.right = new FormAttachment(descriptionText, -ITabbedPropertyConstants.HSPACE); data.top = new FormAttachment(descriptionText, 0, SWT.TOP); label.setLayoutData(data); } /** * @see AbstractPropertySection#shouldUseExtraSpace() */ @Override public boolean shouldUseExtraSpace() { return false; } /** * States if a multi-line text field should be used. This implementation * returns <code>true</code>. Override to change behavior. * * @return if a multi-line text field should be used */ protected boolean useMultilineText() { return true; } /** * @see AbstractPropertySection#refresh() */ @Override public void refresh() { DocumentationService ds = PlatformUI.getWorkbench().getService(DocumentationService.class); Documentation doc = ds.getDocumentation(getDefinition()); String desc = (doc == null) ? (null) : (getDocumentationText(doc)); if (desc == null) { desc = ""; } descriptionText.setText(desc); } /** * Get the label text to display in the section. * * @return the label text */ protected abstract String getDocumentationLabel(); /** * Get the documentation text from a given BBR documentation. * * @param doc the documentation object * @return the text to display */ protected abstract String getDocumentationText(Documentation doc); }