org.pushingpixels.flamingo.api.bcb.BreadcrumbBarModel Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of flamengo Show documentation
Show all versions of flamengo Show documentation
Flamingo Swing component suite
The newest version!
/*
* Copyright (c) 2003-2010 Flamingo Kirill Grouchnikov
* and Topologi.
* Contributed by Rick Jelliffe of Topologi
* in January 2006.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* o Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* o Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* o Neither the name of Flamingo Kirill Grouchnikov Topologi nor the names of
* its contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.pushingpixels.flamingo.api.bcb;
import java.util.*;
import javax.swing.event.EventListenerList;
/**
* Model for the breadcrumb bar component ({@link JBreadcrumbBar}).
*
* @param
* Type of data associated with each breadcrumb bar item.
* @author Kirill Grouchnikov
*/
public class BreadcrumbBarModel {
/**
* The list of breadcrumb items.
*/
private LinkedList> items;
/**
* Listener list.
*/
protected EventListenerList listenerList;
/**
* Indication whether the model is in cumulative mode.
*
* @see #setCumulative(boolean)
*/
protected boolean isCumulative;
/**
* Smallest index of path change since the last call to
* {@link #setCumulative(boolean)} with true
.
*/
protected int smallestCumulativeIndex;
/**
* Creates a new empty model.
*/
public BreadcrumbBarModel() {
this.items = new LinkedList>();
this.listenerList = new EventListenerList();
this.isCumulative = false;
this.smallestCumulativeIndex = -1;
}
/**
* Returns the index of the specified item.
*
* @param item
* Item.
* @return Index of the item if it is in the model or -1 if it is not.
*/
public int indexOf(BreadcrumbItem item) {
return this.items.indexOf(item);
}
/**
* Removes the last item in this model.
*/
public void removeLast() {
this.items.removeLast();
this.firePathChanged(this.items.size());
}
/**
* Resets this model, removing all the items.
*/
public void reset() {
this.items.clear();
this.firePathChanged(0);
}
/**
* Returns an unmodifiable list of the items in this model.
*
* @return Unmodifiable list of the items in this model.
*/
public List> getItems() {
return Collections.unmodifiableList(this.items);
}
/**
* Returns the number of items in this model.
*
* @return Number of items in this model.
*/
public int getItemCount() {
return this.items.size();
}
/**
* Returns the model item at the specified index.
*
* @param index
* Item index.
* @return The model item at the specified index. Will return
* null
if the index is negative or larger than the
* number of items.
*/
public BreadcrumbItem getItem(int index) {
if (index < 0)
return null;
if (index >= this.getItemCount())
return null;
return this.items.get(index);
}
/**
* Replaces the current item list with the specified list.
*
* @param items
* New contents of the model.
*/
public void replace(List> items) {
this.items.clear();
for (int i = 0; i < items.size(); i++) {
this.items.addLast(items.get(i));
}
this.firePathChanged(0);
}
/**
* Adds the specified item at the end of the path.
*
* @param item
* Item to add.
*/
public void addLast(BreadcrumbItem item) {
this.items.addLast(item);
this.firePathChanged(this.items.size() - 1);
}
/**
* Starts or ends the cumulative mode. In cumulative mode calls to
* {@link #addLast(BreadcrumbItem)}, {@link #removeLast()},
* {@link #replace(List)} and {@link #reset()} will not fire events on the
* listeners registered with
* {@link #addPathListener(BreadcrumbPathListener)}.
*
* @param isCumulative
* If true
, the model enters cumulative mode. If
* false
, the model exist cumulative mode and fires
* a path event on all registered listeners with the smallest
* index of all changes that have happened since the last time
* this method was called with true
.
*/
public void setCumulative(boolean isCumulative) {
boolean toFire = this.isCumulative && !isCumulative;
this.isCumulative = isCumulative;
if (toFire) {
this.firePathChanged(Math.max(0, this.smallestCumulativeIndex));
this.smallestCumulativeIndex = -1;
}
}
/**
* Adds the specified path listener to this model.
*
* @param l
* Path listener to add.
*/
public void addPathListener(BreadcrumbPathListener l) {
this.listenerList.add(BreadcrumbPathListener.class, l);
}
/**
* Removes the specified path listener from this model.
*
* @param l
* Path listener to remove.
*/
public void removePathListener(BreadcrumbPathListener l) {
this.listenerList.remove(BreadcrumbPathListener.class, l);
}
/**
* Fires a {@link BreadcrumbPathEvent}.
*
* @param indexOfFirstChange
* Index of the first item that has changed in the model.
*/
protected void firePathChanged(int indexOfFirstChange) {
if (this.isCumulative) {
if (this.smallestCumulativeIndex == -1)
this.smallestCumulativeIndex = indexOfFirstChange;
else
this.smallestCumulativeIndex = Math.min(
this.smallestCumulativeIndex, indexOfFirstChange);
return;
}
BreadcrumbPathEvent event = new BreadcrumbPathEvent(this,
indexOfFirstChange);
// Guaranteed to return a non-null array
Object[] listeners = this.listenerList.getListenerList();
// Process the listeners last to first, notifying
// those that are interested in this event
for (int i = listeners.length - 2; i >= 0; i -= 2) {
if (listeners[i] == BreadcrumbPathListener.class) {
((BreadcrumbPathListener) listeners[i + 1])
.breadcrumbPathEvent(event);
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy