/******************************************************************************* * Copyright (c) 2010 Philipp Kursawe. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Philipp Kursawe (phil.kursawe@gmail.com) - initial API and implementation ******************************************************************************/ package eclipseutils.jface.databinding; import org.eclipse.jface.layout.GridDataFactory; import org.eclipse.jface.layout.GridLayoutFactory; import org.eclipse.swt.SWT; import org.eclipse.swt.widgets.Composite; import org.eclipse.swt.widgets.Control; import org.eclipse.swt.widgets.Label; /** * Builds a Bean Editing/Viewing UI using the GridLayout with 2 columns. * * @author <a href="mailto:phil.kursawe@gmail.com">Philipp Kursawe</a> * */ public class GridLayoutBuilder extends AbstractBuilder { /** * @param toolkit * @param parent * @param bean * @param targetToModelPolicy */ public GridLayoutBuilder(final ControlToolkit toolkit, final Composite parent, final Object bean, final int targetToModelPolicy) { super(toolkit, parent, bean, targetToModelPolicy); GridLayoutFactory.swtDefaults().numColumns(2).applyTo(parent); } /** * @param parent * @param bean * @param targetToModelPolicy */ public GridLayoutBuilder(final Composite parent, final Object bean, final int targetToModelPolicy) { this(SWTControlToolkit.getInstance(), parent, bean, targetToModelPolicy); } @Override protected void applyLayout(final Label label, final Control control) { if (label != null) { GridDataFactory.swtDefaults().align(SWT.RIGHT, SWT.CENTER).applyTo( label); GridDataFactory.fillDefaults().grab(true, false).applyTo(control); } else { GridDataFactory.fillDefaults().grab(true, false).span(2, 1) .applyTo(control); } } }