/* * Copyright 2009 Andrew Pietsch * * Licensed under the Apache License, Version 2.0 (the "License"); you * may not use this file except in compliance with the License. You may * obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or * implied. See the License for the specific language governing permissions * and limitations under the License. */ package com.dragome.forms.bindings.client.form; import java.util.Collection; import com.dragome.forms.bindings.client.format.Format; import com.dragome.forms.bindings.client.list.ArrayListModel; import com.dragome.model.interfaces.list.ListModel; /** * Created by IntelliJ IDEA. * User: andrew * Date: Sep 5, 2009 * Time: 11:42:50 AM * To change this template use File | Settings | File Templates. */ public class FormattedListFieldBuilder<T> { private Format<T> formatter; private FormModel formModel; private Class<T> valueType; private ListFormatExceptionPolicy<T> exceptionPolicy; protected FormattedListFieldBuilder(FormModel formModel, Class<T> type, Format<T> formatter, ListFormatExceptionPolicy<T> exceptionPolicy) { this.formModel= formModel; valueType= type; this.formatter= formatter; this.exceptionPolicy= exceptionPolicy; } public FormattedListFieldModel<T> create() { return formModel.createFormattedListFieldModel(new ArrayListModel<T>(), formatter, exceptionPolicy, valueType); } public FormattedListFieldModel<T> createWithValue(Collection<T> initialValue) { return formModel.createFormattedListFieldModel(new ArrayListModel<T>(initialValue), formatter, exceptionPolicy, valueType); } public FormattedListFieldModel<T> boundTo(ListModel<T> source) { return formModel.createFormattedListFieldModel(source, formatter, exceptionPolicy, valueType); } /** * Binds the field to the specified provider using the specified key. The type * of the key is determined by the provider. I.e. a ListModelProvider<String> * will require a string key. * @param provider the ValueModelProvider to use. * @param key the key of the value (that will be passed to the provider). * @return a new field model bound to the provider using the specified key. */ public <K> FormattedListFieldModel<T> boundTo(ListModelProvider<K> provider, K key) { return boundTo(provider.getListModel(key, valueType)); } }