All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jboss.ballroom.client.widgets.forms.ListEditorFormItem Maven / Gradle / Ivy

Go to download

Bundles the core AS7 console as a GWT module. Includes minor customizations to support extensions.

There is a newer version: 0.7.0.Final
Show newest version
/* 
 * JBoss, Home of Professional Open Source 
 * Copyright 2011 Red Hat Inc. and/or its affiliates and other contributors
 * as indicated by the @author tags. All rights reserved. 
 * See the copyright.txt in the distribution for a 
 * full listing of individual contributors.
 *
 * This copyrighted material is made available to anyone wishing to use, 
 * modify, copy, or redistribute it subject to the terms and conditions 
 * of the GNU Lesser General Public License, v. 2.1. 
 * This program is distributed in the hope that it will be useful, but WITHOUT A 
 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A 
 * PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more details. 
 * You should have received a copy of the GNU Lesser General Public License, 
 * v.2.1 along with this distribution; if not, write to the Free Software 
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, 
 * MA  02110-1301, USA.
 */
package org.jboss.ballroom.client.widgets.forms;

import com.google.gwt.user.client.ui.Widget;
import org.jboss.as.console.client.Console;
import org.jboss.ballroom.client.widgets.window.DefaultWindow;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
 * FormItem that wraps a ListEditor table.
 * 
 * @author Stan Silvert [email protected] (C) 2011 Red Hat Inc.
 */
public class ListEditorFormItem extends FormItem> implements ListManagement {

    protected ListEditor listEditor;
    protected List value = Collections.EMPTY_LIST;
    
    protected DefaultWindow addItemDialog;
    protected String addDialogTitle = Console.CONSTANTS.common_label_addItem();
    
    protected NewListItemWizard newListItemWizard;
    protected List availableChoices = Collections.EMPTY_LIST;
    
    protected boolean limitChoices;
    
    /**
     * Create a new ListEditorFormItem.
     * 
     * @param name The name of the FormItem.
     * @param title The label that will be displayed with the editor.
     * @param title The title shown when the Add button is pressed.
     * @param rows The max number of rows in the PropertyEditor.
     * @param limitChoices If true choices for new items will be limited to values provided
     *                     in the setAvailableChoices() method.  If false the user may add any String value
     *                     to the list.
     */
    public ListEditorFormItem(String name, String title, int rows, boolean limitChoices) {
        super(name, title);
        this.limitChoices = limitChoices;
        this.listEditor = new ListEditor(this, rows);
        this.newListItemWizard = new NewListItemWizard(this, limitChoices);
    }
    
    public void setValueColumnHeader(String headerLabel) {
        this.listEditor.setValueColumnHeader(headerLabel);
        this.newListItemWizard.setLabel(headerLabel);
        this.addDialogTitle = Console.CONSTANTS.common_label_add() + " " + headerLabel;
    }
    
    /**
     * This is the full list of available choices.  The list may be
     */
    public void setAvailableChoices(List availableChoices) {
        this.availableChoices = availableChoices;
    }
    
    @Override
    public Widget asWidget() {
        return this.listEditor.asWidget();
    }

    @Override
    public void clearValue() {
        // do nothing
    }

    @Override
    public void setEnabled(boolean isEnabled) {
        this.listEditor.setEnabled(isEnabled);
    }

    @Override
    public boolean validate(List value) {
        return true;
    }

    @Override
    public List getValue() {
        return this.value;
    }

    @Override
    public void setValue(List items) {
        // clone the item so that you can cancel the edit
        List itemsClone = new ArrayList(items.size());
        itemsClone.addAll(items);

        this.value = itemsClone;
        this.listEditor.setList(itemsClone);
    }

    @Override
    public void closeNewItemDialoge() {
        addItemDialog.hide();
    }

    @Override
    public void launchNewItemDialoge() {
        addItemDialog = new DefaultWindow(addDialogTitle);
        addItemDialog.setWidth(320);
        addItemDialog.setHeight(240);
        addItemDialog.setWidget(newListItemWizard.asWidget());
        addItemDialog.setGlassEnabled(true);
        addItemDialog.center();
        
        if (!limitChoices) return;
        
        // create list containing only choices not yet in the list
        List choicesSubset = new ArrayList(this.availableChoices.size());
        choicesSubset.addAll(this.availableChoices);
        choicesSubset.removeAll(value);
        newListItemWizard.setChoices(choicesSubset);
    }
    
    @Override
    public void onCreateItem(String item) {
        this.value.add(item);
        this.listEditor.setList(value);
        setModified(true);
        closeNewItemDialoge();
    }

    @Override
    public void onDeleteItem(String item) {
        this.value.remove(item);
        this.listEditor.setList(value);
        setModified(true);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy