blob: f382c1742edb7a2c076f5c462a90762f8eb71078 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2018, 2020 Dirk Fauth.
*
* This program and the accompanying materials are made
* available under the terms of the Eclipse Public License 2.0
* which is available at https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Dirk Fauth <dirk.fauth@googlemail.com> - initial API and implementation
******************************************************************************/
package org.eclipse.nebula.widgets.nattable.layer.event;
import java.util.HashMap;
import java.util.Map;
import org.eclipse.nebula.widgets.nattable.coordinate.PositionUtil;
import org.eclipse.nebula.widgets.nattable.layer.ILayer;
/**
* Extension of the {@link RowDeleteEvent} that additionally carries the deleted
* objects per index. Used for example in combination with the DataChangeLayer
* to be able to revert a delete operation.
*
* @since 1.6
*/
public class RowObjectDeleteEvent extends RowDeleteEvent {
private Map<Integer, Object> deletedObjects = new HashMap<>();
/**
* Creates a {@link RowObjectDeleteEvent} for one deleted row object.
*
* @param layer
* The layer to which the row index is matching.
* @param rowIndex
* The index of the row that was deleted.
* @param deletedObject
* The deleted row object.
*/
public RowObjectDeleteEvent(ILayer layer, int rowIndex, Object deletedObject) {
super(layer, rowIndex);
this.deletedObjects.put(rowIndex, deletedObject);
}
/**
* Creates a {@link RowObjectDeleteEvent} for multiple deleted row objects.
*
* @param layer
* The layer to which the row indexes are matching.
* @param deletedObjects
* The mapping from index to object of the deleted rows.
*/
public RowObjectDeleteEvent(ILayer layer, Map<Integer, ?> deletedObjects) {
super(layer, PositionUtil.getRanges(deletedObjects.keySet()));
this.deletedObjects.putAll(deletedObjects);
}
/**
* Clone constructor.
*
* @param event
* The event to clone.
*/
protected RowObjectDeleteEvent(RowObjectDeleteEvent event) {
super(event);
this.deletedObjects.putAll(event.deletedObjects);
}
/**
*
* @return The deleted rows mapped from row index to object.
*/
public Map<Integer, Object> getDeletedObjects() {
return this.deletedObjects;
}
@Override
public RowObjectDeleteEvent cloneEvent() {
return new RowObjectDeleteEvent(this);
}
}