/*******************************************************************************
* 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 java.util.Collection;
import org.eclipse.core.databinding.observable.value.IObservableValue;
import org.eclipse.jface.dialogs.TitleAreaDialog;
/**
* A builder for creating a UI.
*
* @author <a href="mailto:phil.kursawe@gmail.com">Philipp Kursawe</a>
*
*/
public interface Builder {
/**
* Shortcut for {@link #field(String, FieldOptions)}.
*
* @param property
* @return this builder for chaining
*/
Builder field(String property);
/**
*
* @param property
* @param fieldOptions
* @return this builder for chaining
*/
Builder field(String property, FieldOptions fieldOptions);
/**
*
* @return this builder for chaining
*/
Builder newLine();
Builder control(ControlCreator creator);
/**
*
* @param dialog
* @param target
* @return this builder for chaining
*/
Builder addDialogSupport(TitleAreaDialog dialog, IObservableValue target);
/**
* Manually refreshing the models from the targets (controls).
*
* @return this builder for chaining
*/
Builder updateModels();
/**
* Flags the following fields as read-only.
* @return this builder for chaining
*/
Builder readOnly(boolean readOnly);
Builder selection(String property, Collection<?> items);
Builder selection(String property, FieldOptions options);
}