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

bibliothek.gui.dock.action.DefaultDockActionSource Maven / Gradle / Ivy

/*
 * Bibliothek - DockingFrames
 * Library built on Java/Swing, allows the user to "drag and drop"
 * panels containing any Swing-Component the developer likes to add.
 * 
 * Copyright (C) 2007 Benjamin Sigg
 * 
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY 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 along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 * 
 * Benjamin Sigg
 * [email protected]
 * CH - Switzerland
 */

package bibliothek.gui.dock.action;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import bibliothek.gui.dock.action.actions.SeparatorAction;

/**
 * The DefaultDockActionSource is nothing more than a list of 
 * {@link DockAction DockActions} that may be changed at any time.
 * @author Benjamin Sigg
 */
public class DefaultDockActionSource extends AbstractDockActionSource {
	/** the actions used in this source*/
    private List actions = new ArrayList();
    
    /** the preferred location of this source */
    private LocationHint hint;
    

    /**
     * Default constructor, fills the list with some initial actions.
     * @param actions The actions to add
     */
    public DefaultDockActionSource( DockAction...actions ){
    	this( LocationHint.UNKNOWN, actions );
    }
    
    /**
     * Default constructor, fills the list with some initial actions.
     * @param hint the preferred location of this source
     * @param actions The actions to add
     */
    public DefaultDockActionSource( LocationHint hint, DockAction...actions ){
        for( DockAction action : actions )
            this.actions.add( action );
        
        setHint( hint );
    }
    
    public Iterator iterator(){
    	return new Iterator(){
    		private int current = -1;
    		private boolean removed = true;
    		
			public boolean hasNext(){
				return current+1 < actions.size();
			}

			public DockAction next(){
				current++;
				removed = false;
				return actions.get( current );
			}

			public void remove(){
				if( removed )
					throw new IllegalStateException( "Next not yet called or remove already called" );
				
				removed = true;
				DefaultDockActionSource.this.remove( current-- );
			}
    	};
    }
    
    /**
     * Sets the location-hint of this source.
     * @param hint the hint that tells an {@link ActionOffer} where to
     * put this source.
     */
    public void setHint( LocationHint hint ){
    	if( hint == null )
    		throw new IllegalArgumentException( "Hint must not be null" );
		this.hint = hint;
	}
    
    public LocationHint getLocationHint(){
    	return hint;
    }
    
    public int getDockActionCount() {
        return actions.size();
    }

    public DockAction getDockAction( int index ) {
        return actions.get( index );
    }
    
    /**
     * Adds a separator at position
     * @param position the location where to add the separator
     */
    public void addSeparator( int position ){
        add( position, SeparatorAction.SEPARATOR );
    }
    
    /**
     * Adds a separator at the end of this source
     */
    public void addSeparator(){
        add( SeparatorAction.SEPARATOR );
    }
    
    /**
     * Adds all given actions to the end of this source. 
     * @param action The actions to append
     */
    public void add( DockAction...action ){
        add( getDockActionCount(), action );
    }
    
    /**
     * Inserts all given actions such that the first action
     * will have the given index, the second action
     * index+1, and so on...
     * @param index The index of the first action
     * @param actions The actions to insert
     */
    public void add( int index, DockAction...actions ){
        int firstIndex = index;
        for( DockAction action : actions ){
            this.actions.add( index++, action );
        }
        fireAdded( firstIndex, index-1 );
    }
    
    @Override
    public int indexOf( DockAction action ){
        return actions.indexOf( action );
    }
    
    /**
     * Removes the given action from this source.
     * @param action The action to remove
     */
    public void remove( DockAction action ){
        int index = indexOf( action );
        if( index >= 0 )
            remove( index );
    }
    
    /**
     * Removes the action at index from this source. 
     * @param index The index of the action to remove
     */
    public void remove( int index ){
        remove( index, 1 );
    }
    
    /**
     * Removes all actions stored in this source.
     */
    public void removeAll(){
    	remove( 0, getDockActionCount() );
    }
    
    /**
     * Removes all actions between index (incl.)
     * and index+length (excl.).
     * @param index The index of the first action to remove
     * @param length The number of actions to remove
     * @throws IllegalArgumentException If some actions should be removed that
     * do not exist
     */
    public void remove( int index, int length ){
        if( index < 0 )
            throw new IllegalArgumentException( "Index must not be negative" );
        
        if( length < 0 )
            throw new IllegalArgumentException( "Length must not be negative" );
        
        if( index + length > getDockActionCount() )
            throw new IllegalArgumentException( "index + length too great" );
        
        if( length > 0 ){
            for( int i = length-1; i>=0; i-- )
                actions.remove( index + i );
            
            fireRemoved( index, index+length-1 );
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy